{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Generative NN based on objective instead of samples\n",
    "\n",
    "Let $f (x, z) = y  $ be a NN mapping (optional) coordinates $x$ and a noise vector $z$ to the output $y$.\n",
    "Let $l(y) \\in \\R_+$ be an objective. \n",
    "\n",
    "We want to discover an $f$ such that it generates samples $y$ with $l(y)=0$ or at least minimizes $l(y)$.\n",
    "In addition, we want the samples to be diverse: different $z$ should produce different $y(x; z)$."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Experiment 4: harmonic oscillator\n",
    "We want to to parametrize $\\sin$ signals with different phase shifts.\n",
    "\n",
    "- **Dimensions**: $ n_x = 1, n_y = 1, n_z = 1 $\n",
    "- **Constraints**:\n",
    "  - each generated function satisfies the harmonic ODE $y_{xx}(x) + y(x) = 0 \\ \\forall y\\in[0,2\\pi] \\quad \\rightarrow \\quad  l(y) = \\int_0^{2\\pi} (y_{xx}(x) + y(x))^2 dx$\n",
    "  - each generated function has fixed norm $y^2 (x) + y^2_x (x) = 1 \\ \\forall y\\in[0,2\\pi] \\quad \\rightarrow \\quad l(y) = \\int_0^{2\\pi} ( \\sqrt{y^2 (x) + y^2_x (x)} - 1 )^2 dx$\n",
    "- **Diversity**: repel closest neighour $\\delta = $ TODO"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm, trange"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torch import nn\n",
    "from torch.nn.functional import relu\n",
    "from torch import sin, tanh\n",
    "\n",
    "\n",
    "class Net(nn.Module):\n",
    "    def __init__(self, ks):\n",
    "        super(Net, self).__init__()\n",
    "        ## Feature-sizes\n",
    "        self.ks = ks\n",
    "        ## Fully-connected layers\n",
    "        self.fcs = nn.ModuleList([nn.Linear(in_features, out_features)\n",
    "            for in_features, out_features in zip(self.ks[:-1],self.ks[1:])])\n",
    "        ## Depth\n",
    "        self.D = len(self.fcs)\n",
    "    def forward(self, x, z):\n",
    "        x_ = self.fcs[0](torch.hstack([x, z]))\n",
    "        for i in range(2,self.D+1):\n",
    "            x_ = self.fcs[i-1](tanh(x_))\n",
    "        return x_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "nx = 1\n",
    "ny = 1\n",
    "nz = 1\n",
    "model = Net(ks=[nx+nz, 40, 40, ny])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "ename": "ModuleNotFoundError",
     "evalue": "No module named 'torch.func'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mModuleNotFoundError\u001b[0m                       Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[5], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[38;5;28;01mfrom\u001b[39;00m \u001b[38;5;21;01mtorch\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mfunc\u001b[39;00m \u001b[38;5;28;01mimport\u001b[39;00m vmap, grad, jacrev, jacfwd, functional_call\n\u001b[1;32m      2\u001b[0m params \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mdict\u001b[39m(model\u001b[38;5;241m.\u001b[39mnamed_parameters())\n\u001b[1;32m      5\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mf\u001b[39m(params, x, z):\n",
      "\u001b[0;31mModuleNotFoundError\u001b[0m: No module named 'torch.func'"
     ]
    }
   ],
   "source": [
    "from torch.func import vmap, grad, jacrev, jacfwd, functional_call\n",
    "params = dict(model.named_parameters())\n",
    "\n",
    "\n",
    "def f(params, x, z):\n",
    "    \"\"\"\n",
    "    Stateless call to the model.\n",
    "    That this works for\n",
    "    * single inputs:\n",
    "    x: [nx]\n",
    "    z: [nz]\n",
    "    returns: [ny]\n",
    "    -- and -- \n",
    "    * batch inputs:\n",
    "    x: [B, nx]\n",
    "    z: [B, nz]\n",
    "    returns: [B, ny]\n",
    "    \"\"\"\n",
    "    return functional_call(model, params, (x, z))\n",
    "\n",
    "\n",
    "### JACOBIAN ###\n",
    "## Jacobian wrt x : df/dx\n",
    "f_x = jacrev(f, argnums=1) ## not for batch!\n",
    "vf_x = vmap(f_x, in_dims=(None, 0, 0), out_dims=(0)) ## output [B, ny, nx]\n",
    "\n",
    "### HESSIAN ###\n",
    "f_xx = jacfwd(f_x, argnums=1) ## not for batch!\n",
    "vf_xx = vmap(f_xx, in_dims=(None, 0, 0), out_dims=(0)) ## output [B, ny, nx, nx]\n",
    "\n",
    "# ## Test ##\n",
    "# B = 5\n",
    "# xs = torch.rand([B, nx])\n",
    "# zs = torch.rand([B, nz])\n",
    "\n",
    "# x, z = xs[0], zs[0]\n",
    "# y = f(params, x, z)\n",
    "# print(\"no batch\", x.shape, z.shape, y.shape)\n",
    "\n",
    "# ys = f(params, xs, zs)\n",
    "# print(\"batch\", xs.shape, zs.shape, ys.shape)\n",
    "# ##"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def tensor_product_xz(x, z):\n",
    "    \"\"\"\n",
    "    Generate correct inputs for bx different xs and bz different zs.\n",
    "    For each z we want to evaluate it at all xs and vice versa, so we need a tensor product between the rows of the two vectors.\n",
    "    x: [bx, nx]\n",
    "    z: [bz, nz]\n",
    "    returns: [bx*bz, nx+nz]\n",
    "    \"\"\"\n",
    "    z_tp = z.repeat_interleave(len(x), 0)\n",
    "    x_tp = x.repeat(len(z), 1)\n",
    "    # xz = torch.hstack([x_rep, z_rep])\n",
    "    return x_tp, z_tp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def adaptive_penalty_update(mu_dict: dict, lambda_dict: dict, nu_dict: dict, sub_loss_unweighted_dict: dict) -> dict:\n",
    "    gamma = 0.01\n",
    "    alpha = 0.9\n",
    "    epsilon = 1.e-08\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for key in sub_loss_unweighted_dict.keys():\n",
    "            nu_dict[key] = nu_dict[key] * alpha + (1-alpha) * sub_loss_unweighted_dict[key]\n",
    "            mu_dict[key] = gamma / (torch.sqrt(nu_dict[key]) + epsilon)\n",
    "            lambda_dict[key] = lambda_dict[key] + mu_dict[key] * torch.sqrt(sub_loss_unweighted_dict[key])\n",
    "\n",
    "    return mu_dict, lambda_dict, nu_dict"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "metadata": {},
   "outputs": [],
   "source": [
    "## NOTE: currently unused\n",
    "def compute_diversity(y, use_sum=False, use_similarity=True):\n",
    "    if use_similarity:\n",
    "        N_pairs = 2**16\n",
    "        inds_a = torch.randint(len(y), (N_pairs, ))\n",
    "        inds_b = torch.randint(len(y), (N_pairs, ))\n",
    "        mask = inds_a != inds_b\n",
    "        inds_a = inds_a[mask]\n",
    "        inds_b = inds_b[mask]\n",
    "        y_a = y[inds_a]\n",
    "        y_b = y[inds_b]\n",
    "        if use_geodesic:=False:\n",
    "            ## Geodesic distance\n",
    "            y_an = y_a / y_a.norm(dim=-1).unsqueeze(1)\n",
    "            y_bn = y_b / y_b.norm(dim=-1).unsqueeze(1)\n",
    "            inner_products = torch.einsum('bi,bi->b', y_an, y_bn)\n",
    "            # print(inner_products.min(), inner_products.max())\n",
    "            eps = 1e-6\n",
    "            inner_products_filtered = inner_products[torch.logical_and(-1+eps<inner_products, inner_products<1-eps)]\n",
    "            # inner_products_filtered = inner_products\n",
    "            # print(inner_products_filtered.min(), inner_products_filtered.max())\n",
    "            distances_ab = torch.arccos(inner_products_filtered)\n",
    "        else:\n",
    "            distances_ab = torch.norm(y_a - y_b, dim=-1, p=2)\n",
    "        similarities_ab = torch.exp(-10*distances_ab)\n",
    "        diversity = 1/similarities_ab.mean()        \n",
    "    else:\n",
    "        distances = torch.norm(y[:, None] - y, dim=2, p=2)\n",
    "        if use_sum:\n",
    "            return ((distances.triu(1)+1e-8).sqrt().mean()).square() ## SUM\n",
    "        # Create a mask to exclude diagonal elements\n",
    "        distances = distances.masked_fill(torch.eye(distances.size(0), dtype=torch.bool), float('inf'))\n",
    "        # Find the minimum distance for each point\n",
    "        closest_dists = (distances.min(dim=1).values + 1e-8).sqrt()\n",
    "        diversity = (closest_dists.sqrt()).mean().square()\n",
    "\n",
    "\n",
    "    return diversity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "harmonic: 1.29e-03, amplitude: 1.65e-02, diversity: 0.00: 100%|██████████| 1000/1000 [00:23<00:00, 41.73it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "## Losses\n",
    "loss_keys = ['harmonic', 'amplitude', 'diversity']\n",
    "\n",
    "## Logging\n",
    "loss_over_iters = {key: {} for key in loss_keys}\n",
    "\n",
    "\n",
    "## Diversity budget\n",
    "# div_min = 0.3\n",
    "# diversity_is_objective = True\n",
    "\n",
    "if reinit:=1:\n",
    "    ## Optimizer\n",
    "    opt = torch.optim.Adam(model.parameters(), lr=3e-3)\n",
    "\n",
    "    ## ALM\n",
    "    mu_dict = {key: torch.tensor(1.) for key in loss_keys}\n",
    "    nu_dict = {key: torch.tensor(0.) for key in loss_keys}\n",
    "    lambda_dict = {key: torch.tensor(1.) for key in loss_keys}\n",
    "\n",
    "\n",
    "\n",
    "## Train\n",
    "for i in (pbar := trange(1000)):\n",
    "    opt.zero_grad()\n",
    "\n",
    "    x = 2*torch.pi*torch.rand(1000, nx) ## sample from [0, 2pi] which is our wavelength\n",
    "    z = 0.1*torch.randn(5, nz) ## number of latent codes, bz\n",
    "    # z = torch.zeros(1, nz) ## number of codes, bz\n",
    "    \n",
    "    ## HARMONIC ##\n",
    "    x_tp, z_tp = tensor_product_xz(x, z)\n",
    "    y = f(params, x_tp, z_tp).squeeze()\n",
    "    y_xx = vf_xx(params, x_tp, z_tp).squeeze()\n",
    "    loss_harmonic = (y_xx + y).square().mean()\n",
    "    \n",
    "    ## AMPLITUDE ##\n",
    "    y_x = vf_xx(params, x_tp, z_tp).squeeze()\n",
    "    loss_amplitude = 0.1*((y.square() + y_x.square()).sqrt() - 1).square().mean()\n",
    "    \n",
    "    ## DIVERSITY ##\n",
    "    diversity = torch.tensor(0.0) ## NOTE: diversity is disabled\n",
    "    # diversity = compute_diversity(y) * 1e-3\n",
    "    # if torch.isnan(diversity):\n",
    "    #     print(\"nan :(\")\n",
    "    #     break\n",
    "    # if diversity_is_objective:\n",
    "    #     loss_diversity = -diversity\n",
    "    # else:\n",
    "    #     loss_diversity = torch.max(torch.tensor(0.0), div_min - diversity).square()\n",
    "\n",
    "\n",
    "    loss_over_iters['harmonic'][i] = loss_harmonic.item()\n",
    "    loss_over_iters['amplitude'][i] = loss_amplitude.item()\n",
    "    loss_over_iters['diversity'][i] = diversity.item()\n",
    "\n",
    "    \n",
    "    # loss  = lambda_dict['harmonic']*loss_harmonic + .5*mu_dict['harmonic']*loss_harmonic.square()\n",
    "    # loss += lambda_dict['amplitude']*loss_amplitude + .5*mu_dict['amplitude']*loss_amplitude.square()\n",
    "    loss  = loss_harmonic #+ .5*mu_dict['harmonic']*loss_harmonic.square()\n",
    "    loss += loss_amplitude #+ .5*mu_dict['amplitude']*loss_amplitude.square()\n",
    "    # if diversity_is_objective:\n",
    "    #     loss += -diversity\n",
    "    # else:\n",
    "    #     loss += lambda_dict['diversity']*loss_diversity + .5*mu_dict['diversity']*loss_diversity.square()\n",
    "\n",
    "    loss.backward()\n",
    "    opt.step()\n",
    "\n",
    "\n",
    "    ## ALM\n",
    "    sub_loss_unweighted_dict = {\n",
    "        'harmonic': loss_harmonic.detach(), \n",
    "        'amplitude': loss_amplitude.detach(),\n",
    "        'diversity': diversity.detach(),\n",
    "        }\n",
    "    mu_dict, lambda_dict, nu_dict = adaptive_penalty_update(mu_dict, lambda_dict, nu_dict, sub_loss_unweighted_dict)\n",
    "\n",
    "\n",
    "    pbar.set_description(\n",
    "        f\"harmonic: {loss_harmonic.item():.2e}, amplitude: {loss_amplitude.item():.2e}, diversity: {diversity.item():.2f}\")\n",
    "\n",
    "\n",
    "for loss_key in loss_keys:\n",
    "    plt.plot(list(loss_over_iters[loss_key].keys()), list(loss_over_iters[loss_key].values()), label=loss_key)\n",
    "plt.semilogy()\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plot solution manifold"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([100, 1]) torch.Size([1, 1])\n",
      "torch.Size([100, 1]) torch.Size([100, 1])\n",
      "torch.Size([1, 100]) torch.Size([1, 100])\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = torch.linspace(0, 2*torch.pi, 100).unsqueeze(1) ## sample from [0, 2pi] which is our wavelength\n",
    "# z = torch.zeros(1, nz) ## number of codes, bz\n",
    "z = 0.1*torch.randn(1, nz) ## number of codes, bz\n",
    "\n",
    "x_tp, z_tp = tensor_product_xz(x, z)\n",
    "y = f(params, x_tp, z_tp).squeeze().detach().reshape(len(z), len(x))\n",
    "y_xx = vf_xx(params, x_tp, z_tp).squeeze().detach().reshape(len(z), len(x))\n",
    "\n",
    "# print(x.shape, z.shape)\n",
    "# print(x_tp.shape, z_tp.shape)\n",
    "# print(y.shape, y_xx.shape)\n",
    "\n",
    "plt.plot(x, y.T, )\n",
    "plt.plot(x, y_xx.T, )\n",
    "plt.sa()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "audi",
   "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.16"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
