{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "AAbfkiKL-SQy",
        "outputId": "535b5b35-6227-4596-a964-f06bfbe8bb6e"
      },
      "outputs": [],
      "source": [
        "!git clone https://github.com/facebookresearch/DomainBed.git"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "xT6fJiyg-6Zu",
        "outputId": "06ebdbeb-dfa1-4dd7-961d-118485a1ea21"
      },
      "outputs": [],
      "source": [
        "cd /content/DomainBed"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "IoYdt4Zr_LBv",
        "outputId": "a49b0e0a-6aeb-499f-cf5c-0db44163210d"
      },
      "outputs": [],
      "source": [
        "!pip install -r /content/DomainBed/domainbed/requirements.txt"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 35
        },
        "id": "00KKJN8xA-Au",
        "outputId": "fce4a6fe-ccd6-45ec-c15c-09465c58d33d"
      },
      "outputs": [
        {
          "data": {
            "application/vnd.google.colaboratory.intrinsic+json": {
              "type": "string"
            },
            "text/plain": [
              "'/content/DomainBed/domainbed/data/PACS'"
            ]
          },
          "execution_count": 5,
          "metadata": {},
          "output_type": "execute_result"
        }
      ],
      "source": [
        "import shutil\n",
        "import os\n",
        "\n",
        "my_dir = '/content/drive/MyDrive/domainbed/kfold'\n",
        "run_dir = '/content/DomainBed/domainbed/data/PACS'\n",
        "\n",
        "os.makedirs(run_dir, exist_ok=True)\n",
        "\n",
        "shutil.copytree(my_dir, run_dir, dirs_exist_ok=True)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "hiqCk-EPsPIM",
        "outputId": "e258875d-00df-48f8-8c60-e1aaf52d1e1b"
      },
      "outputs": [],
      "source": [
        "!pip uninstall torch torchvision torchaudio"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "1KLRDMO3srsK",
        "outputId": "c9205035-6eb2-4229-b835-d1d223d81f63"
      },
      "outputs": [],
      "source": [
        "!pip install torch torchvision torchaudio --extra-index-url https://download.pytorch.org/whl/cu118"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "NLC3T2ZwBXM-",
        "outputId": "55253e41-3ad1-4b6b-9f60-d7315f12ba28"
      },
      "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/\n",
            "\tdataset: PACS\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: 32\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: 5e-05\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",
            "/usr/local/lib/python3.10/dist-packages/torchvision/models/_utils.py:208: UserWarning: The parameter 'pretrained' is deprecated since 0.13 and may be removed in the future, please use 'weights' instead.\n",
            "  warnings.warn(\n",
            "/usr/local/lib/python3.10/dist-packages/torchvision/models/_utils.py:223: UserWarning: Arguments other than a weight enum or `None` for 'weights' are deprecated since 0.13 and may be removed in the future. The current behavior is equivalent to passing `weights=ResNet50_Weights.IMAGENET1K_V1`. You can also use `weights=ResNet50_Weights.DEFAULT` to get the most up-to-date weights.\n",
            "  warnings.warn(msg)\n",
            "Downloading: \"https://download.pytorch.org/models/resnet50-0676ba61.pth\" to /root/.cache/torch/hub/checkpoints/resnet50-0676ba61.pth\n",
            "100%|##########| 97.8M/97.8M [00:00<00:00, 127MB/s]\n",
            "model.safetensors: 100%|##########| 102M/102M [00:00<00:00, 269MB/s]\n",
            "env0_in_acc   env0_out_acc  env1_in_acc   env1_out_acc  env2_in_acc   env2_out_acc  env3_in_acc   env3_out_acc  epoch         loss          mem_gb        nll           penalty       step          step_time    \n",
            "0.1160388821  0.0924574209  0.1833688699  0.2158119658  0.0943113772  0.1257485030  0.1927480916  0.2076433121  0.0000000000  1.9747275114  7.9352908134  1.9733426571  0.0013848508  0             0.8455760479 \n",
            "0.9896719320  0.9537712895  0.9824093817  0.9615384615  0.9850299401  0.9790419162  0.9793256997  0.9477707006  7.1856287425  0.3409870663  8.1353220940  0.3243896222  0.0165974438  300           0.5123353839 \n",
            "0.8608748481  0.7931873479  0.8454157783  0.8098290598  0.9438622754  0.9251497006  0.8377862595  0.8012738854  14.371257485  0.4546787163  8.1353220940  0.1786691538  0.0032794015  600           0.5134166193 \n",
            "0.7515188335  0.7153284672  0.7873134328  0.7500000000  0.8952095808  0.8742514970  0.8091603053  0.7770700637  21.556886227  -4.859388341  8.1353220940  1.0717503453  -0.059311386  900           0.5138386798 \n",
            "0.6840826245  0.6545012165  0.6849680171  0.6623931624  0.8712574850  0.8263473054  0.6453562341  0.6509554140  28.742514970  -8.337154343  8.1353220940  1.4883185293  -0.098254729  1200          0.5132261999 \n",
            "0.7083839611  0.7007299270  0.6833688699  0.6688034188  0.8315868263  0.8413173653  0.5702926209  0.5694267516  35.928143712  -10.86865442  8.1353220940  1.7637723502  -0.126324269  1500          0.5135051481 \n",
            "0.6099635480  0.5912408759  0.6940298507  0.6559829060  0.7806886228  0.7784431138  0.4576972010  0.4496815287  43.113772455  -11.65372247  8.1353220940  1.7314235429  -0.133851460  1800          0.5133366656 \n",
            "0.7551640340  0.7274939173  0.6226012793  0.6111111111  0.8121257485  0.7664670659  0.4573791349  0.4560509554  50.299401197  -5.169182026  8.1353220940  1.8553899201  -0.070245719  2100          0.5137244813 \n",
            "0.7029161604  0.6885644769  0.6993603412  0.6816239316  0.8031437126  0.8113772455  0.2948473282  0.3006369427  57.485029940  -15.10334224  8.1353220940  1.9150015477  -0.170183439  2400          0.5130787651 \n",
            "0.7928311057  0.7615571776  0.5575692964  0.5705128205  0.8121257485  0.7694610778  0.3326972010  0.3388535032  64.670658682  -27.22316233  8.1353220940  2.1064143769  -0.293295767  2700          0.5139607088 \n",
            "0.6634264885  0.6447688564  0.7542643923  0.7564102564  0.7529940120  0.6736526946  0.8498727735  0.8267515924  71.856287425  -7.914459289  8.1353220940  1.6539015059  -0.095683608  3000          0.5129233511 \n",
            "0.5814094775  0.5717761557  0.6273987207  0.6303418803  0.6811377246  0.6197604790  0.8451017812  0.8012738854  79.041916167  -20.36180188  8.1353220940  1.6531707801  -0.220149726  3300          0.5128038398 \n",
            "0.5613608748  0.5401459854  0.7766524520  0.7820512821  0.7492514970  0.7065868263  0.5079516539  0.5235668790  86.227544910  -26.17908314  8.1353220940  1.9187125240  -0.280977956  3600          0.5130575895 \n",
            "0.4125151883  0.3965936740  0.7665245203  0.7435897436  0.6467065868  0.6077844311  0.5445292621  0.5554140127  93.413173652  -32.30596834  8.1353220940  2.1279705648  -0.344339388  3900          0.5132253114 \n",
            "0.2685297691  0.2603406326  0.5575692964  0.5405982906  0.5000000000  0.4670658683  0.5518447837  0.5872611465  100.59880239  -20.16079333  8.1353220940  2.2400789714  -0.224008719  4200          0.5129694716 \n",
            "0.2825030377  0.2798053528  0.5868869936  0.5940170940  0.5067365269  0.4730538922  0.5372137405  0.5490445860  107.78443113  -23.90344154  8.1353220940  2.1636977351  -0.260671393  4500          0.5129007832 \n",
            "0.4896719320  0.4549878345  0.5991471215  0.5897435897  0.5943113772  0.5329341317  0.5709287532  0.5439490446  114.97005988  -14.86340636  8.1353220940  2.0205875385  -0.168839940  4800          0.5128879523 \n",
            "0.4659781288  0.4160583942  0.5154584222  0.5213675214  0.5097305389  0.4670658683  0.4573791349  0.4649681529  119.76047904  -0.408165555  8.1353220940  1.5676757276  -0.019758413  5000          0.5131240094 \n"
          ]
        }
      ],
      "source": [
        "!python3 -m domainbed.scripts.train\\\n",
        "       --data_dir=./domainbed/data/\\\n",
        "       --algorithm IRM\\\n",
        "       --dataset PACS\\\n",
        "       --test_env 2"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "UtkGmQeLefVg",
        "outputId": "4e808f07-ca32-433f-d9a9-5d933d0337fd"
      },
      "outputs": [],
      "source": [
        "#load model\n",
        "from domainbed.networks import *\n",
        "\n",
        "hparams = {\n",
        "    'batch_size': 32,\n",
        "    'class_balanced': False,\n",
        "    'data_augmentation': True,\n",
        "    'dinov2': False,\n",
        "    'freeze_bn': False,\n",
        "    'irm_lambda': 100.0,\n",
        "    'irm_penalty_anneal_iters': 500,\n",
        "    'lars': False,\n",
        "    'linear_steps': 500,\n",
        "    'lr': 5e-05,\n",
        "    'nonlinear_classifier': False,\n",
        "    'resnet18': False,\n",
        "    'resnet50_augmix': True,\n",
        "    'resnet_dropout': 0.0,\n",
        "    'vit': False,\n",
        "    'vit_attn_tune': False,\n",
        "    'vit_dropout': 0.0,\n",
        "    'weight_decay': 0.0\n",
        "  }\n",
        "\n",
        "input_shape = (3,224,224)\n",
        "num_classes = 7\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)['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)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "9hRZKgVQdzlu",
        "outputId": "fdc41a06-5f8a-45d9-c19b-4c018eaa7b2f"
      },
      "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/\n",
            "\tdataset: PACS\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: 32\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: 5e-05\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, 3, 224, 224])\n",
            "  Batch 2: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 3: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 4: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 5: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 6: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 7: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 8: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 9: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 10: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 11: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 12: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 13: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 14: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 15: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 16: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 17: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 18: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 19: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 20: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 21: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 22: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 23: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 24: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 25: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 26: Inputs shape: torch.Size([46, 3, 224, 224])\n",
            "  Batch 27: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 28: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 29: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 30: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 31: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 32: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 33: Inputs shape: torch.Size([27, 3, 224, 224])\n",
            "Total number of batches: 33\n",
            "\n",
            "DRIC Environment: env2\n",
            "  Batch 1: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 2: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 3: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 4: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 5: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 6: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 7: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 8: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 9: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 10: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 11: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 12: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 13: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 14: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 15: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 16: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 17: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 18: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 19: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 20: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 21: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 22: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 23: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 24: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 25: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 26: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 27: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 28: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 29: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 30: Inputs shape: torch.Size([20, 3, 224, 224])\n",
            "  Batch 31: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 32: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 33: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 34: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 35: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 36: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 37: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 38: Inputs shape: torch.Size([20, 3, 224, 224])\n",
            "Total number of batches: 38\n",
            "\n",
            "DRIC Environment: env3\n",
            "  Batch 1: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 2: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 3: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 4: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 5: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 6: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 7: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 8: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 9: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 10: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 11: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 12: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 13: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 14: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 15: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 16: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 17: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 18: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 19: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 20: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 21: Inputs shape: torch.Size([56, 3, 224, 224])\n",
            "  Batch 22: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 23: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 24: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 25: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 26: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 27: Inputs shape: torch.Size([14, 3, 224, 224])\n",
            "Total number of batches: 27\n",
            "\n",
            "DRIC Environment: env4\n",
            "  Batch 1: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 2: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 3: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 4: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 5: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 6: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 7: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 8: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 9: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 10: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 11: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 12: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 13: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 14: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 15: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 16: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 17: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 18: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 19: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 20: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 21: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 22: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 23: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 24: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 25: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 26: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 27: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 28: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 29: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 30: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 31: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 32: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 33: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 34: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 35: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 36: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 37: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 38: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 39: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 40: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 41: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 42: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 43: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 44: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 45: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 46: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 47: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 48: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 49: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 50: Inputs shape: torch.Size([8, 3, 224, 224])\n",
            "  Batch 51: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 52: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 53: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 54: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 55: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 56: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 57: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 58: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 59: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 60: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 61: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 62: Inputs shape: torch.Size([64, 3, 224, 224])\n",
            "  Batch 63: Inputs shape: torch.Size([17, 3, 224, 224])\n",
            "Total number of batches: 63\n",
            "\n",
            "Input data saved to train_output/dric_envs_inputs.pkl\n"
          ]
        }
      ],
      "source": [
        "#save envs data\n",
        "!python3 save_data.py \\\n",
        "--data_dir=./domainbed/data/ \\\n",
        "--algorithm IRM \\\n",
        "--dataset PACS \\\n",
        "--test_env 2"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Ei4DFdt8eLC4",
        "outputId": "31c4710c-df38-4b75-a047-a1d5359a0807"
      },
      "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 pickle\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": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "hiv335d7AMm8",
        "outputId": "b37c1206-33a5-458d-995f-17e5a7cdaa3c"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Key: env1, Num of Batches: 33\n",
            "Key: env2, Num of Batches: 38\n",
            "Key: env3, Num of Batches: 27\n",
            "Key: env4, Num of Batches: 63\n"
          ]
        }
      ],
      "source": [
        "for key, value in dric_envs.items():\n",
        "    print(f\"Key: {key}, Num of Batches: {len(value)}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ipXK2W6zBBMf",
        "outputId": "4670f8fb-aa66-4c12-fb05-1876ffd70866"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Key: env1, Batch 1: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 2: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 3: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 4: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 5: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 6: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 7: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 8: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 9: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 10: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 11: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 12: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 13: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 14: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 15: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 16: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 17: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 18: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 19: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 20: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 21: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 22: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 23: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 24: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 25: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 26: Resized Inputs Shape: torch.Size([46, 3, 56, 56])\n",
            "Key: env1, Batch 27: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 28: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 29: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 30: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 31: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 32: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env1, Batch 33: Resized Inputs Shape: torch.Size([27, 3, 56, 56])\n",
            "Key: env2, Batch 1: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 2: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 3: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 4: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 5: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 6: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 7: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 8: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 9: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 10: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 11: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 12: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 13: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 14: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 15: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 16: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 17: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 18: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 19: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 20: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 21: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 22: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 23: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 24: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 25: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 26: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 27: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 28: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 29: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 30: Resized Inputs Shape: torch.Size([20, 3, 56, 56])\n",
            "Key: env2, Batch 31: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 32: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 33: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 34: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 35: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 36: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 37: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env2, Batch 38: Resized Inputs Shape: torch.Size([20, 3, 56, 56])\n",
            "Key: env3, Batch 1: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 2: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 3: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 4: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 5: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 6: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 7: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 8: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 9: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 10: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 11: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 12: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 13: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 14: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 15: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 16: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 17: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 18: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 19: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 20: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 21: Resized Inputs Shape: torch.Size([56, 3, 56, 56])\n",
            "Key: env3, Batch 22: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 23: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 24: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 25: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 26: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env3, Batch 27: Resized Inputs Shape: torch.Size([14, 3, 56, 56])\n",
            "Key: env4, Batch 1: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 2: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 3: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 4: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 5: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 6: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 7: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 8: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 9: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 10: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 11: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 12: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 13: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 14: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 15: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 16: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 17: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 18: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 19: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 20: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 21: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 22: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 23: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 24: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 25: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 26: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 27: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 28: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 29: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 30: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 31: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 32: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 33: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 34: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 35: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 36: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 37: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 38: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 39: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 40: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 41: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 42: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 43: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 44: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 45: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 46: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 47: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 48: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 49: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 50: Resized Inputs Shape: torch.Size([8, 3, 56, 56])\n",
            "Key: env4, Batch 51: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 52: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 53: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 54: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 55: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 56: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 57: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 58: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 59: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 60: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 61: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 62: Resized Inputs Shape: torch.Size([64, 3, 56, 56])\n",
            "Key: env4, Batch 63: Resized Inputs Shape: torch.Size([17, 3, 56, 56])\n"
          ]
        }
      ],
      "source": [
        "import pickle\n",
        "import torch.nn.functional as F\n",
        "resized_dric_envs = {}\n",
        "\n",
        "new_size = (56, 56)\n",
        "\n",
        "for key, batches in dric_envs.items():\n",
        "    resized_batches = []\n",
        "    for i, batch in enumerate(batches):\n",
        "        resized_batch = F.interpolate(batch, size=new_size, mode='bilinear', align_corners=False)\n",
        "        resized_batches.append(resized_batch)\n",
        "\n",
        "        print(f\"Key: {key}, Batch {i+1}: Resized Inputs Shape: {resized_batch.shape}\")\n",
        "\n",
        "    resized_dric_envs[key] = resized_batches"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "hQswfibOEnpK"
      },
      "outputs": [],
      "source": [
        "!pip install torch==1.12.1 torchvision==0.13.1"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "ufhmAoCucXuT"
      },
      "outputs": [],
      "source": [
        "model.eval()\n",
        "\n",
        "logits_dict = {}\n",
        "\n",
        "for env, batches in resized_dric_envs.items():\n",
        "    env_logits = []\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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "QobRK6B5gHbu",
        "outputId": "722a7edb-9936-43a4-d781-3d2493481019"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Logits for environment 1 have shape: torch.Size([2057, 7])\n",
            "Logits for environment 2 have shape: torch.Size([2344, 7])\n",
            "Logits for environment 3 have shape: torch.Size([1670, 7])\n",
            "Logits for environment 4 have shape: torch.Size([3929, 7])\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}\")\n",
        "env4_logits = logits_dict['env4']\n",
        "print(f\"Logits for environment 4 have shape: {env4_logits.shape}\")"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "FNJ-JU8ukG-y"
      },
      "outputs": [],
      "source": [
        "dric_envs_concatenated = {}\n",
        "\n",
        "for env, batches in resized_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",
        "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"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "6JvNsgWgPSOv",
        "outputId": "43161cb1-9cd4-4a56-97b2-f53e3aa4dbcb"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "For env1: Inputs shape = torch.Size([2057, 3, 56, 56]), Logits shape = torch.Size([2057, 7])\n",
            "For env2: Inputs shape = torch.Size([2344, 3, 56, 56]), Logits shape = torch.Size([2344, 7])\n",
            "For env3: Inputs shape = torch.Size([1670, 3, 56, 56]), Logits shape = torch.Size([1670, 7])\n",
            "For env4: Inputs shape = torch.Size([3929, 3, 56, 56]), Logits shape = torch.Size([3929, 7])\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",
        "env_data_dict['env4'] = (dric_envs_concatenated['env4'], logits_dict['env4'])\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": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "xJPd-Pgtl8iF",
        "outputId": "f976b9c0-410a-4760-a1f4-5bf613590b47"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Collecting densratio\n",
            "  Downloading densratio-0.3.0-py3-none-any.whl.metadata (11 kB)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from densratio) (1.22.4)\n",
            "Downloading densratio-0.3.0-py3-none-any.whl (10 kB)\n",
            "Installing collected packages: densratio\n",
            "Successfully installed densratio-0.3.0\n"
          ]
        }
      ],
      "source": [
        "pip install densratio"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "DsTo7zm1odn8",
        "outputId": "4e8e357e-f606-4263-e71f-c853f374a4de"
      },
      "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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 181.73323\n",
            "sigma = 100.00000, lambda = 0.01000, score = 14.96797\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.67429\n",
            "sigma = 100.00000, lambda = 1.00000, score = -1.41275\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.52592\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.08563\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00917\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00092\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00009\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 4853.35717\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 247.63689\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 1.77414\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.50837\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.50046\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37361\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08476\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00958\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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 = 2.13810\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.49973\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50005\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49999\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49587\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49583\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 0.79\n",
            "Approximate alpha-relative KL-divergence = 0.67\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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 132.81885\n",
            "sigma = 100.00000, lambda = 0.01000, score = 8.97619\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.43960\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.52031\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.37360\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.08393\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00947\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00096\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 61.45992\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 0.60454\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.50017\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.49988\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49552\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37129\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08465\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00958\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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.49998\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.49583\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37490\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49583\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 0.10\n",
            "Approximate alpha-relative KL-divergence = -0.11\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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 42550.90660\n",
            "sigma = 100.00000, lambda = 0.01000, score = 1266.63222\n",
            "sigma = 100.00000, lambda = 0.10000, score = 5.18964\n",
            "sigma = 100.00000, lambda = 1.00000, score = -3.39637\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.71475\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.09368\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00975\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00098\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 31869.23098\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 962.48326\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 8.87910\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.50882\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.50567\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37574\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08485\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00958\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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 = 10.06013\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.48447\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50010\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.50004\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49592\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49583\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49583\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 1.59\n",
            "Approximate alpha-relative KL-divergence = 1.43\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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 44.32331\n",
            "sigma = 100.00000, lambda = 0.01000, score = 2.87329\n",
            "sigma = 100.00000, lambda = 0.10000, score = -1.09798\n",
            "sigma = 100.00000, lambda = 1.00000, score = -1.06824\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.46036\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.07301\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00776\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00078\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00008\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 3180.49731\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 203.82275\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 1.51514\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.50785\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.50036\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37335\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08462\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00956\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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 = 1.86858\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.49971\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50005\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49999\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49588\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49584\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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.86\n",
            "Approximate alpha-relative KL-divergence = 1.04\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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 265.03415\n",
            "sigma = 100.00000, lambda = 0.01000, score = 20.75688\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.96427\n",
            "sigma = 100.00000, lambda = 1.00000, score = -1.59182\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.57517\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.09227\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00984\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00099\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00010\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 6863.31106\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 211.50782\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 1.16728\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.50794\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.50078\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37396\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08487\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00959\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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 = 1.41155\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.49953\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50005\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49588\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37494\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49584\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 1.37\n",
            "Approximate alpha-relative KL-divergence = 0.84\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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 2238.63676\n",
            "sigma = 100.00000, lambda = 0.01000, score = 73.93403\n",
            "sigma = 100.00000, lambda = 0.10000, score = 0.02861\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.60300\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.31646\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.07449\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00863\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00088\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00009\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 6185.84847\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 147.69314\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 0.49782\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.50172\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49550\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37114\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08461\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00957\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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.63163\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.50002\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.49994\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49583\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37491\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49584\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49584\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = -0.29\n",
            "Approximate alpha-relative KL-divergence = 0.08\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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 824.31275\n",
            "sigma = 100.00000, lambda = 0.01000, score = 30.80429\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.16380\n",
            "sigma = 100.00000, lambda = 1.00000, score = -0.49061\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.35309\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.07941\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00896\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00091\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00009\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 102.29352\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 0.55800\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.50065\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.50039\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.49603\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37173\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08476\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00959\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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.50001\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.49582\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37489\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49582\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37492\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1000.000, lambda = 0.100.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = -0.12\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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 874.24288\n",
            "sigma = 100.00000, lambda = 0.01000, score = 41.02685\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.23615\n",
            "sigma = 100.00000, lambda = 1.00000, score = -1.24164\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.53603\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.08723\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00931\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00094\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00009\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 5016.59496\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 159.48320\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 0.77040\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.50834\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.50142\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37432\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08490\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00960\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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.95731\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.49984\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50006\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.50000\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49588\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37492\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49582\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 0.38\n",
            "Approximate alpha-relative KL-divergence = 0.70\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.00000\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 = -0.00000\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 17794.52606\n",
            "sigma = 100.00000, lambda = 0.01000, score = 657.60885\n",
            "sigma = 100.00000, lambda = 0.10000, score = 0.24653\n",
            "sigma = 100.00000, lambda = 1.00000, score = -2.71901\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.66481\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.08626\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.00891\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00089\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00009\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00001\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 26134.79694\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 542.59853\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 4.03118\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.51606\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.50761\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37697\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08494\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00959\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00097\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 = 4.67520\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.49579\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50012\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.50006\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49593\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37495\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08675\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.49582\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49582\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37493\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 0.46\n",
            "Approximate alpha-relative KL-divergence = 1.32\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.00000\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 = -0.00043\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00004\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 690.63044\n",
            "sigma = 100.00000, lambda = 0.01000, score = 68.35383\n",
            "sigma = 100.00000, lambda = 0.10000, score = -2.31152\n",
            "sigma = 100.00000, lambda = 1.00000, score = -4.58158\n",
            "sigma = 100.00000, lambda = 10.00000, score = -1.79639\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.28744\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.03063\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00308\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00031\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 12926.77175\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 368.18426\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 2.73579\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.52164\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.51312\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.38189\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08622\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00974\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00099\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 = 3.11958\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.49945\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50018\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.50012\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49602\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37504\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 5.54\n",
            "Approximate alpha-relative KL-divergence = 2.02\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.00000\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 = -0.00017\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00002\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 313.00420\n",
            "sigma = 100.00000, lambda = 0.01000, score = 26.80948\n",
            "sigma = 100.00000, lambda = 0.10000, score = -0.19381\n",
            "sigma = 100.00000, lambda = 1.00000, score = -1.34502\n",
            "sigma = 100.00000, lambda = 10.00000, score = -0.95258\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.25954\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.03094\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00315\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00032\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 3214.60092\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 69.71441\n",
            "sigma = 1000.00000, lambda = 0.10000, score = -0.09936\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.50749\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.50236\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.37674\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08601\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00974\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00099\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.04438\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.50008\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50007\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.50002\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49591\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37499\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 1.45\n",
            "Approximate alpha-relative KL-divergence = 1.03\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.00000\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 = -0.00025\n",
            "sigma = 10.00000, lambda = 0.01000, score = -0.00002\n",
            "sigma = 10.00000, lambda = 0.10000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 10000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 100000.00000, score = -0.00000\n",
            "sigma = 10.00000, lambda = 1000000.00000, score = -0.00000\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 = 4683.73809\n",
            "sigma = 100.00000, lambda = 0.01000, score = 324.47953\n",
            "sigma = 100.00000, lambda = 0.10000, score = -2.64294\n",
            "sigma = 100.00000, lambda = 1.00000, score = -8.69878\n",
            "sigma = 100.00000, lambda = 10.00000, score = -2.22762\n",
            "sigma = 100.00000, lambda = 100.00000, score = -0.30125\n",
            "sigma = 100.00000, lambda = 1000.00000, score = -0.03131\n",
            "sigma = 100.00000, lambda = 10000.00000, score = -0.00314\n",
            "sigma = 100.00000, lambda = 100000.00000, score = -0.00031\n",
            "sigma = 100.00000, lambda = 1000000.00000, score = -0.00003\n",
            "sigma = 100.00000, lambda = 10000000.00000, score = -0.00000\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 = 23448.05862\n",
            "sigma = 1000.00000, lambda = 0.01000, score = 445.23403\n",
            "sigma = 1000.00000, lambda = 0.10000, score = 3.20206\n",
            "sigma = 1000.00000, lambda = 1.00000, score = -0.52240\n",
            "sigma = 1000.00000, lambda = 10.00000, score = -0.51368\n",
            "sigma = 1000.00000, lambda = 100.00000, score = -0.38217\n",
            "sigma = 1000.00000, lambda = 1000.00000, score = -0.08624\n",
            "sigma = 1000.00000, lambda = 10000.00000, score = -0.00974\n",
            "sigma = 1000.00000, lambda = 100000.00000, score = -0.00099\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 = 3.58863\n",
            "sigma = 10000.00000, lambda = 0.01000, score = -0.49929\n",
            "sigma = 10000.00000, lambda = 0.10000, score = -0.50018\n",
            "sigma = 10000.00000, lambda = 1.00000, score = -0.50013\n",
            "sigma = 10000.00000, lambda = 10.00000, score = -0.49602\n",
            "sigma = 10000.00000, lambda = 100.00000, score = -0.37504\n",
            "sigma = 10000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 100000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 100000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 1000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 1000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 10000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 10000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 100000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 100000000.00000, lambda = 1000.00000, score = -0.08677\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.49585\n",
            "sigma = 1000000000.00000, lambda = 100.00000, score = -0.37497\n",
            "sigma = 1000000000.00000, lambda = 1000.00000, score = -0.08677\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 = 1.000.\n",
            "Optimizing theta...\n",
            "Approximate alpha-relative PE-divergence = 10.27\n",
            "Approximate alpha-relative KL-divergence = 2.50\n",
            "RuLSIF completed.\n",
            "Q_CRIC value: 0.8750055852700165\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": "L4",
      "machine_shape": "hm",
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
