{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Calculate the Wasserstein distance on empirical data points"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append('./lib')\n",
    "import time\n",
    "import ot\n",
    "import numpy as np\n",
    "from scipy.linalg import sqrtm\n",
    "from PPMM_func import projOtm\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# # Example 1: Data points with equal weights"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Generate the data points from multivariate-Gaussian distribution, calcualte the true Wasserstein distance and the Sinkhorn distance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished data generatation.\n",
      "Finished Sinkhorn(1), Time Lapse:  18.745425939559937 s\n"
     ]
    }
   ],
   "source": [
    "N = 10000\n",
    "pp = 10\n",
    "ITR = 100\n",
    "Mu1 = np.repeat(1, pp)\n",
    "Mu2 = np.repeat(-1, pp)\n",
    "\n",
    "S1 = np.zeros((pp, pp))\n",
    "S2 = np.zeros((pp, pp))\n",
    "\n",
    "for i in range(pp):\n",
    "    for j in range(pp):\n",
    "        S1[i,j] = 0.8**(abs(i-j))\n",
    "        S2[i,j] = 0.5**(abs(i-j))\n",
    "\n",
    "a, b = np.ones((N,)) / N, np.ones((N,)) / N\n",
    "\n",
    "np.random.seed(10)        \n",
    "ori_dat = np.random.multivariate_normal(Mu1, S1, N)\n",
    "des_dat = np.random.multivariate_normal(Mu2, S2, N)\n",
    "#Calculate the true Wasserstein distance\n",
    "W_true = np.sqrt(sum((Mu1-Mu2)**2)+np.matrix.trace(S1+S2-2*sqrtm(sqrtm(S1)@S2@sqrtm(S1))))\n",
    "print('Finished data generatation.')\n",
    "time_start=time.time()\n",
    "#Calculate the true empirical Sinkhorn distance\n",
    "Sinkhorn = np.sqrt(ot.bregman.empirical_sinkhorn2(ori_dat, des_dat, reg=1, a=a, b=b, verbose=False))\n",
    "time_end=time.time()\n",
    "print('Finished Sinkhorn(1), Time Lapse: ', time_end-time_start,'s')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Calculate the Wasserstein distance use difference projection-based methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished PPMM(SAVE), Time Lapse:  3.563474416732788 s\n",
      "Finished PPMM(DR), Time Lapse:  3.918522357940674 s\n",
      "Finished RANDOM, Time Lapse:  1.6176764965057373 s\n",
      "Finished SLICED(10), Time Lapse:  15.573378562927246 s\n"
     ]
    }
   ],
   "source": [
    "dist_hat_save = [0]\n",
    "itr_data = ori_dat\n",
    "\n",
    "time_start=time.time()\n",
    "for i in range(ITR):\n",
    "    itr_data = projOtm(itr_data, des_dat, a, b, method = \"SAVE\")\n",
    "    ddd = itr_data - ori_dat\n",
    "    dist_hat_save.append(np.sqrt(np.mean(np.sum(ddd**2, axis = 1))))\n",
    "time_end=time.time()\n",
    "print('Finished PPMM(SAVE), Time Lapse: ', time_end-time_start,'s')\n",
    "\n",
    "\n",
    "dist_hat_dr = [0]\n",
    "itr_data = ori_dat\n",
    "\n",
    "time_start=time.time()\n",
    "for i in range(ITR):\n",
    "    itr_data = projOtm(itr_data, des_dat, a, b, method = \"DR\")\n",
    "    ddd = itr_data - ori_dat\n",
    "    dist_hat_dr.append(np.sqrt(np.mean(np.sum(ddd**2, axis = 1))))\n",
    "time_end=time.time()\n",
    "print('Finished PPMM(DR), Time Lapse: ', time_end-time_start,'s')\n",
    "\n",
    "\n",
    "\n",
    "dist_hat_random = [0]\n",
    "itr_data = ori_dat\n",
    "\n",
    "time_start=time.time()\n",
    "for i in range(ITR):\n",
    "    itr_data = projOtm(itr_data, des_dat, a, b, method = \"RANDOM\")\n",
    "    ddd = itr_data - ori_dat\n",
    "    dist_hat_random.append(np.sqrt(np.mean(np.sum(ddd**2, axis = 1))))\n",
    "time_end=time.time()\n",
    "print('Finished RANDOM, Time Lapse: ', time_end-time_start,'s')\n",
    "\n",
    "\n",
    "\n",
    "dist_hat_sliced= [0]\n",
    "itr_data = ori_dat\n",
    "\n",
    "time_start=time.time()\n",
    "for i in range(ITR):\n",
    "    itr_data = projOtm(itr_data, des_dat, a, b, method = \"SLICED\", nslice=10)\n",
    "    ddd = itr_data - ori_dat\n",
    "    dist_hat_sliced.append(np.sqrt(np.mean(np.sum(ddd**2, axis = 1))))\n",
    "time_end=time.time()\n",
    "print('Finished SLICED(10), Time Lapse: ', time_end-time_start,'s')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x1d63a0920f0>"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.style.use('seaborn')\n",
    "%matplotlib inline\n",
    "x = range(ITR+1)\n",
    "plt.plot(x, np.repeat(W_true, ITR+1), color='black', linestyle='--', label='True Wasserstein distance')\n",
    "plt.plot(x, np.repeat(Sinkhorn, ITR+1), color='black', linestyle=':', label='Sinkhorn(1)')\n",
    "plt.plot(x, dist_hat_save, color='red', label='PPMM(SAVE)')\n",
    "plt.plot(x, dist_hat_dr, color='purple', label='PPMM(DR)')\n",
    "plt.plot(x, dist_hat_random, color='green', label='RANDOM')\n",
    "plt.plot(x, dist_hat_sliced, color='blue', label='SLICED(10)')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "One can observe that PPMM converges to the true Wasserstein distance.\n",
    "Also, PPMM converges faster than RANDOM and SLICED."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# # Example 2: Data points with unequal weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished data generatation.\n",
      "Finished Sinkhorn(1), Time Lapse:  23.28735613822937 s\n"
     ]
    }
   ],
   "source": [
    "N = 10000\n",
    "pp = 10\n",
    "ITR = 100\n",
    "Mu1 = np.repeat(1, pp)\n",
    "Mu2 = np.repeat(-1, pp)\n",
    "\n",
    "S1 = np.zeros((pp, pp))\n",
    "S2 = np.zeros((pp, pp))\n",
    "\n",
    "for i in range(pp):\n",
    "    for j in range(pp):\n",
    "        S1[i,j] = 0.8**(abs(i-j))\n",
    "        S2[i,j] = 0.5**(abs(i-j))\n",
    "\n",
    "a_raw, b_raw = np.random.uniform(size=N), np.random.uniform(size=N)\n",
    "#Manulally adjust some weights to mimic the setting of non-uniform weights\n",
    "a_raw[range(100)]=5000\n",
    "b_raw[range(100)]=1000\n",
    "a, b = a_raw/sum(a_raw), b_raw/sum(b_raw)\n",
    "\n",
    "np.random.seed(10)        \n",
    "ori_dat = np.random.multivariate_normal(Mu1, S1, N)\n",
    "des_dat = np.random.multivariate_normal(Mu2, S2, N)\n",
    "\n",
    "print('Finished data generatation.')\n",
    "time_start=time.time()\n",
    "#Calculate the true empirical Sinkhorn distance\n",
    "Sinkhorn = np.sqrt(ot.bregman.empirical_sinkhorn2(ori_dat, des_dat, reg=1, a=a, b=b, verbose=False))\n",
    "\n",
    "time_end=time.time()\n",
    "print('Finished Sinkhorn(1), Time Lapse: ', time_end-time_start,'s')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([6.67230115])"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Sinkhorn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Finished PPMM(SAVE), Time Lapse:  3.355031967163086 s\n",
      "Finished PPMM(DR), Time Lapse:  3.2692670822143555 s\n",
      "Finished RANDOM, Time Lapse:  1.52293062210083 s\n",
      "Finished SLICED(10), Time Lapse:  13.697385311126709 s\n"
     ]
    }
   ],
   "source": [
    "dist_hat_save = [0]\n",
    "itr_data = ori_dat\n",
    "\n",
    "time_start=time.time()\n",
    "for i in range(ITR):\n",
    "    itr_data = projOtm(itr_data, des_dat, a, b, method = \"SAVE\")\n",
    "    ddd = itr_data - ori_dat\n",
    "    dist_hat_save.append(np.sqrt(np.mean(np.sum(ddd**2, axis = 1)*a*N)))\n",
    "time_end=time.time()\n",
    "print('Finished PPMM(SAVE), Time Lapse: ', time_end-time_start,'s')\n",
    "\n",
    "\n",
    "dist_hat_dr = [0]\n",
    "itr_data = ori_dat\n",
    "\n",
    "time_start=time.time()\n",
    "for i in range(ITR):\n",
    "    itr_data = projOtm(itr_data, des_dat, a, b, method = \"DR\")\n",
    "    ddd = itr_data - ori_dat\n",
    "    dist_hat_dr.append(np.sqrt(np.mean(np.sum(ddd**2, axis = 1)*a*N)))\n",
    "time_end=time.time()\n",
    "print('Finished PPMM(DR), Time Lapse: ', time_end-time_start,'s')\n",
    "\n",
    "\n",
    "\n",
    "dist_hat_random = [0]\n",
    "itr_data = ori_dat\n",
    "\n",
    "time_start=time.time()\n",
    "for i in range(ITR):\n",
    "    itr_data = projOtm(itr_data, des_dat, a, b, method = \"RANDOM\")\n",
    "    ddd = itr_data - ori_dat\n",
    "    dist_hat_random.append(np.sqrt(np.mean(np.sum(ddd**2, axis = 1)*a*N)))\n",
    "time_end=time.time()\n",
    "print('Finished RANDOM, Time Lapse: ', time_end-time_start,'s')\n",
    "\n",
    "\n",
    "\n",
    "dist_hat_sliced= [0]\n",
    "itr_data = ori_dat\n",
    "\n",
    "time_start=time.time()\n",
    "for i in range(ITR):\n",
    "    itr_data = projOtm(itr_data, des_dat, a, b, method = \"SLICED\", nslice=10)\n",
    "    ddd = itr_data - ori_dat\n",
    "    dist_hat_sliced.append(np.sqrt(np.mean(np.sum(ddd**2, axis = 1)*a*N)))\n",
    "time_end=time.time()\n",
    "print('Finished SLICED(10), Time Lapse: ', time_end-time_start,'s')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x1d63a20ce10>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.style.use('seaborn')\n",
    "%matplotlib inline\n",
    "x = range(ITR+1)\n",
    "plt.plot(x, np.repeat(Sinkhorn, ITR+1), color='black', linestyle=':', label='Sinkhorn(1)')\n",
    "plt.plot(x, dist_hat_save, color='red', label='PPMM(SAVE)')\n",
    "plt.plot(x, dist_hat_dr, color='purple', label='PPMM(DR)')\n",
    "plt.plot(x, dist_hat_random, color='green', label='RANDOM')\n",
    "plt.plot(x, dist_hat_sliced, color='blue', label='SLICED(10)')\n",
    "plt.legend()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "One can observe that PPMM converges faster than RANDOM and SLICED, and the final result is similar to the result of Sinkhorn(1)."
   ]
  }
 ],
 "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.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
