{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "working_KFAC_download_images_Submission.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    },
    "accelerator": "GPU"
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "id": "KLRtBCTxMk2q"
      },
      "source": [
        "!pip3 install optuna\n",
        "!pip install geomloss[full]\n",
        "!pip3 install nflows"
      ],
      "execution_count": null,
      "outputs": []
    },
    {
      "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": 18,
      "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  # Actually check dims\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))  # b * hw * in_c*kh*kw\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",
        "            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))  # b * hw * in_c*kh*kw\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",
        "        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",
        "        # g: batch_size * out_dim\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",
        "        # TODO (CW): KFAC optimizer now only support model as input\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",
        "            # print('=> We keep following layers in KFAC. <=')\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",
        "        # p_grad_mat is of output_dim * input_dim\n",
        "        # inv((ss')) p_grad_mat inv(aa') = [ Q_g (1/R_g) Q_g^T ] @ p_grad_mat @ [Q_a (1/R_a) Q_a^T]\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",
        "        # FIXME (CW): Modified based on SGD (removed nestrov and dampening in momentum.)\n",
        "        # FIXME (CW): 1. no nesterov, 2. buf.mul_(momentum).add_(1 <del> - dampening </del>, d_p)\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",
        "\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": 19,
      "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",
        "        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": 20,
      "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",
        "        #number of points x 1\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": 21,
      "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",
        "  # Forward pass real batch through D\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))#.cuda()\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, download=False):\n",
        "  plt.clf()\n",
        "  plt.cla()\n",
        "  latent_space_samples = torch.randn(200, 2)\n",
        "  generated_samples = generator(latent_space_samples)[0]\n",
        "  generated_samples = generated_samples.detach().cpu().numpy()\n",
        "  colors = sns.color_palette('colorblind', n_colors=2)\n",
        "  plt.plot(generated_samples[:, 0], generated_samples[:, 1], \".\")\n",
        "  if download:\n",
        "    namestr = 'iteration'+ str(t) + '.pdf'\n",
        "    plt.savefig(namestr)\n",
        "    files.download(namestr)\n",
        "  else:\n",
        "    if t % 100 == 0:\n",
        "      plt.show()\n",
        "\n",
        "\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",
        "\n",
        "\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 = 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",
        "      #pdb.set_trace()\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": 22,
      "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",
        "\n",
        "  eps = 1e-2\n",
        "\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": 23,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "MAfEQguWNEyy",
        "outputId": "c5895f04-2f60-495d-c469-111c2eaf394a"
      },
      "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",
        "  d_kfac_opt = KFACOptimizer(netD, lr=learning_rate, momentum=0.9, stat_decay=0.95, damping=1e-3, kl_clip=1e-2, weight_decay=3e-3, TCov=10, TInv=100)\n",
        "  g_kfac_opt = KFACOptimizer(netG, lr=learning_rate, momentum=0.9, stat_decay=0.95, damping=1e-3, kl_clip=1e-2, weight_decay=3e-3, TCov=10, TInv=100)\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",
        "  print(\"Sigma is: %f\" %(sigma))\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",
        "      d_kfac_opt.zero_grad()\n",
        "      with torch.no_grad():\n",
        "        fake_batch = netG(noise_samples)[0].view(-1,2)\n",
        "      d_kfac_opt.acc_stats = True\n",
        "      output_D, loss_D, grad_norm_real, grad_norm_fake = Discriminator_Loss(batch_size, real_batch, fake_batch, netD)\n",
        "      D_kfac_grads(output_D, d_kfac_opt)\n",
        "\n",
        "      d_kfac_opt.pre_step()\n",
        "      d_kfac_opt.zero_grad()\n",
        "      loss_D.backward(retain_graph=True)\n",
        "      torch.nn.utils.clip_grad_norm_(netD.parameters(), 1.)\n",
        "      d_kfac_opt.step()\n",
        "      d_kfac_opt.zero_grad()\n",
        "      d_kfac_opt.acc_stats = False\n",
        "\n",
        "      loss_D_epoch += loss_D.mean().item()\n",
        "\n",
        "      g_kfac_opt.zero_grad()\n",
        "      g_kfac_opt.acc_stats = True \n",
        "      noise_samples = torch.randn((batch_size, 2))\n",
        "      fake_batch = netG(noise_samples)[0].view(-1,2)\n",
        "      prob_batch = fake_batch\n",
        "      G_kfac_grads(prob_batch, g_kfac_opt, netG)\n",
        "      g_kfac_opt.pre_step()\n",
        "      g_kfac_opt.zero_grad()\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",
        "      g_kfac_opt.step()\n",
        "      g_kfac_opt.acc_stats = False\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, download=True)\n",
        "  if run_lyapunov:\n",
        "    return wasserstein_score, wasserstein_list, Lyapunov_list, d_lyap_list, g_lyap_list\n",
        "  else:\n",
        "    return wasserstein_score\n",
        "\n",
        "wasserstein_score, wasserstein_list, Lyapunov_list, D_list, G_list = Run_experiment(learning_rate=1e-4, run_lyapunov=True, n_iter=500)\n",
        "plot2(wasserstein_list, y_label='Wasserstein-1')\n",
        "\n"
      ],
      "execution_count": 24,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Learning Rate is 0.000100\n",
            "=> We keep following layers in KFAC. \n",
            "=> We keep following layers in KFAC. \n",
            "Sigma is: 0.010000\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 6.443543 timestep 0\n",
            "Iteration 0\n"
          ]
        },
        {
          "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": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 8.660344 timestep 1\n",
            "Lyapunov value at 5.341290 timestep 2\n",
            "Lyapunov value at 4.063850 timestep 3\n",
            "Lyapunov value at 7.497115 timestep 4\n",
            "Lyapunov value at 6.926866 timestep 5\n",
            "Lyapunov value at 5.726544 timestep 6\n",
            "Lyapunov value at 3.689038 timestep 7\n",
            "Lyapunov value at 8.306628 timestep 8\n",
            "Lyapunov value at 7.048521 timestep 9\n",
            "Lyapunov value at 6.015725 timestep 10\n",
            "Iteration 10\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 4.415800 timestep 11\n",
            "Lyapunov value at 5.301209 timestep 12\n",
            "Lyapunov value at 5.790933 timestep 13\n",
            "Lyapunov value at 5.852437 timestep 14\n",
            "Lyapunov value at 5.130624 timestep 15\n",
            "Lyapunov value at 8.042837 timestep 16\n",
            "Lyapunov value at 9.176786 timestep 17\n",
            "Lyapunov value at 4.922706 timestep 18\n",
            "Lyapunov value at 5.453135 timestep 19\n",
            "Lyapunov value at 7.963856 timestep 20\n",
            "Iteration 20\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 7.724866 timestep 21\n",
            "Lyapunov value at 7.030680 timestep 22\n",
            "Lyapunov value at 5.819275 timestep 23\n",
            "Lyapunov value at 6.123366 timestep 24\n",
            "Lyapunov value at 8.155677 timestep 25\n",
            "Lyapunov value at 8.519373 timestep 26\n",
            "Lyapunov value at 7.336425 timestep 27\n",
            "Lyapunov value at 2.445673 timestep 28\n",
            "Lyapunov value at 2.161941 timestep 29\n",
            "Lyapunov value at 5.569399 timestep 30\n",
            "Iteration 30\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 5.733085 timestep 31\n",
            "Lyapunov value at 7.450628 timestep 32\n",
            "Lyapunov value at 7.184140 timestep 33\n",
            "Lyapunov value at 7.809074 timestep 34\n",
            "Lyapunov value at 9.571823 timestep 35\n",
            "Lyapunov value at 4.716588 timestep 36\n",
            "Lyapunov value at 10.633655 timestep 37\n",
            "Lyapunov value at 9.442709 timestep 38\n",
            "Lyapunov value at 8.545268 timestep 39\n",
            "Lyapunov value at 6.660742 timestep 40\n",
            "Iteration 40\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 7.506353 timestep 41\n",
            "Lyapunov value at 9.888895 timestep 42\n",
            "Lyapunov value at 12.936138 timestep 43\n",
            "Lyapunov value at 9.596428 timestep 44\n",
            "Lyapunov value at 13.176910 timestep 45\n",
            "Lyapunov value at 7.892242 timestep 46\n",
            "Lyapunov value at 11.794623 timestep 47\n",
            "Lyapunov value at 11.385704 timestep 48\n",
            "Lyapunov value at 14.327147 timestep 49\n",
            "Lyapunov value at 7.637918 timestep 50\n",
            "Iteration 50\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 12.217179 timestep 51\n",
            "Lyapunov value at 14.252558 timestep 52\n",
            "Lyapunov value at 11.763293 timestep 53\n",
            "Lyapunov value at 10.234675 timestep 54\n",
            "Lyapunov value at 6.231433 timestep 55\n",
            "Lyapunov value at 7.036702 timestep 56\n",
            "Lyapunov value at 10.133644 timestep 57\n",
            "Lyapunov value at 7.635730 timestep 58\n",
            "Lyapunov value at 7.581372 timestep 59\n",
            "Lyapunov value at 8.911613 timestep 60\n",
            "Iteration 60\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 9.312927 timestep 61\n",
            "Lyapunov value at 7.558527 timestep 62\n",
            "Lyapunov value at 9.674147 timestep 63\n",
            "Lyapunov value at 6.441722 timestep 64\n",
            "Lyapunov value at 5.602580 timestep 65\n",
            "Lyapunov value at 8.630219 timestep 66\n",
            "Lyapunov value at 11.570914 timestep 67\n",
            "Lyapunov value at 13.483168 timestep 68\n",
            "Lyapunov value at 8.682755 timestep 69\n",
            "Lyapunov value at 9.228320 timestep 70\n",
            "Iteration 70\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 15.086416 timestep 71\n",
            "Lyapunov value at 12.442796 timestep 72\n",
            "Lyapunov value at 15.629492 timestep 73\n",
            "Lyapunov value at 6.224919 timestep 74\n",
            "Lyapunov value at 5.014744 timestep 75\n",
            "Lyapunov value at 3.292008 timestep 76\n",
            "Lyapunov value at 3.316137 timestep 77\n",
            "Lyapunov value at 3.612000 timestep 78\n",
            "Lyapunov value at 2.661943 timestep 79\n",
            "Lyapunov value at 3.932251 timestep 80\n",
            "Iteration 80\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 3.662775 timestep 81\n",
            "Lyapunov value at 2.521520 timestep 82\n",
            "Lyapunov value at 3.861380 timestep 83\n",
            "Lyapunov value at 4.478361 timestep 84\n",
            "Lyapunov value at 4.357243 timestep 85\n",
            "Lyapunov value at 5.793417 timestep 86\n",
            "Lyapunov value at 4.204693 timestep 87\n",
            "Lyapunov value at 3.206033 timestep 88\n",
            "Lyapunov value at 3.972785 timestep 89\n",
            "Lyapunov value at 4.863297 timestep 90\n",
            "Iteration 90\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 3.825722 timestep 91\n",
            "Lyapunov value at 3.669184 timestep 92\n",
            "Lyapunov value at 4.577495 timestep 93\n",
            "Lyapunov value at 5.189144 timestep 94\n",
            "Lyapunov value at 5.741372 timestep 95\n",
            "Lyapunov value at 3.731567 timestep 96\n",
            "Lyapunov value at 3.416492 timestep 97\n",
            "Lyapunov value at 4.377559 timestep 98\n",
            "Lyapunov value at 5.367533 timestep 99\n",
            "Lyapunov value at 2.533458 timestep 100\n",
            "Iteration 100\n"
          ]
        },
        {
          "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": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 2.114190 timestep 101\n",
            "Lyapunov value at 4.077464 timestep 102\n",
            "Lyapunov value at 2.790524 timestep 103\n",
            "Lyapunov value at 4.515364 timestep 104\n",
            "Lyapunov value at 4.522470 timestep 105\n",
            "Lyapunov value at 2.410942 timestep 106\n",
            "Lyapunov value at 2.654345 timestep 107\n",
            "Lyapunov value at 2.445971 timestep 108\n",
            "Lyapunov value at 3.128031 timestep 109\n",
            "Lyapunov value at 2.406652 timestep 110\n",
            "Iteration 110\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 2.763760 timestep 111\n",
            "Lyapunov value at 5.194320 timestep 112\n",
            "Lyapunov value at 4.740594 timestep 113\n",
            "Lyapunov value at 3.761006 timestep 114\n",
            "Lyapunov value at 3.570275 timestep 115\n",
            "Lyapunov value at 4.275713 timestep 116\n",
            "Lyapunov value at 4.033144 timestep 117\n",
            "Lyapunov value at 3.329438 timestep 118\n",
            "Lyapunov value at 3.677075 timestep 119\n",
            "Lyapunov value at 2.288799 timestep 120\n",
            "Iteration 120\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 3.203197 timestep 121\n",
            "Lyapunov value at 1.490169 timestep 122\n",
            "Lyapunov value at 3.036004 timestep 123\n",
            "Lyapunov value at 2.407279 timestep 124\n",
            "Lyapunov value at 2.908704 timestep 125\n",
            "Lyapunov value at 5.475479 timestep 126\n",
            "Lyapunov value at 2.876704 timestep 127\n",
            "Lyapunov value at 2.641177 timestep 128\n",
            "Lyapunov value at 2.916785 timestep 129\n",
            "Lyapunov value at 5.153030 timestep 130\n",
            "Iteration 130\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 5.594211 timestep 131\n",
            "Lyapunov value at 3.498831 timestep 132\n",
            "Lyapunov value at 3.387831 timestep 133\n",
            "Lyapunov value at 3.366238 timestep 134\n",
            "Lyapunov value at 2.676607 timestep 135\n",
            "Lyapunov value at 3.250724 timestep 136\n",
            "Lyapunov value at 3.795930 timestep 137\n",
            "Lyapunov value at 3.357113 timestep 138\n",
            "Lyapunov value at 2.733365 timestep 139\n",
            "Lyapunov value at 3.215712 timestep 140\n",
            "Iteration 140\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 2.924992 timestep 141\n",
            "Lyapunov value at 3.298473 timestep 142\n",
            "Lyapunov value at 3.329487 timestep 143\n",
            "Lyapunov value at 2.549749 timestep 144\n",
            "Lyapunov value at 2.291663 timestep 145\n",
            "Lyapunov value at 2.751313 timestep 146\n",
            "Lyapunov value at 4.152023 timestep 147\n",
            "Lyapunov value at 2.675745 timestep 148\n",
            "Lyapunov value at 2.538998 timestep 149\n",
            "Lyapunov value at 3.777452 timestep 150\n",
            "Iteration 150\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 4.037823 timestep 151\n",
            "Lyapunov value at 3.954804 timestep 152\n",
            "Lyapunov value at 2.410908 timestep 153\n",
            "Lyapunov value at 3.079479 timestep 154\n",
            "Lyapunov value at 2.141934 timestep 155\n",
            "Lyapunov value at 2.459532 timestep 156\n",
            "Lyapunov value at 2.551685 timestep 157\n",
            "Lyapunov value at 3.051585 timestep 158\n",
            "Lyapunov value at 2.577929 timestep 159\n",
            "Lyapunov value at 2.736854 timestep 160\n",
            "Iteration 160\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 2.482106 timestep 161\n",
            "Lyapunov value at 3.310839 timestep 162\n",
            "Lyapunov value at 4.859777 timestep 163\n",
            "Lyapunov value at 3.267918 timestep 164\n",
            "Lyapunov value at 2.163990 timestep 165\n",
            "Lyapunov value at 2.799076 timestep 166\n",
            "Lyapunov value at 2.247668 timestep 167\n",
            "Lyapunov value at 4.821514 timestep 168\n",
            "Lyapunov value at 3.375054 timestep 169\n",
            "Lyapunov value at 2.655015 timestep 170\n",
            "Iteration 170\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 1.754608 timestep 171\n",
            "Lyapunov value at 3.623336 timestep 172\n",
            "Lyapunov value at 3.738949 timestep 173\n",
            "Lyapunov value at 3.274977 timestep 174\n",
            "Lyapunov value at 3.881846 timestep 175\n",
            "Lyapunov value at 4.110023 timestep 176\n",
            "Lyapunov value at 5.335163 timestep 177\n",
            "Lyapunov value at 2.912140 timestep 178\n",
            "Lyapunov value at 3.862612 timestep 179\n",
            "Lyapunov value at 5.620459 timestep 180\n",
            "Iteration 180\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 4.031923 timestep 181\n",
            "Lyapunov value at 4.888350 timestep 182\n",
            "Lyapunov value at 2.466102 timestep 183\n",
            "Lyapunov value at 3.733747 timestep 184\n",
            "Lyapunov value at 3.526779 timestep 185\n",
            "Lyapunov value at 2.268800 timestep 186\n",
            "Lyapunov value at 2.917562 timestep 187\n",
            "Lyapunov value at 3.722442 timestep 188\n",
            "Lyapunov value at 3.027458 timestep 189\n",
            "Lyapunov value at 2.514207 timestep 190\n",
            "Iteration 190\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lyapunov value at 2.773599 timestep 191\n",
            "Lyapunov value at 2.198924 timestep 192\n",
            "Lyapunov value at 2.204354 timestep 193\n",
            "Lyapunov value at 2.305856 timestep 194\n",
            "Lyapunov value at 2.474067 timestep 195\n",
            "Lyapunov value at 2.856993 timestep 196\n",
            "Lyapunov value at 2.866636 timestep 197\n",
            "Lyapunov value at 3.663861 timestep 198\n",
            "Lyapunov value at 3.374982 timestep 199\n",
            "Lyapunov value at 2.312711 timestep 200\n",
            "Iteration 200\n"
          ]
        },
        {
          "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": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/torch/nn/modules/module.py:974: UserWarning:\n",
            "\n",
            "Using a non-full backward hook when the forward contains multiple autograd Nodes is deprecated and will be removed in future versions. This hook will be missing some grad_input. Please use register_full_backward_hook to get the documented behavior.\n",
            "\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_f191ea82-814c-4110-a28b-19f480a97e27\", \"iteration200.pdf\", 9902)"
            ],
            "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"
          }
        }
      ]
    }
  ]
}