{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 81,
   "id": "f8fa244b-ddad-415b-bd60-b1d7c6a47076",
   "metadata": {},
   "outputs": [],
   "source": [
    "import multipers as mp\n",
    "from multipers.data.UCR import get as get_UCR\n",
    "from multipers.ml.point_clouds import PointCloud2SimplexTree\n",
    "import multipers.ml.mma as mmm\n",
    "from random import choice\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import multipers.ml.signed_measures as mms\n",
    "mp.simplex_tree_multi.SAFE_CONVERSION=True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "id": "c66a7da1-c856-4dc8-a5ce-cf54e532f020",
   "metadata": {},
   "outputs": [],
   "source": [
    "x,y = get_UCR(\"UCR/ProximalPhalanxTW\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "1f08d9fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.neighbors import KernelDensity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "id": "813ae54a-1788-4990-aa81-c8829d245efe",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Estimating scale...Done. Chosen scales [0.1, 0.2] are [0.53106151 1.        ]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Filling simplextrees: 100%|███████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 400/400 [00:03<00:00, 124.04it/s]\n"
     ]
    }
   ],
   "source": [
    "tost = PointCloud2SimplexTree(complex='alpha', masses=[.1], bandwidths=[-.1, -.2], n_jobs=4,num_collapses=0, progress=True, threshold=1.0)\n",
    "sts = tost.fit_transform(x)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "id": "5698d39c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[[array([ 0.        , -4.08508396]), array([ 0.9998945 , -2.42806983])],\n",
       " [array([ 0.        , -3.70358133]), array([ 0.9998945 , -2.80370879])],\n",
       " [array([0., 0.]), array([0.9998945 , 0.66991115])]]"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mmm.SimplexTree2MMA(nlines=1000, prune_degrees_above=None, progress=False, n_jobs=1).fit(sts)._boxes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "084b451e-5c95-421f-882c-5e04c07779c9",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Computing modules: 100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 400/400 [00:01<00:00, 289.22it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-----------MMAFormatter-----------\n",
      "---- Infered stats\n",
      "Found axis : True, num : 3\n",
      "Number of parameters : None\n",
      "---- Bounds (only computed if normalize):\n",
      "(axis) x (degree) x (parameter)\n",
      "-- Lower bound :  (3, 1, 2)\n",
      "[[[ 0.         -4.08508396]]\n",
      "\n",
      " [[ 0.         -3.70358133]]\n",
      "\n",
      " [[ 0.          0.        ]]]\n",
      "-- Upper bound : (3, 1, 2)\n",
      "[[[ 0.02217722 -2.88409615]]\n",
      "\n",
      " [[ 0.03642344 -3.15895629]]\n",
      "\n",
      " [[ 0.03831106  0.49972597]]]\n",
      "-- Normalization factors: (3, 1, 2)\n",
      "[[[45.09131566  0.83264791]]\n",
      "\n",
      " [[27.45484418  1.83612563]]\n",
      "\n",
      " [[26.1021201   2.00109673]]]\n",
      "---- Module size :\n",
      "- Axis 0\n",
      " - Degree 0 size 65.37±13.46\n",
      "- Axis 1\n",
      " - Degree 0 size 65.37±13.46\n",
      "- Axis 2\n",
      " - Degree 0 size 65.38±13.47\n",
      "----------------------------------\n",
      "Normalizing...Done.\n"
     ]
    }
   ],
   "source": [
    "modules = mmm.SimplexTree2MMA(nlines=1000, prune_degrees_above=1, progress=True, n_jobs=16).fit_transform(sts)\n",
    "normalizer = mmm.MMAFormatter(normalize=True, degrees=[0], quantiles=[0,0], axis=-1, verbose=True).fit(modules)\n",
    "normalized_modules = normalizer.transform(modules)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "id": "3045b66a-ea8d-4ee6-b6a8-5bf5661c7500",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAqsAAAF2CAYAAABJU9GdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAA0hklEQVR4nO3de3xU1b3///ckM5lcIKkkQIIJF1EIVFALFaFpId7IT3sQKCLiCVLQSpGj0ocoaJXQoqkWrYKi1mPxFg9qBcVTq6ElcrRIMVz6q2Kj3OQSIyA6CbfJbX3/oIkMmSQzgZlZTF7Px2M/zOxZe+azkvjhPTtr9jiMMUYAAACAhWIiXQAAAADQHMIqAAAArEVYBQAAgLUIqwAAALAWYRUAAADWIqwCAADAWoRVAAAAWIuwCgAAAGsRVgEAAGAtwioAAACsRVgFAACAtQir7dhbb70lh8Oh559/3u/948ePV2Jiourq6tr0+KtWrdKUKVOUnZ2tpKQknXnmmbrqqqu0fv36kyk7op599lk5HA7t2LEj4GPWrFmjgoICffPNNyGrC0Dk0EuDRy9FMAir7diGDRskSd/73veavX/gwIGKjY1t0+M/8cQT2rFjh2699Va99dZbevTRR7V3715ddNFFWrVqVZvrjqQrr7xSH3zwgTIyMgI+Zs2aNZo3bx4NFohS9NLg0UsRDGekC0DkbNiwQQkJCerXr1+T+zwej7Zt26aRI0e2+fEff/xxdenSxWdfXl6ezj77bN1///26+OKL2/zYp9rhw4eVmJjY6rjOnTurc+fOYagIwOmCXvoteilCgTOr7dj69eubfbW/ceNGGWOaPVMQiBObqyR16NBB/fv3165duwJ6jIKCAjkcDm3cuFFjx45VcnKyUlJS9J//+Z/at2+fz9jPPvtMEydOVJcuXeR2u9WvXz89/vjjzT7mhg0bNG7cOJ1xxhnq3bu3JGnfvn362c9+pqysLLndbnXu3Fk/+MEP9Je//EWS/z9dtXRMQUGBZs2aJUnq1auXHA6HHA6H3n333aDqbqj5448/1rXXXquUlBR17dpVU6ZMkcfjaTLHf/3rX7r22mvVtWtXud1ude/eXZMmTZLX6w36+wWgZfRSeim9NLQ4s9pOffXVV9q5c6cuueQSv39S+eCDDyQ1/2ettvJ4PNqwYUPQZwLGjBmj8ePHa9q0afr44491zz33aPPmzfr73/8ul8ulzZs3a9iwYerevbseeughpaen65133tEtt9yi/fv3a+7cuU0ec+zYsZowYYKmTZumQ4cOSZLy8/O1YcMG3XffferTp4+++eYbbdiwQV999VWztbV0zA033KADBw5o0aJFWrZsWeOfvPr37y9JQdf9k5/8RNdcc42mTp2qf/7zn5ozZ44k6Q9/+EPjmH/84x/KyclRWlqafvWrX+mcc87RF198oRUrVqi6ulput7tN3y8ATdFL6aX00jAwaJeKi4uNpBa3uLg4U11dbYwxZu/eveaKK64wiYmJ5pxzzjHFxcVtet7rrrvOOJ1OU1paGtD4uXPnGklm5syZPvuLioqMJPPiiy8aY4wZOXKkyczMNB6Px2fcjBkzTHx8vDlw4ECTx7z33nubPF+HDh3Mbbfd1mw9S5YsMZLM9u3bAz7mt7/9bZNjGgRad0PNDz74oM+46dOnm/j4eFNfX9+47+KLLzbf+c53zN69e5utKZjvF4DmBdtLFy9ebC644ALjdDrN3Llz2/y89FJf9NLoxjKAdqrhXaTPPfecSkpKmmzp6ekaMGCAXC6XJOnmm29Wenq69u3bpwULFmj8+PEtvkL255577lFRUZF+97vfadCgQT731dbW+mzGGJ/7r7vuOp/b48ePl9PpVElJiY4ePaq//vWvGjNmjBITE30e54orrtDRo0e1du3aJvX85Cc/abLvwgsv1LPPPqv58+dr7dq1qqmpaXVebTlGUpvqHjVqlM/tgQMH6ujRo9q7d6+kY+vFVq9erfHjxze7Hqyt3y8ATQXbSzMyMjRv3jyNHj26zc9JL/VFL20HIp2WERlXX321iY+PNzU1NU3uq6ysNA6Hw9x4443GGGOqqqqMy+UyO3fubBwzfPhw88wzzwT8fAUFBUaSue+++5rct3379iZnIkpKSowx374K3r17d5PjunbtakaPHm12797d6pmN559/vvG4hsf092p537595tZbbzU9evQwkkyHDh1Mfn6++eKLL4wx/s8GtHZMc2cDgqm7oeZ9+/b5PMaJ9TQ85q9+9atmfxbBfr8ANC+YXnq8qVOntunMKr2UXtoesWa1nWq4lIrT2fRXoOENAQ2v2D/77DN16NBBWVlZjWMGDBigjz/+OKDnmjdvngoKClRQUKC77rqryf3dunXThx9+6LOvb9++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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "module.plot()\n",
    "module_copy = module.get_module_of_degrees([0,1])\n",
    "# module_copy.rescale([5,1])\n",
    "module_copy.translate([-0.1,-0.1])\n",
    "module_copy.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "e492ef32",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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/H6/HnvsMZ199tl6//33df3116uiokILFy5sst/27duVn5+v6dOna8GCBcrMzNSHH36olJSUaIUKAFYijwJAFIvVgoICFRQUNDw+66yzVFJSomXLljWbZG+//XZddtlluv/++wP6AkBbQx4FgBivWfV6vTrzzDObfN7v9+uvf/2r+vTpo1GjRqlTp04aMmSIXnjhhSb7VFVVqby8PGADgEQVjTwqkUsB2Ctmxer27du1ePFizZgxo8k2+/fv15EjR3TvvfeqoKBAxcXFGjt2rMaNG6e1a9cG7VNUVKTMzMyGLTc3N1pDAIC4ilYelcilAOwVdrFaWFgoh8PR7LZx48aAPqWlpSooKNCVV16p6667rslj+/1+SdIVV1yh2bNn6/zzz9fcuXP1wx/+UI8++mjQPvPmzZPX623Y9uzZE+6QACCmbMujErkUgL3CXrM6a9YsTZw4sdk2PXv2bPi6tLRUI0eO1NChQ/Xb3/622X5ZWVlyuVzq379/wP5+/frprbfeCtrH4/HI4/GEFjwAWMC2PCqRSwHYK+xiNSsrS1lZWSG13bdvn0aOHKlBgwbp8ccfV1JS8xO5ycnJ+va3v62SkpKA/R999JF69OgRbqgAYCXyKACELmprVktLSzVixAjl5uZq4cKFOnDggMrKylRWVhbQLi8vT6tWrWp4PGfOHD377LP63e9+p08++URLlizRSy+9pJkzZ0YrVACwEnkUAKJ46ari4mJ98skn+uSTT5STkxPwnDGm4euSkhJ5vd6Gx2PHjtWjjz6qoqIi3Xjjjerbt6+ef/555efnRytUALASeRQAolisTp06VVOnTm2x3YkJt960adM0bdq0KEQFAKcP8igAxPg6qwAAAEA4KFYBAABgLYpVAAAAWItiFQAAANaiWAUAAIC1KFYBAABgLYpVAAAAWItiFQAAANaiWAUAAIC1KFYBAABgLYpVAAAAWItiFQAAANaiWAUAAIC1KFYBAABgLYpVAAAAWItiFQAAANaiWAUAAIC1KFYBAABgLYpVAAAAWItiFQAAANaiWAUAAIC1KFYBAABgLYpVAAAAWItiFQAAANaiWAUAAIC1KFYBAABgragVq7t27dL06dPVq1cvpaamqnfv3po/f76qq6ub7XfkyBHNmjVLOTk5Sk1NVb9+/bRs2bJohQkA1iKPAoDkitaB//3vf8vv9+ux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",
      "text/plain": [
       "<Figure size 800x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "k = choice(range(len(modules)))\n",
    "module = modules[k][0]\n",
    "nmodule = normalized_modules[k][0] \n",
    "module.plot(alpha = .5); nmodule.plot(alpha=.5, box=[[0,0], [1.5,1.1]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8c7e6ea-6736-46cb-b05a-4df8de03fdb6",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "0708724d-926a-4abd-bd2e-2b820a14613d",
   "metadata": {},
   "outputs": [],
   "source": [
    "params = {'degrees': [0, 1], 'rank_degrees': [], 'progress': True, 'n_jobs': 8, 'filtration_quantile': 0.01, 'resolution': [100, 100], '_möbius_inversion': True, 'normalize_filtrations': False, 'fit_fraction': 1, 'expand': False, 'grid_strategy': 'exact', 'enforce_null_mass': False, 'individual_grid': True}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "810799e5-b922-4931-ac84-704370174477",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Computing Signed Measures from simplextrees.: 100%|██████████| 400/400 [00:00<00:00, 918.42it/s]\n"
     ]
    }
   ],
   "source": [
    "mms.SimplexTrees2SignedMeasures(**params).fit_transform(sts);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fc4621e4-5f5b-4844-a045-9a9830d6f328",
   "metadata": {},
   "outputs": [
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mCannot execute code, session has been disposed. Please try restarting the Kernel."
     ]
    },
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mThe Kernel crashed while executing code in the the current cell or a previous cell. Please review the code in the cell(s) to identify a possible cause of the failure. Click <a href='https://aka.ms/vscodeJupyterKernelCrash'>here</a> for more info. View Jupyter <a href='command:jupyter.viewOutput'>log</a> for further details."
     ]
    }
   ],
   "source": [
    "num=1\n",
    "stuff = choice(normalized_modules)[0]\n",
    "stuff.barcodes(degree=0, num=100, threshold=True).plot()\n",
    "stuff.get_module_of_degree(1).barcodes(degree=-1, num=100, threshold=True).plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76c83446-0a1f-4a0d-a527-40c31b5ff987",
   "metadata": {},
   "outputs": [],
   "source": [
    "stuff.plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2fd91e9d-3aa6-40e8-90df-cb5afd029711",
   "metadata": {},
   "outputs": [],
   "source": [
    "k = choice(range(len(modules)))\n",
    "modules[k][0].plot(alpha=.8)\n",
    "normalized_modules[k][0].plot(alpha=.8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "28aa9d50-bf67-4da1-9572-fdb11f4c8c4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import multipers as mp\n",
    "st = mp.SimplexTreeMulti()\n",
    "st.insert([0],[0,0])\n",
    "st.insert([1],[0,0])\n",
    "st.insert([2],[0,0])\n",
    "st.insert([0,1],[1,0])\n",
    "st.insert([0,2],[0,1])\n",
    "mod = st.persistence_approximation(box=[[0,0],[2,2]])\n",
    "# mod.plot(alpha=.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8a6787f3-8a8d-4bdc-a251-c3f42e450021",
   "metadata": {},
   "outputs": [],
   "source": [
    "mod.barcodes(basepoints=[[0,0]], degree=0, threshold=1).plot()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58c48a2c-b325-40e3-bf6b-b2393e160bb4",
   "metadata": {},
   "outputs": [],
   "source": [
    "stuff.get_module_of_degree(1).barcode(degree=-1, basepoint=[0.5,0.5], threshold=True).get_points()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "85509439-76fb-41a3-ae76-7ecce6c6d6dd",
   "metadata": {},
   "outputs": [],
   "source": [
    "stuff.get_module_of_degree(1).barcode(degree=-1, basepoint=[0.5,0.5]).get_points()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "14d24d30",
   "metadata": {},
   "outputs": [],
   "source": [
    "stuff.landscapes(degree=1);"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee57685b",
   "metadata": {},
   "outputs": [],
   "source": [
    "dim = 0 #choice(range(stuff.max_degree+1))\n",
    "dmp = stuff.dump()\n",
    "summand_idx = choice(range(len(dmp[dim])))\n",
    "stuff[summand_idx].get_birth_list()\n",
    "dmp[dim][summand_idx]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a836dfb3",
   "metadata": {},
   "outputs": [],
   "source": [
    "d = stuff.dump()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "03132c2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "d[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9f35b8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "mp.from_dump(d)[0].get_death_list()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "680c7666",
   "metadata": {},
   "outputs": [],
   "source": [
    "stuff.get_filtration_values()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "07890124",
   "metadata": {},
   "outputs": [],
   "source": [
    "_mods[k][0].plot(alpha=.8)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "95dd250b",
   "metadata": {},
   "outputs": [],
   "source": [
    "normalized_modules[0][0].barcodes(box=[[0,0],[1,1]],degree=1,num=100).to_multipers()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "68a145ea-7124-4863-bc4e-4f8c3476a981",
   "metadata": {},
   "outputs": [],
   "source": [
    "imgs = mmm.MMA2IMG(degrees=[0,1], flatten=False, resolution=200, bandwidth=.001).fit_transform(normalized_modules)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "71f898e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "cw = matplotlib.colormaps[\"coolwarm\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "056ac922",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(cw(np.linspace(0,1,100)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3b99eafa",
   "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
}
