{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "1d7-I0cBKNZY",
        "outputId": "776b228a-e101-4450-d736-36e72025a84e"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Cloning into 'DomainBed'...\n",
            "remote: Enumerating objects: 1336, done.\u001b[K\n",
            "remote: Counting objects: 100% (72/72), done.\u001b[K\n",
            "remote: Compressing objects: 100% (36/36), done.\u001b[K\n",
            "remote: Total 1336 (delta 42), reused 56 (delta 36), pack-reused 1264\u001b[K\n",
            "Receiving objects: 100% (1336/1336), 1.10 MiB | 3.36 MiB/s, done.\n",
            "Resolving deltas: 100% (782/782), done.\n"
          ]
        }
      ],
      "source": [
        "!git clone https://github.com/facebookresearch/DomainBed.git"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "veQzAnpqNPgq",
        "outputId": "1a8d6388-66ee-40a5-8c21-52c4588c7d4b"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "/content/DomainBed\n"
          ]
        }
      ],
      "source": [
        "cd /content/DomainBed"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "dREUNYAlNRXv",
        "outputId": "8e1dab89-3aff-4a8c-a050-814174cbf572"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Collecting torch==1.12.1 (from -r /content/DomainBed/domainbed/requirements.txt (line 1))\n",
            "  Downloading torch-1.12.1-cp310-cp310-manylinux1_x86_64.whl.metadata (22 kB)\n",
            "Collecting torchvision==0.13.1 (from -r /content/DomainBed/domainbed/requirements.txt (line 2))\n",
            "  Downloading torchvision-0.13.1-cp310-cp310-manylinux1_x86_64.whl.metadata (10 kB)\n",
            "Collecting backpack-for-pytorch==1.3.0 (from -r /content/DomainBed/domainbed/requirements.txt (line 3))\n",
            "  Downloading backpack_for_pytorch-1.3.0-py3-none-any.whl.metadata (4.3 kB)\n",
            "Collecting numpy==1.22.4 (from -r /content/DomainBed/domainbed/requirements.txt (line 4))\n",
            "  Downloading numpy-1.22.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (2.0 kB)\n",
            "Collecting wilds==2.0.0 (from -r /content/DomainBed/domainbed/requirements.txt (line 5))\n",
            "  Downloading wilds-2.0.0-py3-none-any.whl.metadata (22 kB)\n",
            "Requirement already satisfied: tqdm==4.66.4 in /usr/local/lib/python3.10/dist-packages (from -r /content/DomainBed/domainbed/requirements.txt (line 6)) (4.66.4)\n",
            "Collecting imageio==2.9.0 (from -r /content/DomainBed/domainbed/requirements.txt (line 7))\n",
            "  Downloading imageio-2.9.0-py3-none-any.whl.metadata (2.6 kB)\n",
            "Collecting gdown==3.13.0 (from -r /content/DomainBed/domainbed/requirements.txt (line 8))\n",
            "  Downloading gdown-3.13.0.tar.gz (9.3 kB)\n",
            "  Installing build dependencies ... \u001b[?25l\u001b[?25hdone\n",
            "  Getting requirements to build wheel ... \u001b[?25l\u001b[?25hdone\n",
            "  Preparing metadata (pyproject.toml) ... \u001b[?25l\u001b[?25hdone\n",
            "Collecting parameterized==0.9.0 (from -r /content/DomainBed/domainbed/requirements.txt (line 9))\n",
            "  Downloading parameterized-0.9.0-py2.py3-none-any.whl.metadata (18 kB)\n",
            "Collecting Pillow==10.3.0 (from -r /content/DomainBed/domainbed/requirements.txt (line 10))\n",
            "  Downloading pillow-10.3.0-cp310-cp310-manylinux_2_28_x86_64.whl.metadata (9.2 kB)\n",
            "Collecting timm==0.9.16 (from -r /content/DomainBed/domainbed/requirements.txt (line 11))\n",
            "  Downloading timm-0.9.16-py3-none-any.whl.metadata (38 kB)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.10/dist-packages (from torch==1.12.1->-r /content/DomainBed/domainbed/requirements.txt (line 1)) (4.12.2)\n",
            "Requirement already satisfied: requests in /usr/local/lib/python3.10/dist-packages (from torchvision==0.13.1->-r /content/DomainBed/domainbed/requirements.txt (line 2)) (2.31.0)\n",
            "Collecting einops<1.0.0,>=0.3.0 (from backpack-for-pytorch==1.3.0->-r /content/DomainBed/domainbed/requirements.txt (line 3))\n",
            "  Downloading einops-0.8.0-py3-none-any.whl.metadata (12 kB)\n",
            "Collecting ogb>=1.2.6 (from wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5))\n",
            "  Downloading ogb-1.3.6-py3-none-any.whl.metadata (6.2 kB)\n",
            "Collecting outdated>=0.2.0 (from wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5))\n",
            "  Downloading outdated-0.2.2-py2.py3-none-any.whl.metadata (4.7 kB)\n",
            "Requirement already satisfied: pandas>=1.1.0 in /usr/local/lib/python3.10/dist-packages (from wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (2.1.4)\n",
            "Requirement already satisfied: pytz>=2020.4 in /usr/local/lib/python3.10/dist-packages (from wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (2024.1)\n",
            "Requirement already satisfied: scikit-learn>=0.20.0 in /usr/local/lib/python3.10/dist-packages (from wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (1.3.2)\n",
            "Requirement already satisfied: scipy>=1.5.4 in /usr/local/lib/python3.10/dist-packages (from wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (1.13.1)\n",
            "Requirement already satisfied: filelock in /usr/local/lib/python3.10/dist-packages (from gdown==3.13.0->-r /content/DomainBed/domainbed/requirements.txt (line 8)) (3.15.4)\n",
            "Requirement already satisfied: six in /usr/local/lib/python3.10/dist-packages (from gdown==3.13.0->-r /content/DomainBed/domainbed/requirements.txt (line 8)) (1.16.0)\n",
            "Requirement already satisfied: pyyaml in /usr/local/lib/python3.10/dist-packages (from timm==0.9.16->-r /content/DomainBed/domainbed/requirements.txt (line 11)) (6.0.1)\n",
            "Requirement already satisfied: huggingface_hub in /usr/local/lib/python3.10/dist-packages (from timm==0.9.16->-r /content/DomainBed/domainbed/requirements.txt (line 11)) (0.23.5)\n",
            "Requirement already satisfied: safetensors in /usr/local/lib/python3.10/dist-packages (from timm==0.9.16->-r /content/DomainBed/domainbed/requirements.txt (line 11)) (0.4.3)\n",
            "Requirement already satisfied: urllib3>=1.24.0 in /usr/local/lib/python3.10/dist-packages (from ogb>=1.2.6->wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (2.0.7)\n",
            "Requirement already satisfied: setuptools>=44 in /usr/local/lib/python3.10/dist-packages (from outdated>=0.2.0->wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (71.0.4)\n",
            "Collecting littleutils (from outdated>=0.2.0->wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5))\n",
            "  Downloading littleutils-0.2.4-py3-none-any.whl.metadata (679 bytes)\n",
            "Requirement already satisfied: python-dateutil>=2.8.2 in /usr/local/lib/python3.10/dist-packages (from pandas>=1.1.0->wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (2.8.2)\n",
            "Requirement already satisfied: tzdata>=2022.1 in /usr/local/lib/python3.10/dist-packages (from pandas>=1.1.0->wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (2024.1)\n",
            "Requirement already satisfied: charset-normalizer<4,>=2 in /usr/local/lib/python3.10/dist-packages (from requests->torchvision==0.13.1->-r /content/DomainBed/domainbed/requirements.txt (line 2)) (3.3.2)\n",
            "Requirement already satisfied: idna<4,>=2.5 in /usr/local/lib/python3.10/dist-packages (from requests->torchvision==0.13.1->-r /content/DomainBed/domainbed/requirements.txt (line 2)) (3.7)\n",
            "Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.10/dist-packages (from requests->torchvision==0.13.1->-r /content/DomainBed/domainbed/requirements.txt (line 2)) (2024.7.4)\n",
            "Requirement already satisfied: PySocks!=1.5.7,>=1.5.6 in /usr/local/lib/python3.10/dist-packages (from requests[socks]>=2.12.0->gdown==3.13.0->-r /content/DomainBed/domainbed/requirements.txt (line 8)) (1.7.1)\n",
            "Requirement already satisfied: joblib>=1.1.1 in /usr/local/lib/python3.10/dist-packages (from scikit-learn>=0.20.0->wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (1.4.2)\n",
            "Requirement already satisfied: threadpoolctl>=2.0.0 in /usr/local/lib/python3.10/dist-packages (from scikit-learn>=0.20.0->wilds==2.0.0->-r /content/DomainBed/domainbed/requirements.txt (line 5)) (3.5.0)\n",
            "Requirement already satisfied: fsspec>=2023.5.0 in /usr/local/lib/python3.10/dist-packages (from huggingface_hub->timm==0.9.16->-r /content/DomainBed/domainbed/requirements.txt (line 11)) (2024.6.1)\n",
            "Requirement already satisfied: packaging>=20.9 in /usr/local/lib/python3.10/dist-packages (from huggingface_hub->timm==0.9.16->-r /content/DomainBed/domainbed/requirements.txt (line 11)) (24.1)\n",
            "Downloading torch-1.12.1-cp310-cp310-manylinux1_x86_64.whl (776.3 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m776.3/776.3 MB\u001b[0m \u001b[31m1.4 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading torchvision-0.13.1-cp310-cp310-manylinux1_x86_64.whl (19.1 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m19.1/19.1 MB\u001b[0m \u001b[31m98.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading backpack_for_pytorch-1.3.0-py3-none-any.whl (119 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m119.8/119.8 kB\u001b[0m \u001b[31m12.3 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading numpy-1.22.4-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.8 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m16.8/16.8 MB\u001b[0m \u001b[31m100.3 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading wilds-2.0.0-py3-none-any.whl (126 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m126.2/126.2 kB\u001b[0m \u001b[31m13.1 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading imageio-2.9.0-py3-none-any.whl (3.3 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m3.3/3.3 MB\u001b[0m \u001b[31m100.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading parameterized-0.9.0-py2.py3-none-any.whl (20 kB)\n",
            "Downloading pillow-10.3.0-cp310-cp310-manylinux_2_28_x86_64.whl (4.5 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m4.5/4.5 MB\u001b[0m \u001b[31m101.1 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading timm-0.9.16-py3-none-any.whl (2.2 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m2.2/2.2 MB\u001b[0m \u001b[31m87.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading einops-0.8.0-py3-none-any.whl (43 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m43.2/43.2 kB\u001b[0m \u001b[31m3.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading ogb-1.3.6-py3-none-any.whl (78 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m78.8/78.8 kB\u001b[0m \u001b[31m7.8 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading outdated-0.2.2-py2.py3-none-any.whl (7.5 kB)\n",
            "Downloading littleutils-0.2.4-py3-none-any.whl (8.1 kB)\n",
            "Building wheels for collected packages: gdown\n",
            "  Building wheel for gdown (pyproject.toml) ... \u001b[?25l\u001b[?25hdone\n",
            "  Created wheel for gdown: filename=gdown-3.13.0-py3-none-any.whl size=9014 sha256=0fc5100a10bc3814b4b7d8d37e0148a440181523f18f3f5c77fbde4e2dd16fee\n",
            "  Stored in directory: /root/.cache/pip/wheels/53/6c/7a/fe047b3f05373c27cd684f43c0a48c3bdb5317e98732e5a415\n",
            "Successfully built gdown\n",
            "Installing collected packages: torch, Pillow, parameterized, numpy, littleutils, einops, torchvision, outdated, imageio, timm, gdown, backpack-for-pytorch, ogb, wilds\n",
            "  Attempting uninstall: torch\n",
            "    Found existing installation: torch 2.3.1+cu121\n",
            "    Uninstalling torch-2.3.1+cu121:\n",
            "      Successfully uninstalled torch-2.3.1+cu121\n",
            "  Attempting uninstall: Pillow\n",
            "    Found existing installation: Pillow 9.4.0\n",
            "    Uninstalling Pillow-9.4.0:\n",
            "      Successfully uninstalled Pillow-9.4.0\n",
            "  Attempting uninstall: numpy\n",
            "    Found existing installation: numpy 1.26.4\n",
            "    Uninstalling numpy-1.26.4:\n",
            "      Successfully uninstalled numpy-1.26.4\n",
            "  Attempting uninstall: torchvision\n",
            "    Found existing installation: torchvision 0.18.1+cu121\n",
            "    Uninstalling torchvision-0.18.1+cu121:\n",
            "      Successfully uninstalled torchvision-0.18.1+cu121\n",
            "  Attempting uninstall: imageio\n",
            "    Found existing installation: imageio 2.34.2\n",
            "    Uninstalling imageio-2.34.2:\n",
            "      Successfully uninstalled imageio-2.34.2\n",
            "  Attempting uninstall: gdown\n",
            "    Found existing installation: gdown 5.1.0\n",
            "    Uninstalling gdown-5.1.0:\n",
            "      Successfully uninstalled gdown-5.1.0\n",
            "\u001b[31mERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts.\n",
            "xgboost 2.1.0 requires nvidia-nccl-cu12; platform_system == \"Linux\" and platform_machine != \"aarch64\", which is not installed.\n",
            "albucore 0.0.12 requires numpy<2,>=1.24.4, but you have numpy 1.22.4 which is incompatible.\n",
            "albumentations 1.4.12 requires numpy>=1.24.4, but you have numpy 1.22.4 which is incompatible.\n",
            "arviz 0.18.0 requires numpy<2.0,>=1.23.0, but you have numpy 1.22.4 which is incompatible.\n",
            "astropy 6.1.2 requires numpy>=1.23, but you have numpy 1.22.4 which is incompatible.\n",
            "chex 0.1.86 requires numpy>=1.24.1, but you have numpy 1.22.4 which is incompatible.\n",
            "cudf-cu12 24.4.1 requires numpy<2.0a0,>=1.23, but you have numpy 1.22.4 which is incompatible.\n",
            "numexpr 2.10.1 requires numpy>=1.23.0, but you have numpy 1.22.4 which is incompatible.\n",
            "pandas-stubs 2.1.4.231227 requires numpy>=1.26.0; python_version < \"3.13\", but you have numpy 1.22.4 which is incompatible.\n",
            "plotnine 0.12.4 requires numpy>=1.23.0, but you have numpy 1.22.4 which is incompatible.\n",
            "rmm-cu12 24.4.0 requires numpy<2.0a0,>=1.23, but you have numpy 1.22.4 which is incompatible.\n",
            "scikit-image 0.23.2 requires imageio>=2.33, but you have imageio 2.9.0 which is incompatible.\n",
            "scikit-image 0.23.2 requires numpy>=1.23, but you have numpy 1.22.4 which is incompatible.\n",
            "tensorflow 2.17.0 requires numpy<2.0.0,>=1.23.5; python_version <= \"3.11\", but you have numpy 1.22.4 which is incompatible.\n",
            "torchaudio 2.3.1+cu121 requires torch==2.3.1, but you have torch 1.12.1 which is incompatible.\n",
            "torchtext 0.18.0 requires torch>=2.3.0, but you have torch 1.12.1 which is incompatible.\n",
            "xarray 2024.6.0 requires numpy>=1.23, but you have numpy 1.22.4 which is incompatible.\u001b[0m\u001b[31m\n",
            "\u001b[0mSuccessfully installed Pillow-10.3.0 backpack-for-pytorch-1.3.0 einops-0.8.0 gdown-3.13.0 imageio-2.9.0 littleutils-0.2.4 numpy-1.22.4 ogb-1.3.6 outdated-0.2.2 parameterized-0.9.0 timm-0.9.16 torch-1.12.1 torchvision-0.13.1 wilds-2.0.0\n"
          ]
        },
        {
          "data": {
            "application/vnd.colab-display-data+json": {
              "id": "ec75b57d1e8c4ed3880e85c7c11ab445",
              "pip_warning": {
                "packages": [
                  "PIL",
                  "numpy"
                ]
              }
            }
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "!pip install -r /content/DomainBed/domainbed/requirements.txt"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "tI1Uq7LQNzKk",
        "outputId": "19a7ec2f-6638-443c-9f55-c924b1b91a16"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Found existing installation: torch 1.12.1\n",
            "Uninstalling torch-1.12.1:\n",
            "  Would remove:\n",
            "    /usr/local/bin/convert-caffe2-to-onnx\n",
            "    /usr/local/bin/convert-onnx-to-caffe2\n",
            "    /usr/local/bin/torchrun\n",
            "    /usr/local/lib/python3.10/dist-packages/caffe2/*\n",
            "    /usr/local/lib/python3.10/dist-packages/torch-1.12.1.dist-info/*\n",
            "    /usr/local/lib/python3.10/dist-packages/torch/*\n",
            "    /usr/local/lib/python3.10/dist-packages/torchgen/*\n",
            "Proceed (Y/n)? Y\n",
            "  Successfully uninstalled torch-1.12.1\n",
            "Found existing installation: torchvision 0.13.1\n",
            "Uninstalling torchvision-0.13.1:\n",
            "  Would remove:\n",
            "    /usr/local/lib/python3.10/dist-packages/torchvision-0.13.1.dist-info/*\n",
            "    /usr/local/lib/python3.10/dist-packages/torchvision.libs/libcudart.d9bbffd7.so.10.2\n",
            "    /usr/local/lib/python3.10/dist-packages/torchvision.libs/libjpeg.ceea7512.so.62\n",
            "    /usr/local/lib/python3.10/dist-packages/torchvision.libs/libnvjpeg.23816019.so.10\n",
            "    /usr/local/lib/python3.10/dist-packages/torchvision.libs/libpng16.7f72a3c5.so.16\n",
            "    /usr/local/lib/python3.10/dist-packages/torchvision.libs/libz.1328edc3.so.1\n",
            "    /usr/local/lib/python3.10/dist-packages/torchvision/*\n",
            "Proceed (Y/n)? Y\n",
            "  Successfully uninstalled torchvision-0.13.1\n",
            "Found existing installation: torchaudio 2.3.1+cu121\n",
            "Uninstalling torchaudio-2.3.1+cu121:\n",
            "  Would remove:\n",
            "    /usr/local/lib/python3.10/dist-packages/torchaudio-2.3.1+cu121.dist-info/*\n",
            "    /usr/local/lib/python3.10/dist-packages/torchaudio/*\n",
            "    /usr/local/lib/python3.10/dist-packages/torio/*\n",
            "Proceed (Y/n)? Y\n",
            "Y\n",
            "  Successfully uninstalled torchaudio-2.3.1+cu121\n"
          ]
        }
      ],
      "source": [
        "!pip uninstall torch torchvision torchaudio"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 6,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Zop9Tz48N3pw",
        "outputId": "4e21efa4-5aa8-4ebd-95a5-6cb7c9d77e91"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Looking in indexes: https://pypi.org/simple, https://download.pytorch.org/whl/cu118\n",
            "Collecting torch\n",
            "  Downloading https://download.pytorch.org/whl/cu118/torch-2.4.0%2Bcu118-cp310-cp310-linux_x86_64.whl (857.7 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m857.7/857.7 MB\u001b[0m \u001b[31m1.6 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting torchvision\n",
            "  Downloading https://download.pytorch.org/whl/cu118/torchvision-0.19.0%2Bcu118-cp310-cp310-linux_x86_64.whl (6.3 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m6.3/6.3 MB\u001b[0m \u001b[31m102.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting torchaudio\n",
            "  Downloading https://download.pytorch.org/whl/cu118/torchaudio-2.4.0%2Bcu118-cp310-cp310-linux_x86_64.whl (3.3 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m3.3/3.3 MB\u001b[0m \u001b[31m91.3 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hRequirement already satisfied: filelock in /usr/local/lib/python3.10/dist-packages (from torch) (3.15.4)\n",
            "Requirement already satisfied: typing-extensions>=4.8.0 in /usr/local/lib/python3.10/dist-packages (from torch) (4.12.2)\n",
            "Requirement already satisfied: sympy in /usr/local/lib/python3.10/dist-packages (from torch) (1.13.1)\n",
            "Requirement already satisfied: networkx in /usr/local/lib/python3.10/dist-packages (from torch) (3.3)\n",
            "Requirement already satisfied: jinja2 in /usr/local/lib/python3.10/dist-packages (from torch) (3.1.4)\n",
            "Requirement already satisfied: fsspec in /usr/local/lib/python3.10/dist-packages (from torch) (2024.6.1)\n",
            "Collecting nvidia-cuda-nvrtc-cu11==11.8.89 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_cuda_nvrtc_cu11-11.8.89-py3-none-manylinux1_x86_64.whl (23.2 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m23.2/23.2 MB\u001b[0m \u001b[31m84.7 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-cuda-runtime-cu11==11.8.89 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_cuda_runtime_cu11-11.8.89-py3-none-manylinux1_x86_64.whl (875 kB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m875.6/875.6 kB\u001b[0m \u001b[31m54.6 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-cuda-cupti-cu11==11.8.87 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_cuda_cupti_cu11-11.8.87-py3-none-manylinux1_x86_64.whl (13.1 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m13.1/13.1 MB\u001b[0m \u001b[31m101.4 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-cudnn-cu11==9.1.0.70 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_cudnn_cu11-9.1.0.70-py3-none-manylinux2014_x86_64.whl (663.9 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m663.9/663.9 MB\u001b[0m \u001b[31m1.6 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-cublas-cu11==11.11.3.6 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_cublas_cu11-11.11.3.6-py3-none-manylinux1_x86_64.whl (417.9 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m417.9/417.9 MB\u001b[0m \u001b[31m2.4 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-cufft-cu11==10.9.0.58 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_cufft_cu11-10.9.0.58-py3-none-manylinux1_x86_64.whl (168.4 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m168.4/168.4 MB\u001b[0m \u001b[31m8.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-curand-cu11==10.3.0.86 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_curand_cu11-10.3.0.86-py3-none-manylinux1_x86_64.whl (58.1 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m58.1/58.1 MB\u001b[0m \u001b[31m38.4 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-cusolver-cu11==11.4.1.48 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_cusolver_cu11-11.4.1.48-py3-none-manylinux1_x86_64.whl (128.2 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m128.2/128.2 MB\u001b[0m \u001b[31m18.6 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-cusparse-cu11==11.7.5.86 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_cusparse_cu11-11.7.5.86-py3-none-manylinux1_x86_64.whl (204.1 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m204.1/204.1 MB\u001b[0m \u001b[31m8.0 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-nccl-cu11==2.20.5 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_nccl_cu11-2.20.5-py3-none-manylinux2014_x86_64.whl (142.9 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m142.9/142.9 MB\u001b[0m \u001b[31m16.1 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting nvidia-nvtx-cu11==11.8.86 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/cu118/nvidia_nvtx_cu11-11.8.86-py3-none-manylinux1_x86_64.whl (99 kB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m99.1/99.1 kB\u001b[0m \u001b[31m197.5 kB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hCollecting triton==3.0.0 (from torch)\n",
            "  Downloading https://download.pytorch.org/whl/triton-3.0.0-1-cp310-cp310-manylinux2014_x86_64.manylinux_2_17_x86_64.whl (209.4 MB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m209.4/209.4 MB\u001b[0m \u001b[31m4.0 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hRequirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from torchvision) (1.22.4)\n",
            "Requirement already satisfied: pillow!=8.3.*,>=5.3.0 in /usr/local/lib/python3.10/dist-packages (from torchvision) (10.3.0)\n",
            "Requirement already satisfied: MarkupSafe>=2.0 in /usr/local/lib/python3.10/dist-packages (from jinja2->torch) (2.1.5)\n",
            "Requirement already satisfied: mpmath<1.4,>=1.1.0 in /usr/local/lib/python3.10/dist-packages (from sympy->torch) (1.3.0)\n",
            "Installing collected packages: triton, nvidia-nvtx-cu11, nvidia-nccl-cu11, nvidia-cusparse-cu11, nvidia-curand-cu11, nvidia-cufft-cu11, nvidia-cuda-runtime-cu11, nvidia-cuda-nvrtc-cu11, nvidia-cuda-cupti-cu11, nvidia-cublas-cu11, nvidia-cusolver-cu11, nvidia-cudnn-cu11, torch, torchvision, torchaudio\n",
            "  Attempting uninstall: triton\n",
            "    Found existing installation: triton 2.3.1\n",
            "    Uninstalling triton-2.3.1:\n",
            "      Successfully uninstalled triton-2.3.1\n",
            "\u001b[31mERROR: pip's dependency resolver does not currently take into account all the packages that are installed. This behaviour is the source of the following dependency conflicts.\n",
            "backpack-for-pytorch 1.3.0 requires torch<2.0.0,>=1.6.0, but you have torch 2.4.0+cu118 which is incompatible.\n",
            "fastai 2.7.15 requires torch<2.4,>=1.10, but you have torch 2.4.0+cu118 which is incompatible.\u001b[0m\u001b[31m\n",
            "\u001b[0mSuccessfully installed nvidia-cublas-cu11-11.11.3.6 nvidia-cuda-cupti-cu11-11.8.87 nvidia-cuda-nvrtc-cu11-11.8.89 nvidia-cuda-runtime-cu11-11.8.89 nvidia-cudnn-cu11-9.1.0.70 nvidia-cufft-cu11-10.9.0.58 nvidia-curand-cu11-10.3.0.86 nvidia-cusolver-cu11-11.4.1.48 nvidia-cusparse-cu11-11.7.5.86 nvidia-nccl-cu11-2.20.5 nvidia-nvtx-cu11-11.8.86 torch-2.4.0+cu118 torchaudio-2.4.0+cu118 torchvision-0.19.0+cu118 triton-3.0.0\n"
          ]
        }
      ],
      "source": [
        "!pip install torch torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/cu118"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 7,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "zLBb3sj3NThN",
        "outputId": "871f3847-73b5-4ba8-baa1-6e19fbd820eb"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "RuntimeError: module was compiled against NumPy C-API version 0x10 (NumPy 1.23) but the running NumPy has C-API version 0xf. Check the section C-API incompatibility at the Troubleshooting ImportError section at https://numpy.org/devdocs/user/troubleshooting-importerror.html#c-api-incompatibility for indications on how to solve this problem.\n",
            "Environment:\n",
            "\tPython: 3.10.12\n",
            "\tPyTorch: 2.4.0+cu118\n",
            "\tTorchvision: 0.19.0+cu118\n",
            "\tCUDA: 11.8\n",
            "\tCUDNN: 90100\n",
            "\tNumPy: 1.22.4\n",
            "\tPIL: 10.3.0\n",
            "Args:\n",
            "\talgorithm: ERM\n",
            "\tcheckpoint_freq: None\n",
            "\tdata_dir: ./domainbed/data/MNIST/\n",
            "\tdataset: ColoredMNIST\n",
            "\tholdout_fraction: 0.2\n",
            "\thparams: None\n",
            "\thparams_seed: 0\n",
            "\toutput_dir: train_output\n",
            "\tsave_model_every_checkpoint: False\n",
            "\tseed: 0\n",
            "\tskip_model_save: False\n",
            "\tsteps: None\n",
            "\ttask: domain_generalization\n",
            "\ttest_envs: [2]\n",
            "\ttrial_seed: 0\n",
            "\tuda_holdout_fraction: 0\n",
            "HParams:\n",
            "\tbatch_size: 64\n",
            "\tclass_balanced: False\n",
            "\tdata_augmentation: True\n",
            "\tdinov2: False\n",
            "\tfreeze_bn: False\n",
            "\tlars: False\n",
            "\tlinear_steps: 500\n",
            "\tlr: 0.001\n",
            "\tnonlinear_classifier: False\n",
            "\tresnet18: False\n",
            "\tresnet50_augmix: True\n",
            "\tresnet_dropout: 0.0\n",
            "\tvit: False\n",
            "\tvit_attn_tune: False\n",
            "\tvit_dropout: 0.0\n",
            "\tweight_decay: 0.0\n",
            "env0_in_acc   env0_out_acc  env1_in_acc   env1_out_acc  env2_in_acc   env2_out_acc  epoch         loss          mem_gb        step          step_time    \n",
            "0.4972680523  0.4976425204  0.4996517919  0.4952850407  0.4963839931  0.4939991427  0.0000000000  0.7345538735  0.1683750153  0             0.2892143726 \n",
            "0.8981679880  0.8960565795  0.7967000589  0.8066866695  0.0986768093  0.0936562366  0.3428510205  0.4626337737  0.1711444855  100           0.0064689898 \n",
            "0.8982215556  0.8960565795  0.7967000589  0.8066866695  0.0986232389  0.0936562366  0.6857020410  0.4218262953  0.1711444855  200           0.0063747334 \n",
            "0.8982215556  0.8960565795  0.7967000589  0.8066866695  0.0986232389  0.0936562366  1.0285530616  0.4230927804  0.1711444855  300           0.0066828394 \n",
            "0.8982215556  0.8960565795  0.7967000589  0.8066866695  0.0986232389  0.0936562366  1.3714040821  0.4223391840  0.1711444855  400           0.0066865468 \n",
            "0.8982215556  0.8954136305  0.7965929180  0.8069009859  0.0994803664  0.0951564509  1.7142551026  0.4227312735  0.1711444855  500           0.0065971565 \n",
            "0.8967216627  0.8930561509  0.7963250656  0.8066866695  0.1059088231  0.0998714102  2.0571061231  0.4071267831  0.1711444855  600           0.0066577148 \n",
            "0.8982215556  0.8960565795  0.7967000589  0.8066866695  0.0986232389  0.0936562366  2.3999571436  0.4011485308  0.1711444855  700           0.0064188933 \n",
            "0.8981679880  0.8960565795  0.7964857770  0.8069009859  0.0994803664  0.0942991856  2.7428081641  0.3812456788  0.1711444855  800           0.0062983537 \n",
            "0.8979537176  0.8958422632  0.7964857770  0.8060437205  0.0998017893  0.0949421346  3.0856591847  0.3899265486  0.1711444855  900           0.0068796277 \n",
            "0.8813477609  0.8842691813  0.7947179515  0.8032576082  0.1622113891  0.1648092585  3.4285102052  0.3831329039  0.1711444855  1000          0.0066783190 \n",
            "0.8971502036  0.8951993142  0.7964322066  0.8051864552  0.1060695345  0.1009429919  3.7713612257  0.3794109261  0.1711444855  1100          0.0066868734 \n",
            "0.8877758732  0.8894127733  0.7952536562  0.8028289756  0.1423903145  0.1371624518  4.1142122462  0.3757028094  0.1711444855  1200          0.0064869618 \n",
            "0.8736340261  0.8709815688  0.7901644613  0.7923274754  0.2142818878  0.2087441063  4.4570632667  0.3729538703  0.1711444855  1300          0.0063999748 \n",
            "0.8964538247  0.8960565795  0.7967000589  0.8066866695  0.1080516419  0.1005143592  4.7999142872  0.3695834322  0.1711444855  1400          0.0063232040 \n",
            "0.8977930148  0.8956279468  0.7965393475  0.8062580369  0.1005517759  0.0968709816  5.1427653078  0.3644403806  0.1711444855  1500          0.0066570783 \n",
            "0.8981144204  0.8960565795  0.7967536294  0.8069009859  0.0989982322  0.0938705529  5.4856163283  0.3691380078  0.1711444855  1600          0.0068475771 \n",
            "0.8954896079  0.8949849979  0.7962179247  0.8066866695  0.1099801789  0.1063009001  5.8284673488  0.3721275604  0.1711444855  1700          0.0067406392 \n",
            "0.8976858796  0.8960565795  0.7967536294  0.8066866695  0.1031767290  0.0992284612  6.1713183693  0.3644105953  0.1711444855  1800          0.0064404345 \n",
            "0.8982215556  0.8960565795  0.7967000589  0.8066866695  0.0986232389  0.0936562366  6.5141693898  0.3754944497  0.1711444855  1900          0.0064197445 \n",
            "0.8972573388  0.8947706815  0.7971286227  0.8060437205  0.1079980715  0.1015859408  6.8570204103  0.3625316730  0.1711444855  2000          0.0064468217 \n",
            "0.8971502036  0.8956279468  0.7961643542  0.8051864552  0.1074087963  0.1013716245  7.1998714309  0.3573611425  0.1711444855  2100          0.0065022993 \n",
            "0.8981144204  0.8960565795  0.7970214818  0.8060437205  0.0998017893  0.0942991856  7.5427224514  0.3592216165  0.1711444855  2200          0.0068273592 \n",
            "0.8891686308  0.8849121303  0.7976643274  0.8024003429  0.1456045428  0.1416630947  7.8855734719  0.3735312499  0.1711444855  2300          0.0068470359 \n",
            "0.8938290122  0.8909129876  0.7983607436  0.8041148736  0.1304976697  0.1251607372  8.2284244924  0.3564895204  0.1711444855  2400          0.0062852836 \n",
            "0.8899185772  0.8881268753  0.7988428778  0.8019717102  0.1564257781  0.1594513502  8.5712755129  0.3618606144  0.1711444855  2500          0.0062788177 \n",
            "0.8984893936  0.8958422632  0.7968071999  0.8064723532  0.1013017625  0.0960137162  8.9141265335  0.3577573080  0.1711444855  2600          0.0066460061 \n",
            "0.8936683094  0.8889841406  0.7980393207  0.8032576082  0.1329619114  0.1313759108  9.2569775540  0.3460615604  0.1711444855  2700          0.0063815117 \n",
            "0.8969895007  0.8947706815  0.7993250121  0.8079725675  0.1169443403  0.1125160737  9.5998285745  0.3558143899  0.1711444855  2800          0.0068955421 \n",
            "0.8931326334  0.8872696099  0.8000749987  0.8030432919  0.1458188247  0.1444492070  9.9426795950  0.3626338996  0.1711444855  2900          0.0065201139 \n",
            "0.8983822584  0.8939134162  0.7997535758  0.8073296185  0.1186585954  0.1157308187  10.285530615  0.3587792748  0.1711444855  3000          0.0065331936 \n",
            "0.8965609599  0.8855550793  0.8030749451  0.8019717102  0.1443724219  0.1401628804  10.628381636  0.3629286493  0.1711444855  3100          0.0067271185 \n",
            "0.8996143133  0.8960565795  0.7994321530  0.8073296185  0.1096587561  0.1054436348  10.971232656  0.3397209024  0.1711444855  3200          0.0065050578 \n",
            "0.8993464753  0.8872696099  0.8039856431  0.8032576082  0.1308190925  0.1230175739  11.314083677  0.3561495259  0.1711444855  3300          0.0064427400 \n",
            "0.8864366831  0.8711958851  0.8036106498  0.7976853836  0.2044249210  0.2006000857  11.656934697  0.3491236289  0.1711444855  3400          0.0066932535 \n",
            "0.8711163488  0.8441920274  0.8070391600  0.7906129447  0.3022981732  0.2959708530  11.999785718  0.3551080555  0.1711444855  3500          0.0065891719 \n",
            "0.8972573388  0.8887698243  0.8016821128  0.8060437205  0.1241763540  0.1200171453  12.342636738  0.3428421469  0.1711444855  3600          0.0067620111 \n",
            "0.8925969574  0.8759108444  0.8115926501  0.7998285469  0.1939251085  0.1935276468  12.685487759  0.3522892259  0.1711444855  3700          0.0068122745 \n",
            "0.8908827941  0.8722674668  0.8145390261  0.7946849550  0.2187282370  0.2128161166  13.028338779  0.3430311668  0.1711444855  3800          0.0066288543 \n",
            "0.8899721448  0.8634804972  0.8179139658  0.7936133733  0.2368350565  0.2338191170  13.371189800  0.3415552491  0.1711444855  3900          0.0063791680 \n",
            "0.9002035569  0.8797685384  0.8141104623  0.7996142306  0.1577114694  0.1545220746  13.714040820  0.3362563096  0.1711444855  4000          0.0063402438 \n",
            "0.8955431755  0.8628375482  0.8209139123  0.7966138020  0.2169068409  0.2070295757  14.056891841  0.3254421143  0.1711444855  4100          0.0069765639 \n",
            "0.9002035569  0.8791255894  0.8189318048  0.7983283326  0.1823003161  0.1778825547  14.399742861  0.3296933198  0.1711444855  4200          0.0066643238 \n",
            "0.8972037712  0.8684097728  0.8325922751  0.7914702100  0.2419242514  0.2291041577  14.742593882  0.3253839380  0.1711444855  4300          0.0064541864 \n",
            "0.9048103707  0.8838405486  0.8185568115  0.8064723532  0.1436224353  0.1388769824  15.085444902  0.3276507525  0.1711444855  4400          0.0063494515 \n",
            "0.9011142061  0.8651950279  0.8370921948  0.7966138020  0.2298173247  0.2224603515  15.428295923  0.3131892422  0.1711444855  4500          0.0063575912 \n",
            "0.9063638312  0.8707672525  0.8403064231  0.7963994856  0.2159961429  0.2113159023  15.771146943  0.3223999578  0.1711444855  4600          0.0067151642 \n",
            "0.9071137776  0.8660522932  0.8412706916  0.7953279040  0.2150318744  0.2141020146  16.113997964  0.3044512016  0.1711444855  4700          0.0068010688 \n",
            "0.9111849154  0.8686240892  0.8480741415  0.7927561080  0.2143354583  0.2158165452  16.456848984  0.3003696056  0.1711444855  4800          0.0065391374 \n",
            "0.9149346475  0.8619802829  0.8540740344  0.7865409344  0.2389778754  0.2263180454  16.799700005  0.2889953180  0.1711444855  4900          0.0065717602 \n",
            "0.9065781016  0.8549078440  0.8445920609  0.7918988427  0.2368350565  0.2295327904  17.142551025  0.2806734137  0.1711444855  5000          0.0066931367 \n"
          ]
        }
      ],
      "source": [
        "!python3 -m domainbed.scripts.train\\\n",
        "       --data_dir=./domainbed/data/MNIST/\\\n",
        "       --algorithm ERM\\\n",
        "       --dataset ColoredMNIST\\\n",
        "       --test_env 2"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "_QlakGEaURfq",
        "outputId": "bfd313e6-d547-44bc-d168-6296154539e2"
      },
      "outputs": [],
      "source": [
        "from domainbed.networks import *\n",
        "import timm\n",
        "\n",
        "hparams = {\n",
        "    'data_augmentation': True,\n",
        "    'resnet18': False,\n",
        "    'resnet50_augmix': True,\n",
        "    'dinov2': False,\n",
        "    'vit': False,\n",
        "    'vit_attn_tune': False,\n",
        "    'freeze_bn': False,\n",
        "    'lars': False,\n",
        "    'linear_steps': 500,\n",
        "    'resnet_dropout': 0.0,\n",
        "    'vit_dropout': 0.0,\n",
        "    'class_balanced': False,\n",
        "    'nonlinear_classifier': False,\n",
        "    'irm_lambda': 100.0,\n",
        "    'irm_penalty_anneal_iters': 500,\n",
        "    'lr': 0.001,\n",
        "    'weight_decay': 0.0,\n",
        "    'batch_size': 64\n",
        "}\n",
        "\n",
        "input_shape = (2, 28, 28)\n",
        "num_classes = 2\n",
        "\n",
        "model = WholeFish(input_shape=input_shape, hparams=hparams, num_classes=num_classes)\n",
        "\n",
        "state_dict_path = \"/content/DomainBed/train_output/model.pkl\"\n",
        "state_dict = torch.load(state_dict_path, map_location=torch.device('cpu'))['model_dict']\n",
        "\n",
        "new_state_dict = {}\n",
        "for key, value in state_dict.items():\n",
        "    if key.startswith('network.0.'):\n",
        "        new_key = key.replace('network.0.', 'net.0.')\n",
        "        new_state_dict[new_key] = value\n",
        "    elif key.startswith('network.1.'):\n",
        "        new_key = key.replace('network.1.', 'net.1.')\n",
        "        new_state_dict[new_key] = value\n",
        "\n",
        "model.load_state_dict(new_state_dict)\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 9,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "iRAOqESqQANg",
        "outputId": "9ab6b303-61de-41cd-f88c-e7a542338e97"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "RuntimeError: module was compiled against NumPy C-API version 0x10 (NumPy 1.23) but the running NumPy has C-API version 0xf. Check the section C-API incompatibility at the Troubleshooting ImportError section at https://numpy.org/devdocs/user/troubleshooting-importerror.html#c-api-incompatibility for indications on how to solve this problem.\n",
            "Environment:\n",
            "\tPython: 3.10.12\n",
            "\tPyTorch: 2.4.0+cu118\n",
            "\tTorchvision: 0.19.0+cu118\n",
            "\tCUDA: 11.8\n",
            "\tCUDNN: 90100\n",
            "\tNumPy: 1.22.4\n",
            "\tPIL: 10.3.0\n",
            "Args:\n",
            "\talgorithm: IRM\n",
            "\tcheckpoint_freq: None\n",
            "\tdata_dir: ./domainbed/data/MNIST/\n",
            "\tdataset: ColoredMNIST\n",
            "\tholdout_fraction: 0.2\n",
            "\thparams: None\n",
            "\thparams_seed: 0\n",
            "\toutput_dir: train_output\n",
            "\tsave_model_every_checkpoint: False\n",
            "\tseed: 0\n",
            "\tskip_model_save: False\n",
            "\tsteps: None\n",
            "\ttask: domain_generalization\n",
            "\ttest_envs: [2]\n",
            "\ttrial_seed: 0\n",
            "\tuda_holdout_fraction: 0\n",
            "HParams:\n",
            "\tbatch_size: 64\n",
            "\tclass_balanced: False\n",
            "\tdata_augmentation: True\n",
            "\tdinov2: False\n",
            "\tfreeze_bn: False\n",
            "\tirm_lambda: 100.0\n",
            "\tirm_penalty_anneal_iters: 500\n",
            "\tlars: False\n",
            "\tlinear_steps: 500\n",
            "\tlr: 0.001\n",
            "\tnonlinear_classifier: False\n",
            "\tresnet18: False\n",
            "\tresnet50_augmix: True\n",
            "\tresnet_dropout: 0.0\n",
            "\tvit: False\n",
            "\tvit_attn_tune: False\n",
            "\tvit_dropout: 0.0\n",
            "\tweight_decay: 0.0\n",
            "DRIC Environment: env1\n",
            "  Batch 1: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 2: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 3: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 4: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 5: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 6: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 7: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 8: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 9: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 10: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 11: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 12: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 13: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 14: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 15: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 16: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 17: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 18: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 19: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 20: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 21: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 22: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 23: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 24: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 25: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 26: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 27: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 28: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 29: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 30: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 31: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 32: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 33: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 34: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 35: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 36: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 37: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 38: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 39: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 40: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 41: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 42: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 43: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 44: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 45: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 46: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 47: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 48: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 49: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 50: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 51: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 52: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 53: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 54: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 55: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 56: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 57: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 58: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 59: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 60: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 61: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 62: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 63: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 64: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 65: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 66: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 67: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 68: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 69: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 70: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 71: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 72: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 73: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 74: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 75: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 76: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 77: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 78: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 79: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 80: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 81: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 82: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 83: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 84: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 85: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 86: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 87: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 88: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 89: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 90: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 91: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 92: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 93: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 94: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 95: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 96: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 97: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 98: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 99: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 100: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 101: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 102: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 103: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 104: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 105: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 106: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 107: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 108: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 109: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 110: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 111: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 112: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 113: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 114: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 115: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 116: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 117: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 118: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 119: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 120: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 121: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 122: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 123: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 124: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 125: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 126: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 127: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 128: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 129: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 130: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 131: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 132: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 133: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 134: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 135: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 136: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 137: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 138: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 139: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 140: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 141: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 142: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 143: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 144: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 145: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 146: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 147: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 148: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 149: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 150: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 151: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 152: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 153: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 154: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 155: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 156: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 157: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 158: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 159: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 160: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 161: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 162: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 163: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 164: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 165: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 166: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 167: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 168: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 169: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 170: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 171: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 172: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 173: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 174: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 175: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 176: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 177: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 178: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 179: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 180: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 181: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 182: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 183: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 184: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 185: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 186: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 187: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 188: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 189: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 190: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 191: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 192: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 193: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 194: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 195: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 196: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 197: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 198: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 199: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 200: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 201: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 202: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 203: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 204: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 205: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 206: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 207: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 208: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 209: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 210: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 211: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 212: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 213: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 214: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 215: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 216: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 217: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 218: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 219: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 220: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 221: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 222: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 223: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 224: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 225: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 226: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 227: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 228: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 229: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 230: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 231: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 232: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 233: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 234: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 235: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 236: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 237: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 238: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 239: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 240: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 241: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 242: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 243: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 244: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 245: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 246: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 247: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 248: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 249: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 250: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 251: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 252: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 253: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 254: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 255: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 256: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 257: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 258: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 259: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 260: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 261: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 262: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 263: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 264: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 265: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 266: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 267: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 268: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 269: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 270: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 271: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 272: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 273: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 274: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 275: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 276: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 277: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 278: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 279: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 280: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 281: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 282: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 283: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 284: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 285: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 286: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 287: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 288: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 289: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 290: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 291: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 292: Inputs shape: torch.Size([44, 2, 28, 28])\n",
            "  Batch 293: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 294: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 295: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 296: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 297: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 298: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 299: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 300: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 301: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 302: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 303: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 304: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 305: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 306: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 307: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 308: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 309: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 310: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 311: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 312: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 313: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 314: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 315: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 316: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 317: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 318: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 319: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 320: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 321: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 322: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 323: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 324: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 325: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 326: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 327: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 328: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 329: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 330: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 331: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 332: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 333: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 334: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 335: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 336: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 337: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 338: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 339: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 340: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 341: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 342: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 343: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 344: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 345: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 346: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 347: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 348: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 349: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 350: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 351: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 352: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 353: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 354: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 355: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 356: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 357: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 358: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 359: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 360: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 361: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 362: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 363: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 364: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 365: Inputs shape: torch.Size([58, 2, 28, 28])\n",
            "Total number of batches: 365\n",
            "\n",
            "DRIC Environment: env2\n",
            "  Batch 1: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 2: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 3: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 4: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 5: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 6: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 7: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 8: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 9: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 10: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 11: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 12: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 13: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 14: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 15: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 16: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 17: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 18: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 19: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 20: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 21: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 22: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 23: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 24: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 25: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 26: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 27: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 28: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 29: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 30: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 31: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 32: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 33: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 34: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 35: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 36: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 37: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 38: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 39: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 40: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 41: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 42: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 43: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 44: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 45: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 46: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 47: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 48: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 49: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 50: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 51: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 52: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 53: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 54: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 55: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 56: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 57: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 58: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 59: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 60: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 61: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 62: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 63: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 64: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 65: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 66: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 67: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 68: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 69: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 70: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 71: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 72: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 73: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 74: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 75: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 76: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 77: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 78: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 79: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 80: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 81: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 82: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 83: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 84: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 85: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 86: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 87: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 88: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 89: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 90: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 91: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 92: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 93: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 94: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 95: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 96: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 97: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 98: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 99: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 100: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 101: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 102: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 103: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 104: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 105: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 106: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 107: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 108: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 109: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 110: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 111: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 112: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 113: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 114: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 115: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 116: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 117: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 118: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 119: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 120: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 121: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 122: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 123: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 124: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 125: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 126: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 127: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 128: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 129: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 130: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 131: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 132: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 133: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 134: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 135: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 136: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 137: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 138: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 139: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 140: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 141: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 142: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 143: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 144: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 145: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 146: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 147: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 148: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 149: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 150: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 151: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 152: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 153: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 154: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 155: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 156: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 157: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 158: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 159: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 160: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 161: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 162: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 163: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 164: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 165: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 166: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 167: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 168: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 169: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 170: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 171: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 172: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 173: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 174: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 175: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 176: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 177: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 178: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 179: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 180: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 181: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 182: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 183: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 184: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 185: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 186: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 187: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 188: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 189: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 190: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 191: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 192: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 193: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 194: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 195: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 196: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 197: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 198: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 199: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 200: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 201: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 202: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 203: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 204: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 205: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 206: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 207: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 208: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 209: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 210: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 211: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 212: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 213: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 214: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 215: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 216: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 217: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 218: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 219: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 220: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 221: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 222: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 223: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 224: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 225: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 226: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 227: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 228: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 229: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 230: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 231: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 232: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 233: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 234: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 235: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 236: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 237: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 238: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 239: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 240: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 241: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 242: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 243: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 244: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 245: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 246: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 247: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 248: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 249: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 250: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 251: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 252: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 253: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 254: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 255: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 256: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 257: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 258: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 259: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 260: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 261: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 262: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 263: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 264: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 265: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 266: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 267: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 268: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 269: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 270: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 271: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 272: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 273: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 274: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 275: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 276: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 277: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 278: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 279: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 280: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 281: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 282: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 283: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 284: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 285: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 286: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 287: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 288: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 289: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 290: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 291: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 292: Inputs shape: torch.Size([43, 2, 28, 28])\n",
            "  Batch 293: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 294: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 295: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 296: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 297: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 298: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 299: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 300: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 301: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 302: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 303: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 304: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 305: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 306: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 307: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 308: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 309: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 310: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 311: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 312: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 313: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 314: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 315: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 316: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 317: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 318: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 319: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 320: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 321: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 322: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 323: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 324: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 325: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 326: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 327: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 328: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 329: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 330: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 331: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 332: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 333: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 334: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 335: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 336: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 337: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 338: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 339: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 340: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 341: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 342: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 343: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 344: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 345: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 346: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 347: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 348: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 349: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 350: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 351: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 352: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 353: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 354: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 355: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 356: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 357: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 358: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 359: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 360: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 361: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 362: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 363: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 364: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 365: Inputs shape: torch.Size([58, 2, 28, 28])\n",
            "Total number of batches: 365\n",
            "\n",
            "DRIC Environment: env3\n",
            "  Batch 1: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 2: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 3: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 4: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 5: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 6: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 7: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 8: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 9: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 10: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 11: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 12: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 13: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 14: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 15: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 16: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 17: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 18: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 19: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 20: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 21: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 22: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 23: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 24: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 25: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 26: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 27: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 28: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 29: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 30: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 31: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 32: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 33: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 34: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 35: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 36: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 37: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 38: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 39: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 40: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 41: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 42: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 43: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 44: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 45: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 46: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 47: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 48: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 49: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 50: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 51: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 52: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 53: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 54: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 55: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 56: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 57: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 58: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 59: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 60: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 61: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 62: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 63: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 64: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 65: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 66: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 67: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 68: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 69: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 70: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 71: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 72: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 73: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 74: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 75: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 76: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 77: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 78: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 79: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 80: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 81: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 82: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 83: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 84: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 85: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 86: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 87: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 88: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 89: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 90: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 91: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 92: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 93: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 94: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 95: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 96: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 97: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 98: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 99: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 100: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 101: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 102: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 103: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 104: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 105: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 106: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 107: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 108: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 109: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 110: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 111: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 112: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 113: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 114: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 115: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 116: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 117: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 118: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 119: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 120: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 121: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 122: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 123: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 124: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 125: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 126: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 127: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 128: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 129: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 130: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 131: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 132: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 133: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 134: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 135: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 136: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 137: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 138: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 139: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 140: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 141: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 142: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 143: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 144: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 145: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 146: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 147: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 148: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 149: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 150: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 151: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 152: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 153: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 154: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 155: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 156: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 157: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 158: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 159: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 160: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 161: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 162: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 163: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 164: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 165: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 166: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 167: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 168: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 169: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 170: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 171: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 172: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 173: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 174: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 175: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 176: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 177: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 178: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 179: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 180: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 181: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 182: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 183: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 184: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 185: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 186: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 187: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 188: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 189: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 190: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 191: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 192: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 193: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 194: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 195: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 196: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 197: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 198: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 199: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 200: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 201: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 202: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 203: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 204: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 205: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 206: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 207: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 208: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 209: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 210: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 211: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 212: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 213: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 214: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 215: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 216: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 217: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 218: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 219: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 220: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 221: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 222: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 223: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 224: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 225: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 226: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 227: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 228: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 229: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 230: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 231: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 232: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 233: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 234: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 235: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 236: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 237: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 238: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 239: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 240: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 241: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 242: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 243: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 244: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 245: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 246: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 247: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 248: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 249: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 250: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 251: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 252: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 253: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 254: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 255: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 256: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 257: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 258: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 259: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 260: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 261: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 262: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 263: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 264: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 265: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 266: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 267: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 268: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 269: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 270: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 271: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 272: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 273: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 274: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 275: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 276: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 277: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 278: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 279: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 280: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 281: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 282: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 283: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 284: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 285: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 286: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 287: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 288: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 289: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 290: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 291: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 292: Inputs shape: torch.Size([43, 2, 28, 28])\n",
            "  Batch 293: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 294: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 295: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 296: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 297: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 298: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 299: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 300: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 301: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 302: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 303: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 304: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 305: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 306: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 307: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 308: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 309: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 310: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 311: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 312: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 313: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 314: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 315: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 316: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 317: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 318: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 319: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 320: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 321: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 322: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 323: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 324: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 325: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 326: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 327: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 328: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 329: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 330: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 331: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 332: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 333: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 334: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 335: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 336: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 337: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 338: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 339: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 340: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 341: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 342: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 343: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 344: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 345: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 346: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 347: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 348: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 349: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 350: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 351: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 352: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 353: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 354: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 355: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 356: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 357: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 358: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 359: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 360: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 361: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 362: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 363: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 364: Inputs shape: torch.Size([64, 2, 28, 28])\n",
            "  Batch 365: Inputs shape: torch.Size([58, 2, 28, 28])\n",
            "Total number of batches: 365\n",
            "\n",
            "Input data saved to train_output/dric_envs_inputs.pkl\n"
          ]
        }
      ],
      "source": [
        "!python3 save_data.py \\\n",
        "--data_dir=./domainbed/data/MNIST/ \\\n",
        "--algorithm IRM \\\n",
        "--dataset ColoredMNIST \\\n",
        "--test_env 2"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 10,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "5VAZY2nGRAJU",
        "outputId": "7258ec46-ac7a-4afb-a34c-d9fe46a2730d"
      },
      "outputs": [
        {
          "name": "stderr",
          "output_type": "stream",
          "text": [
            "/usr/local/lib/python3.10/dist-packages/torch/storage.py:414: 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",
            "  return torch.load(io.BytesIO(b))\n"
          ]
        }
      ],
      "source": [
        "import torch\n",
        "import pickle\n",
        "import os\n",
        "\n",
        "data_path = '/content/DomainBed/train_output/dric_envs_inputs.pkl'\n",
        "with open(data_path, 'rb') as f:\n",
        "    dric_envs = pickle.load(f)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 38,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "SK_Bh-smRJJ4",
        "outputId": "165a8b23-721c-4020-cf1e-57e0bac35b83"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Calculating logits for env1\n",
            "Calculating logits for env2\n",
            "Calculating logits for env3\n",
            "Logits for environment 1: tensor([[-0.2254,  0.4234],\n",
            "        [ 0.1601,  0.0689],\n",
            "        [-1.8705,  2.2348],\n",
            "        ...,\n",
            "        [ 1.8647, -1.5976],\n",
            "        [-0.4950,  0.7429],\n",
            "        [-1.6520,  2.0281]])\n"
          ]
        }
      ],
      "source": [
        "model.eval()\n",
        "\n",
        "logits_dict = {}\n",
        "\n",
        "for env, batches in dric_envs.items():\n",
        "    env_logits = []\n",
        "    print(f\"Calculating logits for {env}\")\n",
        "    for j, inputs in enumerate(batches):\n",
        "        inputs = inputs.to(next(model.parameters()).device)\n",
        "\n",
        "        with torch.no_grad():\n",
        "            logits = model(inputs)\n",
        "\n",
        "        env_logits.append(logits.cpu())\n",
        "\n",
        "    logits_dict[env] = torch.cat(env_logits, dim=0)\n",
        "\n",
        "env1_logits = logits_dict['env1']\n",
        "print(f\"Logits for environment 1: {env1_logits}\")\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 39,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "9ybaYspIRMxe",
        "outputId": "3374d5b1-1fd4-4b67-fd6e-5cdbff955214"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Logits for environment 1 have shape: torch.Size([23334, 2])\n",
            "Logits for environment 2 have shape: torch.Size([23333, 2])\n",
            "Logits for environment 3 have shape: torch.Size([23333, 2])\n"
          ]
        }
      ],
      "source": [
        "env1_logits = logits_dict['env1']\n",
        "print(f\"Logits for environment 1 have shape: {env1_logits.shape}\")\n",
        "env2_logits = logits_dict['env2']\n",
        "print(f\"Logits for environment 2 have shape: {env2_logits.shape}\")\n",
        "env3_logits = logits_dict['env3']\n",
        "print(f\"Logits for environment 3 have shape: {env3_logits.shape}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 40,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "kE74b0AkRWb2",
        "outputId": "dc9433c5-e4fa-43b1-c323-9a5a664dfca3"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Concatenated inputs for env1 shape: torch.Size([23334, 2, 28, 28])\n",
            "Concatenated inputs for env2 shape: torch.Size([23333, 2, 28, 28])\n",
            "Concatenated inputs for env3 shape: torch.Size([23333, 2, 28, 28])\n",
            "Concatenated input data saved to train_output/dric_envs_concatenated.pkl\n"
          ]
        }
      ],
      "source": [
        "import torch\n",
        "import os\n",
        "import pickle\n",
        "\n",
        "dric_envs_concatenated = {}\n",
        "\n",
        "for env, batches in dric_envs.items():\n",
        "    all_inputs = []\n",
        "\n",
        "    #dont need label\n",
        "    for inputs in batches:\n",
        "        all_inputs.append(inputs)\n",
        "\n",
        "    concatenated_inputs = torch.cat(all_inputs, dim=0)\n",
        "\n",
        "    dric_envs_concatenated[env] = concatenated_inputs\n",
        "\n",
        "    print(f\"Concatenated inputs for {env} shape: {concatenated_inputs.shape}\")\n",
        "\n",
        "output_dir = \"train_output\"\n",
        "os.makedirs(output_dir, exist_ok=True)\n",
        "with open(os.path.join(output_dir, 'dric_envs_concatenated.pkl'), 'wb') as f:\n",
        "    pickle.dump(dric_envs_concatenated, f)\n",
        "\n",
        "print(f\"Concatenated input data saved to {os.path.join(output_dir, 'dric_envs_concatenated.pkl')}\")\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 41,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "pyFn0NmjRaYC",
        "outputId": "9120c36f-772d-411f-ec11-984e62cc7777"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "For env1: Inputs shape = torch.Size([23334, 2, 28, 28]), Logits shape = torch.Size([23334, 2])\n",
            "For env2: Inputs shape = torch.Size([23333, 2, 28, 28]), Logits shape = torch.Size([23333, 2])\n",
            "For env3: Inputs shape = torch.Size([23333, 2, 28, 28]), Logits shape = torch.Size([23333, 2])\n",
            "Combined input-logit data saved to train_output/env_data_dict.pkl\n"
          ]
        }
      ],
      "source": [
        "env_data_dict = {}\n",
        "\n",
        "env_data_dict['env1'] = (dric_envs_concatenated['env1'], logits_dict['env1'])\n",
        "env_data_dict['env2'] = (dric_envs_concatenated['env2'], logits_dict['env2'])\n",
        "env_data_dict['env3'] = (dric_envs_concatenated['env3'], logits_dict['env3'])\n",
        "\n",
        "for env, (inputs, logits) in env_data_dict.items():\n",
        "    print(f\"For {env}: Inputs shape = {inputs.shape}, Logits shape = {logits.shape}\")\n",
        "\n",
        "output_dir = \"train_output\"\n",
        "os.makedirs(output_dir, exist_ok=True)\n",
        "with open(os.path.join(output_dir, 'env_data_dict.pkl'), 'wb') as f:\n",
        "    pickle.dump(env_data_dict, f)\n",
        "\n",
        "print(f\"Combined input-logit data saved to {os.path.join(output_dir, 'env_data_dict.pkl')}\")\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 30,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "kaI8ujqWRez9",
        "outputId": "eca2e9ec-9619-4fca-e368-f5d8c3bbdade"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Requirement already satisfied: densratio in /usr/local/lib/python3.10/dist-packages (0.3.0)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from densratio) (1.22.4)\n"
          ]
        }
      ],
      "source": [
        "pip install densratio"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 42,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "H73gJ-QuRcSe",
        "outputId": "52cb82e1-2414-4ec2-9e74-71a43f6948af"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "RuLSIF starting...\n",
            "Searching for the optimal sigma and lambda...\n",
            "sigma = 0.00100, lambda = 0.00100, score = 0.00000\n",
            "sigma = 0.00100, lambda = 0.01000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.00100, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.01000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000000000.00000, score = 0.00000\n",
            "sigma = 0.10000, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 0.00100, score = -0.00028\n",
            "sigma = 1.00000, lambda = 0.01000, score = -0.00003\n",
            "sigma = 1.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.00100, score = 2.63729\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.30810\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.49627\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.49423\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.45741\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.18520\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.02515\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00260\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00026\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 10.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 0.00100, score = -0.48295\n",
            "sigma = 100.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.49576\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.37322\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.08572\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00972\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00098\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37498\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08677\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "Found optimal sigma = 100.000, lambda = 0.010.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 0.00\n",
            "Approximate alpha-relative KL-divergence = -0.00\n",
            "RuLSIF completed.\n",
            "RuLSIF starting...\n",
            "Searching for the optimal sigma and lambda...\n",
            "sigma = 0.00100, lambda = 0.00100, score = 0.00000\n",
            "sigma = 0.00100, lambda = 0.01000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.00100, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.01000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000000000.00000, score = 0.00000\n",
            "sigma = 0.10000, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 0.00100, score = -0.00048\n",
            "sigma = 1.00000, lambda = 0.01000, score = -0.00005\n",
            "sigma = 1.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.00100, score = 116.29339\n",
            "sigma = 10.00000, lambda = 0.01000, score = 6.39471\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.44440\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.49859\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.46084\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.18755\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.02553\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00264\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00027\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 10.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 0.00100, score = 1.51008\n",
            "sigma = 100.00000, lambda = 0.01000, score = -0.49970\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.50003\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.49998\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.49579\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.37326\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.08573\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00972\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00098\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37498\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08677\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "Found optimal sigma = 100.000, lambda = 0.100.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 0.00\n",
            "Approximate alpha-relative KL-divergence = -0.00\n",
            "RuLSIF completed.\n",
            "RuLSIF starting...\n",
            "Searching for the optimal sigma and lambda...\n",
            "sigma = 0.00100, lambda = 0.00100, score = 0.00000\n",
            "sigma = 0.00100, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 0.00100, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 0.00100, score = -0.00028\n",
            "sigma = 1.00000, lambda = 0.01000, score = -0.00003\n",
            "sigma = 1.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.00100, score = 3.46700\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.26375\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.49593\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.49387\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.45763\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.18654\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.02541\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00263\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00026\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 10.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 0.00100, score = -0.48835\n",
            "sigma = 100.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.49576\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.37323\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.08573\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00972\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00098\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37498\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08677\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "Found optimal sigma = 100.000, lambda = 0.010.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = -0.00\n",
            "Approximate alpha-relative KL-divergence = -0.00\n",
            "RuLSIF completed.\n",
            "RuLSIF starting...\n",
            "Searching for the optimal sigma and lambda...\n",
            "sigma = 0.00100, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.00100, lambda = 0.01000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 100000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.01000, lambda = 0.01000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 100000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000000000.00000, score = 0.00000\n",
            "sigma = 0.10000, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 0.00100, score = -0.00044\n",
            "sigma = 1.00000, lambda = 0.01000, score = -0.00004\n",
            "sigma = 1.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.00100, score = 78.97632\n",
            "sigma = 10.00000, lambda = 0.01000, score = 5.24147\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.47359\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.49773\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.46155\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.19124\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.02625\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00272\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00027\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 10.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 0.00100, score = 1.57610\n",
            "sigma = 100.00000, lambda = 0.01000, score = -0.49980\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.50003\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.49998\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.49579\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.37329\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.08576\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00972\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00098\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37498\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08677\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "Found optimal sigma = 100.000, lambda = 0.100.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 0.00\n",
            "Approximate alpha-relative KL-divergence = -0.00\n",
            "RuLSIF completed.\n",
            "RuLSIF starting...\n",
            "Searching for the optimal sigma and lambda...\n",
            "sigma = 0.00100, lambda = 0.00100, score = 0.00000\n",
            "sigma = 0.00100, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 0.00100, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 0.00100, score = -0.00002\n",
            "sigma = 1.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.00100, score = 98.19643\n",
            "sigma = 10.00000, lambda = 0.01000, score = 6.64891\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.44519\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.49737\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.45739\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.18146\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.02442\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00253\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00025\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 10.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 0.00100, score = 1.94278\n",
            "sigma = 100.00000, lambda = 0.01000, score = -0.49985\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.50002\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.49996\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.49577\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.37318\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.08569\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00971\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00098\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37498\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08677\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "Found optimal sigma = 100.000, lambda = 0.100.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = -0.00\n",
            "Approximate alpha-relative KL-divergence = -0.00\n",
            "RuLSIF completed.\n",
            "RuLSIF starting...\n",
            "Searching for the optimal sigma and lambda...\n",
            "sigma = 0.00100, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.00100, lambda = 0.01000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 100.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.00100, lambda = 100000000.00000, score = 0.00000\n",
            "sigma = 0.00100, lambda = 1000000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.01000, lambda = 0.01000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 0.10000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 100.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 1000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.01000, lambda = 100000000.00000, score = 0.00000\n",
            "sigma = 0.01000, lambda = 1000000000.00000, score = 0.00000\n",
            "sigma = 0.10000, lambda = 0.00100, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 0.10000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 0.00100, score = -0.00032\n",
            "sigma = 1.00000, lambda = 0.01000, score = -0.00003\n",
            "sigma = 1.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.00100, score = 68.31702\n",
            "sigma = 10.00000, lambda = 0.01000, score = 4.81691\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.46302\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.49681\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.45831\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.18475\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.02504\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00259\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00026\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 10.00000, lambda = 10000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 0.00100, score = 1.85484\n",
            "sigma = 100.00000, lambda = 0.01000, score = -0.49945\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.50001\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.49576\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.37321\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.08572\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00972\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00098\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37498\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08677\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 10000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 10000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 10000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 10000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 10000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 10000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 10000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 100000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 100000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 100000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 100000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 100000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 100000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 100000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 100000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 0.00100, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.01000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 1000000000.00000, lambda = 1.00000, score = -0.49995\n",
            "sigma = 1000000000.00000, lambda = 10.00000, score = -0.49586\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08678\n",
            "sigma = 1000000000.00000, lambda = 10000.00000, score = -0.00985\n",
            "sigma = 1000000000.00000, lambda = 100000.00000, score = -0.00100\n",
            "sigma = 1000000000.00000, lambda = 1000000.00000, score = -0.00010\n",
            "sigma = 1000000000.00000, lambda = 10000000.00000, score = -0.00001\n",
            "sigma = 1000000000.00000, lambda = 100000000.00000, score = -0.00000\n",
            "sigma = 1000000000.00000, lambda = 1000000000.00000, score = -0.00000\n",
            "Found optimal sigma = 100.000, lambda = 0.100.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 0.00\n",
            "Approximate alpha-relative KL-divergence = -0.00\n",
            "RuLSIF completed.\n",
            "Q_CRIC value: 7.417115446226876e-06\n"
          ]
        }
      ],
      "source": [
        "import torch\n",
        "from densratio import densratio\n",
        "\n",
        "def Q_CRIC(env_data_dict):\n",
        "    Q_num = 0\n",
        "\n",
        "    assert isinstance(env_data_dict, dict)\n",
        "\n",
        "    env_keys = list(env_data_dict.keys())\n",
        "\n",
        "    for i in range(len(env_keys)):\n",
        "        env_i_key = env_keys[i]\n",
        "        train_e_inputs, train_e_logits = env_data_dict[env_i_key]\n",
        "        #flat\n",
        "        train_e_inputs_flat = train_e_inputs.view(train_e_inputs.size(0), -1)\n",
        "\n",
        "        q_e = torch.mean(train_e_logits)\n",
        "\n",
        "        for j in range(len(env_keys)):\n",
        "            if j == i:\n",
        "                continue\n",
        "\n",
        "            env_j_key = env_keys[j]\n",
        "            train_t_inputs, train_t_logits = env_data_dict[env_j_key]\n",
        "            #flat\n",
        "            train_t_inputs_flat = train_t_inputs.view(train_t_inputs.size(0), -1)\n",
        "\n",
        "            dr_co = densratio(train_e_inputs_flat.numpy(), train_t_inputs_flat.numpy())\n",
        "            w_co = torch.from_numpy(dr_co.compute_density_ratio(train_t_inputs_flat.numpy()))\n",
        "\n",
        "            w_co = w_co.view(-1, 1)\n",
        "\n",
        "            weighted_logits = w_co * train_t_logits.view(train_t_logits.size(0), -1)\n",
        "            q_e_co = torch.mean(weighted_logits)\n",
        "\n",
        "            Q_num += (q_e_co - q_e) ** 2\n",
        "            Q_num = Q_num.detach()\n",
        "\n",
        "    return Q_num\n",
        "\n",
        "Q_cric_value = Q_CRIC(env_data_dict)\n",
        "print(f\"Q_CRIC value: {Q_cric_value}\")"
      ]
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "gpuType": "A100",
      "machine_shape": "hm",
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
