{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy.io as sio\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from utils_knn import *"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# BBC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "mat_contents = sio.loadmat(\"./data/bbcsport-emd_tr_te_split.mat\")\n",
    "\n",
    "idx_train = mat_contents[\"TR\"]-1\n",
    "idx_test = mat_contents[\"TE\"]-1\n",
    "y = mat_contents[\"Y\"][0]\n",
    "\n",
    "X = mat_contents[\"X\"][0]\n",
    "w = mat_contents[\"BOW_X\"][0]\n",
    "\n",
    "dataset = \"BBC\"\n",
    "path = \"./results_BBC/\""
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# rhos = [0.001, 0.01, 0.1, 1.0]\n",
    "rhos = [0.0001, 0.0005, 0.001, 0.005, 0.01, 0.1, 1.0]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### OT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9454545454545455"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d_sw = np.loadtxt(path + \"d_w_BBC_k0\")\n",
    "acc_w = np.mean(get_acc_knn(d_sw, y, idx_train, idx_test))\n",
    "\n",
    "acc_w"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### UOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9672727272727274"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d_sw = np.loadtxt(path + \"d_uw_BBC_rho1.0_k0\")\n",
    "acc_uw = np.mean(get_acc_knn(d_sw, y, idx_train, idx_test))\n",
    "\n",
    "acc_uw"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Sinkhorn UOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.29454545 0.47909091 0.65363636 0.95454545 0.94545455 0.94818182]\n"
     ]
    }
   ],
   "source": [
    "rhos_sinkhorn = [0.01, 0.05, 0.1, 1.0, 5.0, 10.0]\n",
    "L_mean_sinkhorn = np.zeros((len(rhos_sinkhorn),))\n",
    "\n",
    "for i, rho in enumerate(rhos_sinkhorn):\n",
    "    d_sw = np.loadtxt(path + \"d_sinkhorn_BBC_rho\"+str(rho)+\"_reg0.1_k0\")\n",
    "    L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "    L_mean_sinkhorn[i] = np.mean(L_acc)\n",
    "\n",
    "print(L_mean_sinkhorn)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### SOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8939393939393939 0.007618063690894892\n"
     ]
    }
   ],
   "source": [
    "L_sw = np.zeros((3,))\n",
    "\n",
    "for k in range(3):\n",
    "    d_sw = np.loadtxt(path + \"d_projs500_sw_BBC_k\"+str(k))\n",
    "    acc_sw = np.mean(get_acc_knn(d_sw, y, idx_train, idx_test))\n",
    "    L_sw[k] = acc_sw\n",
    "    \n",
    "print(np.mean(L_sw), np.std(L_sw))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### SUOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.22393939 0.25787879 0.22121212 0.89363636 0.90121212 0.89272727\n",
      " 0.89242424] [0.01330576 0.00631293 0.00701566 0.00196386 0.00154516 0.00519589\n",
      " 0.00366153]\n"
     ]
    }
   ],
   "source": [
    "L_mean_suw = np.zeros((len(rhos), 3))\n",
    "\n",
    "for k in range(3):\n",
    "    for i, rho in enumerate(rhos):\n",
    "        d_sw = np.loadtxt(path + \"d_projs500_suw_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_suw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "print(np.mean(L_mean_suw, axis=-1), np.std(L_mean_suw, axis=-1))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### USOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.76363636 0.92363636 0.91575758 0.89727273 0.8969697  0.88818182\n",
      " 0.89060606] [0.00680301 0.00074227 0.00350783 0.00148454 0.00366153 0.00148454\n",
      " 0.00482951]\n"
     ]
    }
   ],
   "source": [
    "L_mean_rsw = np.zeros((len(rhos), 3))\n",
    "\n",
    "for k in range(3):\n",
    "    for i, rho in enumerate(rhos):\n",
    "        d_sw = np.loadtxt(path + \"d_projs500_rsw_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_rsw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "print(np.mean(L_mean_rsw, axis=-1), np.std(L_mean_rsw, axis=-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "rhos_rsw = [0.0001, 0.00011, 0.00012, 0.00013, 0.00014, 0.00015, 0.00016, 0.00017, 0.00018, 0.00019, \n",
    "            0.0002, 0.000205, 0.000208, 0.000209, 0.00021, 0.000211, 0.000212, 0.000215, 0.00022, 0.0003, \n",
    "            0.0004, 0.0005, 0.0006, 0.0007, 0.0008, 0.0009, 0.001, 0.005, 0.01, 0.1, 1.0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.76363636 0.80212121 0.83575758 0.86969697 0.88848485 0.9030303\n",
      " 0.91030303 0.91666667 0.91909091 0.92333333 0.93090909 0.91848485\n",
      " 0.92393939 0.92575758 0.93515152 0.92848485 0.93151515 0.92787879\n",
      " 0.92757576 0.92636364 0.92848485 0.92363636 0.91969697 0.9269697\n",
      " 0.92272727 0.91363636 0.91575758 0.89727273 0.8969697  0.88818182\n",
      " 0.89060606] [0.00680301 0.0059536  0.00422072 0.00380903 0.00281019 0.00834297\n",
      " 0.00154516 0.00631293 0.00296908 0.0008571  0.00074227 0.00521353\n",
      " 0.00422072 0.00622504 0.00042855 0.00299985 0.00422072 0.00154516\n",
      " 0.00238606 0.00647096 0.00281019 0.00074227 0.00701566 0.00042855\n",
      " 0.00267629 0.00589158 0.00350783 0.00148454 0.00366153 0.00148454\n",
      " 0.00482951]\n"
     ]
    }
   ],
   "source": [
    "L_mean_rsw_v2 = np.zeros((len(rhos_rsw), 3))\n",
    "\n",
    "for k in range(3):\n",
    "    for i, rho in enumerate(rhos_rsw):\n",
    "        d_sw = np.loadtxt(path + \"d_projs500_rsw_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_rsw_v2[i, k] = np.mean(L_acc)\n",
    "        \n",
    "print(np.mean(L_mean_rsw_v2, axis=-1), np.std(L_mean_rsw_v2, axis=-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.0001 0.7636363636363636 0.00680301343049807\n",
      "0.00011 0.8021212121212121 0.005953600819511703\n",
      "0.00012 0.8357575757575759 0.0042207237203588195\n",
      "0.00013 0.8696969696969697 0.0038090318454474534\n",
      "0.00014 0.8884848484848483 0.0028101874228774882\n",
      "0.00015 0.903030303030303 0.00834296963511286\n",
      "0.00016 0.9103030303030303 0.001545157428361438\n",
      "0.00017 0.9166666666666666 0.006312929289696898\n",
      "0.00018 0.9190909090909091 0.002969078476100886\n",
      "0.00019 0.9233333333333332 0.0008570991287109199\n",
      "0.0002 0.9309090909090908 0.0007422696190251649\n",
      "0.000205 0.9184848484848486 0.005213530464874357\n",
      "0.000208 0.9239393939393938 0.004220723720358782\n",
      "0.000209 0.9257575757575758 0.006225041995204182\n",
      "0.00021 0.9351515151515151 0.00042854956435556463\n",
      "0.000211 0.9284848484848486 0.002999846950488399\n",
      "0.000212 0.9315151515151515 0.004220723720358732\n",
      "0.000215 0.9278787878787879 0.0015451574283614816\n",
      "0.00022 0.9275757575757577 0.0023860629921247786\n",
      "0.0003 0.9263636363636364 0.006470956516382634\n",
      "0.0004 0.9284848484848484 0.0028101874228774683\n",
      "0.0005 0.9236363636363637 0.0007422696190251649\n",
      "0.0006 0.9196969696969696 0.007015658728963803\n",
      "0.0007 0.9269696969696971 0.00042854956435551227\n",
      "0.0008 0.9227272727272727 0.002676291171614441\n",
      "0.0009 0.9136363636363636 0.00589158245309799\n",
      "0.001 0.9157575757575757 0.0035078293644819187\n",
      "0.005 0.8972727272727271 0.0014845392380504658\n",
      "0.01 0.8969696969696971 0.0036615290829074545\n",
      "0.1 0.8881818181818182 0.0014845392380504205\n",
      "1.0 0.8906060606060606 0.004829508318336182\n"
     ]
    }
   ],
   "source": [
    "L_means = np.mean(L_mean_rsw_v2, axis=-1)\n",
    "L_std = np.std(L_mean_rsw_v2, axis=-1)\n",
    "\n",
    "for i, rho in enumerate(rhos_rsw):\n",
    "    print(rho, L_means[i], L_std[i])"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### SUSOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.76787879 0.92454545 0.91484848 0.89848485 0.89606061 0.88757576\n",
      " 0.89272727] [0.00373601 0.00392772 0.00042855 0.00477213 0.00557114 0.00281019\n",
      " 0.00128565]\n"
     ]
    }
   ],
   "source": [
    "L_mean_srsw = np.zeros((len(rhos), 3))\n",
    "\n",
    "for i, rho in enumerate(rhos):\n",
    "    for k in range(3):\n",
    "        d_sw = np.loadtxt(path + \"d_projs500_stochastic_rsw_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_srsw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "print(np.mean(L_mean_srsw, axis=-1), np.std(L_mean_srsw, axis=-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.76787879 0.92727273 0.92515152 0.92454545 0.91484848 0.89848485\n",
      " 0.89606061 0.88757576 0.89272727] [0.00373601 0.00267629 0.00042855 0.00392772 0.00042855 0.00477213\n",
      " 0.00557114 0.00281019 0.00128565]\n"
     ]
    }
   ],
   "source": [
    "rhos_srsw = [0.0001, 0.0002, 0.00021, 0.0005, 0.001, 0.005, 0.01, 0.1, 1.0]\n",
    "\n",
    "L_mean_srsw = np.zeros((len(rhos_srsw), 3))\n",
    "\n",
    "for i, rho in enumerate(rhos_srsw):\n",
    "    for k in range(3):\n",
    "        d_sw = np.loadtxt(path + \"d_projs500_stochastic_rsw_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_srsw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "print(np.mean(L_mean_srsw, axis=-1), np.std(L_mean_srsw, axis=-1))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Figures"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Ablation $\\rho$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYoAAADhCAYAAADWOvI9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAABD40lEQVR4nO3deXxU5fnw/8+ZNXtCEggEwi77vlYRRUXRWlGqrRUlKCrVqj+/Uh+FCoIrbaVIv7groIKopS78ntYFpWpFcGFVBJEl7CGQPZlMJrPczx8nmWSSSUgmk8xMcr19jTNzlnvuOQnnyr1rSimFEEIIUQ9DqDMghBAivEmgEEII0SAJFEIIIRokgUIIIUSDJFAIIYRokAQKIYQQDZJAIYQQokGmUGcgEng8Hk6ePEl8fDyapoU6O0II0WxKKUpKSkhPT8dgaLjMIIGiEU6ePElGRkaosyGEEEF37NgxunXr1uAxEigaIT4+HtAvaEJCQohzI4QQzVdcXExGRob3/tYQCRSNUFXdlJCQIIFCCNGmNKY6XRqzhRBCNEgCRSRSCrY8B1n/DXVOhBDtgFQ9RaKfP4KP5+mvFxWFNi9CiDZPShSRKO9g0453u1omH0KIdkFKFJFIa2R8L8mBk9sh50cwWaFDT0jqoT9HSaO8EKJxJFBEooYChdsJp/fAyR1QnO27/dRu/QEQkwIdelQHD3NUi2ZZCBG5JFBEmu2r4aMHq98f3wbdRoMtVw8Op34Al+Ps6ZTl6Y8T20HTIKUvDJ4GBmPL5V0IEZEkUESa//9u3/eHPoMze6HwWOBpKgW5+2HfBzDwqublTwjR5khjdiRxVdTdduSr5gUJAHeFXrrI/h4Ob2peWkKINkdKFJEkd1/dbfmHodNgMMfoVUiNoTx6+0XhYSg4DMUn9G0J3aCiDKI7QNrgIGZcCBHJJFBEklM/1N1WcAi2LAejBaKTIKqDfqOv+bDE6SWGqsBQeAzctdsxNCg+DttXgaMYLnwAkhqYCLEkRz/eHAPmaPB4YMdqvZ2jy7DgfWchRMhJoIgk/gKFNUG/sbsroPS0/qhNM+glhppMUdVdZTv01Nsp9rwHtjP6Dd92Gq5+DmJTfM9zu+DIJjj6jW+a+zfoXXG/eQGuXwN9L2nutxVChAkJFJGkdqBIHwXnXAYeF5QXgb3A91FeCPZC/YZuMOlVS1WBIa5T3W62I2foo75P79Gf10yDm96F2FR9f9Fx2Peh3sOqptIcvccVgLMM/nkLTPgf6DdFqrCEaAMkUEQKpeDU977bEjMgKlEPEjEp+qM2jxsqSvTqJ0M9P26DCTLG6W0VRgskpMPB/0D2LnjhfLhxnV7VdGKrno/a+TrwCaCg1wWQ+zOUnIJvX4SKUj1/iQ3PdS+ECG8SKMKd2wVGExQe1QNCTTHJMHqm/ld+7n7/5xuMEJVUf/pRCXq7QkK6/r4sH7J/oZc6dr0FJdnw8sXQ/0ro2L/u+Wf26iUNgxmufhYcpfDKJXqw+PF9iOsMY2+Ds6ygJYQIX/KvN9ztXa83Pv/077r7YpLBEgtDr4MBV+rTdDRFUncYfXN1kKhKs89FcMVfYfo/IOUcvf1jz3tw8DPfdgl3hV7yABg0VU8vbRBM+bNeSsk/CLv/CSe2NflrCyHChwSKcFecDd+/BVtX6O/7/7J6X3Ry9esuw2DsrXpJoDEyxsLwG/RA44/BCD0nwB+2wJBr9W3Hv4Fdb+pVSgBHNldWLyXBL+6qPnfUTTD0N/rrkzvg4KfgKGlcvoQQYUcCRThzO/Ubsb2oesbYMbOq98ck+x4flQjDfwfnXKpXV/ljNOl//fed3LjqIKMZrnkBhlynt18UHYNtr0LObjj+nX5M38nQaWD1OQYjnHu3nh93BeTsgQMbG/21hRDhRQJFOLMX6I3Fp/cCCtKGQJfh1fv9tT1oGnQbA6NnQUIX333RSTAys+k9kUwWGHkjjJqpN5hXlMJP/wLlhg69oef5YInxPSdtMGSM11/n/Kh/hxPb6razCCHCngSKcFYVKHIqZ3wd+luw1lgI3WSp/9zYFD0o9Jqo/4Wf3Ftvj4hPCywv3cbqXWpHzYSOlaUHzaCPl0jpW/d4TYNxd+iv8w9BhQ1+3qCvzLd5Ofz4nt5AL4QIe9LrKZzZC/QusaWn9MbhETfoA+WqWM+ypoTBoP+132mQPkK7sVN8+GON16uXTu2GgVP1NM3RegkjpY//c3pfCPHpUHJSL1F0G6Nvd5TC6Z/0R2JXyPgFpJ7TvPwJIVqMlCjCWd6B6l5FQ39bOUhOg/Puhb6X6n/lN0ZMcnBuwlVVSZqm39gTu+lVTvFd/B9vNOkN4gCnf/R/TNEJ2P0OfPeKPimhx938fAohgkoCRTjbsUafkyk+HUbfUr39gvvhkgWt/xd4XCdI7uW7Lbl3w/kYdA2g6eMxyvL0bUrpo7ndzurjbLl6F+Cvn4dj3/qfKVcIERJS9RSuPB79L2yAXhdCh+7V+wwm3yqo1pQxHvKzqt8n11PtVKXLMD2Y5B/UG7W7jtIDQkGW/h06D4P0kXrVGOjdaA9s1KdPTx+lV1fV14VXCNEqJFCEq1Pfg9Omj3hO6QOxnar3Gc1NH1wXLMm99JJF6Wm9Mbt2CaO2hK56sMg/qE8Jkr1Tnw8KwFUOx7/VHx166QEjpa+errNcH6dx7Fv9/Ixx1cFECNGqJFCEq58/1p8TM/Sbcc0xD0YzmKJDky/QSxV7/68+ott8lnwYjND7Yr0U4bTp22I7woCr9FlvT27Xe0UVZOkPa4LeBbjLcH1+Ko9LX6715E59CpHu5wbec0sIERAJFOEq6wv9uUMPfWqM2kJZHdNpEBz6vP7eTrWlnqNXIx37Wn/uc7FefRbXSS9B2Ashe4de1eYohsNf6lVPqf31UkZiBuDRe06d3qsHzu6/aPwodCFEs0igCDfZu8CWp8/UCvrNMKlH3eNCGSgMBr3HVWNv1End9XaWHufpo7tri06C3hdBz4lw5id92o/iE/qEg2f2QkyqHjDShuhVbvlZ+iO+s17C6NhfutYK0YIkUISb4pOw5/+Cy6GvHpeUof/lXVuob4zpIxse8FdTfBcwW8FVI8/dx+sz457eA067vs1g0oNB2hB99tnsHfr0H2W5+lTmhz7XR3ynj4S4tMoZat/Tu/9mjIO0ofVPXSKECJj8qwo3FTZ9yVLQSxJJPUIfFPxpbJAAvQSS2F0fFwJ6G0Pvi/Tv1fcSvY0iZzfkHtDbJEAvLcRfoR+Xs1svZZTl6Y3h2Tv1RZjSR+qlibJ82PcRZH2pl3TSR4I5RL3ChGiDJFCEmwpb9dQWHXo0vh0g3CVVBgpNg3OmVAc/g1Fvw0g9Ry9FnflJ70ZbeFQfb2GKgq5jIH00FB3VA0buz/p63cXH4eDGyi62I/T0Dn0ORzfrwaLbWN8pT4QQAZFAEW7shXr1E8C5d+k3vLagQ2U7S+eh+rQd/pis1T2eyov1gJGzWx+Mp2nVJSxHSWVX21366n3HvtYfyX30xvLkXvqa3se36tVYGePrrv0thGg0CRThJm+/PitrdLLeuNtWxKXp4yB6X9S446MSoMe5+qMkRw8Yp/fo80RZ4/U5rHqcp1+vEzv06rr8g/ojKhG6jNRLGtm79DEpqefoc0rVF6SEEPWSQBFOXI7qUc/dxoRn20SgNE1fzKj2dOSNEZ+mP/pcDAWH9aBxZp8+BUhqf/1Rlq9XS+V8r09lnvW53s224wC9VObxwJmf9Sqw7r9oO1V6QrQCCRThpMKmLwwE0GNCaPPSEppb/aNperVSci/od7neVpHzox5cY5L1hvFeF+glj5M79Fl3T/+oP2I76dVS7gq9/SOukx4wOg6U9byFOAsJFOHEXqCPHwD9r2dRP6NZ7yqbNlgPsKf3wqkf9C6zVe0cxdn6yO8ze8F2GvZ/BIc+q+xiO0qfhiTqC70No8swPU0hRB0BBYrHH3+cW2+9lS5d6pleWgTm+Hd691BzjN7oKxrHEqtX1XUbow9WzNmtlzQAEq7Ug+6pH/RxGfYCPXic3K532U0fqVdbHf5SP7/r6LNPSyJEO6MppVRTTzIYDBiNRi6//HJuvfVWrrrqKoxGY0vkLywUFxeTmJhIUVERCQlnWSyoOf79R31dhs7D4I4vW+5z2gOloOi4HjDO7NUnGVRKb+M4ub1yTEflr74lFjoP17vYxqRAlxGQMVZvFG9lTo+TMmcZFqMFq9GKQZNqMdEymnJfC6hE8c0337BixQreeustPvjgAzp16sTMmTOZNWsW/fr1CyjTVZ599lmeeuopTp06xfDhw1m+fDnjxo3ze6zT6WTx4sW89tprnDhxgv79+/OXv/yFyy+/POA0g+3pT35u9LHT9u+mJ7DP2YkPmnCeaEhvNNWDDvajpNr206E8CS1mEhbLGNJsP9Gp9CcsFTY4uhl1dAsF0d05FbeVQutH5Madw8n44dgtyS2aQ6UUpe4z5DsPc7piHw6PDYshFrPBigETJs2CUTNj1CwYNYv+Hn2bqXKbUavxvnKfJkGm3bjv0ubdd88moBJFFbvdzrp161ixYgVffvklmqYxYcIEbr/9dq677jqio5tWhH/77bfJzMzkhRdeYPz48Sxbtox169axb98+OnWqO43Fgw8+yJo1a3j55ZcZMGAAH3/8MXPmzGHz5s2MHDkyoDT9aU6JoimBYsb260m1H+K79Bls6vX/NelzROMY3eWk2LNIte0nwZGDplwk2w+TVrqXREe29zi7KYGcuIGcienPmbhzOJkwghJr56DmxeEpId95mNyKQ5yu+Jk81yFK3aer84oZiyEOixaL1RCLxRCLRYvDaojFrMVg0OovxWuaJkGmHQkkUDTlvtasQFHT/v37WblyJa+//jqnTp0iPj6e6dOnM3v2bEaMGNGoNMaPH8/YsWN55plnAPB4PGRkZHDPPfcwd+7cOsenp6fz0EMPcdddd3m3XXvttURHR7NmzZqA0gRwOBw4HA7v++LiYjIyMlo8UNzxzSVEu4r5tM88fuj86yZ9jmg6q6uEVNt+UssOEO0sJNqZT1rpXjra9mNS+up7Hs1IbkwfTsUO4lTCEE7GD6cgOoBpVZTC7C7D6MqnpOKgXnpwHeWUO5tT5OGkcglYBVaMOLSzLQmrYdaisdYMJFocFoP+2ogVLcDu1Q0HGXP1awkyYaOlA0XQej316tWL0aNH891335GdnU1paSkvv/wyL774IpdffjmvvPJKg43fFRUVbNu2jXnz5nm3GQwGJk+ezJYtW/ye43A4iIryndMnOjqaTZs2BZwmwOLFi3nkkUca9b2DxeipIMpVDEB+lJ/ZYkXQOUzxnEgcxYnEUcQ6zpBatp/iqK4cTRxHatkBOpfuIdaZTyfbz3Sy/Uzvgk2cihvE8cRRHE8cQ25sX1TlX/VGdzlWdylWVykWtw2ruxSLy4bFXYrZXUKh+wwnKOYIJRzXSjiqlVCglXvzEqWMZJBAb08iHYiiCAdlmosynPqj8rVNc1NGBR4UTlWG013m97sZMOlBozJ46MGk+nVDpRGlFG6cuJWz3mPq05gg4xtoJMhEgmYHih9//JEVK1awZs0a8vLy6NKlC/Pnz+e2227DYrHw3HPPsWTJEmbNmsWHH35Ybzq5ubm43W7S0nwXpUlLS+Onn37ye86UKVNYunQpF1xwAX369GHjxo28++67uN3ugNMEmDdvHnPmzPG+rypRtKR4RzYa4NZMFEXJ6OHWZrN2xGbtyJGkX5BUfpxU2wFOxQ0hwXGSzqV7SCk7RJwzl74F/6Vn4decju3H8cRRlFrTsLhsGP3cVAsp54hWwklKOa2VcVQr5gSluDQPAJqCTsTSXcXTV3Wgj0oinThMGHDhoUg5KMJBkeagUDkopQKlgULhwI0dFzaclOGi1OChDDdlOKigAg8uyj1FlFMEfgonZi3aW41Vs0rLosVi0qICLo20bJAxY9BMaBgxaAb9GSMGzVi5zYiGAQNGNM2IAUPl8YYGA6M4u4ACRWlpKW+++SYrVqzgu+++w2AwcPnllzN79myuvPJKDDUGMD366KPExcW1yF/of//737n99tsZMGAAmqbRp08fbrnlFlauXNmsdK1WK1Zr6y41mliuj58oNyXgMMlEdiGjGSiM7k5hdHcMHifJ9iw62g6QYjtAJ9tPpJXuJcpdSnrpbtJLd+M0RKEwoDQNhQGPplEBODQPRQaNIzEWdsRYOWSp/qeW5vJwsd3FRLubzspFDHbMFEBlGi6DhXJTAsmmBBymBBzGjqDVDR5F6MHDowGe6q/gxqMHEc1DiQY2zYMNJ+U4KFd2PLhwKjtOZcfmOVP3EmD0rcrSYn3aSgxaywy/ak6QORtN0xoMIlVBR9MMvsGnZlCqEZAMGH3PrQpSmgkDhlrbIj9IBfQTT0tLo7y8nG7duvHwww9z66230q1bt3qP79GjB3a7vcE0U1NTMRqN5OTk+GzPycmhc2f/jYgdO3bk/fffp7y8nLy8PNLT05k7dy69e/cOOM1Q6WA/AujVIU5jANNciKDzGMzkxvYjN7YfZpeN1LIDdCz9mfSSXXQu3UNS+THMnnKfcxTwk9XKO/GxbIiNobzyjyazUky2lXFtSSljyx00pYLFgwGHKY5yUyLlpvjKPyYSKDclYDPGUmTwUEg5RVoFhZRTSgVGzUKcgrRaLZAKRbnBSLFmoFRTlVVZTsqx4/DYcCo7CjflnmLKKfZbGjFpUbWCR3WVllmLDrg00pKUUijceHB7e0W3luogZaoVdAy1ApLRT2nJgIapMjgZKoNc9bn6MS0/UDSgQHHppZdy++23c8UVV/iUHupz/fXXc/311zd4jMViYfTo0WzcuJFrrrkG0BueN27cyN13393guVFRUXTt2hWn08k777zDb3/722an2do62PWpxW3mlLY1x1Mb4TTFkp0wnOyE4eyvuISOZftJKd7BKedB8iijDCf7TXZ+MjooMFTfXVPcBoa7zAytMNNFpWCIieJgtAUDCg0PmvKgodCUB1AYlAeTp5woVzFRrmKsrhIMeIh2FRNd2YZVm8MYi6MygJSbEigzxZNniibbZOGMUVGEgxIq8GgKDY1oj4doPFRXyJoBC05DGg6DlVKDgVLNQxkuyinH4bFRoWw4PKV4cOJS5bhUOTZPXp28aBjqBA+LIa4ysMRibIWbWrgJVpDSlBujcmL0OL3PBuXEggaMD1p+/QkoULz//vtBzoZuzpw5zJw5kzFjxjBu3DiWLVuGzWbjlltuASAzM5OuXbuyePFiQB/PceLECUaMGMGJEydYtGgRHo+HBx54oNFpthSlFHanG6fbc/aDgQT7cQAKzZ0afY4IDacxieL4seyM6s4PJW+S7zpEocpHVd4FDMpAFxVPN08iqSqGboZ40qyJxGCmFChtyocpD1a3jWh3sTdYRLuKK98XYVJOrG4bVreNBMepunnVrNhNCZSZEigyxZJrjCbbbOW4ycwpgwF3jb/zNI+TKJxEAalVH68ZqTB0wmWIxmmMptxgwKZ5cFBGhcdGhSqt8ShD4cGhSnC4S/yWRoxYvVVaFi2u8qG/1ksj7a8x26Bc3hu/ppwYa7w3VL33ONHwf18wYqaswkW02dhipbmAAsXGjRv59NNPvTfs2ubNm8dll13GRRc1ckrpStdffz1nzpzh4Ycf5tSpU4wYMYKPPvrI2xh99OhRnxJMeXk58+fP59ChQ8TFxfHLX/6S1atXk5SU1Og0W4rd6WbQwx83+vgrLdlggKXZQ/nsxMEWzJkICkM5MT2fw2itHvfgtnfDWTgWZ/FwijxR1N9dIlgUyZTQQ8uhu5ZDD+00PQzVrztphZiVA7PzDAnOM3QG+tc4u1yZOao6cUSleR9HVRpHVCdOqI44m3x7cKOZizCY8zFY8tHM+b6vTWW4cWBXDuzuuqURpYwoZxKeimQ8zmQ8FcmoymePMwU8smphfd56+GP2PDqFGEvLtB8FNI7isssuIzExkXXr1vnd/7vf/Y7CwkI++uijZmcwHAQy4K6swtWEQKH43nobCZqdSxxPcVBJr6dwZ4w5SEyPl1EeE87CMTgLx+FxpIc6Wz5iKKe7drpGIMnxvu+q5WLS6i+5upXGSZXKEdWJoyqNwz6BJI0yArhpG8p9A4elMpCY89EsBWhnGTui3FaUqroRavpDVb32t02r3qf0Z+Vnm89xaJXba+7Du0352Vb/Zzf2/NqfTYPblL88KgM77nquSYGixcdR7Nq1y6d6p7bx48fz17/+NZCk24xos5E9j07hmf8cOOuxUc4iErbpjf3Xj82gMKZXS2dPNNPR8ly+KIJYUxIDMgaQ0juVFHM6ZkPzJhTUlKty/EUZZncZFrcdk8euv696dpdh9FQ0MeV4IB43fTkEZCk3VncpMZVtIT5VW+5ijLjI0M6QwRngxzqplRgs5JmiyTPF+DznmmKwGcw+7Wx69VWUXn1liMZljMJpiMWjJQA99WOUB6eyU6FqVmfZqPCU4lSluHCgGR1oOOrkRYDJYCLa3HK9qwIKFEVFRcTGxta7Pzo6moKCgoAz1RZomkaMxYTZePY619QyfenTCkMM9tgemGV9hLDnxgZAvKkTwxOuDGLdugWPyUI5HShv4ChNuWoEkzLMbjsWt837bHHbMbvLKntl+as00MAYT5klnjJqlWCVwuyxexvUqxvW9Wezx0G8p4L4igp6VhTVSdmhGckzRZNvjibPFEWeKYZ8UxR55miKjFGoyiDiNlhwVgYPp7HqOYXqFpJqbuXUe2R5K0BU5f9rfrfa2xQoj7ee36BcaMqFwePCgAuDx42GU9+mPDXO8r1e/rb7fqqqs62+7arO//VnDYVBKYx4MCiFAQ9GpXduMFR2cjCi0JTC6N2mvM/dO/Zs0d5mAQWKrl27sm3btnr3b9u2Ley6n4azRIceKGyWZDwGWSIkEjiUHijijKkhaYBVmkkfY2E6S1Wo8vgElOqSic0nuJjdZd6KETQNpzEGpzHG7/xWVbMIWGsFkihXsT4qXblJd5aS7qzbbO9Co9AUVSOQ6I98UzT5pihcBhNOQ1SNwKE/Y7D49JgyVN74jZ6KysbeCozKicHjwqgqt6mKyt5kDTHR0G3QoDyYlQeLx41JebAoN2blwVz17HFjUZ4a+6q21zhG6ceYPbXOrXrt8WCup6G60XKzz35MMwR0V7ryyit54YUXuP7665k8ebLPvo0bN/Laa69x2223BSWD7UHVYLtiq6zvESkcHv0maDXEhTgnZ6EZqDDFUWGKqywD1UMpTJ7yytJI3RJKzeCCwYLNkorNUvcvf025sLpKfUohZlcRVlcRsS4bJjykuuykuuz4KzIVGa3kmaLIN0WTZ9YDSJ4pmjxzHCWmOL0k4HZiVi795lvzxu3v5uy9Qde6Ode4yddNo3qbsbUHXQBODDgNBpyaEadmqHxUvjYYqaj5XjPiNpiZNPpGfRr9cOr19NBDD/HOO+8wZcoUrrjiCu+kfzt37uTDDz+kc+fOLFiwIJj5bNOqAkVBtMzxFCkqPPpt16LVXwUbUTQNlzEalzEa/7NHVTO6y7H4lErKMHuru6qrvepMa1JZurG6ijC4CjC4CrG4i4l1lpDoshGl3CS6HSS6HfR2+K/S0lBYzlpKCD4P+Nyc9Zu2gQrNiEvTn6tu5D7HVL6uMFQd53uTr52GSzN4q+Yay4SZSRfc3zJf3PsZAUhLS2Pz5s3ceeedfPjhh3zwwQeAXi9/xRVX8Mwzz8jqd02QUK4XG3Nj+oQ4J6KxHCpCShQtwG2Mwm6Mwm7u0OBxBo/TT6mkZjWYvs/kceiN2Z5S3K58NHcBFlcRMa5SklxlpLjsJLgrsKq6vaJcaN4bbs2bs/fmW+fGbaTCYKhxc69xQ691bM2bvxsNAxparWcDVD7X3Fa93Xebvl1Dw4SGueo4VWO/0tCUb7q1P6/25yhDy083FHCFeI8ePfjggw8oKCjgwAG9Z0/fvn3p0KHhXx5RV3yFPlCqKKr+aVBEePGWKAxtpERRh8KkgVlTBDyc2GAAUzwu4nE1cJim3Jg9DkzuMsweh95m4inH5LZzzF2Mw11EhbsAgzsfDwbcmgGlmfBoBtCMlTdSqm+kyv+NteoYKp+taET53IipkY7m/c9Q47xw5DFYKC/X6/FMJhNGY/AH3jW75bRDhw6MHTs2GHlpt2IrcgEotTZuISUReo7KQNH2ShSKFLOL7jEurEYNQ6vdH81AY5ee9RmNgL9+RZryt696JEPtfVqd4WT1fIbS/6f5Obbm+9YMKwrIysryvjcajXTq1InExMSgBYxmB4rS0lIKCwvxeOrWG3bv3r25yUe8sy4o4iiFr/Sbzswp50FUC67JLYJm43sV5DrhpnEDGJ3WsstQtqbs7GwKCwtJSEglISEBk8kUlpP8RQxVWSKrDDCVG33fq1rBy+++2s+1zrPGoZTC5XJRXFxMdnY2drs9aE0AAQeKt956i8cff5y9e/fWe0zVuhCiASWV3drMsRIkIkhRZWNrgqXt/MzcbjdFRUV07NiR1NS6PZpEZIiPj8dqtZKbm0unTp0wGps/EC+gDuDvv/8+06dPx+Vy8fvf/x6lFDfccAO/+c1vMJvNjB49mocffrjZmWsXivUeT8TLuJNIoZSipKIEgERrY6tLwp/T6UQp1eBgWhEZYmNjUUrhdAZnbY+AAsWSJUsYOHAgO3fu5NFHHwVg1qxZvPXWW2zdupV9+/Y1ep3sdq9YH2xHojRkR4oyVxnuyh44balEUUWqmiJfsH+GAQWK77//npkzZxIVFeWdzbWqmmnIkCHMnj273pllRS1VJYrEll1qVQRPsUNfF8JisBBlkhlNRdsXUKBwu92kpKQA+rxOoM//VKV///7s3r07CNlrBwr1dShIlBljI0VxhR4oEqxtrzQhhD8BBYpu3bpx5Ii+dGd0dDSdOnXymftp3759Us/ZWIX6ynYkhNcU1aJ+3kDRBqudhPAnoF5P5513Hp9++qm3fWLq1KksW7aM6OhoPB4Pzz77LFdddVVQM9pmVVU9JUiJIlJUVT1JoBDtRUAlij/84Q9MmjQJu11fQ+GJJ56gf//+LFq0iEcffZQ+ffqwZMmSoGa0zSqtXL5SShQRQ6qe2o5Dhw4xe/ZsBgwYQExMDB06dGDgwIHMnDmTzz77rM7x69ev58orr6RTp05YLBbS09O59tpr+eKLL3yOW7RoEZqmNepx8803t9K3DVxAJYqxY8f6jMbu2LEjO3fu5Pvvv8doNDJw4ECfJUtFPZx2KK9s25FAETGk6qlt2Lp1KxdeeCFms5nMzEwGDx6M3W5n//79bNiwgfj4eO9yzm63m1tuuYXVq1czaNAg7r33Xrp06cKRI0d4/fXXmTRpEvPmzePJJ58E4Ne//jV9+/b1+bz77rsPgKefftpne58+4T/HW5MDhc1m429/+xvjx49nypQpPvuGDRsWtIy1C1VdY01REJUU0qyIxmuLg+3ao0ceeYSysjJ27tzJ8OHD6+w/deqU9/WiRYtYvXo1mZmZrFixApOp+tb54IMPcvXVV7N48WL69u3LrFmzGDZsWJ374fz58wG46aabWugbtZwmB4rY2FiefPJJnnnmmZbIT/tSFSji0lpsHnkRfO2t6kkphd0ZnrMsRJsDnwBv//79pKSk+A0SgHfxtdOnT7NkyRK6d+/Oiy++6BMkAGJiYnjjjTfo3bs38+fP56abbsJisQSUp3AVUNVTnz59fKKtCFBVoJCG7IjS3hqz7U43gx7+ONTZ8GvPo1OIsQQ2E1GfPn3Yt28f7777Lr/+9a/rPe7f//435eXlzJgxg6go/+NmOnXqxNVXX83atWvZsmULF154YUB5ClcBN2a//PLL5OXlBTs/7UtVj6ckGWwXSaSNom2YP38+ZrOZa6+9ln79+jFr1iyef/75OvPXVY0JGzVqVIPpjR49GoAffvihZTIcQgGF4vj4eJKTk+nfvz8zZ87knHPOISYmps5xmZmZzc5gm+advkMCRSRpb4Ei2mxkz6NTzn5gCESbA5/w7txzz2Xbtm387W9/48MPP2TVqlWsWrUKgIkTJ/Lqq6/Su3dviov1n3diYsPzeiUk6L8PNQcftxUBBYqa3blqt+BX0TRNAsXZFFWOypYeTxGlvbVRaJoWcPVOuBs6dCivvvoqAEeOHOGLL77glVde4csvv+Tqq69m27ZtjQ4AjQ0okSign76//sUiAMVVgULaKCKJ9Hpqm3r06EFmZiYzZsxg4sSJfPXVV3z77bcMGTIEgO3btzfYlrF9+3ZADz5tTUCBoq011IRMSY7+LFOMR4yaU4xLoGibNE1j/PjxfPXVV5w4cYJf/vKXWK1W1qxZw4IFC7Ba665RfebMGdavX0+XLl0499xzQ5DrliWj4kKpvFB/jkkOaTZE4/lMMd5Oqp7aqk8++QSXq+5q3na7nQ0bNgAwaNAg0tLSmDNnDkeOHOHOO++ssyCb3W5nxowZlJaW8vjjj7e5rrEQYImiao6nhmiaxoIFCwJJvn1w2sFdob+WwXYRo6prrNlgJsooU4xHsvvuu4+8vDymTp3K0KFDiYmJ4dixY6xdu5aff/6ZzMxMbzXSo48+ypEjR1i1ahXfffcdN9xwg8/I7KysLObOncusWbNC/K1aRkCBYtGiRfXu0zQNpZQEirOxF+rPmgGs8SHNimi8mj2eZIGfyLZ06VLWr1/Ppk2beOeddygsLCQxMZFhw4bx4IMP+nTaMZlMvPHGG1x33XW89NJLPP300xQVFZGcnMx5553HypUrmTRpUsi+S0sLKFBkZWXV2eZyuTh48KD3Ar722mvNzlybVjXHkzVeRmVHkPbW46ktu+yyy7jsssuadM60adOYNm1aQJ93+PDhgM4LBwEFih49evjd3qdPHy699FIuuOACVq1a5Z0gS/hR1T4h1U4Rpb2NyhYCWqAxW9M0rrvuOl5//fVgJ922VFU9RSeFMheiidrbYDshoIV6PVVUVMj0HmdTVaKIlh5PkUSqnkR7FPRAsXXrVv7+978zcODAYCfdtkiJIiJVDbZLtLS90bdC1CegNorevXv73Z6fn09JSQkmk4lXXnmlWRlr87xtFHLDiSRSohDtUUCBonv37nW6BmqaxqhRo+jXrx+zZ8+mZ8+ewchf21XV60kasyOKtFGI9iigQPH5558HORvtkFQ9RSQJFKI9kik8QkW6x0akEofM8yTan4ACxdtvv93gFOIzZ87kn//8Z8CZahfK8vVnaaOIKEUVlTPHShuFaEcCChTPPPMMBkP9pxqNRpYvXx5wptqF8gL9WaqeIooMuBPtUUCBYu/evYwcObLe/SNHjmTPnj0BZ6pdkMbsiKOUkjYK0S4FFChsNhtGY/1LEGqaRklJScCZaheqAoWUKCKGTDEu2quAAkWvXr3YtGlTvfs3bdpE9+7dA85Um+d26tOMg5QoIohMMS7aq4ACxbRp01i3bh0rVqyos2/lypWsW7euwSUD272qrrEgjdkRRKYYb3teffVVNE3zrptd2+HDh9E0zWfK8aKiIh5//HFGjBhBUlIScXFx9OrVi2uuuabegcbff/89M2fOpEePHlitVpKTk7noootYtWqVz0JIn3/+OZqmNerRmmPVAhpHMXfuXNavX8/s2bN5+umnGTFiBAC7du1iz5499O/fnz/96U8BZejZZ5/lqaee4tSpUwwfPpzly5czbty4eo9ftmwZzz//PEePHiU1NZXrrruOxYsXExWl/8W3aNEiHnnkEZ9z+vfvz08//RRQ/oKiqmusJQ4M9VfhifAio7JFcXExY8eO5dChQ1x33XXMmjULi8XCoUOH2LRpE3//+9+57bbbfM55/vnnueeee+jQoQM333wzAwYMoKCggHfeeYdZs2bx5ptv8t577xEbG8vAgQNZvXq1z/kvvfQSX375JU8//TSpqane7XFxca3ynQFQASosLFR33nmnSk5OVpqmKU3TVHJysrrrrrtUQUFBQGm+9dZbymKxqJUrV6off/xR3X777SopKUnl5OT4Pf6NN95QVqtVvfHGGyorK0t9/PHHqkuXLuq+++7zHrNw4UI1ePBglZ2d7X2cOXOmSfkqKipSgCoqKgroe9Vx7DulFiYo9beBwUlPtIpPD3+qhrw6RN347xtDnZUWYbfb1Z49e5Tdbg91VlrNqlWrFKBWrVrld39WVpYC1MyZM5VSSi1ZskQBatmyZX6Pz87O9nm/YcMGpWmaGjZsmN/7zkMPPaQANWPGjHrzOHPmTAWorKysRn0npRr3s2zKfS3gAXeJiYk899xz5ObmkpOTQ05ODrm5uTzzzDMkJSUFlObSpUu5/fbbueWWWxg0aBAvvPACMTExrFy50u/xmzdvZsKECUyfPp2ePXty2WWXccMNN/Dtt9/6HGcymejcubP3UTMq++NwOCguLvZ5BJWMyo5I0uNJ7N+/H4BLLrnE7/7OnTv7vJ87dy4Aa9eu9Xvfeeyxxxg/fjyrV6/mhx9+CHJug6fZI7M1TaNjx4507NixWfW2FRUVbNu2jcmTJ1dnzmBg8uTJbNmyxe855513Htu2bfMGhkOHDvHBBx/wy1/+0ue4/fv3k56eTu/evbnxxhs5evRog3lZvHgxiYmJ3kdGRkbA38sv76jsDsFNV7Sodlv1pBRU2MLzoVSrXoo+ffoAsGrVKlwuV4PHZmVlsX37ds477zwGDx7s9xhN07j11lsBePfdd4Ob2SAKqI3i2Wef5b333uPTTz/1u/+yyy7j2muv5fe//32j08zNzcXtdpOWluazPS0trd72hOnTp5Obm8v555+PUgqXy8Udd9zh0z4yfvx4Xn31Vfr37092djaPPPIIEydOZPfu3cTH+1+ret68ecyZM8f7vri4OLjBwi6D7SJR1RTj7a5E4SyDJ9NDnQv//nQSLLGt9nG33XYby5cvZ+nSpaxZs4aJEycyduxYJkyYwHnnneczEHn37t0AjBo1qsE0R48eDdD2ShSvvvoq55xzTr37+/XrV291UTB9/vnnPPnkkzz33HNs376dd999l3//+9889thj3mOuuOIKfvOb3zBs2DCmTJnCBx98QGFhIf/4xz/qTddqtZKQkODzCCrvokVJwU1XtCipehIdOnRg27ZtPPjggyQmJvLOO+8wd+5cJk6cSJ8+fdiwYYP32Koq68TEhns2Vt1fioqKWi7jzRRQiWL//v3ccsst9e4fPHgwa9eubVKaqampGI1GcnJyfLbn5OTUqfersmDBAmbMmOHtZTB06FBsNhuzZ8/moYce8jvNSFJSEv369ePAgQNNyl9QyajsiNRuA4U5Rv/LPRyZY1rlY2pWq3fs2JE///nP/PnPfyYvL48tW7bwj3/8gzVr1jBt2jR27dpF3759Gx0AGhtQQimgEoXT6aS8vLze/eXl5Q3u98disTB69Gg2btzo3ebxeNi4cSPnnnuu33PKysrqBIOqEeOqnrrL0tJSDh48SJcuXZqUv6CSxuyI1G7bKDRNr94Jx0czx7NER0cD+r3EH5vN5nNcbSkpKfzqV7/i9ddfZ968eZSVlfHWW28BMGTIEAC2b9/eYB6q9g8dOrTpX6CVBBQo+vXrxyeffFLv/g0bNngbfZpizpw5vPzyy7z22mvs3buXO++8E5vN5i29ZGZmMm/ePO/xV111Fc8//zxvvfUWWVlZfPLJJyxYsICrrrrKGzDuv/9+vvjiCw4fPszmzZuZNm0aRqORG264ocn5CxqZYjwiyRTjbU+vXr0Aff46f6q2Vx3XkF/84hcAnDhxwnvOiBEj2Lx5c73pK6W8A5enTZvWtMy3ooACxQ033MCGDRtYsGABFRUV3u1Op5OFCxeyYcMGpk+f3uR0r7/+epYsWcLDDz/MiBEj2LlzJx999JG3gfvo0aNkZ2d7j58/fz5//OMfmT9/PoMGDeLWW29lypQpvPjii95jjh8/zg033ED//v357W9/S0pKCl9//TUdO3YM5KsHR1VjtgSKiOKdYlwCRZsxatQoMjIyeOuttzh50rd6raKigmeeeQZN05g6dSoAW7ZsobCw0G9a77//PgCDBg3yblu8eDEAN954I3l5eXXOWbRoEV9//TUzZsxg2LBhQfhGLaTRIzhqqKioUJMmTVKapqmUlBQ1YcIENWHCBJWSkqI0TVMXXHCBcjgcgSQdloI+4O7Zc/UBdz9vCE56olVMfHOiGvLqELUvf1+os9Ii2uOAO6WU+te//qXMZrNKSUlRDzzwgHrxxRfVo48+qgYPHqwA9ac//cl77F133aViYmLUb37zG/XUU0+plStXqqeeekpddNFFClCDBg1SpaWlPukvX75cGQwG1bFjR/XAAw+oFStWqCVLlqjzzjtPAerSSy+tc05N4TDgLqDGbLPZzIYNG3j66adZu3YtO3bsAPQqqblz5/I///M/PvOXiFqk6iniKJlivM268sor+eqrr/jrX//Ka6+9Rl5eHrGxsYwcOZK3336b3/72t95j77jjDpKSkvjss89YunQpubm5WK1W+vbty8KFC5kzZw6xsb7dde+++24mTJjA0qVLWbt2LTk5OcTGxjJ8+HBWrlxJZmZmg7NxhwNNqeCOWNm2bRsrVqzg7bff9lvUikTFxcUkJiZSVFQUnK6yT3aDihK46zvo2K/56YkWV+YsY/za8QB8e+O3RJv8N25GsvLycrKysujVq5d3rjQRmRrzs2zKfS2gEkVt+fn5rFmzhpUrV/LDDz+glKJfP7kB+uVx60ECpNdTBKkqTcgU46I9atYUHh9//DHXX389Xbt25b777sPhcLBw4UJ++OGH0M7OGs7Ka/SplqqniFFzVLZMMS7amyaXKA4fPszKlSt57bXXOH78uHdq77Vr1/LEE0/IOhRnU9U+YYoCkyWkWRGN127HUAhBE0oUb7zxBpdccgl9+/blL3/5C2PGjOG9997jxIkTLFq0qN4BbqKWqsF2smBRRJGGbNGeNbpEMWPGDHr37s2yZcu44YYbSElJacl8tV3e6TskUESSqmVQJVCI9qjRJQqr1crhw4dZv349H330EXa7vSXz1XZ5JwSUKcYjiVQ9ifas0YEiOzubZcuWkZeXx4wZM+jcuTO33nor//3vf6XaqSmqRmXHJIc2H6JJ2u0U40LQhECRlJTE3Xffzfbt29m6dSs33XQT7733HhdddBHnn38+mqaF9TS5YcO7FoVU3UUSaaMQ7VlA3WNHjRrFs88+S3Z2NqtXr/au3nTbbbcxYsQIHn/8cX788cegZrTNKMvXn2UMRUSRQCHas2aNo7BarUyfPp2NGzdy8OBBHnroIQoKCnj44YcZPnx4sPLYtnhLFNJGEUmkjUK0Z81eM7tKz549efTRRzl8+DAffPCBjKeojy1Xf5Y2iogiU4yL9iwoU3jUpGkal19+OZdffnmwk24b7JXzX0mJIqLIFOOiPQtaiUI0kreNQkoUkcQ7jkKqnkQ7JIGitVUNuJMSRcSQKcbbrkOHDjF79mwGDBhATEwMHTp0YODAgcycOZPPPvvMe5ymaUyaNKnedCZNmlTvHGDff/89M2fOpEePHlitVpKTk7noootYtWqVz3IMn3/+OZqmNerRs2fPYF2CRgl61ZNogFLVgULaKCKG3WXHrfR/0BIo2o6tW7dy4YUXYjabyczMZPDgwdjtdvbv38+GDRuIj4/noosuatZnPP/889xzzz106NCBm2++mQEDBlBQUMA777zDrFmzePPNN3nvvfeIjY1l4MCBrF692uf8l156iS+//JKnn36a1NRU7/a4uLhm5aupJFC0popS8Lj011KiiBhVpQmTwdQm16Forx555BHKysrYuXOn316ap06dalb6n3zyCXfddRdDhw5l48aNPjf6+++/n/nz5/PEE09w55138vrrr5OWlsZNN93kk8ann37Kl19+yTXXXNPqpYiapOqpNVV1jTWYwRwT2ryIRpMpxtum/fv3k5KSUm9X/s6dOzcr/blz5wKwdu1anyBR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bjIyMpqZ69bRmtcmkjX3Op08eZKuXbt633ft2pUTJ04ElBcJFI1gs9kYPnw4zz77rN/9jVlFr6qOvfbj5MmTrF+/nn79+tGvX7/W+kpB09LXBvSZe3ft2kVWVhZr166tM8ljOGqN6wKQn59PZmYmL730Uot/p2BprWsT6YJxnYImlMPCIxFQZyGkcePGqbvuusv73u12q/T09EZPPDh37lzVrVs31aNHD5WSkqISEhLUI488Esxst4qWuDa13XnnnWrdunXNyWara6nrUl5eriZOnKhef/31YGW11bXk78xnn32mrr322mBkM+QCuU5fffWVuuaaa7z77733XvXGG28E9PlSomimiooKtm3bxuTJk73bDAYDkydPZsuWLY1KY/HixRw7dozDhw+zZMkSbr/9dh5++OGWynKrCca1ycnJoaREX7e6qKiI//73v/Tv379F8ttagnFdlFLcfPPNXHzxxcyYMaOlstrqgnFt2oPGXKdx48axe/duTpw4QWlpKR9++CFTpkwJ6PPCavbYSBToKnrtQTCuzZEjR5g9e7a3Efuee+5h6NChLZHdVhOM6/LVV1/x9ttvM2zYMG/d9erVq+XaVJo8eTK7du3CZrPRrVs31q1bx7nnnhvs7IZMY66TyWTib3/7GxdddBEej4cHHngg4N6CEijCzM033xzqLISVcePGsXPnzlBnI+ycf/75eDyeUGcjbH366aehzkJYmDp1KlOnTm12OlL11EwttYpeWyDXxj+5LvWTa9M4rX2dJFA0k8ViYfTo0WzcuNG7zePxsHHjxjZV1A2EXBv/5LrUT65N47T2dZKqp0YoLS3lwIED3vdZWVns3LmT5ORkunfvHtJV9EJNro1/cl3qJ9emccLqOgXUV6qd+eyzzxRQ51Fztb32uoqeXBv/5LrUT65N44TTdZK5noQQQjRI2iiEEEI0SAKFEEKIBkmgEEII0SAJFEIIIRokgUIIIUSDJFAIIYRokAQKIYQQDZJAIYQQokESKIQQQjRIAoUQQogGSaAQQgjRIAkUQoSJM2fOcPPNN3vXGkhPT+eRRx5BpmMToSaTAgoRBnbv3s3kyZNJSkpixowZREVF8fLLL7Nv3z6WL1/O3XffHeosinZMAoUQIVZeXs7gwYPp1q0bH374ITExMQBkZ2fTvXt3hgwZwo4dO0KcS9GeycJFQoTY8uXLOXz4MJ988ok3SAB06dKFwYMHc/z48RDmTggpUQgRcuPGjcNisbBp06Y6+/r164emaezbty8EORNCJ43ZQoRQQUEBW7duZcyYMXX25efnk5WVxcSJE0OQMyGqSaAQIoR27NiBUoq4uLg6+9auXYvL5eJ3v/tdCHImRDUJFEKEUFUj9caNG326we7bt4/58+dzySWXcPHFF4cqe0IA0pgtREht376dTp06ceTIEaZOncoVV1zBoUOHePHFF0lOTmb16tUYDPL3nAgt+Q0UIoR27NjByJEjWb9+PWfOnOGPf/wja9as4cYbb+S7776jS5cuoc6iEFKiECJUysrK2LdvH7/61a8YO3YsX3/9daizJIRfUqIQIkR27dqFx+Nh6NChoc6KEA2SQCFEiFQ1ZA8bNizEORGiYRIohAiRHTt2YDKZGDhwYKizIkSDZGS2EEKIBkmJQgghRIMkUAghhGiQBAohhBANkkAhhBCiQRIohBBCNEgChRBCiAZJoBBCCNEgCRRCCCEaJIFCCCFEgyRQCCGEaND/A1Oa2aweF9FkAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "m_rsw = np.mean(L_mean_rsw_v2, axis=1)\n",
    "s_rsw = np.std(L_mean_rsw_v2, axis=1)\n",
    "\n",
    "m_suw = np.mean(L_mean_suw, axis=1)\n",
    "s_suw = np.std(L_mean_suw, axis=1)\n",
    "\n",
    "m_sw = np.mean(L_sw) * np.ones(len(rhos))\n",
    "s_sw = np.std(L_sw) * np.ones(len(rhos))\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4,2)) #, gridspec_kw={\"width_ratios\":[1,2]})\n",
    "\n",
    "plt.plot(rhos, m_sw, label=\"SOT\")\n",
    "plt.fill_between(rhos, m_sw-2*s_sw/np.sqrt(3), m_sw+2*s_sw/np.sqrt(3), alpha=0.5)\n",
    "\n",
    "plt.plot(rhos_rsw, m_rsw, label=\"USOT\")\n",
    "plt.fill_between(rhos_rsw, m_rsw-2*s_rsw/np.sqrt(3), m_rsw+2*s_rsw/np.sqrt(3), alpha=0.5)\n",
    "\n",
    "plt.plot(rhos, m_suw, label=\"SUOT\")\n",
    "plt.fill_between(rhos, m_suw-2*s_suw/np.sqrt(3), m_suw+2*s_suw/np.sqrt(3), alpha=0.5)\n",
    "\n",
    "# plt.plot(rhos, acc_w * np.ones(len(rhos)), label=\"OT\")\n",
    "# plt.plot(rhos, L_mean_sinkhorn, label=\"Sinkhorn\")\n",
    "# plt.plot(rhos, L_mean_sinkhorn[-1] * np.ones(len(rhos)), label=\"Sinkhorn\")\n",
    "\n",
    "\n",
    "plt.xlabel(r\"$\\rho$\", fontsize=13)\n",
    "plt.ylabel(\"Accuracy\", fontsize=13)\n",
    "plt.xscale(\"log\")\n",
    "plt.ylim(0.8, 0.94)\n",
    "# plt.grid(True)\n",
    "plt.legend(fontsize=13)\n",
    "# plt.title(\"Accuracy - BBCSport\", fontsize=13)\n",
    "\n",
    "# plt.savefig(\"./Figures/ablation_rho_BBC_noW_v3.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "\n",
    "# plt.grid(True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Ablation FW"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "iters = [1,2,3,4,5,10,15,20,25,50,75,100]\n",
    "rho = 0.0005\n",
    "rho_suw = 0.01\n",
    "    \n",
    "L_mean_rsw = np.zeros((len(iters), 3))\n",
    "ts_rsw = np.zeros((len(iters), 3))\n",
    "    \n",
    "L_mean_suw = np.zeros((len(iters), 3))\n",
    "ts_suw = np.zeros((len(iters), 3))\n",
    "\n",
    "for k in range(3):\n",
    "    for i, n_iter in enumerate(iters):\n",
    "        d_sw = np.loadtxt(\"./results_inner_iter/d_projs500_rsw_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_iter\"+str(n_iter)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_rsw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "        t_sw = np.loadtxt(\"./results_inner_iter/ts_projs500_rsw_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_iter\"+str(n_iter)+\"_k\"+str(k))\n",
    "        ts_rsw[i, k] = np.mean(t_sw)\n",
    "        \n",
    "        d_sw = np.loadtxt(\"./results_inner_iter/d_projs500_suw_BBC_rho1\"+str(rho_suw)+\"_rho2\"+str(rho_suw)+\"_iter\"+str(n_iter)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_suw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "        t_sw = np.loadtxt(\"./results_inner_iter/ts_projs500_suw_BBC_rho1\"+str(rho_suw)+\"_rho2\"+str(rho_suw)+\"_iter\"+str(n_iter)+\"_k\"+str(k))\n",
    "        ts_suw[i, k] = np.mean(t_sw)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9163636363636364"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "d_sw = np.loadtxt(path + \"d_w_BBC_k0\")\n",
    "acc_w = np.mean(get_acc_knn(d_sw, y, idx_train, idx_test))\n",
    "\n",
    "acc_w"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.8939393939393939 0.007618063690894892\n"
     ]
    }
   ],
   "source": [
    "L_sw = np.zeros((3,))\n",
    "\n",
    "for k in range(3):\n",
    "    d_sw = np.loadtxt(path + \"d_projs500_sw_BBC_k\"+str(k))\n",
    "    acc_sw = np.mean(get_acc_knn(d_sw, y, idx_train, idx_test))\n",
    "    L_sw[k] = acc_sw\n",
    "    \n",
    "print(np.mean(L_sw), np.std(L_sw))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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JCBq1LVrV9LT0y2P7du3Ozskl5CXl0ePHj149913bS5/4403+Pvf/86iRYvYtWsXfn5+DB48mIKCgkaO1Lmu9T0BDBkyxOo39sknnzRihM63bds2Jk6cyHfffcfmzZspLi5m0KBB5OXlWco899xz/Oc//+Gzzz5j27ZtpKWl8cADDzgmACVENWbOnKl69Ojh7DBcHqDWrl1reW02m1VUVJT661//apmXnZ2tvLy81CeffOKECF1D5e9JKaUSExPV/fff75R4XNW5c+cUoLZt26aU0n87JpNJffbZZ5Yyv/zyiwLUzp076/1+ciQganTkyBFatGhBu3bt+P3vf8+pU6ecHZLLO378OGfPnmXgwIGWeYGBgSQkJLBz504nRuaakpKSiIiIoFOnTjz55JNkZWU5OySnysnJASAkJASA5ORkiouLrX5PnTt3pk2bNg75PUkSENVKSEhg2bJlbNy4kYULF3L8+HH69etn6X5b2Hb27FkAIiMjreZHRkZalgndkCFD+Oijj9iyZQtz585l27Zt3H333ZSWljo7NKcwm808++yz9O3blxtuuAHQf0+enp4EBQVZlXXU78ntexEV1bv77rst0927dychIYHo6Gj+9a9/MX78eCdGJq4XDz30kGW6W7dudO/endjYWJKSkrjzzjudGJlzTJw4kQMHDjTquTc5EhC1FhQURMeOHTl69KizQ3FpUVFRAFWu3sjIyLAsE7a1a9eOsLAwt/yNTZo0if/+979s3brVqnv7qKgoioqKyM7OtirvqN+TJAFRa5cvX+bXX3+lefPmzg7FpcXExBAVFcWWLVss83Jzc9m1axe33HKLEyNzfWfOnCErK8utfmNKKSZNmsTatWv56quviImJsVreq1cvTCaT1e8pJSWFU6dOOeT3JM1Bolp//vOfGTZsGNHR0aSlpTFz5kyMRiMPP/yws0NzusuXL1vtrR4/fpx9+/YREhJCmzZtePbZZ3nllVfo0KEDMTExvPjii7Ro0YLhw4c7L2gnqOl7CgkJYfbs2YwcOZKoqCh+/fVX/vKXv9C+fXsGDx7sxKgb18SJE1m5ciXr16/H39/f0s4fGBiIj48PgYGBjB8/nsmTJxMSEkJAQABPP/00t9xyCzfffHP9A6j39UXiujVq1CjVvHlz5enpqVq2bKlGjRqljh496uywXMLWrVsVUOWRmJio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",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "k = 8\n",
    "\n",
    "m_rsw = np.mean(L_mean_rsw, axis=1)\n",
    "s_rsw = np.std(L_mean_rsw, axis=1)\n",
    "\n",
    "m_suw = np.mean(L_mean_suw, axis=1)\n",
    "s_suw = np.std(L_mean_suw, axis=1)\n",
    "\n",
    "m_sw = np.mean(L_sw) * np.ones(len(iters))\n",
    "s_sw = np.std(L_sw) * np.ones(len(iters))\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4,2)) #, gridspec_kw={\"width_ratios\":[1,2]})\n",
    "\n",
    "plt.plot(iters[:k], m_sw[:k], label=\"SOT\")\n",
    "plt.fill_between(iters[:k], (m_sw-2*s_sw/np.sqrt(3))[:k], (m_sw+2*s_sw/np.sqrt(3))[:k], alpha=0.5)\n",
    "\n",
    "\n",
    "plt.plot(iters[:k], m_rsw[:k], label=\"USOT\")\n",
    "plt.fill_between(iters[:k], (m_rsw-2*s_rsw/np.sqrt(3))[:k], (m_rsw+2*s_rsw/np.sqrt(3))[:k], alpha=0.5)\n",
    "\n",
    "\n",
    "plt.plot(iters[:k], m_suw[:k], label=\"SUOT\")\n",
    "plt.fill_between(iters[:k], (m_suw-2*s_suw/np.sqrt(3))[:k], (m_suw+2*s_suw/np.sqrt(3))[:k], alpha=0.5)\n",
    "\n",
    "# plt.plot(iters, acc_w * np.ones(len(iters)), label=\"OT\")\n",
    "# plt.plot(rhos, L_mean_sinkhorn, label=\"Sinkhorn\")\n",
    "# plt.plot(rhos, L_mean_sinkhorn[-1] * np.ones(len(rhos)), label=\"Sinkhorn\")\n",
    "\n",
    "\n",
    "plt.xlabel(\"Iterations FW\", fontsize=13)\n",
    "plt.ylabel(\"Accuracy\", fontsize=13)\n",
    "# plt.xscale(\"log\")\n",
    "# plt.ylim(0.8, 0.93)\n",
    "# plt.grid(True)\n",
    "# plt.xticks(iters)\n",
    "plt.legend(fontsize=13)\n",
    "# plt.title(\"BBCSport\", fontsize=13)\n",
    "plt.savefig(\"./Figures/ablation_fw_BBC.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Ablation Projections"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "projs = np.logspace(0, 3, 10, dtype=int)\n",
    "rho = 0.0005\n",
    "rho_suw = 0.01\n",
    "    \n",
    "L_mean_rsw = np.zeros((len(projs), 3))\n",
    "L_mean_sw = np.zeros((len(projs), 3))\n",
    "L_mean_suw = np.zeros((len(projs), 3))\n",
    "\n",
    "for k in range(3):\n",
    "    for i, n_projs in enumerate(projs):\n",
    "        d_sw = np.loadtxt(\"./results_projs/d_projs\"+str(n_projs)+\"_rsw_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_rsw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "        \n",
    "        d_sw = np.loadtxt(\"./results_projs/d_projs\"+str(n_projs)+\"_sw_BBC_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_sw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "        d_sw = np.loadtxt(\"./results_projs/d_projs\"+str(n_projs)+\"_suw_BBC_rho1\"+str(rho_suw)+\"_rho2\"+str(rho_suw)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_suw[i, k] = np.mean(L_acc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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yb6lnip79+5t0VZSUkJtba33m2RMTAzh4eGYTKYOP2g7S//+/fF4POzdu7fFqmvPnj1A6yul00VMTAwhISH8+uuvLY7V1NRQUlLCsGHD2h1jwIABVFRUcP7555/UfJSVlcWKFSsoKytrd1XR3EzXEfr378/XX39NbW0t4eHhPsf27NlDaGhoi439zjBmzBjGjBkDwNGjRxk+fDjz588XQtGA2KMQtMv8+fMJDQ3lgQceaPV4VlYWP/74o4+bZU1NDUuXLu3Wee3fv5/PPvvMp+25554D8O5dqFQqbrzxRrZs2cJHH33U6jjl5eWnNI/Gay1cuNBn5bN7927++9//MnHixB79tq1SqbxurF9//bXPsWeffRaPx3PSh+GsWbMoLS1tc0VRVlbm/f+NN94IwAMPPNBiz6D5/QkODgbocHT5lVdeicfj4dlnn/Vp/+qrr/j555+5/PLL/doDqaysbNGWnJxMTExMn45872rEikLQLtHR0dx///1tbmrfdddd3HTTTZx//vnMnDmT2tpa3nzzTVJTUyktLe22eQ0ePJibbrqJ22+/nQEDBrB27Vo++ugjzjvvPK677jpvv6effpoNGzZw7bXXcu211zJu3Dh0Oh2FhYV8+eWXjBw58pQivKdNm8a1117Lv/71L2pqarjsssu87rEGg4G///3vXfBpT41nnnmGVatWceWVV/KHP/yBzMxMvv/+e5YvX865557L7Nmz2z3/nnvuYdWqVdx///18++23nH/++YSGhlJUVMSaNWswGAysXbsWgP/3//4f1113He+99x4HDx7k8ssvJyIiggMHDvDNN9+we/duAEaPHo1KpeLpp5+mpqaGoKAg0tPTGTt2bKtzuPnmm3n33Xd57rnnKCgo4Nxzz+XQoUP84x//IC4ujmeeecave/PUU0+xcuVKLrvsMtLT05Flmf/973/s27evzS9HZyU96HEl6EWc6B7bHIvFIickJLTqHivLsvz888/L/fr1k3U6nZyTkyMvWbKkXffY/Px8n/Pz8/NlQH788cdbjH3eeefJqampPm00uOSuWrVKHjNmjGwwGOTY2Fj5rrvukk0mU6vzf/LJJ+VBgwbJBoNBDg4OlnNycuTbbrtN3rRpk7dfey6b7eF0OuVnn31WzsnJkXU6nRwRESFfccUV8q5du1r09cc9trV7fiKN7rFtceTIEfmmm26SY2JiZK1WK6enp8vz5s1r4Qbc1j1wOp3ySy+9JI8aNUoODAyUAwMD5czMTPmGG26Qv/nmG5++brdbfuWVV+Thw4fLAQEBcnBwsDx48GB5wYIFPv3eeecdOTc3V9ZqtT5u1q25x8qyLJvNZvmhhx6S09PTZa1WK8fExMg33XSTjwt3e+e3dp/Wrl0rX3vttXJqaqpsMBjkiIgIecyYMfKbb77p4+58tiNyPQkEAi9LlizhtttuY/369S2CHAVnL2KPQiAQeDl+/DhAi/gMwdmNWFEIBAKOHDnC559/zrPPPovBYODw4cOd9kwSnLmIFYVAIOD777/n4YcfJjMzkxUrVgiREPggVhQCgUAgaBexohAIBAJBuwihEAgEAkG7CKEQCAQCQbsIoRAIBAJBuwihEAgEAkG7CKEQCAQCQbsIoRAIBAJBuwihEAgEAkG7/P8T17wh+mXpWgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "m_rsw = np.mean(L_mean_rsw, axis=1)\n",
    "s_rsw = np.std(L_mean_rsw, axis=1)\n",
    "\n",
    "m_suw = np.mean(L_mean_suw, axis=1)\n",
    "s_suw = np.std(L_mean_suw, axis=1)\n",
    "\n",
    "m_sw = np.mean(L_mean_sw, axis=1)\n",
    "s_sw = np.std(L_mean_sw, axis=1)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4,2)) #, gridspec_kw={\"width_ratios\":[1,2]})\n",
    "\n",
    "plt.plot(projs, m_sw, label=\"SOT\")\n",
    "plt.fill_between(projs, m_sw-2*s_sw/np.sqrt(3), m_sw+2*s_sw/np.sqrt(3), alpha=0.5)\n",
    "\n",
    "\n",
    "plt.plot(projs, m_rsw, label=\"USOT\")\n",
    "plt.fill_between(projs, m_rsw-2*s_rsw/np.sqrt(3), m_rsw+2*s_rsw/np.sqrt(3), alpha=0.5)\n",
    "\n",
    "\n",
    "plt.plot(projs, m_suw, label=\"SUOT\")\n",
    "plt.fill_between(projs, m_suw-2*s_suw/np.sqrt(3), m_suw+2*s_suw/np.sqrt(3), alpha=0.5)\n",
    "\n",
    "# plt.plot(projs, acc_w * np.ones(len(projs)), label=\"OT\")\n",
    "# plt.plot(rhos, L_mean_sinkhorn, label=\"Sinkhorn\")\n",
    "# plt.plot(rhos, L_mean_sinkhorn[-1] * np.ones(len(rhos)), label=\"Sinkhorn\")\n",
    "\n",
    "\n",
    "plt.xlabel(\"Number of Projections\", fontsize=13)\n",
    "plt.ylabel(\"Accuracy\", fontsize=13)\n",
    "plt.xscale(\"log\")\n",
    "plt.ylim(0.8, 0.93)\n",
    "# plt.grid(True)\n",
    "plt.legend(fontsize=13)\n",
    "# plt.title(\"BBCSport\", fontsize=13)\n",
    "\n",
    "plt.savefig(\"./Figures/ablation_projs_BBC.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Cross Validation on $\\rho$"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### USOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 [0.9090909090909091, 0.9409090909090909, 0.9090909090909091, 0.9181818181818182, 0.9272727272727272]\n",
      "1 [0.9045454545454545, 0.9454545454545454, 0.9227272727272727, 0.9181818181818182, 0.9227272727272727]\n",
      "2 [0.9136363636363637, 0.9545454545454546, 0.9318181818181818, 0.9181818181818182, 0.9]\n",
      "0.9224242424242425 0.0011338355717495777\n"
     ]
    }
   ],
   "source": [
    "rhos = [0.0001, 0.0005, 0.001, 0.01, 0.1, 1.0]\n",
    "\n",
    "\n",
    "L_mean_rsw = []\n",
    "\n",
    "for k in range(3):\n",
    "    L_acc = get_acc_knn_cv_rho(dataset, \"rsw\", k, rhos, y, idx_train, idx_test)\n",
    "    print(k, L_acc)\n",
    "    L_mean_rsw.append(np.mean(L_acc))\n",
    "    \n",
    "print(np.mean(L_mean_rsw, axis=-1), np.std(L_mean_rsw, axis=-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 [0.9, 0.9545454545454546, 0.9272727272727272, 0.9136363636363637, 0.9090909090909091]\n",
      "1 [0.9136363636363637, 0.95, 0.9181818181818182, 0.9181818181818182, 0.9181818181818182]\n",
      "2 [0.9363636363636364, 0.9545454545454546, 0.9227272727272727, 0.9272727272727272, 0.9272727272727272]\n",
      "0.9260606060606061 0.005471354571293261\n"
     ]
    }
   ],
   "source": [
    "rhos = [0.0001, 0.00011, 0.00012, 0.00013, 0.00014, 0.00015, 0.00016, 0.00017, 0.00018, 0.00019, \n",
    "        0.0002, 0.000205, 0.000208, 0.000209, 0.00021, 0.000211, 0.000212, 0.000215, 0.00022, 0.0003, \n",
    "        0.0004, 0.0005, 0.0006, 0.0007, 0.0008, 0.0009, 0.001, 0.005, 0.01, 0.1, 1.0]\n",
    "\n",
    "L_mean_rsw = []\n",
    "\n",
    "for k in range(3):\n",
    "    L_acc = get_acc_knn_cv_rho(dataset, \"rsw\", k, rhos, y, idx_train, idx_test)\n",
    "    print(k, L_acc)\n",
    "    L_mean_rsw.append(np.mean(L_acc))\n",
    "    \n",
    "print(np.mean(L_mean_rsw, axis=-1), np.std(L_mean_rsw, axis=-1))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### SUOT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 [0.9045454545454545, 0.9272727272727272, 0.8727272727272727, 0.8954545454545455, 0.8863636363636364]\n",
      "1 [0.9363636363636364, 0.9227272727272727, 0.8818181818181818, 0.8772727272727273, 0.9227272727272727]\n",
      "2 [0.8954545454545455, 0.9227272727272727, 0.8772727272727273, 0.8727272727272727, 0.9045454545454545]\n",
      "0.9 0.005891582453098076\n"
     ]
    }
   ],
   "source": [
    "rhos = [0.0001, 0.001, 0.01, 0.1, 1.0]\n",
    "\n",
    "L_mean_rsw = []\n",
    "\n",
    "for k in range(3):\n",
    "    L_acc = get_acc_knn_cv_rho(dataset, \"suw\", k, rhos, y, idx_train, idx_test)\n",
    "    print(k, L_acc)\n",
    "    L_mean_rsw.append(np.mean(L_acc))\n",
    "    \n",
    "print(np.mean(L_mean_rsw, axis=-1), np.std(L_mean_rsw, axis=-1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Unnormalize"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### SOPT + Unnormalize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.84151515 0.87272727 0.87181818 0.85090909 0.84515152 0.78636364\n",
      " 0.75515152 0.58939394 0.50606061 0.34151515 0.34575758] [0.00648513 0.00196386 0.00128565 0.0070808  0.01114229 0.00222681\n",
      " 0.00599969 0.00214275 0.00639961 0.00622504 0.00226767]\n"
     ]
    }
   ],
   "source": [
    "rhos = [1e-6, 5e-6, 1e-5, 5e-5, 0.0001, 0.0005, 0.001, 0.005, 0.01, 0.05, 0.1]\n",
    "\n",
    "L_mean_rsw = np.zeros((len(rhos), 3))\n",
    "\n",
    "for k in range(3):\n",
    "    for i, rho in enumerate(rhos):\n",
    "        d_sw = np.loadtxt(path + \"d_projs500_sopt_unnormalize_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_rsw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "print(np.mean(L_mean_rsw, axis=-1), np.std(L_mean_rsw, axis=-1))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### USOT + Unnormalize"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.34909091 0.86       0.84666667 0.77454545 0.71151515 0.63060606\n",
      " 0.60060606 0.51424242 0.48818182 0.41606061 0.34090909] [0.00647096 0.00560401 0.00648513 0.0070808  0.01895817 0.01950254\n",
      " 0.01806528 0.02062833 0.00826556 0.00860307 0.00668043]\n"
     ]
    }
   ],
   "source": [
    "rhos = [1e-6, 5e-6, 1e-5, 5e-5, 0.0001, 0.0005, 0.001, 0.005, 0.01, 0.05, 0.1]\n",
    "\n",
    "L_mean_rsw = np.zeros((len(rhos), 3))\n",
    "\n",
    "for k in range(3):\n",
    "    for i, rho in enumerate(rhos):\n",
    "        d_sw = np.loadtxt(path + \"d_projs500_rsw_unnormalize_BBC_rho1\"+str(rho)+\"_rho2\"+str(rho)+\"_k\"+str(k))\n",
    "        L_acc = get_acc_knn(d_sw, y, idx_train, idx_test)\n",
    "        L_mean_rsw[i, k] = np.mean(L_acc)\n",
    "        \n",
    "print(np.mean(L_mean_rsw, axis=-1), np.std(L_mean_rsw, axis=-1))"
   ]
  },
  {
   "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": true,
   "title_cell": "Table of Contents",
   "title_sidebar": "Contents",
   "toc_cell": false,
   "toc_position": {},
   "toc_section_display": true,
   "toc_window_display": false
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
