{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "GRdoE3U-SybK"
   },
   "source": [
    "## Compare convergence rates 1d for Online Sinkhorn\n",
    "\n",
    "This notebook compares the theoretical convergence rates with the old paper.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 2357,
     "status": "ok",
     "timestamp": 1694674063950,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "Zes9WhQ1rcDp",
    "outputId": "aca8eb03-f9c3-423e-e83c-208274dfdaa1"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Drive already mounted at /content/drive; to attempt to forcibly remount, call drive.mount(\"/content/drive\", force_remount=True).\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "['closed_forms.py',\n",
       " 'helper.py',\n",
       " 'gq.py',\n",
       " 'recombination.py',\n",
       " 'recombination2.py',\n",
       " 'README.md',\n",
       " 'compression.py',\n",
       " 'algorithms.py',\n",
       " 'OS_theoretical_cts_1d.pkl',\n",
       " 'OS_theoretical_cts_2d.pkl',\n",
       " 'OS_theoretical_cts_5d.pkl',\n",
       " 'example_gmm_5d.pkl',\n",
       " 'example_gmm_2d.pkl',\n",
       " 'example_cts_1d.ipynb',\n",
       " 'example_cts_1d.pkl',\n",
       " 'example_gmm_5d.ipynb',\n",
       " 'example_gmm_2d.ipynb',\n",
       " 'OS_theortical_cts_2d.ipynb',\n",
       " 'OS_theortical_cts_5d.ipynb',\n",
       " 'OS_theortical_cts_1d.ipynb']"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from google.colab import drive\n",
    "drive.mount(\"/content/drive\")\n",
    "path=\"/content/drive/My Drive/Colab Notebooks/COT-gcopy\"\n",
    "import os\n",
    "os.chdir(path)\n",
    "os.listdir(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 6552,
     "status": "ok",
     "timestamp": 1694674070495,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "FQYGMCvpsMZN",
    "outputId": "cf0378b6-6d2b-4fb3-f5c5-97cb4fc55e0f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Collecting celer\n",
      "  Downloading celer-0.7.3-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (4.5 MB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m4.5/4.5 MB\u001b[0m \u001b[31m39.7 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hRequirement already satisfied: seaborn>=0.7 in /usr/local/lib/python3.10/dist-packages (from celer) (0.12.2)\n",
      "Requirement already satisfied: matplotlib>=2.0.0 in /usr/local/lib/python3.10/dist-packages (from celer) (3.7.1)\n",
      "Collecting libsvmdata>=0.3 (from celer)\n",
      "  Downloading libsvmdata-0.4.1-py3-none-any.whl (7.0 kB)\n",
      "Requirement already satisfied: scikit-learn>=1.0 in /usr/local/lib/python3.10/dist-packages (from celer) (1.2.2)\n",
      "Requirement already satisfied: xarray in /usr/local/lib/python3.10/dist-packages (from celer) (2023.7.0)\n",
      "Collecting download (from celer)\n",
      "  Downloading download-0.3.5-py3-none-any.whl (8.8 kB)\n",
      "Requirement already satisfied: tqdm in /usr/local/lib/python3.10/dist-packages (from celer) (4.66.1)\n",
      "Requirement already satisfied: numpy>=1.12 in /usr/local/lib/python3.10/dist-packages (from libsvmdata>=0.3->celer) (1.23.5)\n",
      "Requirement already satisfied: scipy in /usr/local/lib/python3.10/dist-packages (from libsvmdata>=0.3->celer) (1.11.2)\n",
      "Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.0->celer) (1.1.0)\n",
      "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.0->celer) (0.11.0)\n",
      "Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.0->celer) (4.42.1)\n",
      "Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.0->celer) (1.4.5)\n",
      "Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.0->celer) (23.1)\n",
      "Requirement already satisfied: pillow>=6.2.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.0->celer) (9.4.0)\n",
      "Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.0->celer) (3.1.1)\n",
      "Requirement already satisfied: python-dateutil>=2.7 in /usr/local/lib/python3.10/dist-packages (from matplotlib>=2.0.0->celer) (2.8.2)\n",
      "Requirement already satisfied: joblib>=1.1.1 in /usr/local/lib/python3.10/dist-packages (from scikit-learn>=1.0->celer) (1.3.2)\n",
      "Requirement already satisfied: threadpoolctl>=2.0.0 in /usr/local/lib/python3.10/dist-packages (from scikit-learn>=1.0->celer) (3.2.0)\n",
      "Requirement already satisfied: pandas>=0.25 in /usr/local/lib/python3.10/dist-packages (from seaborn>=0.7->celer) (1.5.3)\n",
      "Requirement already satisfied: six in /usr/local/lib/python3.10/dist-packages (from download->celer) (1.16.0)\n",
      "Requirement already satisfied: requests in /usr/local/lib/python3.10/dist-packages (from download->celer) (2.31.0)\n",
      "Requirement already satisfied: pytz>=2020.1 in /usr/local/lib/python3.10/dist-packages (from pandas>=0.25->seaborn>=0.7->celer) (2023.3.post1)\n",
      "Requirement already satisfied: charset-normalizer<4,>=2 in /usr/local/lib/python3.10/dist-packages (from requests->download->celer) (3.2.0)\n",
      "Requirement already satisfied: idna<4,>=2.5 in /usr/local/lib/python3.10/dist-packages (from requests->download->celer) (3.4)\n",
      "Requirement already satisfied: urllib3<3,>=1.21.1 in /usr/local/lib/python3.10/dist-packages (from requests->download->celer) (2.0.4)\n",
      "Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.10/dist-packages (from requests->download->celer) (2023.7.22)\n",
      "Installing collected packages: download, libsvmdata, celer\n",
      "Successfully installed celer-0.7.3 download-0.3.5 libsvmdata-0.4.1\n"
     ]
    }
   ],
   "source": [
    "!pip install celer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 9514,
     "status": "ok",
     "timestamp": 1694674080002,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "ybc4BzbN62xN",
    "outputId": "95ab967b-9863-4a82-f82e-45a5dee50cd5"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Collecting pykeops\n",
      "  Downloading pykeops-2.1.2.tar.gz (88 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m88.9/88.9 kB\u001b[0m \u001b[31m1.0 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25h  Preparing metadata (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
      "Requirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from pykeops) (1.23.5)\n",
      "Collecting pybind11 (from pykeops)\n",
      "  Downloading pybind11-2.11.1-py3-none-any.whl (227 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m227.7/227.7 kB\u001b[0m \u001b[31m7.4 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25hCollecting keopscore==2.1.2 (from pykeops)\n",
      "  Downloading keopscore-2.1.2.tar.gz (84 kB)\n",
      "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m84.5/84.5 kB\u001b[0m \u001b[31m6.1 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
      "\u001b[?25h  Preparing metadata (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
      "Building wheels for collected packages: pykeops, keopscore\n",
      "  Building wheel for pykeops (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
      "  Created wheel for pykeops: filename=pykeops-2.1.2-py3-none-any.whl size=114071 sha256=69ab3c0e9de89f9483a20d488bd7a96afd5b266bd2b8fdd3336da394759b5cc1\n",
      "  Stored in directory: /root/.cache/pip/wheels/93/91/9e/279e56403818cf05d868c2d90a13bde97572bcd11673d6e8ef\n",
      "  Building wheel for keopscore (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
      "  Created wheel for keopscore: filename=keopscore-2.1.2-py3-none-any.whl size=146448 sha256=c5a531daaec8e252db68bf3bff55639e96285715b70e90adfd5e9c118014fc87\n",
      "  Stored in directory: /root/.cache/pip/wheels/63/ac/b7/75fb4d24be97d9a930905eddf822cb765ca204b83df7aeaaa9\n",
      "Successfully built pykeops keopscore\n",
      "Installing collected packages: pybind11, keopscore, pykeops\n",
      "Successfully installed keopscore-2.1.2 pybind11-2.11.1 pykeops-2.1.2\n"
     ]
    }
   ],
   "source": [
    "import locale\n",
    "locale.getpreferredencoding = lambda: \"UTF-8\"\n",
    "!pip install pykeops"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "executionInfo": {
     "elapsed": 15,
     "status": "ok",
     "timestamp": 1694674080003,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "tfRHebKAdox5"
   },
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 30963,
     "status": "ok",
     "timestamp": 1694674110955,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "6f4hsauPrjGD",
    "outputId": "50521e5e-6b27-43f4-a559-29f951edeacd"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[KeOps] Compiling cuda jit compiler engine ... OK\n",
      "[pyKeOps] Compiling nvrtc binder for python ... OK\n",
      "Import recombination2\n",
      "2\n",
      "Importing algorithms.py\n"
     ]
    }
   ],
   "source": [
    "import math\n",
    "import timeit\n",
    "import random\n",
    "import pickle\n",
    "import os\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as pl\n",
    "\n",
    "# exact solution of Gaussian OT\n",
    "from closed_forms import closed_form\n",
    "# for Sinkhorn, Online Sinkhorn, Compressed\n",
    "import algorithms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "executionInfo": {
     "elapsed": 21,
     "status": "ok",
     "timestamp": 1694674110959,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "eutcKoFrrjN5"
   },
   "outputs": [],
   "source": [
    "# generate data and parameters\n",
    "size = 3000 # problem dimension (for Sinkhorn)\n",
    "d = 1 # sample dimension\n",
    "##\n",
    "if d == 1:\n",
    "    mean1, cov1 = 1., 2.\n",
    "    mean2, cov2 = 3., 2.5\n",
    "else:\n",
    "    mean1 = 10*np.random.rand(d)\n",
    "    mean2 = 5*np.random.rand(d)\n",
    "    cov1 = algorithms.random_cov_matrix(d)\n",
    "    cov2 = algorithms.random_cov_matrix(d)\n",
    "## objective function\n",
    "def loss(f,g):\n",
    "  deg=20\n",
    "  return algorithms.GaussHermiteIntegrate(mean1,cov1,f,mean2,cov2,g,deg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "executionInfo": {
     "elapsed": 20,
     "status": "ok",
     "timestamp": 1694674110960,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "Cam41gGGR206"
   },
   "outputs": [],
   "source": [
    "# test distribution\n",
    "def samp1(n, d):\n",
    "    # generate samples from test distribution 2\n",
    "    if d == 1:\n",
    "      x = np.random.normal(mean1,cov1,n)\n",
    "    else:\n",
    "      x = np.random.multivariate_normal(mean1, cov1, n)\n",
    "    return x\n",
    "# test distribution\n",
    "def samp2(n, d):\n",
    "    # generate samples from test distribution 2\n",
    "    if d == 1:\n",
    "      x = np.random.normal(mean2,cov2,n)\n",
    "    else:\n",
    "      x = np.random.multivariate_normal(mean2, cov2, n)\n",
    "    return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 20,
     "status": "ok",
     "timestamp": 1694674110961,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "vL9MUt27399P",
    "outputId": "002aa02d-13ef-488f-a21b-e2575658b28a"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Exact form\n",
      "A mean= [1.] covariance= [[2.]]\n",
      "B mean= [3.] covariance= [[2.5]]\n",
      "epsilon is 0.3\n",
      "a= 1.2 ; b= -0.6\n"
     ]
    }
   ],
   "source": [
    "size_var=10\n",
    "params={}\n",
    "params = {'b': -0.6,# b<a-1 with b=0 corresponding to Sinkhorn\n",
    "          'eta_decay_const':50, # eta=(1+(t/eta_decay_const)^b)\n",
    "          'a': 1.2, # n_t=t^{2a} for a>1+b (number of samples upto iteration t)\n",
    "          'epsilon': 0.3, # regularisation parametr\n",
    "          \"dim\": d,\n",
    "          'maxits': 60,\n",
    "          'no_initial_sinkhorn_its':30,\n",
    "          'compress':True,\n",
    "          'min_compress':5000,\n",
    "          'get_samples1':samp1,\n",
    "          'get_samples2':samp2,\n",
    "          'zeta':0.95, # compression error rate\n",
    "          'compression_const':0.5, # multiply constant for working out compression\n",
    "          't_sampling':'qmc_gau',\n",
    "          'compression_skip':3,# number of steps between compression\n",
    "          #'measure':loss,# for evaluating the objective function in OS\n",
    "          'test_samples1':samp1(size,d),\n",
    "          'test_samples2':samp2(size,d),\n",
    "          'test_samples1_obj':samp1(size_var,d),\n",
    "          'test_samples2_obj':samp2(size_var,d),\n",
    "          'test_samples1_var':samp1(size_var,d),\n",
    "          'test_samples2_var':samp2(size_var,d),\n",
    "          }\n",
    "if d==1:\n",
    "  params[\"measure\"]=loss\n",
    "#\n",
    "exact=algorithms.get_gaussian_potentials(cov1,cov2,mean1,mean2,params['epsilon'])\n",
    "params['exact_f']=lambda tt: exact[0](tt)\n",
    "params['exact_g']=lambda tt: exact[1](tt)\n",
    "\n",
    "#\n",
    "if (params['a']-params['b']<1):\n",
    "    print('Params violate a-b>1 condition')\n",
    "    exit()\n",
    "print('epsilon is', params['epsilon'])\n",
    "print('a=', params['a'], '; b=', params['b'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 536,
     "status": "ok",
     "timestamp": 1694674111481,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "KW2va0Ju4Qll",
    "outputId": "96f66277-0237-4797-982f-e7fbf2deee82"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Objective (theoretical)  4.585655226884807\n"
     ]
    }
   ],
   "source": [
    "# Theoretical results for sqeuclidean cost\n",
    "sigma=(params[\"epsilon\"]/2)**0.5\n",
    "if d == 1:\n",
    "  theoretical = closed_form(np.array([[cov1]]), np.array([[cov2]]), sigma, mean1, mean2)\n",
    "else:\n",
    "  theoretical = closed_form(cov1, cov2, sigma, mean1, mean2)\n",
    "#theoretical-=2*params['epsilon']\n",
    "print(\"Objective (theoretical) \",exact[2])\n",
    "#print(\"Objective (Gauss-Hermite quadrature)\",loss(params['exact_f'],params['exact_g']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 1639214,
     "status": "ok",
     "timestamp": 1694675750685,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "2L38LtCe4hQT",
    "outputId": "ab0a11d2-86e4-4d2f-9b74-9617778a7022"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running online sinkhorn...\n",
      "Online Sinkhorn with Compression= False\n",
      "[KeOps] Generating code for formula Max_SumShiftExpWeight_Reduction(Concat((Var(0,1,1)-(Var(1,1,1)-Var(2,1,0))**2)/Var(3,1,2),1),0) ... OK\n",
      "Running 30 Sinkhorn iterations to start-up.\n",
      "step is 0 obj is 4.14582659036693 err is 0.30004601450250745 ; eta= 1.0 OS step time 0.03\n",
      "step is 1 obj is 4.174939329412565 err is 0.4212033858087949 ; eta= 0.9881887308219607 OS step time 0.07\n",
      "step is 2 obj is 4.194141353552465 err is 0.3587718019042416 ; eta= 0.976742300461482 OS step time 0.11\n",
      "step is 3 obj is 4.209814598374563 err is 0.28451759824977874 ; eta= 0.9656427425776481 OS step time 0.16\n",
      "step is 4 obj is 4.232074610793313 err is 0.33225631137179423 ; eta= 0.9548732931041548 OS step time 0.20\n",
      "step is 5 obj is 4.251321522996408 err is 0.31371589983258197 ; eta= 0.9444182893218951 OS step time 0.25\n",
      "step is 6 obj is 4.2698583799451635 err is 0.24972840107199357 ; eta= 0.9342630790612149 OS step time 0.31\n",
      "step is 7 obj is 4.283527823136642 err is 0.3275707173581095 ; eta= 0.924393938856702 OS step time 0.38\n",
      "step is 8 obj is 4.297723976240738 err is 0.2507122487341631 ; eta= 0.9147980000321643 OS step time 0.44\n",
      "step is 9 obj is 4.31105447795567 err is 0.29032409501545686 ; eta= 0.905463181825604 OS step time 0.56\n",
      "step is 10 obj is 4.3190575294094256 err is 0.2749664193904353 ; eta= 0.8963781307771418 OS step time 0.63\n",
      "step is 11 obj is 4.337347123428739 err is 0.3008560904218607 ; eta= 0.8875321656999794 OS step time 0.71\n",
      "step is 12 obj is 4.348101524691141 err is 0.2881602739879803 ; eta= 0.8789152276381142 OS step time 0.80\n",
      "step is 13 obj is 4.357282862644368 err is 0.2126957757131578 ; eta= 0.870517834286684 OS step time 0.91\n",
      "step is 14 obj is 4.367145761072814 err is 0.21665797636284712 ; eta= 0.8623310384132593 OS step time 0.99\n",
      "step is 15 obj is 4.379313009547466 err is 0.230132259972752 ; eta= 0.8543463898725555 OS step time 1.10\n",
      "step is 16 obj is 4.390930777775368 err is 0.25448093301934716 ; eta= 0.8465559008541063 OS step time 1.54\n",
      "step is 17 obj is 4.399471306766561 err is 0.207431472019163 ; eta= 0.8389520140434555 OS step time 1.71\n",
      "step is 18 obj is 4.409774616753826 err is 0.2321672805405095 ; eta= 0.8315275734132361 OS step time 1.85\n",
      "step is 19 obj is 4.416826617175882 err is 0.21322330581442817 ; eta= 0.8242757973918322 OS step time 2.15\n",
      "step is 20 obj is 4.425663457837826 err is 0.17479616216878213 ; eta= 0.8171902541848022 OS step time 2.47\n",
      "step is 21 obj is 4.431498451179461 err is 0.18640975918673064 ; eta= 0.8102648390483675 OS step time 2.68\n",
      "step is 22 obj is 4.438137958790978 err is 0.20290956810977878 ; eta= 0.8034937533355226 OS step time 2.92\n",
      "step is 23 obj is 4.445471715956741 err is 0.18243232421157707 ; eta= 0.7968714851540509 OS step time 3.17\n",
      "step is 24 obj is 4.450205520371236 err is 0.1430490395664652 ; eta= 0.7903927914922876 OS step time 3.44\n",
      "step is 25 obj is 4.456061609170122 err is 0.16255495287303567 ; eta= 0.7840526816831157 OS step time 4.15\n",
      "step is 26 obj is 4.460682632329135 err is 0.1523688213488681 ; eta= 0.7778464020896673 OS step time 5.28\n",
      "step is 27 obj is 4.465823308977648 err is 0.1533265097991734 ; eta= 0.7717694219077355 OS step time 5.71\n",
      "step is 28 obj is 4.469463295897415 err is 0.14749794228789792 ; eta= 0.7658174199901605 OS step time 6.18\n",
      "step is 29 obj is 4.47412021524971 err is 0.12498875372327678 ; eta= 0.7599862726075867 OS step time 6.68\n",
      "step is 30 obj is 4.478664326068129 err is 0.13951913751565836 ; eta= 0.7542720420681454 OS step time 7.82\n",
      "step is 31 obj is 4.483233560434631 err is 0.12357360538431372 ; eta= 0.7486709661259003 OS step time 8.41\n",
      "step is 32 obj is 4.486759236691483 err is 0.1474611996828088 ; eta= 0.7431794481144116 OS step time 10.30\n",
      "step is 33 obj is 4.491335618098782 err is 0.13664676255895447 ; eta= 0.7377940477476166 OS step time 11.05\n",
      "step is 34 obj is 4.494440653267202 err is 0.12037295797207026 ; eta= 0.7325114725354702 OS step time 12.69\n",
      "step is 35 obj is 4.498358130254203 err is 0.11744993523627922 ; eta= 0.7273285697664938 OS step time 13.63\n",
      "step is 36 obj is 4.500596496496021 err is 0.10911928523334247 ; eta= 0.7222423190136238 OS step time 14.59\n",
      "step is 37 obj is 4.503716357830342 err is 0.11956179931365707 ; eta= 0.7172498251235694 OS step time 16.66\n",
      "step is 38 obj is 4.505054235465152 err is 0.10830432882901597 ; eta= 0.7123483116533305 OS step time 19.68\n",
      "step is 39 obj is 4.508905482541699 err is 0.10364758093863902 ; eta= 0.7075351147206413 OS step time 21.02\n",
      "step is 40 obj is 4.511798717350137 err is 0.11768174328235137 ; eta= 0.7028076772379166 OS step time 23.68\n",
      "step is 41 obj is 4.515578200162288 err is 0.11113435103233016 ; eta= 0.6981635435018217 OS step time 25.27\n",
      "step is 42 obj is 4.51746172731075 err is 0.09128848407188972 ; eta= 0.6936003541129014 OS step time 29.27\n",
      "step is 43 obj is 4.5194640982889425 err is 0.09147509585288027 ; eta= 0.6891158412017896 OS step time 32.70\n",
      "step is 44 obj is 4.5218301414510185 err is 0.09007864681776212 ; eta= 0.6847078239404295 OS step time 34.79\n",
      "step is 45 obj is 4.524878184632774 err is 0.09812048420183661 ; eta= 0.6803742043184604 OS step time 38.71\n",
      "step is 46 obj is 4.526538864573881 err is 0.0890998616889842 ; eta= 0.6761129631665018 OS step time 44.15\n",
      "step is 47 obj is 4.527396581523561 err is 0.07405303116511863 ; eta= 0.6719221564095016 OS step time 48.86\n",
      "step is 48 obj is 4.529679171914498 err is 0.07688422279309659 ; eta= 0.6677999115346216 OS step time 51.83\n",
      "step is 49 obj is 4.532583476797494 err is 0.07898009856565036 ; eta= 0.6637444242593279 OS step time 58.41\n",
      "step is 50 obj is 4.533223064976345 err is 0.0763658460767127 ; eta= 0.6597539553864471 OS step time 64.22\n",
      "step is 51 obj is 4.535032715399453 err is 0.08198733529618707 ; eta= 0.6558268278339454 OS step time 68.28\n",
      "step is 52 obj is 4.536982254963731 err is 0.07254292341801882 ; eta= 0.6519614238281016 OS step time 74.37\n",
      "step is 53 obj is 4.537595687476545 err is 0.07551542284534385 ; eta= 0.6481561822495862 OS step time 85.74\n",
      "step is 54 obj is 4.540141962254439 err is 0.07303593268549147 ; eta= 0.6444095961227203 OS step time 90.54\n",
      "step is 55 obj is 4.541729624455209 err is 0.077380013698094 ; eta= 0.6407202102389011 OS step time 103.48\n",
      "step is 56 obj is 4.542813179446978 err is 0.07311354461522335 ; eta= 0.6370866189058201 OS step time 109.15\n",
      "step is 57 obj is 4.54416610788098 err is 0.06388415911058232 ; eta= 0.6335074638147039 OS step time 118.35\n",
      "step is 58 obj is 4.545947060496422 err is 0.06856699395355559 ; eta= 0.6299814320183484 OS step time 130.38\n",
      "step is 59 obj is 4.547416983835385 err is 0.07454271713945104 ; eta= 0.6265072540132283 OS step time 140.94\n",
      "Time usage for OS is 1639.3215635850001\n"
     ]
    }
   ],
   "source": [
    "print(\"running online sinkhorn...\")\n",
    "params[\"compress\"] = False\n",
    "start = timeit.default_timer()\n",
    "(ft_os, gt_os, x_os, y_os, obj_os, err_os)  = algorithms.online_sinkhorn(params)\n",
    "run_time = timeit.default_timer()-start\n",
    "data_os={\"rt\":run_time,\"obj\":obj_os,\"err\":err_os}\n",
    "print(\"Time usage for OS is\", run_time)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "executionInfo": {
     "elapsed": 6,
     "status": "ok",
     "timestamp": 1694675750685,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "t4y--YKor6ga"
   },
   "outputs": [],
   "source": [
    "# plotting the objective values\n",
    "a = params['a']\n",
    "b = params['b']\n",
    "maxits = params['maxits']\n",
    "batch = [2*math.ceil(pow(i, 2*a)) for i in range(1, maxits+2)]\n",
    "N = np.cumsum(batch)[:len(obj_os)]\n",
    "ref_value=theoretical"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "executionInfo": {
     "elapsed": 943,
     "status": "ok",
     "timestamp": 1694675764148,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "EWaY4L1Br6ga"
   },
   "outputs": [],
   "source": [
    "save_data={\"N\":N,\"ref_value\":ref_value,\n",
    "           \"os\":data_os,\n",
    "           \"a\":a,\"b\":b,\"d\":d,\"theoretical\":theoretical\n",
    "           }\n",
    "#\n",
    "if True:\n",
    "  filehandler = open('OS_theoretical_cts_1d.pkl', 'wb')\n",
    "  pickle.dump(save_data, filehandler)\n",
    "  filehandler.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "executionInfo": {
     "elapsed": 420,
     "status": "ok",
     "timestamp": 1694675766927,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "A5iwINx0r6ga"
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as pl\n",
    "\n",
    "filehandler = open('OS_theoretical_cts_1d.pkl','rb')\n",
    "in_data= pickle.load(filehandler)\n",
    "\n",
    "N=in_data[\"N\"]\n",
    "ref_value=in_data[\"ref_value\"]\n",
    "obj_os=in_data[\"os\"][\"obj\"]\n",
    "err_os=in_data[\"os\"][\"err\"]\n",
    "run_time_os=in_data[\"os\"][\"rt\"]\n",
    "a=in_data[\"a\"]\n",
    "b=in_data[\"b\"]\n",
    "d=in_data[\"d\"]\n",
    "theoretical=in_data[\"theoretical\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 496
    },
    "executionInfo": {
     "elapsed": 1132,
     "status": "ok",
     "timestamp": 1694675772529,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "k2DHeq2N-CqH",
    "outputId": "14e01932-5e5e-4c52-bae7-3e0d9ab4c374"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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fvoJGRkZOHnyJFq3bg0A+OuvvzBw4EB07twZzzzzDHr27IlWrVoBAK5evYoff/wRGzduBAB0794dvXv3NlFWiKgmLASJyGJYW1vD29sbmZmZSE9Px4oVK7BixQqD7Tt06IANGzbo5tYDgF69emHu3LmYPXs2cnJyMGvWrGrbTZ8+HV27djW7QtDHxwefffYZnnvuOb1xK5VKLFy4EBEREfXqf86cOXBzc8M777yDgoICLF26FEuXLtXb1tbWFnZ2dtWWp6am6k7J69OpUyds2rSpTndAE9H9YyFIRBbDzs4O6enpSEhIwJ49e5CQkICzZ8/ixo0bKCkpgaOjI3x8fNCtWzc8/fTTiIiI0DsyFhUVhZ49e2Lp0qVISkpCYWEhmjdvjuDgYEyZMgXh4eGIiYlp/B2sgyeffBKHDx/GokWLsHfvXly/fh1ubm4ICwvD9OnT73taljfeeAOjRo3CN998g927dyMtLQ137tyBSqVCq1at8MADDyA8PBwRERFVJrcOCwtDfHw8du/ejdjYWPz111+64+Lh4YFu3bohIiICkZGRRo9WElH9KYS5TIBFRET1MmDAAOzfvx/9+/dHbGys1OEQURPCm0WIiIiIZIqFIBEREZFMsRAkIiIikikWgkREREQyxUKQiIiISKZ41zARERGRTHFEkIiIiEimWAgSERERyRQLQSIiIiKZYiFIREREJFMsBImIiIhkioUgERERkUyxECQiIiKSKRaCRERERDL1/3WWvbb5s3/8AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "dimension: 1 ; Convergence rate: theory=-0.35; old theory=-0.18; OS=  -0.31 \n"
     ]
    }
   ],
   "source": [
    "# plotting the error at every step\n",
    "pl.loglog(N[1:], err_os[1:], label='OS',linewidth=5)\n",
    "pl.loglog(N[1:],7*N[1:]**(-a/(2*a+1)),'k:',label='Theoretical',linewidth=4)\n",
    "pl.loglog(N[1:],2*N[1:]**(b/(2*a+1)),'k--',label='Old Theoretical',linewidth=4)\n",
    "pl.legend(loc=\"upper right\", borderaxespad=0.,fontsize=\"18\")\n",
    "pl.xlabel('Samples',fontsize=20)\n",
    "pl.ylabel('Error (variational)',fontsize=20)\n",
    "pl.xticks(fontsize=20)\n",
    "pl.yticks(fontsize=20)\n",
    "\n",
    "pl.show()\n",
    "i=20\n",
    "z_os = np.polyfit(np.log(N[i:]), np.log(err_os[i:]), 1)\n",
    "print('dimension:',d,'; Convergence rate: theory={:2.2}; old theory={:2.2}; OS=  {:2.2} '.format(-a/(2*a+1),b/(2*a+1),z_os[0]))"
   ]
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "provenance": []
  },
  "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.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
