{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "GRdoE3U-SybK"
   },
   "source": [
    "## Continuous example in 1d\n",
    "\n",
    "This notebook compares Sinkhorn, Online Sinkhorn, Compressed Online Sinkhorn (with Fourier and GQ compression) for two multivariate normal distributions in dimension one.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 3758,
     "status": "ok",
     "timestamp": 1694693596762,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "Zes9WhQ1rcDp",
    "outputId": "ad6288c4-43bb-4090-92fb-44e6661e02d4"
   },
   "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": [
       "['helper.py',\n",
       " 'COS.ipynb',\n",
       " '.git',\n",
       " '__pycache__',\n",
       " 'gq.py',\n",
       " 'recombination.py',\n",
       " 'recombination2.py',\n",
       " 'closed_forms.py',\n",
       " 'example_cts_20d.ipynb',\n",
       " 'algorithms.py',\n",
       " 'compression.py',\n",
       " 'example_gmm_20d.ipynb',\n",
       " 'myImagePDF.pgf',\n",
       " 'myImagePDF.pdf',\n",
       " 'OS_theoretical_cts_1d.pkl',\n",
       " 'New folder',\n",
       " 'example_gmm_2d.pkl',\n",
       " 'example_gmm_5d.pkl',\n",
       " 'OS_theortical_cts_1d.ipynb',\n",
       " 'OS_theoretical_cts_5d_.pkl',\n",
       " 'OS_theortical_cts_5d_ .ipynb',\n",
       " 'example_gmm_2d.ipynb',\n",
       " 'example_gmm_5d.ipynb',\n",
       " 'untitled0.py',\n",
       " 'repeat_better_data',\n",
       " 'example_gmm_2d_am.pkl',\n",
       " 'example_gmm_2d_am.ipynb',\n",
       " 'example_gmm_5d_am.pkl',\n",
       " 'example_gmm_5d_am.ipynb',\n",
       " 'OS_theoretical_cts_1d_test.pkl',\n",
       " 'OS_theortical_cts_1d_test.ipynb',\n",
       " 'OS_theoretical_cts_2d.pkl',\n",
       " 'example_cts_1d.pkl',\n",
       " 'example_cts_1d_easy.ipynb',\n",
       " 'OS_theoretical_cts_5d.pkl',\n",
       " 'OS_theortical_cts_5d.ipynb',\n",
       " 'OS_theortical_cts_2d.ipynb']"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from google.colab import drive\n",
    "drive.mount(\"/content/drive\")\n",
    "import os\n",
    "path=\"/content/drive/My Drive/Colab Notebooks/compressedOT\"\n",
    "os.chdir(path)\n",
    "os.listdir(path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 5157,
     "status": "ok",
     "timestamp": 1694693601916,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "XevkJMUlYF3z",
    "outputId": "45bb3a2e-3657-45d9-d4db-b94f1054452b"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: celer in /usr/local/lib/python3.10/dist-packages (0.7.3)\n",
      "Requirement 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",
      "Requirement already satisfied: libsvmdata>=0.3 in /usr/local/lib/python3.10/dist-packages (from celer) (0.4.1)\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",
      "Requirement already satisfied: download in /usr/local/lib/python3.10/dist-packages (from celer) (0.3.5)\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"
     ]
    }
   ],
   "source": [
    "!pip install -U celer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 7997,
     "status": "ok",
     "timestamp": 1694693609901,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "ybc4BzbN62xN",
    "outputId": "198ada7a-3519-42c5-bb03-b36b38a60b8f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Requirement already satisfied: pykeops in /usr/local/lib/python3.10/dist-packages (2.1.2)\n",
      "Requirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from pykeops) (1.23.5)\n",
      "Requirement already satisfied: pybind11 in /usr/local/lib/python3.10/dist-packages (from pykeops) (2.11.1)\n",
      "Requirement already satisfied: keopscore==2.1.2 in /usr/local/lib/python3.10/dist-packages (from pykeops) (2.1.2)\n"
     ]
    }
   ],
   "source": [
    "import locale\n",
    "locale.getpreferredencoding = lambda: \"UTF-8\"\n",
    "!pip install pykeops"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 13,
     "status": "ok",
     "timestamp": 1694693609902,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "tfRHebKAdox5",
    "outputId": "931ce155-7411-43d6-d97d-c03534c50f4d"
   },
   "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {
    "executionInfo": {
     "elapsed": 10,
     "status": "ok",
     "timestamp": 1694693609902,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "6f4hsauPrjGD"
   },
   "outputs": [],
   "source": [
    "import sys\n",
    "import math\n",
    "import timeit\n",
    "import random\n",
    "\n",
    "import numpy as np\n",
    "\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": 27,
   "metadata": {
    "executionInfo": {
     "elapsed": 331,
     "status": "ok",
     "timestamp": 1694693610224,
     "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",
    "##\n",
    "if d == 1:\n",
    "    mean1, cov1 = 1., 1.2\n",
    "    mean2, cov2 = 3., 1.7\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": 28,
   "metadata": {
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1694693610225,
     "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": 29,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 5,
     "status": "ok",
     "timestamp": 1694693610225,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "vL9MUt27399P",
    "outputId": "c1298e2e-ab40-41a7-f1f5-7c4a291b6afa"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Exact form\n",
      "A mean= [1.] covariance= [[1.2]]\n",
      "B mean= [3.] covariance= [[1.7]]\n",
      "epsilon is 0.4\n",
      "a= 1.5 ; b= -0.6\n"
     ]
    }
   ],
   "source": [
    "size_var=10\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.5, # n_t=t^{2a} for a>1+b (number of samples upto iteration t)\n",
    "          'epsilon': 0.4, # regularisation parametr\n",
    "          \"dim\": d,\n",
    "          'maxits': 35,\n",
    "          'no_initial_sinkhorn_its':5,\n",
    "          'compress':True,\n",
    "          'min_compress':1000,\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':1,# 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_var':samp1(size_var,d),\n",
    "          'test_samples2_var':samp2(size_var,d),\n",
    "          }\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",
    "if (params['zeta'] <= 3*(params['a']-params['b']) / (4*params['a'] + 1)):\n",
    "    print('Params violate zeta>3(a-b)/(4a+1) condition')\n",
    "    exit()\n",
    "print('epsilon is', params['epsilon'])\n",
    "print('a=', params['a'], '; b=', params['b'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 4,
     "status": "ok",
     "timestamp": 1694693610225,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "KW2va0Ju4Qll",
    "outputId": "8593c3a5-b43c-47e0-8020-108647d8df8f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Objective (theoretical)  4.643609736423016\n",
      "Objective (Gauss-Hermite quadrature) 4.643609736423016\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": 31,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 8083,
     "status": "ok",
     "timestamp": 1694693618306,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "3Nyyy4BQWHhc",
    "outputId": "02048321-1fc9-4869-fa76-5e294a70fe38"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running sinkhorn...\n",
      "objective is 1.522223627635356 ; error is 15.293193597445896\n",
      "objective is 2.20350687178 ; error is 5.232728285826066\n",
      "objective is 2.749434985590082 ; error is 4.819007343849108\n",
      "objective is 3.188231884493456 ; error is 4.476411380347216\n",
      "objective is 3.542089044617244 ; error is 4.156462923492784\n",
      "objective is 3.8282550782585894 ; error is 3.8506835369317676\n",
      "objective is 4.060184683311978 ; error is 3.559574893210852\n",
      "objective is 4.248492575386299 ; error is 3.2883290935906544\n",
      "objective is 4.401624054322797 ; error is 3.050062810698953\n",
      "objective is 4.526323751306052 ; error is 2.844701104467186\n",
      "objective is 4.627992838776006 ; error is 2.6557636753559146\n",
      "objective is 4.710970195890452 ; error is 2.469680991942811\n",
      "objective is 4.7787517860064135 ; error is 2.287791132787099\n",
      "objective is 4.834161627174583 ; error is 2.111702836398825\n",
      "objective is 4.879486026088988 ; error is 1.9426153558020638\n",
      "objective is 4.916579695346774 ; error is 1.7814975602929959\n",
      "objective is 4.946949994962416 ; error is 1.6291583116674637\n",
      "objective is 4.971823991001714 ; error is 1.486220618330231\n",
      "objective is 4.992201980445931 ; error is 1.3530717618387977\n",
      "objective is 5.008900351283398 ; error is 1.2298429879444366\n",
      "objective is 5.022586025529609 ; error is 1.116427422562614\n",
      "objective is 5.033804236303521 ; error is 1.0125217708176768\n",
      "objective is 5.043001000810058 ; error is 0.9176764988462223\n",
      "objective is 5.050541351183237 ; error is 0.8313448959027712\n",
      "objective is 5.0567241561393566 ; error is 0.7529259913205113\n",
      "objective is 5.061794191540434 ; error is 0.6817990881655485\n",
      "objective is 5.065951983590269 ; error is 0.6173494667006665\n",
      "objective is 5.069361844062556 ; error is 0.5589859839750009\n",
      "objective is 5.072158435099226 ; error is 0.5061519413755349\n",
      "objective is 5.07445213627446 ; error is 0.45833079802837684\n",
      "The value of the objective function for Sinkhorn is 5.07445213627446  elapsed time 7.9357497240002886\n",
      "Objective (theoretical)  4.643609736423016\n"
     ]
    }
   ],
   "source": [
    "print('running sinkhorn...')\n",
    "x = params[\"test_samples1\"]\n",
    "y = params[\"test_samples2\"]\n",
    "start = timeit.default_timer()\n",
    "(ft_s, gt_s, obj_s) = algorithms.sinkhorn(x,y, 30, params['epsilon'])\n",
    "run_time = timeit.default_timer()-start\n",
    "data_s={\"f\":ft_s,\n",
    "  \"g\":gt_s,\n",
    "  \"obj\":obj_s,\n",
    "  \"rt\":run_time}\n",
    "print(\"The value of the objective function for Sinkhorn is\", obj_s[-1],\" elapsed time\",run_time)\n",
    "print(\"Objective (theoretical) \",exact[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 146164,
     "status": "ok",
     "timestamp": 1694693764464,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "mqMUVJaSrjVl",
    "outputId": "4d61b79c-931c-4865-ba8c-a26cccbce0c2"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running compressed online sinkhorn with Fourier..\n",
      "Online Sinkhorn with Compression= True\n",
      "Compression method:  Fourier\n",
      "Fourier solver= nnls\n",
      "Running 5 Sinkhorn iterations to start-up.\n",
      "step is 0 obj is 3.65618356065377 err is 1.6848432702538434 ; eta= 1.0 OS step time 0.06\n",
      "Compressing with Fourier from  1008  to  13  points.\n",
      "Compress from  1008  to  13  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.08306144093205425\n",
      "Compressed to  9  points\n",
      "Compress from  1008  to  13  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.007712059519987254\n",
      "Compressed to  9  points\n",
      "Compression time 0.03\n",
      "OS step time 0.05 (as fraction of last compression 1.60)\n",
      "step is 1 obj is 3.80051266075267 err is 1.4522742684916414 ; eta= 0.9881887308219607\n",
      "Compressing with Fourier from  1597  to  19  points.\n",
      "Compress from  3175  to  19  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.007505191334584316\n",
      "Compressed to  12  points\n",
      "Compress from  1597  to  19  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.001351274023948699\n",
      "Compressed to  11  points\n",
      "Compression time 0.06\n",
      "OS step time 0.04 (as fraction of last compression 0.70)\n",
      "step is 2 obj is 3.944229448227727 err is 1.2746346693593926 ; eta= 0.976742300461482\n",
      "Compressing with Fourier from  1529  to  27  points.\n",
      "Compress from  3010  to  27  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.02283484268272054\n",
      "Compressed to  15  points\n",
      "Compress from  1529  to  27  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.005387128515195893\n",
      "Compressed to  12  points\n",
      "Compression time 0.04\n",
      "OS step time 0.05 (as fraction of last compression 1.18)\n",
      "step is 3 obj is 4.059029998030998 err is 1.2916344874675767 ; eta= 0.9656427425776481\n",
      "Compressing with Fourier from  1769  to  37  points.\n",
      "Compress from  3275  to  37  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.003568116655851068\n",
      "Compressed to  18  points\n",
      "Compress from  1769  to  37  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0030031756556481524\n",
      "Compressed to  13  points\n",
      "Compression time 0.10\n",
      "OS step time 0.05 (as fraction of last compression 0.46)\n",
      "step is 4 obj is 4.156411765340281 err is 1.0389645519051716 ; eta= 0.9548732931041548\n",
      "Compressing with Fourier from  1708  to  50  points.\n",
      "Compress from  3316  to  50  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.002165351472723533\n",
      "Compressed to  20  points\n",
      "Compress from  1708  to  50  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.004790345631338204\n",
      "Compressed to  13  points\n",
      "Compression time 0.10\n",
      "OS step time 0.06 (as fraction of last compression 0.60)\n",
      "step is 5 obj is 4.234991359632071 err is 0.9911659572105732 ; eta= 0.9444182893218951\n",
      "Compressing with Fourier from  2012  to  64  points.\n",
      "Compress from  3986  to  64  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00699024436079476\n",
      "Compressed to  18  points\n",
      "Compress from  2012  to  64  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0008831403407808467\n",
      "Compressed to  16  points\n",
      "Compression time 0.11\n",
      "OS step time 0.06 (as fraction of last compression 0.58)\n",
      "step is 6 obj is 4.291032277339561 err is 0.7575104980409948 ; eta= 0.9342630790612149\n",
      "Compressing with Fourier from  2215  to  80  points.\n",
      "Compress from  4311  to  80  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.001962664960261177\n",
      "Compressed to  21  points\n",
      "Compress from  2215  to  80  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0009414513852742689\n",
      "Compressed to  16  points\n",
      "Compression time 0.16\n",
      "OS step time 0.06 (as fraction of last compression 0.35)\n",
      "step is 7 obj is 4.335100490669109 err is 0.7389952127851667 ; eta= 0.924393938856702\n",
      "Compressing with Fourier from  2456  to  97  points.\n",
      "Compress from  4983  to  97  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0008712296351844056\n",
      "Compressed to  21  points\n",
      "Compress from  2456  to  97  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.000614274803438743\n",
      "Compressed to  16  points\n",
      "Compression time 0.17\n",
      "OS step time 0.06 (as fraction of last compression 0.37)\n",
      "step is 8 obj is 4.373309215450329 err is 0.5700636933967183 ; eta= 0.9147980000321643\n",
      "Compressing with Fourier from  2776  to  116  points.\n",
      "Compress from  5773  to  116  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0022223110056277585\n",
      "Compressed to  24  points\n",
      "Compress from  2776  to  116  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00024367958291704326\n",
      "Compressed to  18  points\n",
      "Compression time 0.15\n",
      "OS step time 0.06 (as fraction of last compression 0.37)\n",
      "step is 9 obj is 4.41071597505029 err is 0.5836858682712325 ; eta= 0.905463181825604\n",
      "Compressing with Fourier from  3266  to  137  points.\n",
      "Compress from  6700  to  137  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0014360492941759896\n",
      "Compressed to  24  points\n",
      "Compress from  3266  to  137  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0005226958304622503\n",
      "Compressed to  16  points\n",
      "Compression time 0.19\n",
      "OS step time 0.08 (as fraction of last compression 0.43)\n",
      "step is 10 obj is 4.437398755803912 err is 0.5096686511362944 ; eta= 0.8963781307771418\n",
      "Compressing with Fourier from  3906  to  159  points.\n",
      "Compress from  7964  to  159  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0016430241544462168\n",
      "Compressed to  25  points\n",
      "Compress from  3906  to  159  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0008017562881771466\n",
      "Compressed to  17  points\n",
      "Compression time 0.31\n",
      "OS step time 0.08 (as fraction of last compression 0.24)\n",
      "step is 11 obj is 4.463310639687468 err is 0.5214878603178188 ; eta= 0.8875321656999794\n",
      "Compressing with Fourier from  4643  to  183  points.\n",
      "Compress from  9399  to  183  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0032841283520045855\n",
      "Compressed to  25  points\n",
      "Compress from  4643  to  183  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.001948866417560472\n",
      "Compressed to  18  points\n",
      "Compression time 0.39\n",
      "OS step time 0.08 (as fraction of last compression 0.19)\n",
      "step is 12 obj is 4.482468571967184 err is 0.4328113316092108 ; eta= 0.8789152276381142\n",
      "Compressing with Fourier from  5423  to  208  points.\n",
      "Compress from  10705  to  208  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.001094665475720925\n",
      "Compressed to  25  points\n",
      "Compress from  5423  to  208  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 4.522512531738327e-05\n",
      "Compressed to  21  points\n",
      "Compression time 0.51\n",
      "OS step time 0.09 (as fraction of last compression 0.17)\n",
      "step is 13 obj is 4.501966038650311 err is 0.36783355850119803 ; eta= 0.870517834286684\n",
      "Compressing with Fourier from  6246  to  235  points.\n",
      "Compress from  12449  to  235  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00156714516638381\n",
      "Compressed to  28  points\n",
      "Compress from  6246  to  235  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0004880051593950596\n",
      "Compressed to  21  points\n",
      "Compression time 1.01\n",
      "OS step time 0.11 (as fraction of last compression 0.11)\n",
      "step is 14 obj is 4.514689899149841 err is 0.37286888182027056 ; eta= 0.8623310384132593\n",
      "Compressing with Fourier from  7646  to  263  points.\n",
      "Compress from  14995  to  263  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0004257940561484782\n",
      "Compressed to  31  points\n",
      "Compress from  7646  to  263  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00022191512640793115\n",
      "Compressed to  23  points\n",
      "Compression time 1.23\n",
      "OS step time 0.15 (as fraction of last compression 0.12)\n",
      "step is 15 obj is 4.529643544357958 err is 0.35550136020492284 ; eta= 0.8543463898725555\n",
      "Compressing with Fourier from  8449  to  293  points.\n",
      "Compress from  17319  to  293  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 4.172929163223855e-06\n",
      "Compressed to  31  points\n",
      "Compress from  8449  to  293  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00026339889432931343\n",
      "Compressed to  23  points\n",
      "Compression time 1.31\n",
      "OS step time 0.17 (as fraction of last compression 0.13)\n",
      "step is 16 obj is 4.542797631156848 err is 0.3255583486790714 ; eta= 0.8465559008541063\n",
      "Compressing with Fourier from  9845  to  325  points.\n",
      "Compress from  19757  to  325  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 5.059405216482994e-05\n",
      "Compressed to  32  points\n",
      "Compress from  9845  to  325  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00015541048324051434\n",
      "Compressed to  23  points\n",
      "Compression time 1.37\n",
      "OS step time 0.20 (as fraction of last compression 0.14)\n",
      "step is 17 obj is 4.551515830875885 err is 0.30669924997901243 ; eta= 0.8389520140434555\n",
      "Compressing with Fourier from  11550  to  358  points.\n",
      "Compress from  22954  to  358  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00011716780152808372\n",
      "Compressed to  29  points\n",
      "Compress from  11550  to  358  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0002794857228633822\n",
      "Compressed to  22  points\n",
      "Compression time 1.83\n",
      "OS step time 0.24 (as fraction of last compression 0.13)\n",
      "step is 18 obj is 4.558884215213243 err is 0.23939639227799137 ; eta= 0.8315275734132361\n",
      "Compressing with Fourier from  13052  to  392  points.\n",
      "Compress from  25671  to  392  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0006140412797451514\n",
      "Compressed to  31  points\n",
      "Compress from  13052  to  392  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.000201199728688444\n",
      "Compressed to  24  points\n",
      "Compression time 2.67\n",
      "OS step time 0.43 (as fraction of last compression 0.16)\n",
      "step is 19 obj is 4.566145691749109 err is 0.2463500310618123 ; eta= 0.8242757973918322\n",
      "Compressing with Fourier from  14747  to  428  points.\n",
      "Compress from  29525  to  428  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.0002878160869251466\n",
      "Compressed to  32  points\n",
      "Compress from  14747  to  428  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00017816651772049573\n",
      "Compressed to  21  points\n",
      "Compression time 3.95\n",
      "OS step time 0.54 (as fraction of last compression 0.14)\n",
      "step is 20 obj is 4.574149608910709 err is 0.25331525420569756 ; eta= 0.8171902541848022\n",
      "Compressing with Fourier from  16710  to  466  points.\n",
      "Compress from  33688  to  466  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00014837235021995484\n",
      "Compressed to  32  points\n",
      "Compress from  16710  to  466  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 8.063495610632906e-05\n",
      "Compressed to  24  points\n",
      "Compression time 3.47\n",
      "OS step time 0.56 (as fraction of last compression 0.16)\n",
      "step is 21 obj is 4.578279222747778 err is 0.20544460482925264 ; eta= 0.8102648390483675\n",
      "Compressing with Fourier from  19211  to  505  points.\n",
      "Compress from  37973  to  505  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00034566615462890967\n",
      "Compressed to  31  points\n",
      "Compress from  19211  to  505  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 0.00012924188349780312\n",
      "Compressed to  25  points\n",
      "Compression time 2.24\n",
      "OS step time 0.44 (as fraction of last compression 0.20)\n",
      "step is 22 obj is 4.58383574371996 err is 0.20160768395043172 ; eta= 0.8034937533355226\n",
      "Compressing with Fourier from  21434  to  546  points.\n",
      "Compress from  42581  to  546  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 9.293046065811711e-05\n",
      "Compressed to  33  points\n",
      "Compress from  21434  to  546  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 5.354669431541438e-06\n",
      "Compressed to  27  points\n",
      "Compression time 2.76\n",
      "OS step time 0.78 (as fraction of last compression 0.28)\n",
      "step is 23 obj is 4.587098570502531 err is 0.17079051923362942 ; eta= 0.7968714851540509\n",
      "Compressing with Fourier from  24415  to  588  points.\n",
      "Compress from  47605  to  588  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 7.372251240480278e-05\n",
      "Compressed to  32  points\n",
      "Compress from  24415  to  588  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 3.4292669543502665e-06\n",
      "Compressed to  28  points\n",
      "Compression time 4.14\n",
      "OS step time 0.88 (as fraction of last compression 0.21)\n",
      "step is 24 obj is 4.58954889723193 err is 0.15069481046107858 ; eta= 0.7903927914922876\n",
      "Compressing with Fourier from  26843  to  632  points.\n",
      "Compress from  53962  to  632  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 6.194200007291589e-05\n",
      "Compressed to  31  points\n",
      "Compress from  26843  to  632  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 3.1877415607307256e-05\n",
      "Compressed to  26  points\n",
      "Compression time 4.00\n",
      "OS step time 0.93 (as fraction of last compression 0.23)\n",
      "step is 25 obj is 4.593159417096504 err is 0.13286850695522467 ; eta= 0.7840526816831157\n",
      "Compressing with Fourier from  29514  to  677  points.\n",
      "Compress from  59177  to  677  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 8.360634235705293e-05\n",
      "Compressed to  32  points\n",
      "Compress from  29514  to  677  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 9.499307752117364e-06\n",
      "Compressed to  28  points\n",
      "Compression time 4.63\n",
      "OS step time 1.18 (as fraction of last compression 0.25)\n",
      "step is 26 obj is 4.595519647891466 err is 0.13660995859013525 ; eta= 0.7778464020896673\n",
      "Compressing with Fourier from  33332  to  724  points.\n",
      "Compress from  66164  to  724  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 7.463544657533934e-05\n",
      "Compressed to  32  points\n",
      "Compress from  33332  to  724  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 5.991193967024253e-07\n",
      "Compressed to  27  points\n",
      "Compression time 7.12\n",
      "OS step time 1.31 (as fraction of last compression 0.18)\n",
      "step is 27 obj is 4.596784698408382 err is 0.12343695020364742 ; eta= 0.7717694219077355\n",
      "Compressing with Fourier from  37028  to  772  points.\n",
      "Compress from  73810  to  772  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 3.0357045774953422e-05\n",
      "Compressed to  34  points\n",
      "Compress from  37028  to  772  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 1.3098952247430965e-05\n",
      "Compressed to  27  points\n",
      "Compression time 6.96\n",
      "OS step time 1.59 (as fraction of last compression 0.23)\n",
      "step is 28 obj is 4.598014175184273 err is 0.11111081980018134 ; eta= 0.7658174199901605\n",
      "Compressing with Fourier from  40195  to  822  points.\n",
      "Compress from  81136  to  822  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 3.782384818997032e-05\n",
      "Compressed to  35  points\n",
      "Compress from  40195  to  822  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 6.759886815912151e-06\n",
      "Compressed to  26  points\n",
      "Compression time 7.75\n",
      "OS step time 1.73 (as fraction of last compression 0.22)\n",
      "step is 29 obj is 4.5997580315188635 err is 0.09964390264082446 ; eta= 0.7599862726075867\n",
      "Compressing with Fourier from  43680  to  874  points.\n",
      "Compress from  89296  to  874  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 5.55025225594802e-05\n",
      "Compressed to  32  points\n",
      "Compress from  43680  to  874  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 2.196638677871897e-05\n",
      "Compressed to  26  points\n",
      "Compression time 10.52\n",
      "OS step time 2.09 (as fraction of last compression 0.20)\n",
      "step is 30 obj is 4.601392450198559 err is 0.10529156565624986 ; eta= 0.7542720420681454\n",
      "Compressing with Fourier from  48649  to  927  points.\n",
      "Compress from  96646  to  927  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 5.7970468770892426e-05\n",
      "Compressed to  35  points\n",
      "Compress from  48649  to  927  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 1.9759721887575397e-05\n",
      "Compressed to  27  points\n",
      "Compression time 13.08\n",
      "OS step time 2.28 (as fraction of last compression 0.17)\n",
      "step is 31 obj is 4.60298089801588 err is 0.08974536033525204 ; eta= 0.7486709661259003\n",
      "Compressing with Fourier from  53253  to  981  points.\n",
      "Compress from  106742  to  981  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 6.0128379072089315e-05\n",
      "Compressed to  36  points\n",
      "Compress from  53253  to  981  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 2.92443632148886e-05\n",
      "Compressed to  25  points\n",
      "Compression time 14.12\n",
      "OS step time 2.77 (as fraction of last compression 0.20)\n",
      "step is 32 obj is 4.603885029456058 err is 0.09791904401513651 ; eta= 0.7431794481144116\n",
      "Compressing with Fourier from  58029  to  1037  points.\n",
      "Compress from  116440  to  1037  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 3.8373056656705355e-05\n",
      "Compressed to  36  points\n",
      "Compress from  58029  to  1037  points ( nnls )\n",
      "Reduced compression method\n",
      "Relative residual= 8.448033095805921e-06\n",
      "Compressed to  28  points\n",
      "Compression time 14.23\n",
      "OS step time 3.26 (as fraction of last compression 0.23)\n",
      "step is 33 obj is 4.605315890450549 err is 0.07253895614662231 ; eta= 0.7377940477476166\n",
      "OS step time 9.95 (as fraction of last compression 0.70)\n",
      "step is 34 obj is 4.60558515367607 err is 0.0763309000654635 ; eta= 0.7325114725354702\n",
      "Time usage for OS with Fourier is 145.97948344299994\n",
      "Objective (theoretical)  4.643609736423016\n"
     ]
    }
   ],
   "source": [
    "print(\"running compressed online sinkhorn with Fourier..\")\n",
    "params[\"compress\"] = True\n",
    "params[\"method\"] =\"Fourier\"\n",
    "params[\"fourier_solver\"] =\"nnls\"\n",
    "start = timeit.default_timer()\n",
    "(ft_f, gt_f, x_f, y_f, obj_f, err_f) = algorithms.online_sinkhorn(params)\n",
    "run_time = timeit.default_timer()-start\n",
    "data_cos_f={\"err\":err_f,\n",
    "  \"obj\":obj_f,\n",
    "  \"rt\":run_time,\"solver\":params[\"fourier_solver\"]}\n",
    "print(\"Time usage for OS with Fourier is\", run_time)\n",
    "print(\"Objective (theoretical) \",exact[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 553721,
     "status": "ok",
     "timestamp": 1694694318156,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "pvDHL3-HyyRa",
    "outputId": "15789902-3731-4997-a548-08efaa6d56f9"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running compressed online sinkhorn with Fourier..\n",
      "Online Sinkhorn with Compression= True\n",
      "Compression method:  Fourier\n",
      "Fourier solver= tl\n",
      "Running 5 Sinkhorn iterations to start-up.\n",
      "step is 0 obj is 3.5694365789418927 err is 1.6128650675077032 ; eta= 1.0 OS step time 0.01\n",
      "Compressing with Fourier from  1008  to  13  points.\n",
      "Compress from  1008  to  13  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  13  points\n",
      "Compress from  1008  to  13  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  13  points\n",
      "Compression time 0.03\n",
      "OS step time 0.02 (as fraction of last compression 0.77)\n",
      "step is 1 obj is 3.8235064993326886 err is 2.259438855248642 ; eta= 0.9881887308219607\n",
      "Compressing with Fourier from  1463  to  19  points.\n",
      "Compress from  3100  to  19  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  19  points\n",
      "Compress from  1463  to  19  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  19  points\n",
      "Compression time 0.04\n",
      "OS step time 0.02 (as fraction of last compression 0.55)\n",
      "step is 2 obj is 3.926365290458976 err is 1.987600474516772 ; eta= 0.976742300461482\n",
      "Compressing with Fourier from  1510  to  27  points.\n",
      "Compress from  3149  to  27  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  27  points\n",
      "Compress from  1510  to  27  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  27  points\n",
      "Compression time 0.08\n",
      "OS step time 0.03 (as fraction of last compression 0.33)\n",
      "step is 3 obj is 4.0013575744421495 err is 2.6733491017119375 ; eta= 0.9656427425776481\n",
      "Compressing with Fourier from  1672  to  37  points.\n",
      "Compress from  3309  to  37  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  37  points\n",
      "Compress from  1672  to  37  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  37  points\n",
      "Compression time 0.09\n",
      "OS step time 0.04 (as fraction of last compression 0.41)\n",
      "step is 4 obj is 4.116528770513794 err is 0.8357821929684022 ; eta= 0.9548732931041548\n",
      "Compressing with Fourier from  1676  to  50  points.\n",
      "Compress from  3516  to  50  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  51  points\n",
      "Compress from  1676  to  50  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  51  points\n",
      "Compression time 0.13\n",
      "OS step time 0.03 (as fraction of last compression 0.23)\n",
      "step is 5 obj is 4.142309695916215 err is 0.516435823624618 ; eta= 0.9444182893218951\n",
      "Compressing with Fourier from  2044  to  64  points.\n",
      "Compress from  3889  to  64  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  65  points\n",
      "Compress from  2044  to  64  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  65  points\n",
      "Compression time 0.22\n",
      "OS step time 0.04 (as fraction of last compression 0.18)\n",
      "step is 6 obj is 4.226350493893829 err is 0.833770943150702 ; eta= 0.9342630790612149\n",
      "Compressing with Fourier from  2331  to  80  points.\n",
      "Compress from  4638  to  80  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  81  points\n",
      "Compress from  2331  to  80  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  81  points\n",
      "Compression time 0.31\n",
      "OS step time 0.05 (as fraction of last compression 0.16)\n",
      "step is 7 obj is 4.269830383928499 err is 0.4801431625943432 ; eta= 0.924393938856702\n",
      "Compressing with Fourier from  2556  to  97  points.\n",
      "Compress from  4984  to  97  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  97  points\n",
      "Compress from  2556  to  97  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  97  points\n",
      "Compression time 0.43\n",
      "OS step time 0.06 (as fraction of last compression 0.13)\n",
      "step is 8 obj is 4.330603468484853 err is 0.8080678101560055 ; eta= 0.9147980000321643\n",
      "Compressing with Fourier from  3030  to  116  points.\n",
      "Compress from  5855  to  116  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  117  points\n",
      "Compress from  3030  to  116  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  117  points\n",
      "Compression time 0.58\n",
      "OS step time 0.09 (as fraction of last compression 0.15)\n",
      "step is 9 obj is 4.393397867573107 err is 0.8487589718139821 ; eta= 0.905463181825604\n",
      "Compressing with Fourier from  3439  to  137  points.\n",
      "Compress from  6690  to  137  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  137  points\n",
      "Compress from  3439  to  137  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  137  points\n",
      "Compression time 0.71\n",
      "OS step time 0.06 (as fraction of last compression 0.09)\n",
      "step is 10 obj is 4.421634389474761 err is 0.3741359096338001 ; eta= 0.8963781307771418\n",
      "Compressing with Fourier from  4206  to  159  points.\n",
      "Compress from  8207  to  159  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  159  points\n",
      "Compress from  4206  to  159  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  159  points\n",
      "Compression time 1.06\n",
      "OS step time 0.07 (as fraction of last compression 0.06)\n",
      "step is 11 obj is 4.459419560336165 err is 0.7976730442109157 ; eta= 0.8875321656999794\n",
      "Compressing with Fourier from  4703  to  183  points.\n",
      "Compress from  9670  to  183  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  183  points\n",
      "Compress from  4703  to  183  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  183  points\n",
      "Compression time 1.22\n",
      "OS step time 0.07 (as fraction of last compression 0.06)\n",
      "step is 12 obj is 4.490827869028564 err is 0.6153994843130837 ; eta= 0.8789152276381142\n",
      "Compressing with Fourier from  5639  to  208  points.\n",
      "Compress from  11045  to  208  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  209  points\n",
      "Compress from  5639  to  208  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  209  points\n",
      "Compression time 1.05\n",
      "OS step time 0.08 (as fraction of last compression 0.07)\n",
      "step is 13 obj is 4.509446923194529 err is 0.41351628867231377 ; eta= 0.870517834286684\n",
      "Compressing with Fourier from  6562  to  235  points.\n",
      "Compress from  12886  to  235  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  235  points\n",
      "Compress from  6562  to  235  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  235  points\n",
      "Compression time 1.40\n",
      "OS step time 0.09 (as fraction of last compression 0.06)\n",
      "step is 14 obj is 4.515067202462552 err is 0.3050139280640255 ; eta= 0.8623310384132593\n",
      "Compressing with Fourier from  7684  to  263  points.\n",
      "Compress from  14459  to  263  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  263  points\n",
      "Compress from  7684  to  263  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  263  points\n",
      "Compression time 1.86\n",
      "OS step time 0.15 (as fraction of last compression 0.08)\n",
      "step is 15 obj is 4.522553136698645 err is 0.15167051630564665 ; eta= 0.8543463898725555\n",
      "Compressing with Fourier from  8628  to  293  points.\n",
      "Compress from  17795  to  293  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  293  points\n",
      "Compress from  8628  to  293  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  293  points\n",
      "Compression time 2.49\n",
      "OS step time 0.33 (as fraction of last compression 0.13)\n",
      "step is 16 obj is 4.53933490185014 err is 0.3212752167583999 ; eta= 0.8465559008541063\n",
      "Compressing with Fourier from  10081  to  325  points.\n",
      "Compress from  20046  to  325  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  325  points\n",
      "Compress from  10081  to  325  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  325  points\n",
      "Compression time 3.50\n",
      "OS step time 0.33 (as fraction of last compression 0.10)\n",
      "step is 17 obj is 4.5498017494592204 err is 0.29883673740963984 ; eta= 0.8389520140434555\n",
      "Compressing with Fourier from  11534  to  358  points.\n",
      "Compress from  22957  to  358  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  359  points\n",
      "Compress from  11534  to  358  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  359  points\n",
      "Compression time 4.79\n",
      "OS step time 0.37 (as fraction of last compression 0.08)\n",
      "step is 18 obj is 4.562456404074426 err is 0.3058090851183205 ; eta= 0.8315275734132361\n",
      "Compressing with Fourier from  13411  to  392  points.\n",
      "Compress from  26148  to  392  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  393  points\n",
      "Compress from  13411  to  392  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  393  points\n",
      "Compression time 5.45\n",
      "OS step time 0.40 (as fraction of last compression 0.07)\n",
      "step is 19 obj is 4.573663920470181 err is 0.33625183500351474 ; eta= 0.8242757973918322\n",
      "Compressing with Fourier from  15172  to  428  points.\n",
      "Compress from  30036  to  428  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  429  points\n",
      "Compress from  15172  to  428  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  429  points\n",
      "Compression time 8.22\n",
      "OS step time 0.53 (as fraction of last compression 0.06)\n",
      "step is 20 obj is 4.568027012964507 err is 0.08675925503952375 ; eta= 0.8171902541848022\n",
      "Compressing with Fourier from  17111  to  466  points.\n",
      "Compress from  33993  to  466  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  467  points\n",
      "Compress from  17111  to  466  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  467  points\n",
      "Compression time 8.88\n",
      "OS step time 0.61 (as fraction of last compression 0.07)\n",
      "step is 21 obj is 4.57104758887148 err is 0.043103279567589414 ; eta= 0.8102648390483675\n",
      "Compressing with Fourier from  19256  to  505  points.\n",
      "Compress from  38134  to  505  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  505  points\n",
      "Compress from  19256  to  505  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  505  points\n",
      "Compression time 11.23\n",
      "OS step time 0.60 (as fraction of last compression 0.05)\n",
      "step is 22 obj is 4.576315683217059 err is 0.152088065123819 ; eta= 0.8034937533355226\n",
      "Compressing with Fourier from  22166  to  546  points.\n",
      "Compress from  43060  to  546  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  547  points\n",
      "Compress from  22166  to  546  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  547  points\n",
      "Compression time 14.49\n",
      "OS step time 0.83 (as fraction of last compression 0.06)\n",
      "step is 23 obj is 4.573205603227364 err is 0.18172114920831775 ; eta= 0.7968714851540509\n",
      "Compressing with Fourier from  24655  to  588  points.\n",
      "Compress from  49064  to  588  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  589  points\n",
      "Compress from  24655  to  588  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  589  points\n",
      "Compression time 17.99\n",
      "OS step time 0.88 (as fraction of last compression 0.05)\n",
      "step is 24 obj is 4.578294391478452 err is 0.23093523876514044 ; eta= 0.7903927914922876\n",
      "Compressing with Fourier from  27423  to  632  points.\n",
      "Compress from  54622  to  632  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  633  points\n",
      "Compress from  27423  to  632  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  633  points\n",
      "Compression time 20.44\n",
      "OS step time 0.96 (as fraction of last compression 0.05)\n",
      "step is 25 obj is 4.581140313451374 err is 0.19585336580220697 ; eta= 0.7840526816831157\n",
      "Compressing with Fourier from  30641  to  677  points.\n",
      "Compress from  60697  to  677  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  677  points\n",
      "Compress from  30641  to  677  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  677  points\n",
      "Compression time 25.24\n",
      "OS step time 1.22 (as fraction of last compression 0.05)\n",
      "step is 26 obj is 4.584429244626703 err is 0.08421854185072536 ; eta= 0.7778464020896673\n",
      "Compressing with Fourier from  33809  to  724  points.\n",
      "Compress from  67318  to  724  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  725  points\n",
      "Compress from  33809  to  724  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  725  points\n",
      "Compression time 31.73\n",
      "OS step time 1.29 (as fraction of last compression 0.04)\n",
      "step is 27 obj is 4.58795034881134 err is 0.08107231345679061 ; eta= 0.7717694219077355\n",
      "Compressing with Fourier from  37247  to  772  points.\n",
      "Compress from  73340  to  772  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  773  points\n",
      "Compress from  37247  to  772  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  773  points\n",
      "Compression time 36.38\n",
      "OS step time 1.62 (as fraction of last compression 0.04)\n",
      "step is 28 obj is 4.591928771417714 err is 0.06121519654585911 ; eta= 0.7658174199901605\n",
      "Compressing with Fourier from  40974  to  822  points.\n",
      "Compress from  81820  to  822  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  823  points\n",
      "Compress from  40974  to  822  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  823  points\n",
      "Compression time 42.98\n",
      "OS step time 1.76 (as fraction of last compression 0.04)\n",
      "step is 29 obj is 4.591733428812167 err is 0.1294598147751489 ; eta= 0.7599862726075867\n",
      "Compressing with Fourier from  45120  to  874  points.\n",
      "Compress from  89733  to  874  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  875  points\n",
      "Compress from  45120  to  874  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  875  points\n",
      "Compression time 52.59\n",
      "OS step time 2.11 (as fraction of last compression 0.04)\n",
      "step is 30 obj is 4.594412681128847 err is 0.08640529728360485 ; eta= 0.7542720420681454\n",
      "Compressing with Fourier from  48772  to  927  points.\n",
      "Compress from  98465  to  927  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  927  points\n",
      "Compress from  48772  to  927  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  927  points\n",
      "Compression time 61.48\n",
      "OS step time 2.34 (as fraction of last compression 0.04)\n",
      "step is 31 obj is 4.597855593235822 err is 0.04522541364739352 ; eta= 0.7486709661259003\n",
      "Compressing with Fourier from  53997  to  981  points.\n",
      "Compress from  107795  to  981  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  981  points\n",
      "Compress from  53997  to  981  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  981  points\n",
      "Compression time 73.18\n",
      "OS step time 2.81 (as fraction of last compression 0.04)\n",
      "step is 32 obj is 4.594194578420671 err is 0.09608965842204431 ; eta= 0.7431794481144116\n",
      "Compressing with Fourier from  59172  to  1037  points.\n",
      "Compress from  118177  to  1037  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  1037  points\n",
      "Compress from  59172  to  1037  points ( tl )\n",
      "Full compression method\n",
      "Compressed to  1037  points\n",
      "Compression time 88.22\n",
      "OS step time 3.31 (as fraction of last compression 0.04)\n",
      "step is 33 obj is 4.597526041195632 err is 0.0784071139565839 ; eta= 0.7377940477476166\n",
      "OS step time 9.29 (as fraction of last compression 0.11)\n",
      "step is 34 obj is 4.593970216894755 err is 0.12371531422160759 ; eta= 0.7325114725354702\n",
      "Time usage for OS with Fourier is 553.6367389960005\n",
      "Objective (theoretical)  4.643609736423016\n"
     ]
    }
   ],
   "source": [
    "if (True): # leave as False unless you want to compare run times of fourier_solver\n",
    "  print(\"running compressed online sinkhorn with Fourier..\")\n",
    "  params[\"compress\"] = True\n",
    "  params[\"method\"] =\"Fourier\"\n",
    "  params[\"fourier_solver\"] =\"tl\"\n",
    "\n",
    "  start = timeit.default_timer()\n",
    "  (ft_f2, gt_f2, x_f2, y_f2, obj_f2, err_f2) = algorithms.online_sinkhorn(params)\n",
    "  run_time = timeit.default_timer()-start\n",
    "  data_cos_f2={\"obj\":obj_f2,\"err\":err_f2,\"rt\":run_time,\"solver\":params[\"fourier_solver\"]}\n",
    "  print(\"Time usage for OS with Fourier is\", run_time)\n",
    "  print(\"Objective (theoretical) \",exact[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 149397,
     "status": "ok",
     "timestamp": 1694694467537,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "PqfkGCc54hHa",
    "outputId": "2b9b92aa-21c1-45e3-9b26-eff0d4d01277"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running compressed online sinkhorn with GQ...\n",
      "Online Sinkhorn with Compression= True\n",
      "Compression method:  GQ\n",
      "Running 5 Sinkhorn iterations to start-up.\n",
      "step is 0 obj is 3.5781834173755254 err is 1.6982596159534533 ; eta= 1.0 OS step time 0.02\n",
      "Compressing with GQ...\n",
      "Compressing from  1008 to  11\n",
      "compress to  11 points with GQ\n",
      "compress to  11 points with GQ\n",
      "Compression time 0.08\n",
      "OS step time 0.02 (as fraction of last compression 0.28)\n",
      "step is 1 obj is 3.7583858514763384 err is 1.596534449230429 ; eta= 0.9881887308219607\n",
      "Compressing with GQ...\n",
      "Compressing from  1510 to  12\n",
      "compress to  12 points with GQ\n",
      "compress to  12 points with GQ\n",
      "Compression time 0.19\n",
      "OS step time 0.02 (as fraction of last compression 0.12)\n",
      "step is 2 obj is 3.9049537856625305 err is 1.2859353850494726 ; eta= 0.976742300461482\n",
      "Compressing with GQ...\n",
      "Compressing from  1511 to  13\n",
      "compress to  13 points with GQ\n",
      "compress to  13 points with GQ\n",
      "Compression time 0.21\n",
      "OS step time 0.02 (as fraction of last compression 0.11)\n",
      "step is 3 obj is 4.0259588520254415 err is 1.2457117368395454 ; eta= 0.9656427425776481\n",
      "Compressing with GQ...\n",
      "Compressing from  1636 to  14\n",
      "compress to  14 points with GQ\n",
      "compress to  14 points with GQ\n",
      "Compression time 0.24\n",
      "OS step time 0.03 (as fraction of last compression 0.11)\n",
      "step is 4 obj is 4.12178179583432 err is 1.0416855741940452 ; eta= 0.9548732931041548\n",
      "Compressing with GQ...\n",
      "Compressing from  1722 to  15\n",
      "compress to  15 points with GQ\n",
      "compress to  15 points with GQ\n",
      "Compression time 0.26\n",
      "OS step time 0.03 (as fraction of last compression 0.11)\n",
      "step is 5 obj is 4.209531131731171 err is 0.9681224597519936 ; eta= 0.9444182893218951\n",
      "Compressing with GQ...\n",
      "Compressing from  1994 to  16\n",
      "compress to  16 points with GQ\n",
      "compress to  16 points with GQ\n",
      "Compression time 0.30\n",
      "OS step time 0.03 (as fraction of last compression 0.10)\n",
      "step is 6 obj is 4.277433063379006 err is 0.9018100910047139 ; eta= 0.9342630790612149\n",
      "Compressing with GQ...\n",
      "Compressing from  2179 to  17\n",
      "compress to  17 points with GQ\n",
      "compress to  17 points with GQ\n",
      "Compression time 0.30\n",
      "OS step time 0.05 (as fraction of last compression 0.17)\n",
      "step is 7 obj is 4.329610359632439 err is 0.7734165459886775 ; eta= 0.924393938856702\n",
      "Compressing with GQ...\n",
      "Compressing from  2567 to  18\n",
      "compress to  18 points with GQ\n",
      "compress to  18 points with GQ\n",
      "Compression time 0.23\n",
      "OS step time 0.05 (as fraction of last compression 0.22)\n",
      "step is 8 obj is 4.373491347135684 err is 0.7215604824322837 ; eta= 0.9147980000321643\n",
      "Compressing with GQ...\n",
      "Compressing from  2898 to  19\n",
      "compress to  19 points with GQ\n",
      "compress to  19 points with GQ\n",
      "Compression time 0.28\n",
      "OS step time 0.05 (as fraction of last compression 0.19)\n",
      "step is 9 obj is 4.410945721302168 err is 0.6005955477320088 ; eta= 0.905463181825604\n",
      "Compressing with GQ...\n",
      "Compressing from  3427 to  19\n",
      "compress to  19 points with GQ\n",
      "compress to  19 points with GQ\n",
      "Compression time 0.33\n",
      "OS step time 0.06 (as fraction of last compression 0.19)\n",
      "step is 10 obj is 4.439860603758547 err is 0.560743986876841 ; eta= 0.8963781307771418\n",
      "Compressing with GQ...\n",
      "Compressing from  3886 to  20\n",
      "compress to  20 points with GQ\n",
      "compress to  20 points with GQ\n",
      "Compression time 0.43\n",
      "OS step time 0.07 (as fraction of last compression 0.17)\n",
      "step is 11 obj is 4.462954683472924 err is 0.5313031173562346 ; eta= 0.8875321656999794\n",
      "Compressing with GQ...\n",
      "Compressing from  4558 to  21\n",
      "compress to  21 points with GQ\n",
      "compress to  21 points with GQ\n",
      "Compression time 0.49\n",
      "OS step time 0.06 (as fraction of last compression 0.13)\n",
      "step is 12 obj is 4.482087737756255 err is 0.3987843352765932 ; eta= 0.8789152276381142\n",
      "Compressing with GQ...\n",
      "Compressing from  5266 to  22\n",
      "compress to  22 points with GQ\n",
      "compress to  22 points with GQ\n",
      "Compression time 0.59\n",
      "OS step time 0.08 (as fraction of last compression 0.13)\n",
      "step is 13 obj is 4.5017233459554 err is 0.42745545408240915 ; eta= 0.870517834286684\n",
      "Compressing with GQ...\n",
      "Compressing from  6258 to  23\n",
      "compress to  23 points with GQ\n",
      "compress to  23 points with GQ\n",
      "Compression time 0.70\n",
      "OS step time 0.09 (as fraction of last compression 0.13)\n",
      "step is 14 obj is 4.516037050219334 err is 0.40619519919686065 ; eta= 0.8623310384132593\n",
      "Compressing with GQ...\n",
      "Compressing from  7354 to  23\n",
      "compress to  23 points with GQ\n",
      "compress to  23 points with GQ\n",
      "Compression time 0.85\n",
      "OS step time 0.14 (as fraction of last compression 0.16)\n",
      "step is 15 obj is 4.529789607073358 err is 0.33391970920482206 ; eta= 0.8543463898725555\n",
      "Compressing with GQ...\n",
      "Compressing from  8463 to  24\n",
      "compress to  24 points with GQ\n",
      "compress to  24 points with GQ\n",
      "Compression time 1.03\n",
      "OS step time 0.16 (as fraction of last compression 0.16)\n",
      "step is 16 obj is 4.540755854377753 err is 0.30554094119969855 ; eta= 0.8465559008541063\n",
      "Compressing with GQ...\n",
      "Compressing from  10060 to  25\n",
      "compress to  25 points with GQ\n",
      "compress to  25 points with GQ\n",
      "Compression time 1.26\n",
      "OS step time 0.19 (as fraction of last compression 0.15)\n",
      "step is 17 obj is 4.549893156776571 err is 0.2589503000638753 ; eta= 0.8389520140434555\n",
      "Compressing with GQ...\n",
      "Compressing from  11528 to  26\n",
      "compress to  26 points with GQ\n",
      "compress to  26 points with GQ\n",
      "Compression time 1.51\n",
      "OS step time 0.21 (as fraction of last compression 0.14)\n",
      "step is 18 obj is 4.557123997094973 err is 0.27434593624441783 ; eta= 0.8315275734132361\n",
      "Compressing with GQ...\n",
      "Compressing from  13232 to  26\n",
      "compress to  26 points with GQ\n",
      "compress to  26 points with GQ\n",
      "Compression time 2.67\n",
      "OS step time 0.25 (as fraction of last compression 0.09)\n",
      "step is 19 obj is 4.564585952060524 err is 0.2555061531446403 ; eta= 0.8242757973918322\n",
      "Compressing with GQ...\n",
      "Compressing from  14717 to  27\n",
      "compress to  27 points with GQ\n",
      "compress to  27 points with GQ\n",
      "Compression time 3.12\n",
      "OS step time 0.36 (as fraction of last compression 0.11)\n",
      "step is 20 obj is 4.570464246832718 err is 0.24975455953890702 ; eta= 0.8171902541848022\n",
      "Compressing with GQ...\n",
      "Compressing from  16844 to  28\n",
      "compress to  28 points with GQ\n",
      "compress to  28 points with GQ\n",
      "Compression time 2.52\n",
      "OS step time 0.40 (as fraction of last compression 0.16)\n",
      "step is 21 obj is 4.575437165654861 err is 0.19227924385307427 ; eta= 0.8102648390483675\n",
      "Compressing with GQ...\n",
      "Compressing from  18916 to  29\n",
      "compress to  29 points with GQ\n",
      "compress to  29 points with GQ\n",
      "Compression time 2.89\n",
      "OS step time 0.45 (as fraction of last compression 0.16)\n",
      "step is 22 obj is 4.580772346760091 err is 0.22213403696710143 ; eta= 0.8034937533355226\n",
      "Compressing with GQ...\n",
      "Compressing from  21550 to  29\n",
      "compress to  29 points with GQ\n",
      "compress to  29 points with GQ\n",
      "Compression time 4.35\n",
      "OS step time 0.68 (as fraction of last compression 0.16)\n",
      "step is 23 obj is 4.58496082864883 err is 0.16464151709603625 ; eta= 0.7968714851540509\n",
      "Compressing with GQ...\n",
      "Compressing from  24022 to  30\n",
      "compress to  30 points with GQ\n",
      "compress to  30 points with GQ\n",
      "Compression time 4.37\n",
      "OS step time 0.68 (as fraction of last compression 0.16)\n",
      "step is 24 obj is 4.587554635878362 err is 0.140859623783953 ; eta= 0.7903927914922876\n",
      "Compressing with GQ...\n",
      "Compressing from  26983 to  31\n",
      "compress to  31 points with GQ\n",
      "compress to  31 points with GQ\n",
      "Compression time 4.71\n",
      "OS step time 0.76 (as fraction of last compression 0.16)\n",
      "step is 25 obj is 4.590488638431215 err is 0.15641312326605683 ; eta= 0.7840526816831157\n",
      "Compressing with GQ...\n",
      "Compressing from  29532 to  31\n",
      "compress to  31 points with GQ\n",
      "compress to  31 points with GQ\n",
      "Compression time 7.31\n",
      "OS step time 1.00 (as fraction of last compression 0.14)\n",
      "step is 26 obj is 4.593188969506629 err is 0.14010193941134008 ; eta= 0.7778464020896673\n",
      "Compressing with GQ...\n",
      "Compressing from  32835 to  32\n",
      "compress to  32 points with GQ\n",
      "compress to  32 points with GQ\n",
      "Compression time 6.19\n",
      "OS step time 1.12 (as fraction of last compression 0.18)\n",
      "step is 27 obj is 4.595175127685465 err is 0.14270749804964222 ; eta= 0.7717694219077355\n",
      "Compressing with GQ...\n",
      "Compressing from  36694 to  33\n",
      "compress to  33 points with GQ\n",
      "compress to  33 points with GQ\n",
      "Compression time 8.00\n",
      "OS step time 1.43 (as fraction of last compression 0.18)\n",
      "step is 28 obj is 4.597861504519753 err is 0.11748339257252116 ; eta= 0.7658174199901605\n",
      "Compressing with GQ...\n",
      "Compressing from  40154 to  34\n",
      "compress to  34 points with GQ\n",
      "compress to  34 points with GQ\n",
      "Compression time 10.25\n",
      "OS step time 1.59 (as fraction of last compression 0.16)\n",
      "step is 29 obj is 4.599264617126493 err is 0.11719220734750557 ; eta= 0.7599862726075867\n",
      "Compressing with GQ...\n",
      "Compressing from  44621 to  34\n",
      "compress to  34 points with GQ\n",
      "compress to  34 points with GQ\n",
      "Compression time 10.60\n",
      "OS step time 1.99 (as fraction of last compression 0.19)\n",
      "step is 30 obj is 4.600822355130612 err is 0.09610718017722775 ; eta= 0.7542720420681454\n",
      "Compressing with GQ...\n",
      "Compressing from  48566 to  35\n",
      "compress to  35 points with GQ\n",
      "compress to  35 points with GQ\n",
      "Compression time 12.13\n",
      "OS step time 2.17 (as fraction of last compression 0.18)\n",
      "step is 31 obj is 4.601538507844627 err is 0.0971669377374722 ; eta= 0.7486709661259003\n",
      "Compressing with GQ...\n",
      "Compressing from  53116 to  36\n",
      "compress to  36 points with GQ\n",
      "compress to  36 points with GQ\n",
      "Compression time 13.06\n",
      "OS step time 2.62 (as fraction of last compression 0.20)\n",
      "step is 32 obj is 4.60268972885185 err is 0.10620870898358814 ; eta= 0.7431794481144116\n",
      "Compressing with GQ...\n",
      "Compressing from  57696 to  36\n",
      "compress to  36 points with GQ\n",
      "compress to  36 points with GQ\n",
      "Compression time 16.04\n",
      "OS step time 3.14 (as fraction of last compression 0.20)\n",
      "step is 33 obj is 4.604314306212543 err is 0.09222799275434568 ; eta= 0.7377940477476166\n",
      "OS step time 9.20 (as fraction of last compression 0.57)\n",
      "step is 34 obj is 4.604976421081876 err is 0.08079653985092605 ; eta= 0.7325114725354702\n",
      "Time usage for GQ is 149.3404321199996\n",
      "Objective (theoretical)  4.643609736423016\n"
     ]
    }
   ],
   "source": [
    "if (d==1):\n",
    "  print(\"running compressed online sinkhorn with GQ...\")\n",
    "  params[\"compress\"] = True\n",
    "  params[\"method\"] = \"GQ\"\n",
    "  params[\"zeta\"]=2\n",
    "  start = timeit.default_timer()\n",
    "  (ft_gq, gt_gq, x_gq, y_gq, obj_gq, err_gq) = algorithms.online_sinkhorn(params)\n",
    "  run_time = timeit.default_timer()-start\n",
    "  data_gq={\"obj\":obj_gq,\"err\":err_gq,\"rt\":run_time}\n",
    "  print(\"Time usage for GQ is\", run_time)\n",
    "  print(\"Objective (theoretical) \",exact[2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "executionInfo": {
     "elapsed": 367626,
     "status": "ok",
     "timestamp": 1694694835159,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "2L38LtCe4hQT",
    "outputId": "455c6a77-0434-42da-aaef-20b78222778f"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "running online sinkhorn...\n",
      "Online Sinkhorn with Compression= False\n",
      "Running 5 Sinkhorn iterations to start-up.\n",
      "step is 0 obj is 3.5111102110726637 err is 1.4660251733710576 ; eta= 1.0 OS step time 0.01\n",
      "step is 1 obj is 3.7199618351957584 err is 1.7781093554250416 ; eta= 0.9881887308219607 OS step time 0.03\n",
      "step is 2 obj is 3.9000434035200664 err is 1.428250293351524 ; eta= 0.976742300461482 OS step time 0.05\n",
      "step is 3 obj is 4.020611889809007 err is 1.2469667124720303 ; eta= 0.9656427425776481 OS step time 0.07\n",
      "step is 4 obj is 4.123413776508018 err is 1.1769317699012538 ; eta= 0.9548732931041548 OS step time 0.09\n",
      "step is 5 obj is 4.194196818104235 err is 0.892676672570804 ; eta= 0.9444182893218951 OS step time 0.12\n",
      "step is 6 obj is 4.260442286921173 err is 0.8286420212189733 ; eta= 0.9342630790612149 OS step time 0.15\n",
      "step is 7 obj is 4.322924996069107 err is 0.8066297669314483 ; eta= 0.924393938856702 OS step time 0.18\n",
      "step is 8 obj is 4.364251090212925 err is 0.662760296959909 ; eta= 0.9147980000321643 OS step time 0.22\n",
      "step is 9 obj is 4.401778141241023 err is 0.6572193824506454 ; eta= 0.905463181825604 OS step time 0.27\n",
      "step is 10 obj is 4.431915820795492 err is 0.5565222098628142 ; eta= 0.8963781307771418 OS step time 0.37\n",
      "step is 11 obj is 4.458574185333397 err is 0.45463138067986175 ; eta= 0.8875321656999794 OS step time 0.43\n",
      "step is 12 obj is 4.4798224366095 err is 0.4254770243148407 ; eta= 0.8789152276381142 OS step time 0.52\n",
      "step is 13 obj is 4.496657612360551 err is 0.4282695425340044 ; eta= 0.870517834286684 OS step time 0.61\n",
      "step is 14 obj is 4.513592818542658 err is 0.364010992267785 ; eta= 0.8623310384132593 OS step time 0.73\n",
      "step is 15 obj is 4.524665733181035 err is 0.37143663624515355 ; eta= 0.8543463898725555 OS step time 1.23\n",
      "step is 16 obj is 4.533626172282977 err is 0.317794741837905 ; eta= 0.8465559008541063 OS step time 1.45\n",
      "step is 17 obj is 4.545505097672016 err is 0.3169417543680595 ; eta= 0.8389520140434555 OS step time 1.70\n",
      "step is 18 obj is 4.553739961267812 err is 0.2878637143331906 ; eta= 0.8315275734132361 OS step time 2.17\n",
      "step is 19 obj is 4.561924922510304 err is 0.24841872775619134 ; eta= 0.8242757973918322 OS step time 2.52\n",
      "step is 20 obj is 4.567443677537959 err is 0.23399594274576252 ; eta= 0.8171902541848022 OS step time 3.76\n",
      "step is 21 obj is 4.5733261054498096 err is 0.21967210609281662 ; eta= 0.8102648390483675 OS step time 4.37\n",
      "step is 22 obj is 4.57744659219189 err is 0.18888030805552103 ; eta= 0.8034937533355226 OS step time 5.36\n",
      "step is 23 obj is 4.580844502491747 err is 0.1957429665411765 ; eta= 0.7968714851540509 OS step time 7.44\n",
      "step is 24 obj is 4.58510430477417 err is 0.17310050178504088 ; eta= 0.7903927914922876 OS step time 8.73\n",
      "step is 25 obj is 4.588847371279504 err is 0.14850282689908867 ; eta= 0.7840526816831157 OS step time 10.22\n",
      "step is 26 obj is 4.591156048631864 err is 0.13300614929480914 ; eta= 0.7778464020896673 OS step time 13.54\n",
      "step is 27 obj is 4.593465104954902 err is 0.15052968020404078 ; eta= 0.7717694219077355 OS step time 16.01\n",
      "step is 28 obj is 4.595870674880178 err is 0.14160834756931995 ; eta= 0.7658174199901605 OS step time 20.54\n",
      "step is 29 obj is 4.598428355529062 err is 0.12805218692106002 ; eta= 0.7599862726075867 OS step time 23.99\n",
      "step is 30 obj is 4.600057108022964 err is 0.10927637096503617 ; eta= 0.7542720420681454 OS step time 30.05\n",
      "step is 31 obj is 4.601637003058541 err is 0.11246154859600588 ; eta= 0.7486709661259003 OS step time 34.77\n",
      "step is 32 obj is 4.602784412645803 err is 0.09383253377058187 ; eta= 0.7431794481144116 OS step time 43.81\n",
      "step is 33 obj is 4.604354003276773 err is 0.10003969341471541 ; eta= 0.7377940477476166 OS step time 53.21\n",
      "step is 34 obj is 4.605506899810086 err is 0.09013232038589769 ; eta= 0.7325114725354702 OS step time 60.70\n",
      "Time usage for OS is 367.54094961699957\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={\"obj\":obj_os,\"err\":err_os,\"rt\":run_time}\n",
    "print(\"Time usage for OS is\", run_time)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {
    "executionInfo": {
     "elapsed": 12215,
     "status": "ok",
     "timestamp": 1694695171454,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "roVTgpvvh8zr"
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "# Plotting\n",
    "b=params['b']\n",
    "m=np.array([mean1])\n",
    "t_f=np.arange(np.min(x),np.max(x),0.1)\n",
    "f_fou=ft_f(t_f)-ft_f(m)\n",
    "f_os=ft_os(t_f)-ft_os(m)\n",
    "f_gq=ft_gq(t_f)-ft_gq(m)\n",
    "f_e=params['exact_f'](t_f)-params['exact_f'](m)\n",
    "# find the index of minimum element from the array\n",
    "index_f = np.absolute(x-mean1).argmin()\n",
    "#  Plotting for g\n",
    "t_g=np.arange(np.min(y),np.max(y),0.1)\n",
    "m=np.array([mean2])\n",
    "g_fou=gt_f(t_g)-gt_f(m)\n",
    "g_os=gt_os(t_g)-gt_os(m)\n",
    "g_gq=gt_gq(t_g)-gt_gq(m)\n",
    "g_e=params['exact_g'](t_g)-params['exact_g'](m)\n",
    "index_g = np.absolute(y-mean2).argmin()\n",
    "# plotting for f+g\n",
    "tmin=(np.mean(y)+np.mean(x))/2+0.1\n",
    "tmax=tmin+0.6\n",
    "t=np.arange(tmin,tmax,0.02)\n",
    "fg_fou=gt_f(t)+ft_f(t)-params['exact_g'](t)-params['exact_f'](t)\n",
    "fg_gq=gt_gq(t)+ft_gq(t)-params['exact_g'](t)-params['exact_f'](t)\n",
    "fg_os=gt_os(t)+ft_os(t)-params['exact_g'](t)-params['exact_f'](t)\n",
    "g_os=gt_os(t_g)-gt_os(m)\n",
    "g_gq=gt_gq(t_g)-gt_gq(m)\n",
    "# plotting the objective values\n",
    "a = params['a']\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",
    "#\n",
    "ref_value=theoretical\n",
    "save_data={\"N\":N,\"ref_value\":ref_value,\n",
    "           \"ft_s\":ft_s,\"f_gq\":f_gq,\"f_e\":f_e,\"f_fou\":f_fou,\"f_os\":f_os,\n",
    "           \"gt_s\":gt_s,\"g_gq\":g_gq,\"g_e\":g_e,\"g_fou\":g_fou,\"g_os\":g_os,\n",
    "           \"t\":t,\"fg_fou\":fg_fou,\"fg_gq\":fg_gq,\"fg_os\":fg_os,\n",
    "           \"x\":x,\"y\":y,\n",
    "           \"d\":d,\"index_g\":index_g,\"index_f\":index_f,\n",
    "           \"t_f\":t_f,\"t_g\":t_g,\n",
    "          \"ref_value\":ref_value,\n",
    "          \"a\":a,\"b\":b,    \"d\":d,\n",
    "          \"os\":data_os,\n",
    "          \"gq\":data_gq,\n",
    "          \"cosf\":data_cos_f,\n",
    "          \"s\":data_s,\n",
    "           }\n",
    "if \"cosf2\" in locals():\n",
    "  save_data[\"data_f2\"]=data_cos_f2\n",
    "if True:\n",
    "  filehandler = open('example_cts_1d.pkl', 'wb')\n",
    "  pickle.dump(save_data, filehandler)\n",
    "  filehandler.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {
    "executionInfo": {
     "elapsed": 26,
     "status": "ok",
     "timestamp": 1694694847082,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "Aa3_kqc2iveB"
   },
   "outputs": [],
   "source": [
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as pl\n",
    "filehandler = open('example_cts_1d.pkl','rb')\n",
    "in_data= pickle.load(filehandler)\n",
    "d=in_data[\"d\"]\n",
    "\n",
    "N=in_data[\"N\"]\n",
    "ref_value=in_data[\"ref_value\"]\n",
    "x=in_data[\"x\"]\n",
    "y=in_data[\"y\"]\n",
    "t_f=in_data[\"t_f\"]\n",
    "t_g=in_data[\"t_g\"]\n",
    "ft_s=in_data[\"ft_s\"]\n",
    "f_fou=in_data[\"f_fou\"]\n",
    "f_os=in_data[\"f_os\"]\n",
    "f_gq=in_data[\"f_gq\"]\n",
    "f_e=in_data[\"f_e\"]\n",
    "gt_s=in_data[\"gt_s\"]\n",
    "g_fou=in_data[\"g_fou\"]\n",
    "g_os=in_data[\"g_os\"]\n",
    "g_gq=in_data[\"g_gq\"]\n",
    "g_e=in_data[\"g_e\"]\n",
    "obj_rec=in_data[\"cosf\"][\"obj\"]\n",
    "obj_s=in_data[\"s\"][\"obj\"]\n",
    "obj_os=in_data[\"os\"][\"obj\"]\n",
    "obj_gq=in_data[\"gq\"][\"obj\"]\n",
    "err_os=in_data[\"os\"][\"err\"]\n",
    "err_rec=in_data[\"cosf\"][\"err\"]\n",
    "err_gq=in_data[\"gq\"][\"err\"]\n",
    "index_f=in_data[\"index_f\"]\n",
    "index_g=in_data[\"index_g\"]\n",
    "a=in_data[\"a\"]\n",
    "run_time1=in_data[\"cosf\"][\"rt\"]\n",
    "run_time2=in_data[\"gq\"][\"rt\"]\n",
    "run_time3=in_data[\"os\"][\"rt\"]\n",
    "t=in_data[\"t\"]\n",
    "fg_fou=in_data[\"fg_fou\"]\n",
    "fg_gq=in_data[\"fg_gq\"]\n",
    "fg_os=in_data[\"fg_os\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 480
    },
    "executionInfo": {
     "elapsed": 362,
     "status": "ok",
     "timestamp": 1694694847419,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "n7feDQ3ulzoA",
    "outputId": "c509673d-4737-408f-a1c8-dedaf701f872"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0.5, 0, 'x')"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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PmXPnj1o1KgRLly4UOp7mwMGJiIiovLoP4tb1i1mraZUm0xEnR+ENcfj9H5UWloaOnfujMePHxc4fu3aNTRt2hS//fab3vc2FwxMRERE5cjL85qAF0Nyjln5vxY1pynV9gmWnB6ALdHXdX6eUqnExx9/jNjY2CLPp6en4/3338f167rf25wwMBEREZUjz+c1Vd20MX+tpmd7vxW1VtP3nV7EgFa5d7Br0wrsibur0/NiYmKwe/fuEq+ZPn06AgICdLqvuWFgIiIiKmeez2ty6dQJVTdtLPKacX2scKh2fgz4ODUNkx4+wjzpQqxduxxH4h9o/aw6dergyJEj8Pf3L/J8r169MGrUKN1/CDPDwERERGQJns1pUqLggpUDH6fiq0cpEADIBAUWSuZi8apVOHXzcRE3KVq9evVw4sQJvPHGGwWON2rUCEuXLi0Xe9AxMBEREZVj/12rybqqJ9LsVUi1B4Y/eoxhKakF9p+zE3IQKczErBXrcCEhVevneHp6YteuXerNe318fLBly5Zys/glN98VCTffJSIic/V8w15BEKBSqZCwMwInzv+Id9MzAABPH1njXrQzKtZPg51bLgDgscoRA60mY/r/uqFaRSednvfDDz+gQYMGaNSokeg/i9i0/fxmYBIJAxMREZUlqn8mQTg0FwCQfMoZj684okKNdHg3TFNfc0/lis9k0/Dd4Pfg52ZvqlINStvPbw7JERERWaC8kP546t0NTx9ZI+2WHQAg9bodrv/tgZTrdsjNsEJFIQXzciIwYtnvuJeWZdB6VCoVEhMTDfqM0mBgIiIiskDxbdrixrxDuLHTE4rs/DigzJUg67EMSccqIH67FwCgsvAAMzImYMiynXickWOwembNmoVatWph165dBntGaTAwERERWSDfWTMBK6tn7/67ShNg656Np4+skZthBX9JIjxtxqHHqrlIzxZ/U90dO3YgLCwMKSkp6NChAxYsWABzmzHEOUwi4RwmIiIqa57GxODG+x9ovG513xxs97GHlQqokjMQG/t9BltrK43ttBETE4MmTZogPT29wPEBAwZg4cKFkMlkojynOJzDRERERKLoFZUfWhQCcNt6KfqsWYVchVJDK80ePHiAzp07FwpLALBs2TLMnDmz1M8QCwMTERGRhXq+RpNVxYrFXvPfLVTyJMBVfIf/rf8VSqX+g1S5ubno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Ro4ciYiICJw+fRr16tVDu3btcO/ePVOXRv+xf/9+DBkyBP/++y927dqF3NxcvPXWW8jIyDB1aVSCEydO4IcffkDdunVNXYrF47ICVObMmjULixcvxrVr10xdisVr3LgxXn31VSxcuBBA/p6Kfn5+GDZsGMLCwkxcHZXk/v37qFixIvbv348WLVqYuhwqQnp6Oho2bIjIyEhMnToV9evXx7x580xdlsViDxOVOampqXBzczN1GRYvJycHp06dQps2bdTHJBIJ2rRpg6NHj5qwMtJGamoqAPDfJTM2ZMgQdOzYscC/Y2Q63HyXypT4+HgsWLAAs2fPNnUpFu/BgwdQKBTw8vIqcNzLywtxcXEmqoq0oVQqMXz4cDRv3hy1a9c2dTlUhPXr1+P06dM4ceKEqUuhZ9jDRCYRFhYGQRBKfP33QzchIQHt27dH165dMWDAABNVTlT2DRkyBBcuXMD69etNXQoV4fbt2/jiiy+wdu1a2NramroceoZzmMgk7t+/j4cPH5Z4TWBgIGQyGQAgMTERb775Jpo0aYKoqChIJMz6ppaTkwN7e3v88ssv6NKli/p4nz59kJKSgm3btpmuOCrW0KFDsW3bNhw4cAABAQGmLoeKsHXrVrz77ruwsrJSH1MoFBAEARKJBNnZ2QXOkXFwSI5MwtPTE56enlpdm5CQgJYtWyI0NBQrVqxgWDITMpkMoaGh2L17tzowKZVK7N69G0OHDjVtcVSISqXCsGHDsGXLFuzbt49hyYy1bt0a58+fL3CsX79+CAkJwZgxYxiWTISBicxaQkIC3nzzTfj7+2P27Nm4f/+++py3t7cJKyMAGDlyJPr06YNXXnkFjRo1wrx585CRkYF+/fqZujT6jyFDhmDdunXYtm0bnJyckJycDABwcXGBnZ2diaujlzk5ORWaW+bg4AB3d3fOOTMhBiYya7t27UJ8fDzi4+NRuXLlAuc4mmx6H374Ie7fv48JEyYgOTkZ9evXx19//VVoIjiZ3uLFiwEAb775ZoHjK1asQN++fY1fEFEZwzlMRERERBpwMggRERGRBgxMRERERBowMBERERFpwMBEREREpAEDExEREZEGDExEREREGjAwEREREWnAwERERESkAQMTERERkQYMTEREREQaMDARERERacDARERERKQBAxMRERGRBgxMRERERBowMBERPbNu3ToIggBBEPDZZ58Ve92tW7dQoUIFCIIAuVyOp0+fGrFKIjIFQaVSqUxdBBGRuejZsyfWrVsHANixYwc6duxY4LxSqUSrVq2wf/9+WFtb499//0XDhg1NUSoRGRF7mIiIXhIZGYkqVaoAAD755BPcu3evwPmZM2di//79AIDJkyczLBFZCPYwERH9x4EDB9CyZUsolUq888472L59OwDg1KlTaNq0KXJzc9GiRQvs3bsXEgn/v5PIEvDfdCKi/2jRogXGjBkDIH9YbvHixcjMzETPnj2Rm5sLFxcXrFq1imGJyIKwh4mIqAi5ublo2rQpTp06BTs7O7z11lvYtm0bAGDNmjXo2bOniSskImNiYCIiKsalS5fQsGFDZGZmqo91795dPSmciCwH+5OJiIoRHByML7/8Uv3e09MTkZGRJqyIiEyFgYmIqBhpaWlYuXKl+v2DBw9w+vRpE1ZERKbCwEREVIyhQ4fixo0bAAAnJyeoVCr07dsXKSkpJq2LiIyPgYmIqAibNm3C6tWrAQCffvqpet7S7du3MXjwYFOWRkQmwEnfRET/kZCQgDp16uDx48eoXr06zpw5AwcHBwwePBhLliwBwG/KEVkaBiYiopeoVCq0bdsWu3fvhlQqxeHDh9GoUSMAQGZmJho2bIhLly7BxcUF586dU68KTkTlG4fkiIhe8t1332H37t0AgPHjx6vDEgDY29tjzZo1sLa2RmpqKnr37g2lUmmqUonIiBiYiIieOX/+PMaOHQsAaNq0KcaNG1fomldeeQUREREAgP3792P27NlGrZGITINDckREALKzs/Hqq6/i/PnzcHR0RHR0NIKCgoq8VqFQ4M0338ShQ4cgk8lw7Ngx1K9f37gFE5FRMTARERERacAhOSIiIiINGJiIiIiINGBgIiIiItKAgYmIiIhIAwYmIiIiIg0YmIiIiIg0YGAiIiIi0oCBiYiIiEgDBiYiIiIiDRiYiIiIiDRgYCIiIiLSgIGJiIiISAMGJiIiIiINGJiIiIiINPh/zfe9sofzro4AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pl.plot(t_f,f_os,label='OS',linewidth=5)\n",
    "pl.plot(t_f,f_fou,'--',label='Fourier COS',linewidth=5)\n",
    "pl.plot(t_f,f_gq,'-.',label='GQ COS',linewidth=5)\n",
    "pl.plot(t_f,f_e,'k:',label='Exact',linewidth=5)\n",
    "pl.plot(x,ft_s-ft_s[index_f],'*',label='Sinkhorn',linewidth=5)\n",
    "pl.ylabel('f',fontsize=20)\n",
    "pl.xlabel('x',fontsize=20)\n",
    "#pl.legend(bbox_to_anchor=(1.05, 1), fontsize=\"18\",loc=\"upper right\", borderaxespad=0.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 480
    },
    "executionInfo": {
     "elapsed": 415,
     "status": "ok",
     "timestamp": 1694694847827,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "nz4ZoJV2w8pl",
    "outputId": "1d0ea13b-ae51-491c-eac2-a65bcf826008"
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7becd4be5a50>"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pl.plot(t_g,g_os,label='OS',linewidth=5)\n",
    "pl.plot(t_g,g_gq,'-.',label='GQ COS',linewidth=5)\n",
    "pl.plot(t_g,g_fou,'--',label='Fourier COS',linewidth=5)\n",
    "pl.plot(t_g,g_e,'k:',label='Exact',linewidth=5)\n",
    "pl.plot(y,gt_s-gt_s[index_g],'*',label='Sinkhorn',linewidth=5)\n",
    "pl.ylabel('g',fontsize=20)\n",
    "pl.xlabel('y',fontsize=20)\n",
    "pl.legend(bbox_to_anchor=(0.55, 0.45), fontsize=\"18\", borderaxespad=0.)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 496
    },
    "executionInfo": {
     "elapsed": 1062,
     "status": "ok",
     "timestamp": 1694694849380,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "u0mQPDwUrjMt",
    "outputId": "91a426c4-17de-4d66-fc10-560a57dd56c6"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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eno6YmJi1EuPODs7Y/Hixer+kydPxqpVq6BSqTBs2DCEh4dj0KBBsLOzw6lTp7BixQpkZmZi4MCBRr+kaShvb288ePAA/fr1wwcffICAgAAAQFJSEpYsWaJecmbVqlWwtbXVa+yhQ4fi3XffxcqVK3H48GF07doVM2fOxKBBg+Dq6ori4mJkZWUhOTkZ27ZtQ35+fpU1/86cOYOwsDD4+vpi+PDh6N27N9zd3VFeXo4bN24gNjYW+/btA1BRfD+7FA4R1R2LPSKyGNbW1nB3d8fdu3eRnZ2N6OhoREdHa23fqVMn/Pjjj1VmkXx9ffHpp58iMjISBQUF+Oijj6r1mz9/Prp37252xV7btm3xzTff4M0338SHH35YbbtUKsWXX36JkJCQOo2/YsUKtGjRAosXL8bdu3exaNEirW0dHBxgZWVV7f3U1FSkpqZq7TdgwACsX7++TvERkWYs9ojIYtjZ2SE7OxvHjx/H/v37cfz4cVy5cgX37t1DaWkpHBwc4OHhgR49emDkyJEICQnROMMVEREBHx8frFy5EqmpqSguLkarVq3Qp08fzJw5E0FBQWb7FIhhw4YhLS0Ny5Ytw4EDB3Dnzh24uLjAz88P8+fPV69zVxcSiQQRERGYPHky1qxZgwMHDuD69et4+PAh7O3t4enpiV69eiE4OBijR49G06ZN1X0nTJiA1q1bY9++fUhNTUV2djbu3bunXuKmd+/eGDduHMaPH19lXUEiMpxEmMsCUUREVCcBAQE4dOgQBg8erH6sGRFRJf76RERERGTBWOwRERERWTAWe0REREQWjMUeERERkQVjsUdERERkwXg3LhEREZEF48weERERkQVjsUdERERkwVjsEREREVkwFntEREREFozFHhEREZEFY7FHREREZMFY7BERERFZMBZ7RERERBbs/wNC7KmgwmxnPwAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "OS= 4.605506899810086 ; Fourier OS= 4.60558515367607 ; GQ OS 4.604976421081876 ; S= 5.07445213627446 ; exact= 4.643609736423016\n"
     ]
    }
   ],
   "source": [
    "pl.loglog(N[3:], abs(ref_value-obj_os[3:])/ref_value, label='OS',linewidth=5)\n",
    "pl.loglog(N[3:], abs(ref_value-obj_rec[3:])/ref_value, '--',label='Fourier COS',linewidth=5)\n",
    "if d==1:\n",
    "   pl.loglog(N[1:], abs(ref_value-obj_gq[1:])/ref_value,'-.',label='GQ COS',linewidth=5)\n",
    "pl.legend(bbox_to_anchor=(0.52, 1), fontsize=\"18\", borderaxespad=0.)\n",
    "#pl.title('Obj error to Sinkhorn')\n",
    "pl.xlabel('Samples',fontsize=20)\n",
    "pl.ylabel('Relative error (objective)',fontsize=20)\n",
    "pl.xticks(fontsize=20)\n",
    "pl.yticks(fontsize=20)\n",
    "pl.show()\n",
    "print(\"OS=\",obj_os[-1],'; Fourier OS=',obj_rec[-1],\"; GQ OS\", obj_gq[-1],\"; S=\",obj_s[-1],\"; exact=\",theoretical)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 514
    },
    "executionInfo": {
     "elapsed": 973,
     "status": "ok",
     "timestamp": 1694694850350,
     "user": {
      "displayName": "Tony Shardlow",
      "userId": "01347584962082294341"
     },
     "user_tz": -60
    },
    "id": "k2DHeq2N-CqH",
    "outputId": "30c24021-f168-4942-d422-7a41dc753dd0"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "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.38; Fourier OS=  -0.35; GQ OS=  -0.35;  OS=  -0.33 \n",
      "Execution time: OS 367.54 and Fourier 145.98 and GQ 149.34\n"
     ]
    }
   ],
   "source": [
    "# plotting the error at every step\n",
    "st=5\n",
    "pl.loglog(N[st:], err_os[st:], label='OS',linewidth=5)\n",
    "pl.loglog(N[st:], err_rec[st:], '--',label='Fourier COS',linewidth=5)\n",
    "if d==1:\n",
    "   pl.loglog(N[st:], err_gq[st:],'-.',label='GQ COS',linewidth=5)\n",
    "pl.loglog(N[st:],15*N[st:]**(-a/(2*a+1)),'k:',label='Theoretical')\n",
    "#pl.legend(fontsize=\"20\",loc=\"upper right\", borderaxespad=0.)\n",
    "pl.xlabel('Samples',fontsize=20)\n",
    "pl.ylabel('Error (variational)',fontsize=20)\n",
    "pl.xticks(fontsize=20)\n",
    "pl.yticks(fontsize=20)\n",
    "#pl.ylim(0.1,1.2)\n",
    "pl.show()\n",
    "i=3\n",
    "z_rec = np.polyfit(np.log(N[i:]), np.log(err_rec[i:]), 1)\n",
    "z_os = np.polyfit(np.log(N[i:]), np.log(err_os[i:]), 1)\n",
    "z_gq = np.polyfit(np.log(N[i:]), np.log(err_gq[i:]), 1)\n",
    "print('dimension:',d,'; Convergence rate: theory={:2.2}; Fourier OS=  {:2.2}; GQ OS=  {:2.2};  OS=  {:2.2} '.format(-a/(2*a+1),z_rec[0],z_gq[0],z_os[0]))\n",
    "print('Execution time: OS {:.2f} and Fourier {:.2f} and GQ {:.2f}'.format(run_time3,run_time1,run_time2))"
   ]
  }
 ],
 "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
}
