{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Topological optimization of the ICLR acronym into 4 clusters"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "In this notebook, we show how a topological loss can be use to optimize a data set for four clusters.\n",
    "\n",
    "We start by setting the working directory and importing the necessary libraries."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set working directory\n",
    "import os\n",
    "os.chdir(\"..\")\n",
    "\n",
    "# Handling arrays and data.frames\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "# Random sampling\n",
    "import random\n",
    "\n",
    "# Functions for deep learning (Pytorch)\n",
    "import torch\n",
    "from torch import nn\n",
    "\n",
    "# Pytorch compatible topology layer\n",
    "from topologylayer.nn import AlphaLayer\n",
    "from Code.losses import DiagramLoss\n",
    "\n",
    "# Plotting\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load and view data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We load and view the data as follows."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Load the data\n",
    "data = pd.read_csv(os.path.join(\"Data\", \"ICLR.csv\"), delimiter=\" \")\n",
    "\n",
    "# Plot the data\n",
    "fig, ax = plt.subplots()\n",
    "sns.scatterplot(data=data, x=\"x\", y=\"y\", hue=\"group\", ax=ax)\n",
    "ax.legend().remove()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Apply topological optimization to the embedding\n",
    "\n",
    "We now show how we can use topological optimization to encourage the model underlying the data to become connected. As a topological loss, we will use the persistence of the fourth most prominent gap."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define topological loss\n",
    "def g(p): return p[1] - p[0] # function that returns the persistence d - b of a point (b, d)\n",
    "TopLayer = AlphaLayer(maxdim=0) # alpha complex layer\n",
    "Component4Persistence = DiagramLoss(dim=0, i=4, j=4, g=g) # compute persistence of fourth most prominent gap\n",
    "\n",
    "# Construct topological loss function\n",
    "def top_loss(output):\n",
    "    dgminfo = TopLayer(output)            \n",
    "    loss = - Component4Persistence(dgminfo)\n",
    "    \n",
    "    return loss"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We can now conduct the topological optimization as follows."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[epoch 1] [topological loss: -8.496401]\n",
      "[epoch 50] [topological loss: -13.443504]\n",
      "[epoch 100] [topological loss: -16.110245]\n",
      "[epoch 150] [topological loss: -18.056824]\n",
      "[epoch 200] [topological loss: -19.873667]\n",
      "[epoch 250] [topological loss: -21.365299]\n",
      "[epoch 300] [topological loss: -22.824858]\n",
      "[epoch 350] [topological loss: -23.973787]\n",
      "[epoch 400] [topological loss: -24.931015]\n",
      "[epoch 450] [topological loss: -25.632105]\n",
      "[epoch 500] [topological loss: -26.259472]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Learning hyperparameters\n",
    "num_epochs = 500\n",
    "learning_rate = 1e-1\n",
    "\n",
    "# Conduct topological optimization\n",
    "Y = torch.autograd.Variable(torch.tensor(np.array(data.loc[:,[\"x\",\"y\"]])).type(torch.float), requires_grad=True)\n",
    "optimizer = torch.optim.Adam([Y], lr=learning_rate)\n",
    "\n",
    "for epoch in range(num_epochs):\n",
    "    optimizer.zero_grad()\n",
    "    loss = top_loss(Y)\n",
    "    loss.backward()\n",
    "    optimizer.step()\n",
    "\n",
    "    if epoch == 0 or (epoch + 1) % (int(num_epochs / 10)) == 0:\n",
    "        print (\"[epoch %d] [topological loss: %f]\" % (epoch + 1, loss.item()))\n",
    "        \n",
    "Y = Y.detach().numpy().copy()\n",
    "\n",
    "# View topologically optimized embedding\n",
    "fig, ax = plt.subplots()\n",
    "sns.scatterplot(x=Y[:,0], y=Y[:,1], hue=data.loc[:,\"group\"], ax=ax)\n",
    "ax.get_legend().remove()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We see that ordinary topological optimization resulted in at least four more prominently separated clusters, but points from the same letter in the ICLR acronym are also fragmented into different clusters. Here again, we may use a sampling strategy to both improve the computational efficiency and efectiveness of topological optimization, as we see below."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[epoch 1] [topological loss: -14.186261]\n",
      "[epoch 50] [topological loss: -15.832344]\n",
      "[epoch 100] [topological loss: -13.548508]\n",
      "[epoch 150] [topological loss: -16.434792]\n",
      "[epoch 200] [topological loss: -18.786116]\n",
      "[epoch 250] [topological loss: -18.687740]\n",
      "[epoch 300] [topological loss: -20.456610]\n",
      "[epoch 350] [topological loss: -22.089548]\n",
      "[epoch 400] [topological loss: -23.532574]\n",
      "[epoch 450] [topological loss: -24.267517]\n",
      "[epoch 500] [topological loss: -25.250372]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Learning hyperparameters\n",
    "top_frac = 0.25\n",
    "num_epochs = 500\n",
    "learning_rate = 1e-1\n",
    "\n",
    "# Conduct topologically optimization\n",
    "Y = torch.autograd.Variable(torch.tensor(np.array(data.loc[:,[\"x\",\"y\"]])).type(torch.float), requires_grad=True)\n",
    "optimizer = torch.optim.Adam([Y], lr=learning_rate)\n",
    "\n",
    "random.seed(42)\n",
    "for epoch in range(num_epochs):\n",
    "    optimizer.zero_grad()\n",
    "    I = random.sample(range(Y.shape[0]), int(Y.shape[0] * top_frac))\n",
    "    loss = top_loss(Y[I,:])\n",
    "    loss.backward()\n",
    "    optimizer.step()\n",
    "\n",
    "    if epoch == 0 or (epoch + 1) % (int(num_epochs / 10)) == 0:\n",
    "        print (\"[epoch %d] [topological loss: %f]\" % (epoch + 1, loss.item()))\n",
    "        \n",
    "Y = Y.detach().numpy().copy()\n",
    "\n",
    "# View topologically optimized embedding\n",
    "fig, ax = plt.subplots()\n",
    "sns.scatterplot(x=Y[:,0], y=Y[:,1], hue=data.loc[:,\"group\"], ax=ax)\n",
    "ax.legend().remove()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Note that the sampling strategy is not a guarantee that the points in the four different clusters will remain clustered together. Indeed, the topological loss function does not care whether neighboring points remain close to each other, as long as it reaches **at least** four clusters. Hence, we can also see that fragmentation starts to occur in the current case, which will likely worsen for further epochs. As seen in the main paper, this can be effectively resolved through topological regularization.  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
