{
 "cells": [
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Assuming we have compiled and installed mpml by following the README file we are ready to perform experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from random import sample\n",
    "import numpy as np\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "from scipy import sparse\n",
    "from typing import Tuple, List\n",
    "import argparse\n",
    "import gril.gril as gril\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "from scipy.spatial import Delaunay"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Let's import some helper functions already defined in ``utils.py``"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "num_circles = 2\n",
    "num_disks = 0\n",
    "experiment_name = f'circle_{num_circles}_disk_{num_disks}'\n",
    "data = create_circles_and_disks(num_circles, num_disks, False)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure()\n",
    "plt.scatter(data[:, 0], data[:, 1], s=1, c='b')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "class MultiPersLandscapeValLayer(nn.Module):\n",
    "    def __init__(self, res, hom_rank, step, l):\n",
    "        super().__init__()\n",
    "        self.res = res\n",
    "        self.step = step\n",
    "        self.l = l\n",
    "        self.sample_pts = self.sample_grid()\n",
    "        self.hom_rank = hom_rank\n",
    "        self.filt_layer = get_filtration\n",
    "        self.mpl = gril.MultiPers(hom_rank=hom_rank, l=l, step=2, res=res, ranks=list(range(1, 6)))\n",
    "        self.mpl.set_max_jobs(40)\n",
    "\n",
    "    def sample_grid(self):\n",
    "        pts = []\n",
    "        num_division = int(1.0 / self.res)\n",
    "        for j in range(0, num_division, self.step):\n",
    "            for i in range(0, num_division, self.step):\n",
    "                pts.append((i, j))\n",
    "        return pts\n",
    "\n",
    "    def forward(self, x, edges, tri, tri_converted):\n",
    "        num_vertices = x.shape[0]\n",
    "        f, e = self.filt_layer(x, edges, tri, tri_converted)\n",
    "        simplices = get_simplices(num_vertices, e, tri)\n",
    "        pers_inp = [(f, simplices)]\n",
    "        bars = self.mpl.compute_landscape(self.sample_pts, pers_inp)\n",
    "        return bars"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Took 19839 ms\n",
      "Took 1842 ms\n"
     ]
    }
   ],
   "source": [
    "edges, triangles, tri_converted = delaunay_complex(data)\n",
    "x = torch.tensor(data, dtype=torch.float)\n",
    "num_vertices = x.shape[0]\n",
    "\n",
    "layer1_0 = MultiPersLandscapeValLayer(res=0.01, hom_rank=0, step=2, l=2)\n",
    "# layer1_1 = MultiPersLandscapeValLayer(res=0.01, hom_rank=1, step=2, l=2)\n",
    "\n",
    "out1_0 = layer1_0(x, edges, triangles, tri_converted)\n",
    "lmbda1_0 = out1_0[0]\n",
    "layer1_0.mpl.set_hom_rank(1)\n",
    "out1_1 = layer1_0(x, edges, triangles, tri_converted)\n",
    "lmbda1_1 = out1_1[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, (ax1, ax2) = plt.subplots(1, 2)\n",
    "h1 = lmbda1_1.numpy().reshape((50, 50, 5))\n",
    "h1_1 = h1[:, :, 0].reshape((50, 50))\n",
    "h1_2 = h1[:, :, 1].reshape((50, 50))\n",
    "ax1.imshow(h1_1, cmap='jet', origin='lower')\n",
    "ax1.set_title('$\\lambda_1$')\n",
    "ax1.set_axis_off()\n",
    "ax2.imshow(h1_2, cmap='jet', origin='lower')\n",
    "ax2.set_title('$\\lambda_2$')\n",
    "ax2.set_axis_off()\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "stnets",
   "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.12"
  },
  "orig_nbformat": 4,
  "vscode": {
   "interpreter": {
    "hash": "2014c2466ac851c3e09b7a320280ea5581b5d2277fc5e880758e6946cec9e9b3"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
