{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.neighbors import KernelDensity\n",
    "from sklearn.model_selection import GridSearchCV\n",
    "from sklearn.metrics import mean_squared_error\n",
    "from sklearn.neighbors import KernelDensity\n",
    "from statsmodels.nonparametric.kernel_regression import KernelReg\n",
    "from matplotlib.backends.backend_pdf import PdfPages\n",
    "from joblib import Parallel, delayed"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "source": [
    "def generate_data(num):\n",
    "    samples = np.empty(shape=(0, 2))\n",
    "    k = 2\n",
    "    while samples.shape[0]<num:\n",
    "        x_1 = np.random.uniform(0, 1, num)\n",
    "        x_2 = np.random.uniform(0, 1, num)\n",
    "        z = np.array([x_1, x_2]).T\n",
    "        u = np.random.uniform(0, k, num)\n",
    "        index = np.where(u <= x_1 + x_2)[0]\n",
    "        samples = np.append(samples, z[index,:], axis=0)\n",
    "    # samples_num = samples[:num, :]\n",
    "    return samples[:num, 0], samples[:num, 1]"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "def plot_err(xaxis, results, labels, xylabels, title=None, path=None, plottype=None):\n",
    "    with PdfPages(f'{path}/{title.replace(\" \", \"_\")}.pdf') as pdf:\n",
    "        for i, (result, label) in enumerate(zip(results, labels)):\n",
    "            if plottype=='semilogx':\n",
    "                plt.semilogx(xaxis, result, label=label, color=f'C{i}')\n",
    "            elif plottype=='semilogy': \n",
    "                plt.semilogy(xaxis, result, label=label, color=f'C{i}')\n",
    "            elif plottype=='loglog': \n",
    "                plt.loglog(xaxis, result, label=label, color=f'C{i}')\n",
    "            else: \n",
    "                plt.plot(xaxis, result, label=label, color=f'C{i}')\n",
    "        # if title:\n",
    "        #     plt.title(title, fontdict = {'fontsize' : 15})\n",
    "        plt.xlabel(xylabels[0], fontsize=15)\n",
    "        plt.ylabel(xylabels[1], fontsize=15)\n",
    "        # plt.xticks(fontsize=15)\n",
    "        # plt.yticks(fontsize=15)\n",
    "        # plt.legend(prop={'size': 15})\n",
    "        plt.grid()\n",
    "        if path:\n",
    "            pdf.savefig()\n",
    "        plt.show()\n",
    "        # plt.cla()"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "source": [
    "num = int(1e3)\n",
    "x_train, y_train = generate_data(num)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "source": [
    "eg_length = 50\n",
    "np_x = np.linspace(0, 1, eg_length)\n",
    "width = np_x[1] - np_x[0]\n",
    "np_histx = np.concatenate(([np_x[0]-width/2], np_x + width/2), axis=0)\n",
    "cond_mean = (1/2 * np_x + 1/3) / (np_x + 1/2)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "source": [
    "### ['gau', 'epa', 'uni', 'tri', 'biw', 'triw', 'cos', 'cos2']\n",
    "kernels_regression =  ['gaussian','tricube', 'aitchison_aitken_reg']\n",
    "results_regression = [cond_mean]\n",
    "for kernel in kernels_regression:\n",
    "    kde = KernelReg(endog=y_train, exog=x_train, var_type='c', ckertype=kernel) ## bw='cv_ls', \n",
    "    # estimator = kde.fit(np_x)[1][:,0]\n",
    "    estimator = kde.fit(np_x)[0]\n",
    "    results_regression.append(estimator)\n",
    "\n",
    "labels = ['ground truth', 'gaussian', 'tricube', 'aitchison_aitken']\n",
    "xylabels = ['Sensitive attribute', 'Regression']\n",
    "title = 'Local regression'\n",
    "path = 'results/syn'\n",
    "xaxis = np_x\n",
    "plot_err(xaxis, results_regression, labels, xylabels, title, path)"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAaEAAAEQCAYAAAAZPssSAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABpsElEQVR4nO3dd3gUxRvA8e+b3kM6vYTeUXrvHQSRoggKShesgIINQeEnKqBUKdKkSpMOoQvSpffeWyCUEAKBzO+Pvch5XHpySWA+z7PPcbMzszN3em92d3ZGlFJomqZpWlqwS+sGaJqmaS8uHYQ0TdO0NKODkKZpmpZmdBDSNE3T0owOQpqmaVqacUjrBmQ0/v7+Knfu3Ekqe//+fdzd3VO2Qemc7vOLQff5xZCcPu/evTtUKRVgma6DUCLlzp2bXbt2Janshg0bqFGjRso2KJ3TfX4x6D6/GJLTZxE5Zy3d5pfjRKSIiKwVkQgRuSwiA0XEPp4yA0RExbL1s8jbTEQOiEikiBwWkTZW6vMWkckiEiYid0Rkhoj4pXRfNU3TtLjZ9ExIRHyANcBhoBmQF/gJIxh+EUfRicBKi7TmwKfACrP6qwDzgTHA+0AjYJaIhCmlVpuVnQMUBDoB0cD3wCKgatJ6pmmapiWFrS/HdQNcgRZKqbtAiIh4AQNEZKgp7RlKqYvARfM0EfkSOKqU2muW/CWwSSn1vun9ehEpCnwFrDaVqwjUB6orpTaZ0i4B20WkjlJqTQr1VdM0TYuHrS/HNQRWWQSb2RiBqXpCKxERX6AuMMsszRmoCcy1yD4bqCgi3mZtuBYTgACUUjuAM6Z9mqZpmo3YOggVAo6aJyilzgMRpn0J1RJwxAgwMfKa0o5a5D2C0c8CsbXBLF9i2qBpmqYlk60vx/kAt62kh5n2JdTrwD9KqeMWdWOl/jCL/XG1IdjawUSkC9AFICgoiA0bNiSiqU+Fh4cnuWxGpfv8YtB9fjGkRp/TYoi2tWm7JZb0ZzOKZMG4dPdpAusXK+mJaoNSajwwHqBMmTIqqUMU9ZDOF4Pu84tB9zll2PpyXBiQyUq6N9bPTqxpjREw5lipGyv1x7y/bZbPWhsyJaINiXdxNznOL0i16jVN0zIiWweho1jcdxGRHIA71u/TWPM6sFkpdcEi/RQQZVm/6X00EHPp7pk2mOVLaBsSb98s8p6eCn8NS7VDaJqmZTS2DkIrgPoi4mmW1gZ4AGyMr7CI5AYqYDYqLoZS6iGwHmhlsasNsFUpdcesDZlNzxTF1FsG437QClJLw++5Flgd1n4Df49MtcNomqZlJLa+JzQO4yHSBSLyPcYP/wBgmPmwbRE5CWxUSr1rUf514DEwL5b6BwEbRGQExsOnjUxbg5gMSqmtIrIKmCYivXn6sOrmVH1GyM6eo4U+ICjAF1Z/AXYOUKF7qh1O0zQtI7BpEFJKhYlIbWAUsATjHsxwjEBk2S5rU/m8DqxVSt2Ipf7NItIS+BbojvHsT1uL2RJi6hkO/IZxNrgUIzimKmVnDy0mQPRjWPmZEYjKdU7tw2qapqVbNh8dp5Q6DNSKJ0/uWNJLJaD+RRhnQXHluQ10NG22Ze8Ir/0Gc9+C5b2NQFTG9s3QNE1LD/R6QmnBwQlaT4X89WDph7Dn97RukaZpWprQQSitODhD6+mQtxb82VMHIk3TXkg6CKUlRxd4fSbkrWkEon+mpXWLNE3TbEoHobTm6Aqvz4J8tWFxL9g1Oa1bpGmaZjM6CKUHji7QZgbkr2/cI9oxIa1bpGmaZhM6CKUXji7QZjoUaGiMmts+Pq1bpGmalup0EEpPHJyh9TQo1ARW9IGtY9K6RZqmaalKB6H0xsEJWk2Bwq/Aqn6weURat0jTNC3V6CCUHtk7QsvfoFhLWPM1rPsOVIJWutA0TctQ0mI9IS0h7B2hxXhj9NymoRAVAfW+BZH4y2qapmUQOgilZ3b20PQXcHKHraPg0X1oPAzs9AmspmnPBx2E0js7O2jwP3B0g83DjDOiZmPAXn91mqZlfPqXLCMQgTpfG2dE6wYZgei134xBDJqmaRmYvq6TkVTrDfWHwJElMKuNcXlO0zQtA7N5EBKRIiKyVkQiROSyiAwUEWtrB1kr20JEdorIAxG5KSIrRcTdbL+KZXtolid3LHlmp0Z/U1zFHvDKKDi9AaY1g4hbad0iTdO0JLPp5TgR8QHWAIeBZkBe4CeMYPhFPGU7YSyGNxToA/hgrEtk3oeKVoouAbZYSe9tkR6aoE6kBy+3B9dMMO8dmNIY2i0Aryxp3SpN07REs/U9oW6AK9DCtJx3iIh4AQNEZKj5Et/mRMQfYyXUXkop84nVFprnU0ptsyhXFvAHZlmp9phl/gylcFN4cx7Mbgu/1YP2i8Avb1q3StM0LVFsfTmuIbDKItjMxghM1eMo19r0OjWRx3sDuI9xNvT8Ca4Oby+Gh+HwWwO4eiCtW6RpmpYotg5ChYCj5glKqfNAhGlfbMoDx4B3ReSiiESJyHYRqRRbARERoBXwp1IqwkqWySLyRESuiMgwEXFNdG/Sg2yl4Z1VxsOtkxvDub/TukWapmkJJsqG08GISBTQRyk1wiL9IjBNKdU/lnKrgErAXaAvcNP0WgbIr5S6ZqVMNWAj8IpSaolZehbgc2C1qb4awKfAaqVUs1iO3wXoAhAUFFR69uykjWEIDw/Hw8MjSWXj4xx5g5L7vsb54Q2OFP6Y0ABrt8dsLzX7nF7pPr8YdJ8Tp2bNmruVUmWe2aGUstkGRAEfWEm/BHwXR7kQQAENzNK8gDBgUCxlxgK3AKcEtKu7qf5S8eUtXbq0Sqr169cnuWyChIcqNb6WUgMyKbVjQuoeK4FSvc/pkO7zi0H3OXGAXcrKb6qtL8eFAZmspHsDt+MoFzMOeUNMgjLuK+0GilhmFhEH4DVgvlLqUQLaNc/0+nIC8qZf7n7GPaL89WDZJ7B2kJ74VNO0dM3WQegoFvd+RCQH4I7FvSILRzDOVCxn7xQg2kr+2kAA1kfFWaMsXjMuJ3djldaX2sNfP8LinvAkKq1bpWmaZpWtg9AKoL6IeJqltQEeYNy/ic1SjIBTMyZBRLyB0sA+K/nfAK5iduYUj5am190JzJ++2TvAKyOh+qew53djGLeeXUHTtHTI1kFoHPAQWCAidUw3/AcAw5TZsG0ROSkik2LeK6V2AX8Ck0TkbRFpDCzGuMc02vwAIuIMNAfmKKWeOUsSkQEi8pNp9oU6IjIQ4xmkBUqp/Snc37QjAjX7Q5MRcHINTGkC4dfTulWapmn/YdMgpJQKw7hUZo/x7M43GAHga4usDqY85toBi4BhGPdwooBapjrNNcS4xxTbELajGM8kTQaWA22BH0yvz58yHY3Lc9ePwMQ6cON4WrdI0zTtXzafRVspdRhjup248uS2khaOMYqtezxlF/HsvSPz/bOJPUClGqUUDx6n0S2nQo2g4zKY2QYm1YHXZ0LuKmnTFk3TNDN6Fm0b+d/Ko3y37QF3I9NokEC20tBpDXhkhmnNYd+ctGmHpmmaGR2EbKTmreNU2x3Ch5O28OixtQF9NuCTG95dBTkrwMIusHGoHsKtaVqa0kHIRvJcOEr7IyvpNu5jZn/wDY/Dw5Nc16qzq7h472LSCrv6GLNul3gd1n8Hf/aExwl5lErTNC3l6SBkI0GffcrNfp8RWbAYZdfO5VC1WoT+Op4n4YkbOv3H8T/ovbE3327/NumNcXCCV8cZQ7j3/g6/t9DrEmmaliZ0ELKhx7lyUfWPqSzu/h17PLNzY/hwTtWpQ+j4CUTfjz8Y7bq6i8HbBuPh6MHfl/7mcvjlpDcmZgj3q+PhwnZj5FzoyaTXp2malgQ6CNmYiPBxz+ase/szPqrxARF5C3Fj2DBO1q5D6ITYg9Hl8Mt8vOFjsntmZ0qDKQAsOrko+Q0q2QbeXgKRt2FiLWPFVk3TNBvRQchG7kfd596TewA42tsx5s2XsStclDfztuHJqIm4FC/OjZ+GcbJOXW5OmkR0xNPVJyKiIui1rhePox8zstZICvoWpFLWSiw8uZAn0U+S37icFaDzOvDMAr+/BrsmJ79OTdO0BNBByEZ+3PUjQy4PYeMFY3YiD2cHJncsi7erIx23P4D/jSDXrJm4FC3K9R9+NAWj33h8P5wvtnzBydsn+aH6D+T2zg1Ai/wtuHr/KlsuW1u5PAl8csO7qyG4Biz9EFb2h5QIcJqmaXHQQchG2hZqi6e9Jz3X9WTg1oFEREUQ5OXClHfKEfUkmrYTt3EnuBA5J04g18yZuBQqxPUffuBQrWo4z11F72K9qJyt8r/11cxRE18XXxacWJByjXTxhjfmQLmusG208XBr5J2Uq1/TNM2CDkI2kt8nP72z9KZD0Q7MOz6P1ktbczD0IAWCPJn2TjluR0Tx5sTthIY/xO3ll8j52ySuD/uQoz6RvLUumvLvT+HmlClER0YC4GjvSLO8zdh4YSOhD0JTrqH2DtBoKDQeBqfXw4TaesCCpmmpRgchG3IURz4p8wkT600k8nEk7Za349d9v1IkqwcT3y7N5fvneW3aaL7bOpSOKzvy0c1fWfz+S2SZ9hvO+fJz/X/fc7JuXW5Nm0Z0ZCSv5n+Vx+pxygxQsFT2XXjrT4i4aQxYOLk25Y+hadoLTwehNFAuSznmvzKfernrMWrvKJoubMpH25rimOsHbrlPZs6xWTx4/JBWBVrxc82fyVSuIrmmTCbntKk45wnm2uAhnKpbD+8/N1PO9yUWnFgQs0JsyspdBbqsB6/sMKMlbB2tZ1jQNC1F2XwCU83g7ezN0GpDqZ69OgtPLqRS1koU9S/KndtBfLvwFvIogI/ql8XF8elk4u7lyuE+rRz3t+8gdORIrg0ezId+Xkx9OZydpbdQLlcqTEoaM2BhYVdY1R+uHYImw8HBOeWPpWnaC0cHoTTWOLgxjYMb/yfNx+ESH83dS48Z/zCuXWmcHP57wupevhxu5aYRsX0H10b+zLshe7i/sxe3evUmU6tW2Dk5pWwjnT2g9XTY+D1s/B/cOAZtpoNX1pQ9jqZpLxybX44TkSIislZEIkTksogMFBHLtYNiK9tCRHaKyAMRuSkiK0XE3Wz/FBFRVjbLJcW9RWSyiISJyB0RmSEifind16Rq/lI2vmtenHVHr9Njxj88fPzsUGkRwb1CefL8PoPNfetw0eMR1wZ9y6l69bk1cybRj1J4Pjg7O6jZzwhG14/A+BpwflvKHkPTtBeOTYOQiPgAawAFNAMGAp9gLG4XX9lOwEyMJcIbAp2AEzx7NncUqGixnbXIMweoYaqjA1AWY8G8dKNt+ZwMalaUNUeu0XX6biKjrD+zIyJUa96TL9sJx79ui2OWLFwbOIhT9RsQNns2KqWDUZFXoPNacHKHKY1h50R9n0jTtCSz9ZlQN8AVaKGUClFKjcMIQB+LiFdshUTEH2MF1l5Kqa+UUhuUUguVUr2UUpYPstxXSm2z2CLN6qoI1AfeVkrNV0otxFi1tYqI1Enh/iZL+4q5+V+L4mw8foPO03bx4JH1QFTQtyDF/Iszxe0fcs74nRyTJuIYFMTVAd9wskEDwubMTdlgFFgYOq+HvLVg2SewuBdERcZfTtM0zYKtg1BDYJVS6q5Z2myMwFQ9jnKtTa9TU6gN15RSm2ISlFI7gDOmfenK6+Vy8kPLkmw+GUrHKTu4//Cx1XyvFXiNk7dPcuDmATwqVybXrJnkmDABh4AArn79NacaNCRs7lxUVAotqueayXiwtVof2DMdpjSCu8mYUFXTtBeSrYNQIYzLZf9SSp0HIkz7YlMeOAa8KyIXRSRKRLaLSCUreYuIyF0ReSgim0XEMrg90waTI/G0Ic20LJ2dEW1KsePMLTpM3sE9K6uzNszTEFcHV+YemwsYl+k8qlYh9+zZ5Bj/K/b+/lz9yghGt+fNS5lgZGcHtb6ANr8bgxV+rQZn/kp+vZqmvTAkVZ4vie1gIlFAH6XUCIv0i8A0pVT/WMqtAioBd4G+wE3Taxkgv1LqminfB8Aj4DAQgHG/qTRQxXS2g4iEYFyya25xjN+BYKXUM4FNRLoAXQCCgoJKz549OyndJzw8HA8PjySVBdhx9THj9j0kt5cdn5Rxwd1R/rN//q35bLy3kT6Z+5DDOcd/CyuF08FDeCxdiuO5czz29+N+w0ZEVigP9gkaFxInt/sXKHrof7hFXOZ0cHsu5HgVRJLd54xI9/nFoPucODVr1tytlCrzzA6llM02IAr4wEr6JeC7OMqFYAxmaGCW5gWEAYPiKOeKcZltkUVdC63knQFsia8PpUuXVkm1fv36JJeNseLAFZWv/zLVcMQmde3ug//su/Pwjqo+u7p6fcnr6vGTx1bLR0dHq7vr16vTr7VUhwsWUifq1FVh8+ar6KioZLdNRd5Vak57pb72Umr2m0o9uJMifc5odJ9fDLrPiQPsUlZ+U219OS4MyGQl3Ru4HUe5mGU/N8QkKOO+0m6gSGyFlFIPgOXAywloQ6Z42pAuNCiWmYlvl+Xszfu0HLuVs6FP1x/ycvKid9neHLx5kPkn5lstLyJ41qhB7j/mkn3sGOw9Pbny+eecatSY2wsXoR5bv+eUIM6e0Goq1PsWji6HCbVwu38+6fVpmvbcs3UQOorFfRcRyQG4Y/0+TYwjGGdCYpEuQHQCjmt+zfGZNpjEdq8o3aleIICZnStwLzKKluP+5uClpwMEG+dpTLnM5Rjxz4g4JzYVETxr1iT3/HlkHzMaOw93rvTrx6nGjbm9KBnBSAQq9YK3F0PkbUrv7gMHrQdETdM0WwehFUB9EfE0S2sDPAA2xlFuKUbAqRmTICLeGPd79sVWSERcMUa87bZoQ2YRqWKWrwwQbNqXIZTKkYl53Svh7GBPm1+3suWkEXBEhM8rfM6Dxw8Yvnt4vPWICJ61apFn/nyyjx6FnZs7Vz7rx+nGTbjz55+oJ0lcUyh3Fej6F+EeuWHeO7C8LzxO4WeWNE3L8GwdhMYBD4EFIlLHdMN/ADBMmQ3bFpGTIjIp5r1SahfwJzBJRN4WkcbAYox7TKNNZbxF5C8R6SoitUWkDbAeyAYMNqtrK7AKmGaagaE5xv2gzUqpNanZ+ZSWN8CD+d0rkd3HjY6Td7J0vzFEOtg7mI5FO7L41GJ2Xt2ZoLpEBM/atcmzYD7ZR41EXF25/OlnRjBasiTOYBStopl5ZCaj947mweMHT3d4ZWFvqe+gwnuw41eY3ABu68tzmqY9ZdMgpJQKA2oD9sASjAdVhwNfW2R1MOUx1w5jVoNhwDyMAFTLVCcYwe0G8AXGfaDxGPd4qpuCmLnXMc68fgOmYZwpvZqszqWRzN4uzO1akZI5vOk1aw9TtpwBoHOJzmTzyMa3274l6knCh2OLCJ516pBnwXyy/fIz4uTE5T59Od30Fe4sXfZMMLoecZ2uIV0ZsmMI4/aNo+Xilv8JfMrOARoMhtbTIPSEMYz7+OqU6bymaRmezeeOU0odVkrVUkq5KqWyKKW+VEo9sciTWynVwSItXCnVXSnlZypbRyl1wGx/pFKqhVIqh1LKWSnlrZRqoJR6ZoIzpdRtpVRHpVQmpZSXUqqtUioFV4azLW83R6a/W546hYMYsOQwX/95EEdxpl+5fpy+c5pph6cluk6xs8OrXj3yLFpItp9/Ruztudy7N6dfacadZUYwWntuLS0Wt2DfjX18XfFrJtWbRLSK5p1V7/Dttm8JfxT+tMIizaDLBmNZiJmtYO1AeJKMQRCapj0X9HpCzwkXR3vGtStNpyp5mLr1HJ2m7eLlgErUylGLX/f/yuXwhM9msP3KdhrMb0DbZW0ZvW8Mp18KJMfCeWQbMRyxEy5/0pvtdSsxZ+z7ZHfLypwmc2hZoOW/6yS1L9Keucfm8uriVzn84PDTiv3yQqcQePkt+OsnmN4c7l1L+Q9D07QMQweh54i9nfBFkyIMfrU4f50IpeXYrbxV4AMABm4d+N/7NbFYcmoJ3dZ0w9HOERFhwoEJtF/RnupzazDAZTV/D2nN9DeCuPvoLh8tiua78RH4bT2GijYGKbo5utG3bF+mN5qOm4MbY6+P5eu/v+ZJtOlk19EVXhkJzcfCxV0wrgqc3pBaH4mmaemcDkLPobblczK1Yzku33lA1ymneC1PF7Zc3sJri1+LdaCCUorx+8fTf3N/Xg58mRmNZzCj0Qw2tdnEj9V/pG7uuuy/sZ/vdw9lRxEHfOZMIetPP0K04tKHH3Gm+avcXbX632BUMqAkfzT9gzpedVhwYgGj947+7wFLtTVWbXXzhWnNYf1giE7iSDxN0zKsJC1qJyIFgOyAi+U+pdTy5DZKS74q+f1Z2KMy70zZyaTl2eje4HtWXxvJO6veoWWBlnxc+mM8nYyR8lHRUXy37Tvmn5hPk+AmDKw0EEd7R8BYAbZ+7vrUz10fpRQX713Ez9UPN0c3yAZeDRpwd8VKQseM4dIHH+BcsCD+7/XAs04dnOydaObTDM9ATyYcmECpwFJUy17taSMDC0Pndcbw7Y3fw7m/ocUE8MqSFh+ZpmlpIFFnQqYF6Q5gPDy6BuP5HfNtSYq3UEuyfIEeLHqvMqWyZ+LnpYpKrkN4q/DbLDixgOaLmrP+/HruR92n17pezD8xn87FOzO4yuB/A5AlESGHVw4jAMWk2dvj3aQxwUsWk/WHoahHj7j0/gecafEad0NCQCn6l+9PQZ+C9PurH5fCL/23Uid3aD7auDx3abdxee7k2tT8WDRNS0cSeznuV8AJaAEUBPJYbMEp2jot2Xzdnfi9U3naVcjJpE2X2Lu/CmNqTsHbxZv3179PowWN2HZ5GwMqDuD9l99HxHJSioQRe3u8mzYleOkSsg79HvXgAZd6vY/v4MFEbdjMT9V/IlpF88mGT3j0xMpDq6XaGmsUuQfA76/p0XOa9oJIbBB6CfhEKfWnUuqEUuqc5ZYajdSSx8nBjm+bF2doyxLsPBtG3xlhfFlqPD1L9cTNwY2RtUbyWoHXUuRYYm+P9yuvELxsKVn+NwSJfMjFnr140vEjfrBvzaHQg3y/43vrhQMLGZfnXmpnjJ6b0kg/3Kppz7nEBqFTWLkPpGUMrcvkYF63iiilaDN+J36PG7PitRVUzV41xY8lDg5kat6cmwO+JsuQIUSH38fv6/FMmOPDyWWzWXJysfWCTm7QbBS8NgmuHTYuzx2OJa+maRleYoPQJ0B/EdGX3TKoEtkzsaRXFcrk8qH3H/v4ctFBHj5OxVFp9vZkerU5eZctJct33+H/2IXP5kVj17kfx5bOjFlG41nFW0K3TeCbF+a2N5YR10uIa9pzJ7FBaAjGXGxHReS4iOyw3FKhjVoK8/NwZto75ehSLZjp287x2ti//7MkRGoQR0cyvdaCvMuX4/HVp3hFCtG9B3G8ZQvCN22yHox8g+GdVcas3DsnwsTaxgqumqY9NxIbhA5izMs2A9gCHLKyaRmAg70d/RsV5tf2pTl/M4ImIzezeF/CZ1VIKnF0JEfbDrj8MYGJjZ25evEYF7p05VTrVoT/tfnZYOTgZKxP9OY8uHcFfq0Ou6eADVcE1jQt9STqOSGlVMfUaoiWNuoXzUzRrF68P2sP78/aw9ZToXzVpCiuTslf8jsuZbNXJOfAVfy6exRhCxfS4u/DRHXujHPJEgT2eh/3ypX+O1Ivf13o/jcs7ApLPoBT66Dpz+Dqk6rt1DQtdSV5xgQR8ReR/CLil5IN0mwvu48bc7pWpHuNvMzacYHmo7dw4tq9VD9ukHsQX1UbRM+v/2T+oFr82sCOK2cPcaFTJ86+0ZbwLVv+e2bkmRnaLYQ638DRZTC2ivGAq6ZpGVaig5CItBGRI8A1jJVIr4vIERFpleKt02zG0d6OTxsUYuo75QgNf8gro7Ywc/v52AcOpKC8mfIyot4o3uo3nQmfl2RCfTsun97HhXc7sa9lE8I2b3zaDjs7qPIhvLsa7B1hSmNjyh/9TJGmZUiJnTHhDWAWcBroCDQyvZ4GZovI6wmoo4iIrBWRCBG5LCIDRSRB135Mi9DtFJEHInJTRFaKiLtpn72IfGpa2O6maVstImUt6sgtIsrKNjsxn8XzqnqBAJZ/UJXSuXzov/AAnabu4vo924xKeznoZSY3/Z2WfSewemhzfm/szr3zp7naqRvrm1Zm/cJfuP/INIAiW2no9heUaGNM+TOlEYTpx9Q0LaNJ7JnQ58B4pVRjpdQ0pdQq02tjYALGgnKxEhEfjOl+FNAMGIgx7Pub+A4sIp2AmRhLcDcEOgEneHpfyxX4DNgJtMdYBC8K2Cwipa1U2RuoaLbF2fYXSZCXC9PeKcfXTYuw+WQoDUb8xapDV21ybBGhUrZKfFNjMAN+2IrDH7+yp10ZXK/dIXO/saxuUo5hE95h08VNRDm6wKvjoMVEuH7EeKZo/1ybtFPTtJSR2AlM8wEfxbJvPtAhnvLdMIJFC9Ny3iEi4gUMEJGh5kt8mxMRf4wVWHsppSaY7Vpo9u8HQLDZSquIyFrgONAT44zN3DFrC95pBjs7oWPlPFTJ58+Hc/bSdfpuWpXOzldNi+DpYn1uuZTmaOdIxdzVqPhFNaI+ieDQ5BHkmjaPQj9t5eAf2+hWy4vgGk1pHNyYkl03IQu7wYLOcCIEGv8ILt42aaemaUmX2DOha0CZWPaVMe2PS0NglUWwmY0RmKrHUa616XVqbBmUUk/MA5Ap7RHGsPHAeNqlxSJ/kCcLe1SmZ818zP/nIg1//ottp2/avB2Orm6U6tGfUhu34t/vUwqHe9J7yh0KfT2T78a3o9H6HvxSqhGnK/eEg/ONQQvn9d8YmpbeJTYITcY4a/lCRAqJiI+IFBSRL4Cvgd/iKV8IYzDDv5RS54EI077YlAeOAe+KyEURiRKR7SJSKa6DiYgzUBo4bGX3ZBF5IiJXRGSYiLjG0/YXlpODHb3rF+SPbhWxE+H18dv4ctFBwh/afjCAnbMzAW93oMi6jQT1+4xi4ZkY+PsTPpx6m80rJ9Ls8mJaFavIZFfh6rQmpkELUTZvp6ZpCSOJGf0kInbAIOADjLOXGA+AEcCXKo4KRSQK6KOUGmGRfhGYppTqH0u5VUAl4C7QF7hpei0D5FdKWT0DE5GBwKdACaXUMVNaFox7W6tN9dUw5VmtlGoWSz1dgC4AQUFBpWfPTtoYhvDwcDw8PJJUNr14+Fgx/8QjQs49xtdF6FDUieIBsV/VTfU+P3qE26ZNuK1ajf29e1zNH8T8qg5sDDL+kyj/IJLPHnhzs+DHPHDLmnrtMPM8fM+Jpfv8YkhOn2vWrLlbKfXslTSlVKI3wAeoinGZrCrgk8ByUcAHVtIvAd/FUS4EYzBDA7M0LyAMGBRLmcbAE+DDBLSru6n+UvHlLV26tEqq9evXJ7lserPr7E1V68f1KtenS9Unc/eq2/cfWc1nqz4/iYhQoZN+U8cqVVaHCxZSx956U82Y+5UqP620qjWpiDr6fXaldk1RKjo61dvyPH3PCaX7/GJITp+BXcrKb2qSHlZVSoUppf5SSs01vYbFXwpMQSOTlXRv4HYc5W6ZXjeYteEusBsoYpnZNCx7DvCrsjjrisU80+vLCcirAaVz+bLs/aq8VzMvC/dcos7wjaw8eMUmzxVZY+fqit87HckXsprAPn3gxBle+nIuk9cUIPetTLwd5MOWNX1h9ptwPzRN2qhp2rPiHR0nIo2AzUqpu6Z/x0nFvbz3USzu/YhIDsAdi3tFFo5gnKlYrrgmQLRFfQWAZcBaoFd87TVRFq9aArg42tOnfiEaFstCn3n76fb7P9QuFMiAV4qSw9ct/gpSgZ2bG37vvoPPG68TNmsWNydOovf2MI4X9GBYhQCuXdlMizEVodloKFAvTdqoadpTCTkTWsrTwBGzhLflst4JXd57BVBfRDzN0tpg3FPaGE8bBKgZkyAi3hiDDvaZpWUBVmGse/SGUiqhaxS0NL3uTmB+zUyxbN4s7lmZzxsVZuvpm9QdvpGxG07x6HF0/IVTiRGM3iXfmhACPvmYQtfs+XbqEx6s9WBKpDtqZitY+jE8St3ZwzVNi1tCnhPKA1wx+3dyjAPeBxaIyPcYy4EPAIYps2HbInIS2KiUehdAKbVLRP4EJonIZ0AoxsCEKGC0qYwrRpDzwXguqITZBJgPlVJ7TPkGAJ4Ys4DfBaoBfYAFSqn9yezfC8vR3o7O1YJpVCIL3yw+xPcrj7Lgn4u0zP2EGmnYLjt3d/w7d8bnjbaE/j6NohPG4TzjISEF8lLx1nQ8T2+AFuMhe2xPHmialpriDULKbMlulczlu5VSYSJSGxiFcdZ0G+Mh1AFW2mU5lU874AdgGOCGEURqmd2PCgJKmv691KLsOSC36d9HMWZL6IQxwu+8qd7vktYrzVy2TK6Mf6sMaw5f4+vFhxiyI5ITT/bRt0FBAj3TblFeew93grp1x69de0J+/BD/RVu4eNwf92MPCDjVCNfmH0K1PsZ8dJqm2UyiZkwQkcKAtzLNNGA6+/gSY3DAWqXUyPjqUEodBmrFkye3lbRwjFFs3WMpc5Zn7xlZyzcb4wFZLRXVKRJEpXx+9Jm8jj/3XmLlwau8XzsfHSrlwckhyZO3J5uDhwcNB0xkRpOJHBs/nBa77Ll/zg+Pg+Pxr7EM126TIaBAmrVP0140if01GAM0NXv/I8YzQy7A9yLSJ6UapmV8bk4OtCroxKoPq1Eujy+Dlx+lwYhNrD96Pa2bxptlOpGj54d06RrNgebFiLjtw9kZt7jwRkMi5w6C6LS7n6VpL5LEBqFiwFYAEXHEuET2oVKqAdAfeCdlm6c9D4IDPPitQ1kmdzQmNO84ZScdJ+/g1I3wNG1X5xKdaVe2C4MKH2XpTy3w79KBiBsunPlqJheblyNyZ1xjZTRNSwmJDULuGDfzASqY3i8wvf8HyJVC7dKeQzULBrLyw2p83qgwu86GUX/4JgYsPsSt+4/SrE29XupFu8LtmHJuLrNquJJv09/4t6jM/TPhnGnfjYtvvUrk0bieHtA0LTkSG4ROYwQfgFeBPUqpmNks/YHUX45Ty9CcHIxRdOt616BVmRxM23qW6kPXM2bDSSKjEjqiPuWICH3L9qVlgZZMODCBSefmEDB4IvmWzMW/kjf39xzmTPNXufhedyKPH/9P2YdPHjJi9wjeW/seZ+6csXnbNe15kNggNBz4VkR2Ygy1/sVsXw1AD3HWEiTA05khLYqz+qNqlA/2ZejKY9T8cQPzdl/kSbRtnxkWEb6s8CVNg5sycs9IBvw9gBsBgQRM3EK+H9/Fr1gE9zet58wrzbj44Uc8PHGC/Tf202pJKyYdnMTOqztpubglkw9O5km07QOppmVkiRodp5SaJCIngLLAZ0qptWa7b2FMYqppCZYv0JOJb5dl2+mbDFl+hN5/7GPS5jP0bVCQGgUCMHvWK1XZiR0DKw/E29mb2cdms/jUYloVaEWnqp0ILNUEv1mduLnpPLfWhXB31Up2FrLDu24Avzb7lQK+BRi0dRDDdg8j5FwITR2bxn9ATdOAxJ8JoZTapJT6ySIAoZQaoJRalnJN014kFYL9WNijMiPfeIn7Dx/TcfJOWo3batO1ixzsHPi03KcsfXUpr+R9hTnH5tBwQUN+OL+M250WcKVzKwZ0esyiCkLZ00L/kdfJ9dN8PC/fYUTNEQytNpQL9y4w9MpQJuyfwONo2y91oWkZTaKCkIhUFZFmZu/9RWSmiOwVkZ9MI+Y0LUns7ISmJbOy5uPqfNu8GBfCInh9/DbaT9rO3gu3bdaObB7ZGFBpAEuaL6F+7vr8fuR3Gv75Cm/dWMfNwCBqlHOlSKNL+NXIzb316zndpCmX+/SllirIomaLKO5WnF/2/ELbZW05dPOQzdqtaRlRYs+EhmIM047xM1Ab2IaxtPc3KdMs7UXm5GBHuwq52NinJl80Lsyhy3dpPnoLnaft4vBlqyvAp4ocXjn4rsp3LGq2iIZ5GvJm4TdZ2GIZlTptwaHmewQG/U2+1lH4tarPvXXrON2kKZFffU/nJ434qfpPXI+4TttlbRmyfQj3HukxO5pmTaLuCQEFMQUaEXHDGCH3jlJqtmmwQn/TpmnJ5uJoT6eqwbxeLie/bT7DhE2naXT4L+oVCeL92vkpls3bJu3I452HbypZ/H1V71so1ASHhd0IfPgbvv06cvNUIGFz5uG3dCneTZswv9Moxt36k1lHZxFyLoS+ZftSP3d9m93n0rSMILFnQk5ApOnflTGCWMx9oONAlhRql6b9y8PZgfdr52fzp7X4oHZ+tp6+SZORm+k0dSf7bHiZ7hk5K0D3LVCuKw6HJhPk9gf5pgwhonZt7q0O4XrzNnRceI9ZJYYR4BZAn0196BrSlXN3kzUFo6Y9VxIbhI4CDUz/fhPYqpSKuc6QlaeLz2laivN2c+SjugXY/GktPq5bgJ1nw2g2egsdJu9g97mErquYwpzcodFQeHspRD/GYWEbgkrdJt+Kxfi+9RZ3V67Ert2HDNuch69zdOVA6AFa/NmCVWdXpU17NS2dSWwQGgh8JCI3gLbA/8z2NQD2pFTDNC023q6OpjOjmvSpX5B9F27z2ti/afPrVjYcu542q7vmqQrdt0LZd8lxcTEOfzQjqG0N8q0JwbddO+6tWEnRXuOYsbcSlcnLZ399xuZLm23fTk1LZxIVhJRSi4HCQDegmFJqhdnurejlEDQb8nRx5L2a+dj8aS2+aFyYczcj6DB5J41+2czifZd5/MTGk5A6e0Djn9hbchA8iYLf6uPwzwiCPnmfvCGr8XmzLY9WrqH794f5JMSV7xZ8wD/X/rFtGzUtnUnKc0KnlVLzlVLHLdLHxyzxEBcRKSIia0UkQkQui8hAEbFcOyi2si1EZKeIPBCRmyKyUkTcLfI0E5EDIhIpIodFpI2VerxFZLKIhInIHRGZISJ+CWmDlv64OzvQqWowm/rW5IeWJXj0+Anvz9pDrZ82Mn3bOR48su0sBrd9SkCPv6FMR9g6CsZVxvHBSTL370/ekBB83mhL6b33+WFsBDs+7Mjhgxts2j5NS08SHYREpISIzBGRUyLyUEReNqV/JyIN4ynrA6wBFNAM4/LeJyRgaLeIdAJmYqye2hBjUboTmI3wE5EqwHxgvSnPMmCWiNSzqG4OxjRDnTCGlpcFFsXXBi19c3Kwo1WZHIR8VJ1f25fG192JLxcdpOL/1vLjqmNcvxsZfyUpxdkTmgyHtxZD9GOY3AhWfIqjjzuZP+9PvpDVuLV6lcr7HxHdujvHPv2QqEuXbNc+TUsnEvuwakNgN5AZmAaYP5z6EOgVTxXdMFYzbaGUClFKjcMIQB+LiFccx/XHmLeul1LqK6XUBqXUQqVUL6XUHbOsXwKblFLvK6XWK6X6ACuBr8zqqgjUB942ndEtxFiSooqI1EnQB6Gla3Z2Qv2imVnYoxJzu1akfB5fRm84SeXv1/HJ3H02fdaI4OrGvaJynWH7OBhbCc78hWNQEMHfDMZj0XQ2l3bl4dJVnKzfgCtfDyDq8mXbtU/T0lhiz4SGAFOUUtV59v7PXqBUPOUbAquUUua/ArMxAlP1OMq1Nr1OjS2DiDgDNYG5FrtmAxVFJOahkobANaXUppgMSqkdwBnTPu05ISKUy+PLr+3LsKF3Dd4sn4sVB6/Q6Je/aDthGyGHr9lmslRnD2j0A3RYBghMbQJLP4aH98iTvww1f55Fv17e/F3ajdvz5xvBaMAAoq5cSf22aVoaS2wQKoRxKQuMS2rm7gK+CSj/n8VZlFLngQjTvtiUB44B74rIRRGJEpHtIlLJLE9ejDMzy8VfjmD0M2bN5mfaYJYvrjZoGVguP3cGvFKUrZ/V5rOGhTgTep/O03ZR/Yf1/LrxFGG2WNModxXjuaIK78Gu32B0BTixhoK+BfmuxTh+racY2ic3bs2bcHv+Ak7Vq8/VgQOJuno19dumaWlEEjOcVUTOA98qpcabBhNEAWWUUv+IyHvAB0qpAnGUjwL6KKVGWKRfBKYppazOtiAiq4BKGIGuL3DT9FoGyK+UuiYilYHNwEtKqb1mZfNh3Duqr5RaLSIhwH2lVHOLY/wOBCulzANbzL4uQBeAoKCg0rNnz471M4pLeHg4Hh4eSSqbUaXXPj+JVvxz/QlrzkVxLCwaRzuokMWBOrkcyOWVoHEysUpIn73uHKXgsZG4R1zkalAtTuZ7h0OPLzPu+jiyOmXlA4e2+K3egOuWv8HOjgeVK3O/QQOifTIlq22pJb1+z6lJ9zlxatasuVspVeaZHUqpBG8Yc8ddBaoA9kA08BLGWcZ54Ot4ykdhBCrL9EvAd3GUC8E482pgluYFhAGDTO8rm/KUtCib35Re16yuhVaOMQPYEt9nULp0aZVU69evT3LZjCoj9PnIlTuq34L9qtAXK1SuT5eqV0dvVn/suqAePHqcpPoS3OeoSKXWDFRqgI9SQ/MpdehPtf78elVqain19oq3VURUhHp44aK6/MWX6nDRYupI8RLqyqBv1aOr15LUrtSUEb7nlKb7nDjALmXlNzWxl+O+BHYBG01BB+BP4CDGgnaD4ykfBmSyku4N3I6jXMxMDBtiEpRxX2k3UMSsbqzUH/P+tlk+a23IFE8btOdUocxeDH61ONv61eaLxoW5HRFF7z/2Ue67NQxYfIgT11Jp8lEHZ6j9JXTZAJ6ZYW57avw9iSFlP+Wfa//w0fqPIEsAWQYNJO/KFXi90pSwWbM4VbcuV78bTNT166nTLk2zocQ+rPpQKdUEqIcxSGAixrDpxkqpJkqpqHiqOIrFfRcRyQG4Y/0+TYwjGGczljM/CsbZGMApjDMty/s6hUx5Yp5reqYNZvniaoP2nPN2c6RT1WDWflKdWZ0rUL1gIDO2n6Pu8E20HreVhXsups4zR1lKQOd1UPsrOL6KBn/25Zts9dlyeQt9NvYhKjoKp+zZyfrtt0YwatqEsJkzOVW3HteGDOHxjRsp3yZNs5EEByERcRGR4yLSQCm1VinVXynVRSn1mVIqJIHVrADqi4inWVob4AHG2VVslmIEnJpm7fEGSgP7wAiQGM8HtbIo2wZjjruYodwrgMymZ4pi6ioDBJv2aS84EaFiXj9GvvES2/rVpl/DQly/F8lHc/ZRbvAaPl94gP0Xb6fs9ED2jlD1E2PgQmBRXt08ns/wZd2FdXy55UuilfG3llOOHGT97jvyrliOV6NG3Pp9Bifr1OXakP/pYKRlSAleykEpFSkimXh65pEU44D3gQUi8j3GD/8AYJgyG7YtIieBjUqpd03H3iUifwKTROQzIBRjYEIUMNqs/kHABhEZgfHwaSPTFjPpKkqpraaBDtNEpLepP98Dm5VSa5LRN+055OfhTNfqeelcNZjtZ27xx64LzP/nIjO2n6dQZk9al8lB85ey4evulDIH9M9vDOX+ZwpvhnxNhJsjv5xexs2IUOrmrkf5LOXJ6ZkTp5w5yTpkMP7duhI6dhy3pk/n1uxZXKpbnLllH7H70SkqZK1A0+Cm1MhRAxcHl5Rpn6alsMSuJzQD6AisTsrBlFJhIlIbGAUswbgHMxwjEFm2y3KIUjvgB2AY4AZsAWoppf6dPlkptVlEWgLfAt0xnv1pq5SybO/rpuP+hnE2uBQjOGqaVXZ2xtlRxbx+DGhWlCX7LjN35wUGLj3MkBVHqFkwkNdKZ6dmwcCUOBiUeQcKNKDzst7YX93EDLWDQVe3AxDkFkT5LOUpl7kc/q7+/NXCm4N5MlMl5ApVl+2m5yrhVO2CTHl8iD4XN+Hu6E7dXHVpGtyUMpnLYCeJnihF01JNYoPQeaC1iOwClgPX+O/zQkopNTauCpRSh4Fa8eTJbSUtHCOwdI+n7CLimYJHKXUbI5h2jCufplnj5eLIm+Vz8Wb5XBy9epf5uy+yaO9lVh++RiY3R0r7KzLlvU3J7N7JW8DOKyu8PoN3Di+i4/K+nH90m+1F6rHd25+/Lv7F4lOLAXC2d6ZCvgr41eyG75NgoifPwXHpMr7f6EzkK3VZUsGeZedCWHRyEUFuQVTKWomXAl/ipcCXyOWVSy+yp6WpxAahn0yvWYCXrexXQJxBSNOeJ4Uye/F54yJ82qAQm0+GMv+fS6w8cJm1o7cQHOBO81LZeKVkVnL7u8dfmTUiUPRVJLgmudYMINfuybT2zkl0ox84EZCH0AehvBz0Mq4Ork/LDC2Nf7duhI4dh5q7lFZLXHnnjdYcqpuXpbc2sfb8WhaeXAiAr4svpQJK8XLQyzTI3YAg96AU+FQ0LeESFYSUUvo8XtOscLC3o0bBQGoUDGS5/23uZcrLgn8uMXzNcYaFHKdkjkw0K5mVJiWyEOiVhPszrpmg6Qgo0QaWfIDdrDYULNqCgg3+B+YByMQ5OJhsPwzFv3s3QkeP4e5vU8k1y5Uv2rXDp8MAztuFsef6nn+3dRfWMfngZMbVHUchXz1xiGY7OqhoWgpzcxTalM3JnK4V2fJpLfo3KsTjJ9EMXHqYCkPW8ubEbczecT5pUwXlqgjd/oKan8PRpTC6LOycBNHWxws5BweT7acfCV66BI8aNbg5YQKn69TFc/ISXg2sw3dVvmN5i+UseGUBjvaOdFjZgZ1XdybzE9C0hEvsLNrV4tiqmJZ5cE6txmpaRpM1kytdquVl2ftVWfNxNXrWzMelsAd8tuAAZb9bw1u/7WDurgvciYjvETszDs5QvS90/xsyl4BlH8Nv9eDqgViLOOfNS7ZhPxG8+E/cq1fj5vjxnKxdh+s//8yT27fJ75Of6Q2nk9ktM11DurLmnB4oqtlGYs+ENmA8ixOzmb/fiLG89y0R+TmhC9Vp2osiX6AnH9cryPreNVjaqwqdqwVzNvQ+feftp8x3IXScbASkBJ8h+eeHt5fAq+Ph1hn4tTqs+hwehsdaxDl/frIPH06ePxfhXrUqN8eO42Sdutz45RcCHrsyteFUivoV5ZONnzD3mOWE9JqW8hI7MKEOMAljZNxi4AYQgLFAXSOMBeoKA/2BcODzFGuppj0nRIRi2bwpls2bvvULcvDSXZYeuMyy/VdYP28/9nZChWBfGhTNTP2imeO+hyQCJdtA/rqw9htjJddDC6Hh91CoibHfCpcCBcg+YjiRx7oTOno0oWPGcmvadHzfeoux7X7i0z3fMGjbIG5G3qRbiW56BJ2WahIbhHoCU5VSAyzSV4nIAKCDUqqpiDhgrFiqg5CmxUFEKJ7dm+LZvfmsQSEOXb7LioNXWHHwKl/+eYivFh/i5Zw+1C8aRN0imckT2yg7N19o+jOUbAtLP4I57SB/PSMY+QbHenyXggXI/svPRB49SujoMYSOGYPd9Ol82f5NxhVyY8zeMVyPuM5n5T7D2V5faddSXmKDUD1gTCz7tgC9Tf/eBPRLaqM07UVkfobUp34hTly7x8qDV1lx8CqDlx9l8PKj5A/0oG6RIOoWCaJk9kzY2VmcoeQsD103wvZfYcMQY82iKh9BlQ/B8dlRdDFcChUi+8hfiDxyhBujRxM2ZhxveHlRul4pBkX+wcHQgwytNpQ83nlS90PQXjiJDUK3gFcAa3ctX+HpbNduwB0reTRNS6D8QZ7kD/KkV+38XLgVwZoj1wg5fI1fN51mzIZTBHo6U7twELULBVI5nz+uTqbbsPaOUKknFHsNVn8BG/8H+2ZBw6FQsEGcx3QpXJgco0YRefgwN0aPId+8tUz2cGNJ2dO8faM1H1f7nGZ5m+nLc1qKSWwQGgr8IiK5Mabdsbwn1MuUryagx3lqWgrJ4etGx8p56Fg5D3ciolh/7Dohh6+xeO8lZu04j7ODHZXy+lGrcBC1CgWSLZMreGWBlpPg5bdgeR+Y1QYKNoL6g8E37jMalyJFyDF6FA8OHSJ09BiarVtHve32LNr2Obte28RnNQfi4fRiLeimpY7EPqw6SkQuYVxqG20q/xjYC7QwTZkDMASwwXrJmvbi8XZzpPlL2Wj+UjYePY5m59lbrD1ynbVHr7F+0UG+BApl9qR6wQBqFAikTO6qOHbbDNvHwobvYXR5qPy+cZnOKe6ZHFyLFiXHmNE8OHiIG6NG8saGjdzbuYJfq26jfu+fKZazrG06rT23EnsmhFJqIbBQROwwzoJuKKWiLfKEplD7NE2Lg5ODHZXz+VM5nz9fNinM6dD7rDMFpEl/neHXjafxcHagcj4/ahR8lVodmhK0bQhs+gH2zoR6g6Boi1hH0cVwLVaUnOPG8eDAAU4NG0yj1Xu5+9db/Fo7J9k6dMYp2stGPdaeN4kOQgBiXBDOBuTAGIp9PyUbpWla4okIeQM8yBvgQedqwYQ/fMyWk6FsOHaDjceus+rQNQAKBLXjjYK1aHn9FzznvWPMuNDwe8hcPN5juBYvTrHJs7ix629u/TiIakvPcnftl6yo4MQONtKkWCtKBpR85p6RUorH0Y9xtHdMlb5rGVeig5CI9AC+ADJjTFhaFvhHRBYAm5RSI1K0hZqmJYmHswP1Tc8aKaU4cT2cjcdusOnEDf53KBODHvenrcNG+l6Yi8e4aoQVbotPo6+x84x/OYqAMpUImL2CiD17OTV8CG3W7+fu9oXMLb+Ir6plw97NnQePH/y7RT6ORKFoWaAl/cv3x9FOByPNkKggJCJ9MBaO+x5jloR1Zrs3AG8AI+KpowgwEqiIsZ7QROAbpVSs6yabBkKcsbJrjlLqdbN8sS11+Ugp5ZyYujTteSIiFAjypECQJ52rBRMZ9YSdZ2+x6Xhe3jlWi8a3ptD+8EzuH5nPGr/2PCjdhUoFspLLzy3OkXBuL5Wi+LQ5bPntN7Ju/ov267fxYOdV9tUL5kytEji6e+Li4IKrgyuhD0KZd3weV+5fYVj1Ybg5utnwE9DSq8SeCb0HfKWUGmplWp5jQIG4CouID8bw7sMYI+ryYiwPYYdxdhWf3hjPI8WwvPdU0UqZJRZlElqXpj23XBztqZo/gKr5A6BxEa7frcX6vTvItmMIr94cz/mVCxmytC37PatTMZ8/FYONBf2yZrL+rFFUcDB53nmHiH/2EDpqJBUWbKXyxlD83n0Xnzdex87VKFfMvxjfbvuWDis7MKbOGPxd/W3ZbS0dSmwQygzsjmVfNBDfHPXdAFeMkXR3gRAR8QIGiMhQ8yW+Y3FMKbUttp2W+0SkLOAPzEpsXZr2Ign0cqFutWpQrRrq1HqClvdj7M2fOSHrGHC4LZ/szgVALj+3fwNSxWC/Z6YUcnv5JXL+9hsRu3dzY9Qorg8dys3ffsOv07v4vP46LQu0JNAtkN4be/PmsjcZW2cswZlin9FBe/4ldgLTk0D1WPZVwzjDiUtDYJVFsJmNEZhiqzc53sAYNLEkFerWtOeS5K2J83tboMkI8ttfZYbqx74isxhay5P8gZ4sO3CFD2bvpdzgtdT8cQOfztvPlktRXAyL+LcOt9KlyTV5Mrl+n45zvnxc/9/3nKxbl1tTp1LFvxyT608m8kkk7Ve0Z/e12P6u1V4EiQ1CI4DPROQLIL8pLVBE3gU+BobHU74QcNQ8QSl1Hogw7YvPZBF5IiJXRGSYiMQ6D4lpBF8r4E+lVISVLAmuS9NeOHb2UKYj9PoHqvXB+8JaWm9rwcSAuez95GWW9KzC540KkzfAg5WHrjLhwCOqfL+eyv9bx8dz9jJz+3lOXr+Ha+nS5JoymZzTpuKcJ5hrQ/7Hqbr1yLL8H36vPRlfF1+6rO7C9MPTufsovgsh2vNIlIrtXn4sBYzBCV9hTM0Tc8fyATBAKfVDPGWjgD6WI+hE5CIwTSnVP5ZyWTAmQ10N3AVqAJ8Cq5VSzWIpUw1jeYlXlFJLzNKTUlcXoAtAUFBQ6dmzZ8fVzViFh4fj4fFiPWWu+/x8cHp4i9xnZ5PlSghP7J25kKMFF3K8QrS9C9FKceL6fc5HOnPs1hOOhz3hrulRdQ9HyO9jT34fOwr42FPg6km8ly3D6cQJnnh7E1avJiMLHOFI9CkcxZFSbqWo6FGRfM750v3UQM/j9xyf5PS5Zs2au5VSZSzTEx2EAETEE2MQgD/GfHFbgdIYAaZhHOWigN5KqZ8t0i8BU5RSCZ51W0S6Y0ym+pJSaq+V/WOBNkBmpVScszfEV5e5MmXKqF27diW0mf+xYcMGatSokaSyGZXu83PmxnFjyYijS8EjCKr1gZffYsPmrf/2WSnF2ZsR7Dxzi51nb7HrXBhnQo1HCZ0c7CiZ3Zt6jy5SZv18XI7sxyEoiEdtm7CocDhLL64iPCqcnJ45eTX/qzTL24wAt4A07HDsnuvvORbJ6bOIWA1CCRqYICKZgAYYD6eeBhYrpVab9rUC1gIvASfiqSoMyGQl3RtjuHZizMMIHC9jTBtk3l4H4DVgfnwBKL66NE0zE1AAXp8B57fB2oGwvDds+ZnMmZvDkypg74CIkMffnTz+7rQumwOAG/cesuvsLf45H8auc2EMveZBVIH2lPQ9SaeTa8g3fBJNfP1p8mZHztb0Y9H5pfz8z8+M3z+ej0p/RJuCbbCTxN490DKCeIOQiBTHuHQVZJb8j4i8BswEKmAMSGgHzImnuqNY3PsRkRyAOxb3ihJAWbyaq40xpZC1UXGJrUvTNEs5K0CHZXBqHaz7lkLHRsLo5VCjnzF7t91/A0aApzMNi2ehYfEsAERGPeHgpTvsPleYJWcr83DHdpruWUbRkcPxmZiJwhWbkrXu6xxlFoO3D2bNuTUMrDyQbB7Z0qK3WipKyJnQYIx7J82BfUAujIdNdwLOwNtKqd8TeLwVQB8R8VRK3TOltcG4p7QxEe0GaGl6tTa05g3gKsYDtMmtS9M0a0QgX23IW4sD84dS/MZiWNAJNg8zLtMVaWYMcLDCxdGeMrl9KZPbF6rnRb1Vhgu3OnJ8+Vqcf59E03XTub5tKbfy1+RwiezsiF5Jo/nNqOzbgbaFWlMyhw+eLnrWhedBQoJQGeADpdR20/tjpnsoJ4AuiQhAAOOA94EFIvI9EAwMAIaZD9sWkZPARqXUu6b3AwBPjIdL72IMB+8DLFBK7Tc/gIg4YwTMKZYTqya2Lk3TEkCEm/7loUUfOLwQ1g+BeR3BvyBU621MkGof90+NiJDTz52c7V9BtWvK/S1/4/zLSN7ft4CuFwP5q2JTpuXbz1+3fmV9yFoiL79GHp/slMyeieLZvCmR3ZuiWb2frqmUQHcf3UUQPJ08k/MJaMmQkCAUBJy1SIt5vy8xB1NKhYlIbWAUxrM7tzGGdQ+w0i7z/5qOYsxw0AnjmaLzwA/Ad1YO0xDjHlNsQ9gSU5emaQllZ2dciivSHA4vgk0/woLOxgqvVXtDidbGgnvxEBE8qlTGvXIl7m/ezI2Ro6izdDYNs2Xj+CsN+cZ7Pa4FfsZTtWXLqWIs3HPJOLxAgSBPY3XarF4Uz+5N4SxeuDlZ/5kLORfC139/TQ7PHMxuPDvdj8Z7XiV0xoTY7pU8TuwBlVKHgVrx5Mlt8X42sQcVy7KLeDp03Nr+BNelaVoS2NmbgtGrxii6TUPhzx7GCq+VP4BSb8a51HgMEcGjalXcq1Th/qZN3Bg5ijxjlzA1WxaWV3NjWo5JVK9Qmx7FP+PCDTv2X7rD/ou32XDsOvN2XzSaIpA3wIPi2bwpktWLolm9CQ505NeDI/jj+B8EugZy+OZhNl3cRPUcqfG8vBafhAahVSJiLeCstUxXSsU/Ba+mac8/Ozso8goUbgrHVxlrGC37BNYPhnJdoWwncPeLtxoRwaN6ddyrVSN840ZCR46i4axD1AzKxNSy6+l+dS8Dqg3i4yLVAGOI+LW7Dzlw6Q4HTdvmk6Es2HMJO+cruGSbhb3zdbLRiPo+7VkU/RGj9oyjaraq2NnpEXi2lpAg9E2qt0LTtOeXCBRsAAXqw7m/4e9fYMNg2DwcXmoHFd+Ld7lxoxrBs0YNPKpXJ3z9BkJHjaLr0sPc3BrG7N3d2fhqKz4p3xc3Rzcye7uQ2duFukWMQb1KKSbu+50x+8fgJB7kpQ+Xr+bg5yPncMxUgVtZFvHSj2Mo6lOGwlm8KJzFiyJZvMgb6I6zQ+LuM2mJE28QUkrpIKRpWvKJQO7Kxnb9KPw9EnZPgV2ToFATKN8VclWOd5VXEcGzVk08atYgfP16nEaO5L1lR7ny9xwG117D3eolUXZ2RBONUgqFIiwyjEM3D1E1W1UGVR6En6txBnYvMoqDl1/m47834Zx1E/dvl+L3bed4+NgY0+RgZywUWCiLJwUze1I4sxeFsniS2Su+uZq1hErSyqqapmnJElgImo+GWl/A9nFGMDqyGIKKQbnOULw1OMW93pARjGrhUbMm4WvX8mT4D7w57zyhGzazoU4gB1/KBPZ2CIK92PNZuc9oW6jtfwYgeLo4UjE4Cz0iOzF051CGtXKjhH8lzt68z+Er9zh29S5Hr9xj19kw/tx7+d9yXi4OZHaNZs3tAxQM8qRgZi8KBnni7aaHjSeWDkKapqUdryxQ9xuo/ikcnAfbx8OSDyDkK3ipvXHfKJ5LdSKCZ506FK1Vi3tr1+I8ajQtZx+j7TYH/N/rgVejRoh93JfUXsv/GhMPTGT8gfGMqzOOfIGe5Av0hJJZ/81z50EUx67e4+jVuxy7eo+dxy/y597L3It8els80NOZAkGe5A/yMC0i6EH+IE+89DNNsdJBSNO0tOfkBi+/ZQSe81thx3jYNha2joI81Y19hZqAY+yXwcTODq+6dfGsXZt7a9YQOmo0l/v0JXTMWPx79MCrUcNYg5Gboxvti7Tn539+5lDoIYr6F30mj7erI+Xy+FIujy8AGzbcpHr16ly9G8mxq/c4dvUex6+Fc+L6PWbvuMCDqKeLRWf2ciF/kAf5Aj3IH2gEqXwBHvi4OyXzg8v4dBDSNC39EIFclYzt7mXY8zvsmQ7z3wWXTFCiDbzcHjIXj70KOzu86tXDs04d7q0OIXT0aC736UPouHH49+iOV4MGVoPR6wVf57eDvzHhwARG1ByRwOYKWbxdyeLtSo2CTwcGR0crLt1+wPFr9zh27R4nr4dz8no4c3ZeIOLR0+Dk5+5E3kAjOOUNMF7zBXqQxcsFO7sX47klHYQ0TUufvLJC9b7Gg65nNhrBaPdk2PErZCllPPxatIVxSc8KsbPDq0F9POvV5d7q1UYw+qQ3oWPHEvDee3jWr4+YDcn2cPKgXeF2jN03lhNhJ8jvk99qvQlhZyfk8HUjh68btQs/nXYzOlpx+c4DTlwP5+Q1IzCduhHO8gNXuB0R9W8+V0d78vi7kzfQg2Cz1+AA91gfvs2onq/eaJr2/LGzg7w1jS3iFuyfC3tnwKr+sOpzyF0Fircynkly9XmmuBGMGuBZrx73Vq7kxugxXProY5zz58P/vffwrFfv32D0ZuE3mXpoKhMOTGBotaGp0BUhu48b2X3cqGl25qSU4tb9R6agdJ+T18M5HRrO3gthLN1/GfMVd7J4uxAc4G6aqdwITnn83cnu44qDfcZ7zkkHIU3TMg43X6jQzdhuHDcGMxyYB0veNx6EzV/XeDi2QAMjrxmxs8OrUSM869fn7sqVhI4ew6UPP8K5QAEjGNWtg7ezN20KtWHqoan0KNmD3N65bdItEcHPwxk/D2fKB//3Ad7IqCecuxnBqRvhnL4RzunQ+5y+cZ/Fey9z12xQhIOdkNPXjdz+7uT2cyeP/9N/Z83kin06vbyng5CmaRlTQAGo2d9YPuLKXiMYHVwAx5aD2EHOilCwERRqBL7B/xYTe3u8GzfGq0ED7i5fQeiYMVz64AOcCxbE/70etK/cjplHZjLxwES+rfJt2vXPxMXRnoKZjeeUzCmlCIuI4kyocfZ0NvQ+Z28aAWrrqZv/GRjhZG9HDl9Xcvu5k8vPndz+bkbA8nMnm48rjvGdQT1+BJd2Yf/4QYr3TwchTdMyNhHI+pKx1fsWLu8xAtHR5bD6c2MLKGycJQXXMAY9OLoawahpE7waNeTu8uXGmdH7H+BcqBDv1y/PDycXUci3EO2KtEvrHlolIvi6O+Hr7kvpXP8964uZuuhM6H3O3bzPmZv3ORcawdmb9/nbIkDZ2wlZM7mQy9edXH5u5PJzI6ePK/nkAtlvbcflwl9wdgtE3SdTsS8w5ohOOToIaZr2/BCBbC8bW60v4NYZOLbCCErbxhpTBtk7Q87yRkAKroFkKYV306Z4NWzI3WXLuDFmDGV/XseYHF78dmIID1pH0Llkl7TuWaKIyL9TF1XM+9/Le0opbtx7yNmbEZy7eZ9zNyM4fzMcdf0ILpf2EfD4EKXtDhIgdwA4SxYOu9TgUkAF3O1zE/u4xKTRQUjTtOeXbx6o2MPYHt2Hc1vh9Ho4vdFYnnztQHDyhGwvI9nL4l24HF5/TOfOur9xHDOWvvPvcnrzcGa2O8Lr7/70XExwKiIEOj0kUO2nXPh2uL4dLu6Ch0bQifYK5G7mmuzPVJb9TqU4HOHNhVsRnL8VQbuAZ5ZoSzabByERKYKxMmtFjPWEJgLfKKWexFEmN3DGyq45SqnXzfJNAd62kq+wUuqoWT5vYATG4nd2wFLgfaXUzUR1RtO0jMPJHfLXMTaA8BvG0O/zW+HiTmNCVfUEATL55cO788vcPh3MvSXbCP5pJdvn76RY30F41KyRcdYeUgruXISrB0zbfuP19jlTBoHAIlCshbFke45y2PnkIZMImYASFtVt2LAhxZto0yAkIj7AGuAw0AzIC/yEEQi+SEAVvTFWRI0RaiXPUaCjRdpZi/dzgIIYC9tFA98Di4CqCWiDpmnPA48AKN7S2MA4U7q8xwhIF3Yi5zfj8+AyZWrB7Bt+ZN1zk4s9euCc3ZuA1yrj7+cHV3zBJxe4eKddP5Qyhq7fOg23TsHNU09fb56CR/dMGQX88hqXKku/DVlKQvayadt2bH8m1A1jNdMWpuW8Q0TECxggIkPNl/iOxTGl1LZ48tyPK4+IVATqA9WVUptMaZeA7SJSRym1JsG90TTt+eHkbjxzlLvK07SIW9hdP8Ib1w4xuupiFuw6Q7vNt3n483LcfR8RvmYE7lkeIq6ZjGDkEQRu/sY6Se4Bpn/7g7MnOLgYi/mZv9o5gHoC0U+MYBLz7yeP4OE9eHjXeI28a/w78jbcuwb3rkC46fXeVSN/DLED7xzglw9ylIOAgpC5hHHG4+xh6081XrYOQg2BVRbBZjbGmUh1jCW/bdGGazEBCEAptUNEzpj26SCkaZrBzRdyV0ZyV6Zn+S5MLD6RLsVG8PbZ7NQNuUXkJidcggMJqJUTd7cIJPwaXDsMEaHwODJ12uTsDZ6ZwTPIGIbumRk8s4BPbvDNawRDB+fUOXYqsHUQKgSsM09QSp0XkQjTvviC0GQR8QWuA7OAz5VSlgPXi4jIXcAZ2GnKs9GiDUd51hHTPk3TNKs6Fe9EkFsQXzt+zfJ83oyN7sDjafO4MHEXriVL4t9zMO5VKiNgXN67fwMibsKjcIiKhKgIIzhFPTBeox+D2BtLoou9MbrPzh7sHMHFyziDcvY2+7dXvEtcZDSizOeDSO2DiUQBfZRSIyzSLwLTlFL9YymXBfgcWA3cBWoAnwKrlVLNzPJ9ADzCuOcUAHwClAaqKKV2mPKEYFyya25xjN+BYKVUJSvH7wJ0AQgKCio9e/bsxHYdgPDwcDw80t/pcGrSfX4xvGh9Ph15mvHXxxMt0XTK1IGSe27ivmIF9mFhPAoO5n6TJjwqXCjeBfoymuR8zzVr1tytlCrzzA6llM02IAr4wEr6JeC7RNbVHVBAqTjyuGKMqltklhYCLLSSdwawJb7jli5dWiXV+vXrk1w2o9J9fjG8iH3+Y/UfqtnCZqrU1FJq7rG56snDh+rWzJnqePUa6nDBQurMG21V+N9/q+jo6LRuaopJzvcM7FJWflNtPeg9DMhkJd0bY7h2Yswzvb4cWwZlXKpbbpEntjZkSkIbNE17Qfk7+jO90XTKZy3PwK0D+XHfCLzatCbv6lUEffUlUZcucb7jO5xr357727bF/LGrWbB1EDqKxX0XEckBuGP9Pk1clMVrQvJabYNJbPeKNE3TrPJ08mRUrVG8WfhNph+eTvc13bkbHYFv27bkDVltBKPzFzjfoSPn27/F/e070rrJ6Y6tg9AKoL6ImM/E1wZ4AGy0XiRWpsH97I4tg4i4Yox4M8+zAsgsIlXM8pUBgk37NE3TEszBzoHPyn3G1xW/Zte1Xby+7HWO3DyCnZPT02D0+ec8OneO82+/zbm33ub+Dh2MYtg6CI0DHgILRKSO6Yb/AGCYMhu2LSInRWSS2fsBIvKTiLQwlRsIDAcWKKX2m/J4i8hfItJVRGqLSBtgPZANGBxTl1JqK7AKmGaqrznG/aDNSj8jpGlaErUs0JKpDabyOPox7Ve0Z8kpY7CvnbMzvu3bkXdNCEH9+/PwzGnOv/U2597uQMSuXWnc6rRn0yCklAoDagP2GMOxv8EIJl9bZHUw5YlxFOM5oskY93jaAj+YXmM8BG5gzLywHBiPcY+nulLK8pt+HePM6zdgGsaZ0qvJ6pymaS+84gHFmdNkDsX9i9N/c38Gbx9M1BNjxVQ7Z2d832pPvpAQgvp9xsNTpzjXrj3nOnYkYnesF3SeezafO04pdRioFU+e3BbvZ2M81BpXmUigRQLbcBtjah/L6X00TdOSxc/Vjwn1JjB893CmHZ7G0VtH+an6TwS4BQBg5+KC79tvk6l1a8LmzOHmxEmce7Md7pUq4t+zF24vv5TGPbCtjD8lrKZpWjrjYOdAn7J9GFptKEdvHaXt8racCDvxnzx2rq74dehAvpDVBPbtS+Sx45xr25bz73YiYs+eNGq57ekgpGmalkoa5mnI1AZTeRL9hLdWvMW2K89Oa2nn6orfOx2NYNSnD/cPHeDcG20536kzD/butX2jbUwHIU3TtFRU2K8wMxrNILN7ZrqHdOfPk39azRcmDxhZ+DxvvRvB9Jp23N63m7Ovv8H5zl14sH+/jVttOzoIaZqmpbIsHlmY1nAapTOX5ostXzBm75h/H16NehLFtEPTaLqwKX+e/JNWpdrz+I3GvNPlEaEdGhJ54ABnW7fhfNeuPDhwII17kvL0yqqapmk24OnkydjaY/lm6zeM3TeWS+GXqJerHj/u+pGzd89SOVtl+pbtS7B3MFFPouj24Cbvu6xn3MwR5F1znFuTJnG2VWs8qlfHv2dPXIsXS+supQh9JqRpmmYjjvaODKo8iB6lerD41GJ6ruuJQjG69mjG1h5LsHfwv/mG1xxOLs9cfLStH2GtapB37VoCPvyQiL17OduqFRe69+DBwUNp3KPk00FI0zTNhkSE7iW7M6zGMPqV68fCVxZSLXu1Z5YM93LyYmydsbg4uNBjbQ9u2t3Hv1tX8q1dQ8CHHxDxzz+cbdmSCz3e48GhjBuMdBDSNE1LA3Vz1aVt4bY42jvGmieLRxZG1x7NnYd3eG/te9yPuo+9hwf+3bqRb00I/u/3ImLXLs6+1pIL7/Uk8sgRG/YgZeggpGmalo4V9ivMT9V/4kTYCT7Z8AlR0cYMDPaengT06EG+tWvw79WTiB07OPNqCy726kXk0YwzF7MOQpqmaelc1exV+aLCF2y5vIVvt337n2Uh7D09CXjvPSMYvfce97du40zzV7nY630ijx1Lw1YnjA5CmqZpGUDLAi3pUqILC04sYNz+cc/st/fyIqBXTyMY9ejB/a1bOdOsORc/+JDIY8fToMUJo4OQpmlaBtGzVE9eyfsKY/aOYdHJRVbz2Ht7E/B+L1Mw6s79zZs506wZFz/8iIcnTlgtk5Z0ENI0TcsgRIQBFQdQIUsFvvn7G/6+9HeseY1g9D751q7Br1tX7m/axOlXmnHp4495ePKkDVsdNx2ENE3TMhBHe0eG1xhOcKZgPtrwEUdvPTsIISo6ipBzIfRa14u5V1cQ+OGH5F27Br8uXQjfsJHTTV/h0sef8PDUqTTowX/ZPAiJSBERWSsiESJyWUQGioh9PGVyi4iyss02y2MvIp+aFra7adpWi0jZxNalaZqWnnk4eTCm9hi8nL3osaYHl8MvA3D+7nmG7x5OnT/q8PGGj9lyaQs/7PyBC3cv4ODjQ+BHpmDUqRP3NmzgdJOmXOrdh4enz6RZX2w6bY+I+ABrgMNAMyAv8BNGMPwiAVX0BraYvQ81+7cr8BnGwndDAAX0BDaLSCWllOWqUXHVpWmalq4FuQcxtvZY3lrxFl1DuhLoFsiOqzuwF3uqZa9GywItKeBTgGaLmjF051BG1h4JYASjTz7G952O3PrtN27NmMnd5cvxatIY/+7dcc6Tx6b9sPXccd0wgkUL03LeISLiBQwQkaHmS3zH4phS6tm50A0PgGDT6q0AiMha4DhGMLJcwC6uujRN09K9fD75+LnWz3QL6UZUdBS9XupF83zNCXQL/DdPt5LdGLZ7GJsubqJa9mr/phvB6BN8O3bk5qRJhM2cxd2ly/Bu2gT/7t1xyp3bJn2w9eW4hsAqi2AzGyMwVU9OxUqpJ+YByJT2CDgEBFovpWmalrGVzVyWda3XsbzFcrqU6PKfAATQrnA7cnvl5vsd3/PoyaNnyjv4+hLUpw/51oTg26EDd1et5lTjJlz+rB+Pzp1L9fbbOggVAv5zF00pdR6IMO2Lz2QReSIiV0RkmIi4xpVZRJyB0hiX/5JVl6ZpWnrl7eyNnVj/OXe0d6RfuX6cv3eeaYenxVqHg58fQX1Nwah9e+6uWMGpRo253K8/j86fT62m2/xynA9w20p6mGlfbB4Co4HVwF2gBvApxj2lZnGU+9xU78Tk1CUiXYAuAEFBQWzYsCGOQ8YuPDw8yWUzKt3nF4Puc/pXwrUEY/eMxe+aHz4Ocf3cAhXKY1e4EG6rVqOWLuX2n38SWaE8kTVqpHyflVI224Ao4AMr6ZeA7xJZV3eMwQelYtnfGHgCfJjcusy30qVLq6Rav359kstmVLrPLwbd5/Tv4r2LqvT00qr3ht6JKvfo2jV15dvv1JHiJdTm8eOTfHxgl7Lym2rry3FhQCYr6d5YP0OKyzzT68uWO0zDsucAvyqlRiSnLk3TtOdBNo9svFvsXVaeXcmOKzsSXM4xMJDMn/cn38YNROXPn+LtsnUQOorFvR8RyQG4Y3GvKAGUxWtMfQWAZcBaoFdy6tI0TXuedCzWkWwe2RiyY8i/s3EnlINPPJfwksjWQWgFUF9EPM3S2mAMr96YyLpaml7/ff5HRLIAq4BTwBtKqSdJrUvTNO154+LgQp+yfTh5+yRzjs5J6+YAth+YMA54H1ggIt8DwcAAYJgyG7YtIieBjUqpd03vBwCeGA+X3gWqAX2ABUqp/aY8rhhBzgfjuaASZisVPlRK7UloXZqmac+rWjlqUTlbZUb8M4ICPgUol6VcmrbHpmdCyniOpzZgDywBvgGGA19bZHUw5YlxFOM5osnAcqAt8IPpNUYQUBLj/tJSYKvZtjCRdWmapj2XRIQhVYaQwzMHPdf1ZO/1vWnaHlufCaGUOgzUiidPbov3szEeao2rzFlA4sqT0Lo0TdOeZz4uPkyoN4EOKzvQfU13JtWfRBG/IrHmD4sMY9KBSRSNLpribdGzaGuapr2A/F39mVhvIl5OXnQN6cqJsGfXGnoc/ZhZR2fRZGETfj/yOycjU34JCB2ENE3TXlCZ3TMzsd5EHO0c6by6M+fuPp2mZ9fVXbRZ2obB2wdT2Lcw85rOo7hb8RRvgw5CmqZpL7AcXjmYUG8C0SqaTqs7sef6Hvpu7EvHVR259+gew2oMY0K9CeTzyZcqx7f5PSFN0zQtfcmbKS/j643nnVXv8NaKt3C2d6Z7ye50LNYRV4fUnVZTByFN0zSNQr6FmFB3AotPLeatom+RzSObTY6rg5CmaZoGQFH/ohT1T/kRcHHR94Q0TdO0NKODkKZpmpZmdBDSNE3T0owOQpqmaVqa0UFI0zRNSzM6CGmapmlpRgchTdM0Lc3oIKRpmqalGVFKr2idGCJyAzgXb0br/IHQFGxORqD7/GLQfX4xJKfPuZRSAZaJOgjZkIjsUkqVSet22JLu84tB9/nFkBp91pfjNE3TtDSjg5CmaZqWZnQQsq3xad2ANKD7/GLQfX4xpHif9T0hTdM0Lc3oMyFN0zQtzeggpGmapqUZHYRSgIgUEZG1IhIhIpdFZKCI2CegnLeITBaRMBG5IyIzRMTPFm1OrqT0WUTKmvp70lTumIh8LSIutmp3ciT1ezYrbyciu0VEiUiT1GxrSklOn0WkhYjsFJEHInJTRFaKiHtqtzm5kvH/cxkRWW3q6y0RWSMi5W3R5uQQkXwi8quI7BORJyKyIYHlUuT3S6+smkwi4gOsAQ4DzYC8wE8YAf6LeIrPAQoCnYBo4HtgEVA1lZqbIpLR5zamvN8DJ4ASwCDT62up2ORkS+b3HKMTYJs1k1NAcvosIp2AUcBQoA/gA9Qinf/mJLXPIpLDVO4f4C1Tch9gtYiUUEol9QF3WygKNAK2AU6JKJcyv19KKb0lYwP6AWGAl1laXyDCPM1KuYqAAqqZpZUzpdVJ636lUp8DrKR1MfU5V1r3KzX6bJbXB7gBvGvqb5O07lMqfs/+wD2gc1r3wYZ97gY8ATJZfOdPgO5p3a94+mxn9u95wIYElEmx3y99OS75GgKrlFJ3zdJmA65A9XjKXVNKbYpJUErtAM6Y9qVnSeqzUuqGleQ9ptfAlGteqkjq9xxjELAFWJsKbUstSe1za9Pr1NRqWCpKap8dgcdAuFlauClNUrqRKUkpFZ2EYin2+6WDUPIVAo6aJyilzmP85VQoMeVMjsRTLj1Iap+tqYRxKn8sZZqWapLcZxEpAXQEeqda61JHUvtcHuP7fFdELopIlIhsF5FKqdfUFJPUPs835flJRAJFJBAYjnFW9UcqtTUtpdjvlw5CyecD3LaSHmbal9Ll0oMUabuIZAY+B6Zb/OWZHiWnzyOB0UqpkyndqFSW1D5nxrhX8AXwKdAUuA+sFJGgFG5jSktSn5VSl4GaGPc2r5m2FkD9WK4AZHQp9vulg1DKsPbEr8SSnhLl0oNktV1EnIC5GJcsPkrBdqWmRPdZRF7H+EH+NrUalcqS8j3bAR7Au0qpGUqplUBzjPsjPVO8hSkvKd9zFoz7KbsxLkc1NP17mYjkTI1GpgMp8vulg1DyhQGZrKR7Y/0vhfjKZYqnXHqQ1D4DICICTMM0KkcpFZaSjUslie6ziDgCP2CMGrITkUyAl2m3u4h4pngrU1ZSv+dbptcNMQmmM93dQJGUaVqqSWqf+2CM/GuplFppCryvYQTejHYZNiFS7PdLB6HkO4rFNVDTcE13rF8zjbWcSWzXWtOTpPY5xnCM4a/NlFLpva8xktJndyA7MAzjf9owYJ9p32yeDspIr5L6PR/B+GvY8oa8YNz/S8+S2udCwCGlVFRMglLqEXAIY5j38ybFfr90EEq+FUB9i79q2wAPgI3xlMssIlViEkSkDBBs2peeJbXPiEg/oBfQTim1OfWamOKS0udwjPsE5tsbpn39gTdTp6kpJqnf81KMgFMzJkFEvIHSPA3C6VVS+3wOKGa6zAyAiDgDxYCzqdDOtJZyv19pPUY9o28YN+GuACFAHYznXsKBby3ynQQmWaStBE5j3MBsjjGi6K+07lNq9Rloi/EX8mSggsX2zDNE6WlLzvdssT83Gec5oeT8t73IVPZtoDHGD/gNwCet+5UafcYIsFHAMlN/m2D8GEcBJdO6X/H02Q1oadq2Ypy9xbx3i+M7TpHfrzT/AJ6HDeM69zqMv5auYDwTYm+R5ywwxSItk+kH+TZwF5gJ+Kd1f1Krz8AU0w+wta1DWvcptb5ni/0ZJgglp88YAxPGAjdNZdcAxdO6P6nc59rAJox7YrcwAm+NtO5PAvob89+ktS13HP1Nkd8vvZSDpmmalmb0PSFN0zQtzeggpGmapqUZHYQ0TdO0NKODkKZpmpZmdBDSNE3T0owOQpqmaVqa0UFIy9BEpINpyex7pmWG94jIsDRsixIRD9P7QBEZICK5LfLVMOUrlhbttEZE+opIDYs0J1P7SyWinrMi8qPZ+ykisiuF2lhPRD5Mibq09EMHIS3DMk0BNBFYhfHU9lvAn8AradSkZRgrTkaY3gcCX2M8DGjuH1O+UzZrWfz6AjUs0pww2l8qEfW8CvySMk16Rj3gw1SqW0sj6Xq9d02LR0/gV6VUf7O0JSLyTVo0RhnrxsS7dowyZpTelvotsh0RcVVKPVBKpfdJWbV0Rp8JaRlZJuCqZaKymAZERFxEZKiIXBCRhyKyT0QaWeQ5KyI/ishHptVAw0Rktmn5hZg8jqY85031XBaRhTGTVppfjjNdgjtgKrrelK5M+f5zOU5ENorIXMt+mB1LEtoPa0TkfyJyQETCTX2bYVpQ8N++A37A1zHtNF2au2fKMtksPbdpUyLypohME5HbwBLzz9FKG5qLyFERiRSRzSJSxGxfTH1NLMr8eylPRAYAnwC5zNoyxSxvFdPnGCEiN0VkgqT/pTI0dBDSMrZ/gF4i8raI+MWRbx7QARiMscrnTmCxlXsdrTHm/+qCsSJoE1OZGP0wZr7+EqiLcWnoDmBv5ZhXeDpL9nsYl98qxtK+2UATEXGPSTAFnlbAXLOgmtB+WAo0lWlsanMwsE5EYtr9qqkfk8za+Q9Qy7T/W7P0K2b1/ogRqFrx38/JUi6M5SwGYUxi6w2sEhGXeNptbiLG3GRXzdoyCEBEKgNrTftamvrYCGNeMy29S+vJ8/Smt6RuQAmMWXwVxjo1h4CBgJdZntqm/dUtym4C/jB7fxbjHo2DWdoI4KrZ+6XAT3G0p4PpWB6m98VM72tY5KthSi9meh8APAZeN8tT0ZSnTGL6kYDPzB7IZqqrmll6KDDAIq8HViaX5emElwut1H8W+NHs/RRT3kpmablM/e1mUV8Ti7qmALvM3v8InLVyzL+A9RZptcw/Y72l302fCWkZllJqP1AYYyDCGIw1bL4EdsWMUMOYjv8qsEVEHGI2jL+cy1hUuV4p9djs/WEgUJ6uEbMX6GAaSVYi5jJZCvTjBsaszW3MktsAp5RSMSPLEtOP/xCRhiLyt4jcwfjxv2jaVSCZTV+WwHzXlVJ/x7xRSp3DWGW1XDKPj4i4YQTsuRafy2aMZRRKJ/cYWurSQUjL0JRSD5VSS5RSPZVSRYBOQH7gXVMWfyAzxg+S+TYAyGFR3W2L948wAltMEPoWGA30wFic7YKIfJBCXZkNNBQRLxGxw7jENcdsf2L68S8RKQssxgg87TF+sCuYdifmcpg11xKY73osaVmSeXww1v+xx/gjxPxzeQg4Esdno6UPenSc9lxRSk0SkaE8XXr4FnAJY9Gt5NYdCXwFfCUi+YFuwAgROaaUWpnM6hdirL/TDGOVzqz8NwgltR+vYozYa6NM16lEJFcy2xojoevABMaSdsj070jTq5NFHt8E1H3b1I4BwHIr+y8noA4tDekgpGVYIhKolLpukRaAceM75q/0tRijqsKVUkdT6thKqRMi0htj0EERjFUmLT0yvcZ7xqGUChOR1RiX4c4BR0yXG2MktR+uQFRMADKxtqz4IyvtTHD74xEoIpViLsmJSE7gZZ4OHLiOcfZSOKaA6XJqRYzPItY2KqXui8g2oKBSamAy26mlAR2EtIzsgIj8CazG+CHLBfTGeFh0qilPCMbDrCEi8j3GX99eGA9guiil+iX0YCKyEONexh6MVTdbYvw/tCmWIudN+d423Y+JMrvHY80c4DeMkWqjLPYltR8hwIciMgJjGHUloJ2VfEeBxiKyEmM562NKqXsicgZoLSIHMc5Y9lspG59QYLqIfInxeQzE+L6mACilok3f40cicg7j7OYTU17LNgaJSAfgIBCqlDqL8aDtWhGJxhhBeA/IiTEa8HOl1PEktFmzlbQeGaE3vSV1wzgLWY1xySUSY2TWTKCQRT5n4BvgJMZf01cxzlwam+U5i9moLlNaB/472q0PsAsjSNwDtgPNYstvSnsTOG46rjKl1cDKyC3AEyOAKoy/7C37G28/Yvmc+gIXgPsYy2znNx2jp1me0hgP0N7HbEQfxiwF+02fr8IYyZabWJYot/wcMY1ww5jR4jjGvZotVvoehDHbxV2Ms58uPDs6zgXj7Om66fhTzPaVN30Wd019OIwxLNw7rf871Vvcm17eW9M0TUszenScpmmalmZ0ENI0TdPSjA5CmqZpWprRQUjTNE1LMzoIaZqmaWlGByFN0zQtzeggpGmapqUZHYQ0TdO0NPN/SWo4x8MGSLwAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "source": [
    "# bws = np.array([1e-2, 5e-2, 1e-1, 5e-1, 1.0, 2.0]).reshape(-1, 1)\n",
    "bws = np.exp(np.linspace(-5, -0.5, 40)).reshape(-1, 1)\n",
    "results_err = [0] * len(kernels_regression)\n",
    "for i, kernel in enumerate(kernels_regression):\n",
    "    result = []\n",
    "    for bw in bws:\n",
    "        kde = KernelReg(endog=y_train, exog=x_train, var_type='c', bw=bw, ckertype=kernel) ## bw='cv_ls', \n",
    "        # estimator = kde.fit(np_x)[1][:,0]\n",
    "        estimator = kde.fit(np_x)[0]\n",
    "        mse = mean_squared_error(cond_mean, estimator)\n",
    "        result.append(mse)\n",
    "    results_err[i] = result\n",
    "    \n",
    "labels = ['gaussian', 'tricube', 'aitchison_aitken']\n",
    "xylabels = ['bandwidth', 'regression mse']\n",
    "title = 'regression error'\n",
    "path = 'results/syn'\n",
    "xaxis = bws\n",
    "plot_err(xaxis, results_err, labels, xylabels, title, path, plottype='loglog')"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "source": [
    "plt.figure()\n",
    "plt.scatter(x_train, y_train, c='red')\n",
    "plt.xlabel('x')\n",
    "plt.ylabel('y')\n",
    "plt.title('Scatter plot')\n",
    "plt.show()"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "source": [
    "# eg_length = 50\n",
    "# np_x = np.linspace(-4, 4, eg_length)\n",
    "length = max(np_x) - min(np_x)\n",
    "pdf_true = np_x + 1/2"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "source": [
    "bws = [0.1, 0.2, 0.5]\n",
    "kernels_kde = ['gaussian', 'cosine', 'linear', 'exponential']\n",
    "fig, ax = plt.subplots(nrows=1, ncols=2)\n",
    "plt.subplot(131)\n",
    "bw = bws[0]\n",
    "plt.hist(x_train, bins=int(np.floor(length/bw)), density=True, histtype='step', color=f'C{0}', label='histgram') # \n",
    "plt.plot(np_x, pdf_true, c=f'C{1}', label='True')\n",
    "for i, kernel in enumerate(kernels_kde):\n",
    "    kde = KernelDensity(kernel=kernel, bandwidth=bw).fit(x_train[:, np.newaxis])\n",
    "    dens = np.exp(kde.score_samples(np_x[:, np.newaxis]))\n",
    "    plt.plot(np_x, dens, c=f'C{i+2}', label=kernel)\n",
    "plt.title(f'bandwidth={bw}')\n",
    "# plt.legend(loc='best')\n",
    "plt.xlabel('Sensitive attribute')\n",
    "plt.ylabel('pdf')\n",
    "fig.subplots_adjust(wspace=.3)\n",
    "plt.subplot(132)\n",
    "bw = bws[1]\n",
    "plt.hist(x_train, bins=int(np.floor(length/bw)), density=True, histtype='step', color=f'C{0}', label='histgram') # \n",
    "plt.plot(np_x, pdf_true, c=f'C{1}', label='True')\n",
    "for i, kernel in enumerate(kernels_kde):\n",
    "    kde = KernelDensity(kernel=kernel, bandwidth=bw).fit(x_train[:, np.newaxis])\n",
    "    dens = np.exp(kde.score_samples(np_x[:, np.newaxis]))\n",
    "    plt.plot(np_x, dens, c=f'C{i+2}', label=kernel)\n",
    "plt.title(f'bandwidth={bw}')\n",
    "# plt.legend(loc='best')\n",
    "plt.xlabel('Sensitive attribute')\n",
    "# plt.ylabel('pdf')\n",
    "fig.subplots_adjust(wspace=.3)\n",
    "plt.subplot(133)\n",
    "bw = bws[2]\n",
    "plt.hist(x_train, bins=int(np.floor(length/bw)), density=True, histtype='step', color=f'C{0}', label='histgram') # \n",
    "plt.plot(np_x, pdf_true, c=f'C{1}', label='True')\n",
    "for i, kernel in enumerate(kernels_kde):\n",
    "    kde = KernelDensity(kernel=kernel, bandwidth=bw).fit(x_train[:, np.newaxis])\n",
    "    dens = np.exp(kde.score_samples(np_x[:, np.newaxis]))\n",
    "    plt.plot(np_x, dens, c=f'C{i+2}', label=kernel)\n",
    "plt.title(f'bandwidth={bw}')\n",
    "# plt.legend(loc='best')\n",
    "plt.xlabel('Sensitive attribute')\n",
    "# plt.ylabel('pdf')\n",
    "fig.subplots_adjust(wspace=.3)\n",
    "plt.savefig('results/syn/pdf_est.pdf')\n",
    "plt.show()"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "source": [
    "def true_DP(np_x):\n",
    "    DP_true = 1/48\n",
    "    return DP_true"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "source": [
    "def error_bw_single(bw, num, kernels_kde, kernels_regression):\n",
    "    x_train, y_train = generate_data(num)\n",
    "\n",
    "    eg_length = np.floor(1 / bw).astype(int)\n",
    "    np_x = np.linspace(0, 1, eg_length)\n",
    "    width = np_x[1] - np_x[0]\n",
    "    np_histx = np.concatenate(([np_x[0]-width/2], np_x + width/2), axis=0)\n",
    "\n",
    "    num2 = int(1e4)\n",
    "    np_x2 = np.linspace(1/num2, 1-1/num2, num2)\n",
    "    DP_true = true_DP(np_x2)\n",
    "\n",
    "    ## histogram\n",
    "    (hist_pdf, _, _) = plt.hist(x_train, bins=np_histx, density=True, histtype='step') # \n",
    "    plt.close()\n",
    "    hist_regressions = []\n",
    "    inds = np.digitize(x_train, np_histx)\n",
    "    for index_np in range(len(np_x)):\n",
    "        index = np.where(inds==index_np+1)\n",
    "        if index[0].size:\n",
    "            hist_regression = np.mean(y_train[index])\n",
    "        else:\n",
    "            hist_regression = 0\n",
    "        hist_regressions.append(hist_regression)\n",
    "\n",
    "    results_regression = []\n",
    "    eg_length = int(1e3)\n",
    "    np_x = np.linspace(1/eg_length, 1-1/eg_length, eg_length)\n",
    "    for kernel in kernels_regression:\n",
    "        kde = KernelReg(endog=y_train, exog=x_train, var_type='c', bw=[width], ckertype=kernel) ## bw='cv_ls', \n",
    "        # estimator = kde.fit(np_x)[1][:,0]\n",
    "        estimator = kde.fit(np_x)[0]\n",
    "        results_regression.append(estimator)\n",
    "    dens = []\n",
    "    for i, kernel in enumerate(kernels_kde):\n",
    "        kde = KernelDensity(kernel=kernel, bandwidth=width).fit(x_train[:, np.newaxis])\n",
    "        den = np.exp(kde.score_samples(np_x[:, np.newaxis]))\n",
    "        dens.append(den)\n",
    "    DP_ests = []\n",
    "    ### histgram\n",
    "    DP_est = np.sum(np.abs(hist_regressions - np.mean(y_train)) * hist_pdf)/ np.sum(hist_pdf)\n",
    "    DP_ests.append(DP_est)\n",
    "    for j in range(len(kernels_regression)):\n",
    "        for i in range(len(kernels_kde)):\n",
    "            DP_est = np.sum(np.abs(results_regression[j] - np.mean(y_train)) * dens[i])/ np.sum(dens[i])\n",
    "            DP_ests.append(DP_est)\n",
    "    DP_ests = np.array(DP_ests)\n",
    "    error = np.abs(DP_true - DP_ests)\n",
    "    return error"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "source": [
    "def error_bw(bw, num, kernels_kde, kernels_regression, times=100):\n",
    "    errors = Parallel(n_jobs=1)(delayed(error_bw_single)(bw, num, kernels_kde, kernels_regression) for i in range(times))\n",
    "    errors = np.array(errors)\n",
    "    return np.mean(errors, axis=0)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "source": [
    "def error_optbw(bws, nums, kernels_kde, kernels_regression, times=100):\n",
    "    errors_opt = np.ones((len(nums), 1+len(kernels_kde)*len(kernels_regression)))\n",
    "    width_opt = np.zeros((len(nums), 1+len(kernels_kde)*len(kernels_regression)))\n",
    "    for i, num in enumerate(nums):\n",
    "        for bw in bws:\n",
    "            errors = Parallel(n_jobs=1)(delayed(error_bw_single)(bw, num, kernels_kde, kernels_regression) for i in range(times))\n",
    "            errors = np.mean(np.array(errors), axis=0)\n",
    "            for j in range(len(errors)):\n",
    "                if errors[j] < errors_opt[i, j]:\n",
    "                    errors_opt[i, j] = errors[j]\n",
    "                    width_opt[i, j] = bw\n",
    "    return errors_opt.T, width_opt.T"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "source": [
    "kernels_regression =  ['tricube', 'aitchison_aitken_reg']\n",
    "kernels_kde = ['linear', 'cosine']\n",
    "num = int(1e2)\n",
    "# bw = 0.1\n",
    "bws = np.exp(np.linspace(-5, -1, 40))\n",
    "# bws = [0.01, 0.05, 0.1, 0.5, 1.0]\n",
    "errors = []\n",
    "for bw in bws:\n",
    "    error = error_bw(bw, num, kernels_kde, kernels_regression)\n",
    "    # error = error_bw_single(bw, num, kernels_kde, kernels_regression)\n",
    "    \n",
    "    errors.append(list(error))\n",
    "# errors"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "source": [
    "labels = ['histogram', 'tri-lin', 'tri-cos', 'aa-lin', 'aa-cos']\n",
    "xylabels = ['bandwidth', 'DP_error']\n",
    "title = 'DP_error'\n",
    "path = 'results/syn'\n",
    "xaxis = bws\n",
    "errors_trans = list(np.array(errors).T)\n",
    "plot_err(xaxis, errors_trans, labels, xylabels, title, path, plottype='semilogx')##semilogx"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZkAAAEUCAYAAAD5i0vIAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABGtUlEQVR4nO3dd3xV9fnA8c9zV/YigQQIM+w9AgiIRlBxVBFEcYtVqdZZd1vbIlX7Uyu2LhCLVq2Ko466ioiEocgesnfYI5vs5N7v749zsddwyU5uEp7363VfyT3nfM95bjjkyfd8lxhjUEoppeqDLdABKKWUar40ySillKo3mmSUUkrVG00ySiml6o0mGaWUUvVGk4xSSql64wh0AI1NXFyc6dixY6DDqJb8/HzCwsICHYZS1ab3bvOwatWqdGNMS3/7NMmU07FjR1auXBnoMKolNTWVlJSUQIehVLXpvds8iEjaqfbp4zKllFL1RpOMUkqpeqNJRimlVL3RJKOUUqreaJJRSilVbzTJKKWUqjeaZOrI6r1Z5BaVBjoMpZRqVHScTB0oKfMw5c1VFJe5uXF4R24a2ZHY8KBAh6WUUgGnNZk64HLYeH3yEM7sEsdLqTsY+dS3TP3PRg5mFwY6NKWUCiitydSRvolRzLhuMDuO5jFz4U7+9UMaby9LY/zAttx2dhKdW4YHOkSllGpwWpOpY11ahfPXK/qT+mAK1wxtz6drDzJm+kLueHs1Gw/mBDo8pZRqUJpk6kliTCiPjevDkodHc/vZSSzadoyLn1/Czf9cwZq9WYEOTymlGoQmmXrWMiKIhy7owZJHRnPfed1YtTeL8S9/z/Wzl7FsV0agw1NKqXqlSaaBRIU4uXtMV5Y8PJrfXtiDzYdymTTrB66cuZTF249hjAl0iEopVecCkmREpJeIzBeRAhE5KCLTRMReSRmXiDwjIotFpFBETvlbWURiReQVETnsPXaLiNxQ95+k+sKDHPzq7CQWPzSaP13Si72ZBVw/ezkTZnzPkdyiQIenlFJ1qsGTjIjEAN8ABhgHTAPuBx6rpGgocAtQAHxfwfkjgUXAAOAu4CLgBcBVy9DrVIjLzk0jO7HwoRSeGN+HLYeOc/e7ayhzewIdmlJK1ZlAdGG+DQgBJhhjcoF53sQwVUSe9m47iTEmW0RaGGOMiNwJjD7F+X8HBAHJxpgTA1UW1PFnqDNBDjvXDutAsMPO/R+s42/fbOeBsd0DHZZSStWJQDwuuxCYWy6ZzMFKPGdXVNBUreHiJmC2T4JpEi4fnMiVyYm8lLqDhduOBTocpZSqE4FIMj2ALb4bjDF7sR6D9ajNiUWkE9AKyBaRL0WkRESOich0EWlUj8v8eezSPnRrFcFv3lvLoZwmlSOVUsqvQDwuiwGy/WzP8u6rjQTv16exakcXAP2BJ4Ey4CF/hURkCjAFID4+ntTU1FqGUXM3dvXw2NISbpyZysNDgrHbpNIyeXl5AY1ZqZrSe7f5C9S0Mv4ee8kptlfHiZrZRmPMrd7vvxWRCOB3IjLVGFNwUjDGzAJmASQnJ5uUlJRahlE7oW0PcO97a1lZ0pqHL6i8cpeamkqgY1aqJvTebf4C8bgsC4j2sz0K/zWc6sj0fi3f0P8tVmeApFqev0FcNrAtVw9tx4zUnSzYcjTQ4SilVI0FIslsoVzbi4i0A8Io11ZTAzuBEj/bTzxzajL9g/90SW96to7kN++v1dmclVJNViCSzFfAWO8jrBMmAYXAwtqc2BhTAszj5O7NY7A6FuyozfkbUrDTzkvXDKS0zMNd766hVMfPKKWaoEAkmZlAMfCRiJzrbXSfCkz37dYsIjtEZLZvQRG5UEQmYg20REQmel8dfA6bBgwUkddF5HwReQB4BHjSGFNcr5+sjnVuGc7/Xd6PVWlZPP75JvKLywIdklJKVUuDN/wbY7JEZAzwIvAZVjvMc1iJxpcDKD/VzAzAN6F84P16E/BP7/mXi8glwF+Aa4CjwBPe903OJf3bsGJPJm8sTePdFfsY3jmWc3u2YkzPeNpEhwQ6PKWUqpDoxIw/l5ycbFauXBnoMH7G4zH8sDuD+ZuPMn/zEfZkWB3keraO5NyerYgp2M/kS0djq0J3Z6UaE+1d1jyIyCpjTLK/fboyZhNgswkjkuIYkRTHoxf3ZOexfOZvPsL8zUd5acEOPAY+3f8db90yjMhgZ6DDVUqpn+hU/02MiNClVTi/OjuJ928bzqpHz+OGXi42HsxlypsrKSp1BzpEpZT6iSaZJi4mzMXo9k7+ekV/ftiVyX3vr8Xt0UegSqnGQR+XNROXDWxLel4xj3+xmdiwjUwb1xsRbaNRSgWWJplm5JZRnTl2vJhXFu2iVUQQd43pGuiQlFKnOU0yzczDF/Tg2PFinp23jbiIIK4e2j7QISmlTmOaZJoZm014amI/MgtK+P3HP9IizMXY3gmVF1RKqXqgDf/NkNNu4+VrB9E3MZq7313D8t2ZlRdSSql6oEmmmQp1OXh98hDaxoRwyxsrWLcvO9AhKaVOQ5pkmrEWYS7e/OVQQlx2xr30HTf/cwUr92itRinVcDTJNHOJMaH8956z+M253Vi9N4uJM5cyccb3zN98BI+Op1FK1TNNMqeBmDAX95zble8eGc3US3pxKKeIm99YyQV/X8RHq/frMgJKqXoTkCQjIr1EZL6IFIjIQRGZJiLlZ1wuX8YlIs+IyGIRKRSRSv8MF5HLRMSISOOa8TJAQl0OJo/sROqDKTw3qT+CcN/760h5JpVF244FOjylVDPU4ElGRGKAbwADjMNa/+V+4LFKioYCt2AtPvZ9Fa4TDEwHjtQm3ubIabcxfmAi/713FK9NTiY8yMHNb6zgs3UHAx2aUqqZCURN5jYgBJhgjJlnjJmJlWDuE5HIUxUyxmQDLYwxY4GPq3CdB4EDwH9rH3LzJCKM7hHPB7cPZ2C7GO6es4Z//ZAW6LCUUs1IIJLMhcBc31UwgTlYiefsigqaKi5+IyLtgYeAe2oa5OkkMtjJmzcPZXT3Vjz6yQZe/HY7us6QUqouBCLJ9AC2+G4wxuzFegzWo46u8SzwvjFmdR2dr9kLdtqZef1gxg9sy1+/3sbjX2zW3mdKqVoLxLQyMVhLLpeX5d1XKyJyDjAW6FaNMlOAKQDx8fGkpqbWNowGlZeXV2cxX9LKkNfBwewlu9myax+/7OPCrituqnpSl/euapwCNXeZvz+R5RTbq0xEHMDzwOPGmMNVDsaYWcAssJZfbmrLwdb1ErbnpBhe+HYH0+dtIzQ6lheuHkiws8LOf0rViC6/3PwF4nFZFhDtZ3sU/ms41XGr99xviEi0iEQDLsDufa9rE1eBiHD3mK5MG9ebeZuOMPn15eQUlAY6LKVUExSIJLOFcm0vItIOCKNcW00NdAcSgcNYySwLuBoY4P1+Ui3Pf1q5YXhH/n7VAFalZXHxC4tZvz870CEppZqYQCSZr4CxIhLhs20SUAgsrOW5XwTOKfeaC2zzfj+vluc/7Ywb0Jb3fzUcj8cwccZS3vohTXueKaWqLBBJZiZQDHwkIud6G92nAtN9uzWLyA4Rme1bUEQuFJGJWDUTRGSi99UBwBizwxiT6vvCqtUc977XgZk1MLB9DF/cPYoRXWL5wycbuGfOWvKLywIdllKqCWjwJGOMyQLGAHbgM6yBmM8Bfyp3qMN7jK8ZwAfAzd73H3hf59RXvMoSE+bitRuH8ODY7ny+/iCXvriEbUeOBzospVQjF5DeZcaYTcDoSo7pWJVtVbjW5OqWUf7ZbMId53RhYPto7n53LeNe/I4nxvdhwqDEQIemlGqkdBZmVW0jkuL48u4z6ZcYxX3vr+N3H/+IWwduKqX80CSjaqRVZDBv3zKM285O4p1le/n9xz9qhwCl1EkCNRhTNQMOu41HLuyBwya8uGAHMWEuHr6grmYGUko1B5pkVK3df343MgtKmJG6kxahLm49q3OgQ1JKNRKaZFStiQh/HteHnIJSnvhyMzFhLiYO1s4ASilNMqqO2G3C9En9ySks5eF/rycqxMl5veIDHZZSKsC04V/VmSCHnVeuH0yftlHc8c5qftiVEeiQlFIBpklG1amwIAevTx5C+xah3PrGSjYcyAl0SEqpANIko+pcizAXb/5yKBHBDia/vpzd6fmBDkkpFSCaZFS9aBMdwps3D8NjYNIrS/l+R3qgQ1JKBYAmGVVvurQK551bhxEe7ODa2ct46r9bKHV7Ah2WUqoBBSTJiEgvEZkvIgUiclBEpolIhUsviohLRJ4RkcUiUigiJw0vFxG7iDzsPSbD+/paRIbU36dRFemREMnnd53JpOR2zEjdycSZS0nL0MdnSp0uGjzJiEgM8A3WUsvjgGnA/VizMVckFLgFKAC+P8UxIcAjwArgeuA6oBRYIiKDax28qpFQl4P/u7wfL10ziF3H8rj4+SV8suZAoMNSSjWAQIyTuQ0rGUzwrh8zT0Qigaki8rTvmjK+jDHZItLCGGNE5E78z+JcCHT2LicAgIjMx1q07E7gprr+MKrqLu7Xmv7torh3zlrufW8ti7YdY9plfQgP0uFaSjVXgXhcdiEwt1wymYOVeM6uqKCpZAZGY4zbN8F4t5UAG4FWNQtX1aXEmFDmTDmDe8Z05ZO1B7j4+cXazVmpZiwQSaYHsMV3gzFmL9ZjsDqfXVFEgoDBwKa6PreqGYfdxm/O68acKcMpKfNww2vL2ZdZEOiwlFL1IBBJJgbI9rM9y7uvrv3ee95/1MO5VS0M7dSCf90yjFK3h1vfXEmeLumsVLMTqIfh/h57ySm215iIXIyVZO43xmyt4LgpwBSA+Ph4UlNT6zKMepeXl9fkYvb1qz52nl15nOtf+oa7BgZhEwl0SKqBNPV7V1UuEEkmC4j2sz0K/zWcGvF2W34PeMUY87eKjjXGzAJmASQnJ5uUlJS6CqNBpKam0tRi9pUChCbsZtrnm1hd0oYHxnYPdEiqgTT1e1dVLhBJZgvl2l5EpB0QRrm2mpoSkW7AF8B84K66OKeqXzeN7Mi2I8d5ccEOusaHM25A20CHpJSqA4Fok/kKGCsiET7bJmF1P15Y25OLSGtgLrATuNoY467tOVX9ExGmjevD0I4teOjD9azblx3okJRSdSAQSWYmUAx8JCLnettDpgLTfbs1i8gOEZntW1BELhSRicAA7/uJ3lcH7/sQrCQWAzwO9BORM7yvgQ3w2VQtuBw2Zlw3iJYRQdz65kqO5BYFOiSlVC01eJLxjmMZA9iBz7BG+j8H/KncoQ7vMb5mAB8AN3vff+B9neN9Hw/0x2rf+RxY6vP6uC4/h6ofseFB/OPGZPKLy5jy5kqKSrUiqlRTFpDeZcaYTfgfse97TMeqbCu3fw9WLzXVhPVIiOS5SQP41b9W8fC/1/O3SQMQ7XGmVJOkszCrRun83gk8cH53Pl17kOtmL+PrjYcp0xmclWpyqlyTEZFg4AVgtjHmh/oLSSnLr1OScNltvPbdbqa8tYq20SFcM6w9k4a0Iy48KNDhKaWqoMo1GWNMEXAVEFx/4Sj1PyLCrWd1ZvFD5zDzusF0jAvlmblbGfGXb7l3zhpWpWVSyXR2SqkAq26bzLdYjeypdR+KUv457DYu6JPABX0S2HE0j3/9kMa/V+3nk7UH6d0mkqcn9qN3m6hAh6mU8qO6bTIvATeJyF9FZLSI9PYuQPbTqz6CVOqELq3CmXppb3743RieGN+HjLwSrpi5lHmbjgQ6NKWUH9VNMv8FEoH7sBYeWw/86H1t8H5Vqt6FBTm4dlgH/nPnSLq0CmfKWyt5ddEufXymVCNT3cdl51R+iFINp1VkMO9NGc79H6zliS83sys9n2njeuO0a8dJpRqDaiUZY0ytp31Rqq6FuOy8ePUgpsdt48UFO0jLyGfGtYOJCnUGOjSlTns1+nNPRIaJyP0i8oT367C6Dkyp6rDZhAfGdufZK/qzYk8m41/+jj3p+YEOS6nTXrWSjIiEiciXWNO0/AX4pffr9yLyhYiE1kOMSlXZ5YMTefuWM8gqKOGyl7/jh10ZgQ5JqdNadWsyTwPDsWZNDjbGtMYaN3OVd/tTdRueUtU3tFMLPrljJLFhLq6fvYxP1x4IdEhKnbaqm2QuBx42xnxgjPEAGGM8xpgPgEeAK+o6QKVqokNsGB/9eiSD2sdwz5y1vLpoV6BDUuq0VN0kEwXsO8W+fUBkVU7iHVMzX0QKROSgiEwTkfIzLpcv4xKRZ0RksYgUisgp+6qKyDgR+VFEikRkk4hMqkpcqnmJCnHyxi+HcnHf1jzx5Wb+/PkmPB7t4qxUQ6puklkH3C7lpsT1vr/du79CIhKDNcbGAOOAacD9WFP+VyQUuAUoAL6v4PxnAv8GFgAXYq2Q+a6InF9ZbKr5CXbaeeHqgUwe0ZHZS3Zzz3trKS7T5QOUaijVHSfzO6xFwbaIyMfAEaAVMB7oiPVLvTK3ASHABO8iZfNEJBKYKiJP+y5c5ssYky0iLYwxRkTu5NRLBfwBWGSMudv7foGI9Ab+CHxdpU+pmhWbTfjTJb1IiArm/77aQvrxYl65YTCRwdrFWan6Vq2ajDHmW6xVKddgtb88AVwJrAYGGWMWVOE0FwJzyyWTOViJ5+xKrl/hsw4RCcIaMPp+uV1zgOEiohNcnaZEhNvOTmL6lVYX5ytnLtWVN5VqAFVOMiISJCK/B1zGmKuMMUnGmFDv12u8C5FVRQ9gi+8GY8xerMdgPaocuX9JgLP8+YHNWJ+1Wy3Pr5q4CYMSeW3yEPZlFjDh5e/ZcTQv0CEp1axVZ6r/YuD3QHQtrxkDZPvZnuXdV9tz4+f8WeX2q9PYWd1a8t6vhlNc5mbci0t4c+ke7RCgVD2pbpvMMmAwUNvpZfz9j5ZTbK+L88sptls7RaYAUwDi4+NJTU2tozAaRl5eXpOLuTF4ZLCdf25w88dPN/Lmws38sk8QbcJ1zrOGpPdu81fdJPMQ8I6IlABfYjX8/+wXtzGmoJJzZOG/NhSF/xpOdZyosZQ//4n3fs9vjJkFzAJITk42KSkptQyjYaWmptLUYm4sLr/A8NHqA/z5i01MXVrMHed04faUJFwOTTYNQe/d5q+6/5OWYbV7PA9sB3KB4+VeldlCubYXEWkHhHFyW0p17QRKy5/f+94DbKvl+VUzIyJcPjiRb+47m7F9Enjum2384oXFrN6bVXlhpVSlqluTuakOrvkV8KCIRBhjTiSlSUAhtXwMZ4wpFpEFWD3fXvHZNQlYaozJqc35VfMVFx7EC1cP5LIBbXj0kw1cPuN7Jo/oyAPndycsqLr/TZRSJ1T5f4+3e3Ai8LkxptJBlxWYCdwNfCQiTwGdganAdN9uzSKyA1hojLnZZ9uFWDWeAd73E727Vhhj0rzf/xlIFZG/AZ8AF3lfF9QiZnWaGNMznqGdWvDM3K28/t0e1u/PYc6UM3R9GqVqqLq9y35HLXuXGWOygDGAHfgMa6T/c8Cfyh3q8B7jawbwAXAi8Xzgff20mJoxZgkwETgXmAtcClxjjNGBmKpKIoKdTBvXh79fNYBVaVn8de7WQIekVJNV3ecAy6mD3mXeMTWnGrF/4piOVdl2irKfYNVilKqxcQPasnx3Jq8s2sWwzi0Y3SM+0CEp1eRU9xnAQ1hzl90pIp2968uE+r7qI0ilAuUPv+hFz9aR3Pf+Og5mFwY6HKWanED0LlOqyQh22nn52kGUlnm46901lLo9gQ5JqSaluo/LfkndDZhUqknoFBfGXy7vx93vruGvX2/ltxf2DHRISjUZ1Uoyxph/1lMcSjVql/Zvww+7Mnhl4S7O6BTLOT1aBTokpZqEGvXL9C46dr2I/E5EErzbuohIRN2Gp1Tj8cef2mfWavuMUlVUrSQjIuEi8j6wAfgH1piUNt7dT3JyN2Slmo1gp52XrhlIibbPKFVl1a3JTAdGYI1zieB/E0+CNZeZDnhUzVrnluE8OaEvq9KyePZrnaVIqcpUt+F/AnCPMWaBiJQfKJkGdKibsJRqvMYNaMuy3ZnMXLiTLq3CmTg4MdAhKdVoVbcmEwJknGJfBKCLp6vTwh9/0YthnVrwwAfruP/9deQVlwU6JKUapeommRXADafYNxH4vnbhKNU0BDvtvH3LMO4e05WP1+znF88v5sf9Ov+qUuVVN8k8CkwQkW+AW7DGzFwkIm9hzXysDf/qtOGw27jvvG68e+sZFJd5mDDjO15dtEtX2VTKR7WSjHfyyTFAEPAiVsP/Y1gzKZ9rjFlR5xEq1cgN6xzLV/eMYnSPVjzx5WZufH05R48XBTospRqFao+TMcZ8Z4wZBURiTf0fYYwZaYz5rvyxItJeRE7qXOAdZzNfRApE5KCITPPTkeAkIhIlIq+LSJaI5IjI2yISW+4Yl4j8UUR2iEih9+tj3qUKlKoX0aEuZl43mMcv68Py3Zlc9PfFpG49GuiwlAq4Gi+SYYwpNMYcPNVyy96ksRvoV257DPAN1qO2ccA04H6sGlFl3gNSsB7VTQaGcPJsy/8HPAK8jLWOzAysiT2frsL5laoxEeG6MzrwnzvPJDYsiMmvr+CxzzZSVKr9YdTpq76X/BM/227D6qU2wbtI2TwRiQSmisjTvguX/exEIsOBscDZxphF3m0HgGUicq4x5hvvodcAM4wx073vF4hIW+Ba4J46+2RKnUL3hAg+vXMkf/lyM69/t4fvdqTz96sG0rN1ZKBDU6rBBWK5vwuBueWSyRysxHN2JeWOnEgwAMaY5Vi1pQt9jnMC5bv5ZOM/4SlVL4Kddh4b14fXbxpCZn4p4178jn8s1k4B6vQTiCTTA9jiu8EYsxco8O6rcjmvzeXK/QP4lYiM9E6DMwq4HaujglIN6pzurZh77yjO7t6Sx7/YzHWzl3EoR+c9U6eP+n5c5k8MVs2ivCzvvpqU6+zz/hGsWtESn20vG2OmnerEIjIFmAIQHx9PampqBWE0Pnl5eU0u5tPNNe0MieLi7S0ZjHnmWyb3DmJo60D892tc9N5t/gJ1l/t7ZiCn2F7dcg8C1wF3AeuB/sCfRSTDGPNHvyc1ZhYwCyA5OdmkpKRUEkbjkpqaSlOL+XR0DnBDej73vreWl9dlc9gWx58u6U1UqDPQoQWM3rvNXyAel2UB0X62R+G/plJZuegT5UQkDngceNgY86IxZpEx5gXgYeC3IqKLgKiA6hQXxoe3Defu0V34dN1BxkxfyFc/Hgp0WErVm/pMMh7gDSC93PYtlGt7EZF2QBj+21xOWc7Lt62mM1bD/9pyx6zBqrXpBJ4q4Jx2G/ed351P7xhJfGQQt7+9ml+9tZIjuTqAUzU/lSYZsfxaRH4UkeMisl1EnhKR0IrKGctN3kZ9X18BY8stcDYJKAQWVnDKr4AEETnTJ7ZkrMTylXdTmvfroHJlB3u/7qkoZqUaUp+2UXxyx0gevqAHqVuPce70hcxZvhdjtAeaaj6qUpO5Datn1mHgJWA1cB/wQg2vORMoBj4SkXO9je5Tgem+3Zq9I/Vnn3hvjFkKzAXeFJEJInIZ8Daw5MQYGWPMEazBmU+JyD0ico6I/AZrgOYHxphjNYxZqXrhtNu4PSWJ/957Fr1aR/LIRz9yzavL2JOeH+jQlKoTVUkytwPPG2POM8Y8YoyZBNwM3FiTqVqMMVlY85/Zgc+wRvo/x8mTazq8x/i6Cqu28xrwJrAKGF/umBuxujHfjbWQ2h3AK96YlWqUOsWF8e6tZ/Dk+L5sOJDD2L8tYtainTquRjV5Veld1gXrF7avj4B/Yj2q2lzdixpjNgGjKzmmo59t2cBN3tepyuUCD3hfSjUZNptwzbD2jO7Rikc/2cCTX25h8fZ0pl85gJYROvWeapqqUpMJxhoo6evEaLKQug1HKZUQFcyrNwzmyfF9Wb47kwv/vpjF2/VJr2qaqjpO5nJvI/sJNqyxKVeIyBk+240xZkadRafUaUrEqtUM7hDDne+s5vrZy7k9JYn7zuuG0x6IkQdK1UxVk8yDp9j+cLn3BmvWY6VUHeieEMF/7jyTaZ9vZEbqTn7YlcHzVw2kXYsKO3cq1WhU+ieRMcZWjVela8IopaonxGXnLxP68eI1A9lxJI+Lnl/MlzqAUzURVZ5WRkQEOA84A4j3bj4MLAXmG+3cr1S9+kW/NvRPjObOd9fw67dXc2GfBK4d1oERSbHYbDrJuGqcqpRkRGQg1oJhXYAyrFH8AsR6z7FNRK4yxqytpziVUkC7FqF8eNtwXpi/nTeWpvHVhsMkxoQwKbkdE5MTaR2lfXFU41KVEf/xWIMgC7HWbQk3xrQxxrQGIoCLgRJgrs4NplT9OzEtzbLfjeHvVw2gfYtQnp23jZH/9y2//OcK5m48TKnbE+gwlQKqVpO5CyvBjCq/aqUxphj4SkSWYs0Xdifgd6ZjpVTdCnbaGTegLeMGtCUtI5/3V+7jg5X7+XbLUeLCg3hwbDcmDWkf6DDVaa4qfSHPx1qPxe+yyPDTIMkZwAV1FJdSqho6xIbx4NgefP/IaGbfmEznuDAe/vePPPzheopK3YEOT53GqpJkumDNV1aZVd5jlVIB4rDbGNMznnennMGd53ThvZX7uGLmUvZllh9PrVTDqEqSiQJyqnDccSCyduEopeqC3SY8MLY7r96QzJ70fC55cQkLt+msAarhVSXJVGXFSt9jlVKNxHm94vnPXWeSEBnM5NeX88L87TrppmpQVZ2fYq6IHK3oxf/WdKmUiPQSkfkiUiAiB0VkmohUOpBTRKJE5HURyRKRHBF5W0Ri/RwXKyKviMhhESkUkS0ickNV41OqOekUF8ZHvx7Bpf3b8Oy8bUx5ayU5haWBDkudJqrSu+yxurygiMQA3wCbgHFAEvAsVsJ7tJLi7wHdgVuwVt58Cmv9mFE+548EFgF5WD3j0oFegKsOP4ZSTUqoy8HfJg1gUPsY/vz5Ji59cQmzb0ymS6uIygsrVQuVJhljTJ0mGaxF0EKACd4ea/O8iWGqiDx9ql5sIjIcGAucbYxZ5N12AFgmIueeWLgM+B0QBCQbY07MFr2gjj+DUk2OiHDjiI70aRvJr95azeUzlvLa5GQGd2gR6NBUMxaI6VwvBOaWSyZzsBLP2ZWUO3IiwQAYY5YDu737TrgJmO2TYJRSPgZ3aMHHvx5BizAX17y6jK83Hg50SKoZC0SS6QFs8d1gjNmLtWZNj+qU89p8opyIdAJaAdki8qWIlIjIMRGZLiL6uEwpr3YtQvn37SPo2TqS2/61ireXpQU6JNVMVXmCzDoUA2T72Z7l3VeTcp293yd4vz6NVTu6AOgPPIk159pD/k4sIlOAKQDx8fGkpqZWEEbjk5eX1+RiVo3D7d0NLxfZ+f3HG1i2fivjuzix5sJtGHrvNn+BSDLgv0t0VbpKV1buRM1sozHmVu/334pIBPA7EZlqjDlpVJoxZhYwCyA5OdmkpKRUEkbjkpqaSlOLWTUeY87x8LuPf+T9lfsJiUngifF9cDTQwmh67zZ/gXhclgVE+9kehf+aSmXlon3KZXq/lm/o/xarM0BSlSJU6jTisNt46vJ+3D3amiFgylurKCgpC3RYqpkIRJLZQrm2FxFpB4Thv83llOW8fNtqdmLNCF3eifq/Tk2rlB8iwn3nd+eJ8X1I3XqUq2b9wPc709FlolRtBSLJfAWM9T7COmES1kzPCysplyAiZ57YICLJWO0xXwEYY0qAecDocmXHYHUs2FHr6JVqxq4d1oGZ1w3mQFYh17y6jIueX8KHq/ZTXKaTbKqaCUSSmQkUAx+JyLneRvepwHTfbs0iskNEZp94b4xZirWuzZsiMkFELgPeBpb4jJEBmAYM9M4McL6IPAA8AjzpXZpAKVWB83sn8N0jo3nq8r64PR4e+GAdZz61gOfnbycjT/8Lqepp8IZ/Y0yWiIwBXgQ+w2pPeQ4r0fhyAOWnmrnKe+xrWAnyc+DucudfLiKXAH8BrgGOAk943yulqiDYaWfSkPZcmdyOxdvTmb1kN9PnbeOlBTuYMKgtt4zqTFLL8ECHqZqAgPQuM8Zs4uRHWuWP6ehnWzbWYMubKik7F6vWo5SqBRHhrG4tOatbS7YfOc5r3+3ho9X7+XTtwZ/G2ShVkUA8LlNKNUFd4yP4y4S+LHgghYhgB7e8sZJ0fXymKqFJRilVLW2iQ3j1hmTS84q5/V+rtFOAqpAmGaVUtfVLjOavV/RnxZ4sHv14g3Z1VqcUqBH/Sqkm7pL+bdh+NI/n52+ne0IEt4zqXHkhddrRmoxSqsbuHdOVC/sk8OSXm1mw9Wigw1GNkCYZpVSN2WzCs1f2p0dCJHe/s4YdR48HOiTVyGiSUUrVSqjLwas3JhPktHPzGyvJyvc3s5M6XWmSUUrVWtvoEF65fjCHsov49durKXXrNIHKoklGKVUnBneI4S8T+rJ0Vwb3zFlDZg1qNMYYftyfQ5kmqWZDe5cpperM5YMTOXq8mGe/3srSnRn8/uJeXD6obZUWQlu5J5PHv9jM2n3ZDGwfzfNXDaRdi9AGiFrVJ63JKKXq1O0pSXx+95l0bhnOAx+s4+pXf2DH0bxTHr8nPZ/b/7WKiTOXciinkF+nJLHjSB4X/X0xn6490ICRq/oQkCQjIr1EZL6IFIjIQRGZJiLlJ8P0Vy7KO7tylojkiMjbIhJbwfGXiYgRkZV1+wmUUhXpkRDJB78azpPj+7LpYC4X/X0x0+dto6j0f7MDZOaX8PbmYs6dvpCF245x33ndWPBACg9d0IMv7xlF1/hw7pmzlvvfX0desS6i1lQ1+OMyEYkBvgE2AeOwVqt8FivhPVpJ8feA7sAtWAuQPQV8Aozyc51gYDpwpI5CV0pVg80mXDOsPef1iufxLzbx/PztfLbuIH+6pBdbDx/nxQU7yCsq46qh7fnNeV1pFRH8U9l2LUJ5/1fDeX7+dl5csINVaZk8f/VA+iVGB+4DqRoJRJvMbUAIMMG7fsw8EYkEporI075ryvgSkeHAWOBsY8wi77YDwDIRObfcmjIADwIHsFbL7FNPn0UpVYmWEUH8/aqBXD4okT98uoHJr68A4JzuLTk3Lo9rL+nrt5zDbuO+87szsksc9763lgkvf88DY7szZVRnbLbK23hU4xCIx2UXAnPLJZM5WInn7ErKHTmRYMBaOwbY7d33ExFpDzwE3FNXQSulauesbi2Ze+9ZPDG+D+/cMozXbxpK24jKfwUN6xzLV/eM4tye8fzfV1u44bXlHC8qbYCIVV0IRJLpAWzx3WCM2Yu1PHKP6pTz2uyn3LPA+8aY1bWIUylVx4Kddq4d1oERXeKqVS461MWM6wbx5Hiri/SUN1f9rH1HNV6BSDIxWKthlpfl3VerciJyDtZjtd/XOEKlVKMjYrXx/PWKfj+NxdHxNI1foMbJ+JsXXE6xvcrlRMQBPA88bow5XNVgRGQKMAUgPj6e1NTUqhZtFPLy8ppczEpBze7dGOCaHi7e2XiEX86Yx029XVUah6MCIxBJJguI9rM9Cv81Fd9yLf1sj/Ypd6v3/RsicuIaLsDufZ9vjDnpYa4xZhYwCyA5OdmkpKRUFH+jk5qaSlOLWSmo+b2bAsR+vZUXvt1Br6QOPHJhRU/aVSAFIslsoVwbioi0A8Lw3+biW+6krsrec33i/b47kAj4q8VkAdcD/6peuEqpxui+87qRmV/CzIU7aRHmZMpZSYEOSfkRiDaZr4CxIhLhs20SUAgsrKRcgoiceWKDiCQDnb37AF4Ezin3mgts834/r44+g1IqwESEaeP6cHG/1jz55RbeX7kv0CEpPwJRk5kJ3A18JCJPYSWJqcB0327NIrIDWGiMuRnAGLNUROYCb4rIA/xvMOaSE2NkjDE7gB2+FxORyUCcMSa1nj+XUqqB2W3Cc1cOILewlEf+vZ7oECfn904IdFjKR4PXZIwxWcAYwA58BjwGPAf8qdyhDu8xvq7Cqu28BrwJrALG12e8SqnGzeWwMfO6wfRLjObOd9ewdGdGoENSPgLSu8wYswkYXckxHf1sywZu8r6qeq3J1YtOKdXUhAU5eH3yEK54ZSnXz17GlUPacec5XWgTHRLo0E57OguzUqpZiAlzMWfKGVw9tD0frNxHyjOp/PHTDRzOKQp0aKc1TTJKqWYjLjyIP1/WhwUPpHD54ETeWbaXs55ZwGOfbeTocU02gaBJRinV7CTGhPKXCX1Z8EAKlw1ow5tL0zjr6QU8+eVm9mUWYExl475VXdGVMZVSzVa7FqE8PbE/t6d04YX52/nH4l3MWrSLuHAXfdtG0Tcxmn5to+iXGEWryODKT6iqTZOMUqrZ6xQXxvRJA7hrTFcWbz/G+v05/Lg/h4XbtuPxVmriI4Po2zaam0Z2ZGQ1J/BUp6ZJRil12ugUF0anuLCf3heUlLHpYK6VdA7k8MOuDK6fvYzfXtiTW0Z10jnR6oAmGaXUaSvU5SC5YwuSO7YAIL+4jAc/XMcTX25m06Fc/jKhL8HOSleGVxXQhn+llPIKC3Lw0jWDeOD8bny85gBXvrKUQzmFgQ6rSdMko5RSPkSEO0d35dUbktl1LJ9LXviOVWmZgQ6rydIko5RSfpzXK56Pfz2C8CA7V836gTnL9/o9zuMxHMgu5Psd6SzYchSPR7tH+9I2GaWUOoWu8RF8eseZ3DVnDY989CPrD+TQs3Ukaen57MnIZ09GAXszCygp+98KnZcNaMMzV/THade/4UGTjFJKVSgq1Mnrk4fw9H+38MqiXQAEO210jA0jqWUYY3q0okNsGB1jQ1mZlsX0edvILizl5WsHEerSX7EB+QmISC/gBWA41qqW/wAeM8a4KykXBfwNuAzrUd/nwN3GmAzvfjvwAPALoJe32Crg98aYFXX9OZRSpwe7TfjtRT25Zlh7gp12WkUE+e3ePKJLHK0igvjdxz9y3T+W8drkIUSHugIQcePR4PU5EYkBvgEMMA6YBtyPNeV/Zd7DWnn1FmAyMIT/rYoJEAI8AqzAWgXzOqAUWCIig+sifqXU6atDbBjxkcEVjp+5amh7Xr52MBsO5nLFzKr3Titzeyh1eyo/sIkJRE3mNqxkMMG7SNk8EYkEporI074Ll/kSkeHAWOBsY8wi77YDwDIROde7cFkh0Nm7Zs2JcvOxVsa8k2osEaCUUjV1QZ8E3rhpKLe+uZKJM5by5s1DSWoZftJxxhjW7Mvmo9X7+WzdIVpHBfPelOFEhToDEHX9CETL1IXA3HLJZA5W4jm7knJHTiQYAGPMcmC3dx/GGLdvgvFuKwE2Aq3qJnyllKrc8KRY5kw5g+IyN1fMXMq6fdk/7duXWcDz87cz+tmFTHj5ez5ctZ8zOrdg57E8bnlzBUWlFbYcNCmBqMn0AL713WCM2SsiBd59n1VQbouf7Zu9+/wSkSBgMPBWjaJVSqka6tM2ig9vG8H1ry3j6ld/4Lazk1iyPZ3le6xxN8M7x3J7ShIX9kkgItjJ5+sPcte7a7jzndXMvG4wjmbQQy0QSSYGq7G/vCzvvpqU61xBud97y/6jauEppVTd6RgXxr9vG8ENry1n+rxtJLUM48Gx3blsYFvallu58xf92pCVX8IfPt3Ibz/6kacn9mvy86cFqn+dv9FKcortNS4nIhdjJZn7jTFbT3VSEZkCTAGIj48nNTW1kjAal7y8vCYXs1Jwet279/YxpCeF0DbcILKf7Wv3s93Pce2AcUlOPli1n/zMI1zZvWn3TgtEkskCov1sj8J/TcW3XEs/26P9lRORIVi90V4xxvytooCMMbOAWQDJyckmJSWlosMbndTUVJpazEqB3runcvbZhrBPNvDOsr0M6tWFW0ZV9LCmcQtEktlCuTYUEWkHhOG/zcW33Cg/23vw827MiEg34AtgPnBXLWJVSvkoyc5l9UtfknOskKThHeg0biT24KBAh9XsiAh/HteHrPwSHv9iM7HhLsYPTDzl8ceOF7PxYA7xkcEktQzH5ahaW87R3CJWpWWxKi2LtMwCXr0hua4+wk8CkWS+Ah4UkQhjzHHvtklY3Y8XVlLuDyJypjFmCYCIJGO1x3x14iARaQ3MBXYCV1c2wLMpKDiUztG1u4nr24HwRO0kpxpecUY2K1/8ks1pIRS7WiEeNzsWQNDcL2gXlUuPc7rQ7qIzsDl0hHtdsduEv101gOzXVvDgB+uJDnVxTvdWeDyGncfyWJmWxco9WaxKy2RPRsFP5Rw2IallOD1aR9AjIZIerSPomRBJXLiLLYePs3pv1k+JZX+WNYYnyGGjf2I0BSVldT5LgTT0WtfewZibgA3AU1hJYjrwN2PMoz7H7QAWGmNu9tn2X6Ab1qh+j7f8UWPMKO/+EGAp0BG4FsjwuXSxMWZNZfElJyeblStXVvtzvTl5Jm7CENwIHgSDTbxfbQa7QMvWoSSN6knblP7YXRX3gy9Mz+HHf/2X7esyyXEmYWzWP7yzNJdgdzrhIYW0SmxBQs8OpJVlknLJWAozcig6lkNhRi6FWQUUZR0nLzOD/Nw8PG6DiB273Y7N5sBmd2C3ObA5HIhNaNktnvbnDcIVEVrtz96Y5O46yP4lmzi0+QhHj5ZS7AmiUyIMuOFMorq2q9a50tftoCgjl9D4GMLbxuGMCj9lI6ynrIzjOw6Que0g2XvTyTmcR35uKTYb2J02nE4bdpcNp8uOI8iBM9hJaGwYnS49A2doiN9zNgZFRzJY8dJcthwIo8QZQWjxTr5v9wVr2u1l/Na+dMweQY6tE8bmIKQ4gw5xBfQY25s2owchtsr/mtbHZZU7XlTKVbN+YOexPIZ3jmX13mxyCksBiA1zMahDDMkdYuibGEV6XglbDuWy5fBxth4+zoHs/w0EtdsEt3fyzlYRQSR3jGFQ+xiSO7YgrtjD1oUbGHPzWTWKUURWGWP8VoMaPMnAT9PKvMjPp5WZ6lvrEJE9QKoxZrLPtmjgOWA8P59WJt27vyPWuBl/0owxHSuLraZJ5pWbpoEnErAj2L3heb8XB0ZclAZZtRBHWQHRHKR91xiSxvQnblAXbDYbxTl5bH4vlc3L9pFt64TH7sJZkkWZrMHe8hhlOcFIUUscngQ8zta4HXX7y0k8pUSVHaRt2yA6DE+i3Tn9cYQEdt3zovRsinPyMSWluMvceErceMrKcJe68ZS6KTleyOGNBzmSlktmSThFrliroHHjLD4ApoTSkC6Ix028HKB3Sge6TRyFzXnyX2sej4eDC9ez/ZvN7D1kI8/18yZAu7sIl7sAFyUEOdwEOQ3FJUK+O4hCeyQe+88baJ2lxwHBbXPisft/pOQszaN9VDZ9LupF2zGDK+1JVHQskx2fLiNt3RFKS4WQUCEsykVYbCgR8ZFEJMYR0TGekPjYk37JG48HysrwuN3g9mBzOcHp9HvNgkPprHhpLlsPRVLqDCOsZDtL2n/O8o67uTi4Lb1iezFn/7fstXnonOdi0r5zsWf3I93Eg9gIKc4gPiyfxJ4t6HhuP6K6d/T7eVJTUzlrxAgOL17Hnu+2c3hfEZllUYBgM25slGHHg0082MWDXQwOuyEoCELC7IRGBREaE0pYy0jCEqIJT4wjpHVLbK6m3Vhe3rHjxUx5ayW5haUkd2jB4I5WYukUF1bhPZNTUMrWI8fZcjiXg9lF9GwdweAOMbSNDkFEyMsq4psX53NgfxDO0jwuebQfrTtXv/2n0SWZxqymSQas0bulZUUUFmZSWJhFYXEmhUU5FBXnkltwjI0/riBvo4Ow7K646E5pkPULMagki1AyybEn4rEH4SjNpdSswdFpL2dOuITePS/76ReGMYYjRzeydfc37Ny0gZxdRXgyIpGyEHAWIq4SbEFlOEINQZEOQmNCCY+NxhnipKS0iBJ3ESUlxZSWlVLsLqHMXUJRQQkFOxyEZyQR7u5GSbD1F7/NXUyMOUzbdqFEto4ivFUkEYmxRLRvRVBcFLZyv8TyDx7j6KodHNm8j6P7MsnNc1Jgi8VjcxFclkmIvYCoKDst2sQS0yGWFj3aEt2tHZ6SUjJ+3E3G1oNk7csi60g+uQU28iWKUmdklX72jpIsPJ7dZISkkROXRlDnYnq37YHLEczClavouG0IYeYMypwRBJdk0rV9Gf2vG0V4h3jSvlrBjsU72Z8RQqErBowHV9EuDoWtJzMsg/DicEJLwgkpC8PlDsdhIhDCwBYOnnzcZFDoyCAnJINj4RkciM5gf2wmJU6fJ7UGnG4HocVOQktcBJe46JDRkj5HhuB29cXYnISXHKVLJxt9rh5BVJfEn/6901dvZcfcH9m3q5AMWzwemxO7uwiH+zil9qiTkhuA3V2MGDcGAbFhEIzYMGID8f67GQ82TxliPNiMGzFubLixGQ/F9lDcjhDCS7ayuMPnLOu4l/OcLbnjzD+T1H4kAG53GYvWvsqbG99gpckn1OPhytKuDE6/lPQDoaSXROK2W3+khBcfIT6qmHZ94+l47gCO7z1K2pKt7NmaRa4tgRJXBADB7lwinUdwOR2IhOL22HB7DG634PYIHiOUGTvFBFFm9/9Hlqskl/aRWfS+sCdtzxtapRqVKS3l4Pzl7Fq4jbxcN2VlhjK3jVKPjTJjp8w4cIsDtzitn5v352TDjQ0PNu+TC7t4CHJ4CAoSgkPtBIc7CYkKJqRFGKGxETjDgijOLaQkt5CSvCJK8ospKSihpLCMkiI3QSEO4nu3ps2ZfQlJTKjSvV8TpcVlLJu9mB/XFmGw0SJ9AeEdF3LB1I9xRFb/uppkqqE2SaaqcrL3smzjO2xYsYqyHTFE5HXDLm0pYTslbbcw6MIhjBx6G05n1WoqdfXIITNrF8s2/ItVm5ZTvC2SllldCfF0oyS49UnH2tzFOMtycZp8BDdFtjhKXVE++4uwlxym1HaIMiki2N0Sm8RR6orF2P73qFA8pRix/+8XH+AozUXKjlJsO8rxoHSKHYW4bR6MuDHiBjFgc4N4MLYySMylU6cE+rY9k95dLyYyos3PYjXGsG7T+8xZMQuzvg1JGSMoDemOeNw43IWUOsMRTyn24q3si1rPii4/0jXGwVmth5PYojuFJccpLMmlsCSfgtI8CkvzKSwrpLCsiCC7i3BXOOGuKCKCowgLbkFESCzhoa0IC43F43FTVlZkvdzF1qusmFJ3MUeyd/HtgUVszCnmzC2DaXd8KCXBHRHjpqXnIJGRNg5lusgPsmpUruIj5Do2sqn1Jta134FxeChBCCkOIiE3ioTcSNodjySuJIbQshY4cOGw2bDb7TgcDhwOJ05HEE5XMHaHC3eZh7LSEsrKynCXluF2eyhzGzweKPXk8W37b1je/gAp9hjuGPEHenQ+75T3zsadc3lrxbPMLTqIBzjDBDEiug+9is+hcGckh/aXkOmOwWP7+WNiV2ku8eH52GL2sTZmMV+F7yHX22gd4vGQ5BGSnNF0iWhHUmxvurQ9g4R2IxBXKO4yD/lHc8nbf4y8Q1kUpB8nP6OAI/vyOVzcAmNzEFF8hM7tDX0mDSO6V9LPrl2WX0DaZ9+z8/s0DuSGUxBs/Zzt7iLspgSneHDYvC+7wekwOByCMeDxgNtz4qvg8YDHWImwxLgokaCTPmt1iHETVnSUFqHFtEwMo3X/RBJG9sUZGkTh4UzyD2dQeCSbgvTjFGTlU5RTSEmhm4iWoST0bUer4b1wRUeddF5jDBvfX8oP3xyl2B5JZPYaclt+woSrrqD18DvAVrOlpjXJVENDJJnyDh5ew/a0RQzsOZHIyLbVLl8fz7WNx8PuvYv4fssHbEzbhi3DiSMvDFdBGK6iCFylUTjdkThMJOCkTI5SFnwYYnII6SgkdGtPp9YDaN/2DFzOMA4cXs2+I2vZe2wr6WkZFB+yIdkRuIriMLZSikKPURabQ1BbQ3x8K9pEdyIxthet4/sTHt4ah8OFTWo/+vnIsU28/93jrNh8kIE7RxBUFsmu2I1sTdrMkNhWnN35Aob2vZGQ4JP/g9aX/IJ0lqydzfw9c0lLgyG7hhLhHorbEY69ZAeHwjeytsNGYloVMDimO8kdzqVfj/EEu8I5mrmNvQdXsTd9A3uzd7Ov4DB7S3PYRymFFTxGcRhDWSWP5obbwrlz2G/p1+3SKn+WIxlbmbNkGt9kbmSPzarJtXJ7GOGK44y4EXTIHUnG1hKCI20cb7WBr45/ylJnAcdtNsI9hnPC2nFWxwvILcxgZ+ZmduYfZGfZcdLlf7+nQjweWnsgQVzEO8NJCIolIbw18ZHtSYjpQpu2w/CURLHxve/Z/uNxsm1xiHETV3aAbv2jcYY42L36KAeLYyl1RSAeN6HuneyIXMPCrhvJDssBINLtYRBBDInuzpBO59Otx3jsIdEAlOUdZW9aKtsPrmBH5ma2Fxxmh7uAw3ahtdvQ0RZER0c87RxJJEhnomiPrSyW0uIyCgr3sL9wK7vL9rDelc3+sFKKnCWE2oqJKYqg1cG2dMxoR3Rxe2y29rgd1pxn4nED5qf22YrYPKWEl6YTHVpCXJtQWvVqg83pZOl/9pBla0VI/j4ORXzIGefGMuaiv0Mt73dNMtUQiCRTW4FqPC0tKyY//yhuTyktojvVaGSy212GiGCr4V9QNVVcfJyvf3iGI8f3M7L7RHokXVClxyr1HldJPsvW/5Nvtn1GRnE+/Vt2I7nT+fTpdimuKtZswfqLtbAkn9y8A+TkHiAn7yDZeYfJKUwnpyiT48W5uOwugh0hhDjDCHGFEeIMJ8QVQUhQJLFRnX56LFZTB49tYunGf/H9waX8UHyMXJsgxtDNIxwQD3k2GxEewzmh7RjbfSJn9LkOl8N/21V2QTo79y1h58Hl7M7aweGidI6UHuewp5h08WB87j2XxzCCYM5rPZyzB95G8bEINny4gl37HRQ7rMdydncxCaGZ5Eet5PU2CzkSUspoVyvuGPU4keGtWbHlQ1buX8yKvDT2iZUsIzwe+hgXmaaUXXYo9V7TZgztcdI1KJb40JYcLjzGnuIs0kwJpT7/JSLcHhwYsuzWvR5nbCSHtCG5zTAGdxtH51b9sYmN9LzDbNr1NRv3L2FT5jYOp3tofSiRxOx2iBEKnPnkB+VzPLiA7NA88sLycYcVYHe4ISuKpCNtaZOTSFRxW7AnUuaM+CkGZ0kuR13/wTFkJ3dc/AIRCf1q9W98giaZatAko1Tdc7vL2LTzK77b9jErMzfROiiG87tdTnFWe84dfX6tzl3qLuVYzh4OH9vEkaztrD+0nG+yt3DYZnAYwzCPi/Pih3J2/1vJ3WijtDCP1Z7XeTV7GcfsNkY4orlr+B/pc4rHgYezd7Ny8wesPLCEDfkHiLOH0i2iPV1a9qFru1F0ShhMsJ8/ANweN4dy9rDn4HLSjq5nd/YOit0lDGw9jME9xtO+RY8q/2F2NHs3W3Z9jdtTRlR4ayIj2hAV2Y7I0DiCfDqVlJQVs33fEjamfcumo+vYlH+IrOMuuh5KJKYgkrSu63hw5K/pP/CXNfthn4ImmWrQJKNUw6mve9cYw4ZdXzNvwxvMy9rIfvFgN4Zkj4P9ppQDDhuDbGHcNfRhkruPr/PrNyYlpYVs3/Mtx7J2MHLglCq39VZHRUlGR04ppZodEaFv0lj6Jo3lN8awZe9C5q3/J99mrCfWFsajA+5gZN8bmvzkk1XhcobQu+vFAbu+JhmlVLMmIvTskELPDincHehgTkOBb+lUSinVbGmSUUopVW80ySillKo3mmSUUkrVG00ySiml6o0mGaWUUvVGk4xSSql6o0lGKaVUvdFpZcoRkWNAmp9dUUBONU5V1eOrclxlx8QB6VWMq6mo7s+7sV+7Ls5Z03Povduwmtu9W5XzdjDGtPS7xxijryq8gFn1cXxVjqvsGGBloH8+gf55N/Zr18U5a3oOvXeb/v0T6GvX5rz6uKzqPqun46tyXHWv3RwE8jPXx7Xr4pw1PYfeuw2rud27tTqvPi5rBkRkpTnFDKhKNWZ67zZ/WpNpHmYFOgClakjv3WZOazJKKaXqjdZklFJK1RtNMkoppeqNJpnTjIi0E5H5IrJZRDaKyNNyOiwPqJoFEZkhIgdERJ/zNxGaZE4/ZcDDxpiewEBgGDAhsCEpVWXvAoMCHYSqOk0yjYCIdBGRV0RknYi4RST1FMf18tZCCkTkoIhMExF7da5ljDlkjFnp/b4EWA+0q/WHUKelhrx3AYwxi4wxR2oduGowjkAHoADoDVwE/AC4/B0gIjHAN8AmYByQBDyL9YfCozW5qIjEApcB59ekvFIE6N5VTYd2YW4ERMRmjPF4v/8QiDPGpJQ75rfAQ1hzBOV6tz0ETAUSfLYtARL9XGa+MeZmn/MFAf8FPjfGPFvnH0qdFgJx73qPNcYYbUtsAjTJNDIV/EddBBw0xlzls6091mSelxpjqjztg/cxxXvAXmPMfXUSuDrtNcS961Nek0wToW0yTUcPYIvvBmPMXqDAu686XgGOA/fXTWhKVagu713VxGiSaTpigGw/27O8+6pEREYCNwPJwBoRWSsid9dJhEr5Vyf3LoCI/ENE9nu/3y8i/6h9eKo+acN/0+Lv2aacYrv/ExjznbeMUg2p1vcugDHmlroJRzUUrck0HVlAtJ/tUfj/K1GpxkLv3dOYJpmmYwvlnl+LSDsgjHLPu5VqZPTePY1pkmk6vgLGikiEz7ZJQCGwMDAhKVUleu+exrRNphEQkVCsAW0AbYFIEZnoff+lMaYAmAncDXwkIk8BnbHGGUw/Mc5AqYam966qjI6TaQREpCOw+xS7Oxlj9niP6wW8CAzHepb9D2CqMcZd/1EqdTK9d1VlNMkopZSqN9omo5RSqt5oklFKKVVvNMkopZSqN5pklFJK1RtNMkoppeqNJhmllFL1RpOMUkqpeqNJRqlyROSfIrIywDF8KCKptSifIiJGRPpUctxfRWSPz/uhIjLVz3FTRSS9pvGo05cmGaWap9VYo+t3VrPcUOBPdR+OOl3p3GVKNUPeOcF+CHQcSmlNRqlTEJHLRGSLiBSJyBLv/Fsn9t0vIitEJEdEjojIZyLSpVz5VO9jr2tEZIeI5IrIVyKSWO64diLypYgUisgeEbml3P7O3kdfI3y2vevd1s9n22ci8rb3+5Mel4lItIi8IyL5InJIRH5f7jqTgRe83xvvK7XcMQNF5AcRKRCRNSIyqto/WHVa0SSjlH8dgOnAn4FrsBbYmisiwd79iVgTPo4DbgXswHciElXuPMOAO4H7gSnAIGDWiZ0iIsCnQB+sZbHvA+7BetQFgDFmF3AA8P2FPgooOrHNe56RwOIKPtPrwIXAvd5Yzgeu8tn/BfCs9/vh3tevffaHAm8ArwCXA8XAx96ZmJXySx+XKeVfHDDOGPM9gIiswmrfmAzMNMb85sSBImIH5gFHsZLOmz7niQQuNsZkeY9NAJ4TkRBjTCHWL/2BwBnGmGXlrrXd5zyLsRLKUyLSGWiN9ct+FPAS0BeI4RRJRkR6A5cBVxlj3vNuWwDsBXIBjDHHTnQCMMb4e9QWAtxrjPnWW/4QsAY4C/iv/x+jOt1pTUYp/46eSDAAxpg0YBVWwzgicoaIzBORDKAMKADCgW7lzrPiRILx2uT92tb7dShw5ESCKXctX4uBkSJiw/qlvh74jP/Vbs4CMn3OX94Q79f/+FwnDys5VlUpkOrnsySefKhSFk0ySvl39BTbWotIe+BrQIBfYT2mGuLdH1yuTHa59yXeryeOS6jgWr4WAdFYj9VGYSWd74AEb81mFLDEnHrtjgTguLf2VNF1KpJrjPGceGOMKf9ZlDqJPi5Tyr9Wp9i2EbgAq31inDEmH0BEHECLGlzncAXX8k0IG7FqKqOwai2/Ncbkish677ZRWG1IFV0nwucxne91lKo3WpNRyr9W5XpztcdqtF+O1TbhwXpMdsKV1OyPthVAvIgM83Otn3hrKN95r9MFq2aD9+svsdpoKmr0X+H9eqnPdcKB88odV+Ldp7UTVSe0JqOUf+nAWyLyB6waxTSsR0v/BLpi9SZ7XURmA72BBzj50VhVfAmsAz4QkYexeoyduFZ5i4BngK3GmBP7FwN3Y7UJrT7VRYwxG0XkP8AMEYkEDgEPesv52uL9eo+IfIv1iGxrDT6XUoDWZJQ6lTSsX8JTgTlYPbDGGmOKjDE/AjdhdU/+HKuL8xVATnUv4q2hXIrViP4a8DesrtFL/Rx+oqayyM+2ZcaY0kouNxmrLelvwGxgPtZnK3+NZ7C6US/D6sGmVI3JqdsJlVJKqdrRmoxSSql6o0lGKaVUvdEko5RSqt5oklFKKVVvNMkopZSqN5pklFJK1RtNMkoppeqNJhmllFL1RpOMUkqpevP/8fw5l47Q3JMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "with open('results/syn/errors_trans.npy', 'wb') as f:\n",
    "    np.save(f, errors_trans)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "source": [
    "kernels_regression =  ['tricube', 'aitchison_aitken_reg']\n",
    "kernels_kde = ['linear', 'cosine']\n",
    "# bw = 0.1\n",
    "bws = np.exp(np.linspace(-5, -2, 40))\n",
    "nums = np.floor(np.power(10, np.linspace(2, 5, 10))).astype(int) ## num = [10, 50, 100, 500, 1000, 2000, 5000]\n",
    "errors_opt, width_opt = error_optbw(bws, nums, kernels_kde, kernels_regression, times=100)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "with open('results/syn/errors_opt.npy', 'wb') as f:\n",
    "    np.save(f, errors_opt)\n",
    "with open('results/syn/width_opt.npy', 'wb') as f:\n",
    "    np.save(f, width_opt)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "labels = ['histogram', 'tri-lin', 'tri-cos', 'aa-lin', 'aa-cos']\n",
    "xylabels = ['Samples numbers', 'DP_error']\n",
    "title = 'DP_opt_bw'\n",
    "# path = 'results/Gaussian'\n",
    "xaxis = nums\n",
    "plot_err(xaxis, errors_opt, labels, xylabels, title, path, plottype='loglog')##semilogx"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [
    "labels = ['histogram', 'tri-lin', 'tri-cos', 'aa-lin', 'aa-cos']\n",
    "xylabels = ['Samples numbers', 'bandwidth']\n",
    "title = 'opt_bw'\n",
    "# path = 'results/Gaussian'\n",
    "xaxis = nums\n",
    "plot_err(xaxis, width_opt, labels, xylabels, title, path, plottype='semilogx')##semilogx"
   ],
   "outputs": [],
   "metadata": {}
  }
 ],
 "metadata": {
  "orig_nbformat": 4,
  "language_info": {
   "name": "python",
   "version": "3.7.0",
   "mimetype": "text/x-python",
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "pygments_lexer": "ipython3",
   "nbconvert_exporter": "python",
   "file_extension": ".py"
  },
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3.7.0 64-bit ('FairGNN': conda)"
  },
  "interpreter": {
   "hash": "0d59e7d005459ab828d94ac9f2d56b31a41082ea097fd0fe8ce9027cd475c3ea"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}