{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d556a621",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "OMP: Info #276: omp_set_nested routine deprecated, please use omp_set_max_active_levels instead.\n"
     ]
    }
   ],
   "source": [
    "from pipelines import pipelines_2parameter as p2\n",
    "from sklearn.pipeline import Pipeline\n",
    "import matplotlib.pyplot as plt\n",
    "import warnings\n",
    "warnings.simplefilter(\"ignore\", UserWarning)\n",
    "from datasets_getter.MOL2 import *"
   ]
  },
  {
   "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": null,
   "id": "fea36602",
   "metadata": {},
   "outputs": [],
   "source": [
    "resolution = 10000 # 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 = False # Renormalizes the filtration if set to true"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "258a6663",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Inferring filtration grid from simplextrees, with strategy exact...Done.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Applying pipeline: 100%|██████████| 23/23 [00:03<00:00,  6.63it/s]\n"
     ]
    }
   ],
   "source": [
    "degrees = [0] if invariant == \"hilbert\" else [None]\n",
    "all_pathes = get_all_JC_path() # retrieves the path of the dataset, in a dictionary \n",
    "pathes = get_data_path_JC()\n",
    "filtrations={ # Choose which filtrations to consider, here all available\n",
    "    \"bond_length_filtration\":True, \n",
    "    \"atomic_mass_filtration\":True, \n",
    "    \"bond_type_filtration\":True,\n",
    "}\n",
    "num_parameters = len(filtrations)\n",
    "ST = p2.Molecule2SimplexTree(**filtrations, n_jobs=1) # This pipeline turns molecules into our multiparameter simplextrees\n",
    "SM = p2.SimplexTree2SignedMeasure(degrees=degrees, resolution=resolution, # This pipeline turns simplextrees to signed measures\n",
    "        fit_fraction=1, sparse=True, n_jobs=-1, \n",
    "        infer_filtration_strategy=\"exact\",\n",
    "        expand=False,\n",
    "        normalize_filtrations=renormalize,\n",
    "        invariant=\"_\",\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",
    "sparse = pipeline_sm.get_params()[\"sm__sparse\"]\n",
    "sms = apply_pipeline(pathes=pathes, pipeline=pipeline_sm)  # This computes the signed measures into sms."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a3134e64",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Inferring filtration grid from simplextrees, with strategy exact...Done.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Applying pipeline: 100%|██████████| 23/23 [00:57<00:00,  2.49s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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oKAajVfOqnOu8/Ly4ORk+dWnVCoB3G69INuQ3XejnQZzOzTzNM7PPvtMnD59WkyfPl24urqKxMREIYQQr732mnj88cel+uaphf/85z/F6dOnxWeffebQUwsdibXnet26dUKlUolly5aJ5ORk6ZKRkWGvhyAb1p7r0jjLrOqsPdfZ2dkiKChIPPTQQ+LUqVNiz549okWLFuLJJ5+010OQDWvP9cqVK4VKpRLLly8Xf//9t/jll19E9+7dRc+ePe31EGQjOztbHD9+XBw/flwAEIsXLxbHjx+XljiQ+3cjE6IKLFu2TISGhgqNRiO6du0q9uzZI22LiYkRERERFvV3794tunTpIjQajWjSpIlYsWJFLUcsX9ac64iICAGgzCUmJqb2A5cha1/XJTEhso615/rMmTNi0KBBwtnZWQQFBYkZM2aIvLy8Wo5anqw91x988IFo27atcHZ2FgEBAeKxxx4Tly9fruWo5WfXrl2Vfv7K/btRIQTbCImIiKh+4xgiIiIiqveYEBEREVG9x4SIiIiI6j0mRERERFTvMSEiIiKieo8JEREREdV7TIiIiIio3mNCRERERPUeEyIiqpLIyEgoFAooFAqcOHHC3uFQJcaPHy89V19//bW9wyGSBSZERFRlTz31FJKTk9G+fXuL8uXLlyMsLAw6nQ7dunXD3r1773isO+0TGxuLHj16wN3dHb6+vhg5ciTOnj1rdczVie1O+82ZM0dKOMwXf39/q2OrTnz/+9//MHz4cAQGBlaY8Lz//vtITk6uVjxE9RUTIiKqMhcXF/j7+0OlUkllGzZswPTp0zFr1iwcP34c/fr1Q3R0NC5dulThcaqyz549ezB16lQcPHgQ8fHx0Ov1iIqKQm5ubpXjrU5sVd2vXbt2SE5Oli4nT56sclx3E19ubi46deqEpUuXVljH09Oz2gkaUb1l7x9TI6LqOXTokIiIiBA6nU60atVK/Prrr+I///mPGD58eI3cX0REhJg2bVqZ8p49e4rJkydblLVu3Vq89tprFR6rOvukpqYKABY/3Hkn1bmfquxnqx+6rW58ZgDEli1bqr2diG5jCxGRDB08eBARERG477778Pvvv6Nt27aYM2cO3n77bcydO7fcfRYsWAA3N7dKL1XtTjIrKirC0aNHERUVZVEeFRWF/fv322wfAMjMzAQAeHt711hs1ux37tw5BAYGIiwsDI888gguXLhQpbjuNj4iqhmqO1chIkczY8YMPPjgg3jttdcAAI888ggeffRRjBgxAl26dCl3n8mTJ2PMmDGVHrdx48ZWxXHjxg0YDAb4+flZlPv5+SElJcVm+wghMGPGDPTt27fM+CVbxlbV/cLDw/HFF1+gZcuWuHbtGubNm4fevXvj1KlT8PHxqdH4iKhmMCEikpnLly/jwIEDePvtt6UyjUYDIUSFrUOAqWWlqq0r1lIoFBa3hRBlyu5mn+eeew6///47fvnll1qJ7U77RUdHS+UdOnRAr1690KxZM6xevRozZsyolfiIyLbYZUYkM2fOnAEAdO/eXSo7e/YsevbsiQ4dOlS4X010mTVs2BBKpbJMi0ZqamqZlo/q7vP888/jm2++wa5duxAUFFSjsVV3P1dXV3To0AHnzp2r8fiIqGYwISKSmczMTCiVSul2eno64uLioNVqK91v8uTJOHHiRKWXkklWVWg0GnTr1g3x8fEW5fHx8ejdu/dd7SOEwHPPPYfNmzdj586dCAsLq/HYqrtfYWEhzpw5g4CAgBqPj4hqiP3GcxNRdZw7d04AEG+99ZY4c+aMiIqKEl26dBGNGjUSiYmJNXa/Fc0yW79+vVCr1eKzzz4Tp0+fFtOnTxeurq5SLB9++KEYMGCAVfsIIcSUKVOEp6en2L17t0hOTpYueXl5VY65KvdTnfhefPFFsXv3bnHhwgVx8OBBcf/99wt3d3erz3914svOzhbHjx8Xx48fFwDE4sWLxfHjx8XFixfLHB+cZUZUZUyIiGTorbfeEj4+PkKn04mYmBhx/fp10bVrV9G8efMau8+KEiIhhFi2bJkIDQ0VGo1GdO3a1WJq/JtvvilCQ0Ot2kcI05d5eZeVK1cKIYRYuXKlqMr/dHe6n+rE9/DDD4uAgAChVqtFYGCgGD16tDh16pTF/jUV365du8o9LzExMWWOzYSIqOoUQghR681SRCQ7kZGR6Ny5M5YsWWLvUACYVovevXs3du/ebe9QyuUI8SkUCmzZsgUjR460WwxEcsExRERUZcuXL4ebm1u1VmW2tR9//BFxcXH2DqNC9oxv8uTJcHNzs8t9E8kVW4iIqEquXLmC/Px8AEBISAg0Go2dI6KKpKamIisrCwAQEBAAV1dXO0dE5PiYEBEREVG9xy4zIiIiqveYEBEREVG9x4SIiIiI6j0mRERERFTvMSEiIiKieo8JEREREdV7TIiIiIio3mNCRERERPUeEyIiIiKq95gQERERUb33/yeMxqYF0gjnAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "out_resolution = 20 # 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 = p2.SignedMeasure2Img( # This pipeline turns signed measures to signed measure convolutions\n",
    "    bandwidths=bandwidth, flatten=True,\n",
    "    resolution=out_resolution,\n",
    "    # filtration_grid=filtration_grid,\n",
    "    grid_strategy=\"exact\", n_jobs=4, 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 = apply_pipeline(pathes=sms, pipeline=pipeline_img) # This computes the convolution (or images)\n",
    "distances_to_letter, ytest = 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 : get_EF_vector_from_distances(distances_to_letter, ytest, alpha) # This function gets the Enrichment Factor from these distances\n",
    "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(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": 4,
   "id": "6484d4a0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Applying pipeline: 100%|██████████| 23/23 [01:24<00:00,  3.69s/it]\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\", p2.Molecule2SimplexTree(**filtrations)),\n",
    "\t\t(\"sm\", p2.SimplexTree2SignedMeasure(\n",
    "\t\t\tdegrees=degrees,_möbius_inversion = False, \n",
    "\t\t\tsparse=False, filtration_grid=filtration_grid,invariant=invariant, n_jobs=-1)),\n",
    "        (\"smf\", p2.SignedMeasureFormatter(flatten=True)),\n",
    "])\n",
    "pipeline_hilbert.fit(all_pathes)\n",
    "imgs_hilbert = apply_pipeline(pathes=pathes, pipeline=pipeline_hilbert)\n",
    "distances_to_letter, ytest = img_distances(imgs_hilbert)\n",
    "EF = lambda alpha : get_EF_vector_from_distances(distances_to_letter, ytest, alpha)\n",
    "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(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": 5,
   "id": "c6681c1c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ki01RERE9lIvQk1FOp0OGzZsQGFhIXr16oXz588jPT0dcXFxpm3UajViYmKwf//+Go9VWlqK/Px8s4c98DYJRERE9ldvQs3Jkyfh4eEBtVqNyZMnY8uWLWjXrp1pxuLAwECz7QMDA287m/HixYvh7e1teoSFhdms/opuTr7HlhoiIiJ7qTehpk2bNkhMTMTBgwfx1FNPYcKECTh9+rRpvUwmM9teCFFp2a1mz56NvLw80yMlJcUmtd/K2FLDeWqIiIjsRyF1AUYqlQotW7YEAHTr1g2HDx/G22+/jZkzZwIA0tPTERwcbNo+IyOjUuvNrdRqNdRqte2KrgbnqSEiIrK/etNScyshBEpLSxEREYGgoCDs3LnTtK6srAy7d+9G7969JaywehwoTEREZH/1oqXmxRdfxJAhQxAWFoaCggJs2LABCQkJ2L59O2QyGeLj47Fo0SK0atUKrVq1wqJFi+Dm5oZx48ZJXXqVNHJDt1hJRhaQkABERwM1TFhIREREd65ehJqrV6/i4YcfRlpaGry9vdGxY0ds377dNDPxjBkzUFxcjKeffhrXrl1Dz549sWPHDnh6ekpceRU2b4Z60fvAwGkoSbkC9BsOhIYCb78NjBoldXVEREROSyaEEFIXYS/5+fnw9vZGXl4evLy8rP8CmzcDDzyAY8GtMerhtxCam459H/4LMA5o/uorBhsiIiIL1fbz2+IxNcePH8f58+dNz7/44gv06dMHYWFhuPvuu7Fhw4a6VezodDpg6lRACGjKywAAJYobg5SNuTE+3rAdERERWZ3Foeaxxx7DhQsXAAD//e9/8cQTT6Bbt26YM2cOunfvjscffxyffvqpteus//buBS5fBgBotKUAgFKl6uZ6IYCUFMN2REREZHUWj6lJSkpCixYtAAAffPABli9fjieeeMK0vnv37njttdcwadIk61XpCNLSTN+6l5cAAAqVGughgwtEldsRERGR9VjcUuPq6orMzEwAwJUrV9CzZ0+z9T179jTrnmowKsyh06jIcDsGvYsceRqParcjIiIi67E41AwZMgQrVqwAAMTExOCrr74yW//ll1+aJtFrUKKjDVc5yWRQ6bXwKrkOAMh29zasl8mAsDDDdkRERGR1Fnc/LVmyBH369EFMTAy6deuGt956CwkJCWjbti2SkpJw8OBBbNmyxRa11m9yueGy7Qce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",
      "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 = p2.SignedMeasure2SlicedWassersteinDistance(num_directions=100, _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 : get_EF_vector_from_distances(distances=distances, ytest = ytest, alpha = alpha)\n",
    "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(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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
