{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "1997d552-631e-4d74-981b-6ab97aecf67c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as pl\n",
    "import seaborn as sns\n",
    "import torch\n",
    "from sklearn import datasets\n",
    "from sklearn.metrics import roc_auc_score\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "from src.toy_example import Net, train_net"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "d6a20461-b8fb-406a-b7fa-1652cdebbf33",
   "metadata": {},
   "source": [
    "# Toy example for the persistent homology paper \n",
    "\n",
    "In this notebook, we reproduce the results of the toy example. "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "57ac6343-6ccf-4563-986e-3fdcdc19eac7",
   "metadata": {},
   "outputs": [],
   "source": [
    "N_FEAT = 2\n",
    "CLASSES = 2\n",
    "X, y = datasets.make_classification(\n",
    "    n_samples=1000,\n",
    "    n_features=N_FEAT,\n",
    "    n_informative=N_FEAT,\n",
    "    n_redundant=0,\n",
    "    class_sep=0.8,\n",
    "    n_classes=CLASSES,\n",
    ")\n",
    "\n",
    "\n",
    "X_train, X_test, y_train, y_test = train_test_split(\n",
    "    X, y, train_size=0.7, stratify=y\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "fbd7ca7f-12b9-439e-b5cf-c23f2a692815",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Normalize embeddings: True\n",
      "(300,)\n",
      "roc-auc before training: 0.6098666666666667\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:05<00:00, 189.63it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "roc-auc after training: 0.9242222222222222\n"
     ]
    },
    {
     "data": {
      "image/png": "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2+mDwIVM++tKag2g1gI26+VXINQaQB8BSa0FNFpArbX/YvD0DXi7efpzY63Kvw+q9G8Phfuuwlgcu9YCiAMQJwFILn85actfHqbXF/YaGZvFCmGxwma12v9vtQJWAWG12V/CBthsEDYbYBP2V/l1jPLrFwKQILwkNgKAGZDMygpqLn/JouBclACVFlBrJah05QmLB76+RVH+sgGwmQWsZQJWkwDMAkIABScsyN5V6tzedsX7BAAhSeX/wv4plv8rJPs6SFf831FWZ9iu8YsKqwUAbZwRvTJe9fWp+GQ0GplM+anOJiMXL16E1WpFUpLr8NWkpCQcOHDA7Xvmzp2L2bNnV1qelpZWJTEG7ASArQBekfuGj6osFCKisBa7NOBdhFOTfU1TZ5MRf8yYMQPTp093/myz2ZCdnY369esryobz8/ORlpaGU6dO1fgTtzaVBahd5WFZwldtKg/LcpnRyEkb/VVnk5EGDRpArVYjKyvLZXlWVhaSk93Pr6HX66HXuz5TNS4uzu8YYmJiavzF61CbygLUrvKwLOGrNpWHZaFABO8RrDWMTqdD586dkZGR4Vxms9mQkZGB7t27hzAyIiKiuqXO1owAwPTp05Geno4uXbqga9eueOWVV1BUVITx48eHOjQiIqI6o04nI3fddRcuXLiAp59+GpmZmejUqRO+//77Sp1ag02v12PmzJmVmnxqotpUFqB2lYdlCV+1qTwsCwVDnZ5nhIiIiEKvzvYZISIiovDAZISIiIhCiskIERERhRSTESIiIgopJiPVJDs7G/fccw9iYmIQFxeHCRMmoLCw0Ov206ZNQ6tWrRAREYHGjRvjoYcecj4PpzotWrQITZs2hcFgQLdu3fDrr7963X7lypVo3bo1DAYDOnTogG+//baaIpVHSXneeecd9OrVC/Xq1UO9evXQv39/n+WvTkq/G4cVK1ZAkiSMGDGiagNUQGlZcnNzMWXKFKSkpECv1+Pqq68Om3NNaVleeeUV57WelpaGv//97ygtLfX6nurw448/YujQoUhNTYUkSVi1apXP9/zwww+47rrroNfr0bJlSyxdurTK45RLaXk+++wz3HLLLUhISEBMTAy6d++O1atXV0+wdY2gajFo0CDRsWNHsWXLFvHTTz+Jli1bijFjxnjcfu/evWLkyJHiyy+/FIcPHxYZGRniqquuErfffns1Ri3EihUrhE6nE++//774448/xP333y/i4uJEVlaW2+1//vlnoVarxYIFC8S+ffvEU089JbRardi7d2+1xu2J0vLcfffdYtGiRWLnzp1i//79Yty4cSI2NlacPn26miOvTGlZHI4dOyYaNmwoevXqJYYPH149wfqgtCwmk0l06dJFDBkyRGzatEkcO3ZM/PDDD2LXrl3VHHllSsvy0UcfCb1eLz766CNx7NgxsXr1apGSkiL+/ve/V3PklX377bfiySefFJ999pkAID7//HOv2x89elRERkaK6dOni3379omFCxcKtVotvv/+++oJ2Ael5Xn44YfF/Pnzxa+//ir+/PNPMWPGDKHVasWOHTuqJ+A6hMlINdi3b58AIH777Tfnsu+++05IkiTOnDkjez+ffPKJ0Ol0wmw2V0WYbnXt2lVMmTLF+bPVahWpqali7ty5brcfNWqUuPXWW12WdevWTTzwwANVGqdcSstzJYvFIoxGo/jPf/5TVSHK5k9ZLBaLuPHGG8W7774r0tPTwyYZUVqWxYsXi+bNm4uysrLqClE2pWWZMmWK6Nevn8uy6dOnix49elRpnErJ+eX9+OOPi3bt2rksu+uuu8TAgQOrMDL/yCmPO23bthWzZ88OfkB1HJtpqsHmzZsRFxeHLl26OJf1798fKpUKW7dulb0fxxMhNZrqmauurKwM27dvR//+/Z3LVCoV+vfvj82bN7t9z+bNm122B4CBAwd63L46+VOeKxUXF8NsNiM+Pr6qwpTF37I888wzSExMxIQJE6ojTFn8KcuXX36J7t27Y8qUKUhKSkL79u0xZ84cWK3W6grbLX/KcuONN2L79u3OppyjR4/i22+/xZAhQ6ol5mAK5+s/GGw2GwoKCkJ+/ddGdXoG1uqSmZmJxMREl2UajQbx8fHIzMyUtY+LFy/i2WefxcSJE6siRI/HtFqtlWakTUpKwoEDB9y+JzMz0+32cstZlfwpz5X++c9/IjU1tdINt7r5U5ZNmzbhvffew65du6ohQvn8KcvRo0exfv163HPPPfj2229x+PBhTJ48GWazGTNnzqyOsN3ypyx33303Ll68iJ49e0IIAYvFgkmTJuFf//pXdYQcVJ6u//z8fJSUlCAiIiJEkQXHiy++iMLCQowaNSrUodQ6rBkJwBNPPAFJkry+5P6S8yY/Px+33nor2rZti1mzZgUeOPll3rx5WLFiBT7//HMYDIZQh6NIQUEB7r33Xrzzzjto0KBBqMMJmM1mQ2JiIt5++2107twZd911F5588km8+eaboQ5NsR9++AFz5szBG2+8gR07duCzzz7DN998g2effTbUoVEFH3/8MWbPno1PPvmk0h+XFDjWjATg0Ucfxbhx47xu07x5cyQnJ+P8+fMuyy0WC7Kzs5GcnOz1/QUFBRg0aBCMRiM+//xzaLXaQMOWrUGDBlCr1cjKynJZnpWV5THu5ORkRdtXJ3/K4/Diiy9i3rx5WLduHa655pqqDFMWpWU5cuQIjh8/jqFDhzqX2Ww2APZauoMHD6JFixZVG7QH/nwvKSkp0Gq1UKvVzmVt2rRBZmYmysrKoNPpqjRmT/wpy//93//h3nvvxX333QcA6NChA4qKijBx4kQ8+eSTUKlqzt+Mnq7/mJiYGl0rsmLFCtx3331YuXJlyGtFa6uac5aHoYSEBLRu3drrS6fToXv37sjNzcX27dud712/fj1sNhu6devmcf/5+fkYMGAAdDodvvzyy2r/a1yn06Fz587IyMhwLrPZbMjIyED37t3dvqd79+4u2wPA2rVrPW5fnfwpDwAsWLAAzz77LL7//nuXfj+hpLQsrVu3xt69e7Fr1y7na9iwYejbty927dqFtLS06gzfhT/fS48ePXD48GFnQgUAf/75J1JSUkKWiAD+laW4uLhSwuFIskQNe3RYOF///lq+fDnGjx+P5cuX49Zbbw11OLVXqHvQ1hWDBg0S1157rdi6davYtGmTuOqqq1yG9p4+fVq0atVKbN26VQghRF5enujWrZvo0KGDOHz4sDh37pzzZbFYqi3uFStWCL1eL5YuXSr27dsnJk6cKOLi4kRmZqYQQoh7771XPPHEE87tf/75Z6HRaMSLL74o9u/fL2bOnBl2Q3uVlGfevHlCp9OJTz/91OU7KCgoCFURnJSW5UrhNJpGaVlOnjwpjEajmDp1qjh48KD4+uuvRWJionjuuedCVQQnpWWZOXOmMBqNYvny5eLo0aNizZo1okWLFmLUqFGhKoJTQUGB2Llzp9i5c6cAIF5++WWxc+dOceLECSGEEE888YS49957nds7hvb+4x//EPv37xeLFi0Kq6G9Ssvz0UcfCY1GIxYtWuRy/efm5oaqCLUWk5FqcunSJTFmzBgRHR0tYmJixPjx411+oR07dkwAEBs2bBBCCLFhwwYBwO3r2LFj1Rr7woULRePGjYVOpxNdu3YVW7Zsca7r3bu3SE9Pd9n+k08+EVdffbXQ6XSiXbt24ptvvqnWeH1RUp4mTZq4/Q5mzpxZ/YG7ofS7qSickhEhlJfll19+Ed26dRN6vV40b95cPP/889WaqHujpCxms1nMmjVLtGjRQhgMBpGWliYmT54scnJyqj/wK3i6DzniT09PF7179670nk6dOgmdTieaN28ulixZUu1xe6K0PL179/a6PQWPJEQNqwckIiKiWoV9RoiIiCikmIwQERFRSDEZISIiopBiMkJEREQhxWSEiIiIQorJCBEREYUUkxEiIiIKKSYjREREFFJMRoiIiCikmIwQERFRSDEZISIiopBiMkJEREQh9f/ZpLqhBNvs5wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "NORMALIZE_EMBEDDINGS = True\n",
    "EVERY = 10\n",
    "TOTAL_EPOCHS = 1000\n",
    "\n",
    "\n",
    "print(f\"Normalize embeddings: {NORMALIZE_EMBEDDINGS}\")\n",
    "\n",
    "\n",
    "net = Net(\n",
    "    input_units=N_FEAT,\n",
    "    middle_layer_units=5,\n",
    "    normalize_embeddings=NORMALIZE_EMBEDDINGS,\n",
    "    n_output=CLASSES,\n",
    ")\n",
    "\n",
    "\n",
    "preds = net(torch.tensor(X_test).float()).detach().numpy()[:, 1]\n",
    "print(preds.shape)\n",
    "\n",
    "print(\n",
    "    f\"roc-auc before training: {roc_auc_score(y_test, preds, multi_class='ovo')}\"\n",
    ")\n",
    "\n",
    "net, encodings, h0_data = train_net(\n",
    "    net,\n",
    "    X_train,\n",
    "    y_train,\n",
    "    X_test,\n",
    "    epochs=TOTAL_EPOCHS,\n",
    "    normalised=True,\n",
    "    lr=1e-3,\n",
    "    every=EVERY,\n",
    ")\n",
    "\n",
    "preds = net(torch.tensor(X_test).float()).detach().numpy()[:, 1]\n",
    "\n",
    "print(\n",
    "    f\"roc-auc after training: {roc_auc_score(y_test, preds, multi_class='ovo')}\"\n",
    ")\n",
    "\n",
    "pl.figure(figsize=(5, 3))\n",
    "\n",
    "IND = [0, 1, -1]\n",
    "steps = [0, EVERY, TOTAL_EPOCHS]\n",
    "\n",
    "sns.set_palette(\"rocket\", len(IND))\n",
    "\n",
    "for i in IND:\n",
    "    x = h0_data[i]\n",
    "    ep = steps[i]\n",
    "    sns.kdeplot(x, fill=False, alpha=1.0, label=f\"epoch {ep}\")\n",
    "\n",
    "\n",
    "sns.despine()\n",
    "pl.title(\n",
    "    \"Densities of the normalised persistence times for the $H_0$ group.\",\n",
    ")\n",
    "\n",
    "\n",
    "pl.show()"
   ]
  }
 ],
 "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.10.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
