{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "GDA_regular_Submission.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "id": "KLRtBCTxMk2q",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "aa1f25a8-f4d9-47a5-d477-1a23b38fe727"
      },
      "source": [
        "!pip3 install optuna\n",
        "!pip install geomloss[full]\n",
        "!pip3 install nflows"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Requirement already satisfied: optuna in /usr/local/lib/python3.7/dist-packages (2.10.0)\n",
            "Requirement already satisfied: sqlalchemy>=1.1.0 in /usr/local/lib/python3.7/dist-packages (from optuna) (1.4.25)\n",
            "Requirement already satisfied: alembic in /usr/local/lib/python3.7/dist-packages (from optuna) (1.7.3)\n",
            "Requirement already satisfied: colorlog in /usr/local/lib/python3.7/dist-packages (from optuna) (6.4.1)\n",
            "Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.7/dist-packages (from optuna) (21.0)\n",
            "Requirement already satisfied: cmaes>=0.8.2 in /usr/local/lib/python3.7/dist-packages (from optuna) (0.8.2)\n",
            "Requirement already satisfied: cliff in /usr/local/lib/python3.7/dist-packages (from optuna) (3.9.0)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from optuna) (1.19.5)\n",
            "Requirement already satisfied: tqdm in /usr/local/lib/python3.7/dist-packages (from optuna) (4.62.3)\n",
            "Requirement already satisfied: PyYAML in /usr/local/lib/python3.7/dist-packages (from optuna) (3.13)\n",
            "Requirement already satisfied: scipy!=1.4.0 in /usr/local/lib/python3.7/dist-packages (from optuna) (1.4.1)\n",
            "Requirement already satisfied: pyparsing>=2.0.2 in /usr/local/lib/python3.7/dist-packages (from packaging>=20.0->optuna) (2.4.7)\n",
            "Requirement already satisfied: importlib-metadata in /usr/local/lib/python3.7/dist-packages (from sqlalchemy>=1.1.0->optuna) (4.8.1)\n",
            "Requirement already satisfied: greenlet!=0.4.17 in /usr/local/lib/python3.7/dist-packages (from sqlalchemy>=1.1.0->optuna) (1.1.2)\n",
            "Requirement already satisfied: Mako in /usr/local/lib/python3.7/dist-packages (from alembic->optuna) (1.1.5)\n",
            "Requirement already satisfied: importlib-resources in /usr/local/lib/python3.7/dist-packages (from alembic->optuna) (5.2.2)\n",
            "Requirement already satisfied: PrettyTable>=0.7.2 in /usr/local/lib/python3.7/dist-packages (from cliff->optuna) (2.2.1)\n",
            "Requirement already satisfied: cmd2>=1.0.0 in /usr/local/lib/python3.7/dist-packages (from cliff->optuna) (2.2.0)\n",
            "Requirement already satisfied: pbr!=2.1.0,>=2.0.0 in /usr/local/lib/python3.7/dist-packages (from cliff->optuna) (5.6.0)\n",
            "Requirement already satisfied: autopage>=0.4.0 in /usr/local/lib/python3.7/dist-packages (from cliff->optuna) (0.4.0)\n",
            "Requirement already satisfied: stevedore>=2.0.1 in /usr/local/lib/python3.7/dist-packages (from cliff->optuna) (3.4.0)\n",
            "Requirement already satisfied: wcwidth>=0.1.7 in /usr/local/lib/python3.7/dist-packages (from cmd2>=1.0.0->cliff->optuna) (0.2.5)\n",
            "Requirement already satisfied: colorama>=0.3.7 in /usr/local/lib/python3.7/dist-packages (from cmd2>=1.0.0->cliff->optuna) (0.4.4)\n",
            "Requirement already satisfied: attrs>=16.3.0 in /usr/local/lib/python3.7/dist-packages (from cmd2>=1.0.0->cliff->optuna) (21.2.0)\n",
            "Requirement already satisfied: pyperclip>=1.6 in /usr/local/lib/python3.7/dist-packages (from cmd2>=1.0.0->cliff->optuna) (1.8.2)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from cmd2>=1.0.0->cliff->optuna) (3.7.4.3)\n",
            "Requirement already satisfied: zipp>=0.5 in /usr/local/lib/python3.7/dist-packages (from importlib-metadata->sqlalchemy>=1.1.0->optuna) (3.6.0)\n",
            "Requirement already satisfied: MarkupSafe>=0.9.2 in /usr/local/lib/python3.7/dist-packages (from Mako->alembic->optuna) (2.0.1)\n",
            "Requirement already satisfied: geomloss[full] in /usr/local/lib/python3.7/dist-packages (0.2.4)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from geomloss[full]) (1.19.5)\n",
            "Requirement already satisfied: cmake>=3.18 in /usr/local/lib/python3.7/dist-packages (from geomloss[full]) (3.21.3)\n",
            "Requirement already satisfied: pykeops[full] in /usr/local/lib/python3.7/dist-packages (from geomloss[full]) (1.5)\n",
            "Requirement already satisfied: sphinxcontrib-httpdomain in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (1.8.0)\n",
            "Requirement already satisfied: gpytorch in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (1.5.1)\n",
            "Requirement already satisfied: sphinx in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (4.2.0)\n",
            "Requirement already satisfied: scikit-learn in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (0.22.2.post1)\n",
            "Requirement already satisfied: sphinx-rtd-theme in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (1.0.0)\n",
            "Requirement already satisfied: recommonmark in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (0.7.1)\n",
            "Requirement already satisfied: torch in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (1.9.0+cu102)\n",
            "Requirement already satisfied: imageio in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (2.4.1)\n",
            "Requirement already satisfied: sphinx-gallery in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (0.10.0)\n",
            "Requirement already satisfied: breathe in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (4.31.0)\n",
            "Requirement already satisfied: matplotlib in /usr/local/lib/python3.7/dist-packages (from pykeops[full]->geomloss[full]) (3.2.2)\n",
            "Requirement already satisfied: docutils>=0.12 in /usr/local/lib/python3.7/dist-packages (from breathe->pykeops[full]->geomloss[full]) (0.17.1)\n",
            "Requirement already satisfied: alabaster<0.8,>=0.7 in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (0.7.12)\n",
            "Requirement already satisfied: Jinja2>=2.3 in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (2.11.3)\n",
            "Requirement already satisfied: snowballstemmer>=1.1 in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (2.1.0)\n",
            "Requirement already satisfied: sphinxcontrib-htmlhelp>=2.0.0 in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (2.0.0)\n",
            "Requirement already satisfied: sphinxcontrib-serializinghtml>=1.1.5 in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (1.1.5)\n",
            "Requirement already satisfied: sphinxcontrib-qthelp in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (1.0.3)\n",
            "Requirement already satisfied: setuptools in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (57.4.0)\n",
            "Requirement already satisfied: babel>=1.3 in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (2.9.1)\n",
            "Requirement already satisfied: imagesize in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (1.2.0)\n",
            "Requirement already satisfied: sphinxcontrib-devhelp in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (1.0.2)\n",
            "Requirement already satisfied: requests>=2.5.0 in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (2.23.0)\n",
            "Requirement already satisfied: sphinxcontrib-applehelp in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (1.0.2)\n",
            "Requirement already satisfied: packaging in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (21.0)\n",
            "Requirement already satisfied: sphinxcontrib-jsmath in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (1.0.1)\n",
            "Requirement already satisfied: Pygments>=2.0 in /usr/local/lib/python3.7/dist-packages (from sphinx->pykeops[full]->geomloss[full]) (2.6.1)\n",
            "Requirement already satisfied: pytz>=2015.7 in /usr/local/lib/python3.7/dist-packages (from babel>=1.3->sphinx->pykeops[full]->geomloss[full]) (2018.9)\n",
            "Requirement already satisfied: MarkupSafe>=0.23 in /usr/local/lib/python3.7/dist-packages (from Jinja2>=2.3->sphinx->pykeops[full]->geomloss[full]) (2.0.1)\n",
            "Requirement already satisfied: chardet<4,>=3.0.2 in /usr/local/lib/python3.7/dist-packages (from requests>=2.5.0->sphinx->pykeops[full]->geomloss[full]) (3.0.4)\n",
            "Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.7/dist-packages (from requests>=2.5.0->sphinx->pykeops[full]->geomloss[full]) (1.24.3)\n",
            "Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.7/dist-packages (from requests>=2.5.0->sphinx->pykeops[full]->geomloss[full]) (2021.5.30)\n",
            "Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.7/dist-packages (from requests>=2.5.0->sphinx->pykeops[full]->geomloss[full]) (2.10)\n",
            "Requirement already satisfied: scipy in /usr/local/lib/python3.7/dist-packages (from gpytorch->pykeops[full]->geomloss[full]) (1.4.1)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from torch->pykeops[full]->geomloss[full]) (3.7.4.3)\n",
            "Requirement already satisfied: pillow in /usr/local/lib/python3.7/dist-packages (from imageio->pykeops[full]->geomloss[full]) (7.1.2)\n",
            "Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->pykeops[full]->geomloss[full]) (2.4.7)\n",
            "Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->pykeops[full]->geomloss[full]) (1.3.2)\n",
            "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.7/dist-packages (from matplotlib->pykeops[full]->geomloss[full]) (0.10.0)\n",
            "Requirement already satisfied: python-dateutil>=2.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->pykeops[full]->geomloss[full]) (2.8.2)\n",
            "Requirement already satisfied: six in /usr/local/lib/python3.7/dist-packages (from cycler>=0.10->matplotlib->pykeops[full]->geomloss[full]) (1.15.0)\n",
            "Requirement already satisfied: commonmark>=0.8.1 in /usr/local/lib/python3.7/dist-packages (from recommonmark->pykeops[full]->geomloss[full]) (0.9.1)\n",
            "Requirement already satisfied: joblib>=0.11 in /usr/local/lib/python3.7/dist-packages (from scikit-learn->pykeops[full]->geomloss[full]) (1.0.1)\n",
            "Requirement already satisfied: nflows in /usr/local/lib/python3.7/dist-packages (0.14)\n",
            "Requirement already satisfied: tqdm in /usr/local/lib/python3.7/dist-packages (from nflows) (4.62.3)\n",
            "Requirement already satisfied: torch in /usr/local/lib/python3.7/dist-packages (from nflows) (1.9.0+cu102)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from nflows) (1.19.5)\n",
            "Requirement already satisfied: tensorboard in /usr/local/lib/python3.7/dist-packages (from nflows) (2.6.0)\n",
            "Requirement already satisfied: matplotlib in /usr/local/lib/python3.7/dist-packages (from nflows) (3.2.2)\n",
            "Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->nflows) (1.3.2)\n",
            "Requirement already satisfied: python-dateutil>=2.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->nflows) (2.8.2)\n",
            "Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->nflows) (2.4.7)\n",
            "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.7/dist-packages (from matplotlib->nflows) (0.10.0)\n",
            "Requirement already satisfied: six in /usr/local/lib/python3.7/dist-packages (from cycler>=0.10->matplotlib->nflows) (1.15.0)\n",
            "Requirement already satisfied: tensorboard-plugin-wit>=1.6.0 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (1.8.0)\n",
            "Requirement already satisfied: wheel>=0.26 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (0.37.0)\n",
            "Requirement already satisfied: google-auth<2,>=1.6.3 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (1.35.0)\n",
            "Requirement already satisfied: werkzeug>=0.11.15 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (1.0.1)\n",
            "Requirement already satisfied: google-auth-oauthlib<0.5,>=0.4.1 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (0.4.6)\n",
            "Requirement already satisfied: tensorboard-data-server<0.7.0,>=0.6.0 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (0.6.1)\n",
            "Requirement already satisfied: requests<3,>=2.21.0 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (2.23.0)\n",
            "Requirement already satisfied: absl-py>=0.4 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (0.12.0)\n",
            "Requirement already satisfied: markdown>=2.6.8 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (3.3.4)\n",
            "Requirement already satisfied: setuptools>=41.0.0 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (57.4.0)\n",
            "Requirement already satisfied: grpcio>=1.24.3 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (1.41.0)\n",
            "Requirement already satisfied: protobuf>=3.6.0 in /usr/local/lib/python3.7/dist-packages (from tensorboard->nflows) (3.17.3)\n",
            "Requirement already satisfied: cachetools<5.0,>=2.0.0 in /usr/local/lib/python3.7/dist-packages (from google-auth<2,>=1.6.3->tensorboard->nflows) (4.2.4)\n",
            "Requirement already satisfied: rsa<5,>=3.1.4 in /usr/local/lib/python3.7/dist-packages (from google-auth<2,>=1.6.3->tensorboard->nflows) (4.7.2)\n",
            "Requirement already satisfied: pyasn1-modules>=0.2.1 in /usr/local/lib/python3.7/dist-packages (from google-auth<2,>=1.6.3->tensorboard->nflows) (0.2.8)\n",
            "Requirement already satisfied: requests-oauthlib>=0.7.0 in /usr/local/lib/python3.7/dist-packages (from google-auth-oauthlib<0.5,>=0.4.1->tensorboard->nflows) (1.3.0)\n",
            "Requirement already satisfied: importlib-metadata in /usr/local/lib/python3.7/dist-packages (from markdown>=2.6.8->tensorboard->nflows) (4.8.1)\n",
            "Requirement already satisfied: pyasn1<0.5.0,>=0.4.6 in /usr/local/lib/python3.7/dist-packages (from pyasn1-modules>=0.2.1->google-auth<2,>=1.6.3->tensorboard->nflows) (0.4.8)\n",
            "Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.7/dist-packages (from requests<3,>=2.21.0->tensorboard->nflows) (2.10)\n",
            "Requirement already satisfied: chardet<4,>=3.0.2 in /usr/local/lib/python3.7/dist-packages (from requests<3,>=2.21.0->tensorboard->nflows) (3.0.4)\n",
            "Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.7/dist-packages (from requests<3,>=2.21.0->tensorboard->nflows) (2021.5.30)\n",
            "Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.7/dist-packages (from requests<3,>=2.21.0->tensorboard->nflows) (1.24.3)\n",
            "Requirement already satisfied: oauthlib>=3.0.0 in /usr/local/lib/python3.7/dist-packages (from requests-oauthlib>=0.7.0->google-auth-oauthlib<0.5,>=0.4.1->tensorboard->nflows) (3.1.1)\n",
            "Requirement already satisfied: zipp>=0.5 in /usr/local/lib/python3.7/dist-packages (from importlib-metadata->markdown>=2.6.8->tensorboard->nflows) (3.6.0)\n",
            "Requirement already satisfied: typing-extensions>=3.6.4 in /usr/local/lib/python3.7/dist-packages (from importlib-metadata->markdown>=2.6.8->tensorboard->nflows) (3.7.4.3)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "lCqod6vJMwb4"
      },
      "source": [
        "#import required packages\n",
        "import numpy as np\n",
        "import math\n",
        "import torch\n",
        "import torch.nn as nn\n",
        "from torch.optim import Adam\n",
        "import matplotlib.pyplot as plt\n",
        "import torch.nn.functional as F\n",
        "from torch import autograd\n",
        "import pdb\n",
        "import torch.distributions as distrib\n",
        "import torch.distributions.transforms as transform\n",
        "from torch import optim\n",
        "import optuna\n",
        "from geomloss import SamplesLoss\n",
        "import time\n",
        "from torch.distributions.normal import Normal\n",
        "import seaborn as sns\n",
        "from google.colab import files\n",
        "\n",
        "from nflows.flows.base import Flow\n",
        "from nflows.distributions.normal import StandardNormal\n",
        "from nflows.transforms.base import CompositeTransform\n",
        "from nflows.transforms.autoregressive import MaskedAffineAutoregressiveTransform\n",
        "from nflows.flows import autoregressive as ar\n",
        "from nflows.transforms.permutations import ReversePermutation\n",
        "from nflows.flows import realnvp"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "FujzVntYM0ZT"
      },
      "source": [
        "#KFAC Code - Adapted from https://github.com/alecwangcq/KFAC-Pytorch/blob/master/optimizers/kfac.py\n",
        "def try_contiguous(x):\n",
        "    if not x.is_contiguous():\n",
        "        x = x.contiguous()\n",
        "\n",
        "    return x\n",
        "\n",
        "def _extract_patches(x, kernel_size, stride, padding):\n",
        "    \"\"\"\n",
        "    :param x: The input feature maps.  (batch_size, in_c, h, w)\n",
        "    :param kernel_size: the kernel size of the conv filter (tuple of two elements)\n",
        "    :param stride: the stride of conv operation  (tuple of two elements)\n",
        "    :param padding: number of paddings. be a tuple of two elements\n",
        "    :return: (batch_size, out_h, out_w, in_c*kh*kw)\n",
        "    \"\"\"\n",
        "    if padding[0] + padding[1] > 0:\n",
        "        x = F.pad(x, (padding[1], padding[1], padding[0],\n",
        "                      padding[0])).data  \n",
        "    x = x.unfold(2, kernel_size[0], stride[0])\n",
        "    x = x.unfold(3, kernel_size[1], stride[1])\n",
        "    x = x.transpose_(1, 2).transpose_(2, 3).contiguous()\n",
        "    x = x.view(\n",
        "        x.size(0), x.size(1), x.size(2),\n",
        "        x.size(3) * x.size(4) * x.size(5))\n",
        "    return x\n",
        "\n",
        "\n",
        "def update_running_stat(aa, m_aa, stat_decay):\n",
        "    # using inplace operation to save memory!\n",
        "    m_aa *= stat_decay / (1 - stat_decay)\n",
        "    m_aa += aa\n",
        "    m_aa *= (1 - stat_decay)\n",
        "\n",
        "\n",
        "class ComputeMatGrad:\n",
        "\n",
        "    @classmethod\n",
        "    def __call__(cls, input, grad_output, layer):\n",
        "        if isinstance(layer, nn.Linear):\n",
        "            grad = cls.linear(input, grad_output, layer)\n",
        "        elif isinstance(layer, nn.Conv2d):\n",
        "            grad = cls.conv2d(input, grad_output, layer)\n",
        "        else:\n",
        "            raise NotImplementedError\n",
        "        return grad\n",
        "\n",
        "    @staticmethod\n",
        "    def linear(input, grad_output, layer):\n",
        "        \"\"\"\n",
        "        :param input: batch_size * input_dim\n",
        "        :param grad_output: batch_size * output_dim\n",
        "        :param layer: [nn.module] output_dim * input_dim\n",
        "        :return: batch_size * output_dim * (input_dim + [1 if with bias])\n",
        "        \"\"\"\n",
        "        with torch.no_grad():\n",
        "            if layer.bias is not None:\n",
        "                input = torch.cat([input, input.new(input.size(0), 1).fill_(1)], 1)\n",
        "            input = input.unsqueeze(1)\n",
        "            grad_output = grad_output.unsqueeze(2)\n",
        "            grad = torch.bmm(grad_output, input)\n",
        "        return grad\n",
        "\n",
        "    @staticmethod\n",
        "    def conv2d(input, grad_output, layer):\n",
        "        \"\"\"\n",
        "        :param input: batch_size * in_c * in_h * in_w\n",
        "        :param grad_output: batch_size * out_c * h * w\n",
        "        :param layer: nn.module batch_size * out_c * (in_c*k_h*k_w + [1 if with bias])\n",
        "        :return:\n",
        "        \"\"\"\n",
        "        with torch.no_grad():\n",
        "            input = _extract_patches(input, layer.kernel_size, layer.stride, layer.padding)\n",
        "            input = input.view(-1, input.size(-1))\n",
        "            grad_output = grad_output.transpose(1, 2).transpose(2, 3)\n",
        "            grad_output = try_contiguous(grad_output).view(grad_output.size(0), -1, grad_output.size(-1))\n",
        "\n",
        "            if layer.bias is not None:\n",
        "                input = torch.cat([input, input.new(input.size(0), 1).fill_(1)], 1)\n",
        "            input = input.view(grad_output.size(0), -1, input.size(-1))  \n",
        "            grad = torch.einsum('abm,abn->amn', (grad_output, input))\n",
        "        return grad\n",
        "\n",
        "\n",
        "class ComputeCovA:\n",
        "\n",
        "    @classmethod\n",
        "    def compute_cov_a(cls, a, layer):\n",
        "        return cls.__call__(a, layer)\n",
        "\n",
        "    @classmethod\n",
        "    def __call__(cls, a, layer):\n",
        "        if isinstance(layer, nn.Linear):\n",
        "            cov_a = cls.linear(a, layer)\n",
        "        elif isinstance(layer, nn.Conv2d):\n",
        "            cov_a = cls.conv2d(a, layer)\n",
        "        else:\n",
        "            # FIXME(CW): for extension to other layers.\n",
        "            # raise NotImplementedError\n",
        "            cov_a = None\n",
        "\n",
        "        return cov_a\n",
        "\n",
        "    @staticmethod\n",
        "    def conv2d(a, layer):\n",
        "        batch_size = a.size(0)\n",
        "        a = _extract_patches(a, layer.kernel_size, layer.stride, layer.padding)\n",
        "        spatial_size = a.size(1) * a.size(2)\n",
        "        a = a.view(-1, a.size(-1))\n",
        "        if layer.bias is not None:\n",
        "            a = torch.cat([a, a.new(a.size(0), 1).fill_(1)], 1)\n",
        "        a = a/spatial_size\n",
        "        # FIXME(CW): do we need to divide the output feature map's size?\n",
        "        return a.t() @ (a / batch_size)\n",
        "\n",
        "    @staticmethod\n",
        "    def linear(a, layer):\n",
        "        batch_size = a.size(0)\n",
        "        if layer.bias is not None:\n",
        "            a = torch.cat([a, a.new(a.size(0), 1).fill_(1)], 1)\n",
        "        return a.t() @ (a / batch_size)\n",
        "\n",
        "\n",
        "class ComputeCovG:\n",
        "\n",
        "    @classmethod\n",
        "    def compute_cov_g(cls, g, layer, batch_averaged=False):\n",
        "        \"\"\"\n",
        "        :param g: gradient\n",
        "        :param layer: the corresponding layer\n",
        "        :param batch_averaged: if the gradient is already averaged with the batch size?\n",
        "        :return:\n",
        "        \"\"\"\n",
        "        return cls.__call__(g, layer, batch_averaged)\n",
        "\n",
        "    @classmethod\n",
        "    def __call__(cls, g, layer, batch_averaged):\n",
        "        if isinstance(layer, nn.Conv2d):\n",
        "            cov_g = cls.conv2d(g, layer, batch_averaged)\n",
        "        elif isinstance(layer, nn.Linear):\n",
        "            cov_g = cls.linear(g, layer, batch_averaged)\n",
        "        else:\n",
        "            cov_g = None\n",
        "\n",
        "        return cov_g\n",
        "\n",
        "    @staticmethod\n",
        "    def conv2d(g, layer, batch_averaged):\n",
        "        spatial_size = g.size(2) * g.size(3)\n",
        "        batch_size = g.shape[0]\n",
        "        g = g.transpose(1, 2).transpose(2, 3)\n",
        "        g = try_contiguous(g)\n",
        "        g = g.view(-1, g.size(-1))\n",
        "\n",
        "        if batch_averaged:\n",
        "            g = g * batch_size\n",
        "        g = g * spatial_size\n",
        "        cov_g = g.t() @ (g / g.size(0))\n",
        "\n",
        "        return cov_g\n",
        "\n",
        "    @staticmethod\n",
        "    def linear(g, layer, batch_averaged):\n",
        "        batch_size = g.size(0)\n",
        "\n",
        "        if batch_averaged:\n",
        "            cov_g = g.t() @ (g * batch_size)\n",
        "        else:\n",
        "            cov_g = g.t() @ (g / batch_size)\n",
        "        return cov_g\n",
        "\n",
        "class KFACOptimizer(optim.Optimizer):\n",
        "    def __init__(self,\n",
        "                 model,\n",
        "                 lr=0.001,\n",
        "                 momentum=0.9,\n",
        "                 stat_decay=0.95,\n",
        "                 damping=0.001,\n",
        "                 kl_clip=0.001,\n",
        "                 weight_decay=0,\n",
        "                 TCov=10,\n",
        "                 TInv=100,\n",
        "                 batch_averaged=True):\n",
        "        if lr < 0.0:\n",
        "            raise ValueError(\"Invalid learning rate: {}\".format(lr))\n",
        "        if momentum < 0.0:\n",
        "            raise ValueError(\"Invalid momentum value: {}\".format(momentum))\n",
        "        if weight_decay < 0.0:\n",
        "            raise ValueError(\"Invalid weight_decay value: {}\".format(weight_decay))\n",
        "        defaults = dict(lr=lr, momentum=momentum, damping=damping,\n",
        "                        weight_decay=weight_decay)\n",
        "        super(KFACOptimizer, self).__init__(model.parameters(), defaults)\n",
        "        self.CovAHandler = ComputeCovA()\n",
        "        self.CovGHandler = ComputeCovG()\n",
        "        self.batch_averaged = batch_averaged\n",
        "\n",
        "        self.known_modules = {'Linear', 'Conv2d'}\n",
        "\n",
        "        self.modules = []\n",
        "        self.grad_outputs = {}\n",
        "\n",
        "        self.model = model\n",
        "        \n",
        "        self._prepare_model()\n",
        "\n",
        "        self.steps = 0\n",
        "\n",
        "        self.m_aa, self.m_gg = {}, {}\n",
        "        self.Q_a, self.Q_g = {}, {}\n",
        "        self.d_a, self.d_g = {}, {}\n",
        "        self.stat_decay = stat_decay\n",
        "\n",
        "        self.kl_clip = kl_clip\n",
        "        self.TCov = TCov\n",
        "        self.TInv = TInv\n",
        "\n",
        "    def _save_input(self, module, input):\n",
        "        if torch.is_grad_enabled() and self.steps % self.TCov == 0:\n",
        "            aa = self.CovAHandler(input[0].data, module)\n",
        "            # Initialize buffers\n",
        "            if self.steps == 0:\n",
        "                self.m_aa[module] = torch.diag(aa.new(aa.size(0)).fill_(1))\n",
        "            update_running_stat(aa, self.m_aa[module], self.stat_decay)\n",
        "\n",
        "    def _save_grad_output(self, module, grad_input, grad_output):\n",
        "        # Accumulate statistics for Fisher matrices\n",
        "        if self.acc_stats and self.steps % self.TCov == 0:\n",
        "            gg = self.CovGHandler(grad_output[0].data, module, self.batch_averaged)\n",
        "            # Initialize buffers\n",
        "            if self.steps == 0:\n",
        "                self.m_gg[module] = torch.diag(gg.new(gg.size(0)).fill_(1))\n",
        "            update_running_stat(gg, self.m_gg[module], self.stat_decay)\n",
        "\n",
        "    def _prepare_model(self):\n",
        "        count = 0\n",
        "        print(\"=> We keep following layers in KFAC. \")\n",
        "        for module in self.model.modules():\n",
        "            classname = module.__class__.__name__\n",
        "            if classname in self.known_modules:\n",
        "                self.modules.append(module)\n",
        "                module.register_forward_pre_hook(self._save_input)\n",
        "                module.register_backward_hook(self._save_grad_output)\n",
        "                count += 1\n",
        "\n",
        "    def _update_inv(self, m):\n",
        "        \"\"\"Do eigen decomposition for computing inverse of the ~ fisher.\n",
        "        :param m: The layer\n",
        "        :return: no returns.\n",
        "        \"\"\"\n",
        "        eps = 1e-10  # for numerical stability\n",
        "        self.d_a[m], self.Q_a[m] = torch.symeig(\n",
        "            self.m_aa[m], eigenvectors=True)\n",
        "        self.d_g[m], self.Q_g[m] = torch.symeig(\n",
        "            self.m_gg[m], eigenvectors=True)\n",
        "\n",
        "        self.d_a[m] = self.d_a[m] + 1e-6\n",
        "        self.d_g[m] = self.d_g[m] + 1e-6\n",
        "        self.d_a[m].mul_((self.d_a[m] > eps).float())\n",
        "        self.d_g[m].mul_((self.d_g[m] > eps).float())\n",
        "        \n",
        "\n",
        "    @staticmethod\n",
        "    def _get_matrix_form_grad(m, classname):\n",
        "        \"\"\"\n",
        "        :param m: the layer\n",
        "        :param classname: the class name of the layer\n",
        "        :return: a matrix form of the gradient. it should be a [output_dim, input_dim] matrix.\n",
        "        \"\"\"\n",
        "        if classname == 'Conv2d':\n",
        "            p_grad_mat = m.weight.grad.data.view(m.weight.grad.data.size(0), -1)\n",
        "        else:\n",
        "            p_grad_mat = m.weight.grad.data\n",
        "        if m.bias is not None:\n",
        "            p_grad_mat = torch.cat([p_grad_mat, m.bias.grad.data.view(-1, 1)], 1)\n",
        "        return p_grad_mat\n",
        "\n",
        "    def _get_natural_grad(self, m, p_grad_mat, damping):\n",
        "        \"\"\"\n",
        "        :param m:  the layer\n",
        "        :param p_grad_mat: the gradients in matrix form\n",
        "        :return: a list of gradients w.r.t to the parameters in `m`\n",
        "        \"\"\"\n",
        "        v1 = self.Q_g[m].t() @ p_grad_mat @ self.Q_a[m]\n",
        "        v2 = v1 / (self.d_g[m].unsqueeze(1) * self.d_a[m].unsqueeze(0) + damping)\n",
        "        v = self.Q_g[m] @ v2 @ self.Q_a[m].t()\n",
        "        if m.bias is not None:\n",
        "            # we always put gradient w.r.t weight in [0]\n",
        "            # and w.r.t bias in [1]\n",
        "            v = [v[:, :-1], v[:, -1:]]\n",
        "            v[0] = v[0].view(m.weight.grad.data.size())\n",
        "            v[1] = v[1].view(m.bias.grad.data.size())\n",
        "        else:\n",
        "            v = [v.view(m.weight.grad.data.size())]\n",
        "\n",
        "        return v\n",
        "\n",
        "    def _kl_clip_and_update_grad(self, updates, lr):\n",
        "        # do kl clip\n",
        "        vg_sum = 0\n",
        "        eps = 1e-10  # for numerical stability\n",
        "        for m in self.modules:\n",
        "            v = updates[m]\n",
        "            vg_sum += (v[0] * m.weight.grad.data * lr ** 2).sum().item()\n",
        "            if m.bias is not None:\n",
        "                vg_sum += (v[1] * m.bias.grad.data * lr ** 2).sum().item()\n",
        "        nu = min(1.0, math.sqrt(self.kl_clip / (vg_sum + eps)))\n",
        "\n",
        "        for m in self.modules:\n",
        "            v = updates[m]\n",
        "            m.weight.grad.data.copy_(v[0])\n",
        "            m.weight.grad.data.mul_(nu)\n",
        "            if m.bias is not None:\n",
        "                m.bias.grad.data.copy_(v[1])\n",
        "                m.bias.grad.data.mul_(nu)\n",
        "\n",
        "    def _step(self, closure):\n",
        "        for group in self.param_groups:\n",
        "            weight_decay = group['weight_decay']\n",
        "            momentum = group['momentum']\n",
        "\n",
        "            for p in group['params']:\n",
        "                if p.grad is None:\n",
        "                    continue\n",
        "                d_p = p.grad.data\n",
        "                if weight_decay != 0 and self.steps >= 20 * self.TCov:\n",
        "                    d_p.add_(weight_decay, p.data)\n",
        "                if momentum != 0:\n",
        "                    param_state = self.state[p]\n",
        "                    if 'momentum_buffer' not in param_state:\n",
        "                        buf = param_state['momentum_buffer'] = torch.zeros_like(p.data)\n",
        "                        buf.mul_(momentum).add_(d_p)\n",
        "                    else:\n",
        "                        buf = param_state['momentum_buffer']\n",
        "                        buf.mul_(momentum).add_(1, d_p)\n",
        "                    d_p = buf\n",
        "\n",
        "                p.data.add_(-group['lr'], d_p)\n",
        "\n",
        "    #Decouple KFAC matrices from loss gradient\n",
        "    def pre_step(self):\n",
        "        # FIXME(CW): temporal fix for compatibility with Official LR scheduler.\n",
        "        group = self.param_groups[0]\n",
        "        lr = group['lr']\n",
        "        damping = group['damping']\n",
        "        updates = {}\n",
        "        for m in self.modules:\n",
        "            classname = m.__class__.__name__\n",
        "            if self.steps % self.TInv == 0:\n",
        "                self._update_inv(m)\n",
        "        \n",
        "    def step(self, closure=None):\n",
        "        # FIXME(CW): temporal fix for compatibility with Official LR scheduler.\n",
        "        group = self.param_groups[0]\n",
        "        lr = group['lr']\n",
        "        damping = group['damping']\n",
        "        updates = {}\n",
        "        for m in self.modules:\n",
        "            classname = m.__class__.__name__\n",
        "            p_grad_mat = self._get_matrix_form_grad(m, classname)\n",
        "            v = self._get_natural_grad(m, p_grad_mat, damping)\n",
        "            updates[m] = v\n",
        "        self._kl_clip_and_update_grad(updates, lr)\n",
        "        self.updates = updates\n",
        "        self._step(closure)\n",
        "        self.steps += 1"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "peYD9wcSM4BY"
      },
      "source": [
        "#Real NVP Normalizing Flow\n",
        "kwargs_layer = {'Linear': nn.Linear, 'Conv': nn.Conv2d}\n",
        "def standard_normal_logprob(z):\n",
        "    logZ = -0.5 * math.log(2 * math.pi)\n",
        "    return logZ - z.pow(2) / 2\n",
        "\n",
        "def create_real_nvp_blocks(input_size, hidden_size, n_blocks, n_hidden,\n",
        "                          layer_type='Linear'):\n",
        "    nets, nett = [], []\n",
        "    # Build the Flow Block by Block\n",
        "    if layer_type == 'Conv':\n",
        "        kernel_size = 3\n",
        "        stride = 1\n",
        "        padding = 1\n",
        "\n",
        "    for i in range(n_blocks):\n",
        "        block_nets = [kwargs_layer[layer_type](input_size, hidden_size)]\n",
        "        block_nett = [kwargs_layer[layer_type](input_size, hidden_size)]\n",
        "        for _ in range(n_hidden):\n",
        "            block_nets += [nn.Tanh(), kwargs_layer[layer_type](hidden_size,\n",
        "                                                               hidden_size)]\n",
        "            block_nett += [nn.Tanh(), kwargs_layer[layer_type](hidden_size,\n",
        "                                                               hidden_size)]\n",
        "        block_nets += [nn.Tanh(), kwargs_layer[layer_type](hidden_size,\n",
        "                                                           input_size)]\n",
        "        block_nett += [nn.Tanh(), kwargs_layer[layer_type](hidden_size,\n",
        "                                                           input_size)]\n",
        "        nets +=[nn.Sequential(*block_nets)]\n",
        "        nett +=[nn.Sequential(*block_nett)]\n",
        "\n",
        "    s = nets = nn.Sequential(*nets)\n",
        "    t = nett = nn.Sequential(*nett)\n",
        "    return s,t\n",
        "\n",
        "class RealNVP(nn.Module):\n",
        "    def __init__(self, n_blocks=8, n_hidden=2, hidden_size=16, layer_type='Linear'):\n",
        "        super(RealNVP, self).__init__()\n",
        "        _, self.c, self.h, self.w = 0, 1 ,1 ,2\n",
        "        self.n_blocks = int(n_blocks)\n",
        "        self.n_hidden = n_hidden\n",
        "        self.layer_type = layer_type\n",
        "        checkerboard = [[((i % 2) + j) % 2 for j in range(self.w)] for i in range(self.h)]\n",
        "        mask = torch.tensor(checkerboard).float()\n",
        "        # Reshape to (1, 1, height, width) for broadcasting with tensors of shape (B, C, H, W)\n",
        "        mask = mask.view(1, 1, self.h, self.w)\n",
        "        self.dev = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
        "        i_mask = 1 - mask\n",
        "        mask = torch.vstack([mask,i_mask]).repeat(int(self.n_blocks/2), 1, 1, 1)\n",
        "        self.s, self.t = create_real_nvp_blocks(2, hidden_size,\n",
        "                                                self.n_blocks, n_hidden, layer_type)\n",
        "        self.mask = mask\n",
        "\n",
        "    def inverse(self, z, logpz=None):\n",
        "        z = z.view(-1, self.c, self.h, self.w)\n",
        "        log_det_J, x = z.new_zeros(z.shape[0]), z\n",
        "        for i in range(0,self.n_blocks):\n",
        "            x_ = x*self.mask[i].squeeze()\n",
        "            s = self.s[i](x_)\n",
        "            t = self.t[i](x_)\n",
        "            x = x_ + (1 - self.mask[i]).squeeze() * (x * torch.exp(s) + t)\n",
        "            log_det_J += ((1-self.mask[i]).squeeze()*s).sum(dim=1)  # log det dx/du\n",
        "        return x.squeeze() if logpz is None else (z, -1*log_det_J.view(-1,1))\n",
        "\n",
        "    def forward(self, x, inverse=False):\n",
        "        if inverse:\n",
        "            return self.inverse(x)\n",
        "\n",
        "        log_det_J, z = x.new_zeros(x.shape[0]), x\n",
        "\n",
        "        for i in reversed(range(0,self.n_blocks)):\n",
        "            z_ = self.mask[i].squeeze() * z\n",
        "            s = self.s[i](z_)\n",
        "            t = self.t[i](z_)\n",
        "            z = (1 - self.mask[i]).squeeze() * (z - t) * torch.exp(-s) + z_\n",
        "            log_det_J -= ((1-self.mask[i]).squeeze()*s).sum(dim=1)\n",
        "        return z.squeeze(), log_det_J.view(-1, 1)\n",
        "\n",
        "    def log_prob(self, inputs, beta=1.):\n",
        "        z, delta_logp = self.forward(inputs)\n",
        "        z = z.view(-1, 2)\n",
        "        logpz = standard_normal_logprob(z).view(z.size(0), -1).sum(1, keepdim=True)\n",
        "        logpx = logpz + beta * delta_logp\n",
        "        return logpx, logpz, -1*delta_logp"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "8VVNrbBCM7BC"
      },
      "source": [
        "#Discriminator function\n",
        "class Discriminator(nn.Module):\n",
        "\n",
        "    def __init__(self, dim=1):\n",
        "        super().__init__()\n",
        "        self.dim = dim\n",
        "        self.layer1 = nn.Linear(dim, 32)\n",
        "        self.layer2 = nn.Linear(32,dim)\n",
        "\n",
        "    def forward(self, z):\n",
        "        z = F.relu(self.layer1(z))\n",
        "        z = torch.sigmoid(self.layer2(z))\n",
        "        return z\n",
        "\n",
        "class MyDiscriminator(nn.Module):\n",
        "    def __init__(self):\n",
        "        super().__init__()\n",
        "        self.model = nn.Sequential(\n",
        "            nn.Linear(2, 256),\n",
        "            nn.ReLU(),\n",
        "            nn.Dropout(0.3),\n",
        "            nn.Linear(256, 128),\n",
        "            nn.ReLU(),\n",
        "            nn.Dropout(0.3),\n",
        "            nn.Linear(128, 64),\n",
        "            nn.ReLU(),\n",
        "            nn.Dropout(0.3),\n",
        "            nn.Linear(64, 1),\n",
        "            nn.Sigmoid(),\n",
        "        )\n",
        "\n",
        "    def forward(self, x):\n",
        "        output = self.model(x)\n",
        "        return output\n",
        "\n",
        "      \n",
        "class MyGenerator(nn.Module):\n",
        "    def __init__(self):\n",
        "        super().__init__()\n",
        "        self.model = nn.Sequential(\n",
        "            nn.Linear(2, 16),\n",
        "            nn.ReLU(),\n",
        "            nn.Linear(16, 32),\n",
        "            nn.ReLU(),\n",
        "            nn.Linear(32, 2),\n",
        "        )\n",
        "\n",
        "    def forward(self, x):\n",
        "        output = self.model(x)\n",
        "        return output"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "PnnyJCslM9xH"
      },
      "source": [
        "#Loss functions\n",
        "criterion = nn.BCELoss(reduction='none')\n",
        "G_criterion = nn.BCELoss()\n",
        "real_label = 1.\n",
        "fake_label = 0.\n",
        "sigma = 0.01\n",
        "\n",
        "def Discriminator_Loss(batch_size, real_data, fake_data, netD):\n",
        "  real_samples_labels = torch.ones((batch_size, 1))\n",
        "  generated_samples_labels = torch.zeros((batch_size, 1))\n",
        "  label = torch.tensor([real_label]).repeat(len(real_data))\n",
        "  all_samples = torch.cat((real_data, fake_data))\n",
        "  all_samples_labels = torch.cat(\n",
        "      (real_samples_labels, generated_samples_labels)\n",
        "  )\n",
        "  grad_norm_real, grad_norm_fake = 0, 0\n",
        "  output_discriminator = netD(all_samples)\n",
        "  loss_discriminator = criterion(\n",
        "      output_discriminator, all_samples_labels)\n",
        "\n",
        "  loss_discriminator = loss_discriminator.mean()\n",
        "  loss_discriminator = loss_discriminator\n",
        "  return output_discriminator, loss_discriminator, grad_norm_real, grad_norm_fake\n",
        "\n",
        "def Generator_Loss(batch_size, fake_data, netD):\n",
        "  real_samples_labels = torch.ones((batch_size, 1))\n",
        "  output_discriminator_generated = netD(fake_data)\n",
        "  loss_generator = G_criterion(\n",
        "      output_discriminator_generated, real_samples_labels\n",
        "  )\n",
        "  return loss_generator\n",
        "\n",
        "#Plot sine wave learned by G\n",
        "def plot_G(generator, t):\n",
        "  plt.clf()\n",
        "  plt.cla()\n",
        "  latent_space_samples = torch.randn(200, 2)#.cuda()\n",
        "  generated_samples = generator(latent_space_samples)[0]\n",
        "  generated_samples = generated_samples.detach().cpu().numpy()\n",
        "  plt.xlim([0, 6])\n",
        "  plt.ylim([-1, 1])\n",
        "  colors = sns.color_palette('colorblind', n_colors=2)\n",
        "  plt.plot(generated_samples[:, 0], generated_samples[:, 1], \".\")\n",
        "  if t % 100 == 0:\n",
        "    namestr = 'iteration'+ str(t) + '.pdf'\n",
        "    plt.savefig(namestr)\n",
        "    files.download(namestr)\n",
        "\n",
        "\n",
        "def plot2(l_L, y_label='Lyapunov value'):\n",
        "  fig = plt.figure(figsize=(12, 8))\n",
        "  ax = plt.subplot()\n",
        "\n",
        "  for label in (ax.get_xticklabels()):\n",
        "      label.set_fontname('Arial')\n",
        "      label.set_fontsize(20)\n",
        "  for label in (ax.get_yticklabels()):\n",
        "      label.set_fontname('Arial')\n",
        "      label.set_fontsize(20)\n",
        "\n",
        "  plt.ticklabel_format(style='sci', axis='y', scilimits=(0, 0))\n",
        "  my_l_L = np.stack(l_L).squeeze()\n",
        "  ax.xaxis.get_offset_text().set_fontsize(5)\n",
        "  ax.yaxis.get_offset_text().set_fontsize(5)\n",
        "  axis_font = {'fontname': 'Arial', 'size': '24'}\n",
        "  colors = sns.color_palette('colorblind', n_colors=2)\n",
        "  ax.set_xlabel('Number of Iterations', **axis_font)\n",
        "  ax.set_ylabel(y_label, **axis_font)\n",
        "  plt.plot(np.arange(len(my_l_L)), my_l_L)\n",
        "  namestr = y_label + '.pdf'\n",
        "  plt.savefig(namestr)\n",
        "  files.download(namestr)\n",
        "def D_kfac_grads(output_D, d_kfac_opt):\n",
        "    d_kfac_opt.zero_grad()\n",
        "    d_kfac_opt.acc_stats = True    \n",
        "    output_D.mean().backward(retain_graph=True)\n",
        "\n",
        "def G_kfac_grads(batch, g_kfac_opt, netG):\n",
        "    g_kfac_opt.acc_stats = True \n",
        "    g_real_prob = -1*netG.log_prob(batch)[0]\n",
        "    g_real_prob.mean().backward(retain_graph=True)\n",
        "\n",
        "def Lyapunov_value(i, train_loader, generator, discriminator):\n",
        "    with torch.no_grad():\n",
        "      x_real = train_loader.dataset\n",
        "      x_real = torch.stack(list(zip(*x_real))[0], dim=0)\n",
        "      num_real_points = x_real.shape[0]\n",
        "      noise_samples = torch.randn((num_real_points, 2))\n",
        "      \n",
        "      x_fake = generator(noise_samples)[0].view(-1,2)\n",
        "      x_all = torch.vstack([x_real,x_fake])\n",
        "\n",
        "      output_discriminator = discriminator(x_all)\n",
        "      sum_one = output_discriminator.squeeze() - 0.5\n",
        "      \n",
        "      sum_one = torch.pow(sum_one, 2).mean()\n",
        "\n",
        "      gaussian_exp = torch.exp(-0.5*torch.pow(torch.sin(x_all[:, 0]) - x_all[:, 1] / torch.tensor(sigma), 2))\n",
        "      gaussian_const = 1./ (sigma * torch.sqrt(torch.tensor(2*math.pi))) \n",
        "      const = 1./(2*math.pi)\n",
        "      g_star = gaussian_const * 1./torch.sqrt(1. + torch.pow(torch.cos(x_all[:,0]), 2)) * gaussian_exp\n",
        "      sum_two = const * 1./torch.sqrt(1. + torch.pow(torch.cos(x_real[:,0]), 2)) - generator.log_prob(x_real)[0].exp().squeeze()\n",
        "      sum_two = g_star.squeeze() - generator.log_prob(x_all)[0].exp().squeeze()\n",
        "      sum_two = torch.pow(sum_two, 2).mean()\n",
        "      sum = sum_one + sum_two\n",
        "      print(\"Lyapunov value at %f timestep %d\" %(sum, i))\n",
        "    return sum.item(), sum_one.item(), sum_two.item()\n",
        "    \n",
        "    "
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "yKZYxRXwM96c"
      },
      "source": [
        "from matplotlib import cm\n",
        "from torch.distributions.multivariate_normal import MultivariateNormal\n",
        "\n",
        "def plot_density(flow_G):\n",
        "  plt.clf()\n",
        "  plt.cla()\n",
        "  eps = 1e-2\n",
        "  xline = torch.linspace(-1, 1, steps = 1000)\n",
        "  yline = torch.linspace(-1, 1, steps = 1000)\n",
        "  xgrid, ygrid = torch.meshgrid(xline, yline)\n",
        "  xyinput = torch.cat([xgrid.reshape(-1, 1), ygrid.reshape(-1, 1)], dim=1)\n",
        "  sigma = 0.01\n",
        "  with torch.no_grad():\n",
        "    gaussian_exp = torch.exp(-0.5*torch.pow(torch.sin(xyinput[:, 0]) - xyinput[:, 1] / torch.tensor(sigma), 2))\n",
        "    gaussian_const = 1./ (sigma * torch.sqrt(torch.tensor(2*math.pi))) \n",
        "    const = 1./(2*math.pi)\n",
        "    g_star = gaussian_const * 1./torch.sqrt(1. + torch.pow(torch.cos(xyinput[:,0]), 2)) * gaussian_exp\n",
        "    mask = g_star * (torch.abs(xyinput[:, 1] - torch.sin(2*math.pi*xyinput[:, 0])) <= eps)\n",
        "\n",
        "  plt.contourf(xgrid.numpy(), ygrid.numpy(), mask.reshape(1000, 1000).numpy())\n",
        "  plt.title('Density of the Generator')\n",
        "  plt.show()\n"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "MAfEQguWNEyy",
        "outputId": "c757f5cc-c6c0-43c6-c500-6d3274fecbbd"
      },
      "source": [
        "def package_realnvp(n_blocks, input_dim, hidden_dim, num_layers):\n",
        "    flow = realnvp.SimpleRealNVP(features=input_dim,\n",
        "                                 hidden_features=hidden_dim,\n",
        "                                 num_layers=num_layers,\n",
        "                                 num_blocks_per_layer=n_blocks)\n",
        "    return flow\n",
        "\n",
        "def Run_experiment(learning_rate=0.0001, run_lyapunov=False, n_iter=150):\n",
        "  #Training Loop/Playing Loop\n",
        "  print(\"Learning Rate is %f\" %(learning_rate))\n",
        "  wasserstein = SamplesLoss(\"sinkhorn\", p=1, blur=1e-3)\n",
        "  netD = MyDiscriminator()\n",
        "  netG = RealNVP()\n",
        "  disc_opt = optim.Adam(netD.parameters(), lr=learning_rate)\n",
        "  gen_opt = optim.Adam(netG.parameters(), lr=learning_rate)\n",
        "\n",
        "  n_samples = 1024\n",
        "  n_iter = 201\n",
        "\n",
        "  #sampling real data\n",
        "  batch_size = 64\n",
        "  num_batches = int(n_samples // batch_size)\n",
        "  noise = distrib.MultivariateNormal(torch.zeros(1), torch.eye(1))\n",
        "  train_data_length = 1024\n",
        "  train_data = torch.zeros((train_data_length, 2))\n",
        "  train_data[:, 0]= 2 * math.pi * torch.rand(train_data_length)\n",
        "  y_dist = distrib.Normal(torch.sin(train_data[:, 0]), sigma*torch.ones(n_samples))\n",
        "  y_coord = y_dist.sample()\n",
        "  train_data[:, 1] = y_coord\n",
        "  train_labels = torch.zeros(n_samples)\n",
        "\n",
        "  train_set = [\n",
        "      (train_data[i], train_labels[i]) for i in range(n_samples)\n",
        "  ]\n",
        "  train_loader = torch.utils.data.DataLoader(\n",
        "      train_set, batch_size=batch_size, shuffle=True, pin_memory=True,\n",
        "  )\n",
        "\n",
        "  Lyapunov_list, wasserstein_list, d_lyap_list, g_lyap_list = [], [], [], []\n",
        "  for t in range(n_iter):\n",
        "    start_time = time.time()\n",
        "    loss_D_epoch, loss_G_epoch = 0, 0\n",
        "    for i, (real_batch, _) in enumerate(train_loader):\n",
        "      noise_samples = torch.randn((batch_size, 2))\n",
        "      real_batch = real_batch\n",
        "\n",
        "      disc_opt.zero_grad()\n",
        "      with torch.no_grad():\n",
        "        fake_batch = netG(noise_samples)[0].view(-1,2)\n",
        "\n",
        "      output_D, loss_D, grad_norm_real, grad_norm_fake = Discriminator_Loss(batch_size, real_batch, fake_batch, netD)\n",
        "\n",
        "      loss_D.backward(retain_graph=True)\n",
        "      torch.nn.utils.clip_grad_norm_(netD.parameters(), 1.)\n",
        "      disc_opt.step()\n",
        "\n",
        "      loss_D_epoch += loss_D.mean().item()\n",
        "      \n",
        "      gen_opt.zero_grad()\n",
        "      noise_samples = torch.randn((batch_size, 2))\n",
        "      fake_batch = netG(noise_samples)[0].view(-1,2)\n",
        "      prob_batch = fake_batch\n",
        "      loss_G = Generator_Loss(batch_size, fake_batch, netD)\n",
        "      loss_G.backward()\n",
        "      torch.nn.utils.clip_grad_norm_(netG.parameters(), 1.)\n",
        "      gen_opt.step()\n",
        "      loss_G_epoch += loss_G.item()\n",
        "\n",
        "    if run_lyapunov:\n",
        "      lyap, d_val, g_val = Lyapunov_value(t, train_loader, netG, netD)\n",
        "      Lyapunov_list.append(lyap)\n",
        "      d_lyap_list.append(d_val)\n",
        "      g_lyap_list.append(g_val)\n",
        "    noise_samples = torch.randn((len(train_data), 2))\n",
        "    x_fake = netG(noise_samples)[0].view(-1,2)\n",
        "    with torch.no_grad():\n",
        "      wasserstein_score = wasserstein(train_data,x_fake)\n",
        "      wasserstein_list.append(wasserstein_score)\n",
        "  \n",
        "  #PLOTTING DURING TRAINING\n",
        "    if t % 10 == 0:\n",
        "      print(\"Iteration %d\" %(t))\n",
        "      plot_G(netG, t) \n",
        "\n",
        "  plot_G(netG, t)\n",
        "  if run_lyapunov:\n",
        "    return netG, wasserstein_score, wasserstein_list, Lyapunov_list, d_lyap_list, g_lyap_list\n",
        "  else:\n",
        "    return netG, wasserstein_score\n",
        "\n",
        "\n",
        "generator, wasserstein_score, wasserstein_list, Lyapunov_list, D_list, G_list = Run_experiment(learning_rate=0.00016, run_lyapunov=True, n_iter=500)\n",
        "plot2(wasserstein_list, y_label='Wasserstein-1')\n",
        "\n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Learning Rate is 0.000160\n",
            "Lyapunov value at 3.787225 timestep 0\n",
            "Iteration 0\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "download(\"download_16f7d179-7e0c-40d0-aeeb-16b023f5d585\", \"iteration0.pdf\", 8953)"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 5.792325 timestep 1\n",
            "Lyapunov value at 7.669698 timestep 2\n",
            "Lyapunov value at 10.485244 timestep 3\n",
            "Lyapunov value at 7.701754 timestep 4\n",
            "Lyapunov value at 10.356657 timestep 5\n",
            "Lyapunov value at 7.484400 timestep 6\n",
            "Lyapunov value at 7.114512 timestep 7\n",
            "Lyapunov value at 6.611594 timestep 8\n",
            "Lyapunov value at 10.687466 timestep 9\n",
            "Lyapunov value at 12.905766 timestep 10\n",
            "Iteration 10\n",
            "Lyapunov value at 13.502526 timestep 11\n",
            "Lyapunov value at 9.079904 timestep 12\n",
            "Lyapunov value at 7.498143 timestep 13\n",
            "Lyapunov value at 2.977791 timestep 14\n",
            "Lyapunov value at 7.059946 timestep 15\n",
            "Lyapunov value at 6.474455 timestep 16\n",
            "Lyapunov value at 8.750331 timestep 17\n",
            "Lyapunov value at 6.094800 timestep 18\n",
            "Lyapunov value at 7.748800 timestep 19\n",
            "Lyapunov value at 6.497359 timestep 20\n",
            "Iteration 20\n",
            "Lyapunov value at 3.915465 timestep 21\n",
            "Lyapunov value at 4.925226 timestep 22\n",
            "Lyapunov value at 7.368611 timestep 23\n",
            "Lyapunov value at 11.658978 timestep 24\n",
            "Lyapunov value at 13.046009 timestep 25\n",
            "Lyapunov value at 9.023470 timestep 26\n",
            "Lyapunov value at 9.485679 timestep 27\n",
            "Lyapunov value at 9.304991 timestep 28\n",
            "Lyapunov value at 8.205118 timestep 29\n",
            "Lyapunov value at 6.583849 timestep 30\n",
            "Iteration 30\n",
            "Lyapunov value at 7.321152 timestep 31\n",
            "Lyapunov value at 10.412605 timestep 32\n",
            "Lyapunov value at 8.553068 timestep 33\n",
            "Lyapunov value at 7.802159 timestep 34\n",
            "Lyapunov value at 6.242860 timestep 35\n",
            "Lyapunov value at 6.680323 timestep 36\n",
            "Lyapunov value at 5.241701 timestep 37\n",
            "Lyapunov value at 7.594946 timestep 38\n",
            "Lyapunov value at 7.721649 timestep 39\n",
            "Lyapunov value at 5.535843 timestep 40\n",
            "Iteration 40\n",
            "Lyapunov value at 10.825511 timestep 41\n",
            "Lyapunov value at 6.361894 timestep 42\n",
            "Lyapunov value at 8.435199 timestep 43\n",
            "Lyapunov value at 7.014874 timestep 44\n",
            "Lyapunov value at 7.193697 timestep 45\n",
            "Lyapunov value at 4.523777 timestep 46\n",
            "Lyapunov value at 5.140411 timestep 47\n",
            "Lyapunov value at 7.000322 timestep 48\n",
            "Lyapunov value at 5.133848 timestep 49\n",
            "Lyapunov value at 5.120429 timestep 50\n",
            "Iteration 50\n",
            "Lyapunov value at 6.974036 timestep 51\n",
            "Lyapunov value at 6.086799 timestep 52\n",
            "Lyapunov value at 5.704047 timestep 53\n",
            "Lyapunov value at 4.468301 timestep 54\n",
            "Lyapunov value at 6.246053 timestep 55\n",
            "Lyapunov value at 7.955754 timestep 56\n",
            "Lyapunov value at 8.510975 timestep 57\n",
            "Lyapunov value at 8.190885 timestep 58\n",
            "Lyapunov value at 3.050130 timestep 59\n",
            "Lyapunov value at 4.556439 timestep 60\n",
            "Iteration 60\n",
            "Lyapunov value at 8.045385 timestep 61\n",
            "Lyapunov value at 10.327402 timestep 62\n",
            "Lyapunov value at 5.062228 timestep 63\n",
            "Lyapunov value at 7.475759 timestep 64\n",
            "Lyapunov value at 7.082822 timestep 65\n",
            "Lyapunov value at 7.600400 timestep 66\n",
            "Lyapunov value at 5.719994 timestep 67\n",
            "Lyapunov value at 5.548492 timestep 68\n",
            "Lyapunov value at 6.189312 timestep 69\n",
            "Lyapunov value at 5.364803 timestep 70\n",
            "Iteration 70\n",
            "Lyapunov value at 7.757110 timestep 71\n",
            "Lyapunov value at 3.249304 timestep 72\n",
            "Lyapunov value at 2.809460 timestep 73\n",
            "Lyapunov value at 3.293996 timestep 74\n",
            "Lyapunov value at 3.763265 timestep 75\n",
            "Lyapunov value at 4.383044 timestep 76\n",
            "Lyapunov value at 5.204971 timestep 77\n",
            "Lyapunov value at 4.179773 timestep 78\n",
            "Lyapunov value at 6.323702 timestep 79\n",
            "Lyapunov value at 4.759974 timestep 80\n",
            "Iteration 80\n",
            "Lyapunov value at 3.578411 timestep 81\n",
            "Lyapunov value at 3.462691 timestep 82\n",
            "Lyapunov value at 5.240215 timestep 83\n",
            "Lyapunov value at 6.420735 timestep 84\n",
            "Lyapunov value at 8.736232 timestep 85\n",
            "Lyapunov value at 4.174342 timestep 86\n",
            "Lyapunov value at 4.183556 timestep 87\n",
            "Lyapunov value at 4.931499 timestep 88\n",
            "Lyapunov value at 5.862220 timestep 89\n",
            "Lyapunov value at 6.941391 timestep 90\n",
            "Iteration 90\n",
            "Lyapunov value at 5.966670 timestep 91\n",
            "Lyapunov value at 7.699769 timestep 92\n",
            "Lyapunov value at 6.130841 timestep 93\n",
            "Lyapunov value at 3.771030 timestep 94\n",
            "Lyapunov value at 2.244637 timestep 95\n",
            "Lyapunov value at 3.905789 timestep 96\n",
            "Lyapunov value at 3.655044 timestep 97\n",
            "Lyapunov value at 2.199046 timestep 98\n",
            "Lyapunov value at 3.412550 timestep 99\n",
            "Lyapunov value at 3.089938 timestep 100\n",
            "Iteration 100\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "download(\"download_bbd6d3bf-3aef-4683-9017-be00b8a1e702\", \"iteration100.pdf\", 9554)"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 3.330565 timestep 101\n",
            "Lyapunov value at 3.638232 timestep 102\n",
            "Lyapunov value at 4.366245 timestep 103\n",
            "Lyapunov value at 2.959956 timestep 104\n",
            "Lyapunov value at 5.109585 timestep 105\n",
            "Lyapunov value at 3.151830 timestep 106\n",
            "Lyapunov value at 2.504563 timestep 107\n",
            "Lyapunov value at 3.842185 timestep 108\n",
            "Lyapunov value at 4.459734 timestep 109\n",
            "Lyapunov value at 4.149070 timestep 110\n",
            "Iteration 110\n",
            "Lyapunov value at 4.847438 timestep 111\n",
            "Lyapunov value at 5.670034 timestep 112\n",
            "Lyapunov value at 4.874185 timestep 113\n",
            "Lyapunov value at 4.762768 timestep 114\n",
            "Lyapunov value at 3.465224 timestep 115\n",
            "Lyapunov value at 4.535577 timestep 116\n",
            "Lyapunov value at 3.387341 timestep 117\n",
            "Lyapunov value at 3.252348 timestep 118\n",
            "Lyapunov value at 2.573318 timestep 119\n",
            "Lyapunov value at 2.854835 timestep 120\n",
            "Iteration 120\n",
            "Lyapunov value at 2.783945 timestep 121\n",
            "Lyapunov value at 1.962549 timestep 122\n",
            "Lyapunov value at 2.990797 timestep 123\n",
            "Lyapunov value at 3.512203 timestep 124\n",
            "Lyapunov value at 3.271931 timestep 125\n",
            "Lyapunov value at 5.416984 timestep 126\n",
            "Lyapunov value at 5.251381 timestep 127\n",
            "Lyapunov value at 6.915694 timestep 128\n",
            "Lyapunov value at 5.135949 timestep 129\n",
            "Lyapunov value at 6.009897 timestep 130\n",
            "Iteration 130\n",
            "Lyapunov value at 3.588655 timestep 131\n",
            "Lyapunov value at 2.903562 timestep 132\n",
            "Lyapunov value at 4.343292 timestep 133\n",
            "Lyapunov value at 4.163558 timestep 134\n",
            "Lyapunov value at 2.698104 timestep 135\n",
            "Lyapunov value at 3.429942 timestep 136\n",
            "Lyapunov value at 3.017736 timestep 137\n",
            "Lyapunov value at 2.968116 timestep 138\n",
            "Lyapunov value at 3.088679 timestep 139\n",
            "Lyapunov value at 2.763873 timestep 140\n",
            "Iteration 140\n",
            "Lyapunov value at 6.104871 timestep 141\n",
            "Lyapunov value at 7.670730 timestep 142\n",
            "Lyapunov value at 17.811930 timestep 143\n",
            "Lyapunov value at 23.210175 timestep 144\n",
            "Lyapunov value at 17.113939 timestep 145\n",
            "Lyapunov value at 6.068451 timestep 146\n",
            "Lyapunov value at 3.749407 timestep 147\n",
            "Lyapunov value at 3.484048 timestep 148\n",
            "Lyapunov value at 2.683763 timestep 149\n",
            "Lyapunov value at 2.881481 timestep 150\n",
            "Iteration 150\n",
            "Lyapunov value at 4.482470 timestep 151\n",
            "Lyapunov value at 3.473889 timestep 152\n",
            "Lyapunov value at 4.799150 timestep 153\n",
            "Lyapunov value at 4.134547 timestep 154\n",
            "Lyapunov value at 7.192652 timestep 155\n",
            "Lyapunov value at 3.076911 timestep 156\n",
            "Lyapunov value at 3.126651 timestep 157\n",
            "Lyapunov value at 2.520269 timestep 158\n",
            "Lyapunov value at 2.949246 timestep 159\n",
            "Lyapunov value at 3.293092 timestep 160\n",
            "Iteration 160\n",
            "Lyapunov value at 4.388071 timestep 161\n",
            "Lyapunov value at 6.687865 timestep 162\n",
            "Lyapunov value at 10.782645 timestep 163\n",
            "Lyapunov value at 7.303618 timestep 164\n",
            "Lyapunov value at 11.228991 timestep 165\n",
            "Lyapunov value at 7.590896 timestep 166\n",
            "Lyapunov value at 2.709810 timestep 167\n",
            "Lyapunov value at 3.391612 timestep 168\n",
            "Lyapunov value at 3.643324 timestep 169\n",
            "Lyapunov value at 3.108082 timestep 170\n",
            "Iteration 170\n",
            "Lyapunov value at 3.278962 timestep 171\n",
            "Lyapunov value at 5.790678 timestep 172\n",
            "Lyapunov value at 7.531399 timestep 173\n",
            "Lyapunov value at 8.896582 timestep 174\n",
            "Lyapunov value at 10.366788 timestep 175\n",
            "Lyapunov value at 3.184646 timestep 176\n",
            "Lyapunov value at 3.166530 timestep 177\n",
            "Lyapunov value at 3.308341 timestep 178\n",
            "Lyapunov value at 2.944223 timestep 179\n",
            "Lyapunov value at 4.906744 timestep 180\n",
            "Iteration 180\n",
            "Lyapunov value at 9.925093 timestep 181\n",
            "Lyapunov value at 7.655694 timestep 182\n",
            "Lyapunov value at 2.711110 timestep 183\n",
            "Lyapunov value at 4.703312 timestep 184\n",
            "Lyapunov value at 6.377915 timestep 185\n",
            "Lyapunov value at 2.622559 timestep 186\n",
            "Lyapunov value at 3.679704 timestep 187\n",
            "Lyapunov value at 3.064032 timestep 188\n",
            "Lyapunov value at 4.407957 timestep 189\n",
            "Lyapunov value at 5.327080 timestep 190\n",
            "Iteration 190\n",
            "Lyapunov value at 5.286359 timestep 191\n",
            "Lyapunov value at 6.167352 timestep 192\n",
            "Lyapunov value at 3.393582 timestep 193\n",
            "Lyapunov value at 4.974798 timestep 194\n",
            "Lyapunov value at 3.160595 timestep 195\n",
            "Lyapunov value at 5.380777 timestep 196\n",
            "Lyapunov value at 5.077449 timestep 197\n",
            "Lyapunov value at 5.442491 timestep 198\n",
            "Lyapunov value at 7.324695 timestep 199\n",
            "Lyapunov value at 5.343820 timestep 200\n",
            "Iteration 200\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "download(\"download_f77be127-b5c8-4f10-8185-3253298ee252\", \"iteration200.pdf\", 10082)"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "download(\"download_26a68b50-335f-400d-93e7-18b4a3f43058\", \"iteration200.pdf\", 10077)"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "download(\"download_54da4f12-213e-42bc-ab5c-fea76886716d\", \"Wasserstein-1.pdf\", 12254)"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 432x288 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        },
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 864x576 with 1 Axes>"
            ]
          },
          "metadata": {
            "needs_background": "light"
          }
        }
      ]
    }
  ]
}