{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy               as np\n",
    "import matplotlib.pyplot   as plt\n",
    "import pandas              as pd\n",
    "import utils               as u"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Synthetic data"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Comparing a uniform with a mixture of uniforms"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████| 10/10 [1:33:34<00:00, 561.47s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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55yLA08a1JEQmjKosX07PPqobYt7xhl28/EL51ye8qSRilWrrIZ3VRVccgkcfnjUETnnXEZ50mgOVXjnHXjlFSgutu3M07D2wznn4s6TRlOVl9tivSVLYOhQOP98aJt3ZUecc65OnjSaorTUyrGWlMCYMVa/27czd861IC0vaYQt3ddQMujSBW66KX0xOedcjmh5SSNM6b5kqvDGGzBnDhx4oJdjdc61aC0vaTRFWRk8/TR89JFVZDrnHC/H6pxr0Txp1GfTJlt/sXUrjB8PX/mKj18451o8Txp1WboUZs6ENm1g2jQ4+OCoI3LOuVjwpJEskYBZs+Dtt6FfP5g0CTp1ijoq55yLDU8aySorYcUK64oaOxYKCqKOyDnnYiXvkkZjNcKLoeH63hdcYIv1GpiW2+hrOOdcnvKd9Wrz1d3OOVevvGtpFBYWNlq/O6s1wp1zLo94S8M551xonjScc86FlnfdU6GkukivXbv0xOGcczmm5SWNMPtONaVyn3POtSDePeWccy40TxrOOedCa3ndU3Wpa4yj9jHvrnLOOU8agCcE55wLybunnHPOheZJwznnXGieNJxzzoXmScM551xonjScc86F5knDOedcaLFPGiIyVkQ+EpGPReSGqONxzrmWLNZJQ0QKgN8D44ChwBQRGRptVM4513LFOmkAJwAfq+qnqloOzADOjzgm55xrseK+IrwPsCbp/lrgxIZ+oLEa4c4555ov7i2Nugpf7Lfnh4hcIyLzRGTeli1bshCWc861THFvaawF+iXd7wusr/0kVb0LuAtgxIgR6vW7nXMuM+Le0ngPGCIiA0WkDXAJ8GzEMTnnXIsV65aGqlaKyHeAl4AC4E+qujTisJxzrsWKddIAUNUXgRejjsM551z8u6ecc87FiCcN55xzoXnScM45F5onDeecc6F50nDOOReaqO63wDqniUgJsDrFlykGot6LJA4xQDziiEMMEI844hADxCOOOMQA8YgjHTH0V9UejT0p75JGOojIPFUd0dJjiEsccYghLnHEIYa4xBGHGOISRzZj8O4p55xzoXnScM45F5onjbrdFXUAxCMGiEcccYgB4hFHHGKAeMQRhxggHnFkLQYf03DOOReatzScc86F5kkjiYh8JiKLRWShiMzL4vv+SUQ2iciSpGPdROQVEVkZfO0aURw3i8i64JwsFJHxGY6hn4i8JiLLRGSpiPxbcDxr56OBGLJ9LtqJyD9E5IMgjluC4wNFZG5wLh4NygZkO4b7RWRV0rk4NlMxJMVSICILROT54H7WzkMjcURxLva7VmXrb8STxv7OVNVjszyF7n5gbK1jNwCzVHUIMCu4H0UcAL8Nzsmxwa7DmVQJ/EBVjwBOAr4tIkPJ7vmoLwbI7rnYC4xS1WOAY4GxInIS8OsgjiHAVmB6BDEAXJt0LhZmMIZq/wYsS7qfzfPQUByQ/XMB+1+rsvI34kkjBlT1DaC01uHzgQeC7x8ALogojqxS1Q2q+n7w/Q7sj7MPWTwfDcSQVWp2BndbBzcFRgFPBMczfS7qiyGrRKQvcDZwT3BfyOJ5qC+OmMnK34gnjX0p8LKIzBeRayKOpZeqbgC7iAE9I4zlOyKyKOi+yng3WTURGQAcB8wlovNRKwbI8rkIukIWApuAV4BPgG2qWhk8ZS0ZTmi1Y1DV6nPx8+Bc/FZE2mYyBuA24DogEdzvTpbPQz1xVMvmuYC6r1VZ+RvxpLGvU1R1ODAO65I4PeqAYuAPwCFY18QG4P9l401FpCPwJPA9Vf0yG+8ZIoasnwtVrVLVY4G+wAnAEXU9LZsxiMhRwA+Bw4GvAN2A6zP1/iJyDrBJVecnH64r1EzF0EAckMVzkSSya5UnjSSquj74ugl4GvsjjcoXItIbIPi6KYogVPWL4KKRAO4mC+dERFpjF+uHVfWp4HBWz0ddMURxLqqp6jZgDjbGUiQi1VU3+wLrsxzD2KALT1V1L3AfmT0XpwDnichnwAysW+o2sn8e9otDRP6c5XMB1HutysrfiCeNgIh0EJFO1d8DZwFLGv6pjHoWmBp8PxWYGUUQ1f8JAxeS4XMS9FXfCyxT1f9Keihr56O+GCI4Fz1EpCj4vj0wBhtfeQ24OHhaps9FXTEsT7o4CdZ3nrFzoao/VNW+qjoAuASYraqXkcXz0EAcl2fzXATvU9+1Kjt/I6rqN1vgOAj4ILgtBX6cxfd+BOvuqMD6ZqdjfbazgJXB124RxfEQsBhYFPyn7J3hGE7FuhkWAQuD2/hsno8GYsj2uTgaWBC83xLgJ0n/V/8BfAw8DrSNIIbZwblYAvwZ6Jjp/5/B+44Ens/2eWgkjqyei/quVdn6G/EV4c4550Lz7innnHOhedJwzjkXmicN55xzoXnScM45F5onDeecc6F50nAuQ0RkmoioiGyrveWIiBQGj90cUXjONYsnDecyrwvZ2VrCuYzzpOFc5r0MfFdEDow6EOdS5UnDucz7WfD1x5FG4VwaeNJwLvM2AHcA14hI/6iDcS4VnjScy45fA3uAm6IOxLlUeNJwLgtUtRSrv3GliBwWdTzONZcnDeey57dYOd3/iDoQ55rLk4ZzWaJWa/uXwESs+p9zOceThnPZdSewjpoZVc7lFE8azmWRWknQ/wC+HnUszjWHJw3nsu8+rLqacznHK/c555wLzVsazjnnQvOk4ZxzLjRPGs4550LzpOGccy40TxrOOedC86ThnHMuNE8azjnnQvOk4ZxzLjRPGs4550L7//9UeTyVwysRAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x285e2648748>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "Nrange = range(5,55,5)\n",
    "a      = .35\n",
    "dg     = lambda N : u.generateUniforms(N, 0.5, a)\n",
    "\n",
    "np.random.seed(0)\n",
    "dataKME, dataKVE = u.sampleRangeExperiment(dg, Nrange, **u.TWOSAMPLEKWARGS) \n",
    "figUniforms = u.plotRes(dataKME, dataKVE, Nrange)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Independence testing between a uniform and a $\\chi^2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████| 10/10 [2:56:05<00:00, 1056.55s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x23ae7052780>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "Nrange = range(6,66,6) \n",
    "rho    = .5\n",
    "dg     = lambda N : u.generateUniformAndChi2(N, rho)\n",
    "\n",
    "np.random.seed(0)\n",
    "dataHSIC, dataCSIC = u.sampleRangeExperiment(dg, Nrange, **u.INDEPKWARGS)\n",
    "figUniformAndGaussian = u.plotRes(dataHSIC, dataCSIC, Nrange)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Classical vs. kernelized cumulants"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████| 2/2 [15:35<00:00, 467.93s/it]\n",
      "100%|███████████████████████████████████████████████████████████████████████████████████| 2/2 [21:07<00:00, 633.65s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[19. 17.] [3.  0.5]\n",
      "[56. 68.] [3.5 1. ]\n",
      "[39. 65.] [4.5 3.5]\n",
      "[59. 79.] [3.  1.5]\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "def linker(x,y,bw):\n",
    "    return np.outer(x,y)\n",
    "\n",
    "dg = lambda N : u.generateUniformAndChi2(N, rho = 0.5)\n",
    "Nrange = [20, 30]\n",
    "\n",
    "np.random.seed(0)\n",
    "clasVar, clasSkew = u.sampleRangeExperiment(dg, Nrange, **u.INDEPKWARGS, kernel = linker)\n",
    "kernVar, kernSkew = u.sampleRangeExperiment(dg, Nrange, **u.INDEPKWARGS)\n",
    "\n",
    "for data in [clasVar, clasSkew, kernVar, kernSkew]:\n",
    "    print(100 * np.percentile(data, 50, axis=1), \n",
    "          100 * 0.5 * (np.percentile(data, 75, axis=1)-np.percentile(data, 25, axis=1)))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Real data "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def readBikeDate():\n",
    "    data_raw = pd.read_csv('SeoulBikeData.csv', encoding = 'unicode_escape')\n",
    "    labels = data_raw['Seasons']\n",
    "\n",
    "    data_raw['Functioning Day'] = u.cat2num(data_raw['Functioning Day'])\n",
    "    data_raw['Holiday']         = u.cat2num(data_raw['Holiday'])\n",
    "    data = data_raw.drop(['Date', 'Seasons'], axis=1).values\n",
    "\n",
    "    X = u.standardise(data[labels=='Winter'])\n",
    "    Y = u.standardise(data[labels=='Autumn'])\n",
    "    \n",
    "    return X,Y\n",
    "\n",
    "def readTrafficData():\n",
    "    data_raw = pd.read_csv('Behavior of the urban traffic of the city of Sao Paulo in Brazil.csv', delimiter=';')\n",
    "    X = u.standardise(data_raw.values[:,1:-1])\n",
    "    Y = u.standardise(np.array(list(x.replace(',', '.') for x in data_raw.values[:,-1])).astype(np.float))\n",
    "    return X, Y"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Bike data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████| 11/11 [1:35:02<00:00, 518.38s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x285e3c23278>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "X,Y    = readBikeDate()\n",
    "dg     = lambda N : u.dataGen(N,X,Y)\n",
    "Nrange = range(4, 48, 4)\n",
    "\n",
    "np.random.seed(0)\n",
    "dataKME, dataKVE = u.sampleRangeExperiment(dg, Nrange, **u.TWOSAMPLEKWARGS)\n",
    "    \n",
    "figBikes = u.plotRes(dataKME, dataKVE, Nrange)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Bike data - Type I error"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████████| 8/8 [52:21<00:00, 392.64s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x271b68cf7f0>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "X,Y    = readBikeDate()\n",
    "dg     = lambda N : u.dataGen(N,X,X)\n",
    "Nrange = range(4, 36, 4)\n",
    "\n",
    "np.random.seed(0)\n",
    "dataKME, dataKVE = u.sampleRangeExperiment(dg, Nrange, **u.TWOSAMPLEKWARGS) \n",
    "\n",
    "figBikesTypeI = u.plotRes(dataKME, dataKVE, Nrange, ylabel = 'Type I error (%)', maxLines = 30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Brazilian traffic "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|███████████████████████████████████████████████████████████████████████████████| 10/10 [2:24:28<00:00, 866.81s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAY0AAAEPCAYAAAC+35gCAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvNQv5yAAAIABJREFUeJzt3Xl8XXWZx/HPk6VN96ZNF2hKylL2UgqFslkLVVmUnSKFImAdRAFndERxGQuOjgLjOFZxEERRiyD7JqtlKYoshdJSSnearnRNaUub/Td/PCdku0lOkntzb5Lv+/W6r+Sec+49T9L0PPd3fstjIQRERETiyEp3ACIi0nkoaYiISGxKGiIiEpuShoiIxKakISIisSlpiIhIbEoaIiISm5KGiIjEpqQhIiKx5aQ7gGQrKCgIo0aNSncYIiKdyptvvrklhDCkpeO6XNIYNWoUc+fOTXcYIiKdipkVxzlOt6dERCQ2JQ0REYlNSUNERGJT0hARkdiUNEREJLYOTRpm9jsz22RmC+tsG2Rmz5nZsuhrfrTdzGymmS03swVmdlRHxioiIo11dEvjLuC0BtuuB2aHEEYDs6PnAKcDo6PHlcD/dVCMIiLShA6dpxFCmGNmoxpsPhuYFH3/B+BF4NvR9j8Gr0f7qpkNNLO9QggbmjtHZWUlW7ZsSWbYIiISyYTJfcNqEkEIYYOZDY22jwDW1DlubbStUdIwsyvx1giFhYWpjVZEuq0hQwpiHbd5c+s+uIYAVVVQXg4VFdbo66RJAykvt7aE/LGePQNr125t13tAZiSNpiT6DYVEB4YQbgduBxg/fnwoKIj3Dysi0hoh1P9+504YMABWr/YLfs3j/fcL6j1P9Cgrq/+8urrp85aXw4wZtc9zc6FHj9rHwK9OZWq4p9nYzYxkXBszIWlsrLntZGZ7AZui7WuBkXWOKwTWd3h0ItJt9eoFpaUtH7fPPk3vy8mBn/zEL+49e/rX3r1h4MD6F/7mHjfe6I+m3cPFLTRE8q0EyG/5h2lBJiSNx4DLgJ9GXx+ts/0aM7sXmAB82FJ/hohIe5WVwcaN8MEHnjBuuw02bfLbR+BJYNgwGD7cH336NH2xz82FrCz45jfbF1PAoKICSkpg27bGj5wcuPrq5t/EBtHEzZpW6dCkYWb34J3eBWa2FpiBJ4v7zGw6sBqYEh3+JHAGsBzYDVzRkbGKSNcWAuza5cmh5rFhg1+D67rqqvadp1Wf8JtKDOAZqDnXXNP8/ry8eDG0wEJof+bJJOPHjw9a5VZE6qqu9mtv3eTwwQfw0Ue1x+Tne8thr71qWxH9BhjW3mukWf3OkIqKxK2Fbdvgww/rv7Z3bxg0qPFj8GC/dzZ7NsyaBcXFUFQE06bB5MltDNPeDCGMb+m4TLg9JSLSIosxeCgEvyZv2lQ/OWzc6NsBsrNhyBAYPbo2QQwb1swH8RtuaH2wVVWwZ48/AB57rDYx7NhR/9g+fTwRjBrVODn06tX0OWbPhjvvhOuugzFj4J134JZbfF8bE0ccShoi0ik0/MBv5i2Fuq2HW2+FLVtqj+3Z05PC0UfXth6GDPHEEVtTSaO6GjZv9hM2bDHs3Al9+/oDYOlSTwL77dc4MbT1ttGsWZ4wxo3z5+PG+fOZM5U0RKT7iTNyqU+f5vfn5dV+2G+33bth7Vp/rFkD69b5WNga/fp5EjjggPpJ4cYb298Tnkhxsbcw6hozxrenkJKGiGSk0tLaFsOWLbBggT+2b/eRSQceCHvvXXt7KVECiXNLK6EQvBUB8MgjnihqVprIyvKTHnkkjBzpTZdBgzyojlRU5Lekaloa4M+LilJ6WiUNEclYbb7oR/LjTksoLfWWw5o1/li71sfegt9aGjnSk0RhoWeqjk4QiUyb5n0YDfs0pk9P6Wk1ekpEMkZlJSxbBvPn+9eqKm9FjB3r18V+/WqPbTgoKbYQYOvW2uSwZo23KkLwNx061JNETaKorm5f9mpzoDFo9JSIdDch+If8+fNh4ULvg+jbFyZMgCOO8DtBkPi63XBbwmtzeXltK6ImSdR0dOTleevhsMM8SYwY4b3ndWW1czHw2M2dNpg8OaWd3okoaYhIWpSU1PZTbN3qc9cOPthbFfvt1/haHevDegje6VFzm2nNGh9vW/PiIUPgkEM8UYwcCQUFzbci4pw0lS2JDKSkISItijtHoiWlpbBokbcqagb5jBoFJ50Ehx7a4EP+oEGeWdqjTx94/HFPEoWFzc97kFiUNESkRYnmSMT9cF1VBStWeKJYssT7LQoK/K7KmDG+cF9CJSWJT7J9u7/Z0qU+OaNmedhBg2r7ImpGNWVnw8knx/45pWVKGiKSdCH4hLv5831Qz0cf+YoYRx3lt5/23jtm33LNxLqqKh/yumGDJw3wNckHDID+/f1RM7Fu/vxU/VhNBx2rc6Vr0OgpEWm1ploaO3Z4kpg/35fyyM6Ggw7yDu3Ro1s5E9vMC1XMmwfvvutDYPPzfUTT2LHNNFFiBCqNaPSUiLRJ3BoSzbUUcnLgn//0QUmt7kbYsaO2tdBcoYo4UjlyqZvqcklDNcJF2qe0tKDFcqXV1bB6dRbvvpvD0qXZVFQYAwZUc9hhVRx6aCUHHTSYUaO28NFH9VeSbVJlJdnLl5PzzjtkrVqFhUDVL35B5eGHU3XQQY2HwbaGrgdJ1eWShoikRmUlrFuXxcqV2SxenM3OnVn07Bk49NAqDjuskhEjqls3By4EsjZuJHvBAnIWL8ZKS6nu14/K446j8vDDCWolZKQulzRycnKSUgdXpDsrKCj4ePmlFSv8UVzsy4tnZfmafGPH+vpPTdUGavL/4a5dPjnj7be94yMnx9/syCNh333bP5lOUqrLJQ0Rabtdu/zrww/DypW+wjdAwY3XcBQr2J8VFFFMT8obv7i5DueqKl8XZN48/1pd7fMmPvc5OPzwpFWVk9RT0hDpxioqfIBSTWti40bfvmyZz8rebz/Yf38YcMOv6r8w7qikjRs9USxY4EuL9+0Lxx/vrYohQ5L/A0nKKWmIdCMh+HV8xQpvSRQXe19FdrYPVJo82cs/XHddO9bo270b6A2/+Y3Pq6gZd3vkkX5fS7efOjUlDZEubufO2iSxYkXtaKahQ2H8eG9JFBXVX+271QmjutrffN48n/bNf/j200/3ad+9eyfjR5EMoKQhksHasuZTebm3IGqSxKZNvr1Pn9rbTfvt55Oo237eAPWOyQJGRw/ItxL48pdbDl46HSUNkQwWZ82nmiU7avolVq/2fuecHL/lNHasJ4phw2ImIVrorygtxXrlEe74rS81npXl072PPNKHU2Vngw0CNBO7K1LSEMkgcRZ2benC37evj2bdZ5+mh8O2qGbNp7pKS32p8Q0bmMFEePiN2lqrS5ZEt6Wkq9PaUyIZpLlBSdu2wWuveWuiZpJz377eiqi55dS3bxKWW2r4Bhs2wCuv+PpPZjBmDHbuOYTq0PwCfl3s2tLVae0pkU4q0Yf87du9ql11ta/Tl5/vjxB8maakL+waArz/PvzjH7BiBXbjDcD59Q6xLGv0Eun61NIQySCJPqAvXOiT7fLz4ZJLWl6Dr10f8qurvU/ittu8hdG3Lxx3nA+zas0EPLU0Oh21NEQ6uRD8g/7f/uZDYi+6KIWF58rLfbjsP//pz6+6qn3vp3WjuiwlDZEMVF0NTz4Jc+f6KhvnnOOjoZLuo4/g9df9sWeP954vXuyjoJrrcVdLottS0hDJMG2eiR2J9SF/2zZvVcyb51PCDz4YTjih/fUrpMtT0hDJIDt3wt13+7yLz37WuxIAmD0bZs3yWXtFRTBtmq/50Vrr1/s9r0WLfH7F2LGeLLQytMSUMUnDzL4OfAmfEfQOcAWwF3AvMAh4C7g0hJBgeU2Rzm/zZk8Yu3fD1Kl+hwjwhHHnnb4g1JgxXk/1llt8X5zEEYKP0/3HP3xEVF4enHgiTJgA/frFCy5R86cb1cWWWhmRNMxsBPA14NAQwh4zuw+4CDgD+HkI4V4zuw2YDvxfGkMVSYlVq+Dee73f4vLLYe+96+ycNcsTxrhx/nzcOH8+c2bzSaOqyudW/OMfvkph//7wmc/A0Ue3vhKeEoJEMiJpRHKAXmZWAfQGNgCnABdH+/8A3ICShnQx77wDjzzis8EvucTnYdRTXOwtjLrGjPHtiZSXw1tveZ/Fhx/6yoTnnOOvyc5Oyc8g3UdGJI0Qwjoz+29gNbAHeBZ4E9geQqiMDlsLjGjpvVQjXDqLEODVV3N4+eUejBxZxVlnlVFZ2bikdd9hw9gzZw5VRxzx8bbsBQvoNWwYu+oevGsXufPmkTNvHlZaStXIkVScfjrV++3nt5JaWp9EJIZYScPMsoFjgOOAvYFewBZgCTAnhLC+PUGYWT5wNrAvsB24Hzg9waEJ28hmdiVwJUBhYWF7QhHpENXV8NxzPZg/P4dDDqnk9NPLmxxSWzZlCr1uvZU9V19N1aGHkr1oEb1uvZWySy4BwLZtI/eNN8iOpoxXjR5N5bHHUl3vHpdIcjSbNMxsH7yv4QvAYHwx5D3RYyC+HnIws38Avwb+Eto2xfxTwPshhM3ReR8CTgAGmllO1NooBBImpxDC7cDt4DPCVSNcMllZGTzwgFfHO/VUOOWUFobZnnceDBhA3p/+VDt66qtfJe+gg7yTfPFiv+104oleFW/w4A77WaT7aTJpRLeLrsFbEz8H5gDzQgi76xxThLc+PotftL9jZl8MIbzZyjhWA8eZWW88IU0G5gIvABfgI6guAx5t5fuKZJSdO+HPf/Z+6TPP9D7penr18tVkW3LXXU3vy8vziXoiKdBcS+NwYFII4dWmDgghFAPFwF/MrA9wNTAB74+ILYTwmpk9gA+rrQTm4Unor8C9ZvajaNudrXlfkWRI1hSJTZt8SO2ePT6kdvToBAeVljY9UmnJEg9m0yYYMMBbFUcdVb/kHrR/dqBIM5pMGiGE01rzRiGEj4Cb2xpICGEGMKPB5pXAsW19T5H2au8UiRrvvw9/+YsPqb3iCthrr2YO7pAp4SJtkxGjp0QyVVunSNS1YAE8+mgzQ2rrqtvKCMGHzj73nC/1MWmSty40bFbSqNVJw8xygW8Cp+Ed488At2imtnRFrZ0iUVcI8PLL8PzzsO++8PnPt2J18S1b4PHH/UT77guf+5w6uCUjtKWl8TPgZHyyXV/gWnz+xFeTGJdIRigq8ltSNS0N8OdFRc2/rqoK/vpXbygccQScfXbMBkJVlc/gnjPHa7WefbbX3lY/hWSI5kZPDQ8hfJBg1wXAkSGETdFxC4DfoKQhXdC0ad6H0bBPY/r0pl9TVgb33w/Ll8PEiXDyyTGv+WvXwmOPeUf34YfDaad5ESSRDNJcS2Oxmf0A+GWDuRdl+JyNTdHzwUCMMYIinU9Nv8XMmbWjp6ZPb7o/Y8cOH1K7aROcdZYPbmpRWZnfw3r9dV9A8OKL66xWKJJZmksaZwG3Apeb2VdCCK9F238NvGxmTwF98Jnb/5naMEXSZ/LkeJ3eGzf6kNrSUr/uH3BAjDdfutTvY+3YAcce6zP9WruYoEgHam7I7RwzOxL4BvCsmd0LfDuEcIuZLQZOBT4EpoYQHumYcEUy08qVPqS2Rw/44hdh+PAWXrBrFzz9tBcAHzrUmy9aAkc6gWY7wkMIVcAtZnYPPit8qZl9K4RwF/B4B8QnkvHeftu7IgoKfEjtgAHNHByCv+DZZ3012lNO8eU/NIxWOolYo6dCCGuBKWb2GeCXZjYd+EoIYWFKoxPJYCH4IKcXXoD99oMLL2xhSO3WrfDEEz7Tr6jI1xGJu05asqali7RTSwsWXoj3WeQB/wRuA8YA3wb+YWa3AzdEs8FFuo2qKp9G8fbbPiL2zDObaSxUVXltixdf9CnhZ57pPeRxh9Ema1q6SBJkNbXDzG6kdq2nrcD1wCMhhPIQwn8CRwIH46Oszk95pCIZoqzMR0i9/bZP0m52Dsa6dXDHHfC3v/mIqKuv9lUKWzPvou609Jyc2mnps2Yl48cRaZXmWhpXAl8OIfwZwMx+BbxrZiNCCOtCCO8DZ5rZ2Xh/x4OpD1ckvXbs8BFSmzd7sqg76a+e8nIfRvvaaz7X4qKL4OCD23bS9kxLF0my5pJGFZBb53kuvmxIdd2DQgiPmtmzKYhNJKN88IG3MMrKvMN7//2bOHD5cu+72L4djjnGbyHFXj8kgbZOSxdJgeaSxq3AbWZ2Jl7j4jT89tSGhgeGELR4v3Rqgwa1rhrqd7/beFt+fmDbHQ/5BX3IEB97u88+7Q+uLdPSRVKkuXkaPzGz+Xiy6AF8C/hjRwXWVqoRLm1RUlLA5s2N/25CgLlzc3jppVwGDw5ccEEZ/fqFRgdlL1zIoFNO5qO5c6k87jgqJkzw/odk/C2OHUvuBRfQ8+abyVq7lurCQsqmTKFi7NjkvL9IK7Q0T+NJ4MkOikUko5SXwzPP9OC993IYPbqSM84obzRZ27Zvp8czz5BdXAycTOlllxFSUG64YuJEKiZOTPr7irRWcwsW5oYQKlr7hm19XbLk5OSgGuHSFnX/brZt8xoYmzb5CNmTTmow4Km6unYYbVYWTJkCt8DgtnZ2i3QSzbU0VprZfwF/jDMPw8yOwoflLgB+lKT4RDpOlBWWcQAPcj5G4BIe5IAbVrT82u9+F2iiTKtIF9Jc0rgeX4jwFjN7HHgZmA9sxle6zQf2w8uxngkcBNwN/D6VAYukiiW46F/PTbFfn8ceoFcSIxLJPM11hN9tZvcBFwLTgf8FGk5hMmAj8Bfg/BDC4lQFKpJKe8jjkXtKWbzYiyadeabXQPrYypXY/vsRZtzgk/M+/enGw2itN2ptSFfXUkd4Bd56uNvMegPjgb3xZUW2AotDCMtSHqVICm3eDCs5gr1+cwMn7Q8jAtiCaGcIsGYNrFzJDCb53Is33/SHSDdk9esrdX7jx48Pc+fOTXcY0kksWgSPPAK537uOC1fdUn++XGWlLzA1fz6MGYNdcD7N/ncxo/kDRDKXmb0ZQhjf0nFtqREu0ulVV/sqH3//u5exuJDf0H/Uf9c7xvs4zo0e0bYGS0YF6mzIz09dwCIZQklDup3du+HBB2HFChg/3ktx53xpR+0BmzbBn/9M+OjHcM45cNhhvj1hS0ItC+lelDSkW9mwwSvs7dzZRA3vZcvggQe8BN8VV8Dee6clTpFMpaQh3cb8+d5F0bu3Lws1YkSdnSHAq696Rb3hw2HqVOjfP22ximSqWEnDzHoClVH5V5FOparKc8Frr8GoUT55u0+fBgc8+aSPiDrkEDj3XG9pJKp50ahTQ7enpHtpMWmYWS7wEXA+8GjKIxJJol274L77YPVqOP54n16RVbf02J49fr9q1Sr4xCe8ZndNYlBCEGmkxaQRQqgws01AeQfEI5I0a9Z4wigthfPPb1zHiC1bvEDGhx/Ceef5rD4RaVbcPo17gcuBp1IXikhyhOB3mp56yrslvvQlGDaswUErV3pGyc6Gyy+HkSPTEapIpxM3abwLTDGzl/FbVBtoMNawpiysSDpVVsJf/wrz5sHo0d6A6NVwOag33vCMUlAAF18MAwemJVaRzihu0rgj+joCODHB/gC0K2mY2UDgt8Dh0ft9EViCr2s1ClgFXBhCaEV9NelOPvzQuyfWr4dPfhImTUqwnPnTT8Prr8OBB/o9q4YFMkSkWXGTxiEpjcL9Ang6hHCBmfUAegPfBWaHEH5qZtfjK+9+uwNikU7m/ffh/vt9INTUqXDQQQ0OKC31+RfLl8MJJ8CnPtWgR1xE4oiVNEIIS1IZhJn1Bybi/SaEEMqBcjM7G5gUHfYH4EVaSBoq99q9hABvvOHlWAcNCpx3XhmDB4d6VVCtpISeDz2ElZRQ/ulPUzV2rFdZEpFWa9XkPjM7CPgEMBi4K4Sw0cxGAltDCLvbEcd+eJ2O35vZWOBN4F+BYSGEDQAhhA1mNrSJuK4ErgQoLCxsRxjSmZSXw1NP9WDJkhwOPLCS009vXI41a80aej7yCIRA2YUXUr3PPukJVqSLiDu5Lxf4HXAxXkMjAM/htTR+hXeUf7edcRwFXBtCeM3MfoHfioolhHA7cDv4Krcq99pFzJ4Ns2ZBcTEUFcG0aTB5MuANhUce8WXNzzoLTjwxwVy8efPgiSdgyBC4+GL6DBrU8T+DSBcTt6Xxn8BZwL/gyaK4zr4n8U/57Ukaa4G1IYTXoucP4Eljo5ntFbUy9gI2teMc0knUXvwnR4/IXbXf/uQnfty0abD//g3eoLoa/vY3eOUV3zllSuOCSSLSJnF7Ai8B/iOE8DtgfYN9K4F92xNECOEDYE10+wv8SrEIeAy4LNp2GZqR3i2EAOHyKwhvzft4UnYIUP3mPF449afMmOGrkH/5ywkSRlmZD6F65RU49li45BIlDJEkitvSGAIsbGZ/Mv5XXotXCOyBJ6Ir8KR2n5lNB1YDU5JwHskwvXr54Kb6fl+vZeGtj3H+eMa3XXVV7f68PNizYTvcc4/fszrjDE8aIpJUcZNGMXAM8HyCfeOBdpd8DSG8Hb1XQ5MTbJMupLQ0wTJPV1wBX/sajBvHpk3eeChZtIHT1tzBMY//oFH/hRlwxx0+5vaSSxI0QUQkGeLenpoFfM/Mzgeyo23BzI4HvkG9z4QiSTBtGtxyC0sfWcRvb6+ibOU6Ll//Xxz79RMbd3gviAp69+zpa4YoYYikTNyWxk/w0U33A7uibS8A/YCHgf9NfmjSrU2ezJI1vbnvh4sZtvsppo5fTr+vXfDx6CnAmycvvABz5gBHeMLo3TttIYt0B3En91UC55rZp4FTgaHAVnwG9zMpjE+6qaVL4b41xzP8K3DppQn6sisq4OGHYdGi2vJ7ShgiKdeqyX0hhOfwIbciKbN0qfdhDBvWRMLYsQPuvddrt556Khx3XFriFOmO4k7uuwvvBH8xhLA6pRFJt5SoSB74sNrG+hMtAAA3+Jf8/OTHJCKNxW1pjAGmAWZm7+P9GS8AL9Qs8yHSVjUjp5Yt8wZETQujZklzs+iYRYv8llSfPr4qYaMiGSKSanH7NI6Oli6fBJwSff0igJktBZ4PIVydohilG6hJGEOH1k8YH5szB55/3oslXXRRgyLfItJRYvdphBC2A49ED8zsOHx5kcnAgYCShrTJ8uXehzF0KHzhCw0SRmUlkOMJ44gjfKGpnFZ1xYlIEsX+32dmhcDJeEvjZGAkPnP7tySe9CfSouXL4d4xP2ZI6Wq+wB/pdVUpVq8opP+J2o031HtdoEEnSH6+ljsX6QBxO8KXAvsDa/CaFjPwW1JrUheadHXLl/stqYLSNXxh92/o1es3QFRHuLraiyYtWuSti5phtR9rMIW8qZ50EUmquC2NA4A9wKvAK8ArShjSHitWRAmjAKZzJ7m9f9P0wTfe2PIbalFCkQ4RdxmRYfgCgiXAvwNLzGyNmf3BzC43M1W2kdhWrPB1BQsKvA8jN1RES9sGb2E89RTMmOGzvWu2t/TYsyfdP5ZItxB39NRm4L7ogZntjfdtXAbcid8rUO+ktKhhwmg0ifull+DVV33C3ic/mZYYRaRprS33OhTvBK/pED8ATxjNLZveoVQjPHOtWpXFgw/2ZNCgwBlnlLJ7N+yuUyQ454036PHCC1SOGUP50UeT+/DD9Lz/frLWrqW6sJCyKVOomDgxfT+AiMTuCJ+JJ4lD8HKv7wHPAt/BJ/hp2Io0q27C+PznSxu1MLLnz/eEceCBlJ96Krkvv0zPu+9mz9VXU3XooWQvWkSvW28FUOIQSaO4LY3T8WG1P8KTxMbUhdQ+OTk5qEZ4Zlm5Ep5+GvbZBy67DHr37lv/gHffhb//3edhTJ0K2dnw+OPw/e+TN26cHzN8OOTnkzdzJpx3Xsf/ECICxO/TGJ3qQKRrev9978MYPLiJPoxly+DBBz2jfP7znjAAiothzJj6x44Z49tFJG1a26cxGpgIDMKXRp8TQlieisCk83v/ffjzn33e3Re+kGDlj1WrapeznToVcnNr9xUVwTvvQE1LA/x5UVFHhC4iTYg15NbMss3st8Bi4A7gJnwm+BIzu8PM4g7dlQxn1vIjjroJ47LLEiSM9eu9CZKfn3j986hyH/Pm+VIi8+b582nTkvJzikjbxG1pfB+4HPgvvPTrB8BwfOXb64HV+DpU0sk1rNX98QqzrbBqVQsJY9Mm+NOffJGpSy9NXDyppkLfzJl+S6qoCKZPr1+5T0Q6nIUYVwQzWwnMCiH8IMG+HwKXhBAyojDz+PHjw9y5c9MdRpfR2qSxahXcfTcMHAiXX54gYZSUwO9+599fcQUMGpSkSEWkPczszRDC+JaOi3tbaQQwp4l9c6L90s3VTRgJWxg7dsAf/+i3my69VAlDpBOKmzQ2ABOa2HcsfrtKurHi4voJo2+DUbXs3u23pHbv9n6JoUPTEqeItE/cPo17gR+YWTlwN54khgEXAf8B/Dw14UlnUJMwBgxoImGUlsKsWX5rato0GKGGqUhnFTdp/AAvtHQT8NM62w14GF8qXbqhmoTRv7/3YTRKGBUVPkrqgw98WO2oUWmIUkSSJe7kvnLgPDMbj8/TyAe2AS+FEN5KYXySwVavrk0YCVsYVVU+D2P1ajj/fBitOaIinV2rJveFEOYCGpokrF7td5xqEka/fg0OqK6Ghx7ySktnnQWHH56WOEUkuVpT7tXwPozj8dFS6/CCTH8JccbtSpdRkzD69WsiYYQATzzha0p95jMJqu6JSGcVd5XbQuBJ4HBgC7AR+ARwDfAdMzsjhLAuZVFKSgwa5H3TLWluFviMGQ1Kc4cAzz4Lb73l9TBOOKHdcYpI5ojb0vgVPgP8UyGE52s2mtlk4M/R/nOTH56kUklJ6yburVnjLYy+fb3Tu1+/BAnlpZfgn/+ECRNg0qQkRisimSDuPI1PAdfXTRgAIYTZwHeBTycjmGiNq3lm9kT0fF8ze83MlpnZX8ysRzLOI61XN2EkvCUFXnHvxRfhyCPhtNPiL1QlIp1G3KSxB1jfxL710f5k+Fe8wFONm4CfR0uzlwDTk3QeaYW1az1h9OnjCaN//wQHzZvnRTMOPdQ7vpUwRLqkuLfBrZH3AAAUGElEQVSn7gG+BDydYN+X8FtU7RL1m3wW+DHwjajj/RTg4uiQPwA3AP/X3nNJrRtuaH7/jh0wfz706OENiP/5nwQHvfsuPPYYHHCAF0jK0qLHIl1V3KQxHzjHzOYCD+Ad4cOAC4AhwF/NrObiTgihLUnkf4FvATU3PgYD20MIldHztcRY40o1wlujgGuuafp3tX59Fvfd15PJkwNTp5bRr1/jDpAbbyzgo1mzqB4+nLLJk2H79lQGLCJpFjdp3BF9LQQSjZ/8bZ3vA61seZjZ54BNIYQ3zWxSzeYEhybstjWzK4ErAQoLC1tzammgYMgQABZyGE9wFkPZxeXcRf/v7fz4mC2bNwOQtWYNUEAoKKDs/PPrF1ESkS4pbtI4JKVRwInAWWZ2BpAH9MdbHgPNLCdqbRTSRL9KCOF24HbwpdFVIzy+hr+ryorAM8/AG294BdYLpvenf9hR/zXgRZSefhoYR9+rrqJvoyVtRaQrilVPoyNFLY1vhhA+Z2b3Aw+GEO41s9uABSGEXzf3etXTiC8ZfdX5AwPbStTpLdLZxa2n0aplRNLg28C9ZvYjYB5wZ5rj6VLqfl5YtAgefdT7sM89Fw48MNrRsApTTRGlEOCLX1RNDJFuJuOSRgjhReDF6PuVeL0OSZGqKnjuOZ9iMWIETJniNTES2rmztoiSqu6JdEsZlzSk42zfDvffD+vWwXHHwac/DdnZTRy8e7cnjI8+8skaKqIk0i0paXRTS5bA5sMncXBlJeewmCFsbfrghp0f3/te7fd5ebAnWXM7RSTTKWl0M1VVMHs2vPIK7FV5EFO2/qb5u0wVFT4dfM0auOiiOp0dEc38FulWYk3dNbNFZjamiX2Hmtmi5IYlqbBjB9x1lyeMY46B6dzZfMKoqoL77vO10M87r3HCEJFuJ25L42CgVxP7egMHJSccSZXly70mUmUlXHBBTU2kqqZfsGMHPPkkLFsGZ56pIkoiArTu9lRTEzqOAD5MQiySAtXV8MIL8PLLMGwYXHghDB7czAs+/BD+/nevhxGCr1Z79NEdFq+IZLYmk4aZXQtcGz0NwANmVtbgsF7A3vh6VJJhdu6EBx+EVau8eN7ppzez0sf27Z4s5s3z5+PGwUknNTP+VkS6o+ZaGuuBN6PvDwCWQKMhNmXAIrTybMZZudITRnm5T9YbO7aJA9vbkZ2f377Xi0in0mTSCCE8CDwI4KuU871osp1ksOpqmDPHC+gVFHiFvWgNwvpKSnwK+Ntve+I4+mhvWSQsliEi4mL1aYQQpjbcZmb9gH2AxSGEZnpUpaPs2uWd3StXesvis5/1Ohj1bNvmWWXBAl8z5Jhj4MQTlSxEJJZYScPMvgX0CyH8R/T8BOCv+Gq0xWb2KbVCkmT2bJ8XUVwMRUUwbRpMntziy4qL4YEHfJ7dWWd5l0S9O09bt3qyeOcdTxbHHuvJImHdVhGRxOKOnrocX6q8xs14H8fP8BrhPwSmJTWy7mj2bLjzTrjuOhgzxi/wt9zi+5pIHCF4//Xzz/tSUNOm+Sipj23ZUpsscnJgwgQ44QQlCxFpk7hJoxBYBmBmg4HjgM+EEJ43s0D9hCJtNWuWJ4xx4/z5uHH+fObMhElj9254+GGfSnH44T6domfPaOfmzZ4sFi70ZHH88Z4s+vbtuJ9HRLqcuEkj1Dl2IlAO/D16vgkvzSrt4LeSfg93Ndwz7uPtdVcoX7PGFxv86CPvuxg/PnqPzZu9F/zddz1ZnHCCP1QkSUSSIG7SWARcZGYv4req5oQQyqN9hcDm5IfWNp21RvjmzdD32mvZ8y//QtURRzBkSAGbN28he8ECet1xB7t++Uu2bPHE8cYbOcyZk0u/foFzzy1j+PDAtsWbyX3lFbKXLoWcHCqPOoqK8eM9WezZo0UFRSQp4iaNH+PDby8DqoHT6+w7DS+Q1GkNGdJyedjNm1OfiMqmTKHXrbey5+qrgVM8Ydx6K2WXXAL4df+pp3qwfHkOo0dXcvrp5fTasYncR14hZ+lSQm4ulRMmeLLo3Tvl8YpI9xN3yO0TZnYEMB54K4TwXp3db5BBSSMnJ6dR3euWNKx427BYneuAuuPnnQcDBpD3pz8Bp5D/pz/BV79K3uTJrFvnk/V27vTDJhR9gM15Cd57zzsyTjvN+y16NbVEmIhI+2VcjfD2alON8Aazoo1AoMFM6Q7+PdUkrhDg9dfh2Wd9wNOUiRsZsfQFWLzYk8Vxx/lDyUJE2iHpNcLNbBjwr3hH+CDgghDCIjP7KvB6CKGVV+oM0qipkWBbGpSWwmOPef3uA4eUcG7f5+j12CIvfDRpkg+fTVGyaON0ERHp4uJO7jsYmAPk4rejjgfyot0HASfQWeZpDBrkS2g0KzS/JlN+vs+sTnEY9fNBPnBhssNIqA3TRUSkm4jb0vhv4H3gVGAXPuS2xj+AnyQ5rtQpKWm5FdFSSyMJ1epqwtizxxeYLSnxx/btULItsGrBDnqvX84FQ+ewz/By76+YMKHORIzUFc2bNQuum/ga42beBsXFjCsq4rqJVzFz1gQlDZFuLm7S+CQwLYSw3cyyG+z7ANgruWF1ESFQuaeC7R+UUvJBGSUby9m+uYKSLVXA/nzK/kZlg3+CHCroRSl92cW+rOR3VER7no8edd2QkrCL397GmD2/hG//+8dNjTE3/YziJaPxO5Mi0l21pghTU4sSDga69iSAEHyN8brzHRYuhD17qP5oDzu3eSIo2VrN9pJqSkqMkg+N7Tuy2Vlav4BFTlY1+Xl7gP35xqWbGTjAbzPlD85i4KAs8gb09PtSA4fDEefVa1k0dGOKWhpFu97lnbO/z7hxB/uGceN45+zvU/SDd4FPpOakItIpxBo9ZWYvAJtCCJ+PWhoVwPgQwltmNgvIDyF8NsWxxtLS6Kmb7NvsabJybTw9KKPwnGPZXprHh6U9qcrK9dnXublYbg4D+gcG5kP+IE8E+UNyyB+Sw8ChPehbkIf17oUNaP+qsvlsY1tI/if/2Uf+O3cecgvXfSurtk/j5mqmv3cdk9/+WdLPJyLpl+zRUz8Gnjazx4G78WVFJprZl/He2ZPbHGkHu56bmDEj8b4QYN3s9yityGFPVQ9Kq3MprepBFdm+MmxWFmRn89Ibvbn9pB3sPSyXQ4f0IL8gm/x8L3I3YABkN7yBl+hcDYf0tkVeHqlo5E0etw0mrGDmzNEfj56a/skVTM5LQa+7iHQqsedpmNl5+MKEhXU2rweuCSE8koLY2qSllkbiiXu1br4ZKiqiW0ZRImj4fc+eHTAit6VAU6mp4VPTp2v4lEgXlfR5GiGEh8zsYeAwYChe+vWdEEJ128NMk2aGHV1LHnmUttAOSMHFPFFMDbd1VBKpSQwzZ9ZO1FDCEBGaSRpmthI4N4Qwv2Zb8GbJwo4ILKWaufj2gpY/5aeiAzo6X8ZMqps8WUlCRBpprqUxCmh66I4knSbViUimy0p3AFKrbg2mnJzaGkyzZqU7MhER11LSSP8CTN1IcbG3MOoaM8a3i4hkgpY6wm80sziFJEII4bK2BmFmI4E/AsPxeh23hxB+YWaDgL/gt8pWAReGEFpaOKrTKiryW1I11V7BnxcVpS8mEZG6WkoaRwJlMd6nvS2SSuDfo8mC/YA3zew5vErg7BDCT83seuB64NvtPFeMNZtCs53d+fntjSCxadO8DyPRSFcRkUzQUtI4J4TweqqDCCFsADZE3+80s/eAEcDZwKTosD8AL9JC0mip3OvmGIVpC4YMYUsLB6aiouzYsXDBBbncfHNP1q7NorCwmilTyhg7tiIl5xMRaa3WrD3VIcxsFDAOeA0YFiUUQggbzGxoE6+5ErgSoLCwMNEhncbEiRVMnFjR8oEiImmQUUnDzPritcj/LYSww2Ku/R1CuB24HXxGeGvLvSaSjPcQEelqMmbIrZnl4gnj7hDCQ9HmjWa2V7R/L2BTik5e/9HUNhGRbq7JpBFCyOqI/gwA8ybFncB7IYT/qbPrMaBmVNZlwKMpCaCmGHdzDxERyZjbUycClwLvmNnb0bbvAj8F7jOz6cBqYEqa4hMRETIkaYQQ/k7Tg1y1gIaISIbImD4NERHJfEoaIiISm5KGiIjEpqQhIiKxKWmIiEhsShoiIhKbkoaIiMSmpCEiIrEpaYiISGxKGiIiEpuShoiIxKakISIisSlpiIhIbBmxym0ytVQjXERE2k4tDRERia3LtTRycnJU31tEJEXU0hARkdiUNEREJDYlDRERiU1JQ0REYlPSEBGR2JQ0REQkNiUNERGJTUlDRERiU9IQEZHYlDRERCQ2JQ0REYlNSUNERGJT0hARkdiUNEREJLaMTxpmdpqZLTGz5WZ2fbrjERHpzjI6aZhZNnArcDpwKDDVzA5Nb1QiIt1XRicN4FhgeQhhZQihHLgXODvNMYmIdFuZXrlvBLCmzvO1wITmXqAa4SIiqZPpLQ1LsC00OsjsSjOba2Zzt27d2gFhiYh0T5ne0lgLjKzzvBBY3/CgEMLtwO0A48ePD6oRLiKSGpne0ngDGG1m+5pZD+Ai4LE0xyQi0m1ldEsjhFBpZtcAzwDZwO9CCO+mOSwRkW4ro5MGQAjhSeDJdMchIiKZf3tKREQyiJKGiIjEpqQhIiKxKWmIiEhsShoiIhKbhdBognWnZmabgeJ2vk0BkO61SDIhBsiMODIhBsiMODIhBsiMODIhBsiMOJIRQ1EIYUhLB3W5pJEMZjY3hDC+u8eQKXFkQgyZEkcmxJApcWRCDJkSR0fGoNtTIiISm5KGiIjEpqSR2O3pDoDMiAEyI45MiAEyI45MiAEyI45MiAEyI44Oi0F9GiIiEptaGiIiEpuSRgNmlm1m88zsiTTG8HUze9fMFprZPWaW10Hn/Z2ZbTKzhXW23WJmi81sgZk9bGYDOzqGaPu1ZrYk+r3cnOIYRprZC2b2XnS+f422DzKz58xsWfQ1Px1x1Nn/TTMLZpayAjLN/C6ONLNXzeztqADasamKITpfnpm9bmbzozhujLbfHf1dLIz+dnLTEIOZ2Y/NbGn0e/paqmKoE0u961RUPuK16G/zL1EpidQIIehR5wF8A/gz8ESazj8CeB/oFT2/D7i8g849ETgKWFhn22eAnOj7m4Cb0hDDycDfgJ7R86EpjmEv4Kjo+37AUuBQ4Gbg+mj79R3wu0gYR/R8JF4yoBgoSMPv4lng9Gj7GcCLKf5dGNA3+j4XeA04Ljq3RY97gK+kIYYrgD8CWR3x9xmdo951KrpOXBR9f1sqfw9qadRhZoXAZ4HfpjmUHKCXmeUAvUlQrTAVQghzgG0Ntj0bQqiMnr6KV0/s0BiArwA/DSGURcdsSnEMG0IIb0Xf7wTew5P52cAfosP+AJyTpjgAfg58iwTljzsohgD0jw4bQIr/RoPbFT3NjR4hhPBktC8Ar5PCv8+mYsD/Pn8YQqiOjkvp32fD65SZGXAK8EB0SEr/NpU06vtf/D9idboCCCGsA/4bWA1sAD4MITybrnga+CLwVBrOeyDwiaj5/ZKZHdNRJzazUcA4/FPlsBDCBvCLKTA0HXGY2VnAuhDC/I46f8MYgH8DbjGzNfjf63c64PzZZvY2sAl4LoTwWp19ucClwNNpiGF/4PPRbbqnzGx0KmOg8XVqMLC9zoe7tdR+uEg6JY2ImX0O2BRCeDPNceTjn2j3BfYG+pjZtHTGBGBm3wMqgbvTcPocIB+/FXAdcF/06SqlzKwv8CDwbyGEHak+X5w48H+D7wE/SFcM0e/iK8DXQwgjga8Dd6Y6hhBCVQjhSLw1cayZHV5n96+BOSGEl9MQQ0+gNPiM7DuA36Xq/E1cpxL9X0hZC1RJo9aJwFlmtgq4FzjFzGalIY5PAe+HEDaHECqAh4AT0hDHx8zsMuBzwCXRbYCOthZ4KLo98Dr+CStlnb/w8SfXB4G7QwgPRZs3mtle0f698E+bKZUgjv3xDxTzo7/VQuAtMxvegTEAXIb/bQLcD6S0I7yuEMJ24EXgtCi+GcAQ/D5/OmJYi/9+AB4GjkjhqRtdp/CWx8Dodjb430TKbhcqaURCCN8JIRSGEEYBFwHPhxDS8Ql/NXCcmfWOPk1Pxu8jp4WZnQZ8GzgrhLA7TWE8gv/nwMwOBHqQwgXiot/7ncB7IYT/qbPrMfxiSfT10VTF0FQcIYR3QghDQwijor/VtXhH9QcdFUNkPfDJ6PtTgGWpOH+dOIbUjNwzs174h6vFZvYl4FRgak2fQkfHQJ2/T/x3sjRVMTRxnboEeAG4IDostX+bqeph78wPYBJpGj0Vnf9G/I9xIfAnolFDHXDee/B+lAr8YjQdWA6sAd6OHrelIYYewKzo9/EWcEqKYzgJb94vqPNzn4HfO56NXyBnA4PSEUeDY1aR2tFTTf0uTgLeBObjfRxHp/h3cQQwL4pjIfCDaHslsKJObD9IQwwDgb8C7wD/BMam8ndRJ56Pr1PAfvhAgOV4yy9l1wzNCBcRkdh0e0pERGJT0hARkdiUNEREJDYlDRERiU1JQ0REYlPSEEkRM7s8WoV2e8MVcc0sJ9p3Q5rCE2kTJQ2R1BuAT5AU6fSUNERS71ng2lQu9SHSUZQ0RFLvR9HX76U1CpEkUNIQSb0NwK+AK82sKN3BiLSHkoZIx7gJ2APMSHcgIu2hpCHSAUII24CfAV8ws4PSHY9IWylpiHScn+OlbH+Y7kBE2kpJQ6SDBK8v/RNgCnBkmsMRaRMlDZGO9WtgHbUjqkQ6FSUNkQ4UQijDb0+dmu5YRNpCSUOk4/2eFJdHFUkVVe4TEZHY1NIQEZHYlDRERCQ2JQ0REYlNSUNERGJT0hARkdiUNEREJDYlDRERiU1JQ0REYlPSEBGR2P4flhWjNi7XLk0AAAAASUVORK5CYII=\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x2abe39088d0>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "X, Y   = readTrafficData()\n",
    "Nrange = range(4, 44, 4)\n",
    "def dg(N, dep = True):\n",
    "    indsX = np.random.randint(Y.shape[0], size=N)\n",
    "    indsY = indsX if dep else np.random.randint(Y.shape[0], size=N)\n",
    "    return X[indsX], Y[indsY]\n",
    "\n",
    "np.random.seed(0)\n",
    "dataHSIC, dataCSIC = u.sampleRangeExperiment(dg, Nrange, **u.INDEPKWARGS) \n",
    "    \n",
    "figTraffic = u.plotRes(dataHSIC, dataCSIC, Nrange)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Brazilian traffic skewness comparison"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████████████████████████████████████████████████████████████████████████| 10/10 [3:18:38<00:00, 1191.85s/it]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x271b82cd128>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "X, Y   = readTrafficData()\n",
    "Nrange = range(5, 55, 5)\n",
    "Z = X[Y>0.3]\n",
    "W = X[Y<0.3]\n",
    "dg     = lambda N : u.dataGen(N,W,Z)\n",
    "\n",
    "np.random.seed(0)\n",
    "dataKME, dataKVE = u.sampleRangeExperiment(dg, Nrange, perm_test= u.two_sample_permutation_test, mmd1 = u.KME, mmd2 = u.KSE)\n",
    "    \n",
    "figSkewness = u.plotRes(dataKME, dataKVE, Nrange)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Computational complexity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x142fdaef0f0>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "figKMEvKVE = u.compareStatisticsCompTime(range(50, 2050, 50), u.KME, u.KVE, num_aver = 20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x142802ba320>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "figHSICvCSIC = u.compareStatisticsCompTime(range(50, 2050, 50), lambda x,y,k :u.HSIC(x,y,k,k), lambda x,y,k :u.CSIC(x,y,k,k), \n",
    "                                           num_aver = 20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [],
   "source": [
    "figSkewness.savefig(\"SkewnessTraffic.pdf\", bbox_inches='tight')"
   ]
  },
  {
   "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.6.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
