{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Simulation Study"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "os.environ['KMP_WARNINGS'] = 'off'\n",
    "\n",
    "import sys\n",
    "import warnings\n",
    "\n",
    "if not sys.warnoptions:\n",
    "    warnings.simplefilter(\"ignore\")\n",
    "    os.environ[\"PYTHONWARNINGS\"] = \"ignore\" # Also affect subprocesses"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.insert(0, './Trees')\n",
    "\n",
    "import numpy as np\n",
    "from scipy.interpolate import interp1d as spline\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "import ripser as rip\n",
    "\n",
    "from Utils_dendrograms_OPT import dendrolink\n",
    "\n",
    "from sklearn.metrics import confusion_matrix\n",
    "\n",
    "import ripser as rip\n",
    "import persim\n",
    "from gudhi.wasserstein import wasserstein_distance\n",
    "\n",
    "from persistence_spheres_utils import from_DGMS_to_H, make_weighting, make_dV\n",
    "\n",
    "from persim import PersistenceImager, PersLandscapeApprox, sliced_wasserstein\n",
    "\n",
    "from pers_splines import make_PersSplines_vec\n",
    "\n",
    "from scipy.spatial.distance import squareform, pdist\n",
    "from scipy import sparse\n",
    "\n",
    "from itertools import product\n",
    "\n",
    "import oineus as oin"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "\n",
      " Iteration:  0\n",
      "Wass:   [0.51 0.49 0.54]\n",
      "SWass:  [0.52 0.5  0.5 ]\n",
      "PS:     [0.92 0.84 0.67]\n",
      "PL:     [0.53 0.52 0.52]\n",
      "PI:     [0.82 0.65 0.55]\n",
      "PSpl:   [0.53 0.52 0.54]\n",
      "\n",
      "\n",
      " Iteration:  1\n",
      "Wass:   [0.755 0.74  0.735]\n",
      "SWass:  [0.745 0.725 0.51 ]\n",
      "PS:     [0.955 0.905 0.795]\n",
      "PL:     [0.755 0.52  0.51 ]\n",
      "PI:     [0.69  0.605 0.55 ]\n",
      "PSpl:   [0.525 0.515 0.535]\n",
      "\n",
      "\n",
      " Iteration:  2\n",
      "Wass:   [0.83666667 0.81666667 0.77666667]\n",
      "SWass:  [0.66333333 0.65333333 0.55333333]\n",
      "PS:     [0.96333333 0.91       0.80666667]\n",
      "PL:     [0.83       0.65333333 0.56      ]\n",
      "PI:     [0.77333333 0.7        0.61      ]\n",
      "PSpl:   [0.54       0.51666667 0.53333333]\n",
      "\n",
      "\n",
      " Iteration:  3\n",
      "Wass:   [0.755  0.74   0.7075]\n",
      "SWass:  [0.6225 0.6175 0.54  ]\n",
      "PS:     [0.855  0.8725 0.74  ]\n",
      "PL:     [0.8725 0.73   0.545 ]\n",
      "PI:     [0.7425 0.695  0.59  ]\n",
      "PSpl:   [0.5525 0.5275 0.5275]\n",
      "\n",
      "\n",
      " Iteration:  4\n",
      "Wass:   [0.706 0.7   0.67 ]\n",
      "SWass:  [0.602 0.636 0.536]\n",
      "PS:     [0.84  0.856 0.7  ]\n",
      "PL:     [0.864 0.716 0.542]\n",
      "PI:     [0.766 0.716 0.584]\n",
      "PSpl:   [0.558 0.528 0.524]\n",
      "\n",
      "\n",
      " Iteration:  5\n",
      "Wass:   [0.75166667 0.74666667 0.64166667]\n",
      "SWass:  [0.66 0.66 0.53]\n",
      "PS:     [0.86666667 0.87833333 0.67833333]\n",
      "PL:     [0.885      0.68166667 0.53666667]\n",
      "PI:     [0.78833333 0.715      0.57166667]\n",
      "PSpl:   [0.55166667 0.53666667 0.52166667]\n",
      "\n",
      "\n",
      " Iteration:  6\n",
      "Wass:   [0.72       0.77       0.62142857]\n",
      "SWass:  [0.70285714 0.69571429 0.52857143]\n",
      "PS:     [0.88142857 0.89       0.65285714]\n",
      "PL:     [0.89857143 0.72       0.53142857]\n",
      "PI:     [0.81571429 0.75       0.57428571]\n",
      "PSpl:   [0.55142857 0.53428571 0.52      ]\n",
      "\n",
      "\n",
      " Iteration:  7\n",
      "Wass:   [0.75  0.795 0.61 ]\n",
      "SWass:  [0.7375 0.7225 0.57  ]\n",
      "PS:     [0.89125 0.89625 0.68   ]\n",
      "PL:     [0.9025 0.7    0.53  ]\n",
      "PI:     [0.79375 0.72    0.57125]\n",
      "PSpl:   [0.5475  0.53125 0.52125]\n",
      "\n",
      "\n",
      " Iteration:  8\n",
      "Wass:   [0.77       0.81555556 0.60111111]\n",
      "SWass:  [0.76       0.74666667 0.56555556]\n",
      "PS:     [0.89555556 0.9        0.67      ]\n",
      "PL:     [0.90666667 0.73       0.52888889]\n",
      "PI:     [0.81111111 0.72666667 0.57222222]\n",
      "PSpl:   [0.54444444 0.53       0.52      ]\n",
      "\n",
      "\n",
      " Iteration:  9\n",
      "Wass:   [0.793 0.833 0.634]\n",
      "SWass:  [0.784 0.772 0.559]\n",
      "PS:     [0.906 0.908 0.693]\n",
      "PL:     [0.916 0.755 0.534]\n",
      "PI:     [0.83  0.754 0.593]\n",
      "PSpl:   [0.548 0.531 0.518]\n",
      "\n",
      "\n",
      " Iteration:  10\n",
      "Wass:   [0.81181818 0.84545455 0.62272727]\n",
      "SWass:  [0.80181818 0.79       0.56090909]\n",
      "PS:     [0.91363636 0.91363636 0.71      ]\n",
      "PL:     [0.92272727 0.77181818 0.53181818]\n",
      "PI:     [0.84       0.77363636 0.59363636]\n",
      "PSpl:   [0.54454545 0.53090909 0.51727273]\n",
      "\n",
      "\n",
      " Iteration:  11\n",
      "Wass:   [0.82583333 0.8175     0.61333333]\n",
      "SWass:  [0.81666667 0.8        0.5825    ]\n",
      "PS:     [0.90916667 0.88333333 0.71916667]\n",
      "PL:     [0.88833333 0.75       0.53      ]\n",
      "PI:     [0.83583333 0.75333333 0.595     ]\n",
      "PSpl:   [0.54166667 0.52916667 0.51666667]\n",
      "\n",
      "\n",
      " Iteration:  12\n",
      "Wass:   [0.83923077 0.82538462 0.60538462]\n",
      "SWass:  [0.79307692 0.77769231 0.57692308]\n",
      "PS:     [0.91307692 0.88461538 0.70384615]\n",
      "PL:     [0.89692308 0.73076923 0.53      ]\n",
      "PI:     [0.84538462 0.75076923 0.59384615]\n",
      "PSpl:   [0.53923077 0.52846154 0.51538462]\n",
      "\n",
      "\n",
      " Iteration:  13\n",
      "Wass:   [0.85071429 0.83785714 0.59785714]\n",
      "SWass:  [0.80785714 0.79357143 0.57142857]\n",
      "PS:     [0.91928571 0.89285714 0.71785714]\n",
      "PL:     [0.86857143 0.74642857 0.52785714]\n",
      "PI:     [0.85       0.745      0.59071429]\n",
      "PSpl:   [0.53714286 0.53       0.515     ]\n",
      "\n",
      "\n",
      " Iteration:  14\n",
      "Wass:   [0.85866667 0.84666667 0.59466667]\n",
      "SWass:  [0.81933333 0.80666667 0.56733333]\n",
      "PS:     [0.924      0.89933333 0.70666667]\n",
      "PL:     [0.87533333 0.758      0.54333333]\n",
      "PI:     [0.85866667 0.75733333 0.59266667]\n",
      "PSpl:   [0.56666667 0.52933333 0.516     ]\n",
      "\n",
      "\n",
      " Iteration:  15\n",
      "Wass:   [0.865    0.85     0.589375]\n",
      "SWass:  [0.82875 0.8125  0.56375]\n",
      "PS:     [0.92625  0.900625 0.6975  ]\n",
      "PL:     [0.883125 0.769375 0.54875 ]\n",
      "PI:     [0.865625 0.77125  0.58875 ]\n",
      "PSpl:   [0.590625 0.555625 0.515625]\n",
      "\n",
      "\n",
      " Iteration:  16\n",
      "Wass:   [0.84411765 0.83       0.58411765]\n",
      "SWass:  [0.83529412 0.79411765 0.58058824]\n",
      "PS:     [0.92411765 0.89823529 0.69882353]\n",
      "PL:     [0.86117647 0.75411765 0.54588235]\n",
      "PI:     [0.85176471 0.76647059 0.58470588]\n",
      "PSpl:   [0.58529412 0.55411765 0.51529412]\n",
      "\n",
      "\n",
      " Iteration:  17\n",
      "Wass:   [0.85111111 0.83388889 0.58111111]\n",
      "SWass:  [0.81722222 0.79833333 0.57722222]\n",
      "PS:     [0.92611111 0.89888889 0.69666667]\n",
      "PL:     [0.86777778 0.74       0.54611111]\n",
      "PI:     [0.85722222 0.77444444 0.585     ]\n",
      "PSpl:   [0.58166667 0.55166667 0.51555556]\n",
      "\n",
      "\n",
      " Iteration:  18\n",
      "Wass:   [0.85736842 0.84       0.57789474]\n",
      "SWass:  [0.80368421 0.80315789 0.57736842]\n",
      "PS:     [0.92684211 0.89105263 0.68894737]\n",
      "PL:     [0.87368421 0.75105263 0.54368421]\n",
      "PI:     [0.86105263 0.78368421 0.58526316]\n",
      "PSpl:   [0.57894737 0.54947368 0.51789474]\n",
      "\n",
      "\n",
      " Iteration:  19\n",
      "Wass:   [0.8615 0.8235 0.5745]\n",
      "SWass:  [0.789  0.788  0.5745]\n",
      "PS:     [0.9235 0.888  0.6835]\n",
      "PL:     [0.856  0.7385 0.544 ]\n",
      "PI:     [0.8635 0.784  0.597 ]\n",
      "PSpl:   [0.5775 0.5495 0.519 ]\n",
      "\n",
      "\n",
      " Iteration:  20\n",
      "Wass:   [0.86714286 0.83095238 0.58809524]\n",
      "SWass:  [0.79809524 0.79714286 0.58952381]\n",
      "PS:     [0.92666667 0.89095238 0.69619048]\n",
      "PL:     [0.86190476 0.74952381 0.56238095]\n",
      "PI:     [0.86952381 0.79333333 0.60714286]\n",
      "PSpl:   [0.59714286 0.56761905 0.51952381]\n",
      "\n",
      "\n",
      " Iteration:  21\n",
      "Wass:   [0.87227273 0.83772727 0.585     ]\n",
      "SWass:  [0.80727273 0.80636364 0.58590909]\n",
      "PS:     [0.93       0.89590909 0.70909091]\n",
      "PL:     [0.86727273 0.76       0.56045455]\n",
      "PI:     [0.87454545 0.80181818 0.60681818]\n",
      "PSpl:   [0.605      0.56590909 0.51909091]\n",
      "\n",
      "\n",
      " Iteration:  22\n",
      "Wass:   [0.87782609 0.84347826 0.5826087 ]\n",
      "SWass:  [0.81434783 0.79347826 0.58304348]\n",
      "PS:     [0.92608696 0.88       0.70695652]\n",
      "PL:     [0.8726087  0.74913043 0.55782609]\n",
      "PI:     [0.86869565 0.79086957 0.60391304]\n",
      "PSpl:   [0.60086957 0.56347826 0.51826087]\n",
      "\n",
      "\n",
      " Iteration:  23\n",
      "Wass:   [0.88125    0.84916667 0.59625   ]\n",
      "SWass:  [0.82208333 0.80166667 0.58333333]\n",
      "PS:     [0.92833333 0.885      0.71625   ]\n",
      "PL:     [0.87708333 0.75875    0.55583333]\n",
      "PI:     [0.87333333 0.79166667 0.60416667]\n",
      "PSpl:   [0.60333333 0.5625     0.51833333]\n",
      "\n",
      "\n",
      " Iteration:  24\n",
      "Wass:   [0.886  0.8532 0.5924]\n",
      "SWass:  [0.8092 0.8068 0.58  ]\n",
      "PS:     [0.9264 0.8832 0.7092]\n",
      "PL:     [0.8796 0.764  0.5544]\n",
      "PI:     [0.8692 0.792  0.6008]\n",
      "PSpl:   [0.5996 0.5608 0.5184]\n",
      "\n",
      "\n",
      " Iteration:  25\n",
      "Wass:   [0.87153846 0.84115385 0.58923077]\n",
      "SWass:  [0.81423077 0.79576923 0.57730769]\n",
      "PS:     [0.91846154 0.87       0.70153846]\n",
      "PL:     [0.86538462 0.75961538 0.55230769]\n",
      "PI:     [0.85961538 0.78192308 0.59807692]\n",
      "PSpl:   [0.59846154 0.56       0.51807692]\n",
      "\n",
      "\n",
      " Iteration:  26\n",
      "Wass:   [0.85851852 0.82888889 0.58592593]\n",
      "SWass:  [0.80333333 0.78777778 0.57481481]\n",
      "PS:     [0.91444444 0.86888889 0.70222222]\n",
      "PL:     [0.85259259 0.75259259 0.55111111]\n",
      "PI:     [0.84888889 0.7862963  0.59740741]\n",
      "PSpl:   [0.59555556 0.55888889 0.51777778]\n",
      "\n",
      "\n",
      " Iteration:  27\n",
      "Wass:   [0.86285714 0.83392857 0.58535714]\n",
      "SWass:  [0.80964286 0.79464286 0.585     ]\n",
      "PS:     [0.91714286 0.87321429 0.70928571]\n",
      "PL:     [0.8575     0.74392857 0.55071429]\n",
      "PI:     [0.85321429 0.79107143 0.60642857]\n",
      "PSpl:   [0.595      0.55785714 0.51785714]\n",
      "\n",
      "\n",
      " Iteration:  28\n",
      "Wass:   [0.85068966 0.82655172 0.58275862]\n",
      "SWass:  [0.79965517 0.78482759 0.58241379]\n",
      "PS:     [0.90862069 0.87       0.7062069 ]\n",
      "PL:     [0.85       0.73827586 0.54896552]\n",
      "PI:     [0.84689655 0.78344828 0.60344828]\n",
      "PSpl:   [0.59655172 0.55655172 0.51793103]\n",
      "\n",
      "\n",
      " Iteration:  29\n",
      "Wass:   [0.85266667 0.816      0.581     ]\n",
      "SWass:  [0.802      0.77533333 0.58      ]\n",
      "PS:     [0.90666667 0.86966667 0.69966667]\n",
      "PL:     [0.85033333 0.73066667 0.54733333]\n",
      "PI:     [0.84233333 0.786      0.60166667]\n",
      "PSpl:   [0.59566667 0.555      0.51866667]\n",
      "\n",
      "\n",
      " Iteration:  30\n",
      "Wass:   [0.84225806 0.80645161 0.5783871 ]\n",
      "SWass:  [0.79225806 0.76645161 0.57774194]\n",
      "PS:     [0.89741935 0.85967742 0.69322581]\n",
      "PL:     [0.83935484 0.72387097 0.54580645]\n",
      "PI:     [0.83419355 0.7816129  0.60129032]\n",
      "PSpl:   [0.59322581 0.55354839 0.51806452]\n",
      "\n",
      "\n",
      " Iteration:  31\n",
      "Wass:   [0.8315625 0.7971875 0.5765625]\n",
      "SWass:  [0.7846875 0.7584375 0.5753125]\n",
      "PS:     [0.895625  0.853125  0.6903125]\n",
      "PL:     [0.829375  0.720625  0.5446875]\n",
      "PI:     [0.829375  0.7778125 0.59875  ]\n",
      "PSpl:   [0.5909375 0.5521875 0.5178125]\n",
      "\n",
      "\n",
      " Iteration:  32\n",
      "Wass:   [0.83545455 0.80242424 0.57454545]\n",
      "SWass:  [0.79030303 0.76484848 0.57333333]\n",
      "PS:     [0.89515152 0.8569697  0.68909091]\n",
      "PL:     [0.82848485 0.72212121 0.54333333]\n",
      "PI:     [0.83030303 0.78030303 0.6       ]\n",
      "PSpl:   [0.58878788 0.55121212 0.51848485]\n",
      "\n",
      "\n",
      " Iteration:  33\n",
      "Wass:   [0.82558824 0.79352941 0.57235294]\n",
      "SWass:  [0.78676471 0.75705882 0.57647059]\n",
      "PS:     [0.89029412 0.85117647 0.68823529]\n",
      "PL:     [0.81911765 0.71558824 0.54470588]\n",
      "PI:     [0.82235294 0.77323529 0.6       ]\n",
      "PSpl:   [0.58647059 0.55029412 0.52      ]\n",
      "\n",
      "\n",
      " Iteration:  34\n",
      "Wass:   [0.82942857 0.79942857 0.57114286]\n",
      "SWass:  [0.79228571 0.752      0.57457143]\n",
      "PS:     [0.88057143 0.85285714 0.68914286]\n",
      "PL:     [0.82       0.71       0.54371429]\n",
      "PI:     [0.82371429 0.77714286 0.60342857]\n",
      "PSpl:   [0.58542857 0.55       0.51971429]\n",
      "\n",
      "\n",
      " Iteration:  35\n",
      "Wass:   [0.82027778 0.79111111 0.57055556]\n",
      "SWass:  [0.78416667 0.75111111 0.5725    ]\n",
      "PS:     [0.88138889 0.85138889 0.69111111]\n",
      "PL:     [0.81138889 0.70444444 0.54388889]\n",
      "PI:     [0.82       0.77333333 0.60333333]\n",
      "PSpl:   [0.58333333 0.54916667 0.51972222]\n",
      "\n",
      "\n",
      " Iteration:  36\n",
      "Wass:   [0.82432432 0.79513514 0.56864865]\n",
      "SWass:  [0.78972973 0.75594595 0.57945946]\n",
      "PS:     [0.88324324 0.85378378 0.68648649]\n",
      "PL:     [0.80297297 0.70702703 0.54297297]\n",
      "PI:     [0.8127027  0.77162162 0.60594595]\n",
      "PSpl:   [0.58135135 0.54837838 0.51945946]\n",
      "\n",
      "\n",
      " Iteration:  37\n",
      "Wass:   [0.82842105 0.80026316 0.56684211]\n",
      "SWass:  [0.78210526 0.75763158 0.57789474]\n",
      "PS:     [0.87736842 0.85289474 0.68342105]\n",
      "PL:     [0.80605263 0.70157895 0.54447368]\n",
      "PI:     [0.80605263 0.76526316 0.60552632]\n",
      "PSpl:   [0.58052632 0.54763158 0.51921053]\n",
      "\n",
      "\n",
      " Iteration:  38\n",
      "Wass:   [0.83205128 0.80512821 0.57410256]\n",
      "SWass:  [0.78769231 0.7625641  0.57641026]\n",
      "PS:     [0.88       0.85615385 0.68871795]\n",
      "PL:     [0.81       0.70846154 0.55153846]\n",
      "PI:     [0.80769231 0.76615385 0.60666667]\n",
      "PSpl:   [0.57897436 0.54717949 0.51897436]\n",
      "\n",
      "\n",
      " Iteration:  39\n",
      "Wass:   [0.824  0.7975 0.5725]\n",
      "SWass:  [0.78075 0.756   0.5745 ]\n",
      "PS:     [0.8725  0.84725 0.68675]\n",
      "PL:     [0.80225 0.7045  0.55175]\n",
      "PI:     [0.801   0.76025 0.60575]\n",
      "PSpl:   [0.57725 0.54625 0.51925]\n",
      "\n",
      "\n",
      " Iteration:  40\n",
      "Wass:   [0.81609756 0.80195122 0.57073171]\n",
      "SWass:  [0.78463415 0.75902439 0.57365854]\n",
      "PS:     [0.8697561  0.84536585 0.68560976]\n",
      "PL:     [0.79487805 0.6997561  0.5504878 ]\n",
      "PI:     [0.79609756 0.75414634 0.60341463]\n",
      "PSpl:   [0.57609756 0.54560976 0.51902439]\n",
      "\n",
      "\n",
      " Iteration:  41\n",
      "Wass:   [0.82047619 0.80571429 0.56928571]\n",
      "SWass:  [0.78928571 0.76238095 0.57214286]\n",
      "PS:     [0.87285714 0.84809524 0.69      ]\n",
      "PL:     [0.79904762 0.7047619  0.54928571]\n",
      "PI:     [0.80095238 0.75761905 0.60809524]\n",
      "PSpl:   [0.575      0.54452381 0.51904762]\n",
      "\n",
      "\n",
      " Iteration:  42\n",
      "Wass:   [0.82325581 0.79883721 0.57395349]\n",
      "SWass:  [0.79302326 0.75627907 0.57069767]\n",
      "PS:     [0.87302326 0.84023256 0.69162791]\n",
      "PL:     [0.80232558 0.70069767 0.54837209]\n",
      "PI:     [0.80372093 0.75627907 0.60674419]\n",
      "PSpl:   [0.57348837 0.54465116 0.51930233]\n",
      "\n",
      "\n",
      " Iteration:  43\n",
      "Wass:   [0.81590909 0.79227273 0.5725    ]\n",
      "SWass:  [0.78704545 0.75068182 0.56931818]\n",
      "PS:     [0.865      0.83295455 0.6875    ]\n",
      "PL:     [0.79659091 0.69659091 0.54727273]\n",
      "PI:     [0.80159091 0.75204545 0.60454545]\n",
      "PSpl:   [0.57386364 0.54431818 0.51954545]\n",
      "\n",
      "\n",
      " Iteration:  44\n",
      "Wass:   [0.80888889 0.78577778 0.57111111]\n",
      "SWass:  [0.78066667 0.74577778 0.568     ]\n",
      "PS:     [0.85888889 0.82644444 0.68466667]\n",
      "PL:     [0.79955556 0.69577778 0.54777778]\n",
      "PI:     [0.79755556 0.74777778 0.60355556]\n",
      "PSpl:   [0.57688889 0.54444444 0.51933333]\n",
      "\n",
      "\n",
      " Iteration:  45\n",
      "Wass:   [0.80195652 0.77978261 0.56978261]\n",
      "SWass:  [0.77456522 0.74043478 0.56673913]\n",
      "PS:     [0.85586957 0.82173913 0.68217391]\n",
      "PL:     [0.795      0.69152174 0.54695652]\n",
      "PI:     [0.79304348 0.74282609 0.60369565]\n",
      "PSpl:   [0.57543478 0.54413043 0.51913043]\n",
      "\n",
      "\n",
      " Iteration:  46\n",
      "Wass:   [0.80617021 0.78446809 0.57319149]\n",
      "SWass:  [0.7793617  0.74595745 0.57106383]\n",
      "PS:     [0.85893617 0.82553191 0.68489362]\n",
      "PL:     [0.78914894 0.69765957 0.54744681]\n",
      "PI:     [0.7887234  0.74574468 0.60361702]\n",
      "PSpl:   [0.57404255 0.54404255 0.51914894]\n",
      "\n",
      "\n",
      " Iteration:  47\n",
      "Wass:   [0.8        0.77895833 0.57166667]\n",
      "SWass:  [0.77458333 0.74083333 0.56979167]\n",
      "PS:     [0.85291667 0.819375   0.68166667]\n",
      "PL:     [0.78354167 0.69645833 0.54666667]\n",
      "PI:     [0.78604167 0.74375    0.6025    ]\n",
      "PSpl:   [0.57291667 0.54354167 0.51895833]\n",
      "\n",
      "\n",
      " Iteration:  48\n",
      "Wass:   [0.79408163 0.77326531 0.57020408]\n",
      "SWass:  [0.76897959 0.73591837 0.56918367]\n",
      "PS:     [0.85122449 0.81428571 0.67959184]\n",
      "PL:     [0.77795918 0.69265306 0.54591837]\n",
      "PI:     [0.78489796 0.74387755 0.60102041]\n",
      "PSpl:   [0.57183673 0.54285714 0.51877551]\n",
      "\n",
      "\n",
      " Iteration:  49\n",
      "Wass:   [0.7976 0.7678 0.569 ]\n",
      "SWass:  [0.7732 0.7392 0.5698]\n",
      "PS:     [0.8516 0.815  0.6808]\n",
      "PL:     [0.7816 0.6964 0.545 ]\n",
      "PI:     [0.7882 0.7458 0.5992]\n",
      "PSpl:   [0.5722 0.5432 0.5186]\n",
      "\n",
      "\n",
      " Iteration:  50\n",
      "Wass:   [0.80156863 0.77196078 0.56764706]\n",
      "SWass:  [0.7772549  0.74333333 0.57470588]\n",
      "PS:     [0.8545098  0.81784314 0.68333333]\n",
      "PL:     [0.78588235 0.70196078 0.54431373]\n",
      "PI:     [0.79235294 0.74960784 0.59941176]\n",
      "PSpl:   [0.57078431 0.5454902  0.51843137]\n",
      "\n",
      "\n",
      " Iteration:  51\n",
      "Wass:   [0.805      0.76692308 0.56653846]\n",
      "SWass:  [0.78134615 0.74730769 0.57769231]\n",
      "PS:     [0.85711538 0.81961538 0.68442308]\n",
      "PL:     [0.78057692 0.69961538 0.54365385]\n",
      "PI:     [0.79211538 0.75153846 0.59807692]\n",
      "PSpl:   [0.56961538 0.54519231 0.51903846]\n",
      "\n",
      "\n",
      " Iteration:  52\n",
      "Wass:   [0.80830189 0.77       0.57226415]\n",
      "SWass:  [0.78396226 0.74264151 0.57679245]\n",
      "PS:     [0.85943396 0.82207547 0.68886792]\n",
      "PL:     [0.78264151 0.69641509 0.54301887]\n",
      "PI:     [0.79283019 0.75396226 0.60132075]\n",
      "PSpl:   [0.56849057 0.5445283  0.5190566 ]\n",
      "\n",
      "\n",
      " Iteration:  53\n",
      "Wass:   [0.81148148 0.77333333 0.57111111]\n",
      "SWass:  [0.78740741 0.74666667 0.57796296]\n",
      "PS:     [0.86148148 0.82518519 0.69314815]\n",
      "PL:     [0.78648148 0.70037037 0.54259259]\n",
      "PI:     [0.7962963  0.75777778 0.60666667]\n",
      "PSpl:   [0.56759259 0.54481481 0.51907407]\n",
      "\n",
      "\n",
      " Iteration:  54\n",
      "Wass:   [0.81418182 0.77490909 0.574     ]\n",
      "SWass:  [0.78981818 0.74236364 0.57836364]\n",
      "PS:     [0.86109091 0.826      0.69381818]\n",
      "PL:     [0.78836364 0.69727273 0.542     ]\n",
      "PI:     [0.79781818 0.75727273 0.60872727]\n",
      "PSpl:   [0.56727273 0.54418182 0.51872727]\n",
      "\n",
      "\n",
      " Iteration:  55\n",
      "Wass:   [0.81660714 0.77714286 0.57285714]\n",
      "SWass:  [0.79357143 0.74589286 0.57714286]\n",
      "PS:     [0.86232143 0.82732143 0.69571429]\n",
      "PL:     [0.79107143 0.69375    0.54232143]\n",
      "PI:     [0.79982143 0.76017857 0.61160714]\n",
      "PSpl:   [0.56607143 0.54339286 0.51839286]\n",
      "\n",
      "\n",
      " Iteration:  56\n",
      "Wass:   [0.81105263 0.7722807  0.57157895]\n",
      "SWass:  [0.78842105 0.74175439 0.57578947]\n",
      "PS:     [0.8622807  0.82210526 0.69491228]\n",
      "PL:     [0.79385965 0.69859649 0.54157895]\n",
      "PI:     [0.80105263 0.76052632 0.61280702]\n",
      "PSpl:   [0.56491228 0.5454386  0.51824561]\n",
      "\n",
      "\n",
      " Iteration:  57\n",
      "Wass:   [0.81310345 0.76775862 0.57034483]\n",
      "SWass:  [0.78465517 0.73775862 0.57637931]\n",
      "PS:     [0.85706897 0.81706897 0.69189655]\n",
      "PL:     [0.7962069  0.70189655 0.54086207]\n",
      "PI:     [0.79793103 0.75862069 0.6112069 ]\n",
      "PSpl:   [0.56706897 0.54551724 0.51810345]\n",
      "\n",
      "\n",
      " Iteration:  58\n",
      "Wass:   [0.80779661 0.76322034 0.56932203]\n",
      "SWass:  [0.77983051 0.73457627 0.57508475]\n",
      "PS:     [0.85440678 0.81322034 0.68983051]\n",
      "PL:     [0.79220339 0.69847458 0.54050847]\n",
      "PI:     [0.79661017 0.75864407 0.61135593]\n",
      "PSpl:   [0.56627119 0.54491525 0.51847458]\n",
      "\n",
      "\n",
      " Iteration:  59\n",
      "Wass:   [0.81066667 0.76616667 0.56816667]\n",
      "SWass:  [0.78316667 0.739      0.57383333]\n",
      "PS:     [0.85666667 0.8155     0.69233333]\n",
      "PL:     [0.7875     0.69533333 0.54233333]\n",
      "PI:     [0.79283333 0.75466667 0.61366667]\n",
      "PSpl:   [0.5655     0.5445     0.51833333]\n",
      "\n",
      "\n",
      " Iteration:  60\n",
      "Wass:   [0.81295082 0.76180328 0.56721311]\n",
      "SWass:  [0.77852459 0.73540984 0.57245902]\n",
      "PS:     [0.85754098 0.81180328 0.69163934]\n",
      "PL:     [0.78295082 0.69245902 0.54163934]\n",
      "PI:     [0.79327869 0.75311475 0.61213115]\n",
      "PSpl:   [0.56459016 0.54393443 0.51819672]\n",
      "\n",
      "\n",
      " Iteration:  61\n",
      "Wass:   [0.80806452 0.75758065 0.56677419]\n",
      "SWass:  [0.78080645 0.73870968 0.57467742]\n",
      "PS:     [0.85790323 0.81290323 0.69274194]\n",
      "PL:     [0.78080645 0.69064516 0.54112903]\n",
      "PI:     [0.79112903 0.75032258 0.61129032]\n",
      "PSpl:   [0.565      0.5433871  0.51806452]\n",
      "\n",
      "\n",
      " Iteration:  62\n",
      "Wass:   [0.80333333 0.75396825 0.5668254 ]\n",
      "SWass:  [0.77650794 0.7352381  0.57349206]\n",
      "PS:     [0.8568254  0.8131746  0.69063492]\n",
      "PL:     [0.78301587 0.68777778 0.54333333]\n",
      "PI:     [0.79238095 0.74952381 0.61190476]\n",
      "PSpl:   [0.56428571 0.54333333 0.51809524]\n",
      "\n",
      "\n",
      " Iteration:  63\n",
      "Wass:   [0.80609375 0.75734375 0.56609375]\n",
      "SWass:  [0.77953125 0.7384375  0.57828125]\n",
      "PS:     [0.8590625  0.815625   0.69359375]\n",
      "PL:     [0.78640625 0.6921875  0.54296875]\n",
      "PI:     [0.795625   0.7528125  0.61046875]\n",
      "PSpl:   [0.56375    0.54296875 0.518125  ]\n",
      "\n",
      "\n",
      " Iteration:  64\n",
      "Wass:   [0.80907692 0.76061538 0.56492308]\n",
      "SWass:  [0.78261538 0.742      0.57984615]\n",
      "PS:     [0.86076923 0.81846154 0.69584615]\n",
      "PL:     [0.78953846 0.69646154 0.54246154]\n",
      "PI:     [0.79784615 0.75461538 0.61153846]\n",
      "PSpl:   [0.56323077 0.54230769 0.51830769]\n",
      "\n",
      "\n",
      " Iteration:  65\n",
      "Wass:   [0.81121212 0.76287879 0.56409091]\n",
      "SWass:  [0.785      0.74439394 0.57878788]\n",
      "PS:     [0.8619697  0.81984848 0.69742424]\n",
      "PL:     [0.79151515 0.69893939 0.54181818]\n",
      "PI:     [0.8        0.75666667 0.61151515]\n",
      "PSpl:   [0.56257576 0.5419697  0.51833333]\n",
      "\n",
      "\n",
      " Iteration:  66\n",
      "Wass:   [0.80656716 0.76537313 0.56313433]\n",
      "SWass:  [0.78074627 0.74104478 0.57761194]\n",
      "PS:     [0.86149254 0.81985075 0.69567164]\n",
      "PL:     [0.79149254 0.6961194  0.54134328]\n",
      "PI:     [0.79955224 0.75492537 0.61074627]\n",
      "PSpl:   [0.5619403  0.54149254 0.51835821]\n",
      "\n",
      "\n",
      " Iteration:  67\n",
      "Wass:   [0.80911765 0.76808824 0.56220588]\n",
      "SWass:  [0.77661765 0.73764706 0.57676471]\n",
      "PS:     [0.86220588 0.82176471 0.69588235]\n",
      "PL:     [0.7875     0.69323529 0.54073529]\n",
      "PI:     [0.79985294 0.75661765 0.61161765]\n",
      "PSpl:   [0.56117647 0.54102941 0.51808824]\n",
      "\n",
      "\n",
      " Iteration:  68\n",
      "Wass:   [0.8115942  0.77028986 0.56144928]\n",
      "SWass:  [0.77898551 0.74057971 0.5757971 ]\n",
      "PS:     [0.86391304 0.82391304 0.69869565]\n",
      "PL:     [0.79014493 0.69101449 0.54101449]\n",
      "PI:     [0.80231884 0.75913043 0.61144928]\n",
      "PSpl:   [0.56173913 0.5415942  0.51855072]\n",
      "\n",
      "\n",
      " Iteration:  69\n",
      "Wass:   [0.81414286 0.77285714 0.56085714]\n",
      "SWass:  [0.78171429 0.74357143 0.57957143]\n",
      "PS:     [0.86514286 0.82585714 0.70085714]\n",
      "PL:     [0.79271429 0.69471429 0.54042857]\n",
      "PI:     [0.80042857 0.75728571 0.61142857]\n",
      "PSpl:   [0.56114286 0.54157143 0.51871429]\n",
      "\n",
      "\n",
      " Iteration:  70\n",
      "Wass:   [0.81647887 0.77535211 0.56      ]\n",
      "SWass:  [0.78450704 0.74605634 0.57887324]\n",
      "PS:     [0.86704225 0.82760563 0.70183099]\n",
      "PL:     [0.79535211 0.69197183 0.53985915]\n",
      "PI:     [0.8015493  0.75380282 0.61070423]\n",
      "PSpl:   [0.56070423 0.54112676 0.51873239]\n",
      "\n",
      "\n",
      " Iteration:  71\n",
      "Wass:   [0.81902778 0.77819444 0.55930556]\n",
      "SWass:  [0.78736111 0.74277778 0.57805556]\n",
      "PS:     [0.86875    0.82986111 0.70388889]\n",
      "PL:     [0.79138889 0.69597222 0.54375   ]\n",
      "PI:     [0.80430556 0.75708333 0.61388889]\n",
      "PSpl:   [0.56027778 0.54069444 0.51861111]\n",
      "\n",
      "\n",
      " Iteration:  72\n",
      "Wass:   [0.82109589 0.78082192 0.55863014]\n",
      "SWass:  [0.7839726  0.74041096 0.57931507]\n",
      "PS:     [0.86712329 0.83013699 0.70205479]\n",
      "PL:     [0.78753425 0.69328767 0.54315068]\n",
      "PI:     [0.80643836 0.75534247 0.61246575]\n",
      "PSpl:   [0.56068493 0.54082192 0.51849315]\n",
      "\n",
      "\n",
      " Iteration:  73\n",
      "Wass:   [0.81689189 0.77716216 0.55783784]\n",
      "SWass:  [0.78027027 0.7372973  0.57837838]\n",
      "PS:     [0.86608108 0.82594595 0.69986486]\n",
      "PL:     [0.78837838 0.69121622 0.5427027 ]\n",
      "PI:     [0.80513514 0.75243243 0.61108108]\n",
      "PSpl:   [0.56013514 0.54054054 0.51837838]\n",
      "\n",
      "\n",
      " Iteration:  74\n",
      "Wass:   [0.8128     0.7736     0.55706667]\n",
      "SWass:  [0.78093333 0.73893333 0.57733333]\n",
      "PS:     [0.86613333 0.8224     0.69973333]\n",
      "PL:     [0.78506667 0.6888     0.54293333]\n",
      "PI:     [0.80186667 0.75173333 0.61026667]\n",
      "PSpl:   [0.55946667 0.54013333 0.5184    ]\n",
      "\n",
      "\n",
      " Iteration:  75\n",
      "Wass:   [0.81473684 0.77013158 0.55644737]\n",
      "SWass:  [0.77723684 0.73592105 0.57644737]\n",
      "PS:     [0.86539474 0.81828947 0.70026316]\n",
      "PL:     [0.78723684 0.68644737 0.5425    ]\n",
      "PI:     [0.80342105 0.75065789 0.60907895]\n",
      "PSpl:   [0.55934211 0.54052632 0.51842105]\n",
      "\n",
      "\n",
      " Iteration:  76\n",
      "Wass:   [0.81090909 0.76662338 0.55584416]\n",
      "SWass:  [0.77415584 0.73285714 0.57558442]\n",
      "PS:     [0.86155844 0.81441558 0.7       ]\n",
      "PL:     [0.78350649 0.68402597 0.54194805]\n",
      "PI:     [0.80025974 0.74935065 0.60792208]\n",
      "PSpl:   [0.55857143 0.54012987 0.51831169]\n",
      "\n",
      "\n",
      " Iteration:  77\n",
      "Wass:   [0.81307692 0.76923077 0.55589744]\n",
      "SWass:  [0.77705128 0.73602564 0.57576923]\n",
      "PS:     [0.86333333 0.81641026 0.7025641 ]\n",
      "PL:     [0.78602564 0.6875641  0.5425641 ]\n",
      "PI:     [0.80282051 0.75192308 0.60974359]\n",
      "PSpl:   [0.55794872 0.54025641 0.51846154]\n",
      "\n",
      "\n",
      " Iteration:  78\n",
      "Wass:   [0.80924051 0.76594937 0.55594937]\n",
      "SWass:  [0.77379747 0.73303797 0.5756962 ]\n",
      "PS:     [0.85924051 0.81265823 0.70037975]\n",
      "PL:     [0.78253165 0.68518987 0.54202532]\n",
      "PI:     [0.79936709 0.74924051 0.60873418]\n",
      "PSpl:   [0.55734177 0.53987342 0.51835443]\n",
      "\n",
      "\n",
      " Iteration:  79\n",
      "Wass:   [0.811    0.762625 0.556   ]\n",
      "SWass:  [0.775875 0.73075  0.576   ]\n",
      "PS:     [0.859625 0.8135   0.700375]\n",
      "PL:     [0.783875 0.682875 0.542875]\n",
      "PI:     [0.8005   0.749875 0.609125]\n",
      "PSpl:   [0.556875 0.539875 0.51825 ]\n",
      "\n",
      "\n",
      " Iteration:  80\n",
      "Wass:   [0.81296296 0.75938272 0.55790123]\n",
      "SWass:  [0.7782716  0.72790123 0.57592593]\n",
      "PS:     [0.86098765 0.80975309 0.70234568]\n",
      "PL:     [0.78617284 0.68074074 0.54259259]\n",
      "PI:     [0.80234568 0.74740741 0.60938272]\n",
      "PSpl:   [0.55691358 0.53938272 0.5182716 ]\n",
      "\n",
      "\n",
      " Iteration:  81\n",
      "Wass:   [0.80926829 0.75621951 0.55817073]\n",
      "SWass:  [0.77585366 0.72560976 0.57597561]\n",
      "PS:     [0.85878049 0.80658537 0.70073171]\n",
      "PL:     [0.78280488 0.67902439 0.54219512]\n",
      "PI:     [0.79902439 0.7454878  0.60853659]\n",
      "PSpl:   [0.55634146 0.53914634 0.51829268]\n",
      "\n",
      "\n",
      " Iteration:  82\n",
      "Wass:   [0.81096386 0.75313253 0.55746988]\n",
      "SWass:  [0.77843373 0.72795181 0.57506024]\n",
      "PS:     [0.86024096 0.80819277 0.69831325]\n",
      "PL:     [0.77963855 0.67686747 0.54168675]\n",
      "PI:     [0.79771084 0.74385542 0.6073494 ]\n",
      "PSpl:   [0.55614458 0.53939759 0.51807229]\n",
      "\n",
      "\n",
      " Iteration:  83\n",
      "Wass:   [0.8072619  0.75011905 0.55690476]\n",
      "SWass:  [0.77559524 0.72511905 0.57452381]\n",
      "PS:     [0.85738095 0.8052381  0.69678571]\n",
      "PL:     [0.77642857 0.6747619  0.54130952]\n",
      "PI:     [0.79535714 0.7422619  0.60690476]\n",
      "PSpl:   [0.55571429 0.53916667 0.51809524]\n",
      "\n",
      "\n",
      " Iteration:  84\n",
      "Wass:   [0.80870588 0.74717647 0.55623529]\n",
      "SWass:  [0.77752941 0.72258824 0.57364706]\n",
      "PS:     [0.85847059 0.80694118 0.69870588]\n",
      "PL:     [0.77811765 0.67823529 0.54094118]\n",
      "PI:     [0.79705882 0.74470588 0.608     ]\n",
      "PSpl:   [0.55517647 0.53894118 0.518     ]\n",
      "\n",
      "\n",
      " Iteration:  85\n",
      "Wass:   [0.80534884 0.7444186  0.55569767]\n",
      "SWass:  [0.7744186  0.72       0.57313953]\n",
      "PS:     [0.85860465 0.8072093  0.70023256]\n",
      "PL:     [0.77523256 0.67674419 0.54069767]\n",
      "PI:     [0.79406977 0.74383721 0.60872093]\n",
      "PSpl:   [0.55465116 0.53872093 0.51790698]\n",
      "\n",
      "\n",
      " Iteration:  86\n",
      "Wass:   [0.80183908 0.7416092  0.55551724]\n",
      "SWass:  [0.77126437 0.71747126 0.57252874]\n",
      "PS:     [0.85574713 0.8054023  0.70022989]\n",
      "PL:     [0.77333333 0.67471264 0.54045977]\n",
      "PI:     [0.79091954 0.74126437 0.60793103]\n",
      "PSpl:   [0.55402299 0.53850575 0.51770115]\n",
      "\n",
      "\n",
      " Iteration:  87\n",
      "Wass:   [0.80375    0.74454545 0.55488636]\n",
      "SWass:  [0.77340909 0.71511364 0.57181818]\n",
      "PS:     [0.85715909 0.80727273 0.7025    ]\n",
      "PL:     [0.77556818 0.67840909 0.54011364]\n",
      "PI:     [0.79295455 0.74363636 0.61090909]\n",
      "PSpl:   [0.55352273 0.53818182 0.5175    ]\n",
      "\n",
      "\n",
      " Iteration:  88\n",
      "Wass:   [0.80595506 0.74707865 0.55426966]\n",
      "SWass:  [0.77044944 0.71314607 0.5711236 ]\n",
      "PS:     [0.85842697 0.80921348 0.70213483]\n",
      "PL:     [0.77786517 0.67651685 0.53966292]\n",
      "PI:     [0.7952809  0.74191011 0.61123596]\n",
      "PSpl:   [0.55842697 0.5388764  0.51741573]\n",
      "\n",
      "\n",
      " Iteration:  89\n",
      "Wass:   [0.80766667 0.74477778 0.55377778]\n",
      "SWass:  [0.77266667 0.711      0.57222222]\n",
      "PS:     [0.85966667 0.807      0.70255556]\n",
      "PL:     [0.77488889 0.67488889 0.53988889]\n",
      "PI:     [0.796      0.74033333 0.61144444]\n",
      "PSpl:   [0.55877778 0.53922222 0.51755556]\n",
      "\n",
      "\n",
      " Iteration:  90\n",
      "Wass:   [0.80978022 0.74758242 0.5532967 ]\n",
      "SWass:  [0.77516484 0.71395604 0.57571429]\n",
      "PS:     [0.86098901 0.80868132 0.70450549]\n",
      "PL:     [0.77736264 0.67846154 0.53967033]\n",
      "PI:     [0.79813187 0.74285714 0.61043956]\n",
      "PSpl:   [0.56351648 0.5389011  0.51758242]\n",
      "\n",
      "\n",
      " Iteration:  91\n",
      "Wass:   [0.81184783 0.7448913  0.55304348]\n",
      "SWass:  [0.77663043 0.71641304 0.575     ]\n",
      "PS:     [0.85956522 0.80934783 0.7026087 ]\n",
      "PL:     [0.7773913  0.67652174 0.53967391]\n",
      "PI:     [0.79902174 0.74413043 0.6098913 ]\n",
      "PSpl:   [0.56304348 0.53869565 0.5176087 ]\n",
      "\n",
      "\n",
      " Iteration:  92\n",
      "Wass:   [0.81365591 0.74709677 0.55537634]\n",
      "SWass:  [0.7788172  0.71806452 0.57731183]\n",
      "PS:     [0.86096774 0.81096774 0.70215054]\n",
      "PL:     [0.77956989 0.6788172  0.53967742]\n",
      "PI:     [0.80064516 0.7455914  0.61107527]\n",
      "PSpl:   [0.56322581 0.53849462 0.51763441]\n",
      "\n",
      "\n",
      " Iteration:  93\n",
      "Wass:   [0.81042553 0.74446809 0.55478723]\n",
      "SWass:  [0.78042553 0.71574468 0.57670213]\n",
      "PS:     [0.85755319 0.81202128 0.7006383 ]\n",
      "PL:     [0.77712766 0.67702128 0.53925532]\n",
      "PI:     [0.79819149 0.74393617 0.61010638]\n",
      "PSpl:   [0.56255319 0.53829787 0.51744681]\n",
      "\n",
      "\n",
      " Iteration:  94\n",
      "Wass:   [0.80736842 0.742      0.55421053]\n",
      "SWass:  [0.77831579 0.71442105 0.57642105]\n",
      "PS:     [0.85389474 0.81210526 0.70073684]\n",
      "PL:     [0.77431579 0.67536842 0.53926316]\n",
      "PI:     [0.79652632 0.74305263 0.60989474]\n",
      "PSpl:   [0.56221053 0.53810526 0.51736842]\n",
      "\n",
      "\n",
      " Iteration:  95\n",
      "Wass:   [0.80916667 0.74427083 0.55385417]\n",
      "SWass:  [0.78041667 0.71239583 0.575625  ]\n",
      "PS:     [0.85479167 0.81239583 0.70145833]\n",
      "PL:     [0.7765625  0.67364583 0.5390625 ]\n",
      "PI:     [0.79791667 0.74104167 0.6103125 ]\n",
      "PSpl:   [0.56197917 0.5378125  0.51729167]\n",
      "\n",
      "\n",
      " Iteration:  96\n",
      "Wass:   [0.80608247 0.74185567 0.55402062]\n",
      "SWass:  [0.77783505 0.71061856 0.57484536]\n",
      "PS:     [0.85134021 0.81278351 0.70154639]\n",
      "PL:     [0.77381443 0.6756701  0.53876289]\n",
      "PI:     [0.79948454 0.74278351 0.61154639]\n",
      "PSpl:   [0.56154639 0.53845361 0.51721649]\n",
      "\n",
      "\n",
      " Iteration:  97\n",
      "Wass:   [0.80295918 0.7394898  0.55346939]\n",
      "SWass:  [0.77979592 0.7122449  0.57734694]\n",
      "PS:     [0.85183673 0.81397959 0.70193878]\n",
      "PL:     [0.77102041 0.67755102 0.53867347]\n",
      "PI:     [0.80081633 0.7422449  0.61204082]\n",
      "PSpl:   [0.56234694 0.53867347 0.51734694]\n",
      "\n",
      "\n",
      " Iteration:  98\n",
      "Wass:   [0.80474747 0.73888889 0.55292929]\n",
      "SWass:  [0.77707071 0.71484848 0.57656566]\n",
      "PS:     [0.85252525 0.81484848 0.70373737]\n",
      "PL:     [0.77282828 0.68030303 0.54010101]\n",
      "PI:     [0.80222222 0.7440404  0.61181818]\n",
      "PSpl:   [0.56181818 0.53868687 0.51727273]\n",
      "\n",
      "\n",
      " Iteration:  99\n",
      "Wass:   [0.8018 0.7366 0.5526]\n",
      "SWass:  [0.7745 0.713  0.5771]\n",
      "PS:     [0.8535 0.8156 0.7037]\n",
      "PL:     [0.7702 0.6786 0.5398]\n",
      "PI:     [0.7999 0.7419 0.6109]\n",
      "PSpl:   [0.5617 0.5384 0.5171]\n",
      "\n",
      "\n",
      " Iteration:  100\n",
      "Wass:   [0.7990099  0.73435644 0.55217822]\n",
      "SWass:  [0.77178218 0.7109901  0.57643564]\n",
      "PS:     [0.85207921 0.81386139 0.70178218]\n",
      "PL:     [0.76831683 0.67683168 0.53980198]\n",
      "PI:     [0.7970297  0.74118812 0.61029703]\n",
      "PSpl:   [0.56118812 0.53821782 0.5170297 ]\n",
      "\n",
      "\n",
      " Iteration:  101\n",
      "Wass:   [0.79617647 0.7322549  0.55176471]\n",
      "SWass:  [0.76921569 0.70901961 0.57578431]\n",
      "PS:     [0.84892157 0.81137255 0.70068627]\n",
      "PL:     [0.76578431 0.67578431 0.5395098 ]\n",
      "PI:     [0.7977451  0.73901961 0.60941176]\n",
      "PSpl:   [0.56068627 0.53803922 0.51696078]\n",
      "\n",
      "\n",
      " Iteration:  102\n",
      "Wass:   [0.79796117 0.73456311 0.55135922]\n",
      "SWass:  [0.77126214 0.70699029 0.57514563]\n",
      "PS:     [0.85029126 0.8131068  0.69883495]\n",
      "PL:     [0.76786408 0.67893204 0.5392233 ]\n",
      "PI:     [0.79961165 0.7415534  0.61067961]\n",
      "PSpl:   [0.56019417 0.53796117 0.5168932 ]\n",
      "\n",
      "\n",
      " Iteration:  103\n",
      "Wass:   [0.79509615 0.73240385 0.55096154]\n",
      "SWass:  [0.76875    0.70528846 0.57461538]\n",
      "PS:     [0.85086538 0.81375    0.69923077]\n",
      "PL:     [0.76528846 0.67769231 0.53894231]\n",
      "PI:     [0.7975     0.74       0.61009615]\n",
      "PSpl:   [0.55971154 0.53769231 0.51682692]\n",
      "\n",
      "\n",
      " Iteration:  104\n",
      "Wass:   [0.79228571 0.73019048 0.55057143]\n",
      "SWass:  [0.77028571 0.70428571 0.57638095]\n",
      "PS:     [0.85142857 0.81190476 0.69752381]\n",
      "PL:     [0.7627619  0.676      0.53857143]\n",
      "PI:     [0.79838095 0.74009524 0.60952381]\n",
      "PSpl:   [0.56285714 0.53742857 0.5167619 ]\n",
      "\n",
      "\n",
      " Iteration:  105\n",
      "Wass:   [0.79386792 0.73226415 0.55018868]\n",
      "SWass:  [0.77188679 0.70235849 0.57575472]\n",
      "PS:     [0.85235849 0.81226415 0.69660377]\n",
      "PL:     [0.76320755 0.67462264 0.5390566 ]\n",
      "PI:     [0.79660377 0.74       0.61037736]\n",
      "PSpl:   [0.56264151 0.53726415 0.51669811]\n",
      "\n",
      "\n",
      " Iteration:  106\n",
      "Wass:   [0.79551402 0.73009346 0.55009346]\n",
      "SWass:  [0.7728972  0.70046729 0.5753271 ]\n",
      "PS:     [0.84934579 0.80953271 0.69607477]\n",
      "PL:     [0.76476636 0.6735514  0.53869159]\n",
      "PI:     [0.79794393 0.74140187 0.60990654]\n",
      "PSpl:   [0.56214953 0.53700935 0.51719626]\n",
      "\n",
      "\n",
      " Iteration:  107\n",
      "Wass:   [0.79712963 0.72796296 0.54990741]\n",
      "SWass:  [0.77037037 0.69861111 0.57509259]\n",
      "PS:     [0.85       0.81064815 0.6962037 ]\n",
      "PL:     [0.76666667 0.67194444 0.53833333]\n",
      "PI:     [0.79953704 0.74342593 0.61055556]\n",
      "PSpl:   [0.56555556 0.53666667 0.51722222]\n",
      "\n",
      "\n",
      " Iteration:  108\n",
      "Wass:   [0.79449541 0.72605505 0.54944954]\n",
      "SWass:  [0.76825688 0.69688073 0.57486239]\n",
      "PS:     [0.84807339 0.80908257 0.69495413]\n",
      "PL:     [0.76816514 0.67045872 0.53807339]\n",
      "PI:     [0.79788991 0.74321101 0.61119266]\n",
      "PSpl:   [0.56577982 0.53816514 0.51715596]\n",
      "\n",
      "\n",
      " Iteration:  109\n",
      "Wass:   [0.79618182 0.72836364 0.553     ]\n",
      "SWass:  [0.77036364 0.69945455 0.57818182]\n",
      "PS:     [0.84927273 0.81072727 0.69709091]\n",
      "PL:     [0.77009091 0.67327273 0.54163636]\n",
      "PI:     [0.79954545 0.74536364 0.61218182]\n",
      "PSpl:   [0.56954545 0.54218182 0.51745455]\n",
      "\n",
      "\n",
      " Iteration:  110\n",
      "Wass:   [0.7936036  0.7263964  0.55315315]\n",
      "SWass:  [0.76801802 0.69765766 0.57810811]\n",
      "PS:     [0.84918919 0.81072072 0.69765766]\n",
      "PL:     [0.76864865 0.67198198 0.54135135]\n",
      "PI:     [0.79792793 0.74621622 0.61252252]\n",
      "PSpl:   [0.56936937 0.54207207 0.51747748]\n",
      "\n",
      "\n",
      " Iteration:  111\n",
      "Wass:   [0.79107143 0.72446429 0.55267857]\n",
      "SWass:  [0.76875    0.69839286 0.57883929]\n",
      "PS:     [0.84919643 0.80892857 0.6975    ]\n",
      "PL:     [0.76633929 0.67071429 0.54133929]\n",
      "PI:     [0.79678571 0.74580357 0.61232143]\n",
      "PSpl:   [0.569375   0.54178571 0.5175    ]\n",
      "\n",
      "\n",
      " Iteration:  112\n",
      "Wass:   [0.79247788 0.72256637 0.55230088]\n",
      "SWass:  [0.77044248 0.70044248 0.57823009]\n",
      "PS:     [0.85017699 0.8099115  0.69769912]\n",
      "PL:     [0.7680531  0.66929204 0.54106195]\n",
      "PI:     [0.79831858 0.74584071 0.61185841]\n",
      "PSpl:   [0.56911504 0.54176991 0.51752212]\n",
      "\n",
      "\n",
      " Iteration:  113\n",
      "Wass:   [0.79       0.72078947 0.55184211]\n",
      "SWass:  [0.76894737 0.69973684 0.5795614 ]\n",
      "PS:     [0.84763158 0.80763158 0.69736842]\n",
      "PL:     [0.76578947 0.66807018 0.54114035]\n",
      "PI:     [0.79657895 0.74412281 0.61157895]\n",
      "PSpl:   [0.56868421 0.54149123 0.51745614]\n",
      "\n",
      "\n",
      " Iteration:  114\n",
      "Wass:   [0.79130435 0.71886957 0.5513913 ]\n",
      "SWass:  [0.76669565 0.69826087 0.57913043]\n",
      "PS:     [0.84756522 0.8073913  0.69634783]\n",
      "PL:     [0.76617391 0.66669565 0.54104348]\n",
      "PI:     [0.796      0.74243478 0.612     ]\n",
      "PSpl:   [0.56834783 0.54121739 0.5173913 ]\n",
      "\n",
      "\n",
      " Iteration:  115\n",
      "Wass:   [0.78887931 0.71698276 0.55103448]\n",
      "SWass:  [0.76448276 0.69663793 0.57887931]\n",
      "PS:     [0.84517241 0.80543103 0.69491379]\n",
      "PL:     [0.76396552 0.66534483 0.54077586]\n",
      "PI:     [0.79405172 0.74094828 0.61112069]\n",
      "PSpl:   [0.56793103 0.54103448 0.51732759]\n",
      "\n",
      "\n",
      " Iteration:  116\n",
      "Wass:   [0.78982906 0.71923077 0.55068376]\n",
      "SWass:  [0.76598291 0.69897436 0.57820513]\n",
      "PS:     [0.84581197 0.80632479 0.69478632]\n",
      "PL:     [0.76461538 0.66410256 0.54042735]\n",
      "PI:     [0.79461538 0.73923077 0.61239316]\n",
      "PSpl:   [0.5674359  0.54111111 0.51752137]\n",
      "\n",
      "\n",
      " Iteration:  117\n",
      "Wass:   [0.79152542 0.71737288 0.55025424]\n",
      "SWass:  [0.76381356 0.70084746 0.57754237]\n",
      "PS:     [0.8470339  0.80745763 0.69322034]\n",
      "PL:     [0.76245763 0.66271186 0.54008475]\n",
      "PI:     [0.79525424 0.73737288 0.61169492]\n",
      "PSpl:   [0.5670339  0.5409322  0.51754237]\n",
      "\n",
      "\n",
      " Iteration:  118\n",
      "Wass:   [0.79268908 0.71563025 0.54991597]\n",
      "SWass:  [0.76487395 0.69915966 0.57714286]\n",
      "PS:     [0.84722689 0.80521008 0.69193277]\n",
      "PL:     [0.7602521  0.66134454 0.53991597]\n",
      "PI:     [0.79428571 0.73571429 0.61151261]\n",
      "PSpl:   [0.56663866 0.54067227 0.51764706]\n",
      "\n",
      "\n",
      " Iteration:  119\n",
      "Wass:   [0.79391667 0.717      0.54958333]\n",
      "SWass:  [0.7665     0.69958333 0.57675   ]\n",
      "PS:     [0.84841667 0.80541667 0.69266667]\n",
      "PL:     [0.76141667 0.66008333 0.54      ]\n",
      "PI:     [0.79508333 0.73625    0.61333333]\n",
      "PSpl:   [0.56658333 0.54041667 0.51783333]\n",
      "\n",
      "\n",
      " Iteration:  120\n",
      "Wass:   [0.79157025 0.71528926 0.54917355]\n",
      "SWass:  [0.76793388 0.69793388 0.57694215]\n",
      "PS:     [0.84677686 0.80322314 0.69214876]\n",
      "PL:     [0.76280992 0.66140496 0.53991736]\n",
      "PI:     [0.79586777 0.73669421 0.61305785]\n",
      "PSpl:   [0.5661157  0.54024793 0.51809917]\n",
      "\n",
      "\n",
      " Iteration:  121\n",
      "Wass:   [0.79303279 0.71737705 0.54885246]\n",
      "SWass:  [0.76967213 0.69647541 0.57639344]\n",
      "PS:     [0.84762295 0.80434426 0.69377049]\n",
      "PL:     [0.76442623 0.66352459 0.5397541 ]\n",
      "PI:     [0.79393443 0.73770492 0.61254098]\n",
      "PSpl:   [0.56598361 0.54008197 0.51836066]\n",
      "\n",
      "\n",
      " Iteration:  122\n",
      "Wass:   [0.79447154 0.71569106 0.54853659]\n",
      "SWass:  [0.76837398 0.69520325 0.57577236]\n",
      "PS:     [0.84796748 0.80471545 0.69227642]\n",
      "PL:     [0.76569106 0.66365854 0.53943089]\n",
      "PI:     [0.79373984 0.73796748 0.61276423]\n",
      "PSpl:   [0.56560976 0.54       0.51829268]\n",
      "\n",
      "\n",
      " Iteration:  123\n",
      "Wass:   [0.79225806 0.71419355 0.54814516]\n",
      "SWass:  [0.76629032 0.69362903 0.57564516]\n",
      "PS:     [0.84725806 0.80274194 0.69137097]\n",
      "PL:     [0.76370968 0.66241935 0.53919355]\n",
      "PI:     [0.79362903 0.73733871 0.61233871]\n",
      "PSpl:   [0.56516129 0.53975806 0.5183871 ]\n",
      "\n",
      "\n",
      " Iteration:  124\n",
      "Wass:   [0.79    0.71256 0.54784]\n",
      "SWass:  [0.76424 0.69216 0.5752 ]\n",
      "PS:     [0.84744 0.8004  0.6904 ]\n",
      "PL:     [0.76176 0.66112 0.53904]\n",
      "PI:     [0.7916  0.73576 0.6116 ]\n",
      "PSpl:   [0.5648  0.53952 0.51832]\n",
      "\n",
      "\n",
      " Iteration:  125\n",
      "Wass:   [0.78777778 0.71095238 0.54753968]\n",
      "SWass:  [0.76222222 0.69063492 0.57460317]\n",
      "PS:     [0.84484127 0.80079365 0.68912698]\n",
      "PL:     [0.76111111 0.65984127 0.53873016]\n",
      "PI:     [0.79071429 0.73428571 0.61190476]\n",
      "PSpl:   [0.5647619  0.53936508 0.51833333]\n",
      "\n",
      "\n",
      " Iteration:  126\n",
      "Wass:   [0.78929134 0.71267717 0.54740157]\n",
      "SWass:  [0.76346457 0.6923622  0.57401575]\n",
      "PS:     [0.84582677 0.80173228 0.6880315 ]\n",
      "PL:     [0.7592126  0.66141732 0.53866142]\n",
      "PI:     [0.79133858 0.73259843 0.61181102]\n",
      "PSpl:   [0.56456693 0.5396063  0.51834646]\n",
      "\n",
      "\n",
      " Iteration:  127\n",
      "Wass:   [0.78703125 0.71460938 0.54726563]\n",
      "SWass:  [0.7615625  0.69445313 0.5734375 ]\n",
      "PS:     [0.84351563 0.803125   0.68945313]\n",
      "PL:     [0.7571875  0.66359375 0.5384375 ]\n",
      "PI:     [0.79164063 0.73296875 0.61265625]\n",
      "PSpl:   [0.56429688 0.5396875  0.51835938]\n",
      "\n",
      "\n",
      " Iteration:  128\n",
      "Wass:   [0.7848062  0.71302326 0.54689922]\n",
      "SWass:  [0.7627907  0.69573643 0.57302326]\n",
      "PS:     [0.8427907  0.80364341 0.68930233]\n",
      "PL:     [0.7551938  0.66232558 0.53813953]\n",
      "PI:     [0.79015504 0.73162791 0.61186047]\n",
      "PSpl:   [0.56395349 0.53945736 0.51821705]\n",
      "\n",
      "\n",
      " Iteration:  129\n",
      "Wass:   [0.78623077 0.71146154 0.54653846]\n",
      "SWass:  [0.76084615 0.69430769 0.57315385]\n",
      "PS:     [0.84046154 0.80261538 0.68853846]\n",
      "PL:     [0.75646154 0.664      0.538     ]\n",
      "PI:     [0.79123077 0.73246154 0.61169231]\n",
      "PSpl:   [0.56353846 0.53930769 0.51830769]\n",
      "\n",
      "\n",
      " Iteration:  130\n",
      "Wass:   [0.78755725 0.71328244 0.54900763]\n",
      "SWass:  [0.76206107 0.69274809 0.57549618]\n",
      "PS:     [0.84145038 0.80038168 0.69      ]\n",
      "PL:     [0.75473282 0.66335878 0.5380916 ]\n",
      "PI:     [0.79244275 0.73152672 0.61160305]\n",
      "PSpl:   [0.56320611 0.53916031 0.51839695]\n",
      "\n",
      "\n",
      " Iteration:  131\n",
      "Wass:   [0.78545455 0.71166667 0.54871212]\n",
      "SWass:  [0.76068182 0.69174242 0.57507576]\n",
      "PS:     [0.84159091 0.79825758 0.68871212]\n",
      "PL:     [0.75477273 0.66212121 0.53810606]\n",
      "PI:     [0.7905303  0.73007576 0.61121212]\n",
      "PSpl:   [0.56287879 0.53893939 0.51863636]\n",
      "\n",
      "\n",
      " Iteration:  132\n",
      "Wass:   [0.78706767 0.71368421 0.54842105]\n",
      "SWass:  [0.76233083 0.69390977 0.57481203]\n",
      "PS:     [0.84278195 0.7993985  0.69045113]\n",
      "PL:     [0.75646617 0.66458647 0.53781955]\n",
      "PI:     [0.79210526 0.73172932 0.61345865]\n",
      "PSpl:   [0.56240602 0.54015038 0.51857143]\n",
      "\n",
      "\n",
      " Iteration:  133\n",
      "Wass:   [0.78850746 0.71559701 0.55097015]\n",
      "SWass:  [0.76402985 0.69246269 0.57477612]\n",
      "PS:     [0.84380597 0.8008209  0.69179104]\n",
      "PL:     [0.75820896 0.66679104 0.53761194]\n",
      "PI:     [0.79074627 0.73052239 0.6130597 ]\n",
      "PSpl:   [0.56223881 0.54007463 0.51850746]\n",
      "\n",
      "\n",
      " Iteration:  134\n",
      "Wass:   [0.79       0.71748148 0.55066667]\n",
      "SWass:  [0.76548148 0.69451852 0.57674074]\n",
      "PS:     [0.84481481 0.80214815 0.69318519]\n",
      "PL:     [0.75637037 0.66555556 0.53748148]\n",
      "PI:     [0.7902963  0.72940741 0.61281481]\n",
      "PSpl:   [0.562      0.54007407 0.51837037]\n",
      "\n",
      "\n",
      " Iteration:  135\n",
      "Wass:   [0.79125    0.71602941 0.55051471]\n",
      "SWass:  [0.76367647 0.69316176 0.57625   ]\n",
      "PS:     [0.84411765 0.80029412 0.69205882]\n",
      "PL:     [0.75455882 0.66441176 0.53727941]\n",
      "PI:     [0.78897059 0.72823529 0.61294118]\n",
      "PSpl:   [0.56242647 0.53992647 0.51845588]\n",
      "\n",
      "\n",
      " Iteration:  136\n",
      "Wass:   [0.79277372 0.71788321 0.55021898]\n",
      "SWass:  [0.76518248 0.69182482 0.57576642]\n",
      "PS:     [0.84175182 0.80094891 0.69072993]\n",
      "PL:     [0.75613139 0.66656934 0.53708029]\n",
      "PI:     [0.79029197 0.7289781  0.61248175]\n",
      "PSpl:   [0.56240876 0.54043796 0.51839416]\n",
      "\n",
      "\n",
      " Iteration:  137\n",
      "Wass:   [0.79413043 0.71956522 0.54985507]\n",
      "SWass:  [0.76326087 0.6926087  0.57536232]\n",
      "PS:     [0.84246377 0.80137681 0.69202899]\n",
      "PL:     [0.7576087  0.66543478 0.53688406]\n",
      "PI:     [0.79166667 0.73028986 0.61253623]\n",
      "PSpl:   [0.56202899 0.54021739 0.5184058 ]\n",
      "\n",
      "\n",
      " Iteration:  138\n",
      "Wass:   [0.79208633 0.71805755 0.54964029]\n",
      "SWass:  [0.76143885 0.69151079 0.57517986]\n",
      "PS:     [0.8418705  0.80021583 0.69208633]\n",
      "PL:     [0.75604317 0.66438849 0.53661871]\n",
      "PI:     [0.79100719 0.7294964  0.61266187]\n",
      "PSpl:   [0.56165468 0.54       0.51841727]\n",
      "\n",
      "\n",
      " Iteration:  139\n",
      "Wass:   [0.79   0.7165 0.5495]\n",
      "SWass:  [0.75971429 0.6925     0.57464286]\n",
      "PS:     [0.84114286 0.79914286 0.69157143]\n",
      "PL:     [0.75421429 0.66335714 0.53642857]\n",
      "PI:     [0.7895     0.72857143 0.61207143]\n",
      "PSpl:   [0.56128571 0.53985714 0.51835714]\n",
      "\n",
      "\n",
      " Iteration:  140\n",
      "Wass:   [0.79134752 0.71836879 0.54921986]\n",
      "SWass:  [0.7612766  0.69460993 0.57744681]\n",
      "PS:     [0.8422695  0.80049645 0.6935461 ]\n",
      "PL:     [0.7558156  0.66560284 0.53631206]\n",
      "PI:     [0.79085106 0.73035461 0.61468085]\n",
      "PSpl:   [0.56120567 0.53971631 0.51829787]\n",
      "\n",
      "\n",
      " Iteration:  141\n",
      "Wass:   [0.78943662 0.71690141 0.54894366]\n",
      "SWass:  [0.75985915 0.69330986 0.57697183]\n",
      "PS:     [0.84042254 0.79894366 0.69239437]\n",
      "PL:     [0.75591549 0.66464789 0.53612676]\n",
      "PI:     [0.79049296 0.72922535 0.61443662]\n",
      "PSpl:   [0.56098592 0.53964789 0.51823944]\n",
      "\n",
      "\n",
      " Iteration:  142\n",
      "Wass:   [0.7906993  0.71538462 0.54867133]\n",
      "SWass:  [0.76153846 0.6948951  0.57923077]\n",
      "PS:     [0.8413986  0.80006993 0.69125874]\n",
      "PL:     [0.75727273 0.66356643 0.53594406]\n",
      "PI:     [0.78909091 0.72783217 0.61398601]\n",
      "PSpl:   [0.56062937 0.53951049 0.51818182]\n",
      "\n",
      "\n",
      " Iteration:  143\n",
      "Wass:   [0.79166667 0.71388889 0.54833333]\n",
      "SWass:  [0.75979167 0.69354167 0.57881944]\n",
      "PS:     [0.84048611 0.79951389 0.69069444]\n",
      "PL:     [0.75555556 0.6625     0.53604167]\n",
      "PI:     [0.78770833 0.72722222 0.61354167]\n",
      "PSpl:   [0.56027778 0.53965278 0.51819444]\n",
      "\n",
      "\n",
      " Iteration:  144\n",
      "Wass:   [0.79303448 0.71565517 0.548     ]\n",
      "SWass:  [0.76117241 0.69524138 0.57903448]\n",
      "PS:     [0.84124138 0.80075862 0.69158621]\n",
      "PL:     [0.75386207 0.66158621 0.5357931 ]\n",
      "PI:     [0.78593103 0.72593103 0.61296552]\n",
      "PSpl:   [0.56       0.53944828 0.51806897]\n",
      "\n",
      "\n",
      " Iteration:  145\n",
      "Wass:   [0.79109589 0.71431507 0.54767123]\n",
      "SWass:  [0.75972603 0.6939726  0.57849315]\n",
      "PS:     [0.8389726  0.80054795 0.69061644]\n",
      "PL:     [0.75219178 0.66321918 0.53554795]\n",
      "PI:     [0.78431507 0.72506849 0.61239726]\n",
      "PSpl:   [0.56013699 0.53917808 0.5180137 ]\n",
      "\n",
      "\n",
      " Iteration:  146\n",
      "Wass:   [0.78911565 0.71292517 0.54741497]\n",
      "SWass:  [0.75795918 0.6929932  0.57802721]\n",
      "PS:     [0.83857143 0.79979592 0.68979592]\n",
      "PL:     [0.75061224 0.66217687 0.53537415]\n",
      "PI:     [0.78278912 0.72462585 0.61204082]\n",
      "PSpl:   [0.55986395 0.53897959 0.51795918]\n",
      "\n",
      "\n",
      " Iteration:  147\n",
      "Wass:   [0.79047297 0.71425676 0.54709459]\n",
      "SWass:  [0.75945946 0.69466216 0.57756757]\n",
      "PS:     [0.83952703 0.80054054 0.68912162]\n",
      "PL:     [0.75209459 0.66168919 0.53527027]\n",
      "PI:     [0.78202703 0.72412162 0.61168919]\n",
      "PSpl:   [0.55959459 0.53885135 0.51790541]\n",
      "\n",
      "\n",
      " Iteration:  148\n",
      "Wass:   [0.7885906  0.71288591 0.54684564]\n",
      "SWass:  [0.75785235 0.6933557  0.57711409]\n",
      "PS:     [0.83959732 0.80040268 0.68912752]\n",
      "PL:     [0.75053691 0.66060403 0.53510067]\n",
      "PI:     [0.78087248 0.72302013 0.6114094 ]\n",
      "PSpl:   [0.55926174 0.53865772 0.51785235]\n",
      "\n",
      "\n",
      " Iteration:  149\n",
      "Wass:   [0.7898     0.71166667 0.54666667]\n",
      "SWass:  [0.75933333 0.69246667 0.5766    ]\n",
      "PS:     [0.84   0.7986 0.688 ]\n",
      "PL:     [0.75106667 0.6618     0.53486667]\n",
      "PI:     [0.78166667 0.7236     0.6122    ]\n",
      "PSpl:   [0.559      0.53886667 0.51786667]\n",
      "\n",
      "\n",
      " Iteration:  150\n",
      "Wass:   [0.78794702 0.71033113 0.54635762]\n",
      "SWass:  [0.75761589 0.69125828 0.57615894]\n",
      "PS:     [0.83774834 0.79768212 0.68708609]\n",
      "PL:     [0.7494702  0.66072848 0.53463576]\n",
      "PI:     [0.78046358 0.72251656 0.61172185]\n",
      "PSpl:   [0.55874172 0.5386755  0.51788079]\n",
      "\n",
      "\n",
      " Iteration:  151\n",
      "Wass:   [0.78907895 0.71177632 0.54611842]\n",
      "SWass:  [0.75901316 0.69289474 0.57657895]\n",
      "PS:     [0.83855263 0.79875    0.68802632]\n",
      "PL:     [0.75085526 0.66256579 0.53447368]\n",
      "PI:     [0.78118421 0.72381579 0.61328947]\n",
      "PSpl:   [0.55901316 0.53875    0.51782895]\n",
      "\n",
      "\n",
      " Iteration:  152\n",
      "Wass:   [0.7903268  0.71339869 0.54581699]\n",
      "SWass:  [0.76052288 0.69444444 0.57614379]\n",
      "PS:     [0.83947712 0.79986928 0.68915033]\n",
      "PL:     [0.7524183  0.66431373 0.53627451]\n",
      "PI:     [0.78228758 0.7251634  0.61437908]\n",
      "PSpl:   [0.55875817 0.53869281 0.5179085 ]\n",
      "\n",
      "\n",
      " Iteration:  153\n",
      "Wass:   [0.78850649 0.71207792 0.54577922]\n",
      "SWass:  [0.75987013 0.69337662 0.57642857]\n",
      "PS:     [0.8388961  0.80058442 0.68857143]\n",
      "PL:     [0.75123377 0.66577922 0.53623377]\n",
      "PI:     [0.78253247 0.72655844 0.61383117]\n",
      "PSpl:   [0.55857143 0.53863636 0.51785714]\n",
      "\n",
      "\n",
      " Iteration:  154\n",
      "Wass:   [0.78974194 0.7136129  0.54612903]\n",
      "SWass:  [0.76135484 0.69516129 0.576     ]\n",
      "PS:     [0.83987097 0.8016129  0.68754839]\n",
      "PL:     [0.75251613 0.66477419 0.53625806]\n",
      "PI:     [0.78354839 0.72522581 0.61341935]\n",
      "PSpl:   [0.55832258 0.53851613 0.51780645]\n",
      "\n",
      "\n",
      " Iteration:  155\n",
      "Wass:   [0.79108974 0.7149359  0.54583333]\n",
      "SWass:  [0.76275641 0.69666667 0.57557692]\n",
      "PS:     [0.84076923 0.80237179 0.68653846]\n",
      "PL:     [0.75365385 0.66660256 0.53820513]\n",
      "PI:     [0.78192308 0.72435897 0.61294872]\n",
      "PSpl:   [0.55807692 0.53871795 0.51807692]\n",
      "\n",
      "\n",
      " Iteration:  156\n",
      "Wass:   [0.78929936 0.71363057 0.5456051 ]\n",
      "SWass:  [0.76369427 0.69573248 0.57515924]\n",
      "PS:     [0.84070064 0.80210191 0.68541401]\n",
      "PL:     [0.75356688 0.66796178 0.53796178]\n",
      "PI:     [0.78178344 0.72407643 0.61254777]\n",
      "PSpl:   [0.55783439 0.53872611 0.51796178]\n",
      "\n",
      "\n",
      " Iteration:  157\n",
      "Wass:   [0.79006329 0.71234177 0.54537975]\n",
      "SWass:  [0.76208861 0.69455696 0.57556962]\n",
      "PS:     [0.84006329 0.80151899 0.6856962 ]\n",
      "PL:     [0.75196203 0.66696203 0.53778481]\n",
      "PI:     [0.78044304 0.72291139 0.61221519]\n",
      "PSpl:   [0.55772152 0.5385443  0.51816456]\n",
      "\n",
      "\n",
      " Iteration:  158\n",
      "Wass:   [0.79119497 0.71113208 0.54515723]\n",
      "SWass:  [0.76050314 0.69345912 0.57515723]\n",
      "PS:     [0.84018868 0.80012579 0.68509434]\n",
      "PL:     [0.75314465 0.66867925 0.53767296]\n",
      "PI:     [0.77962264 0.72333333 0.61295597]\n",
      "PSpl:   [0.55748428 0.53842767 0.51811321]\n",
      "\n",
      "\n",
      " Iteration:  159\n",
      "Wass:   [0.7921875 0.7125625 0.5449375]\n",
      "SWass:  [0.7616875 0.694375  0.57475  ]\n",
      "PS:     [0.84075   0.8006875 0.6860625]\n",
      "PL:     [0.751625 0.667625 0.5375  ]\n",
      "PI:     [0.7795625 0.7235    0.6131875]\n",
      "PSpl:   [0.5573125 0.538375  0.5183125]\n",
      "\n",
      "\n",
      " Iteration:  160\n",
      "Wass:   [0.79341615 0.71391304 0.54484472]\n",
      "SWass:  [0.76012422 0.69583851 0.57447205]\n",
      "PS:     [0.8415528  0.80161491 0.68552795]\n",
      "PL:     [0.7531677  0.66937888 0.53751553]\n",
      "PI:     [0.78086957 0.72484472 0.61341615]\n",
      "PSpl:   [0.55708075 0.53819876 0.51826087]\n",
      "\n",
      "\n",
      " Iteration:  161\n",
      "Wass:   [0.79425926 0.71549383 0.5445679 ]\n",
      "SWass:  [0.75864198 0.69641975 0.57438272]\n",
      "PS:     [0.84160494 0.80185185 0.68512346]\n",
      "PL:     [0.75160494 0.66907407 0.53728395]\n",
      "PI:     [0.78135802 0.72549383 0.61283951]\n",
      "PSpl:   [0.55685185 0.53808642 0.51820988]\n",
      "\n",
      "\n",
      " Iteration:  162\n",
      "Wass:   [0.79539877 0.71699387 0.54435583]\n",
      "SWass:  [0.75957055 0.69809816 0.57644172]\n",
      "PS:     [0.84239264 0.80294479 0.68662577]\n",
      "PL:     [0.7501227  0.67055215 0.53730061]\n",
      "PI:     [0.78       0.72570552 0.61233129]\n",
      "PSpl:   [0.55687117 0.53797546 0.51828221]\n",
      "\n",
      "\n",
      " Iteration:  163\n",
      "Wass:   [0.79664634 0.71853659 0.54408537]\n",
      "SWass:  [0.76085366 0.69981707 0.57597561]\n",
      "PS:     [0.84329268 0.80396341 0.68780488]\n",
      "PL:     [0.75146341 0.67237805 0.53713415]\n",
      "PI:     [0.78109756 0.72719512 0.61371951]\n",
      "PSpl:   [0.55676829 0.53786585 0.51817073]\n",
      "\n",
      "\n",
      " Iteration:  164\n",
      "Wass:   [0.79775758 0.71721212 0.544     ]\n",
      "SWass:  [0.76206061 0.70145455 0.57563636]\n",
      "PS:     [0.84381818 0.80472727 0.68757576]\n",
      "PL:     [0.75115152 0.67406061 0.53727273]\n",
      "PI:     [0.7810303  0.72721212 0.61430303]\n",
      "PSpl:   [0.55709091 0.53781818 0.51806061]\n",
      "\n",
      "\n",
      " Iteration:  165\n",
      "Wass:   [0.79879518 0.71596386 0.54379518]\n",
      "SWass:  [0.76054217 0.7010241  0.57524096]\n",
      "PS:     [0.84451807 0.80518072 0.68753012]\n",
      "PL:     [0.7523494  0.67313253 0.53710843]\n",
      "PI:     [0.78222892 0.72626506 0.6139759 ]\n",
      "PSpl:   [0.55710843 0.5376506  0.51801205]\n",
      "\n",
      "\n",
      " Iteration:  166\n",
      "Wass:   [0.79982036 0.71712575 0.54353293]\n",
      "SWass:  [0.75904192 0.70035928 0.57479042]\n",
      "PS:     [0.84377246 0.80508982 0.68658683]\n",
      "PL:     [0.75101796 0.67215569 0.53694611]\n",
      "PI:     [0.78323353 0.72748503 0.6139521 ]\n",
      "PSpl:   [0.55682635 0.53754491 0.51802395]\n",
      "\n",
      "\n",
      " Iteration:  167\n",
      "Wass:   [0.79821429 0.71690476 0.54333333]\n",
      "SWass:  [0.76035714 0.69922619 0.57440476]\n",
      "PS:     [0.8439881  0.80428571 0.68571429]\n",
      "PL:     [0.75005952 0.67184524 0.53708333]\n",
      "PI:     [0.78190476 0.72684524 0.61339286]\n",
      "PSpl:   [0.55660714 0.5375     0.51803571]\n",
      "\n",
      "\n",
      " Iteration:  168\n",
      "Wass:   [0.79940828 0.7156213  0.54307692]\n",
      "SWass:  [0.76118343 0.69810651 0.5739645 ]\n",
      "PS:     [0.84449704 0.80485207 0.68467456]\n",
      "PL:     [0.75094675 0.67307692 0.53686391]\n",
      "PI:     [0.78284024 0.72781065 0.61390533]\n",
      "PSpl:   [0.55804734 0.53733728 0.51798817]\n",
      "\n",
      "\n",
      " Iteration:  169\n",
      "Wass:   [0.80035294 0.71694118 0.54282353]\n",
      "SWass:  [0.75970588 0.69947059 0.57364706]\n",
      "PS:     [0.84517647 0.80570588 0.68541176]\n",
      "PL:     [0.75223529 0.67476471 0.53664706]\n",
      "PI:     [0.78388235 0.72911765 0.61535294]\n",
      "PSpl:   [0.55782353 0.53741176 0.51794118]\n",
      "\n",
      "\n",
      " Iteration:  170\n",
      "Wass:   [0.80105263 0.71573099 0.54269006]\n",
      "SWass:  [0.75830409 0.69836257 0.57380117]\n",
      "PS:     [0.84578947 0.80619883 0.68555556]\n",
      "PL:     [0.75321637 0.67380117 0.53649123]\n",
      "PI:     [0.78479532 0.73       0.61666667]\n",
      "PSpl:   [0.55766082 0.5374269  0.51789474]\n",
      "\n",
      "\n",
      " Iteration:  171\n",
      "Wass:   [0.80197674 0.71447674 0.54255814]\n",
      "SWass:  [0.75680233 0.6972093  0.57348837]\n",
      "PS:     [0.84639535 0.80639535 0.68656977]\n",
      "PL:     [0.75174419 0.6727907  0.53627907]\n",
      "PI:     [0.78517442 0.72877907 0.61726744]\n",
      "PSpl:   [0.55755814 0.53726744 0.51784884]\n",
      "\n",
      "\n",
      " Iteration:  172\n",
      "Wass:   [0.80294798 0.7132948  0.54242775]\n",
      "SWass:  [0.75549133 0.69624277 0.57312139]\n",
      "PS:     [0.84468208 0.80543353 0.68578035]\n",
      "PL:     [0.75236994 0.67184971 0.53612717]\n",
      "PI:     [0.78381503 0.72780347 0.61682081]\n",
      "PSpl:   [0.55745665 0.53710983 0.51786127]\n",
      "\n",
      "\n",
      " Iteration:  173\n",
      "Wass:   [0.80396552 0.71471264 0.54482759]\n",
      "SWass:  [0.75678161 0.69793103 0.57511494]\n",
      "PS:     [0.84557471 0.80649425 0.68712644]\n",
      "PL:     [0.75362069 0.67091954 0.53609195]\n",
      "PI:     [0.785      0.72672414 0.61752874]\n",
      "PSpl:   [0.55718391 0.53701149 0.51787356]\n",
      "\n",
      "\n",
      " Iteration:  174\n",
      "Wass:   [0.80474286 0.71354286 0.54462857]\n",
      "SWass:  [0.75782857 0.69874286 0.57468571]\n",
      "PS:     [0.84622857 0.80697143 0.68611429]\n",
      "PL:     [0.75468571 0.67       0.53588571]\n",
      "PI:     [0.78365714 0.72582857 0.61697143]\n",
      "PSpl:   [0.55685714 0.53685714 0.51782857]\n",
      "\n",
      "\n",
      " Iteration:  175\n",
      "Wass:   [0.80568182 0.715      0.54448864]\n",
      "SWass:  [0.75903409 0.70028409 0.57676136]\n",
      "PS:     [0.84704545 0.80806818 0.68761364]\n",
      "PL:     [0.75607955 0.67176136 0.53573864]\n",
      "PI:     [0.78477273 0.72710227 0.61647727]\n",
      "PSpl:   [0.556875   0.53676136 0.51778409]\n",
      "\n",
      "\n",
      " Iteration:  176\n",
      "Wass:   [0.80677966 0.71632768 0.54429379]\n",
      "SWass:  [0.76033898 0.70169492 0.57649718]\n",
      "PS:     [0.84757062 0.80881356 0.68717514]\n",
      "PL:     [0.75689266 0.67299435 0.53689266]\n",
      "PI:     [0.78474576 0.72700565 0.61706215]\n",
      "PSpl:   [0.55677966 0.53740113 0.5180226 ]\n",
      "\n",
      "\n",
      " Iteration:  177\n",
      "Wass:   [0.80505618 0.71516854 0.54404494]\n",
      "SWass:  [0.7588764  0.70061798 0.5761236 ]\n",
      "PS:     [0.84567416 0.80831461 0.68662921]\n",
      "PL:     [0.7555618  0.67241573 0.53674157]\n",
      "PI:     [0.78398876 0.72685393 0.61651685]\n",
      "PSpl:   [0.55651685 0.53730337 0.51803371]\n",
      "\n",
      "\n",
      " Iteration:  178\n",
      "Wass:   [0.80597765 0.71653631 0.54385475]\n",
      "SWass:  [0.75960894 0.70201117 0.57597765]\n",
      "PS:     [0.84625698 0.80899441 0.68586592]\n",
      "PL:     [0.75681564 0.67346369 0.53664804]\n",
      "PI:     [0.7849162  0.72787709 0.6175419 ]\n",
      "PSpl:   [0.55670391 0.53731844 0.51810056]\n",
      "\n",
      "\n",
      " Iteration:  179\n",
      "Wass:   [0.80683333 0.71544444 0.54383333]\n",
      "SWass:  [0.75844444 0.70094444 0.57555556]\n",
      "PS:     [0.84638889 0.80794444 0.68627778]\n",
      "PL:     [0.75788889 0.67261111 0.53644444]\n",
      "PI:     [0.7855     0.72716667 0.61783333]\n",
      "PSpl:   [0.55644444 0.53727778 0.518     ]\n",
      "\n",
      "\n",
      " Iteration:  180\n",
      "Wass:   [0.80790055 0.71696133 0.54364641]\n",
      "SWass:  [0.75961326 0.69994475 0.57519337]\n",
      "PS:     [0.84707182 0.80883978 0.68530387]\n",
      "PL:     [0.75906077 0.67430939 0.53629834]\n",
      "PI:     [0.78651934 0.72839779 0.61779006]\n",
      "PSpl:   [0.55618785 0.53718232 0.51801105]\n",
      "\n",
      "\n",
      " Iteration:  181\n",
      "Wass:   [0.80895604 0.71851648 0.54340659]\n",
      "SWass:  [0.76076923 0.6989011  0.5760989 ]\n",
      "PS:     [0.84769231 0.80945055 0.68620879]\n",
      "PL:     [0.76021978 0.67604396 0.5360989 ]\n",
      "PI:     [0.78758242 0.72983516 0.61917582]\n",
      "PSpl:   [0.55598901 0.53818681 0.51796703]\n",
      "\n",
      "\n",
      " Iteration:  182\n",
      "Wass:   [0.8073224  0.71748634 0.54344262]\n",
      "SWass:  [0.76021858 0.69786885 0.5757377 ]\n",
      "PS:     [0.84606557 0.80814208 0.68535519]\n",
      "PL:     [0.75918033 0.67519126 0.53612022]\n",
      "PI:     [0.78786885 0.72879781 0.61874317]\n",
      "PSpl:   [0.55590164 0.53808743 0.5179235 ]\n",
      "\n",
      "\n",
      " Iteration:  183\n",
      "Wass:   [0.80820652 0.71902174 0.54505435]\n",
      "SWass:  [0.76141304 0.69951087 0.57532609]\n",
      "PS:     [0.84652174 0.80891304 0.68586957]\n",
      "PL:     [0.76043478 0.67679348 0.53592391]\n",
      "PI:     [0.78896739 0.7298913  0.61972826]\n",
      "PSpl:   [0.55570652 0.53798913 0.51793478]\n",
      "\n",
      "\n",
      " Iteration:  184\n",
      "Wass:   [0.80886486 0.71967568 0.54486486]\n",
      "SWass:  [0.76227027 0.7007027  0.57664865]\n",
      "PS:     [0.84691892 0.80951351 0.68702703]\n",
      "PL:     [0.75908108 0.67821622 0.53578378]\n",
      "PI:     [0.78962162 0.73075676 0.62075676]\n",
      "PSpl:   [0.55551351 0.53843243 0.51816216]\n",
      "\n",
      "\n",
      " Iteration:  185\n",
      "Wass:   [0.8094086  0.71849462 0.54462366]\n",
      "SWass:  [0.76086022 0.69962366 0.57629032]\n",
      "PS:     [0.84709677 0.80908602 0.68709677]\n",
      "PL:     [0.75768817 0.67731183 0.53591398]\n",
      "PI:     [0.78849462 0.73016129 0.62075269]\n",
      "PSpl:   [0.55543011 0.53822581 0.51811828]\n",
      "\n",
      "\n",
      " Iteration:  186\n",
      "Wass:   [0.81016043 0.71941176 0.5444385 ]\n",
      "SWass:  [0.75951872 0.69855615 0.5759893 ]\n",
      "PS:     [0.84529412 0.80946524 0.68679144]\n",
      "PL:     [0.75631016 0.67700535 0.53572193]\n",
      "PI:     [0.78727273 0.72951872 0.62080214]\n",
      "PSpl:   [0.55529412 0.53828877 0.51812834]\n",
      "\n",
      "\n",
      " Iteration:  187\n",
      "Wass:   [0.81106383 0.72026596 0.54420213]\n",
      "SWass:  [0.76047872 0.69776596 0.57702128]\n",
      "PS:     [0.84595745 0.80957447 0.68734043]\n",
      "PL:     [0.75494681 0.67606383 0.5356383 ]\n",
      "PI:     [0.78712766 0.72930851 0.62053191]\n",
      "PSpl:   [0.55510638 0.53840426 0.5181383 ]\n",
      "\n",
      "\n",
      " Iteration:  188\n",
      "Wass:   [0.81195767 0.72164021 0.54402116]\n",
      "SWass:  [0.76164021 0.69925926 0.57687831]\n",
      "PS:     [0.84677249 0.81058201 0.68883598]\n",
      "PL:     [0.75613757 0.67777778 0.53798942]\n",
      "PI:     [0.78820106 0.73074074 0.62248677]\n",
      "PSpl:   [0.55687831 0.53835979 0.51814815]\n",
      "\n",
      "\n",
      " Iteration:  189\n",
      "Wass:   [0.81273684 0.72057895 0.54394737]\n",
      "SWass:  [0.76052632 0.69826316 0.57647368]\n",
      "PS:     [0.84615789 0.80989474 0.68842105]\n",
      "PL:     [0.75489474 0.67689474 0.53815789]\n",
      "PI:     [0.78868421 0.73089474 0.62215789]\n",
      "PSpl:   [0.55747368 0.53868421 0.51810526]\n",
      "\n",
      "\n",
      " Iteration:  190\n",
      "Wass:   [0.81335079 0.71947644 0.54376963]\n",
      "SWass:  [0.75921466 0.69722513 0.5760733 ]\n",
      "PS:     [0.84497382 0.80884817 0.68743455]\n",
      "PL:     [0.75382199 0.67602094 0.53801047]\n",
      "PI:     [0.7873822  0.72994764 0.62183246]\n",
      "PSpl:   [0.55727749 0.53863874 0.5182199 ]\n",
      "\n",
      "\n",
      " Iteration:  191\n",
      "Wass:   [0.81171875 0.7184375  0.54359375]\n",
      "SWass:  [0.76026042 0.69697917 0.57630208]\n",
      "PS:     [0.84536458 0.80942708 0.68671875]\n",
      "PL:     [0.75286458 0.67536458 0.53786458]\n",
      "PI:     [0.78614583 0.72885417 0.62161458]\n",
      "PSpl:   [0.55723958 0.53869792 0.51822917]\n",
      "\n",
      "\n",
      " Iteration:  192\n",
      "Wass:   [0.8126943  0.71979275 0.54533679]\n",
      "SWass:  [0.76129534 0.69834197 0.57590674]\n",
      "PS:     [0.84606218 0.81031088 0.68772021]\n",
      "PL:     [0.75404145 0.67626943 0.53948187]\n",
      "PI:     [0.78673575 0.72984456 0.62139896]\n",
      "PSpl:   [0.55704663 0.53870466 0.51818653]\n",
      "\n",
      "\n",
      " Iteration:  193\n",
      "Wass:   [0.81108247 0.71871134 0.54515464]\n",
      "SWass:  [0.76030928 0.69737113 0.57587629]\n",
      "PS:     [0.84551546 0.80891753 0.68685567]\n",
      "PL:     [0.75278351 0.67536082 0.53927835]\n",
      "PI:     [0.78556701 0.72876289 0.62108247]\n",
      "PSpl:   [0.55680412 0.53850515 0.51819588]\n",
      "\n",
      "\n",
      " Iteration:  194\n",
      "Wass:   [0.80958974 0.71764103 0.54492308]\n",
      "SWass:  [0.76117949 0.69641026 0.57687179]\n",
      "PS:     [0.84610256 0.80851282 0.68646154]\n",
      "PL:     [0.75164103 0.67523077 0.53969231]\n",
      "PI:     [0.78425641 0.72917949 0.62102564]\n",
      "PSpl:   [0.55661538 0.53846154 0.51815385]\n",
      "\n",
      "\n",
      " Iteration:  195\n",
      "Wass:   [0.80806122 0.71658163 0.5447449 ]\n",
      "SWass:  [0.75989796 0.69545918 0.57663265]\n",
      "PS:     [0.8444898  0.8069898  0.68566327]\n",
      "PL:     [0.75040816 0.67459184 0.53954082]\n",
      "PI:     [0.78382653 0.72831633 0.62071429]\n",
      "PSpl:   [0.55642857 0.53831633 0.51816327]\n",
      "\n",
      "\n",
      " Iteration:  196\n",
      "Wass:   [0.80903553 0.71548223 0.54451777]\n",
      "SWass:  [0.76111675 0.69446701 0.57670051]\n",
      "PS:     [0.84522843 0.80593909 0.68568528]\n",
      "PL:     [0.75167513 0.67375635 0.53974619]\n",
      "PI:     [0.78446701 0.7293401  0.6206599 ]\n",
      "PSpl:   [0.55624365 0.53827411 0.51807107]\n",
      "\n",
      "\n",
      " Iteration:  197\n",
      "Wass:   [0.81       0.71671717 0.54666667]\n",
      "SWass:  [0.76232323 0.69585859 0.57641414]\n",
      "PS:     [0.8460101  0.80681818 0.68712121]\n",
      "PL:     [0.75292929 0.67535354 0.54191919]\n",
      "PI:     [0.78555556 0.73060606 0.62075758]\n",
      "PSpl:   [0.5560101  0.53818182 0.5180303 ]\n",
      "\n",
      "\n",
      " Iteration:  198\n",
      "Wass:   [0.80864322 0.71562814 0.54648241]\n",
      "SWass:  [0.76105528 0.69487437 0.5760804 ]\n",
      "PS:     [0.84437186 0.80532663 0.68623116]\n",
      "PL:     [0.75170854 0.67452261 0.54170854]\n",
      "PI:     [0.78502513 0.7301005  0.62055276]\n",
      "PSpl:   [0.55582915 0.5380402  0.5181407 ]\n",
      "\n",
      "\n",
      " Iteration:  199\n",
      "Wass:   [0.8096  0.71695 0.5481 ]\n",
      "SWass:  [0.76225 0.6964  0.5779 ]\n",
      "PS:     [0.84515 0.8063  0.6876 ]\n",
      "PL:     [0.75295 0.6759  0.54165]\n",
      "PI:     [0.7859  0.73045 0.62055]\n",
      "PSpl:   [0.55565 0.53825 0.5182 ]\n"
     ]
    }
   ],
   "source": [
    "np.random.seed(17051991)\n",
    "\n",
    "var = 50\n",
    "n_pts = 200\n",
    "\n",
    "\n",
    "n_class = 2\n",
    "\n",
    "colors = ['b','r','g']\n",
    "labels = ['f','g','h']\n",
    "\n",
    "N = 50 # number of functions in each class\n",
    "n = 500 # cardinality of the random grid where noise is added \n",
    "\n",
    "EPS = np.array([10.0,15.0,30.0])\n",
    "\n",
    "ACC_WASS = []\n",
    "ACC_SWASS = []\n",
    "ACC_PS = []\n",
    "ACC_PL = []\n",
    "ACC_PI = []\n",
    "ACC_PSpl = []\n",
    "\n",
    "m_ACC_WASS = np.zeros_like(EPS)\n",
    "m_ACC_SWASS = np.zeros_like(EPS)\n",
    "m_ACC_PS = np.zeros_like(EPS)\n",
    "m_ACC_PL = np.zeros_like(EPS)\n",
    "m_ACC_PI = np.zeros_like(EPS)\n",
    "m_ACC_PSpl = np.zeros_like(EPS)\n",
    "\n",
    "\n",
    "for count in range(200):\n",
    "\n",
    "    print('\\n\\n Iteration: ',count)\n",
    "    \n",
    "    crit_pts = np.zeros((n_class,n_pts))\n",
    "    crit_grid = np.linspace(0,1,n_pts)\n",
    "    \n",
    "    smooth_grid = np.linspace(0,1,100)\n",
    "    smooth = np.zeros((n_class,len(smooth_grid)))\n",
    "    \n",
    "    smooth_splines = []\n",
    "    \n",
    "    for i in range(n_class):\n",
    "        crit_pts[i,:] = np.random.normal(0,var,n_pts)\n",
    "        smooth_splines.append(spline(crit_grid,crit_pts[i,:], kind = 'cubic'))\n",
    "\n",
    "    DATA = []\n",
    "    DGMS = []\n",
    "    \n",
    "    \n",
    "    for eps in EPS:\n",
    "    \n",
    "        data_eps = np.zeros((n_class*N, len(smooth_grid))) \n",
    "        DGMS_eps = []\n",
    "    \n",
    "        cnt = 0\n",
    "    \n",
    "        for i in range(n_class):\n",
    "            for _ in range(N):\n",
    "    \n",
    "                grid = np.sort(np.random.uniform(0,1,n))\n",
    "                crit = smooth_splines[i](grid)\n",
    "                noise = np.random.normal(0,eps,n)\n",
    "    \n",
    "                noisy_crit = crit + noise\n",
    "                noisy_f = spline(grid,noisy_crit, kind = 'nearest',fill_value='extrapolate')\n",
    "                \n",
    "                f_lower_star = oin.freudenthal_filtration(data=noisy_f(smooth_grid), max_dim=1)\n",
    "                dcmp = oin.Decomposition(f_lower_star, False)\n",
    "                dcmp.reduce()\n",
    "                dgms = dcmp.diagram(f_lower_star, include_inf_points=False)\n",
    "                dgm = dgms.in_dimension(0)\n",
    "                \n",
    "                DGMS_eps.append(dgm)\n",
    "    \n",
    "                data_eps[cnt,:] = noisy_f(smooth_grid)\n",
    "               \n",
    "                cnt+=1\n",
    "        \n",
    "        DATA.append(data_eps)\n",
    "        DGMS.append(DGMS_eps) \n",
    "\n",
    "    WASS = []\n",
    "\n",
    "    for i,DGMS_eps in enumerate(DGMS):\n",
    "        print('Noise: ',EPS[i],'    ',end='\\r')\n",
    "    \n",
    "        D_W = np.zeros((n_class*N,n_class*N))\n",
    "    \n",
    "        for k,dgm0 in enumerate(DGMS_eps):\n",
    "            for j,dgm1 in enumerate(DGMS_eps[k:]):\n",
    "                D_W[k,j+k] = wasserstein_distance(dgm0, dgm1, matching=False, \n",
    "                                                            order=1.0, \n",
    "                                                            enable_autodiff=False, \n",
    "                                                            keep_essential_parts=False)\n",
    "    \n",
    "        D_W = D_W+D_W.T\n",
    "    \n",
    "        WASS.append(D_W)\n",
    "    \n",
    "        T = dendrolink(D_W, linkage = 'average', root = False, root_height = 1)\n",
    "        T.make_mult(f=False)\n",
    "        labels = T.cut_tree((T.f_uniq[-1]+T.f_uniq[-2])/2)\n",
    "    \n",
    "        aux_0 = np.sum(np.array(labels[0])<N)+np.sum(np.array(labels[1])>N-1)\n",
    "        aux_1 = np.sum(np.array(labels[0])>N)+np.sum(np.array(labels[1])<N-1)\n",
    "    \n",
    "        acc = np.max([aux_0,aux_1])/(2*N)\n",
    "    \n",
    "#        print('1-Wass. Clustering Accuracy: ',acc)\n",
    "\n",
    "        ACC_WASS.append(acc)\n",
    "        m_ACC_WASS[i] +=acc\n",
    "\n",
    "        #### Sliced Wasserstein ####\n",
    "\n",
    "        D_SW = np.zeros((n_class*N,n_class*N))\n",
    "    \n",
    "        for k,dgm0 in enumerate(DGMS_eps):\n",
    "            for j,dgm1 in enumerate(DGMS_eps[k:]):\n",
    "                D_SW[k,j+k] = sliced_wasserstein(dgm0, dgm1,M=10)\n",
    "    \n",
    "        D_SW = D_SW+D_SW.T\n",
    "        \n",
    "        T = dendrolink(D_SW, linkage = 'average', root = False, root_height = 1)\n",
    "        T.make_mult(f=False)\n",
    "        labels = T.cut_tree((T.f_uniq[-1]+T.f_uniq[-2])/2)\n",
    "    \n",
    "        aux_0 = np.sum(np.array(labels[0])<N)+np.sum(np.array(labels[1])>N-1)\n",
    "        aux_1 = np.sum(np.array(labels[0])>N)+np.sum(np.array(labels[1])<N-1)\n",
    "    \n",
    "        acc = np.max([aux_0,aux_1])/(2*N)\n",
    "    \n",
    "#        print('Sliced Wass. Clustering Accuracy: ',acc)\n",
    "    \n",
    "        ACC_SWASS.append(acc)\n",
    "        m_ACC_SWASS[i] +=acc\n",
    "\n",
    "        #### Persistence Spheres ####\n",
    "\n",
    "        K_vals = [0.001,0.01,0.1,0.3,0.6]\n",
    "        params = list(product(K_vals,[1,4,8]))\n",
    "        \n",
    "        n_theta = 100\n",
    "        n_phi = 200\n",
    "        \n",
    "        dV = make_dV(n_theta = n_theta, n_phi = n_phi)\n",
    "\n",
    "        acc_max = 0\n",
    "        for K,alpha in params:\n",
    "            \n",
    "            weighting = make_weighting(K,alpha)\n",
    "    \n",
    "            PS = from_DGMS_to_H(DGMS_eps,pts=None,weighting = weighting,n_theta = n_theta, n_phi = n_phi)\n",
    "            D = np.zeros((n_class*N,n_class*N))\n",
    "            \n",
    "            for k,PS0 in enumerate(PS):\n",
    "                for j,PS1 in enumerate(PS[k:]):\n",
    "    \n",
    "                    D[k,j+k] = np.sum(dV*((PS0-PS1)**2))**0.5\n",
    "        \n",
    "            D = D+D.T\n",
    "    \n",
    "            T = dendrolink(D, linkage = 'average', root = False, root_height = 1)\n",
    "            T.make_mult(f=False)\n",
    "            labels = T.cut_tree((T.f_uniq[-1]+T.f_uniq[-2])/2)\n",
    "    \n",
    "            aux_0 = np.sum(np.array(labels[0])<N)+np.sum(np.array(labels[1])>N-1)\n",
    "            aux_1 = np.sum(np.array(labels[0])>N)+np.sum(np.array(labels[1])<N-1)\n",
    "        \n",
    "            acc = np.max([aux_0,aux_1])/(2*N)\n",
    "    \n",
    "            acc_max = np.max([acc_max,acc])\n",
    "    \n",
    "#        print('PS. Clustering Accuracy: ',acc_max)\n",
    "\n",
    "        ACC_PS.append(acc_max)\n",
    "        m_ACC_PS[i] +=acc_max\n",
    "\n",
    "        #### Persistence Landscapes ####\n",
    "\n",
    "        n_grid = 1000\n",
    "        m_b = np.min([np.min(dgm[:,0]) for dgm in DGMS_eps])\n",
    "        M_d = np.max([np.max(dgm[:,1]) for dgm in DGMS_eps])\n",
    "    \n",
    "        PLs_tmp = [PersLandscapeApprox(dgms=[dgm], hom_deg=0, start=m_b, stop=M_d, num_steps=n_grid) for dgm in DGMS_eps]\n",
    "    \n",
    "        PLs=[]\n",
    "\n",
    "        n_land = np.max([pl.values.shape[0] for pl in PLs_tmp])\n",
    "\n",
    "        for pl in PLs_tmp:\n",
    "            \n",
    "            tmp = np.min([n_land,pl.values.shape[0]])\n",
    "            aux = np.zeros((n_land,n_grid))\n",
    "            aux[:tmp,:] = pl.values[:tmp,:]\n",
    "    \n",
    "            PLs.append(aux.flatten())\n",
    "     \n",
    "        D = squareform(pdist(PLs))\n",
    "        \n",
    "        T = dendrolink(D, linkage = 'average', root = False, root_height = 1)\n",
    "        T.make_mult(f=False)\n",
    "        labels = T.cut_tree((T.f_uniq[-1]+T.f_uniq[-2])/2)\n",
    "    \n",
    "        aux_0 = np.sum(np.array(labels[0])<N)+np.sum(np.array(labels[1])>N-1)\n",
    "        aux_1 = np.sum(np.array(labels[0])>N)+np.sum(np.array(labels[1])<N-1)\n",
    "    \n",
    "        acc = np.max([aux_0,aux_1])/(2*N)\n",
    "    \n",
    "#        print('PL. Clustering Accuracy: ',acc)\n",
    "\n",
    "        ACC_PL.append(acc)\n",
    "        m_ACC_PL[i] +=acc\n",
    "\n",
    "        #### Persistence Splines ####\n",
    "\n",
    "        H = [10,20,40]\n",
    "        ITER = [10,50,100]\n",
    "        sig=1e-10\n",
    "        \n",
    "        params = list(product(H,ITER))\n",
    "    \n",
    "        acc_max = 0\n",
    "\n",
    "        for (h,iterations) in params:\n",
    "    \n",
    "            m_b = np.min([np.min(dgm[:,0]) for dgm in DGMS_eps])\n",
    "            M_b = np.max([np.max(dgm[:,0]) for dgm in DGMS_eps])\n",
    "            \n",
    "            M_p = np.max([np.max(dgm[:,1]-dgm[:,0]) for dgm in DGMS_eps])\n",
    "    \n",
    "            PSpl = np.array([make_PersSplines_vec(dgm,m_b,M_b,M_p,h,sig=1e-10,iteration=iterations).flatten() for dgm in DGMS_eps])\n",
    "    \n",
    "            D = squareform(pdist(PSpl))\n",
    "            \n",
    "            T = dendrolink(D, linkage = 'average', root = False, root_height = 1)\n",
    "            T.make_mult(f=False)\n",
    "            labels = T.cut_tree((T.f_uniq[-1]+T.f_uniq[-2])/2)\n",
    "    \n",
    "            aux_0 = np.sum(np.array(labels[0])<N)+np.sum(np.array(labels[1])>N-1)\n",
    "            aux_1 = np.sum(np.array(labels[0])>N)+np.sum(np.array(labels[1])<N-1)\n",
    "        \n",
    "            acc = np.max([aux_0,aux_1])/(2*N)\n",
    "    \n",
    "            acc_max = np.max([acc_max,acc])\n",
    "    \n",
    "#        print('PSpl. Clustering Accuracy: ',acc_max)\n",
    "        ACC_PSpl.append(acc_max)\n",
    "        m_ACC_PSpl[i] +=acc_max\n",
    "\n",
    "    \n",
    "        #### Persistence Images ####\n",
    "\n",
    "        N_PI = [50,100]\n",
    "        N_SIGMA = [0.001,0.01,0.1,100]\n",
    "        P = [2,4,8]\n",
    "        \n",
    "        params = list(product(N_PI,N_SIGMA,P))\n",
    "\n",
    "        acc_max = 0\n",
    "        for (n_PI,n_sigma,p) in params:\n",
    "    \n",
    "            m_b = np.min([np.min(dgm[:,0]) for dgm in DGMS_eps])\n",
    "            m_d = np.min([np.min(dgm[:,1]) for dgm in DGMS_eps])\n",
    "            \n",
    "            M_b = np.max([np.max(dgm[:,0]) for dgm in DGMS_eps])\n",
    "            M_d = np.max([np.max(dgm[:,1]) for dgm in DGMS_eps])\n",
    "            \n",
    "            pimgr = PersistenceImager()\n",
    "            \n",
    "            pix = np.min([(M_b-m_b)/n_PI,(M_d-m_d)/n_PI])\n",
    "            pix = 10 ** np.ceil(np.log10(pix))\n",
    "            sigma = pix/n_sigma\n",
    "            \n",
    "            pimgr.pixel_size = pix\n",
    "            pimgr.kernel_params = {'sigma': sigma}\n",
    "            pimgr.weight_params['n'] = p\n",
    "                \n",
    "            PIs = pimgr.fit_transform(DGMS_eps)\n",
    "            PIs = [pi.flatten() for pi in PIs]\n",
    "    \n",
    "            D = squareform(pdist(PIs))\n",
    "            \n",
    "            T = dendrolink(D, linkage = 'average', root = False, root_height = 1)\n",
    "            T.make_mult(f=False)\n",
    "            labels = T.cut_tree((T.f_uniq[-1]+T.f_uniq[-2])/2)\n",
    "    \n",
    "            aux_0 = np.sum(np.array(labels[0])<N)+np.sum(np.array(labels[1])>N-1)\n",
    "            aux_1 = np.sum(np.array(labels[0])>N)+np.sum(np.array(labels[1])<N-1)\n",
    "        \n",
    "            acc = np.max([aux_0,aux_1])/(2*N)\n",
    "    \n",
    "            acc_max = np.max([acc_max,acc])\n",
    "    \n",
    "        ACC_PI.append(acc_max)\n",
    "        m_ACC_PI[i] += acc_max\n",
    "        \n",
    "    print('Wass:  ',m_ACC_WASS/(count+1))\n",
    "    print('SWass: ',m_ACC_SWASS/(count+1))\n",
    "    print('PS:    ',m_ACC_PS/(count+1))\n",
    "    print('PL:    ',m_ACC_PL/(count+1))\n",
    "    print('PI:    ',m_ACC_PI/(count+1))\n",
    "    print('PSpl:  ',m_ACC_PSpl/(count+1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "ACC_WASS = np.array(ACC_WASS).reshape((200,3))\n",
    "ACC_SWASS = np.array(ACC_SWASS).reshape((200,3))\n",
    "ACC_PS = np.array(ACC_PS).reshape((200,3))\n",
    "ACC_PL = np.array(ACC_PL).reshape((200,3))\n",
    "ACC_PI = np.array(ACC_PI).reshape((200,3))\n",
    "ACC_PSpl = np.array(ACC_PSpl).reshape((200,3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FDA, \\sigma= 10.0 Wass. 0.8096000000000001 0.22133648592132296\n",
      "FDA, \\sigma= 15.0 Wass. 0.71695 0.22269305669463516\n",
      "FDA, \\sigma= 30.0 Wass. 0.5480999999999999 0.1070485403917307\n",
      "FDA, \\sigma= 10.0 SW. 0.76225 0.21974857792486394\n",
      "FDA, \\sigma= 15.0 SW. 0.6963999999999999 0.20719082991290902\n",
      "FDA, \\sigma= 30.0 SW. 0.5779 0.11983985146853277\n",
      "FDA, \\sigma= 10.0 PS. 0.84515 0.15772754198300307\n",
      "FDA, \\sigma= 15.0 PS. 0.8062999999999999 0.16706379021200254\n",
      "FDA, \\sigma= 30.0 PS. 0.6876000000000001 0.1437784406647951\n",
      "FDA, \\sigma= 10.0 PL. 0.7529499999999999 0.2129901347480676\n",
      "FDA, \\sigma= 15.0 PL. 0.6759000000000001 0.20048239324190043\n",
      "FDA, \\sigma= 30.0 PL. 0.54165 0.08496927385826009\n",
      "FDA, \\sigma= 10.0 PI. 0.7859 0.16505814127149257\n",
      "FDA, \\sigma= 15.0 PI. 0.73045 0.15895375899927625\n",
      "FDA, \\sigma= 30.0 PI. 0.62055 0.1025875114231747\n",
      "FDA, \\sigma= 10.0 PSpl. 0.55565 0.09668804217688969\n",
      "FDA, \\sigma= 15.0 PSpl. 0.53825 0.061623351904939415\n",
      "FDA, \\sigma= 30.0 PSpl. 0.5181999999999999 0.014204224723651772\n"
     ]
    }
   ],
   "source": [
    "names = ['Wass.','SW.','PS.','PL.','PI.','PSpl.']\n",
    "\n",
    "for i,ACC in enumerate([ACC_WASS,ACC_SWASS,ACC_PS,ACC_PL,ACC_PI,ACC_PSpl]):\n",
    "    for j,eps in enumerate(EPS):\n",
    "        print('FDA, \\sigma=',eps,names[i],np.mean(ACC[:,j]),np.std(ACC[:,j]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.13.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
