{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "c8ef9e26-9f58-43ce-8800-9a679ba67eaf",
   "metadata": {},
   "outputs": [],
   "source": [
    "import multipers as mp\n",
    "from multipers.data.UCR import get\n",
    "from multipers.ml.kernels import DistanceMatrix2Kernel\n",
    "from multipers.ml.point_clouds import PointCloud2SimplexTree\n",
    "import multipers.ml.signed_measures as mms\n",
    "from sklearn.pipeline import Pipeline\n",
    "from sklearn.svm import  SVC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "1306b26c-e387-4313-b8b6-921cc10691d1",
   "metadata": {},
   "outputs": [],
   "source": [
    "STs = PointCloud2SimplexTree(complex='rips', kernel=\"gaussian\",num_collapses='full', bandwidths=[-.1], threshold=-.5, progress=1)\n",
    "SMs = mms.SimplexTrees2SignedMeasures(individual_grid=True, enforce_null_mass=False, grid_strategy=\"regular_closest\", resolution=50, n_jobs=-1, degrees=[0,1], progress=1, expand=True)\n",
    "SMF = mms.SignedMeasureFormatter(normalize=True, plot=False, axis=0, verbose=True)\n",
    "SMD = mms.SignedMeasure2SlicedWassersteinDistance(n_jobs=-1, )\n",
    "todo = Pipeline([\n",
    "\t('sts', STs),\n",
    "\t('sms', SMs),\n",
    "\t('norm', SMF),\n",
    "\t('ds', SMD),\n",
    "\t('kernel', DistanceMatrix2Kernel(sigma=1.)),\n",
    "\t('svm', SVC()),\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b02f774f-bb9c-4ec9-8489-d0021ca58e1b",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = \"UCR/Coffee\"\n",
    "xtrain,ytrain = get(dataset,test=False)\n",
    "xtest,ytest = get(dataset,test=True)\n",
    "# todo.fit(xtrain,ytrain).score(xtest,ytest)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "12ad5cb2-6d7d-4abe-aa1f-4ae085e86466",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Estimating scale...Done. Chosen scales [0.1, 0.5] are [0.63974773 3.19873863]\n",
      "[KeOps] Warning : Cuda libraries were not detected on the system or could not be loaded ; using cpu only mode\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Computing codensities: 100%|██████████████████████████████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 1275.45it/s]\n",
      "Computing simplextrees:  50%|█████████████████████████████████████████████████▌                                                 | 1/2 [00:00<00:00,  5.41it/s]\n"
     ]
    }
   ],
   "source": [
    "sts = STs.fit_transform(xtrain[:2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "cce28100-616a-4e49-9588-83d0ef28ce62",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "866"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "st = sts[0][0]\n",
    "st.num_simplices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a20f4d32-871c-4716-ad64-78c8ff02e226",
   "metadata": {},
   "outputs": [],
   "source": [
    "mp.signed_measure(st, degree=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c459ed95-b0c4-4e1b-a501-d740ee529285",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Computing Signed Measures from simplextrees.: 100%|███████████████████████████████████████████████████████████████████████████| 2/2 [00:00<00:00, 5102.56it/s]\n"
     ]
    }
   ],
   "source": [
    "sms = SMs.fit_transform(sts)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b4065ea2-4900-458a-adcc-288cf3a6dbf4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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smW67bbb9Ic//EFXXXVVJMuMmlD3R2VlpTZu3KgtW7ZoypQpkuobjjFGLpdLZWVluvLKK6NSeySE8/2RnZ2tbt26KSMjI7Cud+/eMsZoz5496tWrV0RrjpRw9kVpaakuv/xyTZ8+XZLUr18/dezYUd/73vdUUlJi2xlGiV56MvpoMPpoMPposFj1UtvOuCYlJemSSy7R6tWrg9avXr1agwYNanKbyy67rNH4srIyFRQUyO12R6zWaAhnf0j1MwQTJ07UCy+80C6O12sQ6v5IT0/X3/72N23dujWwFBYW6vzzz9fWrVs1YMCAaJUeEeF8f1x++eXau3evjh49Gli3Y8cOORwO5eTkRLTeSApnXxw/flwOR3C7dDqdkk7MNNoVvfQE+mgw+mgw+miwmPXSVp/GFYcaLsPw9NNPm23btpm7777bdOzY0Xz++efGGGNmzpxpJkyYEBjfcAmXadOmmW3btpmnn3663VzCxZjQ98cLL7xgXC6XeeKJJ8xXX30VWL7++utYfQltKtT9car2djZsqPujsrLS5OTkmOuvv9589NFHZu3ataZXr17m9ttvj9WX0GZC3RfPPPOMcblcZtGiRebTTz817777rikoKDCXXnpprL6ENkUvPYE+Gow+Gow+GiwWvdTWwdUYY5544gnTo0cPk5SUZC6++GKzdu3awHO33HKLGTJkSND4t99+21x00UUmKSnJ5OXlmSeffDLKFUdWKPtjyJAhRlKj5ZZbbol+4RES6vfHydpbwzUm9P3x8ccfm6uuusokJyebnJwcc88995jjx49HuerICHVfLFiwwPTp08ckJyeb7OxsM378eLNnz54oVx059NIT6KPB6KPB6KPBot1LLWNs/jkXAAAAEoJtj3EFAABAYiG4AgAAwBYIrgAAALAFgisAAABsgeAKAAAAWyC4AgAAwBYIrgAAALAFgisAAABsgeAKAAAAWyC4AgAAwBYIrgAAALAFgisAAABs4f8DwpayAiw3yeAAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "st = sts[0][0]\n",
    "st.persistence_approximation().plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "29408c80-7983-4f8c-9ab8-ab5c3f065503",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<multipers.simplex_tree_multi.SimplexTreeMulti at 0x2809f1fb0>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "st.expansion(2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91dd7270-95c0-4948-9933-958d771ede13",
   "metadata": {},
   "outputs": [],
   "source": [
    "sms = todo.fit(xtrain,ytrain).score(xtest,ytest)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "88cf7bf9-f406-4adf-b17c-c53b9c6db5ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "from multipers.plots import plot_signed_measures\n",
    "from random import choice\n",
    "k = choice(range(len(sms)))\n",
    "axis = choice(range(2))\n",
    "sm = sms[k][axis] ## choice sm \n",
    "sms_norm = mms.SignedMeasureFormatter(normalize=True, plot=False, axis=-1, verbose=False).fit_transform(sms)\n",
    "sm_norm = sms_norm[k][axis] ## choice sm \n",
    "plot_signed_measures([*sm, *sm_norm], size=3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5500ea3d-d02d-4eb0-9228-a7c81b8c0848",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "893145e5-562c-4b55-9e46-5086d2b473ad",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "id": "e7c9bc61-bdcb-448b-8d2d-6510ef349efe",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "id": "d78d1867-f3f6-4a52-ac29-7be003dd13de",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[33mDEPRECATION: Loading egg at /Users/dloiseau/micromamba/envs/python/lib/python3.11/site-packages/gudhi-3.9.0a1-py3.11-macosx-11.0-arm64.egg is deprecated. pip 23.3 will enforce this behaviour change. A possible replacement is to use pip for package installation..\u001b[0m\u001b[33m\n",
      "\u001b[0mProcessing /Users/dloiseau/Documents/MMA/multipers_diff\n",
      "  Preparing metadata (setup.py) ... \u001b[?25ldone\n",
      "\u001b[?25hBuilding wheels for collected packages: multipers\n",
      "  Building wheel for multipers (setup.py) ... \u001b[?25ldone\n",
      "\u001b[?25h  Created wheel for multipers: filename=multipers-0.0.0-cp311-cp311-macosx_11_0_arm64.whl size=1547365 sha256=184961ffa33890e2f593238c1111494c060d5ad3f6e334b99d8a16add96c44cf\n",
      "  Stored in directory: /private/var/folders/qq/wykj3rzn6r7_07fh4q0j9frh0000gp/T/pip-ephem-wheel-cache-0w4i8zmu/wheels/82/62/9f/332f0ac92a95eaf06d4ed464836e0698139664ce2851a6c2bc\n",
      "Successfully built multipers\n",
      "Installing collected packages: multipers\n",
      "  Attempting uninstall: multipers\n",
      "    Found existing installation: multipers 0.0.0\n",
      "    Uninstalling multipers-0.0.0:\n",
      "      Successfully uninstalled multipers-0.0.0\n",
      "Successfully installed multipers-0.0.0\n"
     ]
    }
   ],
   "source": [
    "!pip install .."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "7f04a49b-6fd9-41f4-ac7e-99b6e31f68cc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading core dependencies...Done.\n",
      "Getting dataset\n",
      "Classes : [0 1]\n",
      "------------- SimplexTree 2 Signed Measure parameters\n",
      "{'degrees': [0, 1], 'rank_degrees': [], 'progress': True, 'n_jobs': 1, 'filtration_quantile': 0.01, 'resolution': [100, 100], 'individual_grid': True, '_möbius_inversion': True, 'normalize_filtrations': False, 'fit_fraction': 1, 'expand': True, 'grid_strategy': 'exact', 'enforce_null_mass': True}\n",
      "------------- \n",
      "Number of axis : bandwidths (5) x num_scales (1) = 5\n",
      "Num parameters 2\n",
      "Num bandwidths 5\n",
      "Transformers :  PointCloud2SimplexTree() PointCloud2SimplexTree(bandwidths=[-0.001, -0.01, -0.1, -0.2, -0.3],\n",
      "                       kernel='gaussian', n_jobs=1, progress=True) SimplexTrees2SignedMeasures() SignedMeasures2SlicedWassersteinDistances(progress=True)\n",
      "Initializing diagrams pipeline\n",
      "Arguments Namespace(dataset='UCR/Coffee', pipeline='smk', final_classifier='rf', filtration='', filtrations=[], train_k=10, test_k=0.5, diagram_threshold=inf, num_samples=-1, num_pts=0, in_resolution=100, in_strategy='exact', out_strategy=None, out_resolution=100, num_directions=20, complex='rips', kernel='gaussian', drop_quantile=0.01, num_rescales=1, rips_threshold=inf, normalize_filtrations=True, sparse_rips=None, extended=False, geodesic_backend='torch_geometric', seed=0, test=False, degrees=[0, 1], rank_degrees=[], n_jobs=1, self_test=False, grid_shape=[100, 100])\n",
      "Initializing pipeline\n",
      "------------smk pipeline\n",
      "Estimating scale...Done. Chosen scales [0.001, 0.01, 0.1, 0.2, 0.3] are [0.00694445 0.06944447 0.69444469 1.38888939 2.08333408]\n",
      "[KeOps] Warning : Cuda libraries were not detected on the system or could not be loaded ; using cpu only mode\n",
      "Computing codensities: 100%|███████████████████| 56/56 [00:00<00:00, 785.35it/s]\n",
      "Computing simplextrees:  98%|██████████████████▋| 55/56 [00:37<00:00,  1.47it/s]\n",
      "Computing Signed Measures from simplextrees.: 100%|█| 56/56 [00:02<00:00, 20.27i\n",
      "------------SignedMeasureFormatter------------\n",
      "---- Parameters\n",
      "Sparse input : True\n",
      "Number of axis : 5\n",
      "Number of degrees : 2\n",
      "Filtration bounds : \n",
      "[array([[[ 0.        , -6.80361366],\n",
      "        [ 5.09865189, -4.96981287]],\n",
      "\n",
      "       [[ 0.00980021, -6.1139946 ],\n",
      "        [ 0.61393297, -4.96981287]]]), array([[[ 0.        , -5.92834234],\n",
      "        [ 5.09865189, -4.96981287]],\n",
      "\n",
      "       [[ 0.00980021, -5.86450291],\n",
      "        [ 0.61393297, -4.96981287]]]), array([[[ 0.        , -5.24491692],\n",
      "        [ 5.09865189, -4.96981287]],\n",
      "\n",
      "       [[ 0.00980021, -5.24361229],\n",
      "        [ 0.61393297, -4.96981287]]]), array([[[ 0.        , -4.96981287],\n",
      "        [ 5.09865189, -4.96981287]],\n",
      "\n",
      "       [[ 0.00980021, -4.96981287],\n",
      "        [ 0.61393297, -4.96981287]]]), array([[[ 0.        , -4.96981287],\n",
      "        [ 5.09865189, -4.96981287]],\n",
      "\n",
      "       [[ 0.00980021, -4.96981287],\n",
      "        [ 0.61393297, -4.96981287]]])]\n",
      "Normalization factor : \n",
      "[array([[5.09865189, 1.83380079],\n",
      "       [0.60413276, 1.14418173]]), array([[5.09865189, 0.95852947],\n",
      "       [0.60413276, 0.89469004]]), array([[5.09865189, 0.27510405],\n",
      "       [0.60413276, 0.27379942]]), array([[5.09865189, 1.        ],\n",
      "       [0.60413276, 1.        ]]), array([[5.09865189, 1.        ],\n",
      "       [0.60413276, 1.        ]])]\n",
      "---- SM stats\n",
      "In axis : 5\n",
      "Size means (axis) x (degree): [[863.26785714 185.19642857]\n",
      " [726.33928571 170.92857143]\n",
      " [713.48214286 188.5       ]\n",
      " [570.         164.39285714]\n",
      " [570.         164.39285714]]\n",
      "Size std : [[30.15406338 22.58113913]\n",
      " [33.97597722 20.35651628]\n",
      " [27.09440577 21.17022842]\n",
      " [ 0.         19.30366228]\n",
      " [ 0.         19.30366228]]\n",
      "----------------------------------------------\n",
      "New axes :  [(0, None), (1, None), (2, None), (3, None), (4, None)]\n",
      "Computing distances matrices of axis, and scales: 100%|█| 5/5 [00:04<00:00,  1.1\n",
      "Num axes of computed measure : 5\n",
      "Initializing classification pipeline\n",
      "Computing classification, with pipeline\n",
      "Pipeline(steps=[('DL2D', DistancesLists2DistanceMatrices()),\n",
      "                ('DM2K', DistanceMatrix2Kernel()),\n",
      "                ('SVMP', SVC(kernel='precomputed'))])\n",
      "Final parameters :  {'DM2K__sigma': [0.001, 0.01, 1, 10, 100, 1000], 'DM2K__axis': [0, 1, 2, 3, 4], 'DM2K__weights': [array([ 0.1, 10. ]), array([ 1., 10.]), array([10. ,  0.1]), array([1. , 0.1]), array([1., 1.])], 'SVMP__kernel': ['precomputed'], 'SVMP__C': [0.001, 0.01, 1, 10, 100, 1000]}\n",
      "------------ Running 10 times small fit... \n",
      "Parameters {'DM2K__sigma': 1, 'DM2K__axis': 3, 'DM2K__weights': array([ 0.1, 10. ]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 1000}\n",
      "Parameters {'DM2K__sigma': 1, 'DM2K__axis': 1, 'DM2K__weights': array([1., 1.]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 1000}\n",
      "Parameters {'DM2K__sigma': 1, 'DM2K__axis': 2, 'DM2K__weights': array([ 0.1, 10. ]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 1}\n",
      "Parameters {'DM2K__sigma': 0.01, 'DM2K__axis': 4, 'DM2K__weights': array([1., 1.]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 0.001}\n",
      "Parameters {'DM2K__sigma': 1000, 'DM2K__axis': 0, 'DM2K__weights': array([10. ,  0.1]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 10}\n",
      "Parameters {'DM2K__sigma': 0.01, 'DM2K__axis': 0, 'DM2K__weights': array([ 0.1, 10. ]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 1}\n",
      "Parameters {'DM2K__sigma': 0.001, 'DM2K__axis': 2, 'DM2K__weights': array([10. ,  0.1]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 100}\n",
      "Parameters {'DM2K__sigma': 100, 'DM2K__axis': 3, 'DM2K__weights': array([10. ,  0.1]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 100}\n",
      "Parameters {'DM2K__sigma': 0.01, 'DM2K__axis': 0, 'DM2K__weights': array([1. , 0.1]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 10}\n",
      "Parameters {'DM2K__sigma': 1, 'DM2K__axis': 3, 'DM2K__weights': array([ 0.1, 10. ]), 'SVMP__kernel': 'precomputed', 'SVMP__C': 10}\n",
      "------------ Done.\n",
      "Computing accuracy, with train test split\n",
      "Fitting...Fitting 10 folds for each of 900 candidates, totalling 9000 fits\n",
      "Computing score...Best classification parameters :  {'DM2K__axis': 0, 'DM2K__sigma': 1, 'DM2K__weights': array([ 1., 10.]), 'SVMP__C': 10, 'SVMP__kernel': 'precomputed'}\n",
      "Done.\n",
      "Accuracy UCR/Coffee : 0.6785714285714286 \n"
     ]
    }
   ],
   "source": [
    "!python ../compute.py --dataset UCR/Coffee --pipeline smk --degrees 0 --degrees 1  --complex rips --kernel gaussian --n_jobs=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "70efe411-f617-445d-86ca-e719cb8fe016",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
