{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Standard imports\n",
    "import matplotlib.pylab as plt\n",
    "import torch \n",
    "import os\n",
    "os.environ['KMP_DUPLICATE_LIB_OK']='True'\n",
    "import numpy as np\n",
    "from pathlib import Path\n",
    "# If you are running this notebook interactively\n",
    "wdir = Path(os.path.abspath('')).parent.parent\n",
    "os.chdir(wdir)\n",
    "# gpytorch imports\n",
    "from gpytorch.mlls import VariationalELBO\n",
    "from gpytorch.priors import NormalPrior\n",
    "\n",
    "%matplotlib inline\n",
    "\n",
    "# Setting manual seed for reproducibility\n",
    "torch.manual_seed(73)\n",
    "np.random.seed(73)\n",
    "device='cuda:0'\n",
    "# this is for running the notebook in our testing framework\n",
    "smoke_test = ('CI' in os.environ)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import urllib.request\n",
    "import tarfile\n",
    "\n",
    "with tarfile.open('3PhData.tar.gz', 'r') as f:\n",
    "    f.extract('DataTrn.txt')\n",
    "    f.extract('DataTrnLbls.txt')\n",
    "\n",
    "Y = torch.Tensor(np.loadtxt(fname='DataTrn.txt')).to(device)\n",
    "labels = torch.Tensor(np.loadtxt(fname='DataTrnLbls.txt'))\n",
    "labels = (labels @ np.diag([1, 2, 3])).sum(axis=1)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "Y=Y.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "from gpytorch.models.gplvm.latent_variable import *\n",
    "from gpytorch.models.gplvm.bayesian_gplvm import BayesianGPLVM\n",
    "from matplotlib import pyplot as plt\n",
    "from tqdm.notebook import trange\n",
    "from gpytorch.means import ZeroMean\n",
    "from gpytorch.mlls import VariationalELBO\n",
    "from gpytorch.priors import NormalPrior\n",
    "from gpytorch.likelihoods import GaussianLikelihood,GaussianLikelihoodWithMissingObs\n",
    "from gpytorch.variational import VariationalStrategy\n",
    "from gpytorch.variational import CholeskyVariationalDistribution\n",
    "from gpytorch.kernels import ScaleKernel, RBFKernel\n",
    "from gpytorch.distributions import MultivariateNormal\n",
    "\n",
    "\n",
    "def _init_pca(Y, latent_dim):\n",
    "    U, S, V = torch.pca_lowrank(Y, q = latent_dim)\n",
    "    return torch.nn.Parameter(torch.matmul(Y, V[:,:latent_dim]))\n",
    "\n",
    "\n",
    "class bGPLVM(BayesianGPLVM):\n",
    "    def __init__(self, n, data_dim, latent_dim, n_inducing, pca=False):\n",
    "        self.n = n\n",
    "        self.batch_shape = torch.Size([data_dim])\n",
    "        \n",
    "     \n",
    "        self.inducing_inputs = torch.randn(data_dim, n_inducing, latent_dim)\n",
    "    \n",
    "        # Sparse Variational Formulation (inducing variables initialised as randn)\n",
    "        q_u = CholeskyVariationalDistribution(n_inducing, batch_shape=self.batch_shape) \n",
    "        q_f = VariationalStrategy(self, self.inducing_inputs, q_u, learn_inducing_locations=True)\n",
    "    \n",
    "        # Define prior for X\n",
    "        X_prior_mean = torch.zeros(n, latent_dim)  # shape: N x Q\n",
    "        prior_x = NormalPrior(X_prior_mean, torch.ones_like(X_prior_mean))\n",
    "    \n",
    "        # Initialise X with PCA or randn\n",
    "        if pca == True:\n",
    "             X_init = _init_pca(Y, latent_dim) # Initialise X to PCA \n",
    "        else:\n",
    "             X_init = torch.nn.Parameter(torch.randn(n, latent_dim))\n",
    "          \n",
    "      \n",
    "        X = VariationalLatentVariable(n, data_dim, latent_dim, X_init, prior_x)\n",
    "        \n",
    "     \n",
    "        \n",
    "        super().__init__(X, q_f)\n",
    "        \n",
    "        # Kernel (acting on latent dimensions)\n",
    "        self.mean_module = ZeroMean(ard_num_dims=latent_dim)\n",
    "        self.covar_module = ScaleKernel(RBFKernel(ard_num_dims=latent_dim))\n",
    "\n",
    "    def forward(self, X):\n",
    "        mean_x = self.mean_module(X)\n",
    "        covar_x = self.covar_module(X)\n",
    "        dist = MultivariateNormal(mean_x, covar_x)\n",
    "        return dist\n",
    "    \n",
    "    def _get_batch_idx(self, batch_size):\n",
    "        valid_indices = np.arange(self.n)\n",
    "        batch_indices = np.random.choice(valid_indices, size=batch_size, replace=False)\n",
    "        return np.sort(batch_indices)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Training the model\n",
    "\n",
    "While we need to specify the dimensionality of the latent variables at the outset, one of the advantages \n",
    "of the Bayesian framework is that by using a ARD kernel we can prune dimensions corresponding to small inverse lengthscales."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "N = len(Y)\n",
    "data_dim = Y.shape[1]\n",
    "latent_dim = 10\n",
    "n_inducing = 25\n",
    "pca = False\n",
    "# Model\n",
    "model = bGPLVM(N, data_dim, latent_dim, n_inducing, pca=pca).to(device)\n",
    "# Likelihood\n",
    "likelihood = GaussianLikelihood(batch_shape=model.batch_shape).to(device)\n",
    "\n",
    "mll = VariationalELBO(likelihood, model, num_data=len(Y)).to(device)\n",
    "loss_list = []\n",
    "eta=0.0025\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We use mini-batch training for scalability where only a subset of the local variaitonal params are optimised in each iteration. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "b70a0104dc1240f6b76624b4cda3a432",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/1500 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Training loop - optimises the objective wrt kernel hypers, variational params and inducing inputs\n",
    "# using the optimizer provided.\n",
    "eta=0.0025\n",
    "K=26\n",
    "scale=100\n",
    "alpha=1/scale\n",
    "beta=0.04\n",
    "optimizer = torch.optim.Adam([\n",
    "    {'params': model.parameters()},\n",
    "    {'params': likelihood.parameters()}\n",
    "], lr=0.02)    \n",
    "\n",
    "iterator = trange(1500 if not smoke_test else 4, leave=True)\n",
    "batch_size = 100\n",
    "#v=0\n",
    "for i in iterator: \n",
    "    torch.cuda.empty_cache()\n",
    "    optimizer.zero_grad()\n",
    "    batch_index = model._get_batch_idx(batch_size)\n",
    "    sample = model.sample_latent_variable().to(device)  # a full sample returns latent x across all N\n",
    "    b = 0\n",
    "    d = 0\n",
    "    \n",
    "    for j in range(1,K):\n",
    "        sample_batch1 = sample[batch_index].to(device)\n",
    "        output_batch1 = model(sample_batch1)\n",
    "        loss1 = (beta*j)*scale*mll.log_likelihood1(output_batch1, Y[batch_index].T).sum().to(device)\n",
    "        +(1-(beta)*j)*torch.distributions.Normal(model.X.q_mu[batch_index], torch.nn.functional.softplus(model.X.q_log_sigma[batch_index])).log_prob(sample[batch_index]).sum().to(device)\n",
    "        -(beta)*j*sample_batch1\n",
    "\n",
    "        a=torch.autograd.grad(loss1, sample, create_graph=False)[0].to(device)\n",
    "\n",
    "        c=torch.randn([Y.shape[0],latent_dim]).to(device)\n",
    "        #v=v+a**2\n",
    "        #eta=0.9*eta+0.1*0.05/(torch.sqrt(v)+0.01)#an daptive step size\n",
    "        \n",
    "        sample=sample.to(device)+eta*a\n",
    "        +torch.sqrt(torch.tensor(2*eta)).to(device)*c\n",
    "        with torch.enable_grad():\n",
    "            b=b+torch.norm((torch.sqrt(torch.tensor(eta)).to(device)*a))**2\n",
    "        \n",
    "            d=d+torch.dot(torch.sqrt(torch.tensor(2*eta)).view(-1,1).squeeze().to(device)*a.view(-1,1).squeeze(),c.view(-1,1).squeeze())\n",
    "    sample_batch = sample[batch_index]\n",
    "    output_batch = model(sample_batch)\n",
    "    loss_1= -mll(output_batch, Y[batch_index].T).sum()\n",
    "    loss =loss_1+alpha*b+alpha*d\n",
    "    loss_list.append(loss_1.item())\n",
    "    iterator.set_description('Loss: ' + str(float(np.round(loss_1.item(),2))) + \", iter no: \" + str(i))\n",
    "    loss.backward()\n",
    "    optimizer.step()\n",
    "    optimizer.zero_grad()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-5.416872978210449\n"
     ]
    }
   ],
   "source": [
    "print(loss_list[999])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualising the 2d latent subspace\n",
    "Visualising a two dimensional slice of the latent space corresponding to the most dominant latent dimensions.  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mll tensor(15.0976, device='cuda:0', grad_fn=<SumBackward0>)\n",
      "mse tensor(1.8999, device='cuda:0')\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_292257/1550865378.py:25: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  mse=torch.norm(Y.T-torch.tensor(output_batch3.mean).to(device),dim=1)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f826cfa1310>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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72b25kiT3ZHbdXl2FV23O7GViMgo8cwzz3DUUUdRV1engPkYYmbU1dVx1FFH8cwzzwzbcRQ0FxEREREREZngnHO/Be4J7q6IrHoycvuoPLsI1+1SPXMRGQs6OzuZOnVqpbshgzR16tRhLaujoLmIiIiIiIiIQN9knsdGlv0xcvuEPNuG6x4qa49ERIaRMszHruF+7RQ0FxERERERERGA5wXX0fIqjwLh5KCnx21kZtOA1wV3fz48XRMRERk5CpqLiIiIiIiIjGNmVm0FUvLMbAnwiuBuNlzunHPAjcHd95hZY8zm7wemA91AZqj9FRERqTQFzUVERERERETGt2OAB8zsfWb2vGgA3cyOMbOPA7cABjwH/FfO9l8EnsZP9vkTM3tZsO1kM7sY+HTQrtk59+gwPxYREQmkUin+4R/+IXbdSSedxLJlywBYtmwZJ510UlH7zGazmBmvfe1rS+5PoW3j+nHPPffwhje8gUMPPZRp06bxghe8gGXLlvH444+XfPxymlTRo4uIiIiIiIjISDgR+Hpw+4CZ7QKmAtMibR4D3umcezq6oXOuzczeDPwMeCFwn5ntBqYANUGznwMfGsb+i4jICLjpppsA+NWvfsWWLVuYO3fusG17zz33kEqleNvb3sZ1113H1KlTeeihh/jWt75Fa2srRx999OAfyBAp01xERERERERkfHsSeBfwNeA+YBswAx8T2ALcCrwXeJFz7oG4HTjn7gdehM9C/zM+WL4XuAe4EDjDOdcxvA9DRESGU2dnJ9///vc57bTTcM7x7W9/e1i3vfbaa1mwYAHf+973eMtb3sIb3vAGPvjBD/Kb3/yGV7/61UN5KEOmTHMRERERERGRccw5dwD4fnAZyn62Ah8OLiIiMs78/Oc/57nnnuNjH/sY+/bt46abbuKyyy4btm137tzJYYcdRty0GwWm4hh2yjQXERERERERkbGnpwd27oQOJbiLiJTDTTfdxKGHHsqSJUv4p3/6JzZu3MjmzZuHbduXvvSl3HnnnXz605/mb3/7WzkeQtko01xERERERERExp777oNXvhJ+/GM466xK90ZExoNLL4WNGytz7EWLYNWqyhwb2LdvH7fccgtLly6lurqad7/73XzoQx/ipptu4qqrrhqWbT/60Y9y77338slPfpJPfvKTHHHEEbzlLW/hwx/+MMcdd1y5H2JJ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\n",
      "text/plain": [
       "<Figure size 1800x576 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "scale1=100*Y.shape[0]/batch_size\n",
    "inv_lengthscale = 1 / model.covar_module.base_kernel.lengthscale\n",
    "values, indices = torch.topk(model.covar_module.base_kernel.lengthscale, k=2,largest=False)\n",
    "\n",
    "l1 = indices.cpu().numpy().flatten()[0]\n",
    "l2 = indices.cpu().numpy().flatten()[1]\n",
    "\n",
    "plt.figure(figsize=(25, 8))\n",
    "plt.rcParams['xtick.labelsize'] = 20\n",
    "plt.rcParams['ytick.labelsize'] = 25\n",
    "colors = ['r', 'b', 'g']\n",
    "\n",
    "plt.subplot(131)\n",
    "X = model.sample_latent_variable().to(device)\n",
    "\n",
    "for j in range(1,26):\n",
    "    output_batch3 = model(X)\n",
    "    loss3 = (beta*j)*scale1*mll.log_likelihood1(output_batch3, Y.T).sum().to(device)\n",
    "    +(1-beta*j)*torch.distributions.Normal(model.X.q_mu, torch.nn.functional.softplus(model.X.q_log_sigma)).log_prob(X).sum().to(device)\n",
    "    -(beta)*j*X\n",
    "\n",
    "    X=X+eta*torch.autograd.grad(loss3, X, create_graph=False)[0]\n",
    "    +torch.sqrt(torch.tensor(2*eta))*torch.randn([1000,10]).to(device)\n",
    "print('mll',mll.log_likelihood1(output_batch3, Y.T).sum().to(device))\n",
    "mse=torch.norm(Y.T-torch.tensor(output_batch3.mean).to(device),dim=1)\n",
    "print('mse',mse.mean())\n",
    "\n",
    "std = 0.1*torch.nn.functional.softplus(model.X.q_log_sigma).cpu().detach().numpy()\n",
    "plt.title('2d latent subspace ',fontsize=20)\n",
    "plt.xlabel('Latent dim 1',fontsize=20)\n",
    "plt.ylabel('Latent dim 2',fontsize=20)\n",
    "\n",
    "X=X.cpu().detach().numpy()\n",
    "\n",
    "# Select index of the smallest lengthscales by examining model.covar_module.base_kernel.lengthscales \n",
    "for i, label in enumerate(np.unique(labels)):\n",
    "    X_i = X[labels == label]\n",
    "    scale_i = std[labels == label]\n",
    "    plt.scatter(X_i[:, l1], X_i[:, l2], c=[colors[i]], label=label)\n",
    "    plt.errorbar(X_i[:, l1], X_i[:, l2], xerr=scale_i[:,l1], yerr=scale_i[:,l2], label=label,c=colors[i], fmt='none')\n",
    "   \n",
    "\n",
    "plt.subplot(132)\n",
    "plt.bar(np.arange(latent_dim), height=inv_lengthscale.cpu().detach().numpy().flatten())\n",
    "plt.title('Inverse Lengthscale with SE-ARD kernel',fontsize=18)\n",
    "plt.subplot(133)\n",
    "indices = np.arange(0, len(loss_list), 10)\n",
    "plt.plot(indices,loss_list[:len(loss_list):10], label='ULA-AIS',color='r')\n",
    "plt.title('Neg. ELBO Loss',fontsize=25)\n",
    "plt.legend(prop={'size': 15})"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "The vertical and horizontal bars indicate axis aligned Gaussian uncertainty around each latent point. "
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python (myenv)",
   "language": "python",
   "name": "myenv"
  },
  "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
