{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Topological optimization of a graph approximation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "In this notebook, we will explore whether we can conduct topological optimization of based on a graph approximation (and a function defined on the nodes thereof) of a point cloud data set.\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",
    "# 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": [
    "## Generate and view data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We will generat"
   ]
  },
  {
   "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 total (finite) 0-dimensional persistence."
   ]
  },
  {
   "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",
    "TotalPersistence = DiagramLoss(dim=0, i=2, g=g) # compute total finite 0-dimensional persistence\n",
    "\n",
    "# Construct topological loss function\n",
    "def top_loss(output):\n",
    "    dgminfo = TopLayer(output)            \n",
    "    loss = TotalPersistence(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: 457.542542]\n",
      "[epoch 100] [topological loss: 129.146744]\n",
      "[epoch 200] [topological loss: 93.165222]\n",
      "[epoch 300] [topological loss: 84.318512]\n",
      "[epoch 400] [topological loss: 78.541626]\n",
      "[epoch 500] [topological loss: 77.293060]\n",
      "[epoch 600] [topological loss: 74.688240]\n",
      "[epoch 700] [topological loss: 69.911301]\n",
      "[epoch 800] [topological loss: 70.679962]\n",
      "[epoch 900] [topological loss: 65.238800]\n",
      "[epoch 1000] [topological loss: 66.778046]\n"
     ]
    }
   ],
   "source": [
    "# Dictionary to store optimized point cloud for multiple epochs\n",
    "optimized = dict()\n",
    "\n",
    "# Learning hyperparameters\n",
    "num_epochs = [5, 50, 100, 250, 500, 1000]\n",
    "learning_rate = 1e0\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[len(num_epochs) - 1]):\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[len(num_epochs) - 1]) / 10) == 0:\n",
    "        print (\"[epoch %d] [topological loss: %f]\" % (epoch + 1, loss.item()))\n",
    "        \n",
    "    if epoch + 1 in num_epochs:\n",
    "        optimized[epoch + 1] = Y.detach().numpy().copy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "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": [
    "# View topologically optimized data for a particular number of epochs\n",
    "epoch = 250\n",
    "fig, ax = plt.subplots()\n",
    "sns.scatterplot(x=optimized[epoch][:,0], y=optimized[epoch][:,1], hue=data.loc[:,\"group\"], ax=ax)\n",
    "ax.legend().remove()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Finally, we save the optimized data sets for plotting in R."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "for epoch in num_epochs:\n",
    "    np.savetxt(os.path.join(\"Data\", \"ICLR Optimized\" , \"epochs\" + str(epoch) + \".csv\"), \n",
    "               optimized[epoch], delimiter=\",\")"
   ]
  },
  {
   "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
}
