{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "AYWmrPPeO7ev"
   },
   "source": [
    "# <center>SW Sphere</center>"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "yFkkHsJRO7e8"
   },
   "outputs": [],
   "source": [
    "import torch\n",
    "import time\n",
    "import sys\n",
    "import ot\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import torch.nn.functional as F\n",
    "\n",
    "from scipy.special import iv, gamma\n",
    "\n",
    "sys.path.append(\"../lib\")\n",
    "from sw_sphere import sliced_wasserstein_sphere, sliced_wasserstein_sphere_unif\n",
    "from utils_sphere import *\n",
    "from utils_vmf import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "r4eGaqG2tYad"
   },
   "outputs": [],
   "source": [
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Swq4mpPzO7fp"
   },
   "source": [
    "### Test SW Von Mises-Fisher"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "AzOekeZ7tv2s"
   },
   "source": [
    "#### SW"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "_Trc9kBut_b5"
   },
   "source": [
    "##### Influence $\\kappa$ + Dimension"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 317
    },
    "id": "hAhCN0vHt2_c",
    "outputId": "ca1af711-58da-45f6-8391-0d1546bc17e8"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n",
      "25\n",
      "50\n",
      "100\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6,3))\n",
    "\n",
    "\n",
    "for d in [3,25,50,100]:\n",
    "    print(d)\n",
    "\n",
    "    x0 = torch.randn((500,d), device=device)\n",
    "    x0 = F.normalize(x0, p=2, dim=-1)\n",
    "\n",
    "    kappas = [1,5,10,20,30,40,50,75,100,150,200,250]\n",
    "    mus = np.ones((len(kappas),d))\n",
    "\n",
    "    L = np.zeros((len(kappas), 10))\n",
    "\n",
    "    for k in range(len(kappas)):\n",
    "        mu = mus[k]\n",
    "        mu = mu/np.linalg.norm(mu)\n",
    "        x1 = rand_von_mises_fisher(mu,kappa=kappas[k],N=500)\n",
    "\n",
    "        for j in range(10):\n",
    "            sw = sliced_wasserstein_sphere(x0, torch.tensor(x1, dtype=torch.float, device=device), 100, device)\n",
    "            L[k, j] = sw\n",
    "\n",
    "    m = np.mean(L, axis=-1)\n",
    "    s = np.std(L, axis=-1)\n",
    "    plt.plot(kappas, m, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(kappas, m-s, m+s,alpha=0.5)\n",
    "    \n",
    "\n",
    "plt.xlabel(r\"$\\kappa$\", fontsize=13)\n",
    "plt.title(r\"$SSW_2^2$\", fontsize=13) # rotation=0, labelpad=20, fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.legend(fontsize=13)\n",
    "plt.savefig(\"./SW_vMF.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 317
    },
    "id": "YLreuFvXcrwc",
    "outputId": "6d9a8971-cdad-40b2-8d04-e0825a999459"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n",
      "25\n",
      "50\n",
      "100\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6,3))\n",
    "\n",
    "\n",
    "for d in [3,25,50,100]:\n",
    "    print(d)\n",
    "\n",
    "    kappas = [1,5,10,20,30,40,50,75,100,150,200,250]\n",
    "    mus = np.ones((len(kappas),d))\n",
    "\n",
    "    L = np.zeros((len(kappas), 10))\n",
    "\n",
    "    for k in range(len(kappas)):\n",
    "        mu = mus[k]\n",
    "        mu = mu/np.linalg.norm(mu)\n",
    "        x1 = rand_von_mises_fisher(mu,kappa=kappas[k],N=500)\n",
    "\n",
    "        for j in range(10):\n",
    "            sw = sliced_wasserstein_sphere_unif(torch.tensor(x1, dtype=torch.float, device=device), 100, device)\n",
    "            L[k, j] = sw\n",
    "\n",
    "    m = np.mean(L, axis=-1)\n",
    "    s = np.std(L, axis=-1)\n",
    "    plt.plot(kappas, m, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(kappas, m-s, m+s,alpha=0.5)\n",
    "    \n",
    "\n",
    "plt.xlabel(r\"$\\kappa$\", fontsize=13)\n",
    "plt.title(r\"$SSW_2^2$\", fontsize=13) # rotation=0, labelpad=20, fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.legend(fontsize=13)\n",
    "plt.savefig(\"./SW_vMF.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "izOjPBGI3XAD"
   },
   "source": [
    "##### Rotation Around Circle"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "###### $SSW_2^2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 317
    },
    "id": "LFPqK8ha3XAD",
    "outputId": "6de1d7fe-347b-422c-e23a-25403a070aae"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n",
      "25\n",
      "50\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "kappa = 10    \n",
    "\n",
    "ds = [3, 25, 50]\n",
    "\n",
    "L = np.zeros((len(ds), len(mus), 100))\n",
    "\n",
    "thetas = [0,np.pi/6,np.pi/3,np.pi/2,2*np.pi/3,5*np.pi/6,np.pi,\n",
    "            -5*np.pi/6,-2*np.pi/3,-np.pi/2,-np.pi/3,-np.pi/6, 0]\n",
    "thetas = np.array(thetas)%(2*np.pi)\n",
    "\n",
    "thetas[-1] = 2*np.pi\n",
    "\n",
    "\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    print(d)\n",
    "    \n",
    "    mu_target = np.zeros((d,))\n",
    "    mu_target[0] = 1\n",
    "    \n",
    "    v = np.zeros((d,))\n",
    "    v[1] = 1\n",
    "\n",
    "    mus = []\n",
    "    for theta in thetas:\n",
    "        mus.append(np.zeros((d,)))\n",
    "        mus[-1][0] = np.cos(theta)\n",
    "        mus[-1][1] = np.sin(theta)\n",
    "        # mus.append([np.cos(theta), np.sin(theta), 0])    \n",
    "        \n",
    "    for k in range(len(mus)):\n",
    "        mu = np.array(mus[k])\n",
    "        \n",
    "        for j in range(100):\n",
    "            x0 = rand_von_mises_fisher(mu_target, kappa=10, N=500)\n",
    "            x1 = rand_von_mises_fisher(mu, kappa=10, N=500)\n",
    "            sw = sliced_wasserstein_sphere(torch.tensor(x0, dtype=torch.float, device=device), \n",
    "                                           torch.tensor(x1, dtype=torch.float, device=device), \n",
    "                                           1000, device, p=2)\n",
    "            L[i, k, j] = sw\n",
    "\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "    plt.plot(thetas, m, label=r\"$d=$\"+str(d))\n",
    "    plt.fill_between(thetas, m-s, m+s,alpha=0.5)\n",
    "    \n",
    "plt.ylabel(r\"$SSW_2^2$\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 310
    },
    "id": "DHxzlw5U3XAF",
    "outputId": "f821faf3-0df1-4310-d2a3-76463cdd7613"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "m = np.mean(L[0], axis=-1)\n",
    "s = np.std(L[0], axis=-1)\n",
    "\n",
    "plt.plot(thetas*180/np.pi, m, label=r\"$d=$\"+str(ds[0])) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "plt.fill_between(thetas*180/np.pi, m-s, m+s,alpha=0.5)\n",
    "\n",
    "plt.xlabel(r\"$\\theta$\")\n",
    "# plt.xticks(thetas*180/np.pi)\n",
    "labels = [\"0\", r\"$\\frac{\\pi}{6}$\", r\"$\\frac{\\pi}{3}$\", r\"$\\frac{\\pi}{2}$\", r\"$\\frac{2\\pi}{3}$\", r\"$\\frac{5\\pi}{6}$\",\n",
    "           r\"$\\pi$\", r\"$\\frac{7\\pi}{6}$\", r\"$\\frac{4\\pi}{3}$\", r\"$\\frac{3\\pi}{2}$\", r\"$\\frac{5\\pi}{3}$\",\n",
    "           r\"$\\frac{11\\pi}{6}$\", r\"$2\\pi$\"]\n",
    "plt.xticks(180*thetas/np.pi, labels, fontsize=10)\n",
    "plt.title(r\"$SSW_2^2$\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 255
    },
    "id": "gEO5S1ky3XAG",
    "outputId": "2e11459a-30f5-4447-f5e6-3ff994db8d4f"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(4,3))\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "    plt.plot(thetas*180/np.pi, m, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(thetas*180/np.pi, m-s, m+s,alpha=0.5)\n",
    "\n",
    "    plt.xlabel(r\"$\\theta$\") #, fontsize=13)\n",
    "    labels = [\"0\", r\"$\\frac{\\pi}{6}$\", r\"$\\frac{\\pi}{3}$\", r\"$\\frac{\\pi}{2}$\", r\"$\\frac{2\\pi}{3}$\", r\"$\\frac{5\\pi}{6}$\",\n",
    "            r\"$\\pi$\", r\"$\\frac{7\\pi}{6}$\", r\"$\\frac{4\\pi}{3}$\", r\"$\\frac{3\\pi}{2}$\", r\"$\\frac{5\\pi}{3}$\",\n",
    "            r\"$\\frac{11\\pi}{6}$\", r\"$2\\pi$\"]\n",
    "    plt.xticks(180*thetas/np.pi, labels, fontsize=10)\n",
    "\n",
    "# ax.set_xticklabels(label)\n",
    "# plt.ylabel(r\"$SSW_2^2$\", fontsize=13, rotation=0, labelpad=20)\n",
    "plt.title(r\"$SSW_2^2$\", fontsize=13)\n",
    "\n",
    "plt.grid(True)\n",
    "plt.legend(fontsize=13)\n",
    "plt.savefig(\"./SSW_vMF_mus_ds.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "k5-AmFRkV0DC"
   },
   "source": [
    "###### $SSW_1$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 317
    },
    "id": "bJDPwcj1V0HQ",
    "outputId": "47c3c825-729d-4ae5-bccb-15d88d957619"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n",
      "25\n",
      "50\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "kappa = 10    \n",
    "\n",
    "ds = [3, 25, 50]\n",
    "\n",
    "L = np.zeros((len(ds), len(mus), 100))\n",
    "\n",
    "thetas = [0,np.pi/6,np.pi/3,np.pi/2,2*np.pi/3,5*np.pi/6,np.pi,\n",
    "            -5*np.pi/6,-2*np.pi/3,-np.pi/2,-np.pi/3,-np.pi/6, 0]\n",
    "thetas = np.array(thetas)%(2*np.pi)\n",
    "\n",
    "thetas[-1] = 2*np.pi\n",
    "\n",
    "\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    print(d)\n",
    "    \n",
    "    mu_target = np.zeros((d,))\n",
    "    mu_target[0] = 1\n",
    "    \n",
    "    v = np.zeros((d,))\n",
    "    v[1] = 1\n",
    "\n",
    "    mus = []\n",
    "    for theta in thetas:\n",
    "        mus.append(np.zeros((d,)))\n",
    "        mus[-1][0] = np.cos(theta)\n",
    "        mus[-1][1] = np.sin(theta)\n",
    "        # mus.append([np.cos(theta), np.sin(theta), 0])    \n",
    "        \n",
    "    for k in range(len(mus)):\n",
    "        mu = np.array(mus[k])\n",
    "        \n",
    "        for j in range(100):\n",
    "            x0 = rand_von_mises_fisher(mu_target, kappa=10, N=500)\n",
    "            x1 = rand_von_mises_fisher(mu, kappa=10, N=500)\n",
    "            sw = sliced_wasserstein_sphere(torch.tensor(x0, dtype=torch.float, device=device), \n",
    "                                           torch.tensor(x1, dtype=torch.float, device=device), \n",
    "                                           1000, device, p=1)\n",
    "            L[i, k, j] = sw\n",
    "\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "    plt.plot(thetas, m, label=r\"$d=$\"+str(d))\n",
    "    plt.fill_between(thetas, m-s, m+s,alpha=0.5)\n",
    "    \n",
    "plt.ylabel(r\"$SSW_2^2$\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 252
    },
    "id": "52F4JjA3V0MG",
    "outputId": "fac9db93-02bf-4b6b-b2aa-1f08695602a5"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAQoAAADrCAYAAACRpNhaAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO2dd3xUVfr/32cmk94JJSEhjdCbdESqUgQBe1vrKoh91f0JqCsuq6xtdVVWsaxt1a8giIJ0lIiARIp0SEgljRDSezIz5/fHnWAIgUwyk8wknPfrNa+Ze+85z33ulGfOPec5nyOklCgUCsXF0DnaAYVC4fyoQKFQKBpFBQqFQtEoKlAoFIpGUYFCoVA0igoUCoWiUVSgUCgUjaICheI8hBCjhRDrhBDZQohSIUSyEOJFa44LITYIIf5Zz94PQoiaevumWOp2aJ2rUtiCi6MdUDgXQoipwHJgNnCtZfcAINya40Ah4FfHXj9gNKAXQnhJKcssh+YBH0kp81ruahT2QqjMTEVdhBBrgFIp5W3NPP4e4Cul/JNl+39AOvAw0EdKmSmEGArsBKKllOktcR0K+6JuPRT1yQUmCSEeF0L0bsbxsy0KIUQ4MAv4N1DEHy2Np4GvVJBoO6hAoajP48BbwL3AESFEmhDi3iYcL+CPgPBX4HMp5Wm0QOEvhIgGrgNeqa0ghNgihMgVQjzXYlelsAkVKBTnIKUskVL+Q0o5COgCrAU+EkKEWnMcS4tCCBEE3AW8btlfBPgDTwFrpZTH6pz2HuD/tfClKWxABQrFBbG0BFagfU88rTxegBYQHgO+l1KmWvYXAd3RgsLL9exk2N97hT1Rox6KswghFgB7gF+BcmAQ8CqwUUqZ0Nhxi5lCoAPwEDCujvkitFbDb1LKXa1wOQo7ogKFoi6ewJtAN8AMnAT+B7xj5XHQWhSewGYp5ZE6+4uAULRhVUUbQw2PKpwCIcQ9QKiU8sXGyipaHxUoFA5HCPExMAJwA45JKWc42CVFPVSgUCgUjaJGPRQKRaOoQKFQKBpFBQqFQtEoTjc8GhQUJCMiIqwqW1ZWhpeXl03ns9WGM/igbCgb9rKxd+/eM1LKjucdkFI61WPIkCHSWrZu3Wp12Zay4Qw+KBvKhr1sAHtkA79LdeuhUCgaRQUKhULRKCpQKBSKRlGBQqFQNIoKFAqFolGcbnhU0XYxmszYOiHAbDbj6upKQkICJpOp2Xb8/Pw4duxY4wUvMRvu7u6EhoZiMBiaVF8FCoXNVNaYWL0/i//tSoXKcvbXxHPb8HC6+Lk32VZGRgZBQUFERERgMBgQQjTLp5KSEnx8fJpVt73a8Pb2Ji8vj4yMDCIjI5tUXwUKRbMpqazhi11pLNudTmpeOQa9wE0neevHRD7Zkcro7kHcfXk4wyI6oNdZ94MvKysjJCQEV1fXFvb+0kMIQYcOHcjNzW1yXRUoFE3mdEklH25L5vv9WZwuqcLTVc/V/brwwNhosuP3srcqmI1HTrH+8Ck2HjlFry6+XD+4KzcNDcXPo/EAoNOprrOWorktNBUoFFaTnFvKu7FJbDp6iuIKIwGeBm4bHsacsVFEBnkDUJis57lJfXhqck82Hc3mq7h0fk8v5MW1x3gvNonxPTty7+hI+ob4NvtLq2h9rAoUltWh3gL0aKs7vVzv+Fy0BV5MQCkwR0p5VAgRARwD4i1Fd0kp59rHdUVrIKVkf3oh78Ymsf3EGSpqTAT7uXPnyHD+PDqSDt5uDdbzcNUza1AoMwd25UROKZ/9msqWYzms3JfJ9/uz6B/qx23DwpgxsCservrWvShFk2k0UAgh9MB/gElABrBbCLFaSnm0TrGvpJRLLeVnAm8AUy3HkqQm7a5oQ5jNkp8Tcnn/5yT2pBVgNEu6d/Tm9hHduGVYKF5u1vWaCyHo0cWHl67rzzPTerP6QBbLdqdzKKOI308W8sbmE0zu25l7R0ecbZUonA9rWhTDgUQpZTKAEOJrtNWfzgYKKWVxnfJeYPMomcJBVBvNrD6QySc7UjmaXYwA+of6c9/oCKb2C8bVpfn9B15uLtw2vBu3DgvjcGYRn+xMJfZ4Lp//qnWIDg0P4KnhbT9YSCnx8/Nj8+bN9OnTx9Hu2IVGpfCEEDcCU6WU91u27wRGSCkfqVfuYeBJwBWYKKU8Ybn1OAIkAMXAc1LKXxo4xxxgDkDnzp2HfP3111Y5X1paire3bV8sW204gw/2sCGlZHd6KZuz9JwolLjp4fJgHVMiXOnibf2tQVP9MJnNHDxtJDbDyKE8yfszgomOjiLIQ2dTH4bJZEKvt+2Wprk2UlJSGDx4MFlZWbi6utrkx6JFi1i+fDkFBQW4ubkxevRoFi9eTFhYWJPs1L2WxMREioqKGiw3YcKEvVLKoecdaGhKad0HcCNav0Tt9p3AkouUvx34zPLaDehgeT0EbbFa34udT00zb30bJpNZ3rx0pwyf94Ps87f18pEv98qjWUWt6ofJZJZxyXlyW9zv8kB6gcwoKG+WnVqKi4ttqm+LjVWrVsm+ffvaxY9jx47J9PR0KaWUZWVl8oknnpCjRo1qsp26fhw9evSC5bBhmnkmUDd8hVr2XYivgWstQahKWpa1l1LuBZKAHlacU9GKPLF8P3Ep+UwJ17HpiXG8c/tgegf7tqoPOp1geGQgQT5ueLoI8kqryCutalUfmsvy5cvp3r07Pj4+3HLLLcTFxXHZZZfZxXavXr3w89OWcpVSotPpiI+Pb6SW/bGmj2I3ECOEiEQLELeitRrOIoSIkVKesGxOB05Y9ncE8qWUJiFEFBADJNvLeYXt/GtTPN/vz2JCz47cGlFG1wAPR7tER09Bdpkgq6gSN4Oef22K52hWceMV69Dc24Y+Ib4snNHX6vKffvopzz//PN988w3Dhw9nyZIlPPXUU7z88jkDgzz00EN89dVXF7Qzf/585s+f3+Cx5cuX8+STT1JcXIyLiwtvvPGG1f7Zi0ZbFFJKI/AIsBFtqHO5lPKIEGKRZYQD4BEhxBEhxH60foq7LfvHAgct+1cAc6WU+Xa/CkWz+GZPOku2JtI72IcP7hziNHkNOiGIDPJCB6TllWE2O2ffeHl5OU899RTvvvsuI0aMQAjBnDlzqKmpOa9F8e6771JYWHjBx4WCBMDNN99MUVER2dnZvPDCC/Tv37+lL+08rMqjkFKuA9bV2/d8ndePX6DeSmClLQ4qWoYdibk8u+ownX3d+Wr2SAwuzpXL4GbQExboSVpeObePCCemkzc6K9PAwT7zIxrj559/xmg0Mn369LP7srOzAex261GXLl26MHv2bKKiojh58iSBgYF2P8eFULmylyAnTpcw94t9uLno+OK+EQR4Oue8Cl8PA5193agymkjNK3O0O+eRk5ND586dz2mJffnll0RGRuLv739O2blz5+Lt7X3Bx+LFi606p9FopKysjKysLLteS2OoQHGJcaa0ijs/+o3KGhPv3TGY7p2cO2+hk687fh4GSquMZBVWONqdc+jbty9JSUls3ryZmpoaVqxYwT//+c8GWxNLly6ltLT0go9nnnnmvDpms5klS5acncSVkZHBww8/TEREBL169Wrx66uLChSXEJXVRu74KI6ckkr+PrMvV8Scr8rujIQFeuJu0HOmtIq8MucZCRk2bBjPPvsst956K+Hh4SxbtowhQ4bY9bZj3bp1jBgxAi8vL0aMGIGnpydbtmzBxaV1p2mpSWGXCGazmfs/38vxUyU8MDaK20eEO9olq6nt3DyRU0p2YSVuLnq83Zzjq7to0SIWLVrUIrZ1Oh3r1q1rlf6WRn1x6NkVrcaCVYfZnniGKX27sGBab0e702QMeh0RHTwBOJlXTrWx+epXiqajAsUlwJKfTrBsdzoDQv1Ycpv9e+NbC083F0L83TGZzaTmlWNy0mHT9ogKFO2c737P5M0tJwgL8ODzPw/HYMOkLmcg0MuNQG83KmtMnMwvr502oGhh2va3RnFR4pLzWPDtIXzcXfjsz8Pxd9Jh0KYS4ueOt5sLJZU1ZBdVOtqdSwIVKNopSbmlPPjlPiSSd/80mKiOzj0M2hSEEIR38MTNRUdeaXWbmRPSllGBoh2SV1rFvZ/spqi8hkUz+3F5dJCjXbI7ep2O8A5e6HSQXVRJaWWNo11q16hA0c6orDFy76e7OZlfztzxUdw8rGm6BW0Jd4Oe0AAPJJBeUEGVGglpMawKFEKIqUKIeCFEohDivNkrQoi5QohDQoj9QojtQog+dY4tsNSLF0JMsafzinMxmSWPfLWfgxlFzBgYwl8n93S0Sy2On4crnXzcqDGZScsrx2Q2O9qldkmjgaKOZubVQB/gtrqBwMJXUsr+UtPGfBVNMxNLuVuBvmgamu9a7ClagBdWH2HLsRyGhgfwr5sGOM1s0Jamk48bfh4GKmtMpOdXYFYjIXbHmhbFWc1MKWU1mjDNrLoF5IU1M2cBX1sEbFKARIs9hZ3Zm13Nl3FpRAZ58dHdQ3F1stmgLYkQgtAATzwMeoorazjl4JEQKSW+vr7ExcU51A97Yk2g6IomYVdLhmXfOQghHhZCJKG1KB5rSl2FbWyLz+XDwzUEerny8d3D2s0waFPQ67SREINeGwmpNDquVZGSkkJ5eTkDBgyw2da8efMYPnw4vr6+hISEMHv2bPLz/5B0ueeeezAYDOfMRH333XdtPm997JYwL6X8D/AfIcTtwHP8IV7TKPXEdYmNjbWqXmlpqdVlW8qGo32oMUsW7ijHRSd5apAg7chu0hzgh71s+Pn5YTKZKCkpaVb9zh6QXSY5UyFx0xfbLNDbHD/i4uLo0aMHRqPRpmup9eH999+nX79+FBUVMWfOHO644w6WLVsGQE1NDbfffjtLliw5p179c9b1o7KysumfUUNCmvJcsdxRwMY62wuABRcprwOKGiqLppI16mLnU+K6TeMvX++T4fN+kC99sdGhftjLxtGjR20WpD1VVCEPpBfI9Lwym+xY68eyZctkdHS09Pb2ljfffLOcP3++vOOOO5pkw1o/1q9fL318fM5u33333fK+++5rko3miOu2qGYmsBr4SgjxBhCCppn5W9NCmeJCbEvIZfX+bAaG+nF5V6Oj3Wk51s+HU4esLt4JiU+1CTNgMujRN6VV0aU/XP1y4+UstIZmZl1+/PFHBg4ceM6+lStX8u233xIUFMSsWbNYuHChzcs/1KdFNTOllEeA5WiLBW0AHpZSqsFuO1BRbWLBt4dwdRG8eYtaiK0uAoFBB0ioMpqQLbQeVWtpZtaycuVKli5dyltvvXV236OPPsrx48c5c+YMq1at4ueff2b27Nl2v9YW1cy0HHsJeKm5Dioa5u9rjpBZWMFfruxOVEdvTjraoZakCf/wtVSWlFBQo6ewvJpgPw86+jS8RqottKZm5jfffMMDDzzA6tWrGTx48Nn9Q4YMOfu6b9++vPnmm4wfP55PP/0UNzf7XbPKzGyDxCXnsWJvBr26+PDoxBhHu+O0hPi546LTcbqkkhqT/ROxWksz84svvuCBBx5gzZo1TJgw4aI+6XTaT1raOZdEBYo2RlWNiXkrD6LTCf5100D0evURXggXvY7Ovm6YzLJF9DZbWjMT4O233+bZZ59l48aNjB49+rzjX3/9NYWFhQCcOHGCp556ipkzZ+Lu7m7Xa1XfsjbG4nXHSM0r5+6R4fTt6udod5yeQC9XPF31FFcY7T5xrDU0Mx9//HFKSkqYMGHCOS2QWpYuXUpUVBReXl5MnjyZkSNH8sknn9jt/LU4h/Cgwir2nSzg/35LJyrIi6entv95HPZACEFXfw8Sc8vILKwkprMLOjumtrekZiZotxAX08y0Ne/FWlSLoo1QbTTx9IqDmKXklRsHON2CPc6Mh6sLAZ4GqowmckuUdkVzUIGijfDaxgQST5dyy7AwhkW03gpR7YVgP3cMeh1nSqqUMG8zUIGiDXAoo5DPf00lNMCD56a3PQVtZ0Cv09HF1x2TlGQWKvm8pqIChZNjNJl5esVBjGbJS9f1x8NVdSs1lwAvV7wsWptFFdWOdqdNoQKFk/PvLSc4dqqEGQOCGdejbazs5cx09fdAJwTZhZVOu0q6M6IChRNzPLuYj3ek0MXXnX/M6udod9oF7gY9HbxcqTaZOVWsbkGsRQUKJ8VoMvP0yoNU1ph4fkYffDwMjnap3dDZ1x1XvY78smoqa1THpjWoQOGkvBebxMGMIib16cy0/sGOdqddodMJgv09MEtJZkGFWkTICuwlrvukEOKoEOKgEOJHIUR4nWMmi+jufiHEans6315JzCnl/W3JBHm7svi6/o52p13i52HAx91AWbWRgnIl9d8Y9hLX/R0YKqUcAKxAk8OrpUJKOcjymIniohhNZuZ9e5CyKiPzpvaig7f9Zz0qNLr6u6MXgpziSqXe3Qj2EtfdKqUst2zuAkLt6+alw0fbU9ibVsDYHh25cYh6G1sSVxc9QRap/yw75lbIdiiuKxq7PxNC3AhMlVLeb9m+ExghpXzkAuWXAKeklC9ato3AfsAIvCyl/K6BOnU1M4d8/fXXVjlfWlpqs5KPrTbs6UNZtZm/7ahAJ+Afoz3wMFjfheQM74U9bPj5+REZGYleb1uKuslkssqGlJJTZZIqk6Srtw6D/o95INbaqE9KSgqDBw8mKysLV1dXm65l7ty5LF++/BxtiUWLFp0VpzGZTCxcuJAvv/ySqqoqJk6cyFtvvUWHDh3OsVP3WhITEykqKmrwfBMmTNgrpRx63oGG9PHqPoAbgY/qbN8JLLlA2TvQWhRudfZ1tTxHAalA9MXOd6lqZhpNZnnr+ztl+Lwf5Cfbkx3mh6Nt2EMzU8qmaVUWV1TLg+mFMuFUsTSbzc2yUZdVq1bJvn372mSjlrvvvlveddddFzz+4osvypiYGJmUlCQLCwvl9ddfL6dOnXpeOVs1M635y8oE6q5LF2rZdw5CiKuAZ4GZUsqzM2+klJmW52QgFrCv9E874fOdqfyanM+IyEDuHBXhaHcuKXzcDfh6uFBRY+JMadMzNpcvX0737t3x8fHhlltuIS4uzu4KVxfigw8+YN68eURFReHn58err77Khg0bSEtrrhZ7w9hLXPcy4H20W5TTdfYHAOVSyiohRBAwmnM7OhVARY2Zt7edwNfdhZdv6I9ed2ms8GUtr/z2CsfzjzepTlNvG6SE8hojET4xvDT2OQxWCgK1hrju6tWrCQwMPE88t7CwkJMnT54jhxcdHY2vry8HDhwgPDy8QXvNwV7iuq8B3sA39YZBewN7hBAHgK1ofRRH7eZ9O8BslnwTX0VBeQ1zx0UTGWRf9WSFdQgBrnodUmK1GlZriOs++uij7Nmzp0Hx3Np1Ovz8zhUw8vf3p7i4+DxbtmAvcd2rLlBvJ6ASAS7Cyn0ZxGaYGRTmz+yxUY52xymZN3xek+tcTOzlQkgpSTxdSnGFkRIr1LBaQ1x3yJAhlJSUoNPpzhPPrb2++h2ThYWF+Pr62uX8tajMTAdSWF7N65vi8TLA4uv6Wd3cVbQMQghC/D1AQFZhZaMZm60lrluXuuK5/v7+dOvWjX379p09npycTHFxsV2WMzznvHa1pmgSL649Rk5xFTd0d6FPiNK/dAa83Fzw99DUsMpqLh4oWkNctzHx3Dlz5vDKK6+QkpJCcXEx8+bNY8qUKURERNj2RtRDBQoHsTslj9X7s4jo4MnYsEtvUWFnJtgi819QJS+asdka4rpLly5lwIABFxTPnT9/PjNmzGDYsGF07doVk8nEF198Ybfz16JUUBxAjcnMC2uOYpKSZ6f3QXf6mKNdUtTBRa+jk48bWUUVZBdVEhrgecGyLS2uGxsbe9H+Fr1ez+uvv87rr7/eYj6AalE4hI9+SeFIVjETe3ViUp/OjnZH0QAdvF1x1wsKy2uoUlPRVaBobbIKy3n/5yT8PQ38fWb9uXUKZ0EIQaC7wCwlWUVK4EYFilbm+e+PUFhRw4Pjognxv3CTVuF43FwEXm4ulFbWUFbVjleLtwIVKFqRTUdPsfV4Lv1CfPnzFZGOdkdhBdpwqWiRJQnbEipQtBIV1UYWrz2GXif4+6y+KmfiIpidSBvCw6DHz8NARY2JgvK2r9zdWG7IhVDf1lbijc0nSM0rZ9agEIaEqwV8LoSXlxc5OTlUV1c7jURdsJ9F4Kao8SQsZ0ZKSV5eXrMWMFbDo61A/KlivoxLo4uvO8+qBXwuSmhoKLt27UIIgdHY/H6ByspKm1f0rmujpKKGkkojRadc8HW3XujY3n7YasPd3Z3Q0KYLIlkVKIQQU4G3AD2aNsXL9Y4/CdyPJk6TC/xZSplmOXY38Jyl6ItSys+a7GUbxmyWPP/9ESqqTbwwsy/+niq56mLodDqqq6uJiYmxyU5sbKzNiU91bVTVmBj3WiwVNUZ+eXoCvh7WfY729sNRNlpUM1MIEQgsBEagSeottEw9v2T4Zm86cSn5jIgK5MbBStqureJm0PPEpBiKKoz8c13Tpry3B1paM3MKsFlKmS+lLAA2A1Pt47rzU1BezRubE/B01bNoZj90SmeiTXPLsG706uLDyt8zScsrc7Q7rYo1gaIrkF5nO8Oy70LcB6xvZt12xUuWSV93jAinR5emTXlWOCcLZ/SlxmRm4eojjnalVbGruK4Q4g40kZtxFlWrvwLu8g+h3b+hyfe/Xq9euxPXzSkz8fzOSsJ9BPOHe1y0NeEM16FsWG/jo4MV7Mwy8/fR7oT5XFxFy9mvpT62iOuOAjbW2V4ALGig3FVoClid6uy7DXi/zvb7wG0XO197ENetNprk1W9tk1EL1sqNR7Jb3Adlo3VtJOeWyJhn1snpb21zqB8tYQMbxHXPamYKIVzRNDPPWfGrjmbmTFlHMxNNPm+yECLA0ok52bKvXfPhtmSOWiZ9Te7TxdHuKOxMZJA3110WwuGsYr77PcPR7rQKLaqZKaXMB/6BFmx2A4ss+9otmYXlfLAtWU36auc8O70Pvu4uvLohHpPJeTJJW4oW1cy0HPsY+Li5DrYlpJQstEz6mj+1l5r01Y7x9TAwe2wU/9qUwLuxSTx6pW15H86OSuG2I5uO5LD1eC59Q3y5b4ya9NXeeWhcNF39Pfjgl2SKK9r3QscqUNiJ8ioji9cfQ68X/H2mmvR1KaDX65h/dS9KKo0sXte+VcrUt9lOvLE5gbS8cmYNDGFohJr0dakwY2AIA0L9WLkvo10nYalAYQeOnyrmq99O0sXXnWfUpK9LjkUz+2Iya/1T7RUVKOzAQsukrycnxxCgJn1dcgzqFsDEXp34OSGXPSntc1BPBQobOXqmps6kr7DGKyjaJf+Y1Q9XFx3Pt9PUbhUobKCsysiXx6rxUpO+LnmC/T24dVgYR7OLWfV7pqPdsTsqUNjAvzYlkFkGf1KTvhTA/Km98Pc08OqG45jMbVcJqyFUoGgmZ0qrWL7nJOE+8MSk9p1so7AODzcXHpnQneyiSt7dmuhod+yKChTN5JUNxymtMnFDjCserkpRUKFx3xWRhAd68v629pWEpQJFM8jIL2fNgSy6d/JmQCfr9RMV7R8hBH+b0ZvSKiMvrT3qaHfshgoUzWDxumNU1ph58ip1y6E4n6t6d2FIeADf/p5JfmX7mDBmVaAQQkwVQsQLIRKFEPMbOD5WCLFPCGG0CN3UPWayzCg9O6u0LXM8u5jNx3Lo39WPaQNCHO2Owkl58dp+mMySFfFVjnbFLthLXPckcA/wVQMmKqSUgyyPmQ0cb1MsXn8Mo1kyb2ovR7uicGJ6B/sypW8Xfs02czCj0NHu2Iy9xHVTpZQHgfbRzroAe9Py2XEij+ERgVwRE+RodxROzsKZfXDVwwvtIAnL3pqZnwI/SClX1NlnBPajrfnxspTyuwbqtQnNzHd/r2DfaTOLr3Cnk5feIT4oG23LxrIjJaxP1/HMcDd6BDZvdKytaGbeiLboT+32ncCSC5T9FLix3r6ulucoIBWIvtj5nFUzc+uxHBkx7wd5z8dxDvNB2Wh7NtZv/kn2+dt6eeXrsdJsNjvMj9bQzMwE6k5iCLXsswopZablORmIBWxb8sgBSCl5bVM8Br1OLQmoaBLuLoJ7R0eSmFvKyn1tV1/TLuK6F8IiqutmeR0EjAba3ODyDwezOZJVzOS+neneSaVqK5rGoxO7E+jlyusbE9psarddxHWFEMOEEBnATcD7Qoja3pvewB4hxAFgK1ofRZsKFGaz5M3NCXgY9DwzTbUmFE3HzaDnkQnRnCqu5MNfkh3tTrOwl7jubv5YRrBumZ1Afxt9dChf/XaS5DNl3Do8jBB/D0e7o2ij3HN5JB9vT2VpbBJ3jwpvc2n/KjPzItQYTbwbm4iPuwvzpvR0tDuKNoxOJ5h3dS8KK2p4Y3OCo91pMipQXIQPt6eQVVjJrcPCCPByc7Q7ijbOjIEh9Oziwxe7TpJf1rYyNlWguAAV1SY+3p5CoJcrj7fzNRsUrcfz1/ShosbES2vblmq3ChQX4O2fTnCmtJp7R0fg7a5miCrsw+juQQyLCGD1gSxO5rcd1W4VKBqgqLyGL3elEeznzgNjohztjqKd8fda1e7VbWcAUAWKBnht03GKK43MHReNq+Hiy9orFE2lT4gfE3p1Ijb+NAfayISxtjVG0wrkFFXw7b5MIjp4cseIbo52xzmREmrKoboMyvOh8CQUpUNJNh2zKyAuAXxDwC8UvDqBmxcYvECvvm61vDCjL9sScvn76qN8+9DljnanUdQnV49/rj9OebWJv1zVA/2ltiyglFB2RgsAFQVQmA5FGVCSDaU5UHZa219RCNWlUFUCxspzTPQFOFFnh84FXL3A1RvcfMAjADwCwSsIvDuDT5c/gopHABgujYWdwwI9mTWoKyv2ZhAbf5rxPTs52qWLogJFHVLPlLH+8Cl6dfFh1qBLQJTGbIK8JEhYD0k/MSA3B/acaTAAACB02g/e1Qs8A6FDzB8/eMuPfXdyIcM6VUPJKUtwydWCS2WhFoQK0sBY0bA/Lu7g6kUftwgoXwt9roXQoeDSPoemn5nWi3WHsnlp7THG9eiIEM673IMKFHV4ad0xqoxmnp7S06k/NJuoKoG0X+HYGqa/Ai4AAB9YSURBVMj4DfKTwVQNQoeLRxh4BkBAxB8BwLuL9m/v3017dvcHN+8L/njL8mPh8vHnH6h/u1KUDsWZUJwNpae0gFKWBxUF+BWegN/2wm8faAGo61DoOR16TNH8aycEernxpxHhfPhLMt/uy+SGIeclNzsNKlBYOJxZyE/HTzO4mz8Te3d2tDv2w2yG/BSI/wESf4Kcw1B+Rjvm5gvBAyHiCug5nX2JxYwfNx50LdCBK4TlFsQLvDtBpwsrhP364ybGB+RAwgbI3AfHVmsPV2/o3A+iJ0Lf6yAoRrPbhnlyUgzf7Enn9U3xXDsoxGlvd60KFEKIqcBbgB5Nm+LlesfHAv8GBgC3ynOFa+4GnrNsviil/MwejtubxeuOI6VkQXuY+FVdDqnb4fgPcPJXLVCYa0DotZZB1HjoMRUix4FPnXvjpNiWCRJNRe8Kg+/UHsYqyNwLR76HtO2QtQ/Sd8HPr0BgJISP1m5RIseAvu3lu3i4uvDAuChe2RDPR9tTeGBctKNdapBGA0UdzcxJQAawWwixut4s0FrNzL/WqxsILASGAhLYa6lbYB/37UNcSh67kvO4PDqIYRGBjnanWeiM5bDjbUj6EbIPQoVlsVx3PwgdBlHjoNc10LFX2xp9cHGD8Mu1B2idq0fXQOJmyPod9n2mPTyDoOsQLQD2vdaxPjeROWOi+PzXNJb+nMRdoyLwcHWCYF0Pa74xZzUzAYQQtZqZZwOFlDLVcqy+ZuYUYLOUMt9yfDMwFfg/mz23I/9cdxydEDzbFlsTCZvgl9cYnfE7yBptlCEgAnpeDT2nQcQY8PBztJf2wy8URj2oPYxVkLINjq6Gkzu04HFiI2yYT48OoyDS9Y8A48To9TqenNSD/7fiIG9sTnBKcSRrAkVXIL3OdgYwwkr7DdXtamXdViGpwMj+9DKm9OlM7xBfR7tjHWYzHFoOO9+GnCOgcyEn6ApCBk6A3jMgMKrN37tbhYsbxEzSHqCN4BxZBSc20SVjO3zyM4RcBmOegt7XONbXRrhxSChLf07iy7g0HhwfTaCXq6NdOocWFdcVQvwVcJdSvmjZ/huafP/r9eo5TFz31V2lpJQIXhnrga9b0zuSWlXEVUoCc3+lW/oq/EsSqNF7kdllEpndZlFQ4+oUYrLOYqMmP50eZzbQNWcLLqZK8n37crLb9RR2GGJ1EG3ta0koMLI4roppEXpu7uXuED9sEdcdBWyss70AWHCBsp9SR1wXuA14v872+8BtFztfa4rrrtybLsPn/SCfXPZ7s220ivBpVZmUPy2W8rUeUi70lXJxqJSrH5eyKLN1/WiLNgpOSrnqISlfCtbeuzf6SvnLm1LWVLWuH1Zy7ZLtsvsza2XqmVKH+IEN4rrN1sxEk8+bbNHODAAmW/Y5HLPZzFs/nsDHAPOvdr57QkDLN1g/H97sDT+/DNIEo5+AJw7DjH9rOQaKi+MfBtf+B/5yGEY+rGWUblmovadb/q7llTgRC2f0wWiWLFrjXBPGWlQzU2qdmP9ACza7gUWWfQ7n693ppOWVc3WkCx19nCzzrygDvnsQ3uwLce+Bqw9M+gc8cRQmvaCNZCiahmcgTF2svYcTngWdAba/AW/0gTVPQEmOoz0EYFC3AMbGdGRr/GkOpjvPhLEW1cy0HPsY+NgGH+2OlJL3YpPwdXdhUrgTdRrlHIOtL8KJTVq2ZMdecPljMPA20DlnIk6bw9UTxj0NVzwJez+BXe/B3o/hwFfQazqMfwaCujvUxYUz+jD5zW0s+uEoKx50jlGbNjSgbj+W70knvaCCOWOiMOgd/0/iUXoSPpupJUlJs5b3MPYpLSdA0TLoXWD4bBh2Pxz+Fnb8Gw6vhKPfQ9QErdXhIKI6ejOtfzCrD2Txc3yuw/yoyyX3NyWlZMnWRHzdXXjM0RJ3ufHw6XSG73kM0nZoGZP3bYb7N6sg0VoIAf1vgLm/wJ3fQehwLWnto4nEHH1LmwvjAP52TW/cDTpeWuccfRWXXKBYuTeD9PwKbh/RDW93BzWoyvPg2znw3uWQ9ivpwVfDQ7vgzm8hbJhjfFJA9AT483q4fytETyQ4Nxb+MxLW/AUqW7fTs6OPOzcPDSMhp5T9OTWteu6GuKQChZSSt39KxM/DwGMTHdCaMNbATy/CvwfCwWVaMtDsrST3fECb4KRwDroOgjtWsnvIm9rnsvcTeKu/liJvrp983HI8PaUnfh4GlsVXU11jarXzNsQlFShW/Z7Jyfxy7hwZjqdbK7cm9n8Fbw+Aba9pPfA3fQ73b4GQga3rh8JqKrwj4MEdMONtbaLa5r/BkqHarNZWwNvdwIPjo8kuh3//eKLxCi3IJRMopJS8teUEfh4GHpnQir3aab/C0jHacGd1OVy5EB7bD31ntZ4PCtsYcjc8fhAuf1RT+/rqFvhkOpw+3uKnnjMmkihfwSc7U8krddxaIJdMoPh+fyZp+eXcc3k47q0xO68gDb64CT6dBrnHYfDd8JdDMOZJNdTZFjG4w+QX4dF90GsGnNwJ718Bqx7UpAFbCJ1Ox+293aioNvH86iONV2ghLonhUSklb245gb+ngYfGt3BrorIEtjwP+78EY7XWQTbtX9BByf63C3yD4dYvIGMPrPurln8RvxZGParlZujt/yfUPUDP6OgOrD+UzdGsIvqEtH7C3SXx17bmQBZpeeX8eXQkbi0lv282w/Z/a51eez6GwGi463u4c1W7DRJSSiqNleRV5JFalMqB3AOkVaVxLO8YKUUpnCo7RUFlAWU1ZdSYa2rn+7QPQofCnFi47gNNeWvri/DOZZrATguw+Pr+6HWCBd8eahH7jdHuWxRSSv61OYEATwNzW0o96OhqraOrIFXTmbzm3zD03pY5l52pMFaQWJDIicITHCw6SNxvcZTXlFNutDxqyqk0VlJhrKDKVEWlqZIqUxXVpmqqTdVIGvjx/3Dh87noXHARLtpznYdBZzj78Kj0YGfcTnoG9KRfUD+i/KMw6JxUvWrgLdD3etj2ipbl+c1dsGsETHsdggfY7TThHby4eWgYX8adZO3BbKYPCLabbWto94Fi7cFs0vLKeXpKT1xd7NyAyo2n96GXIe9Xbd2K0Y9rKcAG98brthJSSnIrconPjyepKInUolQySzM5VXaKMxVnKK0pPbeC5XbboDPgqnfFTe+Gm94Ndxd3fFx96OTSCU+DJ54unngaPPEyeOFl8MLH4IO3qzfpJ9IJiQ7RAoqxiipzFZXGSqpN1VqAMVeffV1jqqHaXH322Wg2UmGsILsqm/3H9591SSd0BHkEEeIVQoRfBDEBMfTr0I/eHXrj4eLRiu/mBXAxwMTnYMRcWPc0HPsePpwAfa5FF3Cj3U7z3LTerD2UzYtrjzK1Xxf0utbTHGnXgUJKyeub4gnwdGX2WDs2/6XU8iF+fYeOJhP0uQ6ufgV8HCPKazQbOVVzirXJa0kuSiatOI2s0ixyynPIr8zHaDaeU97X1ZeOHh0Z2Gkgod6hRPhGEO0fTc7RHK4aexUeLh7om6mdGZsVy/he4226ntjYWIZePpSjeUc5kneEEwUnSC1OJb0knQO5B85pxfi7+RPiFUI3327E+MfQu0Nv+nfsb9P5m41XENz0sSZFuPYpOLyCYa6xELgILvuTzeY93Fx4clIPnv/+CO/FJvHIxNYbvbOXuK4b8DkwBMgDbpFSpgohItBmnMZbiu6SUs61j+uNs+5QNql55Sy4uhcGe6kbZx+Eb2drIxmB0eyO+gsjrrnLPratpLymnLhTcezI3MGB0wdILkqm2lwNWdpxg85AoHsgXTy7MLjTYLr5diPKL4oY/xgi/CJw1Tc8ES42IRZvV9sEUuyFt6s3w4OHMzx4+Dn7q0xVxOfHcyTvCPH58WdbSPEF8WxI/SO/IUAfQM9NPRnSeQjjQsfRK7BX6y3BEDxAS8M/9A1y7bPw/UNw4P/guvfBzzaBtztHhvPZzjTei03kzlHd8PNonUmN9hLXvQ8okFJ2F0LcCrwC3GI5liSlHGRnvxultjUR6OXKn6+ItN2gyaiNZsR9oM0PGP0XuPJ5Krb9YrvtRjhTfoZtmduIy47j8JnDZJRmYJZahmCwVzBjQsfQqbQT4wePp0dADzp4dGi365K46d0Y0HEAAzqee/9vMptIKUrhYO5Bjhcc50DKAQ7mHmRX9i7+s/8/eLh4EOMfw2WdL2NM1zEM7jy45fs9+t/EntN+jC38Bg6vgCXDYPx8LR+jmZ+PEIKXruvHrR/sYtGao/zr5tb5adlFXNey/YLl9QpgiXDwN3XD4VOknCnn2em9bW9NpO+GVXO0CUKd+8ENH0GnlhG7kVKSXJTMtoxt7D61m2P5xzhToa3DoRd6wn3DmRU9i1EhoxjddTS+rprOZ2xsLJd3dY4pyY5Ar9PTPaA73QO05nhsRSzjxo0jviCen9N/Zu/pvcTnx3PwzEE+O/IZBp2BCN8IBnYcyOUhlzO662g8W2A5Q7PeFW74EAbfpbUsNv8NDq2A6z+ETj2bZXNkVAfG9+jIqt8zeXB8NN07+djZ6/Oxi2amEOKwpUyGZTsJTYDXGzgCJADFwHNSyvP+gu2tmSmlZOHOCspqJK+M9cTlIp0+F9MSFGYjYanLiEj/FpPOjcToe8kJvuqcfwNb9QzN0kxCYQIZIoPkqmRSqlMoNWsdjB7CgwjXCKLco4hxj6GbWzcMouF/QWfRqnR2G0XGIhIqE0iqTCK5KplTxlNIJAJBiCGESNdIYtxj6O7RHV2Fzr5+SBOhJ1cRmbYMiSAl4jYyw2ZpSzU28VoKK83M+6WCXgE6nhjaeIeurZqZLd2ZmQ10k1LmCSGGAN8JIfpKKYvrFpJSfgB8ADB06FA5fvx4q4zHxsbSUNn1h7M5WbKP52f04arRF7/tuJANUrbBqse0Ze/CRqK74UN6+3ejfjvigvUvQnlNOZvSNrExdSP7cvZRbiwHtI65fp37MbTzUMaGjqVnYE90jXyJbPFD2YCSqhJ2Zu9kR9YODuUeYlfRLraXbQegs0tnRviPYGrEVEaGjGzWrcr5flwJOQ/Bt/cTk/wpMYW/wPXvaxokTbyWw8ajfLQ9BXOX3kzsdfGOdFvfU2sCRSYQVmc71LKvoTIZQggXwA/Is4h1VgFIKfdaWho9gD3N9rgRpJS8tiGeIG9X7hwZ3nQD1eXwwxNwaJmWSGOnnIjs0mzWJK/hp5M/cTz/OCZpwl3vzsCOA+le3Z27xt9FiI/SwGxtfNx8mBIxhSkRUwCoMdWw7/Q+tmVsY0fiDn5I/oHVSatx1bvSr0M/xoeNZ2rEVIK9bchj6NwH5u6AHW9pWqj/nQyX3QlXv9qkofW/TunJt/syWPj9Ecb16NSiw6XWBIqz4rpoAeFW4PZ6ZVYDdwO/AjcCP0kppRCiI5AvpTQJIaKAGKBFlUA2Hckh+UwZL8zs2/S+ifgNsPpRKDsN3a/Ssu68OjTLD7M0cyj3ED8k/8D2zO1klGYAEOQRxNWRVzMtctrZf6nY2FgVJJwEg97AiOARjAgewbCyYQwbPYyfTv7ElrQt7D29l32n9/HG3jcI9gpmZPBIpkRMYXjw8Ka3NoSAK/4C/W+EVQ9oq52d2AQzl0DMVVaZcDfomT+tN0+vOMinO1K4b0zLZQA3GiiklEYhRK24rh74uFZcF03aezXwX+B/QohEIB8tmACMBRYJIWoAMzC3JcV1pZS8svE4HX3c+NOIbtZXrCyG7x/WFsL1CISbPtUWwW0iFcYKdmTuYF3KOuKy4yiuLkYgiPaP5r5+93FN1DVE+0e32xGJ9oiXwYsZ0TOYET0DKSUJBQmsS17HjqwdfJ/0PasSV+Gmd6N/UH8mhE1gSsQUOns1IZ/GLxTuWQv7/w82zIcvb4A+s2DGO1at8HbTkFD++0sKb245wU3DwvB1b5mRHHuJ61aiKXDXr7cSWGmjj1az6cgpknPLePHafla3JgLP7Ia37oGKAuh3g6Y94GZ9B1aRsYivjn3FprRNHMw9SI25Bje9G4M6DmJyxGQmhU8iwD2gmVekcCaEEPQM7EnPwJ48wROU1ZQRmx7L5rTN7MnZw56cPby25zVCvEMYFTyKqZFTMUkrBWcG3aYtAbnmUU23M/lnLQ18wHk/q/N8evmG/lz37k5eXn+cxde1TLJZu8nM1FoT8XTyceOWYWGNVziTCOufZkDSj+ATrE3eip5o1XkSChJYl7KO2PRYkouSIRMC3QOZEjGF6ZHTGRE8AkMbXFlb0TS8DF5Mj5rO9KjpZ78XG1M3si1jG6sSV7HyxEo8hAfDfhzGNVHXMC503MWHYD384ObPIXELfP8IfHs/7Psc984Xz+q8rFsAU/p2Ztlv6cwZE0VEkJedr7QdBYrNR3NIzi1j8XWNtCZSd0LsYkjbDghSw64n4u6l2jqWF6DaVE1cdhzrUtaxI3MHBVUFCARRflFM85vGfePuI8Y/Rt1SXMLUbW08NvgxSqtL2ZaxjeV7l7P71G62ZWzDRefCwKCBTI2cyuSIyQS6BzZsrPtV8PgB2LAA9n7KiNRf4NTnMH4BRI5psMo/ZvVj6/GtPPvdIb68f6Tdr69dBAopJa9sOE5nXzduHtpAa8JshiPfwi//gtNHwcUd+t8M458h9WAqEQ0EifzKfLae3MqG1A38fvp3qkxVGHQGBnUcxJSIKVwZfiVBHkHExsbSI6BHK1yloi3h7erNtKhpeJ705IqxV7D71G7WJK9he8Z2Xop7icVxi+kR0IPJEZO5OvJqwnzqfW9d3OCaN+DyR0lf+Te6ZW6Gz67R1noZ8yT0u+kcAaROvu7cPyaSd2OT2H7iDFfEBNn1etpFoNh8NIek3DL+eX0/XOq2Jmoq4LcPYde7moSZR6C2svXox+ustpUK/JERuTF1Iz+e/JETBSeQSPzc/JjYbSJXR1zNqJBRuLs4z8xQRdvARefCqJBRjAoZhZSS4/nHWZO8hq0nt/LO7+/wzu/vEOodysRuE5keNZ3egb3/aJ0GRpIccz/d7nxX0zvZ+4mm4L75eRjxIAyfoy1qBDx2ZQzL9qTz3HeH+PGp8XYdLm3zgaK2NdHF142bhliictkZrfWw73NtrcnAKK2TctCftIVfLNSYa0ioTGDrjq38kvkLuRXaYivhvuHc3fdupkZOpU9gH3VLobAbQgh6d+hN7w69eXrY06SXpLMhZQOb0jbxv6P/4/OjnxPgHsC40HFcE3UNgzsP1iq6+8JVz8OEZzT1tB1vaWuobnsNLrsDxvwVd++OPDetN08sP8CXcWncNSrCbn63+UBR25p49Yb+uBQkwdbFcGwNmGsgbKQ2CSdqPPlVBSTl/s6xvGMcyTtCUmESacVpVJoqcTntQv+O/flzvz9zVfhVdPHq4ujLUlwihPmEMXvAbGYPmE1+ZT4/nfyJdSnr+CH5B75L/A4PFw9C9CFs2b6FPh360COgB937zsJ/8F2QHKslbMUthd0fQe8ZXDt+AR8G+/Laxniuvayr3YZL23SgkFLy6objTPVO5MbD/4G1OyjWG0iKGU9CzFiOVJ3hxPEPSPvtWUqq/1jAxcPFgzCfMCZ2m0hIaQizJ81ukQlBCkVTCHQP5MYeN3JjjxsprylnR9YONqVu4kjmETakbuD7pD9k9nxdfTUNjp4j6NN/GtFJ2+gev5aAI6v4usso5lRfyRsbu/LCrH528a3NBoryymKOJ33HTHMsVb6FPFjtTkJUd87IaqiOhyPxuOndCPUJ5fKQy+kV2Is+gX2I9o+mk2ens7cTsbGxKkgonA5PgyeTwicxKXwSsbHaTNhTZadIKkoiPj+e4/nHSSpMYn3KelaZKrVKYV3wFwa6V6bSP/g/eJz4H1u23MLgUbNt9qdNBor4hLXc+Ot8MACdwBV/uvqGMciicNQrsBfR/tEEewVbPalKoXBmhBAEewcT7B3MFV2vOLtfSklOeQ6JhYkkFiRyLP8YSQUn+L4ohQpphMyvYcXXPOU5DRjf7PO3yUARFjqSe2v82XG6N5PH3cP9o0Y0W7pNoWjLCCHo4tWFLl5dzgsgL23Yyf69XzKp8wG6dOxr03na5N+th0cg64tfJL3mWu4bOVIFCYWiHkII/nrVSNLE9SwvfglXDyuylS+CVYFCCDFVCBEvhEgUQsxv4LibEGKZ5XicRSuz9tgCy/54IcQUm7y1cDCjiMTTpczqbjg3b0KhUJzF3aDn+el9SMot4/fTti1y3KKamUKIPmgzSfsCIcAWIUQPKa2dKdMwA8P82fTEWE4eaTFZC4WiXXDNwGD8vQwYMw7bZMeav+OzmplSymqgVjOzLrOAzyyvVwBXWjQzZwFfSymrpJQpQKLFns3EdPZp1XUNFIq2iBCCMTEdbU4atCZQdAXS62xnWPY1WEZKaQSKgA5W1lUoFE5OS4vrvoC2lscXlv3/BdZLKVfUO4ddxXWbgq02nMEHZUPZsJeNC4nrIqW86AMYBWyss70AWFCvzEZglOW1C3AGEPXL1i13oceQIUOktWzdutXqsi1lwxl8UDaUDXvZQFOtO+93ac2tx1nNTCGEK1rn5Op6ZWo1M6GOZqZl/62WUZFINM3M36w4p0KhcCJaVDPTUm452mJBRuBhaeOIh0KhaH0a7aNobYQQuUCalcWD0G5zbMFWG87gg7KhbNjLRriUsmP9nU4XKJqCEGKPbKjjpRVtOIMPyoay0dI2VFqjQqFoFBUoFApFo7T1QPGBE9hwBh+UDWWjRW206T4KhULROrT1FoVCoWgFVKBQKBSN0iYDRWP6GAqFwr60uT4Kiz5GAnX0MYDb5Ln6GAqFwo60xRaFNfoYF8XSIkkSQnwhhEgRQvRuqhOOtiGEuFYI8aFFWWxyU89tsTFeCPGLEGKpEGJ8c2xY7EQLIXKFEKlCiP1CiHzLdflaWX+MxYePhBA7m+mDlxBijxDimmbW723xYYUQ4sFm2mj2+ymEiBJC/FcIsaKhbStthAkhtgohjgohjgghHm/iJVyQthgo7KFxkYomtDMfWCGlPNYMPxxqQ0r5nZRyNjAXTU2sOUFHAqWAO5DR3MAlpUwCtgN3SikHAQeBa6WUxVbW/0VKORf4AfismX7MA5ZD8wKwlPKYxYebgdGt/X5a/vjuu9C2lbaMwFNSyj7ASOBhoanM2UybVOG2AwOBA8Bgy3NbtvEcmlRhOVrQ+Rh43Mqg84uU8mchRGfgDeAfzbBRS1+gVm+tNxDfhLq13I4mq9i1KX4IISahTTysXRg2tSn169iZCTwI/K+ZNuz5ftanUX+klNlAtuV1iRDiGNBVCFEF7ALKgEKgG1AAXGZtMG+LLYpMoK6kcKhlX1MYAOwHAoGAZvrhUBtC4xU0IaB9NCPoSCnNlpcFgFtzbFh88QDcpZQFQogw4IzlttBqhBDdgCIpZUkz/BiP9g96OzC7udchpVwtpbwa+FNzbNjr/bwATbIlNIHry4A4W1t80DZbFGf1MdACxK1oXxCrkVI+a3n5aXOdcAIbjwJXAX5CiO5owfMDYALgY40BIcT1wBTAH1iC1kHcJBsW+gC1/3C967xuCvcBn1heD2iKH7XvoxDiHrQZkqOaUt9SdzxwPdoPfF1TfbDYaPb7KYToALwEXCaEWGCpV3fbuwm2vIGVwF/qBAObWnxtbtQDQAgxDfg3f+hjvNTE+g1etJTSagVSZ7HhDAgh7gIGSimfEkKMQWsiT5NSHnewa5ccQggDWl/PRinlG5Z9HkC8lLKbpcW3QUrZpBWB2mSgUCgU5yOEEGhBOl9K+Zc6+4cAi6WUUywjZHOklDc2xXZbvPWwGSGEDq2jyRdNpeuzRqo0ZKM38DiaIMiPUsr3mmHjWmC6xY//Sik3NaGuVRH+Yq0Te9iwB7b64SzvhS02rK3biL3RwJ3AISHEfsu+Z9C+o7W3HRXAYCFEr6a0+C7JFoUQ4jrgWiAPWCul/NEGWzrgcynlHTbYCABerzscplA4E5dkiwLoCeyUUr5vSWhpVqCoN5xmC7VDnM3xwR4tG5tbWPbAVj8c3cqzsx9O8ZnU0haHR+1BBtoQFkCzxX7rDac1mQaGOJvjwzmJQs2xgZbZGgrUoL03jsImP+zxXtRPZGumjfb0mQCXbqD4FpgihHgH2NYcA5Z03beFEO+jDac1h9ohzhuFEHObaaO2ZbPWBj9qW1hPorWQHIXNftjhvail2a08O/nhLJ8JcIneekgpy9HG7W2xEQvE2mjjbeBtW2xY7KwGVgsh1gJfNcNEBlCbIOXI5RRs9sPW98IycvAyNrTy7OEHzvOZAJdooGhPNJAo1By+Bd6x5EA0q4VlJ2zyw07vxTmJbFLKpQ7yw1k+E+ASHfVQKBRN41Lto1AoFE1ABQqFQtEoKlAoFIpGUYFCoVA0igoUCoWiUVSgUCgUjaIChUKhaBQVKBQKRaOoQKGwC0IIvRDiLaHJxB8SQkQ52ieF/VCBQmEvFgDJFom1t4GHHOyPwo6ouR4KmxFCeAHXSSmHWHaloGk6KNoJKlAo7MFVQFgd+bVAYIsD/VHYGXXrobAHg4DnpZSDLOtGbEJbr0TRTlCBQmEPAtBWKkMI4QJMBtY41COFXVGBQmEPEtBW6gJ4Ak2wOMWB/ijsjNKjUNiMRUV8PZqY7K9o60ZUONYrhT1RgUKhUDSKuvVQKBSNogKFQqFoFBUoFApFo6hAoVAoGkUFCoVC0SgqUCgUikZRgUKhUDTK/wfEdeLUjJhV3wAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(4,3))\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "    plt.plot(thetas*180/np.pi, m, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(thetas*180/np.pi, m-s, m+s,alpha=0.5)\n",
    "\n",
    "    plt.xlabel(r\"$\\theta$\") #, fontsize=13)\n",
    "    labels = [\"0\", r\"$\\frac{\\pi}{6}$\", r\"$\\frac{\\pi}{3}$\", r\"$\\frac{\\pi}{2}$\", r\"$\\frac{2\\pi}{3}$\", r\"$\\frac{5\\pi}{6}$\",\n",
    "            r\"$\\pi$\", r\"$\\frac{7\\pi}{6}$\", r\"$\\frac{4\\pi}{3}$\", r\"$\\frac{3\\pi}{2}$\", r\"$\\frac{5\\pi}{3}$\",\n",
    "            r\"$\\frac{11\\pi}{6}$\", r\"$2\\pi$\"]\n",
    "    plt.xticks(180*thetas/np.pi, labels, fontsize=10)\n",
    "\n",
    "# ax.set_xticklabels(label)\n",
    "# plt.ylabel(r\"$SSW_2^2$\", fontsize=13, rotation=0, labelpad=20)\n",
    "plt.title(r\"$SSW_1$\", fontsize=13)\n",
    "\n",
    "plt.grid(True)\n",
    "plt.legend(fontsize=13)\n",
    "plt.savefig(\"./SSW1_vMF_mus_ds.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "9CC4DBRMWEW3"
   },
   "source": [
    "###### $SW_2^2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 317
    },
    "id": "BeX5CQ6ZWEa1",
    "outputId": "5c6f36f3-7970-4459-ce76-adc49bddb37c"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n",
      "25\n",
      "50\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "kappa = 10    \n",
    "\n",
    "ds = [3, 25, 50]\n",
    "\n",
    "L = np.zeros((len(ds), len(mus), 100))\n",
    "\n",
    "thetas = [0,np.pi/6,np.pi/3,np.pi/2,2*np.pi/3,5*np.pi/6,np.pi,\n",
    "            -5*np.pi/6,-2*np.pi/3,-np.pi/2,-np.pi/3,-np.pi/6, 0]\n",
    "thetas = np.array(thetas)%(2*np.pi)\n",
    "\n",
    "thetas[-1] = 2*np.pi\n",
    "\n",
    "\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    print(d)\n",
    "    \n",
    "    mu_target = np.zeros((d,))\n",
    "    mu_target[0] = 1\n",
    "    \n",
    "    v = np.zeros((d,))\n",
    "    v[1] = 1\n",
    "\n",
    "    mus = []\n",
    "    for theta in thetas:\n",
    "        mus.append(np.zeros((d,)))\n",
    "        mus[-1][0] = np.cos(theta)\n",
    "        mus[-1][1] = np.sin(theta)\n",
    "        # mus.append([np.cos(theta), np.sin(theta), 0])    \n",
    "        \n",
    "    for k in range(len(mus)):\n",
    "        mu = np.array(mus[k])\n",
    "        \n",
    "        for j in range(100):\n",
    "            x0 = rand_von_mises_fisher(mu_target, kappa=10, N=500)\n",
    "            x1 = rand_von_mises_fisher(mu, kappa=10, N=500)\n",
    "            sw = sliced_wasserstein(torch.tensor(x0, dtype=torch.float, device=device), \n",
    "                                           torch.tensor(x1, dtype=torch.float, device=device), \n",
    "                                           1000, device, p=1)\n",
    "            L[i, k, j] = sw\n",
    "\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "    plt.plot(thetas, m, label=r\"$d=$\"+str(d))\n",
    "    plt.fill_between(thetas, m-s, m+s,alpha=0.5)\n",
    "    \n",
    "plt.ylabel(r\"$SW_2^2$\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 255
    },
    "id": "1GbwbDHBY6eC",
    "outputId": "7cc04cea-61fc-43c5-b3b3-a4dd92a59b08"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(4,3))\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "    plt.plot(thetas*180/np.pi, m, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(thetas*180/np.pi, m-s, m+s,alpha=0.5)\n",
    "\n",
    "    plt.xlabel(r\"$\\theta$\") #, fontsize=13)\n",
    "    labels = [\"0\", r\"$\\frac{\\pi}{6}$\", r\"$\\frac{\\pi}{3}$\", r\"$\\frac{\\pi}{2}$\", r\"$\\frac{2\\pi}{3}$\", r\"$\\frac{5\\pi}{6}$\",\n",
    "            r\"$\\pi$\", r\"$\\frac{7\\pi}{6}$\", r\"$\\frac{4\\pi}{3}$\", r\"$\\frac{3\\pi}{2}$\", r\"$\\frac{5\\pi}{3}$\",\n",
    "            r\"$\\frac{11\\pi}{6}$\", r\"$2\\pi$\"]\n",
    "    plt.xticks(180*thetas/np.pi, labels, fontsize=10)\n",
    "\n",
    "# ax.set_xticklabels(label)\n",
    "# plt.ylabel(r\"$SSW_2^2$\", fontsize=13, rotation=0, labelpad=20)\n",
    "plt.title(r\"$SW_2^2$\", fontsize=13)\n",
    "\n",
    "plt.grid(True)\n",
    "plt.legend(fontsize=13)\n",
    "plt.savefig(\"./SW2_vMF_mus_ds.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Gs7jrbYxtxH2"
   },
   "source": [
    "##### Influence Projections + $\\kappa$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "enYi3lTd3XAI"
   },
   "outputs": [],
   "source": [
    "d = 3\n",
    "\n",
    "x0 = torch.randn((500,d), device=device)\n",
    "x0 = F.normalize(x0, p=2, dim=-1)\n",
    "\n",
    "kappas = [1, 10, 20, 50, 100, 200]\n",
    "mus = np.ones((len(kappas),d))\n",
    "projs = [1,10,50,100,200,400,500,750,900,1000]\n",
    "\n",
    "L = np.zeros((len(kappas),len(projs),20))\n",
    "\n",
    "for i, k in enumerate(kappas):\n",
    "    mu = mus[i]\n",
    "    mu = mu/np.linalg.norm(mu)\n",
    "    x1 = rand_von_mises_fisher(mu,kappa=k,N=500)\n",
    "\n",
    "    for l, n_projs in enumerate(projs):\n",
    "        for j in range(20):\n",
    "            sw = sliced_wasserstein_sphere(x0, torch.tensor(x1, dtype=torch.float, device=device), n_projs, device)\n",
    "            L[i,l,j] = sw"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 304
    },
    "id": "oRhoCHOM3XAJ",
    "outputId": "1e94d891-5d40-4154-fb4b-4daab5de8c73"
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAATEAAAEfCAYAAAApw/EuAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nO29e5wdVZnv/X2qat/6lqQvCZAEEghXz8goOXIU1JxxFPS8ozOCB3BQ8dXBYbyfOc44o/jx4+Ac9TjeL8cMOihekGFmjuiojEftM7x4ASKiAhICBAgESEIS0vfeu573j1W1d+2d3d27u/fuvav7+ZKiVq21atWqVbt+/axVq54SVcUwDCOteO2ugGEYxmIwETMMI9WYiBmGkWpMxAzDSDUmYoZhpBoTMcMwUk3Q7gosB3bs2JH1PO8K3/dfr6qrAGl3nQyjAwiB3xSLxTeeddZZT7bqICZiTSAIgr/v6+s757jjjhvNZrMHREzDDCMMQ9m3b98Zjz/++NXAy1t1HOtONodzTzjhhMO5XG7aBMwwHJ7n6dDQ0GHgP7T0OK0sfAXhe55nrz4YRg3RfdFSnTERMwwj1ZiIGYaRakzEjKayffv2NWedddapPT09zwqC4Kx218eo5oILLtgUBMGzu7q6nhUvH/rQh4bi9GKxyJve9KYNa9asObO7u/tZ55133kl79+7t6AeAJmJGUxkYGChdfvnl+6666qqH210Xoz4XXHDBgbGxsTvi5d3vfve+OO0973nPMTfddNPqW2655Z6HH374VwAXXXTR5vbVdm5MxFYgt9xySyGTyTx7fHxcAN773veuO+2008646667cost+4ILLnj6TW9601NbtmyZWnxNVyatvD5zce211w69/e1vf/yMM86YGhgYKH3sYx/bc/PNN/ft3Lkz2+pjL5SONhPTzLtuuHPjzsePdC3FsU45pnfsf1545iON5v/5z3/evWXLlonp6Wm58MILN6sqt95662/7+vrCZL5LL730+G9961v9M5Xz1re+9fG//du/fXwxdW8Hj/31ezZO3nffklyb3Mknjx33tx9s+NpA66/P9773vTWrVq1as2bNmuJ555136CMf+chjq1atCvfv3+/v3bs3e/bZZ4/GeZ/xjGdM9vT0lG677bbCKaec0pF/mEzEViA7duzoWrVqVXHr1q2nPe95zztyzTXX1L3JvvrVrz4MWLdwiWnl9XnHO97x5Cc+8Yk9xx13XPGOO+7Iv/71r9986aWXnvDtb3/7wUOHDnkA/f39peQ+vb29pcOHD/sLPqEWYyLWIuZjGS01v/rVr7offfTR7JYtWybuueeeQrvrs9TM1zJaalp5fZ7//OePxeGtW7dO/N3f/d3DL3vZy04dHx/fvXr16hDgqaeeqhKsI0eO+KtWrSrVltUp2JjYCmNyclJ27txZ+NrXvnb/tdde++Add9zRc911162ql/fVr3718cmnWLXLu9/97mOWuv7LnaW+Pp7nJEBVGRwcLB177LFTt956a7mrfffdd2dHRkb8rVu3jjftJJuMWWIrjB07duRLpZKce+65Y729veEll1yy733ve9/6V73qVYd9v7rH8PWvf33e3ZViscjU1JRMTU0JwNjYmADk83mNbxhjZlp9fbZv377mla985dODg4OlX//617l3vetdG1/0ohcd7urqUoDXvOY1+z7xiU8ce/755x9Zu3Zt8c///M83nHvuuU+feuqpHTkeBmaJrTh+/vOfd2/atGmit7c3BLjqqqv27tmzJ/fpT396oBnlf+5znxvo7u5+9gUXXHByqVSiu7v72d3d3c++7777OvbpVifR6utz9dVXrz3ppJN+p1AoPOv8888/5ayzzhr5xje+8WCc/sEPfvDxl7zkJYee+9znnr5x48YzS6WSXH/99Q/OVma7Efva0eK58847d5955pn7210Pw+hE7rzzzsEzzzxzU6vKN0vMMIxUYyJmGEaqMREzDCPVmIgZhpFqTMQMw0g1JmKGYaQaEzHDMFKNiZhhGKnGRMwwjFRjImYYRqoxETOaylw+9tPow3050Yzr02nX0ETMaCpz+dhPow/35UQzrk+nXUMTsRVIO33sp9GH+1LT6den066hmfGt4n+/eSNP3r0kftxZe8YYf/jZjvex3yk+3H/4lXs2PvXoyJJcm/71PWMveu3pHeVjfyYauT6dcg2TmIitQNrlYz+tPtyXmk6+Pp14DU3EWsU8LKOlpl0+9jvFh/t8LaOlppOvT6dcwyQ2JrbCaKeP/bT6cF9KOv36dOI1NEtshdFuH/tp9OG+lKTh+nTaNTRLbIXRbh/7afThvpSk4fp02jU0H/tNwHzsG8bMmI99wzCMWTARMwwj1ZiIGYaRakzE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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(4,3))\n",
    "    \n",
    "for i,k in enumerate(kappas):\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "    \n",
    "    plt.plot(projs, m, label=r\"$\\kappa=$\"+str(k)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(projs, m-s, m+s,alpha=0.5)\n",
    "    plt.xlabel(\"Number of projections\", fontsize=13)\n",
    "#     plt.yscale(\"log\")\n",
    "    plt.xscale(\"log\")\n",
    "\n",
    "# plt.title(r\"$SSW_2^2$\", fontsize=13)\n",
    "plt.ylabel(r\"$SSW_2^2$\", fontsize=13, rotation=0, labelpad=20)\n",
    "plt.grid(True)\n",
    "plt.legend(fontsize=13, bbox_to_anchor=(0,1.02,1,0.2), loc=\"lower left\", ncol=2)\n",
    "plt.savefig(\"./SSW_projections.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "WRsU0BFnNO-n"
   },
   "source": [
    "##### Influence Projections + Dim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "LAOYZei6NOUc",
    "outputId": "20309e80-27e7-40da-bf5d-39c96a93a2bc",
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n",
      "1\n",
      "10\n",
      "50\n",
      "100\n",
      "200\n",
      "400\n",
      "500\n",
      "600\n",
      "700\n",
      "750\n",
      "100\n",
      "1\n",
      "10\n",
      "50\n",
      "100\n",
      "200\n",
      "400\n",
      "500\n",
      "600\n",
      "700\n",
      "750\n",
      "500\n",
      "1\n",
      "10\n",
      "50\n",
      "100\n",
      "200\n",
      "400\n",
      "500\n",
      "600\n",
      "700\n",
      "750\n",
      "1000\n",
      "1\n",
      "10\n",
      "50\n",
      "100\n",
      "200\n",
      "400\n",
      "500\n",
      "600\n",
      "700\n",
      "750\n",
      "2000\n",
      "1\n",
      "10\n",
      "50\n",
      "100\n",
      "200\n",
      "400\n",
      "500\n",
      "600\n",
      "700\n",
      "750\n"
     ]
    }
   ],
   "source": [
    "kappa = 10\n",
    "ds = [3, 100, 500, 1000, 2000]\n",
    "# ds = [2000]\n",
    "projs = [1,10,50,100,200,400,500,600,700,750]\n",
    "\n",
    "L = np.zeros((len(ds), len(projs), 20))\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    print(d)\n",
    "    x0 = torch.randn((500,d), device=device)\n",
    "    x0 = F.normalize(x0, p=2, dim=-1)\n",
    "    \n",
    "    mu = np.ones((d,))\n",
    "    mu = mu/np.linalg.norm(mu)\n",
    "    x1 = rand_von_mises_fisher(mu, kappa=kappa, N=500)\n",
    "    \n",
    "    for l, n_projs in enumerate(projs):\n",
    "        print(n_projs)\n",
    "        for j in range(20):\n",
    "            t0 = time.time()\n",
    "            sw = sliced_wasserstein_sphere(x0, torch.tensor(x1, dtype=torch.float, device=device), n_projs, device)\n",
    "            L[i,l,j] = sw"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 307
    },
    "id": "V45IELeINOYX",
    "outputId": "1e47a1f8-b01c-4b33-91c1-6b371736871c"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(4,3))\n",
    "# ds = [2000]\n",
    "for i, d in enumerate(ds):\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "\n",
    "    plt.plot(projs, m, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(projs, m-s, m+s,alpha=0.5)\n",
    "plt.xlabel(\"Number of projections\", fontsize=13)\n",
    "plt.ylabel(r\"$SSW_2^2$\", fontsize=13, rotation=0, labelpad=20)\n",
    "plt.yscale(\"log\")\n",
    "plt.xscale(\"log\")\n",
    "    \n",
    "plt.legend(fontsize=13, bbox_to_anchor=(0,1.02,1,0.2), loc=\"lower left\", ncol=2)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./SSW_d_projections_log.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "YHGIrVOIuFG7"
   },
   "source": [
    "##### Computational Time - Projections"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "Ibx2DKbyjVV9",
    "outputId": "21b146d3-efba-4826-9ba0-489e860420c6"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n",
      "100\n",
      "500\n",
      "1000\n"
     ]
    }
   ],
   "source": [
    "kappa = 10\n",
    "ds = [3, 100, 500, 1000]\n",
    "projs = [1,10,50,100,200,400,500,750,900,1000,1250,1500,1750,2000]\n",
    "\n",
    "L = np.zeros((len(ds), len(projs), 20))\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    print(d)\n",
    "    \n",
    "    mu = np.ones(( d,))\n",
    "    mu = mu/np.linalg.norm(mu)\n",
    "    x1 = rand_von_mises_fisher(mu, kappa=kappa, N=500)\n",
    "    \n",
    "    for l, n_projs in enumerate(projs):\n",
    "        # print(n_projs)\n",
    "        for j in range(20):\n",
    "            t0 = time.time()\n",
    "            try:\n",
    "                sw = sliced_wasserstein_sphere_unif(torch.tensor(x1, dtype=torch.float, device=device), n_projs, device)\n",
    "                L[i,l,j] = time.time()-t0\n",
    "            except:\n",
    "                L[i, l, j] = np.inf\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 263
    },
    "id": "n-4L9sIU8A41",
    "outputId": "c1bb464b-0348-4ab6-8628-fa81b2596731"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/usr/local/lib/python3.7/dist-packages/numpy/core/_methods.py:230: RuntimeWarning: invalid value encountered in subtract\n",
      "  x = asanyarray(arr - arrmean)\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6,3))\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "\n",
    "    plt.plot(projs, m, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(projs, m-s, m+s,alpha=0.5)\n",
    "    plt.xlabel(\"Number of projections\", fontsize=13)\n",
    "    plt.ylabel(\"Seconds\", fontsize=13)\n",
    "    # plt.yscale(\"log\")\n",
    "    # plt.xscale(\"log\")\n",
    "    \n",
    "plt.legend(fontsize=13)\n",
    "plt.grid(True)\n",
    "# plt.title(\"Computational Time\", fontsize=13)\n",
    "plt.savefig(\"./SW_time_projections2.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "Dd3MBKbrSJKX"
   },
   "source": [
    "##### Computational Time - Samples + Dim"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "odqOq9llqKlV",
    "outputId": "c3fe39f8-9d61-40fb-b4e0-208314d6302c"
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3\n",
      "100\n",
      "500\n",
      "1000\n"
     ]
    }
   ],
   "source": [
    "kappa = 10\n",
    "ds = [3, 100, 500, 1000]\n",
    "samples = [10,50,100,200,500,750,1000,2000,3000]\n",
    "n_projs = 200\n",
    "\n",
    "L = np.zeros((len(ds), len(samples), 20))\n",
    "L_w = np.zeros((len(ds), len(samples), 20))\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    print(d)\n",
    "    mu = np.ones((d,))\n",
    "    mu = mu/np.linalg.norm(mu)\n",
    "    \n",
    "    for k, n_samples in enumerate(samples):   \n",
    "        x1 = rand_von_mises_fisher(mu, kappa=kappa, N=n_samples)\n",
    "    \n",
    "        for j in range(20):\n",
    "            t0 = time.time()\n",
    "            sw = sliced_wasserstein_sphere_unif(torch.tensor(x1, dtype=torch.float, device=device), n_projs, device)\n",
    "            L[i,k,j] = time.time()-t0\n",
    "\n",
    "            # t1 = time.time()\n",
    "            # ip = x0@torch.tensor(x1, dtype=torch.float, device=device).T\n",
    "            # M = torch.arccos(torch.clamp(ip, min=-1+1e-5, max=1-1e-5))\n",
    "            # a = torch.ones(x0.shape[0], device=device) / x0.shape[0]\n",
    "            # b = torch.ones(x1.shape[0], device=device) / x1.shape[0]\n",
    "            # w = ot.emd2(a, b, M).item()\n",
    "            # L_w[i,k,j] = time.time()-t1\n",
    "\n",
    "            # print(L[i,k,j], L_w[i,k,j])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 228
    },
    "id": "g3CeFI9smzm8",
    "outputId": "40ac5fa8-849d-437d-d6b4-d8d8646762de"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6,3))\n",
    "\n",
    "for i, d in enumerate(ds):\n",
    "    m = np.mean(L[i], axis=-1)\n",
    "    s = np.std(L[i], axis=-1)\n",
    "\n",
    "    plt.plot(samples, m, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    plt.fill_between(samples, m-s, m+s,alpha=0.5)\n",
    "    plt.xlabel(\"Number of samples\", fontsize=13)\n",
    "    plt.ylabel(\"Computational Time\", fontsize=13)\n",
    "    # plt.yscale(\"log\")\n",
    "    # plt.xscale(\"log\")\n",
    "    \n",
    "plt.legend(fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./SW_time_samples.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "AiW_komnuNUg"
   },
   "source": [
    "#### KL"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "bctUGyopm3EQ"
   },
   "source": [
    "\\begin{equation}\n",
    "    \\mathrm{KL}\\big(\\mathrm{vMF}(\\mu,\\kappa)||\\mathrm{vMF}(\\cdot,0)\\big) = \\kappa \\frac{I_{d/2}(\\kappa)}{I_{d/2-1}(\\kappa)}+(\\frac{d}{2}-1)\\log \\kappa - \\frac{d}{2} \\log(2\\pi) - \\log I_{d/2-1}(\\kappa) + \\frac{d}{2}\\log \\pi + \\log 2 -\\log \\Gamma(\\frac{d}{2}).\n",
    "\\end{equation}\n",
    "\n",
    "[1] Davidson, Tim R., et al. \"Hyperspherical variational auto-encoders.\" arXiv preprint arXiv:1804.00891 (2018).\n",
    "\n",
    "[2] Xu, Jiacheng, and Greg Durrett. \"Spherical latent spaces for stable variational autoencoders.\" arXiv preprint arXiv:1808.10805 (2018)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "g1fJu3UEO7f4"
   },
   "outputs": [],
   "source": [
    "def KL(k, d):\n",
    "    cpt1 = k * iv(d/2, k)/iv(d/2-1, k)\n",
    "    cpt2 = (d/2-1)*np.log(k)\n",
    "    cpt3  = -np.log(2*np.pi)*d/2 - np.log(iv(d/2-1, k))\n",
    "    cpt4 = np.log(np.pi)*d/2 + np.log(2) - np.log(gamma(d/2))\n",
    "    return cpt1+cpt2+cpt3+cpt4"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 244
    },
    "id": "5-Yv3cY8m5Ot",
    "outputId": "dd9904c9-7100-4609-9c7d-bfe471997f84"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(4,3))\n",
    "\n",
    "for d in [3,25,50,100]:\n",
    "\n",
    "    x0 = torch.randn((500,d))\n",
    "    x0 = F.normalize(x0, p=2, dim=-1)\n",
    "\n",
    "    kappas = range(1,250) # [1,5,10,20,50,100,200,250]\n",
    "    mus = np.ones((len(kappas),d))\n",
    "\n",
    "    L = np.zeros((len(kappas)))\n",
    "\n",
    "    for k in range(len(kappas)):\n",
    "        L[k] = KL(kappas[k], d)\n",
    "            \n",
    "    plt.plot(kappas, L, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    \n",
    "plt.xlabel(r\"$\\kappa$\", fontsize=13)\n",
    "# plt.ylabel(\"KL\", rotation=0, labelpad=20, fontsize=13)\n",
    "# plt.legend(fontsize=13, bbox_to_anchor=(0,1.02,1,0.2), loc=\"upper left\", ncol=2)\n",
    "# plt.legend(fontsize=13, bbox_to_anchor=(0.5, -0.075), loc=\"lower center\", ncol=2)\n",
    "plt.legend(fontsize=13)\n",
    "# plt.axis(\"tight\")\n",
    "# plt.tight_layout()\n",
    "plt.title(\"KL\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./KL.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 244
    },
    "id": "dxN630E8ufo_",
    "outputId": "8f43d6c4-1069-4d80-f209-bd6999398727"
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(6,3))\n",
    "\n",
    "for d in [3,25,50,100]:\n",
    "\n",
    "    x0 = torch.randn((500,d))\n",
    "    x0 = F.normalize(x0, p=2, dim=-1)\n",
    "\n",
    "    kappas = range(1,250) # [1,5,10,20,50,100,200,250]\n",
    "    mus = np.ones((len(kappas),d))\n",
    "\n",
    "    L = np.zeros((len(kappas)))\n",
    "\n",
    "    for k in range(len(kappas)):\n",
    "        L[k] = KL(kappas[k], d)\n",
    "            \n",
    "    plt.plot(kappas, L, label=r\"$d=$\"+str(d)) # + r\" $\\mu=$[\"+str(mu[0])+\",\"+str(mu[1])+\",\"+str(mu[2])+\"]\")\n",
    "    \n",
    "plt.xlabel(r\"$\\kappa$\", fontsize=13)\n",
    "# plt.ylabel(\"KL\", rotation=0, labelpad=20, fontsize=13)\n",
    "# plt.legend(fontsize=13, bbox_to_anchor=(0,1.02,1,0.2), loc=\"upper left\", ncol=2)\n",
    "# plt.legend(fontsize=13, bbox_to_anchor=(0.5, -0.075), loc=\"lower center\", ncol=2)\n",
    "plt.legend(fontsize=13)\n",
    "# plt.axis(\"tight\")\n",
    "# plt.tight_layout()\n",
    "plt.title(\"KL\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./KL.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "ql8qlsEcKOIU"
   },
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "accelerator": "GPU",
  "colab": {
   "collapsed_sections": [],
   "name": "Sliced_Wasserstein_Sphere.ipynb",
   "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.7.9"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": true,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": true
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
