{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "926e2fe4",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "from torch import Tensor\n",
    "from torch.optim.optimizer import Optimizer, required, _use_grad_for_differentiable\n",
    "from typing import List, Optional\n",
    "import math\n",
    "\n",
    "\n",
    "class NSGD(Optimizer):\n",
    "    r\"\"\"Implements stochastic gradient descent (optionally with momentum).\n",
    "\n",
    "    .. math::\n",
    "       \\begin{aligned}\n",
    "            &\\rule{110mm}{0.4pt}                                                                 \\\\\n",
    "            &\\textbf{input}      : \\gamma \\text{ (lr)}, \\: \\theta_0 \\text{ (params)}, \\: f(\\theta)\n",
    "                \\text{ (objective)}, \\: \\lambda \\text{ (weight decay)},                          \\\\\n",
    "            &\\hspace{13mm} \\:\\mu \\text{ (momentum)}, \\:\\tau \\text{ (dampening)},\n",
    "            \\:\\textit{ nesterov,}\\:\\textit{ maximize}                                     \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                                 \\\\\n",
    "            &\\textbf{for} \\: t=1 \\: \\textbf{to} \\: \\ldots \\: \\textbf{do}                         \\\\\n",
    "            &\\hspace{5mm}g_t           \\leftarrow   \\nabla_{\\theta} f_t (\\theta_{t-1})           \\\\\n",
    "            &\\hspace{5mm}\\textbf{if} \\: \\lambda \\neq 0                                           \\\\\n",
    "            &\\hspace{10mm} g_t \\leftarrow g_t + \\lambda  \\theta_{t-1}                            \\\\\n",
    "            &\\hspace{5mm}\\textbf{if} \\: \\mu \\neq 0                                               \\\\\n",
    "            &\\hspace{10mm}\\textbf{if} \\: t > 1                                                   \\\\\n",
    "            &\\hspace{15mm} \\textbf{b}_t \\leftarrow \\mu \\textbf{b}_{t-1} + (1-\\tau) g_t           \\\\\n",
    "            &\\hspace{10mm}\\textbf{else}                                                          \\\\\n",
    "            &\\hspace{15mm} \\textbf{b}_t \\leftarrow g_t                                           \\\\\n",
    "            &\\hspace{10mm}\\textbf{if} \\: \\textit{nesterov}                                       \\\\\n",
    "            &\\hspace{15mm} g_t \\leftarrow g_{t} + \\mu \\textbf{b}_t                             \\\\\n",
    "            &\\hspace{10mm}\\textbf{else}                                                   \\\\[-1.ex]\n",
    "            &\\hspace{15mm} g_t  \\leftarrow  \\textbf{b}_t                                         \\\\\n",
    "            &\\hspace{5mm}\\textbf{if} \\: \\textit{maximize}                                          \\\\\n",
    "            &\\hspace{10mm}\\theta_t \\leftarrow \\theta_{t-1} + \\gamma g_t                   \\\\[-1.ex]\n",
    "            &\\hspace{5mm}\\textbf{else}                                                    \\\\[-1.ex]\n",
    "            &\\hspace{10mm}\\theta_t \\leftarrow \\theta_{t-1} - \\gamma g_t                   \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                          \\\\[-1.ex]\n",
    "            &\\bf{return} \\:  \\theta_t                                                     \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                          \\\\[-1.ex]\n",
    "       \\end{aligned}\n",
    "\n",
    "    Nesterov momentum is based on the formula from\n",
    "    `On the importance of initialization and momentum in deep learning`__.\n",
    "\n",
    "    Args:\n",
    "        params (iterable): iterable of parameters to optimize or dicts defining\n",
    "            parameter groups\n",
    "        lr (float): learning rate\n",
    "        momentum (float, optional): momentum factor (default: 0)\n",
    "        weight_decay (float, optional): weight decay (L2 penalty) (default: 0)\n",
    "        dampening (float, optional): dampening for momentum (default: 0)\n",
    "        nesterov (bool, optional): enables Nesterov momentum (default: False)\n",
    "        maximize (bool, optional): maximize the params based on the objective, instead of\n",
    "            minimizing (default: False)\n",
    "        foreach (bool, optional): whether foreach implementation of optimizer\n",
    "            is used (default: None)\n",
    "\n",
    "    Example:\n",
    "        >>> # xdoctest: +SKIP\n",
    "        >>> optimizer = torch.optim.SGD(model.parameters(), lr=0.1, momentum=0.9)\n",
    "        >>> optimizer.zero_grad()\n",
    "        >>> loss_fn(model(input), target).backward()\n",
    "        >>> optimizer.step()\n",
    "\n",
    "    __ http://www.cs.toronto.edu/%7Ehinton/absps/momentum.pdf\n",
    "\n",
    "    .. note::\n",
    "        The implementation of SGD with Momentum/Nesterov subtly differs from\n",
    "        Sutskever et. al. and implementations in some other frameworks.\n",
    "\n",
    "        Considering the specific case of Momentum, the update can be written as\n",
    "\n",
    "        .. math::\n",
    "            \\begin{aligned}\n",
    "                v_{t+1} & = \\mu * v_{t} + g_{t+1}, \\\\\n",
    "                p_{t+1} & = p_{t} - \\text{lr} * v_{t+1},\n",
    "            \\end{aligned}\n",
    "\n",
    "        where :math:`p`, :math:`g`, :math:`v` and :math:`\\mu` denote the\n",
    "        parameters, gradient, velocity, and momentum respectively.\n",
    "\n",
    "        This is in contrast to Sutskever et. al. and\n",
    "        other frameworks which employ an update of the form\n",
    "\n",
    "        .. math::\n",
    "            \\begin{aligned}\n",
    "                v_{t+1} & = \\mu * v_{t} + \\text{lr} * g_{t+1}, \\\\\n",
    "                p_{t+1} & = p_{t} - v_{t+1}.\n",
    "            \\end{aligned}\n",
    "\n",
    "        The Nesterov version is analogously modified.\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(self, params, lr=required,\n",
    "                 weight_decay=0, nesterov=False, *, maximize=False, foreach: Optional[bool] = None,\n",
    "                 differentiable=False):\n",
    "        if lr is not required and lr < 0.0:\n",
    "            raise ValueError(\"Invalid learning rate: {}\".format(lr))\n",
    "        if weight_decay < 0.0:\n",
    "            raise ValueError(\"Invalid weight_decay value: {}\".format(weight_decay))\n",
    "\n",
    "        defaults = dict(lr=lr,\n",
    "                        weight_decay=weight_decay, nesterov=nesterov,\n",
    "                        maximize=maximize, foreach=foreach,\n",
    "                        differentiable=differentiable)\n",
    "\n",
    "        self.step_t = 0\n",
    "        # if nesterov and (momentum <= 0 or dampening != 0):\n",
    "        #     raise ValueError(\"Nesterov momentum requires a momentum and zero dampening\")\n",
    "        super(NSGD, self).__init__(params, defaults)\n",
    "\n",
    "    def __setstate__(self, state):\n",
    "        super().__setstate__(state)\n",
    "        for group in self.param_groups:\n",
    "            group.setdefault('nesterov', False)\n",
    "            group.setdefault('maximize', False)\n",
    "            group.setdefault('foreach', None)\n",
    "            group.setdefault('differentiable', False)\n",
    "\n",
    "    @_use_grad_for_differentiable\n",
    "    def step(self, closure=None):\n",
    "        \"\"\"Performs a single optimization step.\n",
    "\n",
    "        Args:\n",
    "            closure (Callable, optional): A closure that reevaluates the model\n",
    "                and returns the loss.\n",
    "        \"\"\"\n",
    "        loss = None\n",
    "        if closure is not None:\n",
    "            with torch.enable_grad():\n",
    "                loss = closure()\n",
    "\n",
    "        for group in self.param_groups:\n",
    "            params_with_grad = []\n",
    "            d_p_list = []\n",
    "            momentum_buffer_list = []\n",
    "            has_sparse_grad = False\n",
    "\n",
    "            for p in group['params']:\n",
    "                if p.grad is not None:\n",
    "                    params_with_grad.append(p)\n",
    "                    d_p_list.append(p.grad)\n",
    "                    if p.grad.is_sparse:\n",
    "                        has_sparse_grad = True\n",
    "\n",
    "                    state = self.state[p]\n",
    "                    if 'momentum_buffer' not in state:\n",
    "                        momentum_buffer_list.append(None)\n",
    "                    else:\n",
    "                        momentum_buffer_list.append(state['momentum_buffer'])\n",
    "\n",
    "            self.effective_stepsize = nsgd(params_with_grad,\n",
    "                d_p_list,\n",
    "                momentum_buffer_list,\n",
    "                weight_decay=group['weight_decay'],\n",
    "                lr=group['lr'],\n",
    "                nesterov=group['nesterov'],\n",
    "                maximize=group['maximize'],\n",
    "                has_sparse_grad=has_sparse_grad,\n",
    "                foreach=group['foreach'],\n",
    "                step=self.step_t)\n",
    "\n",
    "            # update momentum_buffers in state\n",
    "            for p, momentum_buffer in zip(params_with_grad, momentum_buffer_list):\n",
    "                state = self.state[p]\n",
    "                state['momentum_buffer'] = momentum_buffer\n",
    "\n",
    "        self.step_t += 1\n",
    "\n",
    "        return loss\n",
    "\n",
    "\n",
    "\n",
    "def nsgd(params: List[Tensor],\n",
    "        d_p_list: List[Tensor],\n",
    "        momentum_buffer_list: List[Optional[Tensor]],\n",
    "        # kwonly args with defaults are not supported by functions compiled with torchscript issue #70627\n",
    "        # setting this as kwarg for now as functional API is compiled by torch/distributed/optim\n",
    "        has_sparse_grad: bool = None,\n",
    "        foreach: bool = None,\n",
    "        *,\n",
    "        weight_decay: float,\n",
    "        lr: float,\n",
    "        nesterov: bool,\n",
    "        maximize: bool,\n",
    "        step):\n",
    "    r\"\"\"Functional API that performs SGD algorithm computation.\n",
    "\n",
    "    See :class:`~torch.optim.SGD` for details.\n",
    "    \"\"\"\n",
    "\n",
    "    if foreach is None:\n",
    "        # Placeholder for more complex foreach logic to be added when value is not set\n",
    "        foreach = False\n",
    "\n",
    "    if foreach and torch.jit.is_scripting():\n",
    "        raise RuntimeError('torch.jit.script not supported with foreach optimizers')\n",
    "\n",
    "    if foreach and not torch.jit.is_scripting():\n",
    "        raise NotImplementedError\n",
    "        func = _multi_tensor_nsgd\n",
    "    else:\n",
    "        func = _single_tensor_nsgd\n",
    "\n",
    "    return func(params,\n",
    "         d_p_list,\n",
    "         momentum_buffer_list,\n",
    "         weight_decay=weight_decay,\n",
    "         lr=lr,\n",
    "         nesterov=nesterov,\n",
    "         has_sparse_grad=has_sparse_grad,\n",
    "         maximize=maximize,\n",
    "         step=step)\n",
    "\n",
    "def _single_tensor_nsgd(params: List[Tensor],\n",
    "                       d_p_list: List[Tensor],\n",
    "                       momentum_buffer_list: List[Optional[Tensor]],\n",
    "                       *,\n",
    "                       weight_decay: float,\n",
    "                       lr: float,\n",
    "                       nesterov: bool,\n",
    "                       maximize: bool,\n",
    "                       has_sparse_grad: bool,\n",
    "                       step):\n",
    "\n",
    "    for i, param in enumerate(params):\n",
    "        d_p = d_p_list[i] if not maximize else -d_p_list[i]\n",
    "\n",
    "        if weight_decay != 0:\n",
    "            raise NotImplementedError\n",
    "            d_p = d_p.add(param, alpha=weight_decay)\n",
    "\n",
    "        buf = momentum_buffer_list[i]\n",
    "\n",
    "        alpha_t = 1.41421356 / ((step + 2) ** 0.5)\n",
    "        if buf is None:\n",
    "            buf = torch.clone(d_p).detach()\n",
    "            momentum_buffer_list[i] = buf\n",
    "        else:\n",
    "            buf.mul_(1 - alpha_t).add_(d_p, alpha=alpha_t)\n",
    "\n",
    "        d_p = buf\n",
    "        d_p_norm = d_p.norm()\n",
    "\n",
    "        lr_t = lr / ((step + 1) ** 0.75)\n",
    "\n",
    "        param.addcdiv_(d_p, d_p_norm, value=-lr_t)\n",
    "\n",
    "        #return lr_t / d_p_norm.item()\n",
    "\n",
    "\n",
    "from collections import defaultdict\n",
    "import math\n",
    "from typing import cast, List, Optional, Dict, Tuple\n",
    "\n",
    "import torch\n",
    "from torch import Tensor\n",
    "from torch.optim.optimizer import Optimizer, _use_grad_for_differentiable\n",
    "\n",
    "\n",
    "class _MultiDeviceReplicator:\n",
    "    main_tensor: Tensor\n",
    "    _per_device_tensors: Dict[str, Tensor]\n",
    "\n",
    "    def __init__(self, main_tensor: Tensor) -> None:\n",
    "        self.main_tensor = main_tensor\n",
    "        self._per_device_tensors = {str(main_tensor.device): main_tensor}\n",
    "\n",
    "    def get(self, device: str):\n",
    "        if device in self._per_device_tensors:\n",
    "            return self._per_device_tensors[device]\n",
    "        tensor = self.main_tensor.to(device=device, non_blocking=True, copy=True)\n",
    "        self._per_device_tensors[device] = tensor\n",
    "        return tensor\n",
    "\n",
    "\n",
    "# todo(crcrpar): Move this to another place when adding another fused optimizer.\n",
    "def _get_fp16AMP_params(\n",
    "    *,\n",
    "    optimizer: Optimizer,\n",
    "    grad_scaler: Optional[torch.cuda.amp.GradScaler] = None,\n",
    "    device: torch.device,\n",
    ") -> Optional[_MultiDeviceReplicator]:\n",
    "    if grad_scaler is None:\n",
    "        return None\n",
    "    found_inf_dict = grad_scaler._check_inf_per_device(optimizer)\n",
    "    # Combines found_inf tensors from all devices. As in GradScaler.update(),\n",
    "    # tensors are combined on the scale's device, which is an arbitrary but\n",
    "    # reasonable choice that avoids new context creation.\n",
    "    found_infs = [f.to(device, non_blocking=True) for f in found_inf_dict.values()]\n",
    "    assert len(found_infs) > 0, \"No inf checks were recorded in _check_inf_per_device.\"\n",
    "    with torch.no_grad():\n",
    "        found_inf_combined = cast(torch.Tensor, sum(found_infs))\n",
    "    return _MultiDeviceReplicator(found_inf_combined)\n",
    "\n",
    "class Adam(Optimizer):\n",
    "    r\"\"\"Implements Adam algorithm.\n",
    "\n",
    "    .. math::\n",
    "       \\begin{aligned}\n",
    "            &\\rule{110mm}{0.4pt}                                                                 \\\\\n",
    "            &\\textbf{input}      : \\gamma \\text{ (lr)}, \\beta_1, \\beta_2\n",
    "                \\text{ (betas)},\\theta_0 \\text{ (params)},f(\\theta) \\text{ (objective)}          \\\\\n",
    "            &\\hspace{13mm}      \\lambda \\text{ (weight decay)},  \\: \\textit{amsgrad},\n",
    "                \\:\\textit{maximize}                                                              \\\\\n",
    "            &\\textbf{initialize} :  m_0 \\leftarrow 0 \\text{ ( first moment)},\n",
    "                v_0\\leftarrow 0 \\text{ (second moment)},\\: \\widehat{v_0}^{max}\\leftarrow 0\\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                                 \\\\\n",
    "            &\\textbf{for} \\: t=1 \\: \\textbf{to} \\: \\ldots \\: \\textbf{do}                         \\\\\n",
    "\n",
    "            &\\hspace{5mm}\\textbf{if} \\: \\textit{maximize}:                                       \\\\\n",
    "            &\\hspace{10mm}g_t           \\leftarrow   -\\nabla_{\\theta} f_t (\\theta_{t-1})         \\\\\n",
    "            &\\hspace{5mm}\\textbf{else}                                                           \\\\\n",
    "            &\\hspace{10mm}g_t           \\leftarrow   \\nabla_{\\theta} f_t (\\theta_{t-1})          \\\\\n",
    "            &\\hspace{5mm}\\textbf{if} \\: \\lambda \\neq 0                                           \\\\\n",
    "            &\\hspace{10mm} g_t \\leftarrow g_t + \\lambda  \\theta_{t-1}                            \\\\\n",
    "            &\\hspace{5mm}m_t           \\leftarrow   \\beta_1 m_{t-1} + (1 - \\beta_1) g_t          \\\\\n",
    "            &\\hspace{5mm}v_t           \\leftarrow   \\beta_2 v_{t-1} + (1-\\beta_2) g^2_t          \\\\\n",
    "            &\\hspace{5mm}\\widehat{m_t} \\leftarrow   m_t/\\big(1-\\beta_1^t \\big)                   \\\\\n",
    "            &\\hspace{5mm}\\widehat{v_t} \\leftarrow   v_t/\\big(1-\\beta_2^t \\big)                   \\\\\n",
    "            &\\hspace{5mm}\\textbf{if} \\: amsgrad                                                  \\\\\n",
    "            &\\hspace{10mm}\\widehat{v_t}^{max} \\leftarrow \\mathrm{max}(\\widehat{v_t}^{max},\n",
    "                \\widehat{v_t})                                                                   \\\\\n",
    "            &\\hspace{10mm}\\theta_t \\leftarrow \\theta_{t-1} - \\gamma \\widehat{m_t}/\n",
    "                \\big(\\sqrt{\\widehat{v_t}^{max}} + \\epsilon \\big)                                 \\\\\n",
    "            &\\hspace{5mm}\\textbf{else}                                                           \\\\\n",
    "            &\\hspace{10mm}\\theta_t \\leftarrow \\theta_{t-1} - \\gamma \\widehat{m_t}/\n",
    "                \\big(\\sqrt{\\widehat{v_t}} + \\epsilon \\big)                                       \\\\\n",
    "            &\\rule{110mm}{0.4pt}                                                          \\\\[-1.ex]\n",
    "            &\\bf{return} \\:  \\theta_t                                                     \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                          \\\\[-1.ex]\n",
    "       \\end{aligned}\n",
    "\n",
    "    For further details regarding the algorithm we refer to `Adam: A Method for Stochastic Optimization`_.\n",
    "\n",
    "    Args:\n",
    "        params (iterable): iterable of parameters to optimize or dicts defining\n",
    "            parameter groups\n",
    "        lr (float, optional): learning rate (default: 1e-3)\n",
    "        betas (Tuple[float, float], optional): coefficients used for computing\n",
    "            running averages of gradient and its square (default: (0.9, 0.999))\n",
    "        eps (float, optional): term added to the denominator to improve\n",
    "            numerical stability (default: 1e-8)\n",
    "        weight_decay (float, optional): weight decay (L2 penalty) (default: 0)\n",
    "        amsgrad (bool, optional): whether to use the AMSGrad variant of this\n",
    "            algorithm from the paper `On the Convergence of Adam and Beyond`_\n",
    "            (default: False)\n",
    "        foreach (bool, optional): whether foreach implementation of optimizer\n",
    "            is used (default: None)\n",
    "        maximize (bool, optional): maximize the params based on the objective, instead of\n",
    "            minimizing (default: False)\n",
    "        capturable (bool, optional): whether this instance is safe to capture in a CUDA graph.\n",
    "            Passing True can impair ungraphed performance, so if you don't intend to\n",
    "            graph capture this instance, leave it False (default: False)\n",
    "        fused (bool, optional): whether fused implementation of optimizer is used.\n",
    "            Currently, `torch.float64`, `torch.float32`, `torch.float16`, and `torch.bfloat16`\n",
    "            are supported. (default: False)\n",
    "\n",
    "    .. _Adam\\: A Method for Stochastic Optimization:\n",
    "        https://arxiv.org/abs/1412.6980\n",
    "    .. _On the Convergence of Adam and Beyond:\n",
    "        https://openreview.net/forum?id=ryQu7f-RZ\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(self, params, lr=1e-3, betas=(0.9, 0.999), eps=1e-8,\n",
    "                 weight_decay=0, amsgrad=False, *, foreach: Optional[bool] = None,\n",
    "                 maximize: bool = False, capturable: bool = False,\n",
    "                 differentiable: bool = False, fused: bool = False):\n",
    "        if not 0.0 <= lr:\n",
    "            raise ValueError(\"Invalid learning rate: {}\".format(lr))\n",
    "        if not 0.0 <= eps:\n",
    "            raise ValueError(\"Invalid epsilon value: {}\".format(eps))\n",
    "        if not 0.0 <= betas[0] < 1.0:\n",
    "            raise ValueError(\"Invalid beta parameter at index 0: {}\".format(betas[0]))\n",
    "        if not 0.0 <= betas[1] < 1.0:\n",
    "            raise ValueError(\"Invalid beta parameter at index 1: {}\".format(betas[1]))\n",
    "        if not 0.0 <= weight_decay:\n",
    "            raise ValueError(\"Invalid weight_decay value: {}\".format(weight_decay))\n",
    "        defaults = dict(lr=lr, betas=betas, eps=eps,\n",
    "                        weight_decay=weight_decay, amsgrad=amsgrad,\n",
    "                        maximize=maximize, foreach=foreach, capturable=capturable,\n",
    "                        differentiable=differentiable, fused=fused)\n",
    "        super(Adam, self).__init__(params, defaults)\n",
    "\n",
    "        if fused:\n",
    "            if differentiable:\n",
    "                raise RuntimeError(\"`fused` cannot be `differentiable`\")\n",
    "            self._step_supports_amp_scaling = True\n",
    "            # TODO(crcrpar): [low prec params & their higher prec copy]\n",
    "            # Suppor AMP with FP16/BF16 model params which would need\n",
    "            # higher prec copy of params to do update math in higher prec to\n",
    "            # alleviate the loss of information.\n",
    "            if not all(\n",
    "                p.is_cuda and torch.is_floating_point(p)\n",
    "                for pg in self.param_groups for p in pg['params']\n",
    "            ):\n",
    "                raise RuntimeError(\"FusedAdam requires all the params to be CUDA, floating point\")\n",
    "\n",
    "    def __setstate__(self, state):\n",
    "        super().__setstate__(state)\n",
    "        for group in self.param_groups:\n",
    "            group.setdefault('amsgrad', False)\n",
    "            group.setdefault('maximize', False)\n",
    "            group.setdefault('foreach', None)\n",
    "            group.setdefault('capturable', False)\n",
    "            group.setdefault('differentiable', False)\n",
    "            group.setdefault('fused', False)\n",
    "        state_values = list(self.state.values())\n",
    "        step_is_tensor = (len(state_values) != 0) and torch.is_tensor(state_values[0]['step'])\n",
    "        if not step_is_tensor:\n",
    "            for s in state_values:\n",
    "                s['step'] = torch.tensor(float(s['step']))\n",
    "\n",
    "    @_use_grad_for_differentiable\n",
    "    def step(self, closure=None, *, grad_scaler=None):\n",
    "        \"\"\"Performs a single optimization step.\n",
    "\n",
    "        Args:\n",
    "            closure (Callable, optional): A closure that reevaluates the model\n",
    "                and returns the loss.\n",
    "            grad_scaler (:class:`torch.cuda.amp.GradScaler`, optional): A GradScaler which is\n",
    "                supplied from ``grad_scaler.step(optimizer)``.\n",
    "        \"\"\"\n",
    "        self._cuda_graph_capture_health_check()\n",
    "\n",
    "        loss = None\n",
    "        if closure is not None:\n",
    "            with torch.enable_grad():\n",
    "                loss = closure()\n",
    "\n",
    "        for group in self.param_groups:\n",
    "            params_with_grad = []\n",
    "            grads = []\n",
    "            exp_avgs = []\n",
    "            exp_avg_sqs = []\n",
    "            max_exp_avg_sqs = []\n",
    "            state_steps = []\n",
    "            beta1, beta2 = group['betas']\n",
    "\n",
    "            grad_scale = None\n",
    "            found_inf = None\n",
    "            if group['fused'] and grad_scaler is not None:\n",
    "                grad_scale = grad_scaler._get_scale_async()\n",
    "                device = grad_scale.device\n",
    "                grad_scale = _MultiDeviceReplicator(grad_scale)\n",
    "                found_inf = _get_fp16AMP_params(optimizer=self, grad_scaler=grad_scaler, device=device)\n",
    "\n",
    "            for p in group['params']:\n",
    "                if p.grad is not None:\n",
    "                    params_with_grad.append(p)\n",
    "                    if p.grad.is_sparse:\n",
    "                        raise RuntimeError('Adam does not support sparse gradients, please consider SparseAdam instead')\n",
    "                    grads.append(p.grad)\n",
    "\n",
    "                    state = self.state[p]\n",
    "                    # Lazy state initialization\n",
    "                    if len(state) == 0:\n",
    "                        state['step'] = (\n",
    "                            torch.zeros((1,), dtype=torch.float, device=p.device)\n",
    "                            if self.defaults['capturable'] or self.defaults['fused']\n",
    "                            else torch.tensor(0.)\n",
    "                        )\n",
    "                        # Exponential moving average of gradient values\n",
    "                        state['exp_avg'] = torch.zeros_like(p, memory_format=torch.preserve_format)\n",
    "                        # Exponential moving average of squared gradient values\n",
    "                        state['exp_avg_sq'] = torch.zeros_like(p, memory_format=torch.preserve_format)\n",
    "                        if group['amsgrad']:\n",
    "                            # Maintains max of all exp. moving avg. of sq. grad. values\n",
    "                            state['max_exp_avg_sq'] = torch.zeros_like(p, memory_format=torch.preserve_format)\n",
    "\n",
    "                    exp_avgs.append(state['exp_avg'])\n",
    "                    exp_avg_sqs.append(state['exp_avg_sq'])\n",
    "\n",
    "                    if group['amsgrad']:\n",
    "                        max_exp_avg_sqs.append(state['max_exp_avg_sq'])\n",
    "                    if group['differentiable'] and state['step'].requires_grad:\n",
    "                        raise RuntimeError('`requires_grad` is not supported for `step` in differentiable mode')\n",
    "                    state_steps.append(state['step'])\n",
    "\n",
    "            self.effective_stepsize = adam(params_with_grad,\n",
    "                 grads,\n",
    "                 exp_avgs,\n",
    "                 exp_avg_sqs,\n",
    "                 max_exp_avg_sqs,\n",
    "                 state_steps,\n",
    "                 amsgrad=group['amsgrad'],\n",
    "                 beta1=beta1,\n",
    "                 beta2=beta2,\n",
    "                 lr=group['lr'],\n",
    "                 weight_decay=group['weight_decay'],\n",
    "                 eps=group['eps'],\n",
    "                 maximize=group['maximize'],\n",
    "                 foreach=group['foreach'],\n",
    "                 capturable=group['capturable'],\n",
    "                 differentiable=group['differentiable'],\n",
    "                 fused=group['fused'],\n",
    "                 grad_scale=grad_scale,\n",
    "                 found_inf=found_inf)\n",
    "\n",
    "        return loss\n",
    "\n",
    "\n",
    "\n",
    "def adam(params: List[Tensor],\n",
    "         grads: List[Tensor],\n",
    "         exp_avgs: List[Tensor],\n",
    "         exp_avg_sqs: List[Tensor],\n",
    "         max_exp_avg_sqs: List[Tensor],\n",
    "         state_steps: List[Tensor],\n",
    "         # kwonly args with defaults are not supported by functions compiled with torchscript issue #70627\n",
    "         # setting this as kwarg for now as functional API is compiled by torch/distributed/optim\n",
    "         foreach: Optional[bool] = None,\n",
    "         capturable: bool = False,\n",
    "         differentiable: bool = False,\n",
    "         fused: bool = False,\n",
    "         grad_scale: Optional[_MultiDeviceReplicator] = None,\n",
    "         found_inf: Optional[_MultiDeviceReplicator] = None,\n",
    "         *,\n",
    "         amsgrad: bool,\n",
    "         beta1: float,\n",
    "         beta2: float,\n",
    "         lr: float,\n",
    "         weight_decay: float,\n",
    "         eps: float,\n",
    "         maximize: bool):\n",
    "    r\"\"\"Functional API that performs Adam algorithm computation.\n",
    "    See :class:`~torch.optim.Adam` for details.\n",
    "    \"\"\"\n",
    "\n",
    "    if not all(isinstance(t, torch.Tensor) for t in state_steps):\n",
    "        raise RuntimeError(\"API has changed, `state_steps` argument must contain a list of singleton tensors\")\n",
    "\n",
    "    if foreach is None:\n",
    "        # Placeholder for more complex foreach logic to be added when value is not set\n",
    "        foreach = False\n",
    "\n",
    "    if foreach and torch.jit.is_scripting():\n",
    "        raise RuntimeError('torch.jit.script not supported with foreach optimizers')\n",
    "\n",
    "    if foreach and not torch.jit.is_scripting():\n",
    "        raise NotImplementedError\n",
    "        func = _multi_tensor_adam\n",
    "    elif fused and not torch.jit.is_scripting():\n",
    "        raise NotImplementedError\n",
    "        func = _fused_adam\n",
    "    else:\n",
    "        func = _single_tensor_adam\n",
    "\n",
    "    return func(params,\n",
    "         grads,\n",
    "         exp_avgs,\n",
    "         exp_avg_sqs,\n",
    "         max_exp_avg_sqs,\n",
    "         state_steps,\n",
    "         amsgrad=amsgrad,\n",
    "         beta1=beta1,\n",
    "         beta2=beta2,\n",
    "         lr=lr,\n",
    "         weight_decay=weight_decay,\n",
    "         eps=eps,\n",
    "         maximize=maximize,\n",
    "         capturable=capturable,\n",
    "         differentiable=differentiable,\n",
    "         grad_scale=grad_scale,\n",
    "         found_inf=found_inf)\n",
    "\n",
    "\n",
    "def _single_tensor_adam(params: List[Tensor],\n",
    "                        grads: List[Tensor],\n",
    "                        exp_avgs: List[Tensor],\n",
    "                        exp_avg_sqs: List[Tensor],\n",
    "                        max_exp_avg_sqs: List[Tensor],\n",
    "                        state_steps: List[Tensor],\n",
    "                        grad_scale: Optional[_MultiDeviceReplicator],\n",
    "                        found_inf: Optional[_MultiDeviceReplicator],\n",
    "                        *,\n",
    "                        amsgrad: bool,\n",
    "                        beta1: float,\n",
    "                        beta2: float,\n",
    "                        lr: float,\n",
    "                        weight_decay: float,\n",
    "                        eps: float,\n",
    "                        maximize: bool,\n",
    "                        capturable: bool,\n",
    "                        differentiable: bool):\n",
    "\n",
    "    assert grad_scale is None and found_inf is None\n",
    "\n",
    "    for i, param in enumerate(params):\n",
    "\n",
    "        grad = grads[i] if not maximize else -grads[i]\n",
    "        exp_avg = exp_avgs[i]\n",
    "        exp_avg_sq = exp_avg_sqs[i]\n",
    "        step_t = state_steps[i]\n",
    "\n",
    "        if capturable:\n",
    "            assert param.is_cuda and step_t.is_cuda, \"If capturable=True, params and state_steps must be CUDA tensors.\"\n",
    "\n",
    "        # update step\n",
    "        step_t += 1\n",
    "\n",
    "        if weight_decay != 0:\n",
    "            grad = grad.add(param, alpha=weight_decay)\n",
    "\n",
    "        if torch.is_complex(param):\n",
    "            grad = torch.view_as_real(grad)\n",
    "            exp_avg = torch.view_as_real(exp_avg)\n",
    "            exp_avg_sq = torch.view_as_real(exp_avg_sq)\n",
    "            param = torch.view_as_real(param)\n",
    "\n",
    "        # Decay the first and second moment running average coefficient\n",
    "        exp_avg.mul_(beta1).add_(grad, alpha=1 - beta1)\n",
    "        exp_avg_sq.mul_(beta2).addcmul_(grad, grad.conj(), value=1 - beta2)\n",
    "\n",
    "        if capturable or differentiable:\n",
    "            raise NotImplementedError\n",
    "        else:\n",
    "            step = step_t.item()\n",
    "\n",
    "            bias_correction1 = 1 - beta1 ** step\n",
    "            bias_correction2 = 1 - beta2 ** step\n",
    "\n",
    "            lr_t = lr / (step ** 0.5)\n",
    "            step_size = lr_t / bias_correction1\n",
    "\n",
    "            bias_correction2_sqrt = math.sqrt(bias_correction2)\n",
    "\n",
    "            if amsgrad:\n",
    "                # Maintains the maximum of all 2nd moment running avg. till now\n",
    "                torch.maximum(max_exp_avg_sqs[i], exp_avg_sq, out=max_exp_avg_sqs[i])\n",
    "                # Use the max. for normalizing running avg. of gradient\n",
    "                denom = (max_exp_avg_sqs[i].sqrt() / bias_correction2_sqrt).add_(eps)\n",
    "            else:\n",
    "                denom = (exp_avg_sq.sqrt() / bias_correction2_sqrt).add_(eps)\n",
    "\n",
    "            param.addcdiv_(exp_avg, denom, value=-step_size)\n",
    "\n",
    "            #return step_size / denom.item()\n",
    "\n",
    "\n",
    "import torch\n",
    "from torch import Tensor\n",
    "from torch.optim.optimizer import Optimizer, required, _use_grad_for_differentiable\n",
    "from typing import List, Optional\n",
    "\n",
    "class CSGD(Optimizer):\n",
    "    r\"\"\"Implements stochastic gradient descent (optionally with momentum).\n",
    "\n",
    "    .. math::\n",
    "       \\begin{aligned}\n",
    "            &\\rule{110mm}{0.4pt}                                                                 \\\\\n",
    "            &\\textbf{input}      : \\gamma \\text{ (lr)}, \\: \\theta_0 \\text{ (params)}, \\: f(\\theta)\n",
    "                \\text{ (objective)}, \\: \\lambda \\text{ (weight decay)},                          \\\\\n",
    "            &\\hspace{13mm} \\:\\mu \\text{ (momentum)}, \\:\\tau \\text{ (dampening)},\n",
    "            \\:\\textit{ nesterov,}\\:\\textit{ maximize}                                     \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                                 \\\\\n",
    "            &\\textbf{for} \\: t=1 \\: \\textbf{to} \\: \\ldots \\: \\textbf{do}                         \\\\\n",
    "            &\\hspace{5mm}g_t           \\leftarrow   \\nabla_{\\theta} f_t (\\theta_{t-1})           \\\\\n",
    "            &\\hspace{5mm}\\textbf{if} \\: \\lambda \\neq 0                                           \\\\\n",
    "            &\\hspace{10mm} g_t \\leftarrow g_t + \\lambda  \\theta_{t-1}                            \\\\\n",
    "            &\\hspace{5mm}\\textbf{if} \\: \\mu \\neq 0                                               \\\\\n",
    "            &\\hspace{10mm}\\textbf{if} \\: t > 1                                                   \\\\\n",
    "            &\\hspace{15mm} \\textbf{b}_t \\leftarrow \\mu \\textbf{b}_{t-1} + (1-\\tau) g_t           \\\\\n",
    "            &\\hspace{10mm}\\textbf{else}                                                          \\\\\n",
    "            &\\hspace{15mm} \\textbf{b}_t \\leftarrow g_t                                           \\\\\n",
    "            &\\hspace{10mm}\\textbf{if} \\: \\textit{nesterov}                                       \\\\\n",
    "            &\\hspace{15mm} g_t \\leftarrow g_{t} + \\mu \\textbf{b}_t                             \\\\\n",
    "            &\\hspace{10mm}\\textbf{else}                                                   \\\\[-1.ex]\n",
    "            &\\hspace{15mm} g_t  \\leftarrow  \\textbf{b}_t                                         \\\\\n",
    "            &\\hspace{5mm}\\textbf{if} \\: \\textit{maximize}                                          \\\\\n",
    "            &\\hspace{10mm}\\theta_t \\leftarrow \\theta_{t-1} + \\gamma g_t                   \\\\[-1.ex]\n",
    "            &\\hspace{5mm}\\textbf{else}                                                    \\\\[-1.ex]\n",
    "            &\\hspace{10mm}\\theta_t \\leftarrow \\theta_{t-1} - \\gamma g_t                   \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                          \\\\[-1.ex]\n",
    "            &\\bf{return} \\:  \\theta_t                                                     \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                          \\\\[-1.ex]\n",
    "       \\end{aligned}\n",
    "\n",
    "    Nesterov momentum is based on the formula from\n",
    "    `On the importance of initialization and momentum in deep learning`__.\n",
    "\n",
    "    Args:\n",
    "        params (iterable): iterable of parameters to optimize or dicts defining\n",
    "            parameter groups\n",
    "        lr (float): learning rate\n",
    "        momentum (float, optional): momentum factor (default: 0)\n",
    "        weight_decay (float, optional): weight decay (L2 penalty) (default: 0)\n",
    "        dampening (float, optional): dampening for momentum (default: 0)\n",
    "        nesterov (bool, optional): enables Nesterov momentum (default: False)\n",
    "        maximize (bool, optional): maximize the params based on the objective, instead of\n",
    "            minimizing (default: False)\n",
    "        foreach (bool, optional): whether foreach implementation of optimizer\n",
    "            is used (default: None)\n",
    "\n",
    "    Example:\n",
    "        >>> # xdoctest: +SKIP\n",
    "        >>> optimizer = torch.optim.SGD(model.parameters(), lr=0.1, momentum=0.9)\n",
    "        >>> optimizer.zero_grad()\n",
    "        >>> loss_fn(model(input), target).backward()\n",
    "        >>> optimizer.step()\n",
    "\n",
    "    __ http://www.cs.toronto.edu/%7Ehinton/absps/momentum.pdf\n",
    "\n",
    "    .. note::\n",
    "        The implementation of SGD with Momentum/Nesterov subtly differs from\n",
    "        Sutskever et. al. and implementations in some other frameworks.\n",
    "\n",
    "        Considering the specific case of Momentum, the update can be written as\n",
    "\n",
    "        .. math::\n",
    "            \\begin{aligned}\n",
    "                v_{t+1} & = \\mu * v_{t} + g_{t+1}, \\\\\n",
    "                p_{t+1} & = p_{t} - \\text{lr} * v_{t+1},\n",
    "            \\end{aligned}\n",
    "\n",
    "        where :math:`p`, :math:`g`, :math:`v` and :math:`\\mu` denote the\n",
    "        parameters, gradient, velocity, and momentum respectively.\n",
    "\n",
    "        This is in contrast to Sutskever et. al. and\n",
    "        other frameworks which employ an update of the form\n",
    "\n",
    "        .. math::\n",
    "            \\begin{aligned}\n",
    "                v_{t+1} & = \\mu * v_{t} + \\text{lr} * g_{t+1}, \\\\\n",
    "                p_{t+1} & = p_{t} - v_{t+1}.\n",
    "            \\end{aligned}\n",
    "\n",
    "        The Nesterov version is analogously modified.\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(self, params, lr=required, momentum=0, dampening=0,\n",
    "                 weight_decay=0, nesterov=False, *, maximize=False, foreach: Optional[bool] = None,\n",
    "                 differentiable=False):\n",
    "        if lr is not required and 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",
    "\n",
    "        self.step_t = 0\n",
    "\n",
    "        defaults = dict(lr=lr, momentum=momentum, dampening=dampening,\n",
    "                        weight_decay=weight_decay, nesterov=nesterov,\n",
    "                        maximize=maximize, foreach=foreach,\n",
    "                        differentiable=differentiable)\n",
    "        if nesterov and (momentum <= 0 or dampening != 0):\n",
    "            raise ValueError(\"Nesterov momentum requires a momentum and zero dampening\")\n",
    "        super(CSGD, self).__init__(params, defaults)\n",
    "\n",
    "    def __setstate__(self, state):\n",
    "        super().__setstate__(state)\n",
    "        for group in self.param_groups:\n",
    "            group.setdefault('nesterov', False)\n",
    "            group.setdefault('maximize', False)\n",
    "            group.setdefault('foreach', None)\n",
    "            group.setdefault('differentiable', False)\n",
    "\n",
    "    @_use_grad_for_differentiable\n",
    "    def step(self, closure=None):\n",
    "        \"\"\"Performs a single optimization step.\n",
    "\n",
    "        Args:\n",
    "            closure (Callable, optional): A closure that reevaluates the model\n",
    "                and returns the loss.\n",
    "        \"\"\"\n",
    "        loss = None\n",
    "        if closure is not None:\n",
    "            with torch.enable_grad():\n",
    "                loss = closure()\n",
    "\n",
    "        for group in self.param_groups:\n",
    "            params_with_grad = []\n",
    "            d_p_list = []\n",
    "            momentum_buffer_list = []\n",
    "            has_sparse_grad = False\n",
    "\n",
    "            for p in group['params']:\n",
    "                if p.grad is not None:\n",
    "                    params_with_grad.append(p)\n",
    "                    d_p_list.append(p.grad)\n",
    "                    if p.grad.is_sparse:\n",
    "                        has_sparse_grad = True\n",
    "\n",
    "                    state = self.state[p]\n",
    "                    if 'momentum_buffer' not in state:\n",
    "                        momentum_buffer_list.append(None)\n",
    "                    else:\n",
    "                        momentum_buffer_list.append(state['momentum_buffer'])\n",
    "\n",
    "            self.effective_stepsize = sgd(params_with_grad,\n",
    "                d_p_list,\n",
    "                momentum_buffer_list,\n",
    "                weight_decay=group['weight_decay'],\n",
    "                momentum=group['momentum'],\n",
    "                lr=group['lr'],\n",
    "                dampening=group['dampening'],\n",
    "                nesterov=group['nesterov'],\n",
    "                maximize=group['maximize'],\n",
    "                has_sparse_grad=has_sparse_grad,\n",
    "                foreach=group['foreach'],\n",
    "                step=self.step_t)\n",
    "\n",
    "            # update momentum_buffers in state\n",
    "            for p, momentum_buffer in zip(params_with_grad, momentum_buffer_list):\n",
    "                state = self.state[p]\n",
    "                state['momentum_buffer'] = momentum_buffer\n",
    "\n",
    "        self.step_t += 1\n",
    "\n",
    "        return loss\n",
    "\n",
    "\n",
    "\n",
    "def sgd(params: List[Tensor],\n",
    "        d_p_list: List[Tensor],\n",
    "        momentum_buffer_list: List[Optional[Tensor]],\n",
    "        # kwonly args with defaults are not supported by functions compiled with torchscript issue #70627\n",
    "        # setting this as kwarg for now as functional API is compiled by torch/distributed/optim\n",
    "        has_sparse_grad: bool = None,\n",
    "        foreach: bool = None,\n",
    "        *,\n",
    "        weight_decay: float,\n",
    "        momentum: float,\n",
    "        lr: float,\n",
    "        dampening: float,\n",
    "        nesterov: bool,\n",
    "        maximize: bool,\n",
    "        step):\n",
    "    r\"\"\"Functional API that performs SGD algorithm computation.\n",
    "\n",
    "    See :class:`~torch.optim.SGD` for details.\n",
    "    \"\"\"\n",
    "\n",
    "    if foreach is None:\n",
    "        # Placeholder for more complex foreach logic to be added when value is not set\n",
    "        foreach = False\n",
    "\n",
    "    if foreach and torch.jit.is_scripting():\n",
    "        raise RuntimeError('torch.jit.script not supported with foreach optimizers')\n",
    "\n",
    "    if foreach and not torch.jit.is_scripting():\n",
    "        raise NotImplementedError\n",
    "        func = _multi_tensor_sgd\n",
    "    else:\n",
    "        func = _single_tensor_sgd\n",
    "\n",
    "    return func(params,\n",
    "         d_p_list,\n",
    "         momentum_buffer_list,\n",
    "         weight_decay=weight_decay,\n",
    "         momentum=momentum,\n",
    "         lr=lr,\n",
    "         dampening=dampening,\n",
    "         nesterov=nesterov,\n",
    "         has_sparse_grad=has_sparse_grad,\n",
    "         maximize=maximize,\n",
    "         step=step)\n",
    "\n",
    "def _single_tensor_sgd(params: List[Tensor],\n",
    "                       d_p_list: List[Tensor],\n",
    "                       momentum_buffer_list: List[Optional[Tensor]],\n",
    "                       *,\n",
    "                       weight_decay: float,\n",
    "                       momentum: float,\n",
    "                       lr: float,\n",
    "                       dampening: float,\n",
    "                       nesterov: bool,\n",
    "                       maximize: bool,\n",
    "                       has_sparse_grad: bool,\n",
    "                       step):\n",
    "\n",
    "    for i, param in enumerate(params):\n",
    "        d_p = d_p_list[i] if not maximize else -d_p_list[i]\n",
    "\n",
    "        if weight_decay != 0:\n",
    "            d_p = d_p.add(param, alpha=weight_decay)\n",
    "\n",
    "        if momentum != 0:\n",
    "            buf = momentum_buffer_list[i]\n",
    "\n",
    "            if buf is None:\n",
    "                buf = torch.clone(d_p).detach()\n",
    "                momentum_buffer_list[i] = buf\n",
    "            else:\n",
    "                buf.mul_(momentum).add_(d_p, alpha=1 - dampening)\n",
    "\n",
    "            if nesterov:\n",
    "                d_p = d_p.add(buf, alpha=momentum)\n",
    "            else:\n",
    "                d_p = buf\n",
    "\n",
    "        lr_t = lr / ((step + 1) ** 0.5)\n",
    "\n",
    "        param.add_(d_p, alpha=-lr_t)\n",
    "\n",
    "        #return lr_t\n",
    "\n",
    "import torch\n",
    "from torch import Tensor\n",
    "\n",
    "from torch.optim.optimizer import Optimizer\n",
    "from typing import List, Optional\n",
    "\n",
    "class Adagrad(Optimizer):\n",
    "    r\"\"\"Implements Adagrad algorithm.\n",
    "\n",
    "    .. math::\n",
    "       \\begin{aligned}\n",
    "            &\\rule{110mm}{0.4pt}                                                                 \\\\\n",
    "            &\\textbf{input}      : \\gamma \\text{ (lr)}, \\: \\theta_0 \\text{ (params)}, \\: f(\\theta)\n",
    "                \\text{ (objective)}, \\: \\lambda \\text{ (weight decay)},                          \\\\\n",
    "            &\\hspace{12mm}    \\tau \\text{ (initial accumulator value)}, \\: \\eta\\text{ (lr decay)}\\\\\n",
    "            &\\textbf{initialize} :  state\\_sum_0 \\leftarrow 0                             \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                                 \\\\\n",
    "            &\\textbf{for} \\: t=1 \\: \\textbf{to} \\: \\ldots \\: \\textbf{do}                         \\\\\n",
    "            &\\hspace{5mm}g_t           \\leftarrow   \\nabla_{\\theta} f_t (\\theta_{t-1})           \\\\\n",
    "            &\\hspace{5mm} \\tilde{\\gamma}    \\leftarrow \\gamma / (1 +(t-1) \\eta)                  \\\\\n",
    "            &\\hspace{5mm} \\textbf{if} \\: \\lambda \\neq 0                                          \\\\\n",
    "            &\\hspace{10mm} g_t \\leftarrow g_t + \\lambda \\theta_{t-1}                             \\\\\n",
    "            &\\hspace{5mm}state\\_sum_t  \\leftarrow  state\\_sum_{t-1} + g^2_t                      \\\\\n",
    "            &\\hspace{5mm}\\theta_t \\leftarrow\n",
    "                \\theta_{t-1}- \\tilde{\\gamma} \\frac{g_t}{\\sqrt{state\\_sum_t}+\\epsilon}            \\\\\n",
    "            &\\rule{110mm}{0.4pt}                                                          \\\\[-1.ex]\n",
    "            &\\bf{return} \\:  \\theta_t                                                     \\\\[-1.ex]\n",
    "            &\\rule{110mm}{0.4pt}                                                          \\\\[-1.ex]\n",
    "       \\end{aligned}\n",
    "\n",
    "    For further details regarding the algorithm we refer to `Adaptive Subgradient Methods for Online Learning\n",
    "    and Stochastic Optimization`_.\n",
    "\n",
    "    Args:\n",
    "        params (iterable): iterable of parameters to optimize or dicts defining\n",
    "            parameter groups\n",
    "        lr (float, optional): learning rate (default: 1e-2)\n",
    "        lr_decay (float, optional): learning rate decay (default: 0)\n",
    "        weight_decay (float, optional): weight decay (L2 penalty) (default: 0)\n",
    "        eps (float, optional): term added to the denominator to improve\n",
    "            numerical stability (default: 1e-10)\n",
    "        foreach (bool, optional): whether foreach implementation of optimizer is used (default: None)\n",
    "        maximize (bool, optional): maximize the params based on the objective, instead of\n",
    "            minimizing (default: False)\n",
    "\n",
    "    .. _Adaptive Subgradient Methods for Online Learning and Stochastic\n",
    "        Optimization: http://jmlr.org/papers/v12/duchi11a.html\n",
    "    \"\"\"\n",
    "\n",
    "    def __init__(\n",
    "        self,\n",
    "        params,\n",
    "        lr=1e-2,\n",
    "        lr_decay=0,\n",
    "        weight_decay=0,\n",
    "        initial_accumulator_value=0,\n",
    "        eps=1e-10,\n",
    "        foreach: Optional[bool] = None,\n",
    "        *,\n",
    "        maximize: bool = False\n",
    "    ):\n",
    "        if not 0.0 <= lr:\n",
    "            raise ValueError(\"Invalid learning rate: {}\".format(lr))\n",
    "        if not 0.0 <= lr_decay:\n",
    "            raise ValueError(\"Invalid lr_decay value: {}\".format(lr_decay))\n",
    "        if not 0.0 <= weight_decay:\n",
    "            raise ValueError(\"Invalid weight_decay value: {}\".format(weight_decay))\n",
    "        if not 0.0 <= initial_accumulator_value:\n",
    "            raise ValueError(\n",
    "                \"Invalid initial_accumulator_value value: {}\".format(\n",
    "                    initial_accumulator_value\n",
    "                )\n",
    "            )\n",
    "        if not 0.0 <= eps:\n",
    "            raise ValueError(\"Invalid epsilon value: {}\".format(eps))\n",
    "\n",
    "        defaults = dict(\n",
    "            lr=lr,\n",
    "            lr_decay=lr_decay,\n",
    "            eps=eps,\n",
    "            weight_decay=weight_decay,\n",
    "            initial_accumulator_value=initial_accumulator_value,\n",
    "            foreach=foreach,\n",
    "            maximize=maximize,\n",
    "        )\n",
    "        super(Adagrad, self).__init__(params, defaults)\n",
    "\n",
    "        for group in self.param_groups:\n",
    "            for p in group[\"params\"]:\n",
    "                state = self.state[p]\n",
    "                state[\"step\"] = torch.tensor(0.0)\n",
    "                init_value = (\n",
    "                    complex(initial_accumulator_value, initial_accumulator_value)\n",
    "                    if torch.is_complex(p)\n",
    "                    else initial_accumulator_value\n",
    "                )\n",
    "                state[\"sum\"] = torch.full_like(\n",
    "                    p, init_value, memory_format=torch.preserve_format\n",
    "                )\n",
    "\n",
    "    def __setstate__(self, state):\n",
    "        super().__setstate__(state)\n",
    "        for group in self.param_groups:\n",
    "            group.setdefault(\"foreach\", None)\n",
    "            group.setdefault(\"maximize\", False)\n",
    "\n",
    "        state_values = list(self.state.values())\n",
    "        step_is_tensor = (len(state_values) != 0) and torch.is_tensor(\n",
    "            state_values[0][\"step\"]\n",
    "        )\n",
    "        if not step_is_tensor:\n",
    "            for s in state_values:\n",
    "                s[\"step\"] = torch.tensor(float(s[\"step\"]))\n",
    "\n",
    "    def share_memory(self):\n",
    "        for group in self.param_groups:\n",
    "            for p in group[\"params\"]:\n",
    "                state = self.state[p]\n",
    "                state[\"sum\"].share_memory_()\n",
    "\n",
    "    @torch.no_grad()\n",
    "    def step(self, closure=None):\n",
    "        \"\"\"Performs a single optimization step.\n",
    "\n",
    "        Args:\n",
    "            closure (Callable, optional): A closure that reevaluates the model\n",
    "                and returns the loss.\n",
    "        \"\"\"\n",
    "        loss = None\n",
    "\n",
    "        if closure is not None:\n",
    "            with torch.enable_grad():\n",
    "                loss = closure()\n",
    "\n",
    "        for group in self.param_groups:\n",
    "            params_with_grad = []\n",
    "            grads = []\n",
    "            state_sums = []\n",
    "            state_steps = []\n",
    "\n",
    "            has_sparse_grad = False\n",
    "            for p in group[\"params\"]:\n",
    "                if p.grad is not None:\n",
    "                    if p.grad.is_sparse:\n",
    "                        has_sparse_grad = True\n",
    "                    params_with_grad.append(p)\n",
    "                    grads.append(p.grad)\n",
    "                    state = self.state[p]\n",
    "                    state_sums.append(state[\"sum\"])\n",
    "                    state_steps.append(state[\"step\"])\n",
    "\n",
    "            self.effective_stepsize = adagrad(\n",
    "                params_with_grad,\n",
    "                grads,\n",
    "                state_sums,\n",
    "                state_steps,\n",
    "                lr=group[\"lr\"],\n",
    "                weight_decay=group[\"weight_decay\"],\n",
    "                lr_decay=group[\"lr_decay\"],\n",
    "                eps=group[\"eps\"],\n",
    "                has_sparse_grad=has_sparse_grad,\n",
    "                foreach=group[\"foreach\"],\n",
    "                maximize=group[\"maximize\"],\n",
    "            )\n",
    "\n",
    "        return loss\n",
    "\n",
    "\n",
    "\n",
    "def adagrad(\n",
    "    params: List[Tensor],\n",
    "    grads: List[Tensor],\n",
    "    state_sums: List[Tensor],\n",
    "    state_steps: List[Tensor],\n",
    "    # kwonly args with defaults are not supported by functions compiled with torchscript issue #70627\n",
    "    # setting these as kwargs for now as functional API is compiled by torch/distributed/optim\n",
    "    has_sparse_grad: bool = None,\n",
    "    foreach: bool = None,\n",
    "    *,\n",
    "    lr: float,\n",
    "    weight_decay: float,\n",
    "    lr_decay: float,\n",
    "    eps: float,\n",
    "    maximize: bool,\n",
    "):\n",
    "    r\"\"\"Functional API that performs Adagrad algorithm computation.\n",
    "\n",
    "    See :class:`~torch.optim.Adagrad` for details.\n",
    "    \"\"\"\n",
    "\n",
    "    if not all(isinstance(t, torch.Tensor) for t in state_steps):\n",
    "        raise RuntimeError(\n",
    "            \"API has changed, `state_steps` argument must contain a list of singleton tensors\"\n",
    "        )\n",
    "\n",
    "    if foreach is None:\n",
    "        # Placeholder for more complex foreach logic to be added when value is not set\n",
    "        foreach = False\n",
    "\n",
    "    if foreach and torch.jit.is_scripting():\n",
    "        raise RuntimeError(\"torch.jit.script not supported with foreach optimizers\")\n",
    "\n",
    "    if foreach and not torch.jit.is_scripting():\n",
    "        raise NotImplementedError\n",
    "        func = _multi_tensor_adagrad\n",
    "    else:\n",
    "        func = _single_tensor_adagrad\n",
    "\n",
    "    return func(\n",
    "        params,\n",
    "        grads,\n",
    "        state_sums,\n",
    "        state_steps,\n",
    "        lr=lr,\n",
    "        weight_decay=weight_decay,\n",
    "        lr_decay=lr_decay,\n",
    "        eps=eps,\n",
    "        has_sparse_grad=has_sparse_grad,\n",
    "        maximize=maximize,\n",
    "    )\n",
    "\n",
    "\n",
    "def _single_tensor_adagrad(\n",
    "    params: List[Tensor],\n",
    "    grads: List[Tensor],\n",
    "    state_sums: List[Tensor],\n",
    "    state_steps: List[Tensor],\n",
    "    *,\n",
    "    lr: float,\n",
    "    weight_decay: float,\n",
    "    lr_decay: float,\n",
    "    eps: float,\n",
    "    has_sparse_grad: bool,\n",
    "    maximize: bool,\n",
    "):\n",
    "\n",
    "    for (param, grad, state_sum, step_t) in zip(params, grads, state_sums, state_steps):\n",
    "        # update step\n",
    "        step_t += 1\n",
    "        step = step_t.item()\n",
    "        grad = grad if not maximize else -grad\n",
    "\n",
    "        if weight_decay != 0:\n",
    "            if grad.is_sparse:\n",
    "                raise RuntimeError(\n",
    "                    \"weight_decay option is not compatible with sparse gradients\"\n",
    "                )\n",
    "            grad = grad.add(param, alpha=weight_decay)\n",
    "\n",
    "        clr = lr / (1 + (step - 1) * lr_decay)\n",
    "\n",
    "        if grad.is_sparse:\n",
    "            raise NotImplementedError\n",
    "            # grad = grad.coalesce()  # the update is non-linear so indices must be unique\n",
    "            # grad_indices = grad._indices()\n",
    "            # grad_values = grad._values()\n",
    "            # size = grad.size()\n",
    "            #\n",
    "            # state_sum.add_(_make_sparse(grad, grad_indices, grad_values.pow(2)))\n",
    "            # std = state_sum.sparse_mask(grad)\n",
    "            # std_values = std._values().sqrt_().add_(eps)\n",
    "            # param.add_(\n",
    "            #     _make_sparse(grad, grad_indices, grad_values / std_values), alpha=-clr\n",
    "            # )\n",
    "        else:\n",
    "            is_complex = torch.is_complex(param)\n",
    "            if is_complex:\n",
    "                raise NotImplementedError\n",
    "                # grad = torch.view_as_real(grad)\n",
    "                # state_sum = torch.view_as_real(state_sum)\n",
    "                # param = torch.view_as_real(param)\n",
    "            state_sum.addcmul_(grad, grad, value=1)\n",
    "            std = state_sum.sqrt().add_(eps)\n",
    "            param.addcdiv_(grad, std, value=-clr)\n",
    "            #return clr / std.item()\n",
    "            # if is_complex:\n",
    "            #     param = torch.view_as_complex(param)\n",
    "            #     state_sum = torch.view_as_complex(state_sum)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2fd69030",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "\n",
    "import torch\n",
    "import torchvision\n",
    "import torch.nn as tn\n",
    "import torch.nn as nn\n",
    "import matplotlib.pyplot as plt\n",
    "import torchvision.transforms as tt\n",
    "import torch.utils as utils\n",
    "from tqdm.notebook import trange, tqdm\n",
    "import numpy as np\n",
    "import torch.nn.functional as F\n",
    "\n",
    "\n",
    "device = torch.device(\"cpu\")\n",
    "batch_size = 128\n",
    "test_batch = 10000\n",
    "\n",
    "# Load dataset to memory to accelerate\n",
    "temp_dataset = torchvision.datasets.MNIST('./data', download=True, transform=tt.ToTensor())\n",
    "temp_loader = torch.utils.data.DataLoader(temp_dataset,\n",
    "        batch_size=len(temp_dataset),\n",
    "        shuffle=False)\n",
    "for data, label in temp_loader:\n",
    "    tensor_data = data.to(device)\n",
    "    tensor_label = label.to(device)\n",
    "\n",
    "\n",
    "train_data = torch.utils.data.TensorDataset(tensor_data, tensor_label)\n",
    "\n",
    "# Test dataset\n",
    "temp_dataset = torchvision.datasets.MNIST('data', train=False, transform=tt.ToTensor())\n",
    "temp_loader = torch.utils.data.DataLoader(temp_dataset,\n",
    "        batch_size=len(temp_dataset),\n",
    "        shuffle=False)\n",
    "for data, label in temp_loader:\n",
    "    tensor_data = data.to(device)\n",
    "    tensor_label = label.to(device)\n",
    "    \n",
    "test_data = torch.utils.data.TensorDataset(tensor_data, tensor_label)\n",
    "\n",
    "\n",
    "input_size = 784\n",
    "num_classes = 10\n",
    "\n",
    "\n",
    "class MLP(nn.Module) :\n",
    "    def __init__(self):\n",
    "        super(MLP, self).__init__()\n",
    "        self.linear1 = nn.Linear(784,512)\n",
    "        self.linear2 = nn.Linear(512,256)\n",
    "        self.linear3 = nn.Linear(256,10)\n",
    "    \n",
    "    def forward(self,input):\n",
    "        x = F.relu(self.linear1(input))\n",
    "        x = F.relu(self.linear2(x))\n",
    "        x = self.linear3(x)\n",
    "        return x\n",
    "\n",
    "\n",
    "class LogisticRegression(tn.Module):\n",
    "    def __init__(self,input_size,num_classes):\n",
    "        super(LogisticRegression,self).__init__()\n",
    "        self.linear = tn.Linear(input_size,num_classes)\n",
    "    \n",
    "    def forward(self,feature):\n",
    "        output = self.linear(feature)\n",
    "        return output\n",
    "    \n",
    "loss = nn.CrossEntropyLoss()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1663f363",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "38799379f0d14993956fb171d818d6cd",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/3 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import math\n",
    "from itertools import product\n",
    "\n",
    "def get_gradient_norm(params, norm_type=2.0):\n",
    "    with torch.no_grad():\n",
    "        total_norm = torch.norm(torch.stack(\n",
    "            [torch.norm(\n",
    "                p.grad.detach(), norm_type) \\\n",
    "                        for p in params]), norm_type)\n",
    "    return total_norm\n",
    "\n",
    "\n",
    "num_epochs = 1\n",
    "\n",
    "methods = ('SGD', 'NSGD-M', 'AdaGrad')\n",
    "\n",
    "lrs = [10]\n",
    "\n",
    "results = {}\n",
    "for method in methods:\n",
    "    results[method] = {}\n",
    "    for lr in lrs:\n",
    "        results[method][lr] = {}\n",
    "        results[method][lr]['train_loss'] = []\n",
    "        results[method][lr]['test_loss'] = []\n",
    "        results[method][lr]['grad'] = []\n",
    "\n",
    "for lr, method in tqdm(list(product(lrs, methods))):\n",
    "    random.seed(8)\n",
    "    np.random.seed(8)\n",
    "    torch.manual_seed(8)\n",
    "    \n",
    "    train_dataLoader = torch.utils.data.DataLoader(train_data, batch_size=batch_size,shuffle=True)\n",
    "    test_dataLoader = torch.utils.data.DataLoader(test_data,batch_size=test_batch,shuffle=False)\n",
    "    train_loss_dataLoader = torch.utils.data.DataLoader(train_data, batch_size=test_batch,shuffle=False)\n",
    "\n",
    "\n",
    "    model = MLP().to(device)\n",
    "    \n",
    "    iters = []\n",
    "\n",
    "    if method == 'SGD':\n",
    "        optimizer = CSGD(model.parameters(), lr=lr)\n",
    "    elif method == 'NSGD-M':\n",
    "        optimizer = NSGD(model.parameters(), lr=lr)\n",
    "    elif method == 'AdaGrad':\n",
    "        optimizer = Adagrad(model.parameters(), lr=lr, initial_accumulator_value=1)\n",
    "\n",
    "    run = 0\n",
    "    for epoch in range(num_epochs):\n",
    "        for i,(images,labels) in enumerate(train_dataLoader):\n",
    "            \n",
    "            batch_len = images.shape[0]\n",
    "            images = images.view(batch_len, -1)\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            output = model(images)\n",
    "            compute_loss = loss(output,labels)\n",
    "            compute_loss.backward()\n",
    "            optimizer.step()\n",
    "            \n",
    "            results[method][lr]['grad'].append(get_gradient_norm(model.parameters()).item())\n",
    "\n",
    "            if run % 10 == 0 and False:\n",
    "                iters.append(run)\n",
    "                \n",
    "                \n",
    "                # train loss\n",
    "                current_train_loss = 0\n",
    "                total_sample = 0\n",
    "                with torch.no_grad():\n",
    "                    for images,labels in train_loss_dataLoader:\n",
    "                        batch_len = images.shape[0]\n",
    "                        images = images.view(batch_len, -1)\n",
    "                        labels = F.one_hot(labels, num_classes=10)\n",
    "                        \n",
    "                        output = model(images)\n",
    "                        current_train_loss += loss(output,labels).item() * batch_len\n",
    "                        total_sample += labels.shape[0]\n",
    "                current_train_loss /= total_sample\n",
    "                results[method][lr]['train_loss'].append(current_train_loss)\n",
    "\n",
    "            run += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "a84e6d23",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "application/javascript": [
       "/* Put everything inside the global mpl namespace */\n",
       "/* global mpl */\n",
       "window.mpl = {};\n",
       "\n",
       "mpl.get_websocket_type = function () {\n",
       "    if (typeof WebSocket !== 'undefined') {\n",
       "        return WebSocket;\n",
       "    } else if (typeof MozWebSocket !== 'undefined') {\n",
       "        return MozWebSocket;\n",
       "    } else {\n",
       "        alert(\n",
       "            'Your browser does not have WebSocket support. ' +\n",
       "                'Please try Chrome, Safari or Firefox ≥ 6. ' +\n",
       "                'Firefox 4 and 5 are also supported but you ' +\n",
       "                'have to enable WebSockets in about:config.'\n",
       "        );\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure = function (figure_id, websocket, ondownload, parent_element) {\n",
       "    this.id = figure_id;\n",
       "\n",
       "    this.ws = websocket;\n",
       "\n",
       "    this.supports_binary = this.ws.binaryType !== undefined;\n",
       "\n",
       "    if (!this.supports_binary) {\n",
       "        var warnings = document.getElementById('mpl-warnings');\n",
       "        if (warnings) {\n",
       "            warnings.style.display = 'block';\n",
       "            warnings.textContent =\n",
       "                'This browser does not support binary websocket messages. ' +\n",
       "                'Performance may be slow.';\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.imageObj = new Image();\n",
       "\n",
       "    this.context = undefined;\n",
       "    this.message = undefined;\n",
       "    this.canvas = undefined;\n",
       "    this.rubberband_canvas = undefined;\n",
       "    this.rubberband_context = undefined;\n",
       "    this.format_dropdown = undefined;\n",
       "\n",
       "    this.image_mode = 'full';\n",
       "\n",
       "    this.root = document.createElement('div');\n",
       "    this.root.setAttribute('style', 'display: inline-block');\n",
       "    this._root_extra_style(this.root);\n",
       "\n",
       "    parent_element.appendChild(this.root);\n",
       "\n",
       "    this._init_header(this);\n",
       "    this._init_canvas(this);\n",
       "    this._init_toolbar(this);\n",
       "\n",
       "    var fig = this;\n",
       "\n",
       "    this.waiting = false;\n",
       "\n",
       "    this.ws.onopen = function () {\n",
       "        fig.send_message('supports_binary', { value: fig.supports_binary });\n",
       "        fig.send_message('send_image_mode', {});\n",
       "        if (fig.ratio !== 1) {\n",
       "            fig.send_message('set_device_pixel_ratio', {\n",
       "                device_pixel_ratio: fig.ratio,\n",
       "            });\n",
       "        }\n",
       "        fig.send_message('refresh', {});\n",
       "    };\n",
       "\n",
       "    this.imageObj.onload = function () {\n",
       "        if (fig.image_mode === 'full') {\n",
       "            // Full images could contain transparency (where diff images\n",
       "            // almost always do), so we need to clear the canvas so that\n",
       "            // there is no ghosting.\n",
       "            fig.context.clearRect(0, 0, fig.canvas.width, fig.canvas.height);\n",
       "        }\n",
       "        fig.context.drawImage(fig.imageObj, 0, 0);\n",
       "    };\n",
       "\n",
       "    this.imageObj.onunload = function () {\n",
       "        fig.ws.close();\n",
       "    };\n",
       "\n",
       "    this.ws.onmessage = this._make_on_message_function(this);\n",
       "\n",
       "    this.ondownload = ondownload;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_header = function () {\n",
       "    var titlebar = document.createElement('div');\n",
       "    titlebar.classList =\n",
       "        'ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix';\n",
       "    var titletext = document.createElement('div');\n",
       "    titletext.classList = 'ui-dialog-title';\n",
       "    titletext.setAttribute(\n",
       "        'style',\n",
       "        'width: 100%; text-align: center; padding: 3px;'\n",
       "    );\n",
       "    titlebar.appendChild(titletext);\n",
       "    this.root.appendChild(titlebar);\n",
       "    this.header = titletext;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (_canvas_div) {};\n",
       "\n",
       "mpl.figure.prototype._init_canvas = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var canvas_div = (this.canvas_div = document.createElement('div'));\n",
       "    canvas_div.setAttribute(\n",
       "        'style',\n",
       "        'border: 1px solid #ddd;' +\n",
       "            'box-sizing: content-box;' +\n",
       "            'clear: both;' +\n",
       "            'min-height: 1px;' +\n",
       "            'min-width: 1px;' +\n",
       "            'outline: 0;' +\n",
       "            'overflow: hidden;' +\n",
       "            'position: relative;' +\n",
       "            'resize: both;'\n",
       "    );\n",
       "\n",
       "    function on_keyboard_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.key_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    canvas_div.addEventListener(\n",
       "        'keydown',\n",
       "        on_keyboard_event_closure('key_press')\n",
       "    );\n",
       "    canvas_div.addEventListener(\n",
       "        'keyup',\n",
       "        on_keyboard_event_closure('key_release')\n",
       "    );\n",
       "\n",
       "    this._canvas_extra_style(canvas_div);\n",
       "    this.root.appendChild(canvas_div);\n",
       "\n",
       "    var canvas = (this.canvas = document.createElement('canvas'));\n",
       "    canvas.classList.add('mpl-canvas');\n",
       "    canvas.setAttribute('style', 'box-sizing: content-box;');\n",
       "\n",
       "    this.context = canvas.getContext('2d');\n",
       "\n",
       "    var backingStore =\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        this.context.webkitBackingStorePixelRatio ||\n",
       "        this.context.mozBackingStorePixelRatio ||\n",
       "        this.context.msBackingStorePixelRatio ||\n",
       "        this.context.oBackingStorePixelRatio ||\n",
       "        this.context.backingStorePixelRatio ||\n",
       "        1;\n",
       "\n",
       "    this.ratio = (window.devicePixelRatio || 1) / backingStore;\n",
       "\n",
       "    var rubberband_canvas = (this.rubberband_canvas = document.createElement(\n",
       "        'canvas'\n",
       "    ));\n",
       "    rubberband_canvas.setAttribute(\n",
       "        'style',\n",
       "        'box-sizing: content-box; position: absolute; left: 0; top: 0; z-index: 1;'\n",
       "    );\n",
       "\n",
       "    // Apply a ponyfill if ResizeObserver is not implemented by browser.\n",
       "    if (this.ResizeObserver === undefined) {\n",
       "        if (window.ResizeObserver !== undefined) {\n",
       "            this.ResizeObserver = window.ResizeObserver;\n",
       "        } else {\n",
       "            var obs = _JSXTOOLS_RESIZE_OBSERVER({});\n",
       "            this.ResizeObserver = obs.ResizeObserver;\n",
       "        }\n",
       "    }\n",
       "\n",
       "    this.resizeObserverInstance = new this.ResizeObserver(function (entries) {\n",
       "        var nentries = entries.length;\n",
       "        for (var i = 0; i < nentries; i++) {\n",
       "            var entry = entries[i];\n",
       "            var width, height;\n",
       "            if (entry.contentBoxSize) {\n",
       "                if (entry.contentBoxSize instanceof Array) {\n",
       "                    // Chrome 84 implements new version of spec.\n",
       "                    width = entry.contentBoxSize[0].inlineSize;\n",
       "                    height = entry.contentBoxSize[0].blockSize;\n",
       "                } else {\n",
       "                    // Firefox implements old version of spec.\n",
       "                    width = entry.contentBoxSize.inlineSize;\n",
       "                    height = entry.contentBoxSize.blockSize;\n",
       "                }\n",
       "            } else {\n",
       "                // Chrome <84 implements even older version of spec.\n",
       "                width = entry.contentRect.width;\n",
       "                height = entry.contentRect.height;\n",
       "            }\n",
       "\n",
       "            // Keep the size of the canvas and rubber band canvas in sync with\n",
       "            // the canvas container.\n",
       "            if (entry.devicePixelContentBoxSize) {\n",
       "                // Chrome 84 implements new version of spec.\n",
       "                canvas.setAttribute(\n",
       "                    'width',\n",
       "                    entry.devicePixelContentBoxSize[0].inlineSize\n",
       "                );\n",
       "                canvas.setAttribute(\n",
       "                    'height',\n",
       "                    entry.devicePixelContentBoxSize[0].blockSize\n",
       "                );\n",
       "            } else {\n",
       "                canvas.setAttribute('width', width * fig.ratio);\n",
       "                canvas.setAttribute('height', height * fig.ratio);\n",
       "            }\n",
       "            canvas.setAttribute(\n",
       "                'style',\n",
       "                'width: ' + width + 'px; height: ' + height + 'px;'\n",
       "            );\n",
       "\n",
       "            rubberband_canvas.setAttribute('width', width);\n",
       "            rubberband_canvas.setAttribute('height', height);\n",
       "\n",
       "            // And update the size in Python. We ignore the initial 0/0 size\n",
       "            // that occurs as the element is placed into the DOM, which should\n",
       "            // otherwise not happen due to the minimum size styling.\n",
       "            if (fig.ws.readyState == 1 && width != 0 && height != 0) {\n",
       "                fig.request_resize(width, height);\n",
       "            }\n",
       "        }\n",
       "    });\n",
       "    this.resizeObserverInstance.observe(canvas_div);\n",
       "\n",
       "    function on_mouse_event_closure(name) {\n",
       "        return function (event) {\n",
       "            return fig.mouse_event(event, name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousedown',\n",
       "        on_mouse_event_closure('button_press')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseup',\n",
       "        on_mouse_event_closure('button_release')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'dblclick',\n",
       "        on_mouse_event_closure('dblclick')\n",
       "    );\n",
       "    // Throttle sequential mouse events to 1 every 20ms.\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mousemove',\n",
       "        on_mouse_event_closure('motion_notify')\n",
       "    );\n",
       "\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseenter',\n",
       "        on_mouse_event_closure('figure_enter')\n",
       "    );\n",
       "    rubberband_canvas.addEventListener(\n",
       "        'mouseleave',\n",
       "        on_mouse_event_closure('figure_leave')\n",
       "    );\n",
       "\n",
       "    canvas_div.addEventListener('wheel', function (event) {\n",
       "        if (event.deltaY < 0) {\n",
       "            event.step = 1;\n",
       "        } else {\n",
       "            event.step = -1;\n",
       "        }\n",
       "        on_mouse_event_closure('scroll')(event);\n",
       "    });\n",
       "\n",
       "    canvas_div.appendChild(canvas);\n",
       "    canvas_div.appendChild(rubberband_canvas);\n",
       "\n",
       "    this.rubberband_context = rubberband_canvas.getContext('2d');\n",
       "    this.rubberband_context.strokeStyle = '#000000';\n",
       "\n",
       "    this._resize_canvas = function (width, height, forward) {\n",
       "        if (forward) {\n",
       "            canvas_div.style.width = width + 'px';\n",
       "            canvas_div.style.height = height + 'px';\n",
       "        }\n",
       "    };\n",
       "\n",
       "    // Disable right mouse context menu.\n",
       "    this.rubberband_canvas.addEventListener('contextmenu', function (_e) {\n",
       "        event.preventDefault();\n",
       "        return false;\n",
       "    });\n",
       "\n",
       "    function set_focus() {\n",
       "        canvas.focus();\n",
       "        canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    window.setTimeout(set_focus, 100);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'mpl-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'mpl-button-group';\n",
       "    for (var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'mpl-button-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        var button = (fig.buttons[name] = document.createElement('button'));\n",
       "        button.classList = 'mpl-widget';\n",
       "        button.setAttribute('role', 'button');\n",
       "        button.setAttribute('aria-disabled', 'false');\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "\n",
       "        var icon_img = document.createElement('img');\n",
       "        icon_img.src = '_images/' + image + '.png';\n",
       "        icon_img.srcset = '_images/' + image + '_large.png 2x';\n",
       "        icon_img.alt = tooltip;\n",
       "        button.appendChild(icon_img);\n",
       "\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    var fmt_picker = document.createElement('select');\n",
       "    fmt_picker.classList = 'mpl-widget';\n",
       "    toolbar.appendChild(fmt_picker);\n",
       "    this.format_dropdown = fmt_picker;\n",
       "\n",
       "    for (var ind in mpl.extensions) {\n",
       "        var fmt = mpl.extensions[ind];\n",
       "        var option = document.createElement('option');\n",
       "        option.selected = fmt === mpl.default_extension;\n",
       "        option.innerHTML = fmt;\n",
       "        fmt_picker.appendChild(option);\n",
       "    }\n",
       "\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.request_resize = function (x_pixels, y_pixels) {\n",
       "    // Request matplotlib to resize the figure. Matplotlib will then trigger a resize in the client,\n",
       "    // which will in turn request a refresh of the image.\n",
       "    this.send_message('resize', { width: x_pixels, height: y_pixels });\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.send_message = function (type, properties) {\n",
       "    properties['type'] = type;\n",
       "    properties['figure_id'] = this.id;\n",
       "    this.ws.send(JSON.stringify(properties));\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.send_draw_message = function () {\n",
       "    if (!this.waiting) {\n",
       "        this.waiting = true;\n",
       "        this.ws.send(JSON.stringify({ type: 'draw', figure_id: this.id }));\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_save = function (fig, _msg) {\n",
       "    var format_dropdown = fig.format_dropdown;\n",
       "    var format = format_dropdown.options[format_dropdown.selectedIndex].value;\n",
       "    fig.ondownload(fig, format);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_resize = function (fig, msg) {\n",
       "    var size = msg['size'];\n",
       "    if (size[0] !== fig.canvas.width || size[1] !== fig.canvas.height) {\n",
       "        fig._resize_canvas(size[0], size[1], msg['forward']);\n",
       "        fig.send_message('refresh', {});\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_rubberband = function (fig, msg) {\n",
       "    var x0 = msg['x0'] / fig.ratio;\n",
       "    var y0 = (fig.canvas.height - msg['y0']) / fig.ratio;\n",
       "    var x1 = msg['x1'] / fig.ratio;\n",
       "    var y1 = (fig.canvas.height - msg['y1']) / fig.ratio;\n",
       "    x0 = Math.floor(x0) + 0.5;\n",
       "    y0 = Math.floor(y0) + 0.5;\n",
       "    x1 = Math.floor(x1) + 0.5;\n",
       "    y1 = Math.floor(y1) + 0.5;\n",
       "    var min_x = Math.min(x0, x1);\n",
       "    var min_y = Math.min(y0, y1);\n",
       "    var width = Math.abs(x1 - x0);\n",
       "    var height = Math.abs(y1 - y0);\n",
       "\n",
       "    fig.rubberband_context.clearRect(\n",
       "        0,\n",
       "        0,\n",
       "        fig.canvas.width / fig.ratio,\n",
       "        fig.canvas.height / fig.ratio\n",
       "    );\n",
       "\n",
       "    fig.rubberband_context.strokeRect(min_x, min_y, width, height);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_figure_label = function (fig, msg) {\n",
       "    // Updates the figure title.\n",
       "    fig.header.textContent = msg['label'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_cursor = function (fig, msg) {\n",
       "    fig.rubberband_canvas.style.cursor = msg['cursor'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_message = function (fig, msg) {\n",
       "    fig.message.textContent = msg['message'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_draw = function (fig, _msg) {\n",
       "    // Request the server to send over a new figure.\n",
       "    fig.send_draw_message();\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_image_mode = function (fig, msg) {\n",
       "    fig.image_mode = msg['mode'];\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_history_buttons = function (fig, msg) {\n",
       "    for (var key in msg) {\n",
       "        if (!(key in fig.buttons)) {\n",
       "            continue;\n",
       "        }\n",
       "        fig.buttons[key].disabled = !msg[key];\n",
       "        fig.buttons[key].setAttribute('aria-disabled', !msg[key]);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_navigate_mode = function (fig, msg) {\n",
       "    if (msg['mode'] === 'PAN') {\n",
       "        fig.buttons['Pan'].classList.add('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    } else if (msg['mode'] === 'ZOOM') {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.add('active');\n",
       "    } else {\n",
       "        fig.buttons['Pan'].classList.remove('active');\n",
       "        fig.buttons['Zoom'].classList.remove('active');\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function () {\n",
       "    // Called whenever the canvas gets updated.\n",
       "    this.send_message('ack', {});\n",
       "};\n",
       "\n",
       "// A function to construct a web socket function for onmessage handling.\n",
       "// Called in the figure constructor.\n",
       "mpl.figure.prototype._make_on_message_function = function (fig) {\n",
       "    return function socket_on_message(evt) {\n",
       "        if (evt.data instanceof Blob) {\n",
       "            var img = evt.data;\n",
       "            if (img.type !== 'image/png') {\n",
       "                /* FIXME: We get \"Resource interpreted as Image but\n",
       "                 * transferred with MIME type text/plain:\" errors on\n",
       "                 * Chrome.  But how to set the MIME type?  It doesn't seem\n",
       "                 * to be part of the websocket stream */\n",
       "                img.type = 'image/png';\n",
       "            }\n",
       "\n",
       "            /* Free the memory for the previous frames */\n",
       "            if (fig.imageObj.src) {\n",
       "                (window.URL || window.webkitURL).revokeObjectURL(\n",
       "                    fig.imageObj.src\n",
       "                );\n",
       "            }\n",
       "\n",
       "            fig.imageObj.src = (window.URL || window.webkitURL).createObjectURL(\n",
       "                img\n",
       "            );\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        } else if (\n",
       "            typeof evt.data === 'string' &&\n",
       "            evt.data.slice(0, 21) === 'data:image/png;base64'\n",
       "        ) {\n",
       "            fig.imageObj.src = evt.data;\n",
       "            fig.updated_canvas_event();\n",
       "            fig.waiting = false;\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        var msg = JSON.parse(evt.data);\n",
       "        var msg_type = msg['type'];\n",
       "\n",
       "        // Call the  \"handle_{type}\" callback, which takes\n",
       "        // the figure and JSON message as its only arguments.\n",
       "        try {\n",
       "            var callback = fig['handle_' + msg_type];\n",
       "        } catch (e) {\n",
       "            console.log(\n",
       "                \"No handler for the '\" + msg_type + \"' message type: \",\n",
       "                msg\n",
       "            );\n",
       "            return;\n",
       "        }\n",
       "\n",
       "        if (callback) {\n",
       "            try {\n",
       "                // console.log(\"Handling '\" + msg_type + \"' message: \", msg);\n",
       "                callback(fig, msg);\n",
       "            } catch (e) {\n",
       "                console.log(\n",
       "                    \"Exception inside the 'handler_\" + msg_type + \"' callback:\",\n",
       "                    e,\n",
       "                    e.stack,\n",
       "                    msg\n",
       "                );\n",
       "            }\n",
       "        }\n",
       "    };\n",
       "};\n",
       "\n",
       "// from https://stackoverflow.com/questions/1114465/getting-mouse-location-in-canvas\n",
       "mpl.findpos = function (e) {\n",
       "    //this section is from http://www.quirksmode.org/js/events_properties.html\n",
       "    var targ;\n",
       "    if (!e) {\n",
       "        e = window.event;\n",
       "    }\n",
       "    if (e.target) {\n",
       "        targ = e.target;\n",
       "    } else if (e.srcElement) {\n",
       "        targ = e.srcElement;\n",
       "    }\n",
       "    if (targ.nodeType === 3) {\n",
       "        // defeat Safari bug\n",
       "        targ = targ.parentNode;\n",
       "    }\n",
       "\n",
       "    // pageX,Y are the mouse positions relative to the document\n",
       "    var boundingRect = targ.getBoundingClientRect();\n",
       "    var x = e.pageX - (boundingRect.left + document.body.scrollLeft);\n",
       "    var y = e.pageY - (boundingRect.top + document.body.scrollTop);\n",
       "\n",
       "    return { x: x, y: y };\n",
       "};\n",
       "\n",
       "/*\n",
       " * return a copy of an object with only non-object keys\n",
       " * we need this to avoid circular references\n",
       " * https://stackoverflow.com/a/24161582/3208463\n",
       " */\n",
       "function simpleKeys(original) {\n",
       "    return Object.keys(original).reduce(function (obj, key) {\n",
       "        if (typeof original[key] !== 'object') {\n",
       "            obj[key] = original[key];\n",
       "        }\n",
       "        return obj;\n",
       "    }, {});\n",
       "}\n",
       "\n",
       "mpl.figure.prototype.mouse_event = function (event, name) {\n",
       "    var canvas_pos = mpl.findpos(event);\n",
       "\n",
       "    if (name === 'button_press') {\n",
       "        this.canvas.focus();\n",
       "        this.canvas_div.focus();\n",
       "    }\n",
       "\n",
       "    var x = canvas_pos.x * this.ratio;\n",
       "    var y = canvas_pos.y * this.ratio;\n",
       "\n",
       "    this.send_message(name, {\n",
       "        x: x,\n",
       "        y: y,\n",
       "        button: event.button,\n",
       "        step: event.step,\n",
       "        guiEvent: simpleKeys(event),\n",
       "    });\n",
       "\n",
       "    /* This prevents the web browser from automatically changing to\n",
       "     * the text insertion cursor when the button is pressed.  We want\n",
       "     * to control all of the cursor setting manually through the\n",
       "     * 'cursor' event from matplotlib */\n",
       "    event.preventDefault();\n",
       "    return false;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function (_event, _name) {\n",
       "    // Handle any extra behaviour associated with a key event\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.key_event = function (event, name) {\n",
       "    // Prevent repeat events\n",
       "    if (name === 'key_press') {\n",
       "        if (event.key === this._key) {\n",
       "            return;\n",
       "        } else {\n",
       "            this._key = event.key;\n",
       "        }\n",
       "    }\n",
       "    if (name === 'key_release') {\n",
       "        this._key = null;\n",
       "    }\n",
       "\n",
       "    var value = '';\n",
       "    if (event.ctrlKey && event.key !== 'Control') {\n",
       "        value += 'ctrl+';\n",
       "    }\n",
       "    else if (event.altKey && event.key !== 'Alt') {\n",
       "        value += 'alt+';\n",
       "    }\n",
       "    else if (event.shiftKey && event.key !== 'Shift') {\n",
       "        value += 'shift+';\n",
       "    }\n",
       "\n",
       "    value += 'k' + event.key;\n",
       "\n",
       "    this._key_event_extra(event, name);\n",
       "\n",
       "    this.send_message(name, { key: value, guiEvent: simpleKeys(event) });\n",
       "    return false;\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onclick = function (name) {\n",
       "    if (name === 'download') {\n",
       "        this.handle_save(this, null);\n",
       "    } else {\n",
       "        this.send_message('toolbar_button', { name: name });\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.toolbar_button_onmouseover = function (tooltip) {\n",
       "    this.message.textContent = tooltip;\n",
       "};\n",
       "\n",
       "///////////////// REMAINING CONTENT GENERATED BY embed_js.py /////////////////\n",
       "// prettier-ignore\n",
       "var _JSXTOOLS_RESIZE_OBSERVER=function(A){var t,i=new WeakMap,n=new WeakMap,a=new WeakMap,r=new WeakMap,o=new Set;function s(e){if(!(this instanceof s))throw new TypeError(\"Constructor requires 'new' operator\");i.set(this,e)}function h(){throw new TypeError(\"Function is not a constructor\")}function c(e,t,i,n){e=0 in arguments?Number(arguments[0]):0,t=1 in arguments?Number(arguments[1]):0,i=2 in arguments?Number(arguments[2]):0,n=3 in arguments?Number(arguments[3]):0,this.right=(this.x=this.left=e)+(this.width=i),this.bottom=(this.y=this.top=t)+(this.height=n),Object.freeze(this)}function d(){t=requestAnimationFrame(d);var s=new WeakMap,p=new Set;o.forEach((function(t){r.get(t).forEach((function(i){var r=t instanceof window.SVGElement,o=a.get(t),d=r?0:parseFloat(o.paddingTop),f=r?0:parseFloat(o.paddingRight),l=r?0:parseFloat(o.paddingBottom),u=r?0:parseFloat(o.paddingLeft),g=r?0:parseFloat(o.borderTopWidth),m=r?0:parseFloat(o.borderRightWidth),w=r?0:parseFloat(o.borderBottomWidth),b=u+f,F=d+l,v=(r?0:parseFloat(o.borderLeftWidth))+m,W=g+w,y=r?0:t.offsetHeight-W-t.clientHeight,E=r?0:t.offsetWidth-v-t.clientWidth,R=b+v,z=F+W,M=r?t.width:parseFloat(o.width)-R-E,O=r?t.height:parseFloat(o.height)-z-y;if(n.has(t)){var k=n.get(t);if(k[0]===M&&k[1]===O)return}n.set(t,[M,O]);var S=Object.create(h.prototype);S.target=t,S.contentRect=new c(u,d,M,O),s.has(i)||(s.set(i,[]),p.add(i)),s.get(i).push(S)}))})),p.forEach((function(e){i.get(e).call(e,s.get(e),e)}))}return s.prototype.observe=function(i){if(i instanceof window.Element){r.has(i)||(r.set(i,new Set),o.add(i),a.set(i,window.getComputedStyle(i)));var n=r.get(i);n.has(this)||n.add(this),cancelAnimationFrame(t),t=requestAnimationFrame(d)}},s.prototype.unobserve=function(i){if(i instanceof window.Element&&r.has(i)){var n=r.get(i);n.has(this)&&(n.delete(this),n.size||(r.delete(i),o.delete(i))),n.size||r.delete(i),o.size||cancelAnimationFrame(t)}},A.DOMRectReadOnly=c,A.ResizeObserver=s,A.ResizeObserverEntry=h,A}; // eslint-disable-line\n",
       "mpl.toolbar_items = [[\"Home\", \"Reset original view\", \"fa fa-home icon-home\", \"home\"], [\"Back\", \"Back to previous view\", \"fa fa-arrow-left icon-arrow-left\", \"back\"], [\"Forward\", \"Forward to next view\", \"fa fa-arrow-right icon-arrow-right\", \"forward\"], [\"\", \"\", \"\", \"\"], [\"Pan\", \"Left button pans, Right button zooms\\nx/y fixes axis, CTRL fixes aspect\", \"fa fa-arrows icon-move\", \"pan\"], [\"Zoom\", \"Zoom to rectangle\\nx/y fixes axis\", \"fa fa-square-o icon-check-empty\", \"zoom\"], [\"\", \"\", \"\", \"\"], [\"Download\", \"Download plot\", \"fa fa-floppy-o icon-save\", \"download\"]];\n",
       "\n",
       "mpl.extensions = [\"eps\", \"jpeg\", \"pgf\", \"pdf\", \"png\", \"ps\", \"raw\", \"svg\", \"tif\"];\n",
       "\n",
       "mpl.default_extension = \"png\";/* global mpl */\n",
       "\n",
       "var comm_websocket_adapter = function (comm) {\n",
       "    // Create a \"websocket\"-like object which calls the given IPython comm\n",
       "    // object with the appropriate methods. Currently this is a non binary\n",
       "    // socket, so there is still some room for performance tuning.\n",
       "    var ws = {};\n",
       "\n",
       "    ws.binaryType = comm.kernel.ws.binaryType;\n",
       "    ws.readyState = comm.kernel.ws.readyState;\n",
       "    function updateReadyState(_event) {\n",
       "        if (comm.kernel.ws) {\n",
       "            ws.readyState = comm.kernel.ws.readyState;\n",
       "        } else {\n",
       "            ws.readyState = 3; // Closed state.\n",
       "        }\n",
       "    }\n",
       "    comm.kernel.ws.addEventListener('open', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('close', updateReadyState);\n",
       "    comm.kernel.ws.addEventListener('error', updateReadyState);\n",
       "\n",
       "    ws.close = function () {\n",
       "        comm.close();\n",
       "    };\n",
       "    ws.send = function (m) {\n",
       "        //console.log('sending', m);\n",
       "        comm.send(m);\n",
       "    };\n",
       "    // Register the callback with on_msg.\n",
       "    comm.on_msg(function (msg) {\n",
       "        //console.log('receiving', msg['content']['data'], msg);\n",
       "        var data = msg['content']['data'];\n",
       "        if (data['blob'] !== undefined) {\n",
       "            data = {\n",
       "                data: new Blob(msg['buffers'], { type: data['blob'] }),\n",
       "            };\n",
       "        }\n",
       "        // Pass the mpl event to the overridden (by mpl) onmessage function.\n",
       "        ws.onmessage(data);\n",
       "    });\n",
       "    return ws;\n",
       "};\n",
       "\n",
       "mpl.mpl_figure_comm = function (comm, msg) {\n",
       "    // This is the function which gets called when the mpl process\n",
       "    // starts-up an IPython Comm through the \"matplotlib\" channel.\n",
       "\n",
       "    var id = msg.content.data.id;\n",
       "    // Get hold of the div created by the display call when the Comm\n",
       "    // socket was opened in Python.\n",
       "    var element = document.getElementById(id);\n",
       "    var ws_proxy = comm_websocket_adapter(comm);\n",
       "\n",
       "    function ondownload(figure, _format) {\n",
       "        window.open(figure.canvas.toDataURL());\n",
       "    }\n",
       "\n",
       "    var fig = new mpl.figure(id, ws_proxy, ondownload, element);\n",
       "\n",
       "    // Call onopen now - mpl needs it, as it is assuming we've passed it a real\n",
       "    // web socket which is closed, not our websocket->open comm proxy.\n",
       "    ws_proxy.onopen();\n",
       "\n",
       "    fig.parent_element = element;\n",
       "    fig.cell_info = mpl.find_output_cell(\"<div id='\" + id + \"'></div>\");\n",
       "    if (!fig.cell_info) {\n",
       "        console.error('Failed to find cell for figure', id, fig);\n",
       "        return;\n",
       "    }\n",
       "    fig.cell_info[0].output_area.element.on(\n",
       "        'cleared',\n",
       "        { fig: fig },\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_close = function (fig, msg) {\n",
       "    var width = fig.canvas.width / fig.ratio;\n",
       "    fig.cell_info[0].output_area.element.off(\n",
       "        'cleared',\n",
       "        fig._remove_fig_handler\n",
       "    );\n",
       "    fig.resizeObserverInstance.unobserve(fig.canvas_div);\n",
       "\n",
       "    // Update the output cell to use the data from the current canvas.\n",
       "    fig.push_to_output();\n",
       "    var dataURL = fig.canvas.toDataURL();\n",
       "    // Re-enable the keyboard manager in IPython - without this line, in FF,\n",
       "    // the notebook keyboard shortcuts fail.\n",
       "    IPython.keyboard_manager.enable();\n",
       "    fig.parent_element.innerHTML =\n",
       "        '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "    fig.close_ws(fig, msg);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.close_ws = function (fig, msg) {\n",
       "    fig.send_message('closing', msg);\n",
       "    // fig.ws.close()\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.push_to_output = function (_remove_interactive) {\n",
       "    // Turn the data on the canvas into data in the output cell.\n",
       "    var width = this.canvas.width / this.ratio;\n",
       "    var dataURL = this.canvas.toDataURL();\n",
       "    this.cell_info[1]['text/html'] =\n",
       "        '<img src=\"' + dataURL + '\" width=\"' + width + '\">';\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.updated_canvas_event = function () {\n",
       "    // Tell IPython that the notebook contents must change.\n",
       "    IPython.notebook.set_dirty(true);\n",
       "    this.send_message('ack', {});\n",
       "    var fig = this;\n",
       "    // Wait a second, then push the new image to the DOM so\n",
       "    // that it is saved nicely (might be nice to debounce this).\n",
       "    setTimeout(function () {\n",
       "        fig.push_to_output();\n",
       "    }, 1000);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._init_toolbar = function () {\n",
       "    var fig = this;\n",
       "\n",
       "    var toolbar = document.createElement('div');\n",
       "    toolbar.classList = 'btn-toolbar';\n",
       "    this.root.appendChild(toolbar);\n",
       "\n",
       "    function on_click_closure(name) {\n",
       "        return function (_event) {\n",
       "            return fig.toolbar_button_onclick(name);\n",
       "        };\n",
       "    }\n",
       "\n",
       "    function on_mouseover_closure(tooltip) {\n",
       "        return function (event) {\n",
       "            if (!event.currentTarget.disabled) {\n",
       "                return fig.toolbar_button_onmouseover(tooltip);\n",
       "            }\n",
       "        };\n",
       "    }\n",
       "\n",
       "    fig.buttons = {};\n",
       "    var buttonGroup = document.createElement('div');\n",
       "    buttonGroup.classList = 'btn-group';\n",
       "    var button;\n",
       "    for (var toolbar_ind in mpl.toolbar_items) {\n",
       "        var name = mpl.toolbar_items[toolbar_ind][0];\n",
       "        var tooltip = mpl.toolbar_items[toolbar_ind][1];\n",
       "        var image = mpl.toolbar_items[toolbar_ind][2];\n",
       "        var method_name = mpl.toolbar_items[toolbar_ind][3];\n",
       "\n",
       "        if (!name) {\n",
       "            /* Instead of a spacer, we start a new button group. */\n",
       "            if (buttonGroup.hasChildNodes()) {\n",
       "                toolbar.appendChild(buttonGroup);\n",
       "            }\n",
       "            buttonGroup = document.createElement('div');\n",
       "            buttonGroup.classList = 'btn-group';\n",
       "            continue;\n",
       "        }\n",
       "\n",
       "        button = fig.buttons[name] = document.createElement('button');\n",
       "        button.classList = 'btn btn-default';\n",
       "        button.href = '#';\n",
       "        button.title = name;\n",
       "        button.innerHTML = '<i class=\"fa ' + image + ' fa-lg\"></i>';\n",
       "        button.addEventListener('click', on_click_closure(method_name));\n",
       "        button.addEventListener('mouseover', on_mouseover_closure(tooltip));\n",
       "        buttonGroup.appendChild(button);\n",
       "    }\n",
       "\n",
       "    if (buttonGroup.hasChildNodes()) {\n",
       "        toolbar.appendChild(buttonGroup);\n",
       "    }\n",
       "\n",
       "    // Add the status bar.\n",
       "    var status_bar = document.createElement('span');\n",
       "    status_bar.classList = 'mpl-message pull-right';\n",
       "    toolbar.appendChild(status_bar);\n",
       "    this.message = status_bar;\n",
       "\n",
       "    // Add the close button to the window.\n",
       "    var buttongrp = document.createElement('div');\n",
       "    buttongrp.classList = 'btn-group inline pull-right';\n",
       "    button = document.createElement('button');\n",
       "    button.classList = 'btn btn-mini btn-primary';\n",
       "    button.href = '#';\n",
       "    button.title = 'Stop Interaction';\n",
       "    button.innerHTML = '<i class=\"fa fa-power-off icon-remove icon-large\"></i>';\n",
       "    button.addEventListener('click', function (_evt) {\n",
       "        fig.handle_close(fig, {});\n",
       "    });\n",
       "    button.addEventListener(\n",
       "        'mouseover',\n",
       "        on_mouseover_closure('Stop Interaction')\n",
       "    );\n",
       "    buttongrp.appendChild(button);\n",
       "    var titlebar = this.root.querySelector('.ui-dialog-titlebar');\n",
       "    titlebar.insertBefore(buttongrp, titlebar.firstChild);\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._remove_fig_handler = function (event) {\n",
       "    var fig = event.data.fig;\n",
       "    if (event.target !== this) {\n",
       "        // Ignore bubbled events from children.\n",
       "        return;\n",
       "    }\n",
       "    fig.close_ws(fig, {});\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._root_extra_style = function (el) {\n",
       "    el.style.boxSizing = 'content-box'; // override notebook setting of border-box.\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._canvas_extra_style = function (el) {\n",
       "    // this is important to make the div 'focusable\n",
       "    el.setAttribute('tabindex', 0);\n",
       "    // reach out to IPython and tell the keyboard manager to turn it's self\n",
       "    // off when our div gets focus\n",
       "\n",
       "    // location in version 3\n",
       "    if (IPython.notebook.keyboard_manager) {\n",
       "        IPython.notebook.keyboard_manager.register_events(el);\n",
       "    } else {\n",
       "        // location in version 2\n",
       "        IPython.keyboard_manager.register_events(el);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype._key_event_extra = function (event, _name) {\n",
       "    // Check for shift+enter\n",
       "    if (event.shiftKey && event.which === 13) {\n",
       "        this.canvas_div.blur();\n",
       "        // select the cell after this one\n",
       "        var index = IPython.notebook.find_cell_index(this.cell_info[0]);\n",
       "        IPython.notebook.select(index + 1);\n",
       "    }\n",
       "};\n",
       "\n",
       "mpl.figure.prototype.handle_save = function (fig, _msg) {\n",
       "    fig.ondownload(fig, null);\n",
       "};\n",
       "\n",
       "mpl.find_output_cell = function (html_output) {\n",
       "    // Return the cell and output element which can be found *uniquely* in the notebook.\n",
       "    // Note - this is a bit hacky, but it is done because the \"notebook_saving.Notebook\"\n",
       "    // IPython event is triggered only after the cells have been serialised, which for\n",
       "    // our purposes (turning an active figure into a static one), is too late.\n",
       "    var cells = IPython.notebook.get_cells();\n",
       "    var ncells = cells.length;\n",
       "    for (var i = 0; i < ncells; i++) {\n",
       "        var cell = cells[i];\n",
       "        if (cell.cell_type === 'code') {\n",
       "            for (var j = 0; j < cell.output_area.outputs.length; j++) {\n",
       "                var data = cell.output_area.outputs[j];\n",
       "                if (data.data) {\n",
       "                    // IPython >= 3 moved mimebundle to data attribute of output\n",
       "                    data = data.data;\n",
       "                }\n",
       "                if (data['text/html'] === html_output) {\n",
       "                    return [cell, data, j];\n",
       "                }\n",
       "            }\n",
       "        }\n",
       "    }\n",
       "};\n",
       "\n",
       "// Register the function which deals with the matplotlib target/channel.\n",
       "// The kernel may be null if the page has been refreshed.\n",
       "if (IPython.notebook.kernel !== null) {\n",
       "    IPython.notebook.kernel.comm_manager.register_target(\n",
       "        'matplotlib',\n",
       "        mpl.mpl_figure_comm\n",
       "    );\n",
       "}\n"
      ],
      "text/plain": [
       "<IPython.core.display.Javascript object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/html": [
       "<img src=\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABQAAAAPACAYAAABq3NR5AAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAAFAKADAAQAAAABAAADwAAAAADIn4SfAABAAElEQVR4AezdTawc16En9qJE2fqwJPJSsvzGkm2JMQYIZhYjkgKyyUYikO0ApITMZBmSu2QnPiIIkE3gEYGsgkFCMUgGQTKARC2CBFlkSA4wQT4GI1IBMi8vk+ehbFnysy2JH6I+bVG6uf+WzlWxu7q7um933+7q3wGuu7u66tQ5v+rXev3nOXX2bG6VSiFAgAABAgQIECBAgAABAgQIECBAoJMC93SyVzpFgAABAgQIECBAgAABAgQIECBAgEBPQADog0CAAAECBAgQIECAAAECBAgQIECgwwICwA5fXF0jQIAAAQIECBAgQIAAAQIECBAgIAD0GSBAgAABAgQIECBAgAABAgQIECDQYQEBYIcvrq4RIECAAAECBAgQIECAAAECBAgQEAD6DBAgQIAAAQIECBAgQIAAAQIECBDosIAAsMMXV9cIECBAgAABAgQIECBAgAABAgQICAB9BggQIECAAAECBAgQIECAAAECBAh0WEAA2OGLq2sECBAgQIAAAQIECBAgQIAAAQIEBIA+AwQIECBAgAABAgQIECBAgAABAgQ6LCAA7PDF1TUCBAgQIECAAAECBAgQIECAAAECAkCfAQIECBAgQIAAAQIECBAgQIAAAQIdFhAAdvji6hoBAgQIECBAgAABAgQIECBAgAABAaDPAAECBAgQIECAAAECBAgQIECAAIEOCwgAO3xxdY0AAQIECBAgQIAAAQIECBAgQICAANBngAABAgQIECBAgAABAgQIECBAgECHBQSAHb64ukaAAAECBAgQIECAAAECBAgQIEBAAOgzQIAAAQIECBAgQIAAAQIECBAgQKDDAgLADl9cXSNAgAABAgQIECBAgAABAgQIECAgAPQZIECAAAECBAgQIECAAAECBAgQINBhAQFghy+urhEgQIAAAQIECBAgQIAAAQIECBAQAPoMECBAgAABAgQIECBAgAABAgQIEOiwgACwwxdX1wgQIECAAAECBAgQIECAAAECBAgIAH0GCBAgQIAAAQIECBAgQIAAAQIECHRYQADY4YurawQIECBAgAABAgQIECBAgAABAgQEgD4DBAgQIECAAAECBAgQIECAAAECBDosIADs8MXVNQIECBAgQIAAAQIECBAgQIAAAQICQJ8BAgQIECBAgAABAgQIECBAgAABAh0WEAB2+OLqGgECBAgQIECAAAECBAgQIECAAAEBoM8AAQIECBAgQIAAAQIECBAgQIAAgQ4LCAA7fHF1jQABAgQIECBAgAABAgQIECBAgIAA0GeAAAECBAgQIECAAAECBAgQIECAQIcFBIAdvri6RoAAAQIECBAgQIAAAQIECBAgQEAA6DNAgAABAgQIECBAgAABAgQIECBAoMMCAsAOX1xdI0CAAAECBAgQIECAAAECBAgQICAA9BkgQIAAAQIECBAgQIAAAQIECBAg0GEBAWCHL66uESBAgAABAgQIECBAgAABAgQIEBAA+gwQIECAAAECBAgQIECAAAECBAgQ6LCAALDDF1fXCBAgQIAAAQIECBAgQIAAAQIECAgAfQYIECBAgAABAgQIECBAgAABAgQIdFhAANjhi6trBAgQIECAAAECBAgQIECAAAECBASAPgMECBAgQIAAAQIECBAgQIAAAQIEOiwgAOzwxdU1AgQIECBAgAABAgQIECBAgAABAgJAnwECBAgQIECAAAECBAgQIECAAAECHRYQAHb44uoaAQIECBAgQIAAAQIECBAgQIAAAQGgzwABAgQIECBAgAABAgQIECBAgACBDgsIADt8cXWNAAECBAgQIECAAAECBAgQIECAgADQZ4AAAQIECBAgQIAAAQIECBAgQIBAhwUEgB2+uLpGgAABAgQIECBAgAABAgQIECBAQADoM0CAAAECBAgQIECAAAECBAgQIECgwwICwA5fXF0jQIAAAQIECBAgQIAAAQIECBAgIAD0GSBAgAABAgQIECBAgAABAgQIECDQYQEBYIcvrq4RIECAAAECBAgQIECAAAECBAgQEAD6DBAgQIAAAQIECBAgQIAAAQIECBDosIAAsMMXV9cIECBAgAABAgQIECBAgAABAgQICAB9BggQIECAAAECBAgQIECAAAECBAh0WEAA2OGLq2sECBAgQIAAAQIECBAgQIAAAQIEBIA+AwQIECBAgAABAgQIECBAgAABAgQ6LCAA7PDF1TUCBAgQIECAAAECBAgQIECAAAECAkCfAQIECBAgQIAAAQIECBAgQIAAAQIdFhAAdvji6hoBAgQIECBAgAABAgQIECBAgAABAaDPAAECBAgQIECAAAECBAgQIECAAIEOCwgAO3xxdY0AAQIECBAgQIAAAQIECBAgQICAANBngAABAgQIECBAgAABAgQIECBAgECHBQSAHb64ukaAAAECBAgQIECAAAECBAgQIEBAAOgzQIAAAQIECBAgQIAAAQIECBAgQKDDAgLADl9cXSNAgAABAgQIECBAgAABAgQIECAgAPQZIECAAAECBAgQIECAAAECBAgQINBhAQFghy+urhEgQIAAAQIECBAgQIAAAQIECBAQAPoMECBAgAABAgQIECBAgAABAgQIEOiwgACwwxdX1wgQIECAAAECBAgQIECAAAECBAgIAH0GCBAgQIAAAQIECBAgQIAAAQIECHRYQADY4YurawQIECBAgAABAgQIECBAgAABAgQEgD4DBAgQIECAAAECBAgQIECAAAECBDosIADs8MXVNQIECBAgQIAAAQIECBAgQIAAAQICQJ8BAgQIECBAgAABAgQIECBAgAABAh0WEAB2+OLqGgECBAgQIECAAAECBAgQIECAAAEBoM8AAQIECBAgQIAAAQIECBAgQIAAgQ4LCAA7fHF1jQABAgQIECBAgAABAgQIECBAgIAA0GeAAAECBAgQIECAAAECBAgQIECAQIcFBIAdvri6RoAAAQIECBAgQIAAAQIECBAgQEAA6DNAgAABAgQIECBAgAABAgQIECBAoMMCAsAOX1xdI0CAAAECBAgQIECAAAECBAgQICAA9BkgQIAAAQIECBAgQIAAAQIECBAg0GEBAWCHL66uESBAgAABAgQIECBAgAABAgQIEBAA+gwQIECAAAECBAgQIECAAAECBAgQ6LCAALDDF1fXCBAgQIAAAQIECBAgQIAAAQIECAgAfQYIECBAgAABAgQIECBAgAABAgQIdFhAANjhi6trBAgQIECAAAECBAgQIECAAAECBASAPgMECBAgQIAAAQIECBAgQIAAAQIEOiwgAOzwxdU1AgQIECBAgAABAgQIECBAgAABAgJAnwECBAgQIECAAAECBAgQIECAAAECHRYQAHb44uoaAQIECBAgQIAAAQIECBAgQIAAAQGgzwABAgQIECBAgAABAgQIECBAgACBDgsIADt8cXWNAAECBAgQIECAAAECBAgQIECAgADQZ4AAAQIECBAgQIAAAQIECBAgQIBAhwUEgB2+uLpGgAABAgQIECBAgAABAgQIECBAQADoM0CAAAECBAgQIECAAAECBAgQIECgwwICwA5fXF0jQIAAAQIECBAgQIAAAQIECBAgIAD0GSBAgAABAgQIECBAgAABAgQIECDQYQEBYIcvrq4RIECAAAECBAgQIECAAAECBAgQEAB24DPwxhtvVPv375+oJ6dPn66OHj1aHTp0qPeX55cuXZqoDjsTIECAAAECBAgQIECAAAECBAgsv8Ceza2y/M3Uwn6BW7du9QK7c+fObQd3N2/erPbt29e/612v33rrrerEiRPVmTNnqmPHjm2/V7ZvbGxUFy9e3N7uCQECBAgQIECAAAECBAgQIECAwGoLCABX7PolqMuovWeeeaZ64YUXqoMHD1YZzZcyLgBMaPj8889Xly9fHhoUpr5nn322unDhworJaC4BAgQIECBAgAABAgQIECBAgECTgACwSWWFtr399tu9EDBNHhcAnj17tnrzzTdHhnuZBpzpwAaGrtCHQFMJECBAgAABAgQIECBAgAABAiME3ANwBE7X3srU3kzxHVUOHz7cezsjDRUCBAgQIECAAAECBAgQIECAAIHVFxAArv41bN2DjBZ8/fXXq0wFHlayT8q4ewkOO952AgQIECBAgAABAgQIECBAgACB5RIQAC7X9Zhra3Jvv4R/uYfgsBF+WVQk++UegwoBAgQIECBAgAABAgQIECBAgMDqCwgAV/8atu7BqVOnevtmlF9CwLJ4SKkg9//LCMHz58+XTR4JECBAgAABAgQIECBAgAABAgRWXEAA2OICZlGM48ePt9hz9C4ZdZcQLivt7t+/v/eXIC6Lc4yalju61vbvZtXgkydPbh+Q86YtCf5effXVXtuyQnBGACoECBAgQIAAAQIECBAgQIAAAQLdEBAAjriOb7zxxnZAttOALgFiwr6ULMaRFXvz98orr1SZdvv000/3grgRzZnJWzlX/krJaMAEnBkNePXqVeFfgfFIgAABAgQIECBAgAABAgQIEOiIwN6O9GPH3cgouIRhCfrefPPNKuHfLErqe/7553v33EvwVh+Bl/ozKu/atWu9cDBBXALBl19+eRanHlrHiy++2Ash0+cSbOYxIeSFCxd6bRp6sDcIECBAgAABAgQIECBAgAABAgRWSmDP5lZZqRbPqbF79uzprXy7sbHRC8AyYi+hWJn6m6AuI/cmLZnym+m1Cf7qI+/668m5Mi04ZZKReAktM403JSMKx63em9AvbcqIv7QpbcvzEgSmnkWEkF988UX1L//lv8zpqscff7zau1cW3cPwPwQIECBAgAABAgQIECBAYIYCd+7cqT744INejX/7b//t6v77759h7apaGYEEgEqzwNZouISjvb+tALB5pxFbt4K87eO3RvmN2PObt7YCud7+Wyvwjt237JB6Sxu3AsCyufFxK8Ds7ZvHeslx5dylrv596vvP4vm/+Bf/Yrvd5Zwev/msceDgM+Az4DPgM+Az4DPgM+Az4DPgM+Az4DMwj89Afosr6yngHoBb/xc1r1JW2d0K9Kr8jSv1VXozUm+WpYxmzPTijGasl4wazOjEjHAsIwhL2+v7eU6AAAECBAgQIECAAAECBAgQILB6AuZdzumaJXArIV7bVXXr+yWQ6w/qdtLU119/vTfN98yZM0Oryfky/ThTirNi8TxLpv2WsvUvENWf/dmflZceCRAgQIAAAQIECBAgQIAAgRkJ/O53v6uee+65Xm313+Izql41KyIgAJzThUrgVkqb0X/1fXNfv1ktQlLqLaP7ygi/sr3/MW0t9wZMiDlu//7j276u3/Mv4d+TTz7Z9lD7ESBAgAABAgQIECBAgAABAlMI1H+LT3G4Q1ZYwBTgOV28BG6llEU6yutRj/XAbZaj8LK4SX2hj1FtKO2tt2XU/t4jQIAAAQIECBAgQIAAAQIECBBYXgEB4JyuTT28m3QEYGnSlStXytMdPx49erRXR5mWPKrChJcZBagQIECAAAECBAgQIECAAAECBAisvoApwHO6hpnGW0pG301Ttlb4HXtY21F9x44dq/J3/Pjx6le/+tXQqb2Zepy210cwjm2EHQgQIECAAAECBAgQIECAAAECBJZWwAjAOVyatqHcuFO3qee1117brqZ+38HtjbUnFy5c6C0s8vTTT1evvvrqXVOCE/plFeJf/OIXwr+amacECBAgQIAAAQIECBAgQIAAgVUXMAJwDlfwxo0bU9daHy04rJ79+/ffVX+5V9/p06er/JVy8+bN8nT7MSFgpicn6HvllVe2t2cF4pdeeqnK6sOzKO+9997IarIKkUKAAAECBAgQIECAAAECBAgQIDB/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CBAgQIAAAQIECBAgQGBtBQSAa3vpdZxABwT++npVJQTsL0YA9ot4TYAAAQIECBAgQIAAAQJrLCAAXOOLr+sEVl7gnT80d0EA2OxiKwECBAgQIECAAAECBAispYAAcC0vu04T6IjAr4cFgFYA7sgV1g0CBAgQIECAAAECBAgQmIGAAHAGiKogQGCXBJoWAElTjADcpQvitAQIECBAgAABAgQIECCwjAICwGW8KtpEgEA7gaYpwPt+UFWPPtTueHsRIECAAAECBAgQIECAAIE1EBAArsFF1kUCnRVoCgCtANzZy61jBAgQIECAAAECBAgQIDCdgABwOjdHESCw2wKbm1X1mw8GW2H676CJLQQIECBAgAABAgQIECCw1gICwLW+/DpPYIUFPrhVVZ//cbADRgAOmthCgAABAgQIECBAgAABAmstIABc68uv8wRWWGDYCsA/eWKFO6XpBAgQIECAAAECBAgQIEBg9gICwNmbqpEAgUUIvPN+81l+JgBshrGVAAECBAgQIECAAAECBNZVQAC4rldevwmsusBv/tDcA1OAm11sJUCAAAECBAgQIECAAIG1FRAAru2l13ECKy7QNAX4ge9X1eP7Vrxjmk+AAAECBAgQIECAAAECBGYrIACcrefS1/bGG29Ub7311tB25r1Lly4Nfd8bBJZG4DcNU4Az+m/PnqVpooYQIECAAAECBAgQIECAAIFlENi7DI3Qhp0JJNQ7ceJEdfPmzbEVnT59unr77berffv2VYcPH66eeeaZ3jHZduXKlerWrVvV1atXx9ZjBwK7LtA0AvAnWwGgQoAAAQIECBAgQIAAAQIECNwlIAC8i2N1XiSoy0i9c+fObY/Yy7YEe21KOb6+b8LAy5cvV88++2x9s+cElk/go0+rKn/9xQIg/SJeEyBAgAABAgQIECBAgACByhTgFfsQZIrunq0pjocOHaouXrxYHT16dOIevPDCC9tBYUK/vE6QeO3aNeHfxJoO2BWBd4YsAPITKwDvyvVwUgIECBAgQIAAAQIECBBYagEjAJf68gw2LqPzNjc3t9/I1N1M652kXLhwYTsAnOQ4+xJYGoGm6b9pnBWAl+YSaQgBAgQIECBAgAABAgQILI+AEYDLcy20hACBtgLvftC8pynAzS62EiBAgAABAgQIECBAgMBaCwgA1/ry6zyBFRX48KPmhj+x0bzd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\" width=\"640\">"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10\n",
      "10\n",
      "10\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.rcParams[\"text.usetex\"] = True\n",
    "plt.rcParams[\"font.family\"] = \"serif\"\n",
    "plt.rcParams[\"font.serif\"] = \"Computer Modern Roman\"\n",
    "plt.rcParams[\"font.size\"] = 16\n",
    "plt.rcParams[\"legend.fontsize\"] = 16\n",
    "# plt.rcParams[\"ytick.labelsize\"] = 16\n",
    "plt.rcParams[\"axes.labelsize\"] = 18\n",
    "plt.rcParams[\"lines.linewidth\"] = 2\n",
    "color_list = [\"#ff1f5b\", \"#00cd6c\", \"#009ade\"]\n",
    "xlabel = \"\\\\#gradient calls\"\n",
    "ylabel = \"$\\\\| g(x_t, \\\\xi_t)\\\\|$\"\n",
    "\n",
    "\n",
    "\n",
    "%matplotlib notebook\n",
    "\n",
    "overlapping = 1\n",
    "\n",
    "def smooth(scalars, weight):  # Weight between 0 and 1\n",
    "    last = scalars[0]  # First value in the plot (first timestep)\n",
    "    smoothed = list()\n",
    "    for point in scalars:\n",
    "        smoothed_val = last * weight + (1 - weight) * point  # Calculate smoothed value\n",
    "        smoothed.append(smoothed_val)                        # Save it\n",
    "        last = smoothed_val                                  # Anchor the last smoothed value\n",
    "\n",
    "    return smoothed\n",
    "\n",
    "\n",
    "for lr_id in range(len(lrs)):\n",
    "    fig = plt.figure()\n",
    "    for method, color in zip(('SGD', 'AdaGrad', 'NSGD-M'), color_list):\n",
    "        lr = lrs[lr_id]\n",
    "        print(lr)\n",
    "        data = smooth(results[method][lr]['grad'], 0)\n",
    "        data = data[:100]\n",
    "        plt.plot(data, label=method, alpha=overlapping, color=color)\n",
    "    \n",
    "    plt.yscale('log')\n",
    "    plt.xlabel(xlabel)\n",
    "    plt.ylabel(ylabel)\n",
    "\n",
    "    plt.legend()\n",
    "\n",
    "plt.savefig('mnist.pdf', bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
