{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d556a621",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/dadou/micromamba/envs/python/lib/python3.11/site-packages/MDAnalysis/topology/TPRParser.py:161: DeprecationWarning: 'xdrlib' is deprecated and slated for removal in Python 3.13\n",
      "  import xdrlib\n"
     ]
    }
   ],
   "source": [
    "import multipers as mp\n",
    "import multipers.ml.signed_measures as mms\n",
    "from sklearn.pipeline import Pipeline\n",
    "import matplotlib.pyplot as plt\n",
    "import warnings\n",
    "warnings.simplefilter(\"ignore\", UserWarning)\n",
    "import multipers.data.MOL2 as mdm\n",
    "import numpy as np"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "id": "d292e095",
   "metadata": {},
   "source": [
    "The following provide the code to get the Enrichment Factor and the ROC-AUC from the Cleves-Jain dataset, with our pipeline. The dataset is assumed to be installed in `$HOME/Datasets/Cleves-Jain/`. Note that the convolution implementation slightly changed (c.f. `pipelines/convolutions/convolutions.py`), and Sliced Wasserstein has some randomness, so the results may differ.\n",
    "\n",
    "As one can see, non-renormalized filtrations performs **significantly better** than its \"normalized\" counterpart, but choosing non rescaled filtrations is not based on *a priori* information, as in general, one wants each filtration to be comparable, i.e., in the same scale, i.e., normalized.\n",
    "\n",
    "The parameter to choose for the paper are `resolution = 1000` and `renormalize=True` and a `bandwidth=1`. The grid of the image can either be infered (by choosing a `out_resolution`, or by choosing the same grid as the simplextrees, i.e., `filtration_grid=filtration_grid`)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fea36602",
   "metadata": {},
   "outputs": [],
   "source": [
    "resolution = 100 # The grid resolution on which to compute the signed measure (for each filtration)\n",
    "invariant = \"euler\" # The topological invariant to compute the signed measure\n",
    "renormalize = True # Renormalizes the filtration if set to true\n",
    "degrees = [0] if invariant == \"hilbert\" else [None]\n",
    "graph=True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "258a6663",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Applying pipeline: 100%|██████████| 23/23 [00:06<00:00,  3.75it/s]\n"
     ]
    }
   ],
   "source": [
    "all_pathes = mdm.get_all_JC_path() # retrieves the path of the dataset, in a dictionary \n",
    "pathes = mdm.get_data_path_JC()\n",
    "filtrations=[ # Choose which filtrations to consider, here all available\n",
    "    \"bond_length\",\n",
    "    \"atomic_mass\", \n",
    "    \"bond_type\",\n",
    "]\n",
    "num_parameters = len(filtrations)\n",
    "ST = mdm.Molecule2SimplexTree(filtrations=filtrations,graph=graph, n_jobs=1) # This pipeline turns molecules into our multiparameter simplextrees\n",
    "SM = mms.SimplexTree2SignedMeasure(degrees=degrees, # This pipeline turns simplextrees to signed measures\n",
    "    fit_fraction=1, n_jobs=-1, \n",
    "    grid_strategy=\"exact\",\n",
    "    expand=False,\n",
    "    individual_grid=True,\n",
    "    enforce_null_mass=True,\n",
    "    normalize_filtrations=renormalize,\n",
    ")\n",
    "pipeline_sm = Pipeline([ # this combines the two previous pipelines\n",
    "\t\t(\"st\", ST),\n",
    "\t\t(\"sm\", SM),\n",
    "])\n",
    "pipeline_sm.fit(all_pathes)  # Compiles the pipelines together, it computes : the number of parameters, filtration bounds, the format of the simplextrees ... from the molecule files\n",
    "filtration_grid = SM._reconversion_grid\n",
    "sms = mdm.apply_pipeline(pathes=pathes, pipeline=pipeline_sm)  # This computes the signed measures into sms."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a3134e64",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computed a diameter of 125.97281184020595\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Applying pipeline:   0%|          | 0/23 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[KeOps] Warning : Cuda libraries were not detected on the system ; using cpu only mode\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Applying pipeline: 100%|██████████| 23/23 [00:15<00:00,  1.44it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkQAAAHHCAYAAABeLEexAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABli0lEQVR4nO3dd3xTVf8H8E9Wk+4FXXTQspENgixbVtkyRJShRR4VEJWKgiIqRZEqKoKA86eMR6YKiI+syhIFlKnsIatAS6Gb7iTn90ea0HTRlLTJbT/v1yu0uffm5tvbpPlwzrnnyoQQAkRERES1mNzWBRARERHZGgMRERER1XoMRERERFTrMRARERFRrcdARERERLUeAxERERHVegxEREREVOsxEBEREVGtx0BEREREtZ6kA9Gff/6JYcOGITg4GGq1Gr6+vujcuTNeeeUVs+0iIiIQERFhmyItUL9+fYwbN+6e28lkMshksjK3feedd0zbXL582ao1SlVeXh4WL16Mbt26wdPTEw4ODqhXrx5GjhyJPXv22Lo8i4wbNw7169ev1GP37duHmJgYpKWllVhXHe+TZcuWQSaTWWVfERERptd58Vtlj095Kvr+LOry5cuQyWT46KOPrF5Pddi8eTNiYmIqvP24cePK/J3873//s2ptp06dQkxMjN38jRs+fDhkMhleeOGFUtcbX/uHDh0qdf2gQYNKfd1mZGTgvffeQ4cOHeDm5ga1Wo369etj/PjxOHLkiDV/hApZs2YN2rRpA41Gg4CAAERHR+POnTsVemxCQgLGjRsHHx8faDQatGrVCt98802p2+7atQt9+vSBj48PXFxc0KpVK3z66afQ6XRm282cORNt27aFl5cXNBoNwsLC8Nxzz+HKlSsW/2xKix9hJ3755Rc88sgjiIiIwLx58+Dv74+EhAQcOnQIa9aswccff2za9rPPPrNhpVXD1dUV33//PRYtWgRXV1fTciEEli1bBjc3N2RkZNiwQvtx+/Zt9OvXD//88w/Gjx+PadOmwcvLC9evX8dPP/2EXr164fDhw2jdurWtS61y+/btw+zZszFu3Dh4eHiYrZPi+yQsLAwrV64ssVytVlv9uTZs2AA3Nzer79eebd68GUuWLLEoFDk6OmLnzp0lljdt2tSKlRkC0ezZsxEREVElAdgSSUlJpsC3cuVKfPTRR9BoNPe9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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "out_resolution = 1000 # The resolution of the images. One can increase this to get (slightly) better results\n",
    "bandwidth=1 # The bandwidth. As this is unsupervised, we have to fix it to 1.\n",
    "pipeline_img = mms.SignedMeasure2Convolution( # This pipeline turns signed measures to signed measure convolutions\n",
    "    bandwidth=bandwidth, flatten=True,\n",
    "    resolution=out_resolution,\n",
    "    # filtration_grid=filtration_grid,\n",
    "    grid_strategy=\"partition\",\n",
    "    progress=True,    \n",
    "    )\n",
    "sms_ = pipeline_sm.fit_transform(all_pathes); pipeline_img.fit(sms_) # This compiles the previous pipeline. It computes the structure of the signed measure, e.g., is it in a sparse format, the bounds, etc.\n",
    "imgs = mdm.apply_pipeline(pathes=sms, pipeline=pipeline_img) # This computes the convolution (or images)\n",
    "distances_to_letter, ytest = mdm.img_distances(imgs) # This computes the distances between each target and the rest of the dataset, according to the ToDD paper.\n",
    "EF = lambda alpha : mdm.get_EF_vector_from_distances(distances_to_letter, ytest, alpha) # This function gets the Enrichment Factor from these distances\n",
    "mdm.plot_EF_from_distances(EF=EF, alphas=[0.02, 0.05, 0.1]) # Evaluates the EF on a graph\n",
    "means = []\n",
    "for distances, labels in zip(distances_to_letter, ytest):\n",
    "    labels = labels == labels[0]\n",
    "    means.append(mdm.EF_AUC(distances=distances, labels=labels))\n",
    "plt.title(f\"Signed Measure Convolution's Enrichment Factor. AUC = {np.mean(means).round(decimals=3)}\")\n",
    "plt.savefig(f\"JC_SMI_r{resolution}_i{invariant}_b{bandwidth}_renormalize{renormalize}.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6484d4a0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Applying pipeline: 100%|██████████| 23/23 [00:09<00:00,  2.39it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Same for the undecomposed hilbert function / Euler caracteristic, with the same filtration grid ! i.e. the same information as our vectorizations\n",
    "pipeline_hilbert = Pipeline([\n",
    "\t\t(\"st\", ST),\n",
    "\t\t(\"sm\", SM),\n",
    "\t\t('smf', mms.SignedMeasureFormatter(integrate=True, flatten=True, resolution=20, grid_strategy='regular')) ## its in fact quicker to integrate the sparse signed measure than compute the non sparse directly (due to the cancelations)\n",
    "])\n",
    "pipeline_hilbert.fit(all_pathes)\n",
    "imgs_hilbert = mdm.apply_pipeline(pathes=pathes, pipeline=pipeline_hilbert)\n",
    "distances_to_letter, ytest = mdm.img_distances(imgs_hilbert)\n",
    "EF = lambda alpha : mdm.get_EF_vector_from_distances(distances_to_letter, ytest, alpha)\n",
    "mdm.plot_EF_from_distances(EF=EF, alphas=[0.02, 0.05, 0.1])\n",
    "means = []\n",
    "for distances, labels in zip(distances_to_letter, ytest):\n",
    "    labels = labels == labels[0]\n",
    "    means.append(mdm.EF_AUC(distances=distances, labels=labels))\n",
    "plt.title(f\"Hilbert Function's Enrichment Factor. AUC = {np.mean(means).round(decimals=3)}\")\n",
    "plt.savefig(f\"JC_H_r{resolution}_i{invariant}_b{bandwidth}_renormalize{renormalize}.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c6681c1c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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W7bg0qVLiI2NdUSpDxxHfzbyv193CQgIgEwmK5PyU1NTyyROk6CgoHK3l8vl8Pf3t1utrq4659rku+++w3PPPYe1a9eiT58+9izTLVh7rnNycnDo0CEcPXoUL774IgDjB68QAnK5HL/88gt69erlkNpdTXV+r4ODg1G3bl34+PiYl7Vo0QJCCFy9ehVNmza1a82uqjrnetGiRejevTtee+01AEDbtm3h4eGByMhILFiwgC3rNuSMz0a21NxFqVSiY8eOSEhIsFiekJCAbt26lbtP165dy2z/yy+/oFOnTlAoFHar1dVV51wDxhaasWPHYtWqVewHryJrz7W3tzdOnDiBY8eOmR+xsbFo3rw5jh07hi5dujiqdJdTnd/r7t274/r167h9+7Z52fnz5yGVSlGvXj271uvKqnOu8/LyIJVafvTJZDIAd1oRyDac8tlotyHILsx0ieBXX30lTp8+LeLi4oSHh4f4+++/hRBCTJs2TTz99NPm7U2Xrb3yyivi9OnT4quvvuIl3VVk7bletWqVkMvl4uOPPxbJycnmR2ZmprPegsuw9lzfjVc/VZ215zonJ0fUq1dPPPHEE+LUqVNi9+7domnTpuKf//yns96Cy7D2XC9btkzI5XLxySefiL/++kv8+uuvolOnTqJz587OegsuIycnRxw9elQcPXpUABBLliwRR48eNV8+XxM+GxlqKvDxxx+LBg0aCKVSKTp06CB2795tXjdmzBgRFRVlsf2uXbtE+/bthVKpFA0bNhSffvqpgyt2Xdac66ioKAGgzGPMmDGOL9wFWft7XRpDjXWsPddnzpwRffr0ERqNRtSrV0+8+uqrIi8vz8FVuyZrz/UHH3wgWrZsKTQajQgODhajR48WV69edXDVrmfnzp2V/vtbEz4bJUKwvY2IiIhcH8fUEBERkVtgqCEiIiK3wFBDREREboGhhoiIiNwCQw0RERG5BYYaIiIicgsMNUREROQWGGqIiIjILTDUEFGVREdHQyKRQCKR4NixY84uhyoxduxY889qw4YNzi6HyGEYaoioyp5//nkkJyejdevWFss/+eQThIWFQa1Wo2PHjti7d+89j3WvfRYtWoSHHnoIXl5eqFOnDoYMGYJz585ZXXN1arvXfnPmzDGHBtMjKCjI6tqqU9+ePXswaNAghISEVBha3n//fSQnJ1erHiJXxlBDRFWm1WoRFBQEuVxuXvbdd98hLi4OM2fOxNGjRxEZGYn+/fvjypUrFR6nKvvs3r0bEydOxIEDB5CQkACdToeYmBjk5uZWud7q1FbV/Vq1aoXk5GTz48SJE1Wu637qy83NRbt27fDRRx9VuI2Pj0+1QxaRS7PrnaWIyG5+//13ERUVJdRqtWjevLn4448/xOeffy4GDRpkl9eLiooSkyZNKrO8c+fOIjY21mJZeHi4mDZtWoXHqs4+qampAoDFzQrvpTqvU5X9bHVzz+rWZwJArF+/vtrridwNW2qIXNCBAwcQFRWFRx55BMePH0fLli0xZ84cvPPOO5g7d265+yxcuBCenp6VPqraNWNSVFSEw4cPIyYmxmJ5TEwM9u3bZ7N9ACArKwsAUKtWLbvVZs1+Fy5cQEhICMLCwjBixAgkJiZWqa77rY+IKia/9yZEVNO8+uqrePzxxzFt2jQAwIgRIzBy5EgMHjwY7du3L3ef2NhYDB8+vNLj1q1b16o60tLSoNfrERgYaLE8MDAQKSkpNttHCIFXX30VDz/8cJnxPLasrar7denSBd988w2aNWuGGzduYMGCBejWrRtOnToFf39/u9ZHRBVjqCFyMVevXsX+/fvxzjvvmJcplUoIISpspQGMLRxVbeWwlkQisXguhCiz7H72efHFF3H8+HH8+uuvDqntXvv179/fvLxNmzbo2rUrGjdujBUrVuDVV191SH1EVBa7n4hczJkzZwAAnTp1Mi87d+4cOnfujDZt2lS4nz26nwICAiCTycq0LKSmppZpgajuPi+99BI2btyInTt3ol69enatrbr7eXh4oE2bNrhw4YLd6yOiijHUELmYrKwsyGQy8/OMjAzEx8dDpVJVul9sbCyOHTtW6aN0UKoKpVKJjh07IiEhwWJ5QkICunXrdl/7CCHw4osvYt26ddixYwfCwsLsXlt19yssLMSZM2cQHBxs9/qIqBLOG6NMRNVx4cIFAUDMmzdPnDlzRsTExIj27duL2rVri7///ttur1vR1U9r1qwRCoVCfPXVV+L06dMiLi5OeHh4mGv58MMPRa9evazaRwghxo8fL3x8fMSuXbtEcnKy+ZGXl1flmqvyOtWpb/LkyWLXrl0iMTFRHDhwQAwcOFB4eXlZff6rU19OTo44evSoOHr0qAAglixZIo4ePSouX75c5vjg1U/0gGGoIXJB8+bNE/7+/kKtVosxY8aImzdvig4dOogmTZrY7TUrCjVCCPHxxx+LBg0aCKVSKTp06GBx2fXs2bNFgwYNrNpHCOMHcnmPZcuWCSGEWLZsmajK/8vu9TrVqe/JJ58UwcHBQqFQiJCQEDFs2DBx6tQpi/3tVd/OnTvLPS9jxowpc2yGGnrQSIQQwuHNQ0TkcqKjoxEREYGlS5c6uxQAxll9d+3ahV27djm7lHLVhPokEgnWr1+PIUOGOK0GIkfimBoiqrJPPvkEnp6e1Zo919a2bt2K+Ph4Z5dRIWfWFxsbC09PT6e8NpEzsaWGiKrk2rVryM/PBwCEhoZCqVQ6uSKqSGpqKrKzswEAwcHB8PDwcHJFRI7BUENERERugd1PRERE5BYYaoiIiMgtMNQQERGRW2CoISIiIrfAUENERERugaGGiIiI3AJDDREREbkFhhoiIiJyCww1RERE5BYYaoiIiMgt/H/3Ic1oYp7tdwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# The same with our signed measure sliced wasserstein kernel.\n",
    "def swd_distances(img_dict:dict):\n",
    "    from joblib import Parallel,delayed\n",
    "    decoy_list = img_dict[\"decoy\"]\n",
    "    def todo_letter(letter, imgs):\n",
    "        xtrain, xtest = imgs\n",
    "        assert len(xtest)>0\n",
    "        D = mms.SignedMeasure2SlicedWassersteinDistance(num_directions=50, _sliced=True, epsilon=0.1, n_jobs=-1).fit(xtrain).transform(xtest + decoy_list)\n",
    "        letter_ytest = np.array([letter]*len(xtest) + ['0']*len(decoy_list), dtype=\"<U1\")\n",
    "        return D,letter_ytest\n",
    "    out = Parallel(n_jobs=-1,prefer=\"threads\")(delayed(todo_letter)(letter, imgs) for letter, imgs in img_dict.items() if len(letter) == 1)\n",
    "    return [truc for truc,_ in out], [truc for _,truc in out]\n",
    "distances, ytest = swd_distances(sms)\n",
    "EF = lambda alpha : mdm.get_EF_vector_from_distances(distances=distances, ytest = ytest, alpha = alpha)\n",
    "mdm.plot_EF_from_distances(alphas = [0.02, 0.05, 0.1], EF=EF)\n",
    "means = []\n",
    "for distances, labels in zip(distances_to_letter, ytest):\n",
    "    labels = labels == labels[0]\n",
    "    means.append(mdm.EF_AUC(distances=distances, labels=labels))\n",
    "plt.title(f\"Sliced Wasserstein's Enrichment Factor. AUC = {np.mean(means).round(decimals=3)}\")\n",
    "plt.savefig(f\"JC_SMD_r{resolution}_i{invariant}_b{bandwidth}_renormalize{renormalize}.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5c4c6495",
   "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.11.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
