{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import torch\n",
    "import ot\n",
    "\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "sys.path.append(\"./lib\")\n",
    "from distributions import sampleWrappedNormal\n",
    "from utils_hyperbolic import *\n",
    "from hsw import hyper_sliced_wasserstein\n",
    "from hhsw import horo_hyper_sliced_wasserstein_lorentz, horo_hyper_sliced_wasserstein_poincare\n",
    "from sw import sliced_wasserstein"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "Bv1gQfUIpjgr"
   },
   "outputs": [],
   "source": [
    "mu0 = torch.tensor([1,0,0], dtype=torch.float64, device=device)\n",
    "Sigma0 = torch.eye(2, dtype=torch.float, device=device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "x0 = torch.from_numpy(np.array([1,0,0])).to(device)\n",
    "v = torch.from_numpy(np.array([0,1,1])/np.sqrt(2)).to(device)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Lorentz Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_try = 100\n",
    "n = 1000\n",
    "\n",
    "t = torch.linspace(-10, 10, 201, dtype=torch.float64).to(device)\n",
    "# mus = torch.cat([torch.sqrt(1+ys[:,None]**2), ys[:,None], torch.zeros((201,1), device=device)], axis=-1)\n",
    "mus = torch.cosh(t)[:,None] * x0 + torch.sinh(t)[:,None] * v/torch.linalg.norm(v)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([-1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000, -1.0000,\n",
       "        -1.0000], device='cuda:0', dtype=torch.float64)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "-mus[:,0]**2 + mus[:,1]**2 + mus[:,2]**2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[ 1.1013e+04, -7.7875e+03, -7.7875e+03],\n",
       "        [ 9.9652e+03, -7.0465e+03, -7.0465e+03],\n",
       "        [ 9.0169e+03, -6.3759e+03, -6.3759e+03],\n",
       "        [ 8.1588e+03, -5.7691e+03, -5.7691e+03],\n",
       "        [ 7.3824e+03, -5.2201e+03, -5.2201e+03],\n",
       "        [ 6.6799e+03, -4.7234e+03, -4.7234e+03],\n",
       "        [ 6.0442e+03, -4.2739e+03, -4.2739e+03],\n",
       "        [ 5.4690e+03, -3.8672e+03, -3.8672e+03],\n",
       "        [ 4.9486e+03, -3.4992e+03, -3.4992e+03],\n",
       "        [ 4.4776e+03, -3.1662e+03, -3.1662e+03],\n",
       "        [ 4.0515e+03, -2.8649e+03, -2.8649e+03],\n",
       "        [ 3.6660e+03, -2.5922e+03, -2.5922e+03],\n",
       "        [ 3.3171e+03, -2.3456e+03, -2.3456e+03],\n",
       "        [ 3.0015e+03, -2.1223e+03, -2.1223e+03],\n",
       "        [ 2.7158e+03, -1.9204e+03, -1.9204e+03],\n",
       "        [ 2.4574e+03, -1.7376e+03, -1.7376e+03],\n",
       "        [ 2.2235e+03, -1.5723e+03, -1.5723e+03],\n",
       "        [ 2.0119e+03, -1.4227e+03, -1.4227e+03],\n",
       "        [ 1.8205e+03, -1.2873e+03, -1.2873e+03],\n",
       "        [ 1.6472e+03, -1.1648e+03, -1.1648e+03],\n",
       "        [ 1.4905e+03, -1.0539e+03, -1.0539e+03],\n",
       "        [ 1.3486e+03, -9.5363e+02, -9.5363e+02],\n",
       "        [ 1.2203e+03, -8.6288e+02, -8.6288e+02],\n",
       "        [ 1.1042e+03, -7.8077e+02, -7.8077e+02],\n",
       "        [ 9.9910e+02, -7.0647e+02, -7.0647e+02],\n",
       "        [ 9.0402e+02, -6.3924e+02, -6.3924e+02],\n",
       "        [ 8.1799e+02, -5.7841e+02, -5.7841e+02],\n",
       "        [ 7.4015e+02, -5.2336e+02, -5.2336e+02],\n",
       "        [ 6.6972e+02, -4.7356e+02, -4.7356e+02],\n",
       "        [ 6.0598e+02, -4.2849e+02, -4.2849e+02],\n",
       "        [ 5.4832e+02, -3.8772e+02, -3.8772e+02],\n",
       "        [ 4.9614e+02, -3.5082e+02, -3.5082e+02],\n",
       "        [ 4.4892e+02, -3.1744e+02, -3.1744e+02],\n",
       "        [ 4.0620e+02, -2.8723e+02, -2.8723e+02],\n",
       "        [ 3.6755e+02, -2.5989e+02, -2.5989e+02],\n",
       "        [ 3.3257e+02, -2.3516e+02, -2.3516e+02],\n",
       "        [ 3.0092e+02, -2.1278e+02, -2.1278e+02],\n",
       "        [ 2.7229e+02, -1.9253e+02, -1.9253e+02],\n",
       "        [ 2.4638e+02, -1.7421e+02, -1.7421e+02],\n",
       "        [ 2.2293e+02, -1.5763e+02, -1.5763e+02],\n",
       "        [ 2.0172e+02, -1.4263e+02, -1.4263e+02],\n",
       "        [ 1.8252e+02, -1.2906e+02, -1.2906e+02],\n",
       "        [ 1.6515e+02, -1.1678e+02, -1.1678e+02],\n",
       "        [ 1.4944e+02, -1.0566e+02, -1.0566e+02],\n",
       "        [ 1.3522e+02, -9.5609e+01, -9.5609e+01],\n",
       "        [ 1.2235e+02, -8.6510e+01, -8.6510e+01],\n",
       "        [ 1.1071e+02, -7.8277e+01, -7.8277e+01],\n",
       "        [ 1.0017e+02, -7.0828e+01, -7.0828e+01],\n",
       "        [ 9.0639e+01, -6.4087e+01, -6.4087e+01],\n",
       "        [ 8.2014e+01, -5.7988e+01, -5.7988e+01],\n",
       "        [ 7.4210e+01, -5.2470e+01, -5.2470e+01],\n",
       "        [ 6.7149e+01, -4.7476e+01, -4.7476e+01],\n",
       "        [ 6.0759e+01, -4.2958e+01, -4.2958e+01],\n",
       "        [ 5.4978e+01, -3.8869e+01, -3.8869e+01],\n",
       "        [ 4.9747e+01, -3.5169e+01, -3.5169e+01],\n",
       "        [ 4.5014e+01, -3.1822e+01, -3.1822e+01],\n",
       "        [ 4.0732e+01, -2.8793e+01, -2.8793e+01],\n",
       "        [ 3.6857e+01, -2.6052e+01, -2.6052e+01],\n",
       "        [ 3.3351e+01, -2.3572e+01, -2.3572e+01],\n",
       "        [ 3.0178e+01, -2.1328e+01, -2.1328e+01],\n",
       "        [ 2.7308e+01, -1.9297e+01, -1.9297e+01],\n",
       "        [ 2.4711e+01, -1.7459e+01, -1.7459e+01],\n",
       "        [ 2.2362e+01, -1.5796e+01, -1.5796e+01],\n",
       "        [ 2.0236e+01, -1.4292e+01, -1.4292e+01],\n",
       "        [ 1.8313e+01, -1.2930e+01, -1.2930e+01],\n",
       "        [ 1.6573e+01, -1.1697e+01, -1.1697e+01],\n",
       "        [ 1.4999e+01, -1.0582e+01, -1.0582e+01],\n",
       "        [ 1.3575e+01, -9.5727e+00, -9.5727e+00],\n",
       "        [ 1.2287e+01, -8.6591e+00, -8.6591e+00],\n",
       "        [ 1.1122e+01, -7.8322e+00, -7.8322e+00],\n",
       "        [ 1.0068e+01, -7.0837e+00, -7.0837e+00],\n",
       "        [ 9.1146e+00, -6.4061e+00, -6.4061e+00],\n",
       "        [ 8.2527e+00, -5.7926e+00, -5.7926e+00],\n",
       "        [ 7.4735e+00, -5.2370e+00, -5.2370e+00],\n",
       "        [ 6.7690e+00, -4.7339e+00, -4.7339e+00],\n",
       "        [ 6.1323e+00, -4.2781e+00, -4.2781e+00],\n",
       "        [ 5.5569e+00, -3.8652e+00, -3.8652e+00],\n",
       "        [ 5.0372e+00, -3.4910e+00, -3.4910e+00],\n",
       "        [ 4.5679e+00, -3.1516e+00, -3.1516e+00],\n",
       "        [ 4.1443e+00, -2.8439e+00, -2.8439e+00],\n",
       "        [ 3.7622e+00, -2.5646e+00, -2.5646e+00],\n",
       "        [ 3.4177e+00, -2.3109e+00, -2.3109e+00],\n",
       "        [ 3.1075e+00, -2.0804e+00, -2.0804e+00],\n",
       "        [ 2.8283e+00, -1.8707e+00, -1.8707e+00],\n",
       "        [ 2.5775e+00, -1.6798e+00, -1.6798e+00],\n",
       "        [ 2.3524e+00, -1.5056e+00, -1.5056e+00],\n",
       "        [ 2.1509e+00, -1.3465e+00, -1.3465e+00],\n",
       "        [ 1.9709e+00, -1.2009e+00, -1.2009e+00],\n",
       "        [ 1.8107e+00, -1.0674e+00, -1.0674e+00],\n",
       "        [ 1.6685e+00, -9.4445e-01, -9.4445e-01],\n",
       "        [ 1.5431e+00, -8.3099e-01, -8.3099e-01],\n",
       "        [ 1.4331e+00, -7.2586e-01, -7.2586e-01],\n",
       "        [ 1.3374e+00, -6.2799e-01, -6.2799e-01],\n",
       "        [ 1.2552e+00, -5.3640e-01, -5.3640e-01],\n",
       "        [ 1.1855e+00, -4.5018e-01, -4.5018e-01],\n",
       "        [ 1.1276e+00, -3.6847e-01, -3.6847e-01],\n",
       "        [ 1.0811e+00, -2.9045e-01, -2.9045e-01],\n",
       "        [ 1.0453e+00, -2.1533e-01, -2.1533e-01],\n",
       "        [ 1.0201e+00, -1.4237e-01, -1.4237e-01],\n",
       "        [ 1.0050e+00, -7.0829e-02, -7.0829e-02],\n",
       "        [ 1.0000e+00,  0.0000e+00,  0.0000e+00],\n",
       "        [ 1.0050e+00,  7.0829e-02,  7.0829e-02],\n",
       "        [ 1.0201e+00,  1.4237e-01,  1.4237e-01],\n",
       "        [ 1.0453e+00,  2.1533e-01,  2.1533e-01],\n",
       "        [ 1.0811e+00,  2.9045e-01,  2.9045e-01],\n",
       "        [ 1.1276e+00,  3.6847e-01,  3.6847e-01],\n",
       "        [ 1.1855e+00,  4.5018e-01,  4.5018e-01],\n",
       "        [ 1.2552e+00,  5.3640e-01,  5.3640e-01],\n",
       "        [ 1.3374e+00,  6.2799e-01,  6.2799e-01],\n",
       "        [ 1.4331e+00,  7.2586e-01,  7.2586e-01],\n",
       "        [ 1.5431e+00,  8.3099e-01,  8.3099e-01],\n",
       "        [ 1.6685e+00,  9.4445e-01,  9.4445e-01],\n",
       "        [ 1.8107e+00,  1.0674e+00,  1.0674e+00],\n",
       "        [ 1.9709e+00,  1.2009e+00,  1.2009e+00],\n",
       "        [ 2.1509e+00,  1.3465e+00,  1.3465e+00],\n",
       "        [ 2.3524e+00,  1.5056e+00,  1.5056e+00],\n",
       "        [ 2.5775e+00,  1.6798e+00,  1.6798e+00],\n",
       "        [ 2.8283e+00,  1.8707e+00,  1.8707e+00],\n",
       "        [ 3.1075e+00,  2.0804e+00,  2.0804e+00],\n",
       "        [ 3.4177e+00,  2.3109e+00,  2.3109e+00],\n",
       "        [ 3.7622e+00,  2.5646e+00,  2.5646e+00],\n",
       "        [ 4.1443e+00,  2.8439e+00,  2.8439e+00],\n",
       "        [ 4.5679e+00,  3.1516e+00,  3.1516e+00],\n",
       "        [ 5.0372e+00,  3.4910e+00,  3.4910e+00],\n",
       "        [ 5.5569e+00,  3.8652e+00,  3.8652e+00],\n",
       "        [ 6.1323e+00,  4.2781e+00,  4.2781e+00],\n",
       "        [ 6.7690e+00,  4.7339e+00,  4.7339e+00],\n",
       "        [ 7.4735e+00,  5.2370e+00,  5.2370e+00],\n",
       "        [ 8.2527e+00,  5.7926e+00,  5.7926e+00],\n",
       "        [ 9.1146e+00,  6.4061e+00,  6.4061e+00],\n",
       "        [ 1.0068e+01,  7.0837e+00,  7.0837e+00],\n",
       "        [ 1.1122e+01,  7.8322e+00,  7.8322e+00],\n",
       "        [ 1.2287e+01,  8.6591e+00,  8.6591e+00],\n",
       "        [ 1.3575e+01,  9.5727e+00,  9.5727e+00],\n",
       "        [ 1.4999e+01,  1.0582e+01,  1.0582e+01],\n",
       "        [ 1.6573e+01,  1.1697e+01,  1.1697e+01],\n",
       "        [ 1.8313e+01,  1.2930e+01,  1.2930e+01],\n",
       "        [ 2.0236e+01,  1.4292e+01,  1.4292e+01],\n",
       "        [ 2.2362e+01,  1.5796e+01,  1.5796e+01],\n",
       "        [ 2.4711e+01,  1.7459e+01,  1.7459e+01],\n",
       "        [ 2.7308e+01,  1.9297e+01,  1.9297e+01],\n",
       "        [ 3.0178e+01,  2.1328e+01,  2.1328e+01],\n",
       "        [ 3.3351e+01,  2.3572e+01,  2.3572e+01],\n",
       "        [ 3.6857e+01,  2.6052e+01,  2.6052e+01],\n",
       "        [ 4.0732e+01,  2.8793e+01,  2.8793e+01],\n",
       "        [ 4.5014e+01,  3.1822e+01,  3.1822e+01],\n",
       "        [ 4.9747e+01,  3.5169e+01,  3.5169e+01],\n",
       "        [ 5.4978e+01,  3.8869e+01,  3.8869e+01],\n",
       "        [ 6.0759e+01,  4.2958e+01,  4.2958e+01],\n",
       "        [ 6.7149e+01,  4.7476e+01,  4.7476e+01],\n",
       "        [ 7.4210e+01,  5.2470e+01,  5.2470e+01],\n",
       "        [ 8.2014e+01,  5.7988e+01,  5.7988e+01],\n",
       "        [ 9.0639e+01,  6.4087e+01,  6.4087e+01],\n",
       "        [ 1.0017e+02,  7.0828e+01,  7.0828e+01],\n",
       "        [ 1.1071e+02,  7.8277e+01,  7.8277e+01],\n",
       "        [ 1.2235e+02,  8.6510e+01,  8.6510e+01],\n",
       "        [ 1.3522e+02,  9.5609e+01,  9.5609e+01],\n",
       "        [ 1.4944e+02,  1.0566e+02,  1.0566e+02],\n",
       "        [ 1.6515e+02,  1.1678e+02,  1.1678e+02],\n",
       "        [ 1.8252e+02,  1.2906e+02,  1.2906e+02],\n",
       "        [ 2.0172e+02,  1.4263e+02,  1.4263e+02],\n",
       "        [ 2.2293e+02,  1.5763e+02,  1.5763e+02],\n",
       "        [ 2.4638e+02,  1.7421e+02,  1.7421e+02],\n",
       "        [ 2.7229e+02,  1.9253e+02,  1.9253e+02],\n",
       "        [ 3.0092e+02,  2.1278e+02,  2.1278e+02],\n",
       "        [ 3.3257e+02,  2.3516e+02,  2.3516e+02],\n",
       "        [ 3.6755e+02,  2.5989e+02,  2.5989e+02],\n",
       "        [ 4.0620e+02,  2.8723e+02,  2.8723e+02],\n",
       "        [ 4.4892e+02,  3.1744e+02,  3.1744e+02],\n",
       "        [ 4.9614e+02,  3.5082e+02,  3.5082e+02],\n",
       "        [ 5.4832e+02,  3.8772e+02,  3.8772e+02],\n",
       "        [ 6.0598e+02,  4.2849e+02,  4.2849e+02],\n",
       "        [ 6.6972e+02,  4.7356e+02,  4.7356e+02],\n",
       "        [ 7.4015e+02,  5.2336e+02,  5.2336e+02],\n",
       "        [ 8.1799e+02,  5.7841e+02,  5.7841e+02],\n",
       "        [ 9.0402e+02,  6.3924e+02,  6.3924e+02],\n",
       "        [ 9.9910e+02,  7.0647e+02,  7.0647e+02],\n",
       "        [ 1.1042e+03,  7.8077e+02,  7.8077e+02],\n",
       "        [ 1.2203e+03,  8.6288e+02,  8.6288e+02],\n",
       "        [ 1.3486e+03,  9.5363e+02,  9.5363e+02],\n",
       "        [ 1.4905e+03,  1.0539e+03,  1.0539e+03],\n",
       "        [ 1.6472e+03,  1.1648e+03,  1.1648e+03],\n",
       "        [ 1.8205e+03,  1.2873e+03,  1.2873e+03],\n",
       "        [ 2.0119e+03,  1.4227e+03,  1.4227e+03],\n",
       "        [ 2.2235e+03,  1.5723e+03,  1.5723e+03],\n",
       "        [ 2.4574e+03,  1.7376e+03,  1.7376e+03],\n",
       "        [ 2.7158e+03,  1.9204e+03,  1.9204e+03],\n",
       "        [ 3.0015e+03,  2.1223e+03,  2.1223e+03],\n",
       "        [ 3.3171e+03,  2.3456e+03,  2.3456e+03],\n",
       "        [ 3.6660e+03,  2.5922e+03,  2.5922e+03],\n",
       "        [ 4.0515e+03,  2.8649e+03,  2.8649e+03],\n",
       "        [ 4.4776e+03,  3.1662e+03,  3.1662e+03],\n",
       "        [ 4.9486e+03,  3.4992e+03,  3.4992e+03],\n",
       "        [ 5.4690e+03,  3.8672e+03,  3.8672e+03],\n",
       "        [ 6.0442e+03,  4.2739e+03,  4.2739e+03],\n",
       "        [ 6.6799e+03,  4.7234e+03,  4.7234e+03],\n",
       "        [ 7.3824e+03,  5.2201e+03,  5.2201e+03],\n",
       "        [ 8.1588e+03,  5.7691e+03,  5.7691e+03],\n",
       "        [ 9.0169e+03,  6.3759e+03,  6.3759e+03],\n",
       "        [ 9.9652e+03,  7.0465e+03,  7.0465e+03],\n",
       "        [ 1.1013e+04,  7.7875e+03,  7.7875e+03]], device='cuda:0',\n",
       "       dtype=torch.float64)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mus"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### HSW"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "id": "DUJNeHBbpjgt"
   },
   "outputs": [],
   "source": [
    "L = np.zeros((len(mus), n_try))\n",
    "for i, mu in enumerate(mus):\n",
    "    for k in range(n_try):\n",
    "        x0 = sampleWrappedNormal(mu, Sigma0, n)\n",
    "        x1 = sampleWrappedNormal(mu0, Sigma0, n)\n",
    "        hsw = hyper_sliced_wasserstein(x0, x1, 1000, device, p=2)\n",
    "        L[i,k] = hsw.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 282
    },
    "id": "dLcPgn9gpjgt",
    "outputId": "cf7b0951-87a4-4eca-935d-6e984160b55b"
   },
   "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",
    "L_mean = np.mean(L, axis=-1)\n",
    "L_std = np.std(L, axis=-1)\n",
    "plt.plot(t.detach().cpu(), L_mean)\n",
    "plt.fill_between(t.detach().cpu(), L_mean-L_std, L_mean+L_std, alpha=0.5)\n",
    "plt.xlabel(r\"$t$\", fontsize=13)\n",
    "plt.ylabel(r\"$HSW_2^2$\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./HSW_WND.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savetxt(\"./HSW_WND.csv\", L, delimiter=\",\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### HHSW"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {
    "id": "DUJNeHBbpjgt"
   },
   "outputs": [],
   "source": [
    "L = np.zeros((len(mus), n_try))\n",
    "for i, mu in enumerate(mus):\n",
    "    for k in range(n_try):\n",
    "        x0 = sampleWrappedNormal(mu, Sigma0, n)\n",
    "        x1 = sampleWrappedNormal(mu0, Sigma0, n)\n",
    "        hsw = horo_hyper_sliced_wasserstein_lorentz(x0, x1, 1000, device, p=2)\n",
    "        L[i,k] = hsw.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 282
    },
    "id": "dLcPgn9gpjgt",
    "outputId": "cf7b0951-87a4-4eca-935d-6e984160b55b"
   },
   "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",
    "L_mean = np.mean(L, axis=-1)\n",
    "L_std = np.std(L, axis=-1)\n",
    "plt.plot(t.detach().cpu(), L_mean)\n",
    "plt.fill_between(t.detach().cpu(), L_mean-L_std, L_mean+L_std, alpha=0.5)\n",
    "plt.xlabel(r\"$t$\", fontsize=13)\n",
    "plt.ylabel(r\"$HHSW_2^2$\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./HHSW_WND_lorentz.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savetxt(\"./HHSW_WND_Lorentz.csv\", L, delimiter=\",\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### SW"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {
    "id": "DUJNeHBbpjgt"
   },
   "outputs": [],
   "source": [
    "L = np.zeros((len(mus), n_try))\n",
    "for i, mu in enumerate(mus):\n",
    "    for k in range(n_try):\n",
    "        x0 = sampleWrappedNormal(mu, Sigma0, n)\n",
    "        x1 = sampleWrappedNormal(mu0, Sigma0, n)\n",
    "        hsw = sliced_wasserstein(x0, x1, 1000, device, p=2)\n",
    "        L[i,k] = hsw.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 282
    },
    "id": "dLcPgn9gpjgt",
    "outputId": "cf7b0951-87a4-4eca-935d-6e984160b55b"
   },
   "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",
    "L_mean = np.mean(L, axis=-1)\n",
    "L_std = np.std(L, axis=-1)\n",
    "plt.plot(t.detach().cpu(), L_mean)\n",
    "plt.fill_between(t.detach().cpu(), L_mean-L_std, L_mean+L_std, alpha=0.5)\n",
    "plt.xlabel(r\"$t$\", fontsize=13)\n",
    "plt.ylabel(r\"$SW_2^2$\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./SW_WND_lorentz.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savetxt(\"./SW_WND_Lorentz.csv\", L, delimiter=\",\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### W"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "EMmrA_hCpjgu",
    "outputId": "899b14ab-29bf-40fb-e7a0-a75c1498a106",
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "n = 200\n",
    "\n",
    "L = np.zeros((len(mus), n_try))\n",
    "for i, mu in enumerate(mus):\n",
    "    for k in range(n_try):\n",
    "        x0 = sampleWrappedNormal(mu, Sigma0, n)\n",
    "        x1 = sampleWrappedNormal(mu0, Sigma0, n)\n",
    "\n",
    "        a = torch.ones((n,), device=device)/n\n",
    "        b = torch.ones((n,), device=device)/n\n",
    "        M = torch.arccosh(torch.clamp(-minkowski_ip2(x0, x1), min=1+1e-5))**2\n",
    "        w = ot.emd2(a, b, M)\n",
    "\n",
    "        L[i,k] = w.item()\n",
    "\n",
    "# print(np.mean(L, axis=-1), np.std(L, axis=-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 228
    },
    "id": "rHhZhbiTpjgu",
    "outputId": "2a979b21-a252-40e3-e084-0cf3d4816633"
   },
   "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",
    "L_mean = np.mean(L, axis=-1)\n",
    "L_std = np.std(L, axis=-1)\n",
    "plt.plot(t.detach().cpu(), L_mean)\n",
    "plt.fill_between(t.detach().cpu(), L_mean-L_std, L_mean+L_std, alpha=0.5)\n",
    "plt.xlabel(r\"$t$\", fontsize=13)\n",
    "plt.ylabel(r\"$W_2^2$\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./W_WND.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savetxt(\"./W_WND.csv\", L, delimiter=\",\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Poincaré Ball"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### HHSW"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "from hhsw import horo_hyper_sliced_wasserstein_lorentz, horo_hyper_sliced_wasserstein_poincare"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "L = np.zeros((len(mus), n_try))\n",
    "for i, mu in enumerate(mus):\n",
    "    for k in range(n_try):\n",
    "        x0 = lorentz_to_poincare(sampleWrappedNormal(mu, Sigma0, n))\n",
    "        x1 = lorentz_to_poincare(sampleWrappedNormal(mu0, Sigma0, n))\n",
    "        hsw = horo_hyper_sliced_wasserstein_poincare(x0, x1, 1000, device, p=2)\n",
    "        L[i,k] = hsw.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "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",
    "L_mean = np.mean(L, axis=-1)\n",
    "L_std = np.std(L, axis=-1)\n",
    "plt.plot(t.detach().cpu(), L_mean)\n",
    "plt.fill_between(t.detach().cpu(), L_mean-L_std, L_mean+L_std, alpha=0.5)\n",
    "plt.xlabel(r\"$t$\", fontsize=13)\n",
    "plt.ylabel(r\"$HHSW_2^2$\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./HHSW_WND_poincare.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savetxt(\"./HHSW_WND_poincare.csv\", L, delimiter=\",\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### SW"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "L = np.zeros((len(mus), n_try))\n",
    "for i, mu in enumerate(mus):\n",
    "    for k in range(n_try):\n",
    "        x0 = lorentz_to_poincare(sampleWrappedNormal(mu, Sigma0, n))\n",
    "        x1 = lorentz_to_poincare(sampleWrappedNormal(mu0, Sigma0, n))\n",
    "        hsw = sliced_wasserstein(x0, x1, 1000, device, p=2)\n",
    "        L[i,k] = hsw.item()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYwAAADTCAYAAACSliTcAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAAA/qklEQVR4nO3deXSb93ng+++DhQQIkARJcCfFRdQu2ZIlL7KdxHI2OUntpHUauzNpMzMZTzvX7Sx3eptMz/HNpNMz7czpbLeZ22baTO5kOlXSrE7ixEm8L7Etydp3UqTEfSeIhdh/9w+AMEiREkkRBEQ9n3N4iPd9fwAevgDx4P2tYoxBKaWUuhFLvgNQSil1a9CEoZRSakk0YSillFoSTRhKKaWWRBOGUkqpJdGEoZRSakls+Q4gV7xer2ltbV3RfYPBIC6Xa3UDWgUa1/IVamwa1/JoXMtzM3EdPXp0zBhTveBBY8y6/Nm7d69ZqZdeemnF980ljWv5CjU2jWt5NK7luZm4gCNmkc/VgqiSEpGDInJBRDpF5AsLHP9PInI8/XNRRKbyEKZSSt3W8l4lJSJW4CvAh4E+4LCIPGuMOTtbxhjzL7LK/y6wZ80DVUqp21whXGHcA3QaYy4bY6LAIeCx65R/EvjbNYlMKaVURiEkjEagN2u7L73vGiLSArQBL65BXEoppbKIyfPkgyLyOHDQGPP59PZngXuNMU8vUPYPgCZjzO8u8lhPAU8B1NbW7j106NCKYgoEArjd7hXdN5c0ruUr1Ng0ruXRuJbnZuI6cODAUWPMvgUPLtYavlY/wH7g+aztLwJfXKTsMeD+pTzuavaSCkZiZiYav+H9pmei5nT/lInEEit+7uXEVSgKNS5jCjc2jWt5Ci2uRCJpjFleXJeG/WYyGMlJPGf6fSYQjmW2c9VLKu+N3sBhYJOItAH9wBPAb8wvJCJbgQrgl7kOKBhJ8MK5YXY3eyh32nn2+AAWET51VyN2a6oWbyoURRCcRVYA3uga40TvFMbAW5cn+Mj2WporSzKPearPx9b6UuxWC5PBKG90jVFss/Lh7bVAKnGLCACBSBxXkRURIRJP8EbnGNvqy3L9Zyt120gmDUljsFnn1sofvTLJqb4pKt3F+EJREklDXbkDm8XC7g0evO5iQtE4z50a4lfurJ9z30TSEE8mKbZZM/tmogmKbBYSScPLF0aochfxqT1NC8bkm4lxZsBHsc3CHU2ezGeNPxzj0kiAIquF7fVlHOudpGcsxAMdXmKJJKf6fVwY8uMqtnJfexUtVbkbF5L3hGGMiYvI08DzgBX4mjHmjIh8mVSmezZd9AngUDoD5lTSGE72+TjdP02lu4gxfwSAbx7uZXNtKZOhKOcGp5mNRASyo5qeifHdd/u5u62C3c0eBn1hXjg/zFgwwj2tlXz3WD/TMzEA2rwlBCMJ3u4eZ1ejhxF/mMujQYpsFoptFmIJQziW4PJokHaTevPMRBPEkoaBqRmaKpzUlzsBiCeSdI8F2VRbmollJprANxOjrtyBMYZwLJlJcrFEMvOmVGq9SiQNPeNBpmdibKotxV1s4/XOMU71+9heX8b7N1djEXjt0hhHr0wCMBmKZe4/ezsST/LxO+o53T9N70SIbx/toyqWoHPEz/FeHwNTM1gtws7GcrbXl2G1CN871o/dKlS7i/GH4/jDcV46P8JYIEIgEqfMYWdvSwVTMzFevzRKLJH6IDnSM8nuZg8GONw9QTyZ2v9m1xjBSAKAq+9cnfN3pr7ojtBY4aQmR+cy7wkDwBjzHPDcvH3PzNv+0lrGBKnEMZssAEb9EUaztmctlMKSxvD25QkOd09itaTKnOid4spYMJMsAH5yaijzZnjr8nhmfzSeJBpPZrb94Thj4Qh/9Vr3nOexWYT7O6oIRRNcGPLjD8e5oynEw1triCUM3z/ez1Qoxqf3NXGkZ4KrEyEO7qjnzICPaCLJY7sbmQhGeevyOB/dUYfVIis+X0qttclglLOD0zzQ4QXg7MA0J/umaK4s4Y6mcs4P+TnRO4U/HAdSH8Q7G8szieF47xQTwSg2q3B5NHjd57o04mc8UMmpfh8AI9MR7OE4PzwxmCmTSBrevTLJu1cmsYiQTH84jAeimTLHe6cyt6dCMa5OhK55rlA0wZtd49fsn00W+VIQCWM9SxpDMv0aGzP3mwuQSRYrFU8aXr04Nmff7NWR3SZEYqmk87/fvkoi/VzfebcvU/bY1UlO9/sYC0SJJw0VJXamQjHcDhtVriJaqlyUO+3EEkne7BrnA5sXnjFAqbU2FYrynXf78IfjGAPjwUjmQ3/QF+ad7olr7hOIxOd8MQMW/MBeiDHw41ODc77wXU8y95Uha04TxjqVNIZI7L03bGKRxPTyhdHM7a6RwDXHSx02fuPeDZzo9XHs6iQ7Gsrwuos52TfF2YFpbVtRa843E+Nw9wRnB6cz7+vDPdcmh1zIvlK4HWnCmGe2N8BK7hdNzG3wWg/84Tg/OD7AeCCSbtAfp9Rh5930Jf2gL8wWk9/LZLU+JZOG431TFFkthGMJjl6ZYNCXauNb7AtQIRvyhXHYLXhKihYtE40nEWHBtsXsjjHz79M9FqTKXYTXXbyqMc+nCWOeN7vG+bfvxGitHWdzrZsim4Wfnxum2GrlQ9trKLZZMcYwPB0hnkzitFuxWISfnBpiNBCh2GZhS10pu5s8eErsGAPT4RiBSJyaUgcAr10aZSwQxVVs5aM76piJJugcDbCpxk2pw04yaRgPRglG4vgjcfomQtR7nDR4r/9PkjSGsUCEanfxgm+slRryhTO3Lw1fexUSiMT56ekhDmytXncJU62dQd8M1e7iTM+lU/0+XklfATeG45ybV/V6M4wxTASjBCJxmitKsFiEUDTORDDKRDCKPxyntsxBSZGV4ekwRTYLjR4nnpIipkJReidmqC0rps7+3v/kkC/MqD/CjsYyLPP+/yZDUb79bh9WER7eWpP5rNjVWI7DbiWeSHL0yiTvXp1CBN6/qZpt9aWICOOBCC+cHyEYibN/YxXjgSjRRJK7NlRwacTPkZ5JIun2zqYKJ3c2eXiwPEkuaMKYx2YRPMWpS9x3eiawCFgtQiJp+Nt3IrR5XfRPzjAamNv4XWyzcG9bJVMzMU73+zjZ58NhsxBNJJn9MlTmsOGwWxkNRGj0OOkaDfLS+RGGpyNMhKK8fmkMh91KNJGc8w2q2Gbh4kiAGZ/glyHGg1HCsQSNFU42VJZQWmynbyrE2YFppsNx9rdXcU9bJcmk4fywn1g8yZ3NHo5emaRzJMAHt9VQ6rCRSBpKilbnLXBucJqu0QBb60rZWO2mweOkyKY9sNTSGGN4/vQQdpuFh7fWUFFSdE1bw0rFE0nODfrpHA1QUWJnV2M5z58dznRgafO68LqLONIzyfW+khVZLfz9+zbwk9NDjKTv+x0LVLpTE1UMTae+WF2dDPH+TV4i6W/+JUVWzg36sVkEV5GNn54ZwiKQNKnPmZ2N5fRPzjDij7Cx2sVMNMHPzw1zcdhPhauIk31TFNkslNhtPH9mGAEsIpzsSzW+t1aVsGdDBUO+MOeHpvnxqUFsG+08uSpnby5NGPPc217F7+4u4kS8gc6RAGOBCHe1VBCKJHj10iin+324i218aFsNZQ47/kgcXyjG9oYyyp12AB7YWEX3WJBRfwSH3YqnxE6R1cKbXeOMB6J8fFc9G6vdvHZplHevTmEROLijjolQlFA0TpHVQk2pgzJnKsF4nHZeujDKO/0+HPYgtWUOyhx2Lo8GOTfoz8Te4HFQ5rTzdvc4RTYLp/p8TIRSda7jwSin0707/vadqxhAgLs2VOC0W5mJJdjVWM5EKMrgVJgGj4PGCic2y3sf+otdEs+KxpOc7EslSxGoLXPwqT2NOOx61aGur2c8lOkQcuidXpxFVmaiN67q7JsMMeALs7vJg28mxvmhaZJJSGKwWyw0Vzp5uztVlVXutHN1IsSJPh9FVgsHtlQTSxhe7xyjeyzItrpSttSVUukqoqTIxsDUDJF4krpyB4FwnG+/28d33u3HNxPj/Zu8lBTZmJ4YpjciJBKG/e1VWATe6Bqnc4H2wA9uraGjxk3nSIA2r4tQNMGRKxMcv5pKCL9yRz3t1W5Mulv/G11jXJ0Isb2hjPs3VlFss3JlIojXXYwxqSuwJo+TVm9q3MWGyhLuaavE7bBRHepZ1ddnliaMRbiKbdzZ7MlsV5TAk/dsyLRvXO+Ds9Rh544mzzX727wuwrEkbkfqtO/fWEUgEqe1ysWWutJrymc7sKWaX6kP4C9ry1zuJpKGyVCU6XCM2lIHrmIbM9EE33jrCq9cHKWixM7HdtVxdmCaU/0+yp12Prm7geO9UxTbrPjDMY6k2yJEyNyeVWyzsLWulAc6vFwaDvBW9zi/uqfxunWws4xJXaJ/71g/97VXkUgaOmoKbwoFlR/T4RgXh/yMBSLsavJwIqurKXDDZBFPJNPfwlMfzCd6p5iJJRDAZrVgAWIJw9Grk9gswiM769hU46Z/aoZTfT7uba+i0pV6H1e5i0gkDRur574/swfeuott7Gup4O3uCWrLitnd7EFEaPSM0e+YOxCvweNkIhhFBFqrXPgjcaaCUbbUpaqYdjaWA6nPmEd21vNARwyrCK7i1OeCiHBns4dNtW7iSUOZw5557HbvezE+mO5KPF+5044nkZure00Yy3QzbQM2qwV3VmOWzWLhkZ3117nH3Of1FAvBrOe3WgSvu3hOQ5ezyMpjuxuYDEXZXFOKxSJsqCzh9Utj7Goqx1NSxENb3hvWs6+1kiKrBYPhdP80ZU4bHTVuBqbCXBj2c7LPx6AvzFggQtLAOz0TvK+jmnOD05QUW2muKOF6hnxhvn+sH4CDO+u0V5XiSM8Eb3aNZ6pds6+SrycSS3Csdwq3w0bPWJCu0SD3tlXS6HHyRtcY7V4XD3R4M1e00XiSKxNBqlzFmeTQVFFC07z3bOsSR0bva6kgEk+yo6Hsup8DDR4nDR5nZttVbKOuzLFo+eyEkG21qotXU+FFpG5abZmD2qw3aLHNyge31S5YdvYfCVJXPLPavK7UT5WL588OUeaw0+hxcm5wmiFfOFN9YLcKH2kWNrQkb9hm8cK5YYKROI1Zo9PV7SUaT/JOz8SSejmdHZzm8miApooSLkWSvDZ8NTMAD+D9m7zs2VABwBOVG665f5HNwqaa61+5L4fNarntxyFpwlDX9V6dbupb28VhP9PhOI/tbqDEbuWXl8f5cU8I29XL1HscVJYUsb2+jJoFvlHFEobXLqV6ujRXlvDhbbWUlyz87UqtT+eHpjODSefLnqpmYGqGF84NY7UIXenBeFUuG5/Z14zBMBNN0F69/qo4Z2daKNRuw5owFmCRa+eHupGmCifNlSUc6ZnIzAcDsKnWjcNmzUwnALCrsZyEMXSOBDLTf2yqdTMwNZMZ+m+1CJWuIpx2K5F4khF/eM7z2a0y53kgdWVR6rAt2OA2a7l/F0B16XtVXo/e2UCRzZK5gnn0zgYSo928NuFmaDrMmYFpTvT5aKkq4e7WVHXBQnonQnz/eD+fubtZG8VvE8mkuaatYtbA1AzfebePKlcx1aXFdI8FKXXYefLuZiLxJK2JXibcLasaj9UibK4t5fxQal647Kk8lnr/bBYRypw2pkILjwQvd9pp8DgIx1JdYrvHg5nxTABedxEHd9YTiSf44YlBwrH32nG21pXSUePmpQsjc6YHKSmy8kCHF0+JnZloghF/JPWZsvhHwE3RhLEAV7GNz+9vZ2BqhkAkTlOFk6lQjMM9E8xEE9SWOdjVWI6nxI4/HKd/aoZ9LRXYrBZ2NpbTORJgJppgY40rM/aiwlXE9EyMNq8r06thS22Q7x/vp83r4hN3NJBMGs4OTnNlPMT9G6uoyKouGvTN8M6bV/jgthraq93YLMKzxwcYC0a4s8nDjoYyPCVFxBNJvv5mD/5wnFKHjZIiG+OBCPGkwVNi5xN3NPDS+RH6p2ZWdG6yGwIh1bbSUibYalLtIpF4gpN9Po5dneLbR/vY2VjGBzZXYxW5pt53Ihjlu++mJmfb3lDGjobyFcWkCtuFIT8vnh+Z8wGYLZE0vHh+BGeRFRHoHgvidRfx/s3VFNutFNutOMM3N67IZhH2bKggEIlzbnCa2jIHB7ZWU1/upKnCyXgwyr1tlRy9Mok/HGdvSwWvXBxlKhTl4a01ROJJjvRMMBZINWbva6lkX2sFb73Rz727Gnmne4J9rZVUuYv4m7euXvO3WkQ4uLNuTtvGhqoSqlxFHO6ZoK7MwYe212ausJ68p5kfnhxkMhjlzmYP79/kRURor3YjwFggwi8vj/Ngh5eqrDbM2YlHXx46Sy5owliEu9jG5qxZX2tKHXO2Z3lKiq7pTbE7q3fVrL0tFdfsa/W6uLu1MtNrwpKe6XJ2O1t9uZNy59zeV796VyPxpJnzDd1mtbC3pYKjVyZ58p4NuIptnB+a5ienhti/sYrq0mJ+/e5mfDMxpmdilJfYebNznHOD0wBsqy/jrg0ezgxMc7rft+y5roptVu5urWR3s4e3uyc4emWScwN+ELi3rZJ9LRVzEsdwuu/6TCyhCWMd6p0I8dypwQWPjQUivHZpjHAswXgwmulWulIWEarcRYwFInjdxTR6nBzvTXVZ/fTepkw16fs2eTM9koA5/28PZPU8+tU9jUQTycz/V4PHyTcPX+Xu1spM2wlAS5VrzpTiH9tVx/B0hDKnjSFfmOlwnMZ5DeHZz71QI7qnpIgn7m4mHEtQmtUoPntVU1Pm4LHdCy5MmlMFkTBE5CDwX0hNb/5Xxpg/WaDMrwNfAgxwwhhzzZoZt6IHFukatxQ2q4WFBlbvaixnQ2VJ5p9ia10ZM9EEW7ISXrnTnhk3cnBnHXe1eLBbLJmrmpoyB3tbK3jt4hgXh1ODjqrcxZkP+BuxWy082OGlyePk6mSIqVCMN7vG8YfjPLSl+pqRsOOBKD1jwczVl1ofji1QBRVLJOmfnOH5s0MIQrnTzu5mz7KTRXu1iz3NFYikkk9rlYsKVxGBSJyS9AwMBsOGypI5bWrZyeJ6LBbBYXnvH6zcaefv3dtyw/tnJ5CtdTfuFbhYjyu71VJwyw/kPWGIiBX4CvBhUut5HxaRZ40xZ7PKbCK1Et8DxphJEcnVdO/rgs1qmXOZCsz5RrSQ2aqzbGUOOx+/o56NQy4qXUU47Fa+/kYPiaRZcn1va7oKzhjDG13jHL0ySTAS5+GtNdf8473TPUG9x6HTi6wT0+EY3fOmDB/yhfnOu33Ek4ZSh23J43ogdQXxiTvr+WXXOL6ZGB/aVpt5D82/yp/18NaFeweu1FKTzXpVCH/9PUCnMeYygIgcAh4Dsivh/jHwFWPMJIAxZmTNo7yNZX9L2tlYxqAvzK/c2cDblyc4M+CbU9ZmkQWrsUSEBzu8uIttvHJxlMuvd9PmdfHIzrrMt6j+qRn+11tX+eiO2mv6yqtbRzyRZNgf4XS/b86XCmNSo6qLbBY+tq2WxhtMH1PqsNFU4eTCUAABDmytZmO1G6+7mL7J0G3/4Z0PsgYL2F0/AJHHgYPGmM+ntz8L3GuMeTqrzPeBi8ADpKqtvmSM+ekCj/UU8BRAbW3t3kOHDq0opvW4sPtqSZrUlCKzV9HGgD/gp8TlxioCAoFwnJlFGjgBhkKG46NJXuozbPIIn91qodg697LcXWzLdOW9GYVwzhaynuOaDsfnNPqOzhiOjSaxW4SfXEnyyXYL99dfv6rFbrVQ7rRn5lwKBdfv+cqFm4nrwIEDR40x+xY6dqukaBuwCXgIaAJeFZFdxpip7ELGmK8CXwXYt2+feeihh1b0ZC+//DIrvW8u3UpxdY74+dnZ4YX73DtgVyVIqY8Xzo3wzNsJ2qpcfGxX/Zyuih/dXMf2hpsbGX4rnbNCsNK4IvEEE8Eo/ZMzHLs0lvpaB5zsm+LVS2PpcQWpaqimllb6F1jZ0VVsxWG30uZ18cBGL5asMuvtfOVaruIqhITRDzRnbTel92XrA942xsSAbhG5SCqBHF6bENVyddSUUlvm4HDPBJdHg0QTyWuSx86GciqcRXSOBDjeN8WJvinuymprefH8MN7SogXbV1RhOdIzec0Kd5OhKK9cHKWpooQPbq1hIhilzGlfcBng9moXB3fWaftVgSuEhHEY2CQibaQSxRPA/B5Q3weeBP6HiHiBzcDltQxSLV+pw87DW2t5eGtq0Na5oWlevTg2p7qiscJJg8fB1EyUty9PsKW2NFM3HUsY/u5IH4/srFuXo3rXi3AsMWed6llvdI5htQgf2Z5qnC5zXjuqv7HCyd2tlbRWlazqGi4qN/LeZ8sYEweeBp4HzgHfMsacEZEvi8ij6WLPA+MichZ4Cfh9Y8zqTJav1oTFIuxoKOehLdfOxSMifGBzNQlj+N7xfvzh90bKRuNJfnRyMLN2gSo8716dzMxYMKs7PTng3paKRRunHXYrn7ijnjavS5PFLSLvCQPAGPOcMWazMWajMeaP0/ueMcY8m75tjDH/0hiz3RizyxizstZslXfb6sto9V7bA8pTUsSv3FGPfybON4/0zpkKJZE0/OLc8IqWzlW55QvF5kxvAXB1IsSPTw3idRfNqWKc7/6NVQU5I6taXEEkDHV7+cQdDXzu/lbuaaucs7+lysWn9zUhCN8+2sfViVDm2JAvzNF5H0wq/35xbjgzp5kxhiM9E/zgeD8ep51f3dN0zcAzEXhsd+r1v6NJR/bfajRhqDVnt6ZGlD/Q4eWBDi/ZtRFedzGfubuZMqedH50cmDOy/I3OcfomQws8osqHNzrHMkk9EInz3WP9vNE1Tnu1m8f3NuFMd4sud9q5r70Kh93K3pYK2qvdVLiKtBrqFqQJQ+XVPW2VPL63iVLHe1UT7mIbn9ydWtr1B8cHGEuvn540hp+cGrqmvlytvZfOj2R6RYVjCb55uJchX5gPbqvhYzvrMvMvtXld/Ob+FvZvrEr9bq+63sOqAqcJQ+VdU0UJv3ZX05yBeu5iG5/a3YjFAt852pdp0whE4pzom8pTpApSs8/O9ooyxvDC+RFC0Ti/treJnQ3lmSsHT4mdgzvrsKWrpVzFtsxtdWvSV08VhApXEZ/a0zhnqogKVxGf3tuMzWrhZ2eGM4vKHOmZJBK//prPKjcCkTgvnn9vZp7zQ346RwLsb6+6ZhnSj+6o07VO1hlNGKpg1JQ5+MQd9XNmsi132nloSzXjwWhmEapwLLXmhlp7b3WNZ8bR+GZivHxhlEaPk7vmTd/f5nUtOJ23urVpwlAFpaXKxcfvqMeWNRq43etiQ2UJv7w8zmQoCsCZfk0Ya20qFOXMQGrdlGAkzk9Op9a5+Mj22jlJXiTVZVatP5owVMHpqHHzq3ubKLan3p4iwoEtqVX7vvtuP9PhGJOhmPaYWmNvXR4naQzD02H+5u2rjAWifHh7bWYEt0iqGupz97cuuKa7uvVpwlAFqdHj5PGshnBPSRGf3NNANJ7M1KGf7p/OZ4i3lSFfmPNDfgBevTSKReCJu5vpqHlvypY9GyrYnl4qWK1PmjBUwaopc/CpuxozVxo1palVAK+Mhxj1R+gc8TPkW9oKgGrljDG8fGEEY6B/coaBqTD7WivxZi3SVVNWrNVQtwFNGKqg1ZQ6ePTOhszgvjsay7FbhXevThJLGL53rF/nmcqxMwPTDKYT8zs9EzjtVnZmTTu/obKEx/deO6pbrT/6CquC11RRwta61HrkDruVHQ3lXBz24w/HCMcS/PyszjOVK/5wjFcvjQKpOaKuToTY21KRGU9RU1bMo7sbdFry20RBJAwROSgiF0SkU0S+sMDxz4nIqIgcT/98Ph9xqvzZv9Gb6Tm1p9mDAY6lB48NT4c5N+jPX3Dr2IvnR4jEkiSThlcvjVLmsHFneg6oUoeNX7mzQa8sbiN5f6VFxAp8BXgE2A48KSLbFyj6TWPM7vTPX61pkCrvyp123re5GhEoc9rZVOPmdL+PSHpMwJtdY8QTOmXIapqJJugeCwJwesDHeCDKgx1ebFYL97RV8lv3t1LmuHaNC7V+5T1hAPcAncaYy8aYKHAIeCzPMakCtLvZwyfuaABgb0sFsYTJTFHhD8czYwTU6rgyEcQYCEXjvNk1TpPHSUeNm5IiK/vbq/TK4jZUCK94I9Cbtd2X3jffr4nISRH5tog0L3Bc3QY6atxsqCyhptRBR7Wbt7onOD+UShRHrkySTGpbxmrpSV9dvN45RiyR5MDWGkSELXWlc9bbVrcPyXdjoYg8Dhw0xnw+vf1Z4F5jzNNZZaqAgDEmIiL/BPiMMebhBR7rKeApgNra2r2HDq1snaVAIIDbXXhLgmpcKZF4Et9MjGjC8LWzSXqmDU/faaXJLZQ57Djs730P0nO2PNlxjQUidE4Z/uJ0ggONwiOtqYbtSlfRnJH4ax1XIVmPcR04cOCoMWbfQscKIWHsB75kjPloevuLAMaYf7dIeSswYYy57uor+/btM0eOHFlRTC+//DIPPfTQiu6bSxpXijGGr7/Zw1QoRiSW4Ou/7KGm1MGn9jRSX+7giXs25C22pSr0uIZ8Yf7XW1f423euEk0k+ex9LditFmrKivl797bkLa5Csx7jEpFFE0YhVEkdBjaJSJuIFAFPAM9mFxCR+qzNR0mt/a1uUyLC3a2p1fqK7Vbubq3k6kSI3okQg75wZv0MtTLxRJJXLo5wqt/HeDDKQ5ursVstiMBDW2ryHZ7Ko7wnDGNMHHgaeJ5UIviWMeaMiHxZRB5NF/s9ETkjIieA3wM+l59oVaHYXl9GpSs1BcUdjeW4i2280TWGMYbTOjHhTXnh/AgDU2HODkxTV+agvTpVtXFHUzmNOgPtbS3vCQPAGPOcMWazMWajMeaP0/ueMcY8m779RWPMDmPMncaYA8aY8/mNWOWbxSKZqShsVgv3tVcyPB2hazTIuUE/Me1iuyJJYzg3OM1kKMpoIMLm2lSycBVbuX+jN8/RqXwriISh1Epsqi1lzwYPANvqyqgosfPLrnFCkXhm7Qy1POFYEmPg0nAAIDO54IMd1boYktKEoW5tD22pYVt9qpvn/o1VTISidI4GONozqQP5VmB2caRLI37qyx2UOuw0epxsz5o7St2+NGGoW979HV6sFmFjtZsyh41TfT4CkTindSDfskwEo8SThgtDfsYCUbbUlmIR4cBWbehWKZow1C2vzGFPDSYTYVdTOX1TM4wHIhy7Opnv0G4pZwemGQwafnFumAaPg52N5dzRXE51afGN76xuC5ow1Lpwd2slFhG215dhFeFkv4+pUIxoXKulliKeSHJ6wMfPriaxWy18bGc9xTYL97XpGhfqPZow1LpQ6SpizwYPJUU2OmrcXBjyE08mCaXr5NX1XRj24wvFuDBp2FJXiqvYxqZaN84ibehW79GEodaN/Rur8JTY2VZfSiSepHssSDSeZFwH8t3QiV4fPeNB4gY60uMudjV58huUKjiaMNS6YbdaeKDDS3NlCa4iK+fTa2Qc7pnIc2SF7XS/j+HpMJdGArjtUO9x4HUX6SA9dQ1NGGpd6ah2U+5MNYL3jAcJxAwXhgL4QrF8h1aQZlfUiyWS9IwF2Vkl2CwW7RmlFqQJQ60rFouwZ4OH7fVlJA28PpAkaQzv9mqPqYUc7pkgEktyftBPPGnY402Nmm+qKMl3aKoAacJQ686OhnJqyxxsrnXz2oAhGIlzJb22g3pPPJHk/JAfYwzHeiepKS2mrQz2pSd2VGo+TRhq3XHYrTRVOtnfXkXCwNvdE0yGYvjDWi2VrWs0SCSWpHs8yGQoxp4NHortVqy6OJJahCYMtS61ed14Soq4u0Y4OzhNKBqnd2Im32EVlLODPowxHL0yibvYxqaaUopt+pGgFlcQ7w4ROSgiF0SkU0S+cJ1yvyYiRkQWXNxDqVltVS4AHmywkEgaTvdPc3UilOeoCkcknuDq+Az9UzMMTIXZ11KB3Wqh2KbjLtTi8p4w0ivofQV4BNgOPCki2xcoVwr8M+DttY1Q3YrKS+xUuYuoLRE2VJZwsn+KK+PajjFrcCpM0hje7p7AVWRlR0MZ9eUORGuj1HXkPWEA9wCdxpjLxpgocAh4bIFyfwT8KRBey+DUravdmxqAtrvZQzCS4GSfj/4prZYCGJiaYcQfpm9yhr0tFdisFnY2XnfVY6WwLXZARO4C/jMQB/7EGPOz9P5vG2MeX2qZJWgEerO2+4B7F4il2RjzYxH5/evE/BTwFEBtbS0vv/zyEkOYKxAIrPi+uaRxLY8xYE9G2O8a5uc2GB4e4u03xjIr9eVTvs/ZZCjG8EAMC3CgYpLSiI+RiwN5j2sxGtfy5CquRRMGqUTwT4Ao8F9EpNUY81WgapllboqIWID/yBKWZU0/91cB9u3bZ1a6CPp6XNg9lwo1LoCfv/AiV0wTzVWDnJmYocfewpbNdexoyO+36Xyes0TS8JUXL3FsoofGChtTpU3ctbWGO5s9BftaalzLk6u4rpcwjDHmHEB6be2viUg1YJZZ5kb6geas7ab0vlmlwE7gZUlVsNYBz4rIo8aYI8t4HnUbslsttJSX0Fbl4uJwgGF/hDMD03lPGPk0PB1mxB9hMhTjzmYPDnuqDUOpG7luG4aIVAAYY5LGmM8B9cD9yy1zA4eBTSLSJiJFwBPAs7MHjTE+Y4zXGNNqjGkF3gI0Wagl29VYTku611TPWJBhX5hEcjnfadaXvskZukZTHQA6qt1srS/FZi2E5kxV6K73LvkHszeyksLTwEcXKjNrgTLXZYyJA08DzwPngG8ZY86IyJfTVy1K3ZR2rxtvaRH15Q66RgPEEkmGpm/fvhPdYwG6RgPUlztwFdvYeRtfbanlWbRKyhhzOWvzqoh8FfgzY8wri5TJvu8rC+2/znM9Bzw3b98zi5R9aDmPrZTFIuxoKGdbXRkvXhhJjz2YuS1nYw1F41wc9jPij/BARxV15Q5dUU8t2VKvQx8HdgOXReSvRWRz7kJSavVtri1lW30pTruVI1cm6Z+8PbvXXh4N0jWSqo7a6HWzubY0zxGpW8mSEoYx5nljzAeBB0k1Qp8Wke+KyN05jU6pVVJdWkxNmYPdGzxcGQ9xom8KY26/doyu0QCXx4J4SuxUuIpordJZadXSLaulyxhzxBjz68BWYJBUz6UXROTDOYlOqVW0qdbNHY3liMCp23AQXziWoHPYT99kiI1eN6UOG1VurY5SS7fkhCEiThGpF5GtQA3wQ+ALwCbgpzmKT6lVs7m2FIfdSmO5k+7xICf7fPkOaU0d752iczRI0kB7tYvWdM8xpZbqeuMwMkQkSiq5+IFpwJf181r6t1IFzesuxusuos3r4rXOMY72TPL+zdW4i5f0b3BLi8aTHO+doms0gNNupa7cQatXq6PU8iz1P+VnpMZW/DfgPxtjxnIXklK5s72hnEsjAV7rHKNrLMDJvinu3+jNd1g5d3rARyAcp2c8REe1G4fdSnOlJgy1PEtt9P4E8D5gA9ApIv9FRJpvcDelCs72+jK87mI8TjvdY0EuDvnzHdKauDTsp39qhmg8SXu1ix0NZTqVuVq2JbdhGGPOGGN+E7gzfb9TIvJ1EdmWs+iUWmXOIivt1S42VrvpnQjRNznDRDCa77ByaiaaYNAX5vJoAJtFaK1ycVdLRb7DUregZc8HYIy5Yoz5XWAjcAV4RUS+s+qRKZUjOxvK2dFYRtLAmYFpuscC+Q4pp7rHgsxEE5wb9NPmdbGzsYwyhz3fYalb0FIbvf8YKF/gpwIoAT6Zo/iUWnUtVSVsqCyhudLJqX4fl0YC7G2pzHdYOdM9FuTolUmiiST3tFWySQfrqRVaaqP3XcAUMElq7YrJrO3Z30rdEkRSU4Xc0ejhx6cG+WXnOJ/c3YjDvv7q9JNJw7khHyf6pthc66a+3MEGbexWK7SkhGGMeSTXgSi1lnY0ltFe7aLIaqFrNED3WJBt9etviu/B6TCn+6aJJQx3t1bSVFGCXWemVSu0pHdOeubYT83b1yAiHasRhIgcFJELItIpIl9Y4Phvi8gpETkuIq8vtOa3UstR5rCzsdpNU4WTqxMhLg2vz95SV8aDXB4LUlFix+sups2rg/XUyi31q8ZvkGrgBkBEPgdcBS6IyI/T61isiIhYga8AjwDbgScXSAj/2xizyxizG/j3pFbgU+qm7GwsZ0NVCdPhOCf7fMQTyXyHtOrOD6amAmmvTq1v3latCUOt3FITRg1wMmv7S8BfAh9KH3v6JmK4B+g0xlw2xkSBQ8Bj2QWMMdNZmy6Wt6KfUgtq97rYWpdqAO4cDXBlIpTniFZXOJbgnZ5xkgY2VrvYXFuqvaPUTVlqwsj0O0zPJdUE/N/GmJdIren9mzcRQyOphvRZfel9c4jI/yEiXaSuMH7vJp5PKSC1TsaDHV7KHDZ6J0J0jayv7rVXJ0J0jQQpKbLS6HHyYMf6H9GuckuWMsWziPwY+B/GmG+LyO8BnzPG3JU+JsC4MWZF/RJF5HHgoDHm8+ntzwL3plfuW6j8bwAfNcb81gLHngKeAqitrd176NChlYREIBDA7Xav6L65pHEt341iiycM//3kDMdGDf/mXiv15Y6CiGs1TIVifOGNKLuqhN/cUUTpEubMKtTXUuNanpuJ68CBA0eNMfsWPGiMueEP8ACpCQb/BhgB/jDrmAuYWsrjLPLY+4Hns7a/CHzxOuUtgO9Gj7t3716zUi+99NKK75tLGtfy3Si2RCJp/tXfHTctf/Aj8zvfOGIGp2YKIq7V8Mz3T5mWP/iR+e1vHDHDvqX9XYX6Wmpcy3MzcQFHzCKfq0udS+oN4DOkFk/6IfCfsw7vJ9UAvlKHgU0i0pZuPH8CeDa7gIhsytr8OHDpJp5PqQyLRdjfVkVJkZULw34ur5NR36P+COeH/Aipke01ZWtz5aTWtyXP62yM+SkLr3uxD/j+SgMwxsRF5GngecAKfM0Yc0ZEvkwq0z0LPC0iHwJipAYJXlMdpdRKbagqYXNtKaf6fJwdmF4Xs9f2jAe5Mh6itszBrqbyfIej1ombXgjAGPMnq/AYzwHPzdv3TNbtf3azz6HUYpoqSthaV8rx3il+2TXOZ+5upvQW7010dsDH8HSYu1sr2VRbeHXs6takQz7Vba+mtJimCidlDhtdowHO3+JTnodjCd7pnsQAW+tKqdPqKLVKNGGo257FImysdtNe7aZ3coYjPZOzHSxuSZ0jAbpGAzhsFu7bWEWqI6NSN08ThlLArqZy2r0uEknD6X4fl8eC+Q5pxc4OTNMzFqTVm1r3Q6nVoglDKVLtGLuayim2Wbg8FuB0/625TH0gEudwzwTh9Mp6LVU6M61aPZowlErb3eyh1euieyxIz2iQ2C04t9SFIT+XR4NYBO5urVyXU7ar/NGEoVTa5tpSNtW4CceSdI8H6ZucyXdIy3amf4qu0QCNFU621OlCSWp1acJQKs1VbGN/exVFVgsXhv303GLtGH2TIc4M+JmaibG5tpQObb9Qq0wThlJZttaXsbHGRddIkM6RW6t77ak+H+eHprFahLs2VOjobrXqNGEolaWjxs2W2lKiiSTHe31MhaL5DmlJZqIJzg/5uTgcoN3rYkfD+ls9UOWfJgylspQ77dzVUpHpLXX1Flkj48pEkMtjAWZiCbbWldJRo9VRavVpwlBqno4aNy2VJVwZD906CWM8xPlBPw67he0NZTSUO/MdklqHNGEoNU+7101LlYtQNMGxq5P5DmdJLg37uTwWZHNtKdsbyrFYdHS3Wn0FkTBE5KCIXBCRThH5wgLH/6WInBWRkyLygoi05CNOdXuoLSvOLN16btDPeCCS54iubzwQ4XjvFImkYVtdGdvrtf1C5UbeE4aIWIGvAI8A24EnRWT7vGLHgH3GmDuAb5NaplWpnBARdjaV43UXcWU8RG+Bj8e4MhHi/JAfj9POrqYyqkuL8x2SWqfynjCAe4BOY8xlY0wUOAQ8ll3AGPOSMWa2MvktUmuKK5Uz7V4XLVUuBn0zXBiaznc413V2YJr+yZlMdZRSuVIICaMR6M3a7kvvW8w/An6S04jUba+5soRNNW6SBl69OFaws9fGEklevzSGATbWuNikvaNUDkm+/xFE5HHgoDHm8+ntzwL3GmOeXqDs3weeBj5gjLmmYllEngKeAqitrd176NChFcW0Hhd2z6VCjQtuLrbxYJQvvx2jyS38i71ObNbVa0herXMWiSf582NhrvgNz9xrw+u6ueqoQn0tNa7luZm4Dhw4cNQYs2/Bg4st9r1WP6TWBH8+a/uLwBcXKPch4BxQs5TH3bt378pWQDfrc2H3XCrUuIy5udje6hozj/4/r5n2L/7YvHJhZPWCMqt3zn5yasB0/Osfm4//11fN4e7xm368Qn0tNa7luZm4SC2NveDnaiFUSR0GNolIm4gUAU8Az2YXEJE9wF8CjxpjRvIQo7oNtXpddNS4SSQNPz87nO9wFvTKxVFiCUO7162D9VTO5T1hGGPipKqZnid1BfEtY8wZEfmyiDyaLvYfADfwdyJyXESeXeThlFo1NaXFdNS4cdgtHLkyUXDTnY/4w5zpn8ZmEXZv8OApKcp3SGqds+U7AABjzHPAc/P2PZN1+0NrHpS67YkIW+vKaK4o4epEiN6JEO0FNAPsxaHUYL2WqhJ26NgLtQbyfoWhVCHbs8HDhqoSgpEEr18ay3c4c7x6aZRAJE6b18XmWl37QuWeJgylrsNTUsSDHV4g9QGdTBZG99rh6TAnelPLyO5traTCpdVRKvc0YSh1Ax/aVku5087l0SD9U4Ux6vvisJ/usSD15Q7uavbkOxx1m9CEodQNNHqctFaV0Dc5w7khX77DAeBw9wQj/ggd1W42aXWUWiOaMJS6AYtFuKetkmgiyc/PjJDIc7XUTDTBW90TCLB/YyWVWh2l1ogmDKWW4IPbanHYLJzs89E9FshrLL2TQc4NTtNcWcLuDRV5jUXdXjRhKLUEG6vddNS66RoNcKRnIq+xvHR+FH84zrb6UjbVaHWUWjuaMJRaAq+7iN1NHuJJw8sXRvHNxPIWy6uXRrFahH0tlTqVuVpTmjCUWgIR4f4OL6UOG2cGp7k07M9LHOFYgovDAerLHezZ4MlLDOr2pQlDqSXa1VjO9voyeidmOHolP0u3vntlklF/hA2VJWxv0NHdam1pwlBqiZoqnOzfWAXAi+dHiMbXfm6pZ08MAHBfeyUlRQUxs4+6jWjCUGqJRIT7N3ppqSrhzMA03WPBNX3+nrEgZwensVuFj+6oW9PnVgo0YSi1LNsbytjRUE4gEufF82s75fnx3il6J0I0epwFNQmiun0URMIQkYMickFEOkXkCwscf7+IvCsi8fQKfUrlhbvYxgc2e7HI2i7dGo4leLt7nMlQjN3NHuzWgvjXVbeZvL/rRMQKfAV4BNgOPCki2+cVuwp8DvjfaxudUtfa21JJY4WTC8N+eifWZm6prtEAx65OYbcKn9xzvSXvlcqdvCcM4B6g0xhz2RgTBQ4Bj2UXMMb0GGNOAoW1go26LbV7XWypLWUiGOXFC2tTLXXs6iSXhgNsry9jm659ofJE1uqSetEAUlVMB40xn09vfxa41xjz9AJlvw78yBjz7UUe6yngKYDa2tq9hw4dWlFM63Fh91wq1Lggd7F1T8X4N29FebTNwic3O7FI7uIywDfPzvDTq0l+/y4rO2ocyw84B3GtJY1reW4mrgMHDhw1xuxb6Ni66pdnjPkq8FWAffv2mYceemhFj/Pyyy+z0vvmksa1fLmKrWMyxJ+ffoM3R+GzH9nF3W1VOYvrdL+P1196i+bKYrbs3MFD22tXEPHqx7WWNK7lyVVchVAl1Q80Z203pfcpVbAaPU7ua6tiLBDlB+mxEbnyd0d6CUTi3Nnk0cF6Kq8KIWEcBjaJSJuIFAFPAM/mOSalrktE+MSd9ZQ5bPzi7Agj0+GcPI9vJsYvzo1Q6rCxr7WCBo8zJ8+j1FLkPWEYY+LA08DzwDngW8aYMyLyZRF5FEBE7haRPuDTwF+KyJn8RaxUypbaUva2VDA0HeZHJ3NzlfHi+WH6p2bY1VjOzobynDyHUktVEG0YxpjngOfm7Xsm6/ZhUlVVShWM1ioXD2ys4vXOMZ49McDn7m/DstzW7+tIJg3ffTdVO7uvpYJdTZowVH7l/QpDqVuVxSIc3FXPpppSzgxMc2ZgdZdvPTc4zck+H80VTn5tbxPFNuuqPr5Sy6UJQ6mb0FRRwsd21hFLGL7x1tVVe1xjDN871o9vJsb7N1fTUuVatcdWaqU0YSh1k35tbxMVJXZevjDCqH91Gr+7x4K8dGEEu1X49X1aG6sKgyYMpW5SvcfJgS01jPgjfOOtK6vymN860kvXaJD72qvYoY3dqkBowlBqFXx2fwvuYhvfOdqPL3Rzy7eOBcJ860gf5U47n7m7GZtONKgKhL4TlVoFOxvLuX9jFf1TM3z9zZ6beqy/fOUyE8EoD3Z4ubPJsyrxKbUaNGEotQrsVgu//YGNlDvt/M9f9jAejKzocaZCUb51pI/q0mIe39tIc2XJKkeq1MppwlBqlexu9vDxXXWMB6P82fMXVvQY/+H5C/hmYnx8Vx0f2FyzyhEqdXM0YSi1SiwW4Z8e6GBDZQnfOzbAeGB5Vxknrk7xnaN9NJQ7+L2HN63qIEClVoMmDKVWUVNFCZ9/XxszsQR/+tPzS75fImn4198/RSxh+P2DW6h0F+cwSqVWRhOGUqvs79/bwuZaN88eH+CFc0tbYOm/vnCJMwPTPLythsfu1BX1VGHShKHUKrNYhN//6BZiScPvHTrGD473Xbf8ib5J/uKVLhrKHfzxp3ZqVZQqWAWRMETkoIhcEJFOEfnCAseLReSb6eNvi0hrHsJUask+vL2Of/mhzdgsFv7V353k5QsjC5a7OhHk818/ijHwR5/cSU1p7lbTU+pm5T1hiIgV+ArwCLAdeFJEts8r9o+ASWNMB/CfgD9d2yiVWr7feWgjf/4beyh12HnqG0f5ox+dZSQ9dYgxhh+eGOCTX3mTqZkof/DIFj64LXcr6Sm1GgphevN7gE5jzGUAETkEPAaczSrzGPCl9O1vA38uImLyvSC5UtdhsQjv21TNt397P7/zv97lr1/v5q9f76a+3MF0KEwwdgxPiZ0/+/U7eVTbLdQtoBASRiPQm7XdB9y7WBljTFxEfEAVMLYmESp1E9qr3Tz/L97PucFpfnC8nxO9PqzuGB/eu5XfuHcDdp36Q90iJN9f0kXkceCgMebz6e3PAvcaY57OKnM6XaYvvd2VLjM277GeAp4CqK2t3Xvo0KEVxRQIBHC73Su6by5pXMtXqLFpXMujcS3PzcR14MCBo8aYfQseNMbk9QfYDzyftf1F4IvzyjwP7E/ftpG6spDrPe7evXvNSr300ksrvm8uaVzLV6ixaVzLo3Etz83EBRwxi3yuFsK18GFgk4i0iUgR8ATw7LwyzwK/lb79OPBi+g9TSim1RvLehmFSbRJPk7qKsAJfM8acEZEvk8p0zwJ/DXxDRDqBCVJJRSml1BrKe8IAMMY8Bzw3b98zWbfDwKfXOi6llFLvKYQqKaWUUrcATRhKKaWWJO/danNFREaBlS6w7KUwx3hoXMtXqLFpXMujcS3PzcTVYoypXujAuk0YN0NEjpjF+iHnkca1fIUam8a1PBrX8uQqLq2SUkoptSSaMJRSSi2JJoyFfTXfASxC41q+Qo1N41oejWt5chKXtmEopZRaEr3CUEoptSS3bcIQkU+LyBkRSYrIvnnHvphe3e+CiHx0kfu3pVf/60yvBliUgxi/KSLH0z89InJ8kXI9InIqXe7IasexwPN9SUT6s2L72CLlrruSYg7i+g8icl5ETorI90TEs0i5NTlfhbiSpIg0i8hLInI2/f7/ZwuUeUhEfFmv7zMLPVaO4rvuayMp/zV9zk6KyF1rENOWrHNxXESmReSfzyuzJudMRL4mIiPpGbxn91WKyM9F5FL6d8Ui9/2tdJlLIvJbC5W5ocVmJVzvP8A2YAvwMrAva/924ARQDLQBXYB1gft/C3giffsvgN/Jcbx/BjyzyLEewLuG5+5LwL+6QRlr+ty1A0Xpc7o9x3F9BLClb/8p8Kf5Ol9L+fuBfwr8Rfr2E8A31+C1qwfuSt8uBS4uENdDwI/W6v20nNcG+BjwE0CA+4C31zg+KzBEaqzCmp8z4P3AXcDprH3/HvhC+vYXFnrfA5XA5fTvivTtiuU+/217hWGMOWeMubDAoceAQ8aYiDGmG+gktSpghogI8DCp1f8A/j/gk7mKNf18vw78ba6eIwcyKykaY6LA7EqKOWOM+ZkxJp7efAtoyuXz3cBS/v7HSL13IPVe+mD6tc4ZY8ygMebd9G0/cI7UAmW3iseA/2lS3gI8IlK/hs//QaDLGLPSQcE3xRjzKqkJWLNlv48W+yz6KPBzY8yEMWYS+DlwcLnPf9smjOtYaAXA+f9QVcBU1ofTQmVW0/uAYWPMpUWOG+BnInI0vYjUWng6XSXwtUUugZdyHnPpH5L6JrqQtThfS/n756wkCcyuJLkm0lVge4C3Fzi8X0ROiMhPRGTHWsXEjV+bfL+vnmDxL275Ome1xpjB9O0hYKHF4VflvBXEbLW5IiK/AOoWOPSHxpgfrHU8C1lijE9y/auLB40x/SJSA/xcRM6nv4nkJC7g/wX+iNQ/9x+Rqi77hzfzfKsR1+z5EpE/BOLA3yzyMKt+vm41IuIGvgP8c2PM9LzD75Kqcgmk26e+D2xao9AK9rVJt1M+SmqRt/nyec4yjDFGRHLW9XVdJwxjzIdWcLd+oDlruym9L9s4qUthW/qb4UJlViVGEbEBvwrsvc5j9Kd/j4jI90hVh9zUP9lSz52I/HfgRwscWsp5XPW4RORzwCeAD5p05e0Cj7Hq52sBS/n7Z8v0pV/nclLvrZwSETupZPE3xpjvzj+enUCMMc+JyH8TEa+ZtyRyLizhtcnJ+2qJHgHeNcYMzz+Qz3MGDItIvTFmMF09N7JAmX5S7Syzmki13y6LVkld61ngiXQPljZS3xLeyS6Q/iB6idTqf5BaDTBXVywfAs6b9Hrm84mIS0RKZ2+Tavg9vVDZ1TKvzvhTizzfUlZSXO24DgL/F/CoMSa0SJm1Ol8FuZJkuo3kr4Fzxpj/uEiZutm2FBG5h9TnxFoksqW8Ns8Cv5nuLXUf4Muqjsm1Ra/083XO0rLfR4t9Fj0PfEREKtJVyB9J71ueXLfqF+oPqQ+6PiACDDN3XfE/JNXD5QLwSNb+54CG9O12UomkE/g7oDhHcX4d+O15+xqA57LiOJH+OUOqaibX5+4bwCngZPrNWj8/rvT2x0j1wulao7g6SdXTHk///MX8uNbyfC309wNfJpXQABzp905n+r3Uvgbn6EFSVYkns87Tx4Dfnn2fAU+nz80JUp0H7s91XNd7bebFJsBX0uf0FFk9HHMcm4tUAijP2rfm54xUwhoEYunPr39Eqt3rBeAS8AugMl12H/BXWff9h+n3WifwD1by/DrSWyml1JJolZRSSqkl0YShlFJqSTRhKKWUWhJNGEoppZZEE4ZSSqkl0YShlFJqSTRhKLXGROR5Efk/8x2HUsulCUOptbeH1NxDSt1SNGEotUZEpEpEgkA18EMRCYjIP853XEotlY70VmoNicgjwH8zxrTlOxallkuvMJRaW/uAo/kOQqmV0ISh1NrShKFuWZowlFpbe9GEoW5RmjCUWlvVpKboVuqWowlDqbX174C/TfeQejjfwSi1HNpLSiml1JLoFYZSSqkl0YShlFJqSTRhKKWUWhJNGEoppZZEE4ZSSqkl0YShlFJqSTRhKKWUWhJNGEoppZZEE4ZSSqkl+f8BInHjNKgBKn8AAAAASUVORK5CYII=\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",
    "L_mean = np.mean(L, axis=-1)\n",
    "L_std = np.std(L, axis=-1)\n",
    "plt.plot(t.detach().cpu(), L_mean)\n",
    "plt.fill_between(t.detach().cpu(), L_mean-L_std, L_mean+L_std, alpha=0.5)\n",
    "plt.xlabel(r\"$t$\", fontsize=13)\n",
    "plt.ylabel(r\"$SW_2^2$\", fontsize=13)\n",
    "plt.grid(True)\n",
    "plt.savefig(\"./SW_WND_poincare.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "np.savetxt(\"./SW_WND_poincare.csv\", L, delimiter=\",\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.9"
  },
  "toc": {
   "base_numbering": 1,
   "nav_menu": {},
   "number_sections": true,
   "sideBar": true,
   "skip_h1_title": false,
   "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": 4
}
