{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The autoreload extension is already loaded. To reload it, use:\n",
      "  %reload_ext autoreload\n"
     ]
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "%matplotlib inline\n",
    "\n",
    "import numpy as np\n",
    "\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.cm as cm\n",
    "from parfor import parfor\n",
    "\n",
    "from tools_weak_proximal import *\n",
    "from class_weak_barycenter import *\n",
    "\n",
    "import ot\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Computation of the optimal weak transport plan for one-dimensional histograms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Objective OT: 185.13479283310912, Objective OWT: 185.11090629524543, and Objective OWT via QP: 185.10849422582095\n"
     ]
    },
    {
     "data": {
      "image/png": "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7LMCADiPsAIAOI+wAgA4j7ACADiPsAIAOI+wAgA4j7ACADiPsAIAOI+wAgA4j7ACADiPsAIAOI+wAgA4j7ACADiPsAIAOI+wAgA4j7CqJg4cOKBhw4bpe9/7nkJDQ9WyZUu98MILunLlirfPyJEjNWDAgEL383g8MsZo7Nixhdrfffdd1a1bV8aYUi/Lly+vlOcHoGojrKqBFStWqEuXLgoLC9MHH3ygw4cP6w9/+IOWLFmihx9+2NuvXr16ysjIKHTf1157TbVr19ZXX31VqH3OnDkaPny4Tp8+7b00b95czz33XKG2xx57rBKeIYCqzq9vCjbGPCDpPySFSHrLWjujhH7dJP1d0mPW2v9XblXipu3cuVMjR47Um2++qTFjxnjbW7durdDQUA0ZMkQ7d+5U7969FRkZWSisTp48qbVr12rMmDE6duyYt33Hjh3au3evVqxYoSZNmkiSMjIylJaWpl69ennbAKC8lBlWxpgQSfMk9ZeUJinRGLPOWnvQR7+ZkjZXRKElWb9+fWU+3A0bOHBgua8zPj5eCxcu1O7du/XFF18oNDRUjRs3VocOHXTPPfdowoQJqlEjd9A8YcIE9evXr1BQ5bv33nslScnJyerdu3exkdXrr7+uBx98UN26ddPevXu97X/60580cOBA3X777d42j8cja626du3q13O4cuWKIiMjNW7cOM2ePVuSNGbMGK1cuVLp6emqWdOv91EAqgl/XhG6S0q11h6XJGPMSkkPSTpYpN+vJa2V1K1cK4RXTk6Oxo4dq0WLFum2227TgAED1KJFC126dEmpqanatGmTkpKSNGnSJEm5IeTxePT+++/7XF/+/qrQ0FBJhacBMzMz9dZbb2nTpk06e/astz01NVUbNmxQfHx8oXXt3btX9evXV0xMjF/PZdeuXbp27Zruu+8+b9u2bdvUt29fggpAMf68KjST9HmB22mSehTsYIxpJulnku5TKWFljBkjaYwkv1/U8K1XX31VixYt0qBBg7Rs2TJFREQUWp6eni6Px+O9nX+9pNFO/vI77rhDkhQZGalLly4pJydHCxYsUMeOHXX33XcrLi7Ou89qzpw5io2NVZ8+fYqtq0uXLn4/l+3btyskJER9+/aVJJ04cULHjx/X+PHj/V4HgOrDnwMsjI82W+T265JesNbmlLYia+1Ca22stTa2YcOGfpYISbLWau7cuZKkBQsWFAsqSYqKitKPfvQj7+3r169LkurWretznfPmzVP79u0VGxsrKXdkJUnnz5/X3LlzNXnyZElSeHi4MjIylJ6eriVLluj5558vti6Px1PqFODFixeVmprqvXz88cdq166dvvzyS6Wmpmr16tWSpFatWnn7FDxSUZLmzp0rY4wWL15cbP0ZGRmqUaNGoZEagKrDn5FVmqTmBW5HSzpVpE+spJXGGElqIOlBY0y2tfbD8igSudNy58+flyTVqlXLr/vceeedkqSEhAQNGTKk0LK3335bW7Zs0ZYtW5T3e1NkZKSk3DC85ZZbNGjQIElSRESEvv76a73xxhtq3LixBg8eXGhdly5d0qefflrqyGrt2rX61a9+Vay9TZs2hW4XXHdcXJz69evnvV3aSPFG95kBCC7+hFWipDbGmFaS/inp55L+T8EO1tpW+deNMUskbSCoyldERISio6OVlpam/v37a/z48br//vsVHR1d4n26d++un/zkJ/r1r3+t7Oxsde/eXefOndPSpUu1aNEivf3224VGIvkjq9mzZ2vmzJnegzTCw8Ml5U4BTps2TSEhIYUeZ9++ffrmm29KDat7771Xa9askSTt3r3bu6527dpJkkaMGKEePXpo3Lhx3vt06NCh0Do8Ho/q1KlTrF2S9wCQG5mKBBA8ygwra222MeYZ5R7lFyJpsbX2gDHm6bzl8yu4RuRZtWqVhg8frn379mnUqFGScvf9DRgwQE899ZR3JFXQmjVr9Morr+iFF17QqVOnVL9+ffXr10+JiYnq3Llzob75I6vQ0FANHz7c254/5WiM0RNPPFHsMTwejyIiItS6desSa2/RooVatGghSfrb3/6mWrVq6dlnn9Wtt96qo0eP6vLlyxo6dGixEWC+q1ev6tChQ+rSpYvPAzDyw4qRFVA1+XXYlbV2o6SNRdp8hpS1duR3Lwu+3H333Tp69Kh27typzZs3KyEhQZ988okWLFighQsXasGCBRo9enSh+9StW1czZszQjBk+PxpXyG233SZri+6OlGrXru2zPd+ECRM0YcIEv5/H9u3b1a1bN916662ScqcpJemee+4p8T4pKSnKzs4uMYySkpIUFhZWbFoRQNXAMcJBpkaNGurbt6/3KLr09HRNnDhRy5cv1/PPP69Ro0Z590G5Ij4+3nuou7VWKSkp6tq1q6ZOnSpJ2rhxo0JCQrRq1Spv7fnL8pW2vyojI0PHjh1Tnz59nHvuAMoHYRXkoqKi9Oqrr2r58uXKzMxUenq66tevH+iyComPj9crr7xSqC0xMVGJiYmF2qZNm+a9fiNhtWvXLllr2V8FVGGcG7AKOH36tKTc4IqKigpwNcVNnTpV1lpZa/Xss8+qTp06unr1qqy1Ongw97Pl8+fP9/bxNeWYH1bNmjUrtmzlypWS2F8FVGWEVRBYvny5tm7d6vNF/Pjx495TKU2cONH5abC4uDj17NlTtWvXliTv9GDBQ9SLysrK0v79+yXlnuuwoNWrV2vFihWSpI4dO5Z/wQCcwDRgEFi8eLHi4+MVExOjvn37qnnz5rp06ZKOHj2qrVu3KicnR+PGjdNLL70U6FJLdeHCBSUnJ2vKlCnetvj4eDVp0qTQeQaL2r9/v65du6bGjRvr8ccf1+DBg1W/fn0lJydr3759atSokc6cOaNp06Zp8uTJ6tmzZ2U8HQCViLAKAjNmzPCej2/Hjh06c+aMatSooejoaA0fPlyjR4/WXXfdFegyy5SQkKBvvvmm0Chqx44dpY6qpG+nAKdMmaLjx49ryZIlunLlinr06KG4uDglJCRoypQp+uyzzziNF1BFBX1YVcRZzV3To0cP9ejRo+yOjnv44YeLTWXm728rTX5YxcbGaty4cXrttdcKLY+NjdVzzz1XfoUCcA77rOA8j8ejkJAQ9kkB1RhhBafl5OQoJSVFbdu2LfGEvACqPsIKTjt8+LAuX77s/RoTANVT0O+zQtXWoUOHUk/1BKB6YGQFAHAeYQUAcB5hBQBwHmEFAHAeYQUAcB5hBQBwHoeuA0AFWb9+fYnLqsOp4soTYQUAJVm/Xtqzp+TlX5Vy1z17tOfToyUuJ6xuDNOAAADnEVYAAOcRVgAA5xFWAADnEVYAAOcRVgAA5xFW1cSBAwc0bNgwfe9731NoaKhatmypF154QVeuXPH2GTlypAYMGFDofh6PR8YYjR07tlD7u+++q7p168oYU+pl+fLllfL8AFRthFU1sGLFCnXp0kVhYWH64IMPdPjwYf3hD3/QkiVL9PDDD3v71atXTxkZGYXu+9prr6l27dr66quvCrXPmTNHw4cP1+nTp72X5s2b67nnnivU9thjj1XCMwRQ1fGh4Cpu586dGjlypN58802NGTPG2966dWuFhoZqyJAh2rlzp3r37q3IyMhCYXXy5EmtXbtWY8aM0bFjx7ztO3bs0N69e7VixQo1adJEkpSRkaG0tDT16tXL21ZVnDhxQq1atdKIESO0ZMmSQJcDVEtBH1brj5R8OhMXDLy9/D+lHh8fr4ULF2r37t364osvFBoaqsaNG6tDhw665557NGHCBNWokTtonjBhgvr161coqPLde++9kqTk5GT17t272Mjq9ddf14MPPqhu3bpp79693vY//elPGjhwoG6//XZvm8fjkbVWXbt29es5XLlyRZGRkRo3bpxmz54tSRozZoxWrlyp9PR01awZ9H+aNyUpKUnz5s1TQkKCTp8+rVq1aqlVq1Z64IEHNGnSpBLfCBhjCt2uUaOGIiMj1alTJz355JP6xS9+URnlAxWmer4iBKmcnByNHTtWixYt0m233aYBAwaoRYsWunTpklJTU7Vp0yYlJSVp0qRJknJDyOPx6P333/e5vvz9VaGhoZIKTwNmZmbqrbfe0qZNm3T27Flve2pqqjZs2KD4+PhC69q7d6/q16+vmJgYv57Lrl27dO3aNd13333etm3btqlv377OBVWzZs106NAhRUREVNhjWGv14osvatasWapZs6b69++voUOH6vr169q9e7dmzZqlN998U++9955++tOflrie3//+95KkrKwsHTlyRB9++KHi4uK0d+9e75sCIBi59aqAUr366qtatGiRBg0apGXLlhV78UxPT5fH4/Hezr9e0mgnf/kdd9whSYqMjNSlS5eUk5OjBQsWqGPHjrr77rsVFxfn3Wc1Z84cxcbGqk+fPsXW1aVLF7+fy/bt2xUSEqK+fftKyp1qO378uMaPH+/3OipLrVq11LZt2wp9jOnTp2vWrFlq2bKlNmzYoA4dOhRavnbtWv3yl7/U4MGD9de//lU9evTwuZ6pU6cWur1t2zb1799fr7/+un7zm9+oZcuWFfQMgIrFARZBwlqruXPnSpIWLFjg811+VFSUfvSjH3lvX79+XZJUt25dn+ucN2+e2rdvr9jYWEm5IytJOn/+vObOnavJkydLksLDw5WRkaH09HQtWbJEzz//fLF1eTyeUqcAL168qNTUVO/l448/Vrt27fTll18qNTVVq1evliS1atXK26fgkYqSNHfuXBljtHjx4mLrz8jIUI0aNQqN1Hz529/+JmOMBg8eXGKfdu3aqXbt2kpPT5eUG6TGGI0cObJY3yVLluiRRx5R69atVbduXYWHh6tXr15asWJFqXUUdOLECU2fPl21atXSunXrigWVJD3yyCOaM2eOsrKy9NRTT/m97h/+8Idq27atrLVKTEz0+36AaxhZBYnMzEydP39eUu47fX/ceeedkqSEhAQNGTKk0LK3335bW7Zs0ZYtW7z7OyIjIyXlhuEtt9yiQYMGSZIiIiL09ddf64033lDjxo2LvdBfunRJn376aakjq7Vr1+pXv/pVsfY2bdoUul1w3XFxcerXr5/3dmkjRX/3md111126/fbbtWHDBp0/f17169cvtHzPnj06fPiwHnnkEUVFRZW6LkkaO3as2rdvr759+6pp06Y6f/68Nm7cqGHDhunIkSOaPn16met45513lJ2drUcffVQdO3Yssd+oUaM0ffp0JScn6+9//7t69uxZ5rql3Dc6UvH9WkAwIayCREREhKKjo5WWlqb+/ftr/Pjxuv/++xUdHV3ifbp3766f/OQn+vWvf63s7Gx1795d586d09KlS7Vo0SK9/fbbhUYi+SOr2bNna+bMmd6DNMLDwyXlTgFOmzZNISEhhR5n3759+uabb0oNq3vvvVdr1qyRJO3evdu7rnbt2kmSRowYoR49emjcuHHe+xQdYXg8HtWpU8fnyCP/ABB/piJHjBihl156Se+9956eeeaZQsuWLl3q7eOP/fv36/vf/36htuvXr2vAgAGaMWOGnn76aTVr1qzUdezcuVOSCo2KfalZs6b69eund999Vzt27PArrLZu3aojR47IGKNu3bqV2R9wFWEVRFatWqXhw4dr3759GjVqlCQpJiZGAwYM0FNPPeUdSRW0Zs0avfLKK3rhhRd06tQp1a9fX/369VNiYqI6d+5cqG/+yCo0NFTDhw/3tudPORpj9MQTTxR7DI/Ho4iICLVu3brE2lu0aKEWLVpIyp2Kq1Wrlp599lndeuutOnr0qC5fvqyhQ4cWGwHmu3r1qg4dOqQuXbr4PAAjP6z8ORpx2LBhevnll7V06dJCYXX9+nWtXLlSjRo1Kvbh6JIUDSopd/uNHz9e27dv17Zt2wptS19Onz4tSWrevHmZj5ffJy0tzefy/H1WBQ+wsNZq0qRJ3u0PBCPCKojcfffdOnr0qHbu3KnNmzcrISFBn3zyiRYsWKCFCxdqwYIFGj16dKH71K1bVzNmzNCMGTPKXP9tt93mnTIqqHbt2j7b802YMEETJkzw+3ls375d3bp106233iopd5pSku65554S75OSkqLs7OwSwygpKUlhYWHFphV9iY6O1g9/+ENt2bJFBw8eVPv27SXlfqtrenq6Jk2a5PcRiSdPntTMmTO1bds2nTx5sth+tn/+859lruNGpuny+169etXn8ldeecW7rnr16qlPnz568skn9ctf/rLMdQMuI6yCTI0aNdS3b1/vUXTp6emaOHGili9frueff16jRo1ybt9EfHy891B3a61SUlLUtWtX7yhg48aNCgkJ0apVq7y1Fz2qrbT9VRkZGTp27Jj69Onj93MfOXKktmzZoqVLl2rmzJmSbnwK8Pjx4+revbsuXLigPn366Mc//rEiIiIUEhKiEydOaOnSpbp27VqZ62natKkOHz6skydPltk3f0TVsGFDn8tLe1MBBDPCKshFRUXp1Vdf1fLly5WZman09PRiBw0EWnx8vPcdf77ExMRiR6dNmzbNe/1GwmrXrl2y1t7QofM/+9nPFB4erhUrVujf//3flZ6ero8++kidO3cuNj1aktmzZ+v8+fN65513ih0p+N5773nDryy9e/dWXFyctm7dWmxkXFBOTo439P398DVQVXDoehWQv88jKirKryPYKtvUqVNlrZW1Vs8++6zq1Kmjq1evylqrgwcPSpLmz5/v7eNrdJAfVr4OVli5cqWkG3sBr1u3rh599FGdOnVKW7du1Z///GdlZ2f7PaqScj8gLeUeVl5U/tSmP5544gnVrFlTH3zwgQ4cOFBiv8WLF+vUqVOKiorSAw884Pf6gaqAsAoCy5cv19atW32+iB8/ftx7KqWJEyc6NwVYVFxcnHr27KnatWtLknekUPAQ9aKysrK0f/9+Sd8eOZdv9erV3s80lXbYty/5o6Fly5Zp2bJlqlmz5g2dlij/A7ZFz+axefNmvfXWWze0npdffllZWVkaNGiQN8AL+vDDD737BWfOnKlbbrnF7/UDVQHTgEFg8eLFio+PV0xMjPr27avmzZvr0qVLOnr0qLZu3aqcnByNGzdOL730UqBLLdWFCxeUnJysKVOmeNvi4+PVpEmTQucZLGr//v26du2aGjdurMcff1yDBw9W/fr1lZycrH379qlRo0Y6c+aMpk2bpsmTJ/v9+aNe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\n",
      "text/plain": [
       "<Figure size 504x504 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "ns_1D = 20 # nb samples xs\n",
    "nt_1D = 20 # nb samples xs\n",
    "mu_s_1D = 0\n",
    "sigma_s_1D = 2\n",
    "mu_t_1D = 14\n",
    "sigma_t_1D = 1.4\n",
    "X_source_1D = np.random.normal(mu_s_1D, sigma_s_1D, ns_1D)\n",
    "Y_target_1D = np.random.normal(mu_t_1D, sigma_t_1D, nt_1D)\n",
    "\n",
    "OWT_1D = weak_map_1D(X_source_1D, Y_target_1D)\n",
    "OWT_1D.set_parameters(gamma = 1e-3, method_proj = 'proj_eucl_acc', nb_iter_proj = 1e3, nb_iter_prox = 800)\n",
    "OWT_1D.compute_OWT_1D()\n",
    "OWT_1D.print_objective()\n",
    "OWT_1D.plot_Smaps()\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Computation of the optimal weak transport plan in 2D and comparison of barycentric projections"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Objective OT: 0.9274737363681997, Objective OWT: 0.38207910224758074 and Objective OWT via QP: 0.38158128151233667\n"
     ]
    },
    {
     "data": {
      "image/png": "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Xr1aZ5xxRpN1fP3113XixAlde+21obIVK1Zo7NixysrioxjSnJV0Tr70JUkXBDLOJfnSDkk1Zc52ArVGeGcAAAApa/bs2VqwYIFuvPFGLV68WL169YrYvn//flVWVkaUvf322/riF78YCtC2b9+u1157TX/96181b9680H719fU67bTTJEkffvihli9fHsrCBXXp0kUXXXRRs3VcuXKlfD6fxo4dK0mqqqrStm3bdO+997bpNQMpxciJOAaGlX028PNjEaA1oV1BmjHmFjm3oBsu6VJrLfPqAwAg2siOYK0NBVVPPvlkowBNkvr06aNx48ZFlK1fv17/9m//Flp/++231bNnT61du7bR8zt37ixJqqysVFZWVqNujZs2bdJ1110XUXbo0KGIsWyvvfaahg8frj179mjPnj168cUXJUnnnnuutm7dKkkaMGCAunXrFnrOvHnzNHnyZD311FO66667Io5fU1OjM844Q/n5+Vq5cmUTVwfwkLvLnIzZinxnfVyZdJ0I0JrR3kzaRkk3S3oyAXUBACCd0EYm2cGDB7Vv3z5JUnZ2dlzPOXLkiD744AONGjUqVJadna0jR47o7LPPVvfu3WM+z+fzqb6+XkePHtXpp58uSVq7dq1ef/31iLFmkvTCCy/ozjvvbHSMYcOGRayHd6VctWqV8vPzQ+vB7N/o0aMbHaeyslLW2pjbAM+KDsgI0JrVrolDrLWbrLXvJaoygFcwiR+A9qKNTL5evXpp4ECnD9X48eP11FNPaceOHc0+Z8OGDZKkiy++OFR22WWX6YwzztBtt92mdevW6YMPPtDy5ct17733hiYcycvLU5cuXTRt2jR98MEHevXVV/Xtb3+70bEk6ZprrtGyZcu0bNmy0Fi4WbNmhcpOO+20iH2WLVumESNGRByjsrJSXbt2bVQuKZTxCw80O8quXR1+SqSTcWXOghYxuyMQw8yZbtcAADwgempsD06V/dxzz+kzn/mM1q1bp7vvvluDBg3SkCFDdM8992jdunWN9l+/fr2GDRsWkTE744wz9Oc//1k1NTW65pprdPHFF+uBBx7QwIED1amT81Hp7LPP1tNPP61XXnlFF154oX75y1/qjjvuUN++fTV06NCIcwwZMkQTJkzQhAkTZIxRdna2pk6dqgkTJujCCy/U0aNHdcstt4T2mTBhgvr27Rt6/vHjx7Vp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wsJCLViwQN27d9cNN9ygIUOG6PDhw9q6dateffVVVVRUaMqUKZKc4KuyslIvvvhizOMFx6N17txZUmSQdvDgQf3617/Wq6++qr1794bKt27dqpdfflllZWURx1q7dq1ycnI0ePDguF7L66+/rhMnTujaa68Nla1YsUJjx45VVhYf2ZC+ikqKNH/bfNWfXi/fEZ8KhhaouLDY7Wq5iv94AACQsmbPnq0FCxboxhtv1OLFi9WrV6+I7fv371dlZWVoPfi4qexWcPvFF18sSTrjjDN0+PBh1dfX68knn9TIkSP1+c9/XqtWrQpl0ubMmaO8vDxdddVVjY41atSouF/LypUr5fP5NHbsWElSVVWVtm3bpnvvvTfuYwCppqikSCU7S6Tuznp993pnvUQZHajR3REAAKQka63mzZsnSXryyScbBWiS1KdPH40bNy60fvLkSUlSt27dYh7zV7/6lS644ALl5eVJcjJpkrRv3z7NmzdP06ZNkyT17NlTNTU12r9/vxYtWqQHHnig0bEqKyub7ep46NAhbd26NbS89tprGj58uPbs2aOtW7fq+eeflySde+65oX3CZ56UpHnz5skYo4ULFzY6fk1NjTp16hSRmQO8Zv62+VJ2VGF2oDyDkUkDAAAp6eDBg9q3b58kKTs7+lNebJ/73OckSeXl5ZowYULEtqeeekrLly/X8uXLZYyR5GTSJCcIPO2003TjjTdKknr16qUjR47ol7/8pc466yzdfPPNEcc6fPiw3n///WYzaS+88ILuvPPORuXDhg2LWA8/9qpVq5Sfnx9aby4z2NoxcYAb6k+vb1V5piBIAwAAKalXr14aOHCgduzYofHjx+vee+/V9ddfr4EDBzb5nEsvvVRf+tKX9P3vf191dXW69NJL9cknn+jpp5/WggUL9NRTT0VknoKZtJ///Od69NFH1amT0wmpZ8+ekpyujrNmzZLP54s4z7p163Tq1Klmg7RrrrlGy5YtkyS98cYboWMNHz5cknT77bdrzJgxKioqCj1nxIgREceorKxU165dG5VLzpg4Sa3qcgl0NN8Rn+q7Nw7IfEd8MfbOHHR3BAAAMS1dulS5ubnq1KmTcnNztXTpUrer1Mhzzz2nz3zmM1q3bp3uvvtuDRo0SEOGDNE999yjdevWxXzOsmXLdPvtt+vBBx/UeeedpxtvvFH79u3TW2+9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zDOtqlNVVZV+9KMfKTs7W3/84x8bBWiS9PWvf11z5sxRbW2tvve978V13Ouuu07nn3++rLV66623WlUnINHIpAEAgJR08OBB7du3T5KTvYnH5z73OUlSeXm5JkyYELHtqaee0vLly7V8+XIFbkCuM844Q5ITBJ522mm68cYbJUm9evXSkSNH9Mtf/lJnnXVWoyDm8OHDev/995vNpL3wwgu68847G5UPGzYsYj382KtWrVJ+fn5ovbnMYGvHxMVy+eWX67zzztPLL7+sffv2KScnJ2L7//7v/2rz5s36+te/rj59+jR7rMLCQl1wwQUaO3aszjnnHO3bt0+vvPKKbrvtNr333nv60Y9+FFedfvOb36iurk7f+MY3NHLkyCb3u/vuu/WjH/1I69ev19///ndddtllLR7bWitJod8/4BaCNAAAkJJ69eqlgQMHaseOHRo/frzuvfdeXX/99Ro4cGCTz7n00kv1pS99Sd///vdVV1enSy+9VJ988omefvppLViwQE899VRE5imYSfv5z3+uRx99VJ06OZ2QevbsKcnp6jhr1iz5fL6I86xbt06nTp1qNki75pprtGzZMknSG2+8ETrW8OHDJUm33367xowZo6KiotBzorNGlZWV6tq1a8xs0tq1ayWpVV0uY7n99tv10EMP6Xe/+53+7d/+LWLb008/HdqnJRs3btRnPvOZiLKTJ0/qhhtu0COPPKJ77rlHAwYMaPE4a9askaSIDGksWVlZys/P129/+1utXr26xSCttLRU7733nowxuuSSS1qsB5BMBGkAACCmpf9YqodXPKztNds1uNdgzb5utiaOnOh2tSI899xzmjRpktatW6e7775bkjR48GDdcMMN+t73vhfKnIVbtmyZZs6cqQcffFC7du1STk6O8vPz9dZbb+miiy6K2DeYSevcubMmTZoUKg92rTTG6K677mp0jsrKSvXq1UtDhw5tsu5DhgzRkCFDJDndCrOzszV16lSdfvrp2rJli44ePapbbrmlUcYv6Pjx49q0aZNGjRoVc2KRYJDWnkyaJN122236z//8Tz399NMRQdrJkyf17LPPql+/fo1u+B1LdIAmOdf13nvv1cqVK7VixYqIa9yUjz76SJI0aNCgFvcN7rNjx45G24Jj0sInDrHWasqUKaHfC+AWgjQAyCR+v7MALVj6j6Uq+FOBjtYe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\n",
      "text/plain": [
       "<Figure size 1080x576 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "## Data setting\n",
    "ns = 30 # nb samples xs\n",
    "nt = 20 # nb samples xs\n",
    "mu_s = np.array([0, 0])\n",
    "cov_s = np.array([[1, 0], [0, 1]])\n",
    "mu_t = np.array([0, 0])\n",
    "cov_t = np.array([[1, -.8], [-.8, 1]])\n",
    "X_source = ot.datasets.make_2D_samples_gauss(ns, mu_s, cov_s)\n",
    "Y_target = ot.datasets.make_2D_samples_gauss(nt, mu_t, cov_t)\n",
    "\n",
    "# method_proj = 'proj_eucl_acc', 'proj_eucl', 'proj_eucl_sto_acc', 'proj_eucl_sto' \n",
    "OWT = comparison_maps(X_source, Y_target)\n",
    "OWT.set_parameters(gamma = 1e-3, method_proj = 'proj_eucl_acc',batch_size_proj = 3, nb_iter_proj = 1e3, nb_iter_prox = 200)\n",
    "OWT.compute_OWT()\n",
    "OWT.compute_OT_OTreg()\n",
    "OWT.print_objective()\n",
    "OWT.plot_Smaps()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# WEAK BARYCENTERS"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "example = 'gaussian' # 'gaussian', 'double_ring'\n",
    "\n",
    "nb_data = 5 # number of measures that will pass through the algorithm\n",
    "n = np.random.randint(100, 105, nb_data) # number of points per mesures\n",
    "\n",
    "bar = barycenters(example, nb_data, n)\n",
    "\n",
    "bar.set_data()\n",
    "bar.plot_data()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# STOCHASTIC ALGORITHM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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e/akb9++7L333nz/+9/nnXfe6ZgvFothjMnrr7m52b8vFlUbN8Ly5fDOO86rggMR8UhkBzgSh7WWiy66iGuuuYaamhoOO+wwTjzxRFpaWli8eDE///nPuemmm5g7dy4nnHAC9fX1XHbZZZ2WsX79en7xi1/Qr18/ZsyY0WUd/fv39+bLVJING6C93fl3e7vz/969/S2TiFQEY631uwx5GTt2rF2yZEnW+ZYtW8Yee+zhQYmC7YorruCyyy6jvr6eBx98kL322qvT9HvvvZfTTjuN1tZWHn30USZOnNhlGc3Nzey8884MHz5ctQNeSdQYtLdDVRWMHKnAIEc69iVqjDFLrbVjvVqfmhIirLm5mdmzZ1NbW8sDDzzQJSgAmDp1Ktdffz1tbW2ce+65tCfuUsVfvXs7wcBOOykoEBFPKTCIsNtuu43NmzczZcoU9t5774zzff3rX2fHHXfk1VdfZeHChR6WULrVuzcMHqygQEQ8pcAgwp544gkADj300G7nq6mpobGxEYAnn3yy3MUSEZEAU2AQYWvWrAFg6NChWedNzLN69eqylklERIJNgUEpxOMwZ47zGiCJxNJchonNZ14REYkudVcsVjwOkydDSwvU1UFTEzQ0+F0qAAYPHswrr7zCihUrss67atWqjs+IiEjlUo1BsWIxJyhoa3NeYzG/S9ThoIMOAuCxxx7rdr62tjZibrnHjx9f7mKJiEiAKTAoVmOjU1NQXe28ukl8QTB9+nSqq6u57777eOmllzLOd+utt7J69Wp23313JkyY4GEJRUQkaBQYFKuhwWk+mD07UM0IACNGjOCSSy6htbWVY445hpdffrnLPPPmzeOCCy6gurqam266iaoq7RIiIpVMOQal0NAQqIAg2axZs/jkk0+47rrr2HfffTniiCPYa6+9aG1tZfHixTz99NP07NmTe+65h0mTJvldXBER8ZkCg4irqqri2muv5eSTT+bGG29k0aJFNDU1UV1dTX19PTNnzmTGjBkMGTLE76KKiEgAKDCoEAceeCAHHnhgQZ+tr68nbM/UEBGRwqhBWURERDooMBAREZEOngYGxpirjTFNxpiVxpjPjDHrjDH/MsZcZowZ6GVZREREpCuvawy+B/QCHgV+AdwFbAZmAc8bY7IP6i8iIiJl43XyYV9r7eepbxpjfgJcAlwMfNvjMomIiIjL0xqDdEGB60/u625elUVERES6Ckry4dHu6/O+lkJERKTC+TKOgTHmv4DeQD9gLHAQTlDwUz/KIyIiIg6/Bjj6L2D7pP8/Aky31r6fbmZjzDnAOQDDhg0rf+lEREQqlC9NCdbaHay1BtgBOB4YAfzLGLN/hvlvttaOtdaO3Xbbbb0sqoiISEXxNcfAWvsfa+19wOHAQOAOP8sjIiJS6QKRfGitfRt4GdjLGDPI7/KIiIhUqkAEBq4d3dc2X0shIiJSwTwLDIwxo4wxO6R5v8od4Gg7YLG19kOvyiQiIiKdedkr4cvAz4wxi4A3gLU4PRMm4CQfvgt8w8PyiIiISAovmxIeA27GSTI8Hvg+MBVYB1wO7GWtfdnD8kjANTc3Y4xh+vTpni2nVOsUEQkrzwIDa+2L1trzrLWjrbWDrLU11tp+1toDrLWzrLXrvCpLpVqyZAlnnnkmI0aMoGfPnvTt25e9996b73//+7zzzjud5jXG5PV3++23Z11/W1sbv/3tb5kwYQIDBgygtraW7bbbjn322Yevf/3rPPDAA2X65hIGf/nLX/jud7/LwQcfTN++fTHGcNppp/ldLJGK49cAR+Ihay0XXXQR11xzDTU1NRx22GGceOKJtLS0sHjxYn7+859z0003MXfuXE444QQALrvssi7LueGGG/joo4+44IIL6N+/f6dpo0eP7rYMbW1tHHXUUTzyyCP079+fI488kiFDhrBu3TreeOMN7r77bl555RWOOeaYjs/stNNOLFu2jH79+hW9DST4rrzySp577jl69+7NkCFDeOWVV/wukkhFUmBQAWbPns0111xDfX09Dz74IHvttVen6ffeey+nnXYap5xyCo8++igTJ05k1qxZXZZz++2389FHHzFjxgzq6+vzKsM999zDI488wr777svChQu7XOw//fRTnn766U7v1dbWMmrUqLzWI+F1/fXXM2TIEHbddVcWLlzIxIkT/S6SSEUKUndFKYPm5mZmz55NbW0tDzzwQJegAGDq1Klcf/31tLW1ce6559Le3l7ycixevBiA6dOnp60B2HrrrbtcCNK19ye/19zczCmnnMKgQYPYaqutGDt2LA8++GDOZWpvb+f888/HGMPxxx/P5593fvhnvsv/05/+xCGHHEK/fv3o2bMne++9N3PmzGHTpk0Zv9fy5cs5+eST2W677aiqqiIWi5X0O+bilVde4dvf/ja77bYbW2+9NX379mXUqFGcfPLJXcpeThMnTmS33XbDGOPZOkWkKwUGEXfbbbexefNmpkyZwt57751xvq9//evsuOOOvPrqqyxcuLDk5Rg4cCAAy5cvL8ny3n77bQ488ECam5v52te+xsknn8yLL77Isccey4IFC7J+/vPPP+ekk07il7/8Jeeddx5/+ctf2GqrrQpe/iWXXMLJJ5/MsmXLmDZtGt/5znew1nLJJZdwxBFH0Nra2uUzb7zxBl/84hdpbm7m1FNP5ZxzzqFv374l+465iMVi7Lffftx6663su+++XHDBBUyfPp0RI0bw3HPP0aNHj5KsR0TCQ00JEffEE08AcOihh3Y7X01NDY2Njdx99908+eSTJa/GPf7447n66qv5zW9+w4YNG5gyZQpjxoxh+PDhBS0vFosxa9asTrkQ06ZN48tf/jI/+9nPui3/unXrOPbYY3nyySf56U9/yg9+8IOilh+Px5kzZw5Dhw7lmWeeYYcdnOE65syZw5QpU3jwwQf52c9+xiWXXNJpHU888QQXX3wxV111Vaf3m5ubi/6OufrhD39Ia2srzzzzDPvvn/ZRJZ1t3AgbNkCfPtxwyy2sX78+53WNHj2a4447ruCyiohHrLWh+hszZozNxcsvv5zTfFG3xx57WMA+/PDDWef9wQ9+YAF77rnnpp0+fPhwC9i33nqroLL88Y9/tDvssIMFOv4GDBhgjzvuOPvAAw90mf+tt96ygD3jjDO6vDd8+HC7efPmLp8ZNmyYHThwYMblNDc321GjRtna2lp75513ZlxnPsv/+te/bgH7v//7v13mf/XVV21VVZXdeeedu6xj++23t59//nlJylCokSNH2gEDBtjPPvss+8wbNli7dKm1zz5r7dKldviwYZ1+y2x/yb9jNgsWLLCAPfXUU/P+Tjr2JWqAJdbD66yaEkpg6Rq48VnnNWicfYqc2m3zmbcQJ510EitWrODvf/87l156KUcddRTt7e3MmzePY445hjPOOKOjDNmMHj2a6urqLu8PHTqUDz9MP3jmq6++SkNDA6tXr+bhhx/m1FNPLcny//nPfwIwadKkLvOPHDmSIUOG8NZbb3W5u9533327raov5Dvm67rrrqOmpob999+fmTNnMmvWLB5//PH0M2/YAIn8k/Z2mp96Kq+TTS5dWkXEf2pKKNLSNTDtr9DaBrXVcPfxMGaw36XaYvDgwbzyyiusWLEi67yrVq3q+Ey51NbWcvjhh3P44YcDTjfGe++9l7POOos77riDKVOm5FTdnNpdMqGmpiZj8uTy5ctZt24do0ePzlptns/yP/roIyDzdhs8eDArVqzgo48+6rTcRJNDKcpQCGst//nPfxg+fDjPPvssy5YtA2CPPfZI/4E+faCqygkOqqqc/4tI5CgwKNJTq5ygoM0Cbc7/gxQYHHTQQSxYsIDHHnuMb3wj84jTbW1txGIxAMaPH+9R6aC6upqTTjqJF154gSuvvJL58+eXrR366KOPZvfdd+eSSy5h8uTJ/OMf/2DQoOIf5pnoZfHuu++yyy67dJm+Zs2aTvMl+J19f/755/OrX/2Kc889l9tuu41dd921+2TD3r1h5EjlGIhEnAKDIo0b4tQU4NYYjBvid4k6mz59OldddRX33XcfL730UtruigC33norq1evZvfdd2fChAllKcvGlo1s2LSBPj360Luud6dpfdy7z1ybEgp18cUX07NnT773ve8xceJEHnvsMbbffvuilrnffvvxz3/+k1gs1iUweP3111m1ahU777xzxhoAP7z33nvcdNNNHHHEEdx00025f7B3b+cPZ8Crt99+O+ePnnHGGQoMREJAOQZFGjPYaT6Y2RC8ZgSAESNGcMkll9Da2soxxxzDyy93fRzFvHnzuOCCC6iuruamm26iqqr0u8Vtv7+NO/56Bys/WsnytcvZ2LKxY9q7777Lb3/7WwAOOeSQkq871YwZM/j1r3/NSy+9xIQJE1i9enVRyzvrrLMAZ+S+999/v+P9trY2/uu//ov29nbOPvvsotaRi+nTp+c8PPV7771He3s7H3/8MW1tXZ90/tlnn2VdRnNzs3IMRCJINQYlMGZw8AKCZLNmzeKTTz7huuuuY9999+WII45gr732orW1lcWLF/P000/Ts2dP7rnnnrQJdKWwOL6YW359CwO3G8joA0YzcteR9K7rzVtvvcVDDz3EZ599xrHHHtsxJHO5fetb32Krrbbi7LPP5pBDDmH+/PkMGzasoGV96Utf4r//+7+55ppr+MIXvsAJJ5xAr169ePjhh3nxxRc56KCD+P73v1/ib9BVIu+gpib7Yb377rszcuRI4vE4e+65J4cddhj9+vXjgw8+4KWXXmLkyJHceuut5S5yJ/PmzWPevHmAEyyC0xU0McDVoEGD+PnPf+5pmUQqkQKDClBVVcW1117LySefzI033siiRYtoamqiurqa+vp6Zs6cyYwZMxgypHztIDNnzmTgkIE8/fjTvL7sdZ5Z9Ayff/45AwcOpLGxkWnTpjFt2jRP292nT59Ojx49OP300zuCg0JrS66++mr2228/fvWrX3HHHXfQ2trKLrvswpVXXsnMmTOpq6srcem7euGFF+jTpw9HHnlk1nlra2tpamriiiuu4NFHH+Xmm2+mtraWHXbYgf33358zzzyz7OVN9e9//5u5c+d2eu/NN9/kzTffBGD48OEKDEQ8YMrdpltqY8eOtUuWLMk637JlyzJnV4svussxkOKsX7+egQMHMnPmTK655hq/i+MrHfsSNcaYpdbasV6tTzUG4pnedb0VEJTJ448/Tm1tLRdeeKHfRRGRkFNgIBIBRx99dJeHQImIFEK9EkRERKSDagykYnzSAp+0Qq9a6FX+XEARkVBSYCAV4ZMWeGs9WAvGwM79FRyIiKSjpgSpCJ+0OkGBxXn9pNXvEomIBJMCA6kIvWqdmgKD89qr1u8SiYgEk5oSpCL0qnOaD5RjICLSPQUGUjF61SkgEBHJRk0JIiIi0kGBgYiIiHRQYCAiIiIdFBiIiIhIBwUGIiJBEI/DnDnOq4iP1CtBAqOxsZGFCxfi9aPA6+vrAWhubvZ0vZlo6OYKFI/D5MnQ0gJ1ddDUBA0NfpdKKpRqDCJq6dKlGGMYN25c2ul33303xhiMMbz11ltdpn/22WdstdVWbL311mzatKncxe3exo2wZo3zGmKffvop119/PYcccgiDBg2iR48e7Ljjjhx33HHcd999wJahm/+z0Xn9pMUJmBK/VeKvT58+jBkzhquuuorPPvvM1+8lJRCLOUFBW5vzGov5XSKpYKoxiKj99tuPbbbZhiVLlvDxxx/Tt2/fTtPnz5+PMQZrLfPnz+fss8/uNP3JJ59k06ZNHHbYYfTo0cPLone2cSMsXw7t7VBVBSNHQu/eJV1FU1NTSZeXzksvvcTRRx/NW2+9xfDhw5k6dSoDBw5kxYoVPPTQQ9x///0cddRR/M8t92DpjQVIGbr5jDPOoL6+Hmstq1at4q9//Ss//OEPuf/++3niiSeordVwjqHV2OjUFCRqDBob/S6RVDAFBhFVVVVFY2Mj9913HwsXLuToo4/uNH3+/Pk0Njby/PPPpw0M5s+fD8DkyZM9K3NaGzY4QQE4rxs2lDww2GWXXUqynI0tG9mwaQN9evShd92WMr777rscdthhrFmzhosvvpgrrriCmpoth966deuYNm0aDz74IPbrp/LT390PtuvQzdOnT6cx6YJx5ZVXst9++/HMM89w9913c8YZZ5Tke4gPGhqc5oNYzAkK1IwgPlJTQoQlLuqJi3xCc3Mzb731FpMnT2bChAksWLCgy2fTBQabN2/mpptuYty4cfTt25ett96a/fbbj1/96le0Jy7eSW6//XamTp3KiBEj6NmzJ3379mX8+PHceeeduX+JPn2Yv2QJ/Rob2fErX+HfaZo9ko0aNYq6ujo++OCDtNN/+tOfYozhxhtv7Hivvr6+I88g4aOPPuJnP/sZkyZNYsiQIdTV1bHttttyzDHH8NRTT3VZ7saWjSxfu5x3NrzD8rXL2diypdnjRz/6EWvWrOGUU07hqquu6hQUAAwYMIB7772XESNG8NCDD/Diwnls3zv7EyAHDx7M8ccfD8AzzzzT7XaREGhogIsvVlAgvlNgEGGTJk0CulaVJ/4/adIkJk6cyJo1a3j55Zc7pn/88ccsWbKE/v37s//++wPQ2trKUUcdxXnnncf69euZNm0a55xzDu3t7Xz3u99Ne7d67rnn0tzczCGHHMKMGTM45ZRTePvtt/na177GpZdemtN3uOv++/nKBRew4+DBxBcuZPSXvtTt/GeccQatra3cc889aaffcccd1NXVccopp3S7nGXLlvHDH/6QqqoqjjzySC688EIOO+ww5s+fz8EHH8wjjzzSaf4NmzbQbp3gqN22s2HTBsDJ1UgEQj/+8Y8zrq9Xr17MnDkTgNt/9xu265Vb4mEiUdMYk31mEZFcWGtD9TdmzBibi5dffjmn+aJuxx13tMYY+95773W8N23aNNu7d2/b2tpqX3zxRQvYX/7ylx3TH3jgAQvYKVOmdLx32WWXWcB+5zvfsZs3b+54f/Pmzfass86ygJ03b16ndb/++utdyrNp0yY7adIkW1NTY1etWtVp2oQJE5ynIruuvvpqa4yx48ePt2vXrs3p+65atcpWVVXZdPvJM888YwF7/PHHd3p/+PDhdvjw4Z3eW79+vX3//fe7LGPlypV28ODBdtSoUZ3e37Bpg126eql99p1n7dLVS+2GTRustdYuWrTIAnbHHXfMWvbly5dbwPbq1cu2tbV1vJ/YLgsWLOg0/+rVq+12221nAXvHHXdkXX6l0LEvUQMssR5eZ1VjUALxlXHmPD6H+Mrg9T+eOHEi1tpOzQULFizg4IMPpqamhr322ovtttuuU3NDajNCe3s7v/rVr9hhhx24/vrrqa6u7pi3urqaa6+9FmMMd911V6d1p2u7r6ur47zzzmPz5s0Zk/7a29v5zne+ww9+8AOmTJnCY489xoABA3L6vjvttBOTJ09m6dKlvPTSS52mzZ07FyCntvh+/foxaNCgLu8PGTKEE044gVdeeYUVK1Z0vN+7rjcjB45kpz47MXLgyI4cgzVr1gAwdOjQrOtMzPPJJ5+wfv36LtNvv/12Zs2axWWXXcbZZ5/NnnvuyXvvvceBBx6YtQZERCRXSj4sUnxlnMl3TKalrYW66jqaTm+iYWhw2ggnT57MXXfdxfz58znppJNYtmwZa9as4Xvf+17HPI2NjTz66KO0t7dTVVXVERgceuihACxfvpy1a9ey2267ceWVV6ZdT8+ePVm2bFmn91asWMHVV19NU1MTK1as6NKt7p133km7rKlTpzJv3jy++93vcsMNN1BVlV/8On36dB599FHmzp3LNddcA0BLSwt/+MMf2HbbbfnqV7+a03KefPJJfvGLXxCPx3nvvfdoaWnpUv5hw4Z1/L93Xe9OSYdQeFX/559/3uW9RGADTtPDbrvtxtSpU7nwwgvVI0FESkaBQZFizTFa2lpos220tLUQa44FLjCALXkFyfkFCY2NjfzpT3/iX//6F8OHD+eFF15gp512Yvfddwdg7dq1ALz22mtcfvnlGde1MWmcgTfffJMDDzyQDz/8kIMPPpjDDz+cfv36UV1dTXNzM3Pnzs04PsKiRYuoqanh6KOPzjsoAJgyZQp9+/blzjvvZM6cOVRXV/Pggw+ydu1aZsyY0SX5L5377ruPE044ga222orDDjuMXXbZhV69elFVVUUsFmPhwoU5je8wePBggE61C5msXLkScHqUpKshWbBgQadeCSIi5aDAoEiN9Y3UVdd11Bg01jf6XaROhg0bxi677MLrr7/OypUrmT9/Pv3792e//fbrmGfixImA04QwfPhwrLWdeiP069cPcC64f/3rX3Na73XXXcfatWu57bbbmD59eqdp99xzT6e731QLFizg0EMP5eijj+bee+/lyCOPzPXrAk7txUknncQtt9zCo48+ype//OW8mhEALr30Uurq6liyZAl77LFHp2nf/OY3WbhwYU7LOeCAA+jRowerV69m2bJlXZaV7LHHHgNgr732Yquttspp+SIipaYcgyI1DG2g6fQmZk+cHbhmhITERf6xxx5j4cKFTJgwodOd+KhRoxg8eDDz589P201x1KhR9O/fn/hTcVasW9GpK14mr7/+OuA0C6TKdlHdZ599WLhwIQMGDOD4449n3rx5WdeXKhGMzJ07lw8++ICHH36YffbZh9GjR+f0+ddff50999yzy4W8vb2dJ554Iudy9OzZk9NOOw0gYzMMOL0XrrvuOgCmTZuW8/JFREpNgUEJNAxt4OKDLw5kUABbmg2uv/561q1b11FDkKyxsZHHH3+cf/zjH0DnwKCmpoZvfvubvLvmXS6ccSHPr3q+S3CQ2uUxMS5ALGVo17///e/ccsstWcu8xx57sGjRIrbffntOPPFE/vjHP+b0XRPGjx/Pbrvtxv3338+vf/1rWltbu9RcdKe+vp7XXnuN1atXd7xnreXyyy/v9D1zceWVVzJ48GDuvvtuLr30UjZv3txp+ocffsgJJ5zA66+/zqhRozjvvPPyWr6ISEl52QWiFH/qrpi/9957zxpjLGAB+/zzz3eZ5+abb+6Yvvvuu3eZ/vbat+0hhx9iAbvdDtvZE045wV500UX2rLPOsgcffLCtqqqyc+bM6Zj/ueees3V1dbZHjx522rRp9vvf/779yle+Yo0x9uSTT7aAveyyyzqtI7W7orXWNjc32xEjRtjq6mo7d+7cvL737NmzLWBra2ttTU2Nfffdd9POl6674m9+8xvnu263nT333HPt+eefb8eMGWN79uxpjz766LTdB7vzwgsv2Pr6egvY+vp6+61vfctecskl9rTTTrPbbLNNR5fGdF08M3VXlPSicuwvXrHYXrXoKrt4xWK/iyI+w+Puir5f6PP9U2BQmH322ccCdtCgQba9vb3L9Ndee60jMPj2t7/dZfqGTRvskneW2Mt/cbk94KAD7DbbbGNra2vtjjvuaMePH29/8pOf2BUrVnT6zJNPPmknTpxo+/fvb3v37m3Hjx9v77vvPrtgwYKcAwNrnbEJdt99d1tVVWVvvvnmnL/z22+/bauqqixg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\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "#method_proj = 'proj_eucl_acc', 'proj_eucl', 'proj_eucl_sto_acc', 'proj_eucl_sto' \n",
    "bar.set_parameters(gamma = 1e-2, method_proj = 'proj_eucl_acc', batch_size_proj = 10, nb_iter_proj = 1e4, nb_iter_prox = 500)\n",
    "\n",
    "method = ['OWT', 'OWT_QP', 'OT', 'OTreg']\n",
    "for m in method:\n",
    "    bar.stochastic_bar(m)\n",
    "\n",
    "bar.plot_bar_stochastic(show_data = 'False', show_bar = method)\n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# NON-STOCHASTIC ALGORITHM"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Method OWT with QP\n",
      "Iteration 1 out of 10 done\n",
      "Iteration 2 out of 10 done\n",
      "Iteration 3 out of 10 done\n",
      "Iteration 4 out of 10 done\n",
      "Iteration 5 out of 10 done\n",
      "Iteration 6 out of 10 done\n",
      "Iteration 7 out of 10 done\n",
      "Iteration 8 out of 10 done\n",
      "Iteration 9 out of 10 done\n",
      "Iteration 10 out of 10 done\n",
      "Method OT\n",
      "Iteration 1 out of 10 done\n",
      "Iteration 2 out of 10 done\n",
      "Iteration 3 out of 10 done\n",
      "Iteration 4 out of 10 done\n",
      "Iteration 5 out of 10 done\n",
      "Iteration 6 out of 10 done\n",
      "Iteration 7 out of 10 done\n",
      "Iteration 8 out of 10 done\n",
      "Iteration 9 out of 10 done\n",
      "Iteration 10 out of 10 done\n",
      "Method regularised OT\n",
      "Iteration 1 out of 10 done\n",
      "Iteration 2 out of 10 done\n",
      "Iteration 3 out of 10 done\n",
      "Iteration 4 out of 10 done\n",
      "Iteration 5 out of 10 done\n",
      "Iteration 6 out of 10 done\n",
      "Iteration 7 out of 10 done\n",
      "Iteration 8 out of 10 done\n",
      "Iteration 9 out of 10 done\n",
      "Iteration 10 out of 10 done\n"
     ]
    },
    {
     "data": {
      "image/png": "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IiLiOwUkIiIi4jsFJCIiIuI7BSQiIiLiOwUkIiIi4jsFJCIiIuI7BSQiIiLiu6oaGK0YmzdvZt26dWzYsIFkMul3cUSkjCKRCH379mXHHXekV69efhdHRLKoyYBk8+bNrFixgh122IGmpiYaGhowxvhdLBEpA2stbW1tfPTRR6xYsYIRI0YoKBEJoJpsslm3bh077LADAwcOpLGxUcGISBUzxtDY2MjAgQPZYYcdWLdund9FEpEsajIg2bBhA/369fO7GCJSYf369WPDhg1+F0NEsqjJgCSZTNLQ0OB3MUSkwhoaGpQzJhJQNRmQAGqmEalB+t2LBFfNBiQiIiISHApIRMJq40ZYs8aZioiEXE12+xUJvY0bYdky6OiAujoYPRr69PG7VCIiJVMNibB48WLOP/98Ro0aRe/evenXrx9jxozhyiuv5O23396yXjwexxhT1F9LS4t/H6yabdjgBCPgTNVzRERCTjUkNcxay3e/+11uvPFG6uvrOfroo/niF79Ia2srzz77LD/+8Y+58847mTlzJqeffjpNTU1ce+21nbaxfv16fvKTn9C/f3+mTp3a5T223377ynyYWtO3r1Mzkqoh6dvX7xKJiPSIsdb6XQbPjBs3zi5evDjvekuXLmXvvfeuQImC7Qc/+AHXXnstTU1NPPbYY+y7776dlj/00EOcc845tLW1MXfuXCZMmNBlGy0tLey6666MHDlStSGVtnGjUzPSt6+aa4qg379UG2PMEmvtOL/L0VNqsqlRLS0tTJ8+nYaGBh599NEuwQjAaaedxq233koymeTiiy+mI9VEIMHQpw8MGaJgRESqggKSGnXPPffQ3t7OpEmTGDNmTM71vvzlLzN06FBee+01FixYUMESiohILVFAUqOefvppAI466qhu16uvrycWiwHwzDPPlLtYIiJSoxSQlFsiATNmONMAWbNmDQDDhw/Pu25qndWrV5e1TCIiUrvUy6acEgmYOBFaW6GxEZqbIRr1u1SA08MGChtKu5h1RURESqEaknKKx51gJJl0pvG43yXaYsiQIQCsWLEi77qrVq3q9BoRERGvKSApp1jMqRmJRJypm4sRBIcddhgATz75ZLfrJZNJ4m4gdeihh5a7WCIiUqMUkJRTNOo000yfHqjmGoApU6YQiUR4+OGHefnll3Oud/fdd7N69Wr23HNPxo8fX8ESiohILVFAUm7RKFx1VaCCEYBRo0Zx9dVX09bWxkknncQrr7zSZZ05c+Zw+eWXE4lEuPPOO6mr0+EiIiLloaTWGjZt2jQ+/vhjbrnlFvbff3+OPfZY9t13X9ra2nj22Wd57rnn6N27Nw888ABHHnmk38UVEZEqpoCkhtXV1XHzzTdz5plncscdd7Bw4UKam5uJRCI0NTVxxRVXMHXqVIYNG+Z3UUVEpMopIBEOPvhgDj744JJe29TURDU9D0lERPyhpAARERHxnQISERER8V1gAhJjzI+MMc3GmJXGmE3GmHXGmL8bY641xgzwu3wiIiJSPoEJSIBvAtsBc4GfAPcD7cA04J/GmPwPXREREZFQClJSaz9r7aeZM40x/wNcDVwFfL3ipRIREZGyC0wNSbZgxPUbd7pHpcoiIiIilRWYgKQbJ7rTf/paChERESmbIDXZAGCM+S+gD9AfGAcchhOM/NDPcomIiEj5BC4gAf4L2Dnt/08AU6y172Vb2RhzEXARwIgRI8pfOhEREfFc4JpsrLWDrbUGGAycCowC/m6MOSjH+r+w1o6z1o4bNGhQJYsqIiIiHglcQJJirf23tfZh4BhgADDL5yKJiIhImQQ2IEmx1r4FvALsa4wZ6Hd5RERExHuBD0hcQ91p0tdSiIiISFkEIiAxxuxljBmcZX6dOzDaTsCz1toPKl86ERERKbeg9LI5DrjJGLMQeANYi9PTZjxOUus7wFf8K56IiIiUUyBqSIAngV/gJK+eClwJnAasA64D9rXWvuJf8SRoWlpaMMYwZcqUim3Hq/cUEZGuAhGQWGtfstZeYq09wFo70Fpbb63tb639rLV2mrV2nd9lrHaLFy/m/PPPZ9SoUfTu3Zt+/foxZswYrrzySt5+++1O6xpjivq79957875/Mpnkl7/8JePHj2fHHXekoaGBnXbaif32248vf/nLPProo2X65BIGv/vd7/jGN77B4YcfTr9+/TDGcM455/hdLBHxUFCabMQn1lq++93vcuONN1JfX8/RRx/NF7/4RVpbW3n22Wf58Y9/zJ133snMmTM5/fTTAbj22mu7bOe2227jww8/5PLLL2f77bfvtOyAAw7otgzJZJITTjiBJ554gu23357jjz+eYcOGsW7dOt544w1mz57Nq6++ykknnbTlNbvssgtLly6lf//+Pd4HEnzXX389//jHP+jTpw/Dhg3j1Vdf9btIIuIxBSQ1bvr06dx44400NTXx2GOPse+++3Za/tBDD3HOOedw1llnMXfuXCZMmMC0adO6bOfee+/lww8/ZOrUqTQ1NRVVhgceeIAnnniC/fffnwULFnQJMj755BOee+65TvMaGhrYa6+9inofCa9bb72VYcOGsfvuu7NgwQImTJjgd5FExGOBaLIRf7S0tDB9+nQaGhp49NFHuwQjAKeddhq33noryWSSiy++mI6ODs/L8eyzzwIwZcqUrDUe2267bZcLULZ8jvR5LS0tnHXWWQwcOJBtttmGcePG8dhjjxVcpo6ODi677DKMMZx66ql8+mnnh1EXu/3f/OY3HHHEEfTv35/evXszZswYZsyYwebNm3N+rmXLlnHmmWey0047UVdXRzwe9/QzFuLVV1/l61//OnvssQfbbrst/fr1Y6+99uLMM8/sUvZymjBhAnvssQfGmIq9p4hUlgKSGnbPPffQ3t7OpEmTGDNmTM71vvzlLzN06FBee+01FixY4Hk5BgwYAMCyZcs82d5bb73FwQcfTEtLC1/60pc488wzeemllzj55JOZP39+3td/+umnnHHGGfz0pz/lkksu4Xe/+x3bbLNNydu/+uqrOfPMM1m6dCmTJ0/m0ksvxVrL1VdfzbHHHktbW1uX17zxxht87nOfo6WlhbPPPpuLLrqIfv36efYZCxGPxznwwAO5++672X///bn88suZMmUKo0aN4h//+Ae9evXy5H1EREBNNjXt6aefBuCoo47qdr36+npisRizZ8/mmWee8by6/NRTT+VHP/oRP/vZz9iwYQOTJk1i7NixjBw5sqTtxeNxpk2b1inXZfLkyRx33HHcdNNN3ZZ/3bp1nHzyyTzzzDP88Ic/5Dvf+U6Ptp9IJJgxYwbDhw/n+eefZ/BgZ7idGTNmMGnSJB577DFuuukmrr766k7v8fTTT3PVVVdxww03dJrf0tLS489YqO9973u0tbXx/PPPc9BBWR8lldNtt93G+vXrC17/gAMO4JRTTimugCJSXay1VfM3duxYW4hXXnmloPW8sHi1tbc/70yDZu+997aAffzxx/Ou+53vfMcC9uKLL866fOTIkRawb775ZkllefDBB+3gwYMtsOVvxx13tKeccop99NFHu6z/5ptvWsCed955XeaNHDnStre3d3nNiBEj7IAB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27AlNql8+umnXealAipwmnj22GMPTjvtNL71rW+ph42IhIICkjKKNcVojDTSmmylMdJIrCnmd5E6SdVypGoj0vNHUmKxGL/5zW/4+9//zsiRI3nxxRfZZZdd2HPPPQFYu3YtAK+//jrXXXddzvfauHHjln//61//4uCDD+aDDz7g8MMP55hjjqF///5EIhFaWlqYOXNmzvFNFi5cSH19PSeeeGLRwQjApEmT6NevH/fddx8zZswgEonw2GOPsXbtWqZOndolqTSbhx9+mNNPP51tttmGo48+mt12243tttuOuro64vE4CxYsKGh8liFDhgAUVJuycuVKwOkhla1GaP78+cTUG0NEQkwBSRlFh0dpPreZeEucWFMsULUjACNGjGC33XZj+fLlrFy5knnz5rH99ttz4IEHbllnwoQJgNNUM3LkSKy1nXrX9O/fH3Au9L///e8Let9bbrmFtWvXcs899zBlypROyx544IFOd/uZ5s+fz1FHHcWJJ57IQw89xPHHH1/oxwWc2pozzjiDX/3qV8ydO5fjjjuuqOYagGuuuYbGxkYWL17M3nvv3WnZV7/61axdqbP57Gc/S69evVi9ejVLly7tsq10Tz75JAD77rsv22yzTUHbFxEJE+WQlFl0eJSrDr8qcMFISiq4ePLJJ1mwYAHjx4/vVPOw1157MWTIEObNm5e1u+9ee+3F9ttvz6JFi2hrayvoPZcvXw44zS+Z8l3M99tvPxYsWMCOO+7IqaeeWnA32HSpIGjmzJm8//77PP744+y33355e+mkLF++nH322adLANHR0cHTTz9dcDl69+7NOeecA5CzuQuc3ji33HILAJMnTy54+yIiYaKApMalmmduvfVW1q1bt6VGJF0sFuOpp57iL3/5C9A5IKmvr+cb3/gGa9as4bLLLss6VHlm1+HUuB7xeLzTen/+85/51a9+lbfMe++9NwsXLmTnnXfmi1/8Ig8++GDe16Q79NBD2WOPPXjkkUe46667aGtr61JT052mpiZef/11Vq9evWWetZbrrruu0+csxPXXX8/gIYOZPXs237n6O7S3t3da/sEHH3D66aezfPly9tprLy655JKiti8iEhp+d/Px8i+I3X6D7t1337XGGAtYwP7zn//sss4vfvGLLcv33HPPLstbW1vtSSedZAG7yy672C996Uv2u9/9rr3gggvs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erhPu/OeO625Jpse7NN9caq6zzfGnJ9jndfdBNdJtZZfUsZj9XF3GivT9gPLi31qjKnHycH5ojs9t5Zz8cp4nFa10AUkPdQMfAP4TOYCt90z1eWvpYJlqmaHuNN/+VqKcGkB/jfHsuNxxiL5LfAROk69tIs7VY+QIrlN3L8BTgZmAedn614tkk+tBSSP41wcj3VHZJybtuwanN43C6y17/hSuhAyxnwO+Lu1tjVj/pE4bfPgVONKAay1L5Aj58bttTQYuFpd1IvnHqsvWms/yZjfh61Nin+seMFCzL2R+z1Ot+n/BS5SMCKlMrXWxGeMOQxnVMZG4GHgLZzuwEfgNDEcZq3V0PEFci+S++IMgrTKnb0fcKT772ustddXvmTVx93X44E9FJAUzxgzB6dJZgFO7sgnOOMQfQHYHmck12OttRv9KWH4GGPuAaYA7wN3AtkuKHFrbbyCxQo9Y8x3gb3c/x4A7I9zfL7uznvaWvsrH4pWVrVWQ4K19mljzDicbn8TcE5E/8YZEXO6tXZVNy+Xrn4NTMIJ6r4ANODsz98At1trn/KxbCLpfgl8jHOsxoBtcfLGluAcr3frOTZF29WdDsTpRp1LvPxFqSrH0fUxEZ+n86i3VReQ1FwNiYiIiARP6MYhERERkeqjgERERER8p4BEREREfKeARERERHyngERERER8p4BEREREfKeARERERHyngERERER8p4BEREREfKeARERERHz3/wGaWYzQ4gwKMAAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 576x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "nb_iter = 10\n",
    "method = ['OWT', 'OWT_QP', 'OT', 'OTreg']\n",
    "for m in method:\n",
    "    bar.non_stochastic_bar(m, nb_iter)\n",
    "bar.plot_bar_non_stochastic(show_data = 'False', show_bar = method)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
