{
 "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": 19,
   "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": "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",
      "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": "iVBORw0KGgoAAAANSUhEUgAAAYUAAAEWCAYAAACJ0YulAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABpLElEQVR4nO3ddXhU19bA4d8ei7sTJRCCu7sXKRfqfmu33q/uQnur1N2o0fbWHS0Ut0JxkqAhBIi728j+/piQBkggMpOJ7Pd58hDm2JpZk1lzztkipJQoiqIoCoDG0QEoiqIorYcqCoqiKEoNVRQURVGUGqooKIqiKDVUUVAURVFqqKKgKIqi1GizRUEIkSyEmNwajyOE+FAI8eRZlkshRFdbHrO9Uflt/1SOW6c2WxRaMynlrVLKZxuyrhBigRDiOXvEIYSYJIQ4IIQoE0KsEUJEnmXdO4UQ24UQlUKIBfaIp71oa/kVQjgJIT4VQhwTQhQLIXYJIabbI6b2oq3luHrdtUKICiFESfXPwaYcUxWFdkoI4Q/8AjwJ+ALbge/Pskka8Bzwmf2jU5qrkfnVASeAcYBX9TY/CCGi7B+p0lRN+BsGuFNK6V79E9uU47b1ojBECLFPCJEvhPhcCOEshPARQiwWQmRXP75YCBF2coPqavqsEGJT9bemFdUv/snl11R/o8oVQjxe63FnIUT5yXWFEE8IIUxCCM/q/z8nhHiz+vdTvjkIIR4UQqQLIdKEEDfUevxm4CrgoerKvqjWc+svhNgrhCgUQnwvhHBu5GtzIZAgpfxRSlkBPA30E0J0r2tlKeUvUsrfgNxGHseeVH7r1+D8SilLpZRPSymTpZQWKeVi4CgwqJHHtAeV4/o16m/YVtp6UbgKOA/oAnQDnsD6nD4HIoEIoBx497TtrgSuBwIBA/AAgBCiJ/ABcA3QCfADwgCqk7IN67ctgLHAMWBUrf+vOz1AIcS06v1PAWKAmuuMUsr5wNfAy9WVfVatTS8FpgGdgb7AddX7ixBCFJzl58rq7XsBe2odqxQ4Uv14W6Hya4f8CiGCsL6eCedatwWoHNs2xy8KIXKqC+b4s6xXr7ZeFN6VUp6QUuYBzwNXSClzpZQ/SynLpJTF1Y+PO227z6WUh6SU5cAPQP/qxy8GFksp10spK7GetllqbbcOGCeE0GFN8tvV/3cGhgAb6ojx0urjxVcn9ekGPre3pZRp1c9t0ckYpZTHpZTeZ/n5pnp7d6DwtH0WAh4NPH5roPJr4/wKIfRYP8S+kFIeaGCs9qRybLscPwxEA6HAfGCREKJLA2Ot0daLwolavx8DOgkhXIUQH1WfPhYB6wFvIYS21roZtX4vw/rig/WbRc0+q98AtS+nrAPGAwOBOOBPrG/W4UCilDKnjhhP2Wd1nA1RX4wNVQJ4nvaYJ1DcyP04kspv/RqdXyGEBvgKqALubOTx7EXluH6NyrGUcquUslhKWSml/ALYBMxo5DHbfFEIr/V7BNabpfcDscAwKaUn1lNCANGA/aXX3qcQwhXr6edJm6v3fQGwTkq5r/q4M6njtLOufVavX1ujhqmtPvUsOcvPVdWrJgD9am3nhvUUvTVcMmgolV8b5VcIIYBPgSDgIimlsTFx2ZHKsf3+hiUNe81O0daLwh1CiDAhhC/wGNY78x5Yr0EWVD/+VCP29xNwvhBitBDCADxDrddISlkG7ADu4J830GbgFup/Q/0AXCeE6Fn9Bj09nkysp3wNUn3q6X6Wn6+rV/0V6C2EuKj61HgusLe+SwZCCF31elpAK6w35XQNjctOVH5tlF+s19l7ALOqL7m0FirHNsixEMJbCHHeyb/b6sIyFlje0LhOautF4RtgBZBU/fMc8CbgAuQAW4A/GrozKWUC1jfLN1i/HeQDKaettg7QA3/X+r8H1lPcuva5rDqm1UBi9b+1fQr0rL7B9FtDYz0XKWU2cBHW67H5wDDg8pPLhRCPCSGW1drkCax/iI8AV1f//oSt4mkild96NCa/wtq2/Ras17Qz6vhG6kgqx/Vo5N+wHutrl431dfs/YI6UstF9FYRUk+woiqIo1dr6mYKiKIpiQ6ooKIqiKDVUUVAURVFqqKKgKIqi1HB0k8NG8/f3l1FRUY4Oo0PZsWNHjpQyoKWOp3Lc8lSO27+G5rjNFYWoqCi2b9/u6DA6FCFEQ3tw2oTKcctTOW7/GppjdflIURRFqaGKgqIoilJDFQVFURSlhioKiqIoSg1VFBRFUZQaqigoiqIoNVRRUBRFUWqooqCcqjgDzK1l/hXFLgpTwWI593pK21WYAk0cAVsVBeUfFgt8fw18dUGT31BKK2esgC9mwa+3ODoSxV7K8uCjcfDn3CZtroqC8o9dX0HK39D/ShCNnsVPaQs2vw15R6D/FY6ORLGXVc9AeR70uaRJm6uioFiV5sLKpyByFPRTHxjtUl4SrH8Vel0IXSY6OhrFHlK2w44FMOxWCOnbpF2ooqBYrZwLlcUw8zV1ltAeSQlLHwStAc57wdHRKPZgNsHie8EjGCY81uTdtLkB8RQ7OL4Fdv0PRt0DgT0cHY1iD/t+h8SVcN6L4Bni6GgUe9j2CWTshUsWgJNHk3ejzhQ6OrPR+u3CKxzGPeToaBR7qCyGPx6F4D4w9GZHR6PYQ3EGrH7Oelmw55xm7UqdKXR0Wz6ArH1w+TdgcHN0NIo9rHkRitPh0i9Bq/7k26Xlj4G5Cma82uzLv+pMoSMrTIG186DbdOg+09HRKPaQEQdbP4RB10L4EEdHo9jDkdUQ/zOMuQ/8ujR7d6oodGTLHgZpgekvOToSxR4sFlhyP7j4wKSnHB2NYg+mSljyAPhGW+8J2oA6l+xgRs1bTWpBORM0u/jcsJiXjZfx/kvxQHzNOqHeLmx6RDVZbPN2fQUntsKcD8DV19HRKPaw8U1rv5OrfwG9s012qYpCB5NaUE7yMxPg/UdA142Hbn2Xh3SGU9aJemSJg6JTbEb1O2n/8pJgw2vWfiddJ9lst3a7fCSE+EwIkSWEiD/HekOEEGYhxMX2ikU5zYbXoOC4tU/CaQWhMVSOWzEb9TtROW6l7NjvxJ73FBYA0862ghBCC7wELLdjHEotXUQqbHoL+l4Gncc2d3cLUDlufU72Oxlxhy36nSxA5bj1OdnvZOLjNu93YreiIKVcD+SdY7X/A34GsuwVh1KLlDyjWwAGV5j6nA12p3Lc6pzS7+ThZu9O5bgVqt3vZMhNNt+9w1ofCSFCgQuADx0VQ4cT9xOjtAkwaS64B9r9cCrHDnCy38n0l1qk34nKsQOc7Hcy8w279DtxZJPUN4GHpZTmc60ohLhZCLFdCLE9Ozvb/pG1R+UFsPwxdluiYdD1LXXUN1E5bjk1/U6mQeyMljrqm6gct5wW6HfiyNZHg4HvhPUmmD8wQwhhklL+dvqKUsr5wHyAwYMHq4H+m2L1c1CWw+PGu1mi0bbUUVWOW1JNv5OXW3JQQ5XjlmKxwOL7wMXbrv1OHFYUpJSdT/4uhFgALK7rjaTYQOpO62BZQ28mYX3nc69vIyrHLejQcjiw2Hpp0CeyxQ6rctyCTs53Mvt9u/Y7sVtREEJ8C4wH/IUQKcBTgB5ASqmuP7YUi9l649E90NpSYf1Gm+1a5biVqCqDpQ+AfzcY8X823bXKcStxst9JxEjrJFh2ZLeiIKVscI8ZKeV19oqjw9v+GaTvhos+BWcvm+5a5biVONnv5NpFzep3UheV41biZL+T81+3+6VBNfZRe1acCauehc7joPdFjo5GsYfsQ7bsd6K0Rrbtd3JOqii0ZyueAFM5zLT/twvFAaSEJfeB3jb9TpRW6GS/E88wm/Q7aQg19lF7lbQO4n6AsQ+Cf1dHR6PYQ9xPkLzBOpRFC/Q7URzgZL+Ty75usflO1JlCe2Sqst549I6EMfc7OhrFHqr7ndBpYEv2O1FaUu1+Jy0434k6U2iPNr8NOYfgqp9A7+LoaBR7WPM8lOXAVT9Ay/U7UVrSH4/8M99JC17+VUWhjTk5H0J9BnsW8ZPlFegxC2KmtGBkSotJ22XtdzLkP9BpgKOjUezh0ArYv6i630lUix5aFYU2JrWgnOR59ZxKSsnKuRPAWQvT5rVsYErLONnvxC0AJj7h6GgUe7Bjv5OGUEWhPTmwhMnaXTDhOfAKq3c1U14esrwcfWhoCwan2MT2z6xnCnbod6K0Ehteg4Jjdul30hDqRnN7UVkCyx5mvyUcht1a/3pSsu6e91n50FctF5tiG6rfSfuXc9jh/U5UUWhj+lRqST2Uf+aC9S9DUQpPGG8Arb7e7UdnJ3PQeShH3QZQkVtox0gVm/vzyep+J82bTU1ppVpJvxN1+agNSTucx7RyA7+/vpORF8fQb1I4QgjI3Ad/vQcDrmHHX7H1bi+lZHy5jkova9qPrd1H7EUjWip8pTmOroe938PYhxj1yQlSCw41a3eh3i5semSijYJTbCL+Z2ueHdzvRBWFNkJKyYb3NmKoNONVnMymnwQVJUaGz46GJfeDkwdM/i/8taXefRxdtIVKr2708M/mYKYnx+KKiVVXIVo/U5U1xz5RMOY+Ulesrr+xQQNFPbLENrEptlFR2Gr6najLR23Egf+tIqfCnfKiBIbo/qZTxmZ2/HGMXV/8Dsc3w5RnwM3v7PtYm4TGVMGoh2fhW3aMtCyV/jbhZL+TGa+qfift1ernoDTbOuCdg/udqDOFNsBYVMKW1Xm4anXM69yHO578Pyz/vg5Triubt/QlvNf5+Pe/+qz7sFgspBW5Q1kqTh6uhHiUEGdxoyCrDO9A1xZ6Jsq5+pmcLkxksdIwj9WWodz+aRWwhFBvVRjalVbW70QVhTZg02tLKHMKYOp0Nyr/ykHr5UXkJ/OpunAO6726saXsP5yvOfu3/vTNB6jUeZCiTQEgrKsHcYlwfHcG3lOjW+JpKJyjn8nppIRvLoNkAzPu/Jzk6mbGprw8ynbuwnWg4z9AlGaymK2zqbWififq+kErl3swlf3p3oSKFGJmD6t5XFdxlOghB4g8sZJjRyUZSWdvSXR49QGQFtZ7W2dsChgYg76qiMx9aXaNX2mGA4vh8HKY8Ch4hVEen0DKXXdzeNx4jl15JTkffODoCJXm2v4ZpO2E815oNf1O1JlCKxf//V9YhDdjb63VSshsgsX34RQaSL/wzpyIK2Lzlzu58OkJ9e4nJcWMtzGDVB8fAJx79cKlYjGF6U72fgpKU1SWwLJHyPMcT0LSOI5+9TsVlaBhPIbxU3GxlBD81Y901+oIuPkmR0erNEVJVqvsd6LOFFq5jBOVeJhy8e0X88+Df8+HzDiY9iJBd9xGZNke0jMk2Qfq/tafFpdGocaPsBBLzWO6wEBczMWUlFjq3EZxrMo/X2NDynl8d/gu4tZnoM9LJSLISOfRXQjsE0m5Vxh7+97O6pXlVKZnOjpcpSlWPAHGslbX70SdKbRixqIS8vAj2q+g5rEg8qwjZHadTEH0OA7n7cHrxj6IH038/dpCNL6nDl1RWljJsg/24FxRQr9LBsP3RwEQQuCmqyTL7ITFItFoWs+bsqM7vGoHG5b2ocLiSaf0TcQST+eXn8U59p8+KGaThe0/xbF9bW/+emsF4+dd48CIlUar6XfyIPjHnHv9FmS3oiCE+Aw4H8iSUvauY/lVwMmphEqA26SUe+wVT1t0YsU2LFoDYQP++aB/Uv8Vu3SCd7wN7PhxPBZp/aZ/pf5KTlT159rEH4BZgLVvw/J3/qbKKJgQfhzvAZfUFAUAN1eJRENZYSXuPs6Njk/l2Pb2bUpjzY+F+FTl03vvhwQPjCL09c/Rup86wYpWp2HoZX3J2Pg1CfkhdN11grAB4TaPR+X4TI1tQXY6PSaWGR5BTyBTV/SicoV9+ow0tYOiPc8UFgDvAl/Ws/woME5KmS+EmA7MB4bVs26HdGJbMhBJ5JT+ABgP/cGuwEM86ulDUHk2/+nzHwYFDkIIwa6Q/Zh/cWJEoQuL332AmXe8wsGVh0hPMdIjfRkxrz17xv49vHRQAkW5FU0qCqgc29SxhFzW/m8/fkX76bPrAwJuvJ6Ae+5B6Or+MxVCMPG2IXz3agLbvt1ll6KAyvEZGtWCrC4bXoNVaXDljxzsNtV2gZ2mqR0U7VYUpJTrhRBRZ1m+udZ/twD1D+vZQZz+DeTpY5VoXPLo/ep6nEQJwyOeYaenB//ufhV3DLwLV/0//QtGdBrBDzu3csQ4kdHvPcVfqxLY73MT7sZSBj90CVpPzzOO5xngZi0K2WV06urd6HhVjm0nN62E5R/txb00hd77PiPyw/dxHzfunNt59IolVC4lubA3FaVGnN3qH/eqKVSObSw/GdZVz3dix4LQHK3lRvONwLL6FgohbhZCbBdCbM/Ozm7BsFrWyW8gyfNmcvCOflS4h9M53MDhF6Yypt/H7HYR/LfrFTw47JFTCsJJQ6ZHY9H7smPyNBINQ6kweDPuP4PwHDu6zuN5hlgLRWFKHQPs2Z7KcT0qSowsfXc3mtJC+sW/T/QrjzWoIJzUpYc7UmhJ3HTMjlE2iMrx2UgJyx4GoWnV8504vCgIISZgfTM9XN86Usr5UsrBUsrBAQEBLRecAyUt3Y5Z50Lk0EieX/cwWyszedapCxeOeqzebaL6+JOrsVDBLIp9xnEobAsBIyPrXd8pOABDZQFF6UX2eAo1VI7PbtOPBynJLadP/IfE3Ngf1ykXN2r7sMmDcCnL5OD6ZPsE2AAqxw1wYAkc+qOm30lr5dCiIIToC3wCzJZS5joyltZm/95S9KZS4qMO8vPxP/lPcQX/Ov8jKkpKyEpOIiPxEGaT6ZRthEaw1cmE2WghbLQLq8O+5cuE+i4Fgz4wEOeKPIpym37T7FxUjs8uP6OUA1szCU1ZS/eBx3D9z6uN3odrv74EF8STkSMoLay0Q5Rnp3LcAFWl1rOEwF5nn++kFXBYk1QhRATwC3CNlLJ54wC3MyV55WSYAol0PsJ/d81nWHkF/zf4fg7tO8If77+JscL6Ie7q5U3vCVMYecmVaHXWa8kJBjNfPzocrwAX1q6dzIKEBVzW/TJ8nX3POI4uMBCXilxKiuo/m2gOleNz2/zVLrSmSvpqf8Przheto902ktDpiIoQHDUJkvfm0GtMy82op3LcQOtegqIUuPjTs8530hrYs0nqt8B4wF8IkQI8BegBpJQfAnMBP+B9Ye24YZJSDrZXPG1J3MI4pNAS77ManamKZ2QQGxMNbFv0IiExsQyZdREWi5kDm9bz928/kn7oAP+6/3Gc3d1BUDPA3f8N/D9Wn1jNZ3Gf8cCQB844js7fH+eKPLLKNU3qq6By3DxHd2WQfKSK6MxVhM+JgZ6zm7yv4DF9cfojn2PbTti0KKgc20DNfCdXQ8RwR0dzTvZsfXTFOZb/B/iPvY7fVkkpObgrH5+8RL7vvY+HMwrZWDKBE4m/0HfyNCZcdws6vfWbRuyIMezbsIblH7zFLy8+xeXPvHzKvqK9opkcMZnfjvzGXQPvwqA9db5XYTDgqi1HIigtqMTDt3HNUlWOmy4jMZ/lH+3FoziNYZ1+Q3vBn83q1eo+Yji+33xFapKXTTsjqhw3k5S15jt5xtHRNIjDbzQrp8pPL6O0Uo+hfA/ddZVoC0aRevQE026/lyk33VlTEE7qOWYC0++4l/TEg2z97Ycz9jen6xwKKwtZn7K+zuO5VzdiKrbjfQXlVBVlRha/vhVDeT6TLPPwvfIW8G3eSLX68HD8q45TZdKQdcy+DQeURtj9jXW+k8n/Ped8J62FKgqtTNK2EwAk+8ZzQ5obB5NLGHbBpfQaN6nebbqPGkf3UePY8vN3BFSe2tRvZKeRBLoE8lvib3Vu6+ptHRCvrMhomyegnNPmt1ZQadYxyrSA0JFuMOruZu9TCEGnSGeQkhP78mwQpdJsZXnWebXDhsKAtjMMiSoKrcz+DQdxL0nBJySLuIxYfEPDGTrnknNuN/GGW3Hx8GRCznqk5Z9B7rQaLed3OZ+NqRvJKc85YztXf+uNzYpSVRRaQq+CbA4c1RNevpduXTZbB0PT2WakWu/+PfAoPs7xuA7YB6A1WvVfKC+A89+Ac8x30pq0nUg7ACeLhaJiV7RlOzBnxFJWYeK8W+8+45JRXVzcPRh79Q0EVWURv3blKctmd5mNWZpZkbzijO1cg6xDaZcXVdjmSSj1klJyYX4JGmlmXKePEH0vhujxNtu/S79++OYfIPNYCcYqs832qzTBiW2wYwEMvw2CzxgyqlVTo6S2IgPMR5D0JE+fiE7rzqVPPENI19hzb1itx+jxfPX5d/z+8XyuXpJNod67ZplbFz+eXfUrod63nbKNU1AA2rhyynJKbPU0lHrkrv+bSq9Yuum34eVVBuc9b9P9O/fpg2fxm0gJOSdKCOnSOiZt6XDMJlh8L3h0gvGPODqaRlNnCq1EpbmSIcVVULYNI4IZdz/SqIIA1uvK9z/9KD6uev6T+xsr5njVDJtxZZ8pePgcY82Dpw55oQsMRG8spTxPFQV72/31FqRGy0DPL61TL3oE23T/Wnd3/P2sf9JZyepms8Ns+9g638n0eU3qd+Joqii0Et/EfYWrORpj1TYie/clqm/T5t/1j4jimpfewi8sgkVvvsTBvzYCMDp0NOWmcnZm7TxlfZ2fH3pjCeVFLd8TtiMp3RvPUWM4AVXx+EYGWCdptwOfvl1xqiokU7VAcoyidFhtne+EHv9ydDRNoopCK1BYWciOnxdTadqPBRNjrrqhWfvz9A/kkiefJzS2B0vfeZVjcbsZEjwEnUbH5tTNp6yr9fbGYCylokxdg7anhE+WUuXkzUCfRXD+m6DR2uU4zr164VF0jKwjLTLIoXK65Y+CxQgzXmlVs6k1hioKrcD8ba/RM7kr5oqddBk0nKDors3ep97JmTkPzcU7KJhVn76Ps9aJQYGD2Ji28ZT1tN7e6I0lVFbKZh9TqVtVcjKHs7xwNWfzl7MnhA2y27GcunXDo/gYhblVVJabzr2BYjtHVkPCrzDm/mb3O3EkVRQcLKU4hd8TfkWaAIyMufJam+3b2c2dUZdfQ356Gof+2sjI0JEczj98StNUjYcHelMplVVt81tNW5D00fcUeMfQx3str5gvPWVZSVUJB/IOsC1jG0cLj2I0N69psFNMDJ5F1iG0s48XN2tfSiMYK6w9l3272KTfiSOp1kcO9va6Rxkb502FJZEiQ2f8wmw7e1bMkBH4hUWw5ZfvGfCg9Tr2nuw9TIqwdoYTGg1OWjMmqcVkNKPT2+eyRkdlyslh/74qNMFV9L54PEW/umM0G1l4ZCGLkxazI3MHkn/O0jz0HkyOnMy1va6li3eXRh9P6+GBr1sVYL3ZHBbrY7PnopzFpjchLwmu+Q2L0JOZWEBaYgFmk8TJRUdAhDsBkZ7oDa3/70sVBQfam/Y3y3J3c3dGTwq1Zaz1tf0shkKjYdgFl7L0nVdxSi5Bp9GxN3tvTVEAcDJYP5QqSky4+7T+N21bkvnV12QEDqar136ch96DbuU8Zv32DqklqUR7RXNz35vp5tMND4MHOeU5bEnfwvLk5SxKWsT1va7ntv63odc0blRNj67huJgK1XAXLSX3CGx4HXPPS9h3Ioadn/xFSf6ZDTcMLjr6Tw6n38RwDC6t96O39UbWzkkpeWntg/TMkBRqynFyjuWYs32+1cWOGMPG774kbvlSug/qTlxO3CnLnZytVxErSqtw97FN71oFpMlE3NpULCF96Hb5KB5c/xAuYX/gaejBE5OfYFSnUYjTbkbO6jKL+wffz2vbX+PjuI85kHeAV8e9WudMe/Vxio3FfVMyuSm2bfKq1EFKWPogueZoVsRdQ172IXw1eQwyJRBgKMCjdzf0I8ZTqA1g36Y0/l50lH2b0phyfU86xbTOszh1T8FBlu39jL3GPGbsDwUBXQedB3a6rK/Raul/3vmk7Iunr4wmPicek+Wfm5DObtbvBhUlaqgLW8r/bj7H/EcT4HqMO489y8pjK6nMmso3M79hdOjoMwrCSb7Ovjw/+nnmjpjLprRN3LryVipMDe9x7tQtBreSVAqzyzGpns32te83EnZJfkh/huLUAvrEfcSg/e8TXLwfjh8m9+23ybjiQnQf/5fJM7y46KFBaLUafn19F3FrUxwdfZ1UUXCA0qoSXtv1DsPTDeSU6dEaetN9QtP6JTRUnwlT0Tk54b+/gnJTOUcKjtQsc/G0nh2Uq6JgO2Yje37bj0nvztddl1FYWcgn531CVe5EdJqGnaBf0u0SXhr7EruydvHU5qeQsmEtxJy7dcO9NA0pIT+jrDnPQjkLWVHEug+2srbs//AqTOK8iP0M/+Zluq1ZTdT339Fl8WJiNqwn4O67KNm0maQ5F+B66C8ufXwIUX38Wf/dIfasOuHop3EGVRQc4MOV9yILdPTc0wkniwsGt9GE2vmGoLO7O73GTqJkzxEMVRr25uytWebi7QKoMwVbKvr6WRI9JmLkMMbgEr6Z+Q2DghrfFHVa1DTuGnAXS48u5YuELxq0jSEqCvfKLABy01RPdXuQUrLy8S+IN00lvGgnc+ZOIPLpRzBEnjqLoS4gAP/bbqPLsqU4d+9O6j33UvT5x0y7pTddBgSw8cfDHNqW4aBnUTdVFFpYYsZO/ty/ixl/B+Kq0ePiOoOwboEt0iqh1/hJWEwmYvP92Ztdqyj4ugNQXqDmVLCJguOsW1pClZMXcQO2s2DaAsI8mj5R+3/6/IfJEZN5e9fbJOYnnnN9odfj1ckTjTSTl1ra5OMq9Vvz1HccKu1FdMkmZn58G649zz4kjT4oiIgvFuA1+19kv/U2eR99yJQbexHS1YvVXx5oVY0CVFFoQWaLmVe+v5eJ2wPx8fEjItuXCtdIug7r1CLHD46Owc3Hl9h8P+Jz4mse1/t4ozOWUZanPkBsYe+nD5HiMRUpd/PSv18k0DWwWfsTQvDE8Cdw17szd/PcU+4H1celSzRuldnqTMEOZmRnsD8riMjCdUx99ya0bm4N2k5jMBDywgt4zZ5NztvvUPj9t0y7uQ8uHnr++CieqorW0dlQFYUW9NWG5wne7Yyzm45R0aNJjryIThFO9BgR0iLHFxoNXQYOxT2lkmN5R6kyW9uza7290ZtKKS9UZwrNlbX3O7buGYQUgsm3T8Tfxd8m+/Vz8ePRYY8SlxPHDwfPnGHvdIbozrgWHic3VRUFW0rbcpA+mlB8Sg5x3l1d0Ho3roWX0GoJeeF53CdMIPOFF5H7dzP1xt4U51ew+edznwW2BLsVBSHEZ0KILCFEfD3LhRDibSFEohBirxBioL1iaQ2S8hNZu2IFnmV6wsIvZd3+MLQamHLbIISN5tNtiC6Dh0GVmYBcPUcLjwL/DHVRUdy4QfFUjk9VXpbHFx//QpXrIKKC0uner79N9z8tahrDgofx4Z4PKak6+4e9U5cuuJekUlpQ1awJlFSO/2EsKefPj/eiM5czc8AK9MObNpua0Grp9MrLGKKiSL37bvzdK+g/OYKEDWmtYtY8e54pLACmnWX5dCCm+udm4AM7xuJQleZKnvnmJnoneqMzdCMr1Y+A4gPMuq0H7j7OLRpLRO9+aA0GIjJdOZR/CKhVFEobffq6AJVjwHrj8Y2Pr8G75FJcTdlMffLqBm9rqqoi48hhjsfvIWVfPHlpKafMnneSEIJ7B99LfmU+n8V/dtZ9GjpH41aaDkBeerMuCy5A5RiA1c/+Tonej5HaD/C65oVmDXindXcn7J13sFRWkv7oYwydGYl3kCvrvz+E2XRm7luS3TqvSSnXCyGizrLKbOBLaW1nt0UI4S2ECJFSptsrJkd5648n6L/OE7PGCS9zN/rtnEfs/Ddw7R/V4rHoDAYi+w6gMGEThwsOA6D19kJvLKWoonGD4qkc/+PHX58mbMtMij29mH5DNDrD2f+0LBYzqfsTOPjXRg5sXkdl6akf3F5BwfSbMoMB552PzmCoebyXXy+md57OV/u+4soeV9Z7ecoQFYl7eXVRSC2hU1fvJj0vlWOrwwu3klgYSJeiFayLDqJXYPdm79MpujNBDz9ExtP/pfiH7xh18XSWvLeXuLUp9J8cYYOom8aRPZpDgdqNdFOqHzvjzSSEuBnrtxAiIhzzYo2at5rUs7TOCfV2YdMjE894fFH8T7h/dphynZmg4Elc9OBs9C6XovP1tWe4ZxXVpz9J27dy9Ph+GFRrpFTbD4rXpnLcVLu2LqXqey+KfbozdpITYcPOPmbRsb27WTH/HYqyM9HpDXQdOoKYoSNw8fTCYjJTlJPFvg2rWf+/z4hf8yfTb7+X4K7dara/o/8d/HH0D77Z/w13DbyrzmNonJxwD3BHi4n8TLv2VWj3OS7PK2HdwgzcjCVM7PsH9xTM5XYb7dv7sssoXrOGrDfeoMuSSUT08mPb4qN0GxqMq6fh3DuwA0cWhbo+ger8qiqlnA/MBxg8eLBDxnhOLShn6y1jMBnNhHY7s09B1CNLznhs+8EdHH1+OUadCU+PAXwcGMMT7+yo9xih1f0F7C2sZx8AihKto2lqnJzQY8QsNbY+dW1TOW6K9L27iXsrmWKf/gyMTaLPJfVPnmM2mRiTu5Gfno/Dp1MY59/zMJ0HDMbgfGbe+0ycSvLuHSyf/w7fPfUQ59/7KF0HW8fGivSMZHLkZL478B039L4Bd4N7ncdz7twZV2M+hVlBtnmydWv3OV75wjKqNN5McXkewwUvUvG57f5GhBCEzJ3LkZnnk/niPEY//iLf/ncrO5cfY/QlMTY7TmM4siikALWHBA0D0hwUyzlpJPwxPw5jpZlrnh+J0zkGtErKSWT9c58iLekEOPlx+RsP8/zz60ieN7OFIq6ff1gEwsWAS3oJhZWFeDl5oTdYby8ZK2w6LEKbynFjJS/ezOofkyn3iKGb38+MuPudetctKyxg4esv0r8ogYHT/8XoK69Fbzj7OFNR/Qfx75ff4ZcXn2Lha88z866HiB1hnU71xt438uexP/np0E9c1/u6Orc3REfjsi2Fgky7fitv1zk+sHAHx0v86F6ykMhZXSF2OnDmF8Dm0IeG4n/rrWS/+Sbel15C7IgQ4tel0n9yeIvfcwTHNkldCPy7uvXCcKCwNV+HjDVqKcmvpLLMRNyas3dNP5FxhK8feQhZdZxgkwvXPHk1Bo+6v805gtBo8O4aRXCeM4kF1mZwBmdrkbNxW+k2lePG2P3RHyxZVIZR64Sb76tMufNm0NT955SXlso3Tz5A5pHDLA+YxITrbj5nQTjJxd2DS554jpCY7vzx3utkJlnz1cu/F8OCh/HV/q/q7bfg1CUal9IMinLKMZvtdvOy3ea4rKCcDYvT8ShLYUzXn61zLtuJ7w3Xo4+MIOvllxk8LQIpJduXHbPb8c7GbmcKQohvgfGAvxAiBXgK0ANIKT8ElgIzgESgDLjeXrE0l5SSIZU6fIJd8QxwYffKE/SdGF7zQVpbTnkOb759DyHFAnfdGKZHrkfETHFA1GfXpc8g8uMOsT9pF4OCBqF3tT4XY2XDzxTaU44b4uR9pYnphxhi6I6+Kold/d5lcF4sUW+lYP3SfKqosmNMzl6FRLA46Hx0wVGNPq7BxZXZDzzO/x69h99ffZ6rX3wDVy9vruhxBfesuYf1KeuZGHHm/SxDdDSuZYuQEopzKvAOavhIqyd1tBzXtuaVPzHizFT9Oxim3gfe9jvj0hgMBN57H6n33IPc8Ac9R/Vm38Y0Bk6NwNO/ZS4rn2TP1kdXnGO5BO6w1/FtKfVQAUFmDf2nROAX6s5P87YTvz6VgVNPHeckuyybO365kSFJEp1TX3ok7cTz+ZcdFPXZ9eg/ku3ffMuJfXEwApzcnKAKqhoxhWN7ynFDpBaUs2uEhcU/eFFiMPPb4K/41FhJyBOfcqOz5ynrmk0mNnz7BTsWLyUgsjP/uu8xngxueidFV08vZt//ON/OfZDlH73NnAefZFzYOAJdA/nh4A91F4XOnXEtt46BVJBZ1qSi0NFyfNLxv4+SnOtOTNFyIkYLGG7/p+hx3lSc+/Ul+623GfD97+zbnMaO5ceYcFXzWzo1hurR3ABJO7MwYsH9pzeoeuUxgiNc2L8p/ZRRK0P8yhn/9SX47CxBSA3Oul4gj9P1w2SiHllC1CNLWuxGckMEhEdiMkDpMevlX4OH9dplVSPOFDoSaTZz7b6lrPlsN0UeUayN/p6bKo8QMvUFOK0glOTn8eOzj7Fj8a/0mzqTK597De9mFISTgqK7Mvryf5O042/i1/6JTqPj4piL2ZS2iRPFZ17S1Pn44K6zDrldkKVGS20oi9nCugV7cKrIY1SnLxHnvwE6+7cEEkIQ9MADmLKyMP7xG71GdeLApnSKclt2pAFVFBrgxN4M/PIPUbZqBaWbN+O7/ksKMsvYfePDFK9dy7GiY7h3/ohQTMSmu+HiHItvQRq9rruB5Hkza37qarLqKEKjwRLohibL2j7eydP6LbKqXI2UejpTfj7Hb7qFoVXOpIeMIi50FT6+25gTMBh6XXjKusV5OXz/9MNkHj3CjLseZPKNt53Sz6C5Bs2YTVjP3qxZ8DEFGelcGHMhWqHl50M/17m+W3ggellJQZYawqShdn+7lSKLJwMqv8VtzGyIGtVix3YdMgS3kSPI/eQT+o8PAg3s+KNl7y2oonAOpYWVFOSbcS86Qudffib6t1/p3NUJrTRyrCKElFtvY/0NczBWVnBt3li0GoF0GotvwUE8prS+ewm1uYUG4V4oKC4v+qcoFKkPj9qqUlLZfv0jrDFNJDlqJvnhyewKX8zTufmIma+f0qu1JD+PH595nNKCAi554jl6jBpn83iERsP02+9Do9Ww5O2X8XfyZWSnkSxOWoxFnnkz2RAZiWtFNgX27avQbpSXVLJ9fR4+xYfp32M7THm2xWPwv+MOzLm5GP/4jR4jO3Hgr3RKCxs3BE1zqKJwDsf+SgJgr6srTl27YoiMJOrdN+k2OoIM//4sGu/P4PgKXoofRMbOvUS66RAaNzqF6jFERTk2+HMI7NwFrUVwIHEnBi9rUagsUCOlnlR0IIll93/NjuDL0IZ0YrH/Qb4PfYO7c3MIHnE3+HetWbckP48f/vsoJXm5XPjo03Tq1sNucXkGBDL1lrvIOHKYTd//j1ldZpFZlsm2jG1nrGuIjMSlMJXCTJXXhtj83lqMwonh+s/QTp8L7gEtHoProEE1Zwv9xgYhzbJFJ+NRReEcklfHozOVsbjTqTd7AgfrMRrN4HwP2TMuYk9CAs4aC0I7FOeKXDpd6vj+COfSpVt/AI4c2o2ztwcAlcUNn/axvTIZzaz73z6+fuMwKd4D6TPInZlP9uNE5y/oaxZcpvOH0ffVrF+cl2MtCPl5XPjYfwnr3svuMXYbNoo+E6eyfdGv9DZF4q53Z+GRhWesZ4iMwqU8i5KCKoxqas6zyj2ez8EkDWH5m+k80hUGOa4hld+tt2LOzUWuW0KXQYHEr0+lsqxlLu2qonAWsqqKjGyBv66AbDfvmscLKwt57OB9/Nn/Y7woZVvaQcqcneh5JJsMUx98S4/ieV7rvnQE0KPrIIxaC1lHj6DzckdjrqKqtGMXBbPRwrIP44nfmEFQxt/Mmq5l7E1DeT/+PTTaUuZmpqGd8RrorTfmi3Ky+OHpRyktyOOiR1umIJw09uobcPH0ZN1nHzMlfDIrj62k3HTq5T9DVBSuZdYWSEXZ6tLg2ax7fzMacxWjfP+HmPVmvf1OWoLrkCG49O9P3qefMWBiKMYKMwkbWqZPoCoKZ5GxfCPlTr6EDwytecxkMfHYz3dRmpLBLaHnUZb9CxqtG/5+U8nreQ0mrQtdenuiseHNRXtxd3KnxAvKUrPQenqiNVdSVVrl6LAcatWX+zmekEvswa8ZNdqZiDkTSMhJ4IeDP3BZUSmxXWdAzGQACrMy+eG/j1JeXMTFjz9HaPeeLRqrs5s7E669icykwwzKCKHMVMa6E+tOWccQFYlLRS4Axbkdu+CfTdLfJ0gvcCE2bxH+sy+AkH4OjUcIgd8tN2NMS8Mpbj2dYrxJ2JCKxWL/0UFUUTiLoyutU1ZGnzcAgMKsDN558maif89lxoZADnz1C8FdujF9ZDSFsjcZzr0ZOkjQ+6FrHRl2o8ggdzTZpQhXV7Tmikb1U2hvMpOLOLwtk+i8TXR2SiPg7ruxSAsvbH0eXzTcmFcG06y9WguzMvn+v49QWVrKxU88R0jM2adjtJfYkWMJ69Gb9FVbCDT4s+LYilOWa93dcXW1fpAUqaJQJ4vZwsb/xeFSlsmQmPUw4XFHhwSA+/jxOHXrRu4nn9B7XChFORUcT8i1+3FVUaiHpaKC9FQTTqIKvwgvkJJv5z1B5dEMykYEM+u+R5ly8/9x8b//Rffs1xjRO5HxV8Uy5KYJaFxaT3+Ec3EPDUZrhOLKCnSmCoytZEpAR9i25CgGjYmwhF8IfvppNAYDS5KWsDcnjnuzs/jYeBF4dsJUVcXC116gqryMi598nuAujhm4DKzfKEdcfCWl+XlMLuzFhpQNlBlPbWnkHuqPRpoobuH27m1F/IpEiquc6VP4A+5XP3NGvxNHEULgd+MNVB5OJLBoP66eBuLXp9r9uI4cEK9VK163njyPaEIjnRFC0KnyOKXpGRwZouGtO97GVe8KZhPMHweeoQy86Upwaj3jGzVUUFQ0+SRxPCsZrbkSY5UFdC03E1xLOdfQ58EmwTUlzkQeXca6kJ7M+i0Hfv8F9y6vEGs207XIj9fc5/AksO5/n5KVfITZDz5JUOezD5PdEsJ79SGsR2+ydh7DOLyC9anrmRb1z7w4TpGROGcUUJynzhROV1Vh4u9FSXgVHqfP2ArofZGjQzqF54wZZL3xJgULPqfnxU+xfVkyRTnldh36QhWFeqQv20iV03giR1j/6AdUrqVCb+amy+ZaCwLA1g8hMx4u+1+bLAgAnaN6k89KjqcmopNajEbZLotCakH5WUeo/eOjOI7vSiUqdyvnLfmNO4MCeXfXu3y0t4Qns7PpddMS1ocP5dDWTexevoRBM+fUDGXtaEIIhl90OT899wR9s4L4M/nPU4qCITIS5yNZFGVHnmUvHdPO3w9QaTEwrPQ7nK+d36zZ1OxB6PX4/vvfZL38MtG3FrEd2P9XOsNmRdvtmOryUR2klKQcKgQgrKc/uxO3EJVfiugbytDwEdaVClNh7YsQMxW6n+/AaJsnOiiGcoOZnLTj6IQZo6l1/VG0hKLccpJ2ZxNyfC3B//k3+qBAssqy+DJhAeeVltG/1+UQPpTCrExWfPg2wV1iGHNl67pvFNG7H4Gdu9DnmDcbUjZQYfrnrMAQFYlzRS7FOeryUW2lhZXsXpNGYNYOYq8aekq/k9bE+9JL0Li7U/XL14T38OXA5nS73nBWRaEOxtQ08lwicXMy4+nvzPc/vgkS/n3VI/+s9McjYDHB9Jdb3beLxujk1oliNxPFWdnotRaM5o73lohbmwIWC5GmA/hedx0A7+16F6OpkrvLJEz+L8aqSha/9RJSSmbe/TBand6xQZ9GCMHgmXPQ5FXgmy7Zkr6lZpk+PBznijwqyi2NGgW3vdv6YwIWC/STizFc+LSjw6mX1t0drwsuoGj5crr1dqMkv5LUA/l2O17H+wRogIoDByjw7kqnKBc2p27G+WABKZ4ehIVWf5M4/CfsXwhjHwDfzo4Ntpn0Wj1GTx2m3CL0OjBJraNDalHGSjP71h7HP3s3Ebdei8bZmcT8RH5L/I0riooIn/QM0tmbZe++RsaRw0y77R68g4IdHXaduo0Yg5uvH32TfVh7Ym3N44aICJxPNktV9xUAyEsvZf/2PELT1hP5fzfV9DtprXyuvAKMRrzj/8TJTcf+zfbrs6CKQh1y445g1LsT3KcTny17HfdyHfudh1gXGsth6QPgFwMj654ft63R+XmiLTWh1UvMQo9oMxMlNt+hrWlUGQWd5WG8Zv8LgHe2v4arxcLNbt2g35Ws/2YBh7duZtzVNxAzbKSDI66fVqdjwHnnE5RjYNu+dTVjIWk9PHDTWfufqL4KVlu/24XWXEVvly04Tbza0eGck1PnzriNHUPRj9/SbVAASbtzqLRT83FVFOqQmZgHwAnPo+gP5KJx0pPkUt3KZMPrkJ8MM18DXcNmz2rtPIICATDrrNecW9eFEfuKX3oAt9J0ut1yEUKrZU/2HlanbeTawmK8z3+TfRvXsn3RL/SbOpNBM+c4Otxz6jVuEmgE/kdMxOXE1TzuUd1aRTVLhexjRSQdrCL8xGpCH5rr6HAazPeqqzBn5xAqj2E2WTi6O9sux1FFoQ45uaDBzLcpn9A5w40eI8dh0ughJxE2vQl9LoVo24+A6SgBnawzShmF9QPD0EHOFLJPFJNToCXceADPqdZeyu9sfg5fs5lrul9Oar5gxfx3CO/VlwnX3oRoA/eO3H18Ce/bn66p7qw5tqbmcY9QP4Q0qctHwJb/bUZvLKGH92Gch4x1dDgN5jZ6NPpOndD++T0efs4c3pZpl+OctSgIIS6p/rdtXzhvBHNJCQX44upUTPGBo+hMgt5jJwMSlt4POhc473lHh2lTYRHdACiTJQAYZOv/8LOFvT/uQGMx0nvOIIRGw7a0LWwtOMCNFYKiiMv5Zd5TePoHcP49D6PVtZ3W2wMmTse1Usvebf8UBUN4OM4V+R1+/KPsI5kcP2Eg/MQqQtrQWQKA0GrxvvQSyrdsoUs3Z04cyKesyPbD0pzrTOHR6n/rnsHjHIQQ04QQB4UQiUKIR+pY7iWEWCSE2COESBBCOHx+1/IDByn2iCDXJZke6T54BgQS2r0nszR/QdJamPQkuAc6OkybivSLpszJRLnZWhRcLI2ap7nN5RisN5iPHCwnsHg/gRfOAOD9jXPxN5mZ0vN+fn5lHq6e3lwy9wVcPb0cHG3jRA8agnA14HqgiIzSDAAMEeE4V+RSlFnc6P211RzXZdc3K9GaK4jxy8Rl4CBHh9NoXhdcCFotASc2IS2SIzuzbH6McxWFXCHEGqCzEGLh6T9n21AIoQXeA6YDPYErhBCnjxh2B7BPStkP6+TgrwkhHDqSXObORCxaA3GGXQRka+k5ZgKiqpgn9f+DkP4w+AZHhmcXYR5hFLmaKDdZi4KXsWFD9LbVHAPE/bQdo3Ci97AAhMHA34lL2V6ezg2aEP5YuA2NVsslTz6Ph6+/o0NtNK1OT9SQoYRnubA+yXq2oA+zNktt7OWjtpzj0xUd2EtiSiCd0jYSfPudjg6nSfRBgXhMnABLvsU3xJXEHS1fFGZiPVvIAV6r4+dshgKJUsokKWUV8B0w+7R1JOAhrBdr3YE8wKGD72Qest5k1lpyQEKPMRNh9fP4Uwjnvw6a9tdk09vJm3IPqKyyXlpwNzU4BW0yx9IiiduQgWfpCbr+xxruh389S4DZjHfOSPLTUjn/nofxDGi7Z4RDxs9EZ9Gwa8tKwHqm4FRZQHm5xGw+c4a2s2iTOT6DxcKeb5YB0EWXhNvolpti09a8LroIc34+Yd4lpCUW2PwS0lmLgpSySkq5BRgppVx3+s859h0K1J4uKKX6sdreBXoAaUAccLeUZ84pKIS4WQixXQixPTvbPnfcT8rKMoKplNg8d0K6xuJLNmz7mP+ZJ0No2zvdbAghBFpfd6TJjJRG3M0NnsyjTeY4ccVeSvCgR6wGrbs7O3fMZ5ulhKssAzi0fRfDL7qMiN6OHTq5uUK798Tipqci4ThGsxFdUBBOpmJAUN64D5E2mePTVf39DfszexGYtYPQ6y5vE40G6uM+ejS6gAB89q8CCUf32Pa1PNeN5kXVl4k+bezlI6CuV/30di3nAbuBTkB/4F0hxBlDFEop50spB0spBwcE2G96PFlVRb70w2jehSa3nN7jJ8GS+8DVn1dNl9rtuK2Bu48fANJSgqulwd8k21yOAXYuPIChqpC+t84EYznzd72Drxn0h31x9/NnyL9a16BoTaHRaAnq34vgTD3bjm9BaLW4eVhvlpcUNGq+3zaZ41OU5bF/4TqMwpWokt14zZzRcse2A6HT4TX7X2g2LMLT18CRXS1YFIBXsV4mOgqUAx9X/5QA8efYNgUIr/X/MKzfJGq7HvhFWiVWH6c7DpK/dz9lbiGYRRIGFxe6u56A1B1w3vMU4eaosFqEb4C1l660lODa8MsLbS7HR5duI8cSQI/wcgz+vuxb9QSb9HCZaQzZyUcZc/m/0Tu17t6tDTVq4oXoLBr+2rgIAHd/63u4tHFFoc3l+HSWP59ib/4EvAqPEHXhOEQbmADrXLwuvBBhNtPJkE3qgXwqSm03VedZ29mdvEQkhHhWSlm7Qe8iIcT6c+x7GxBT3Zw1FbgcuPK0dY4Dk4ANQoggIBZIakT8NrV99SakJRJRnkePceMxbHgeOo+FPpcASx0VVosIDIwgiz1gKcJZejR0szaVY2mxsPWn/Rg03gy5dxbkJPJZ0u94uLij21tBQFQ0PUaPd0RodhHdsz9GF0Fh/EEAPDt5Q2aji0KL5PhcQ5s31UBxiNflPorkBcSmfs6kQ+dT+MiSZu0z1Nvx86U4RUfj0q8fPnHLsARczrG4HGKHh9hk3w1tfB0ghIiWUiZBTb+Fs57/SSlNQog7geWAFvhMSpkghLi1evmHwLPAAiFEHNbT1IellDlNfC5NdvINeV9aFlIUIS0WspNWU+VSwvQDszjy6NJW8Uawp7CQaLIAYSrASdOwYcDbUo4BEr9aRq4hjIHdK3DycufEl5fxp6sz11aNoTj7KJNvuA3hwHl5bU1oNLjGhGHZn0x2SRZuESGIdCPFmUUN3kdL5fhcQ5s3idkE81/g94NX4lRZQPfRkex54TLbHsOBPP81i7Jnn8d15pUc3dvyReFeYK0QIgnr9cTOwC3n2khKuZTTvmJXv4lO/p4GTG1wtHaSWlDO33OH8PstqZRUraZTVBhXuHwLY+5n1aSbHR1eiwj368wWrQWDuQhDI27CtZUcayxmdq7KwuAUzKBbz4P4n1lQtA+9uxcuOwvwioml84DBjg7T5noNGcvuvSdY+/dCzouIxGl9PsXpDT4TBNpOjs/w90fkp+aTUtGD6NSF+D98q6MjsinPGTPIfHEeQZpMju8TmI0WtPrmf6lp6B7WAh8B+ViLwkfAuVoftSm/x/9KhV6DRZbQzykBvCNgzAOODqvFdHLvRJmLCSmL0dd5b7Ftm5F2mBzXaHr1c8ZAGXkrHuN3Dw8uKB9JWX4+oy69pk23SKnPiJEzsQjJwe2bMYSF4VRVSElu2bk3bOsKU2HNC+zV3YKwmOgSVIpz91Zzm8MmdD4+uI8Zg/e+lRgrzKQets1w2g0tCl9iPTt4G+upYmfgK5tE0CpI4tf+halqH3qtjm7EwfRXwODq6MBajKvelSoXDVKWoWtnQ2JJk4khVQZ0lkoG3jAO1rzA99oKjBbw2VtMp9ieRPRp201Q6+Pq7ompkxvGwxnoQkNxqiykrLh1dSGwi+WPUmXScyC7F0FZ2wm++hJHR2QXXv+ahefRrWi1kLzHNldlG/rXHyul/I+Uck31z81AN5tE0ApoXY4RmBSIxZhIrGsWup4zIXbauTdsZzQezghzLs6pKxwdik2lL15LiU8PuvfQ41yQQOW2+XznG8D0kv6U5xcw8uIr2+VZwknBfXrjWaQhIfsAzpRTVqU9s1Fpe3J4Jez7nQMhT2Mya4isSMBj0kRHR2UX7hMmoHcxEKjJ5ujeHKRsfmIbWhR2CSGGn/yPEGIYsKnZR28l9F47cC9zBSwMDk6DafMcHZJDOHl7YhRQ1M7maI5ftg+AgVcNhSX3sdQniAJTFaEJZjp169FuzxJOGj5iOgB/b12Oq5vALLW0/UaZ9TCWw9L7kb4x7E3qjGfRUaIuHI9oQwMaNobG2RmPyZPxPryOkvxKclNLm7/PBq43DNgshEgWQiQDfwHjhBBxQoi9zY7CgcqMZcRUlWIyHsRbCvym3wve4efesB1y9/EDIfi0j41bgThQVUoKJypDqKzKxuPYj8jUHXwVGMqovC5UFRQx4uIr2vVZAkD3boOocpKk7U/Azds6B4i7pZ0+5+r5TlJ6v0phvpmwzM14X3Kxo6OyK89Zs/BN2wnA8YTcZu+voeWz3V5LWXV8FcOORIJlH4MDCmH47Y4OyWF8A0LI5zDusmWHILCnw1/+QYVzNPHaNFj1X7ZHDeFIaSZjD/kT1C2GyL4DHB2i3QmNBk24L+JEDm5dPCAVPO048bvDnJzvpPfF7N3nhd54gq6DgtD5+Dg6MrtyGz4MVw8dnqKQ4wm5DDwvsln7a9CZgpTy2Nl+mhWBgy099AduJSVopZ5edz0D2o4079ipgoOtbyZ32kdRkBYLh/YWopNGZvj8CFVlfB0cRd/MQMyFpYy4pH3fS6gtoldf3Mq15LkUAhBc0c4m25En5ztxpnjo0xyLz6NT2ib8r7nC0ZHZndDp8Jw+HZ8T20lPLKSqmdN0tq9mJo2UVZZF3q58LKbjRAgNutgJjg7JocJDugLgbslzcCS2UbJjF5nu3YkMLOJi3VrSht7Auoxt9D/iQ0i37kT26e/oEFvM8KHW+wqJ5ckABFU1qldz65fwi3W+k4lPEr+jEikl0Z7ZuPTp4+jIWoTnzBn4Zu/FYpGkHGhe09T2efelgZYmLaHPUT+giIGTJzk6HIfrHNINi5B4WBre47U1S1y4FbOuO7GGbzlhDOBn3wC6bHeD4gpG3Nn+7yXUFtWlF0ZnSC1IJ8hYgm8jJlJq9SqK4I/HIKQ/5v7Xs+/bDfjnxtHp6n/Z7ZBV5iqOFh7laNFRskqzKKgsoNJsLbQuOhd8nH0Idgsm2iuaCI8ItHYect+lf3/83SvRySqOJeQSPaDpAw526KKwOO4bRpaGobe4EX7FtY4Ox+HcnTyocJa4mdp+5yZpsZB8uBydVyURpmXcaP4/jiYuYsaxQIKiOxPVb6CjQ2xRQgj0kYFUHUsjKH8nua5nDGLadq15Hkoy4YpvSdydS0UF9Czcied0290flFISnxPP+tT1/JX2F/ty92G0/DMInVZoMWitbboqTBXIWm1+XXQu9A/oz/BOw5kYPpEoryibxXWSEALvmdPx2byP4/FuSBnb5H112KJwOGMH2iQPpDkbkzkYrXv7HgW1ocxuOtxMbf/SQunO3WS5xRBm2YG2xzQ2JunolVyFrsjE8Jsv61BnCSdFdO/N8YNZhJWsJq0szNHh2Eb6Hvh7Pgy5EUIHEvf5ZlzLMomeNhCNk1Ozd59RmsHPh39m0ZFFpJakohEaevv35qoeV9HTryedvToT4haCp8Gz5j1lkRYKKgtIL0nncMFhEnIS2J65nTd2vMEbO96gh28P5nSdw6wus/AwNG7IkbPxPH8mPotfJbugP4XNmIu7wxaFZeuepn9iJyCVzd6x3OvogFqJETffyL0/H+Z1RwfSTEmLtmDSdyfWaytMex/DN7cyaJc//hGRdBk01NHhOcTA/hM4/vtqtl46iPcOj6bNt7OzmGHxveDqBxOfJPt4MZkpFcSkbcB33hPN2vXBvIN8GvcpK46twCItDA8Zzq39bmV82Hi8nb3Puq1GaPB19sXX2Zde/r2Y03UOAOkl6aw6voqFRxby4t8v8vaut7ko5iKu7309/i7Nn/bVuVs3grwqOQTNuq/QIYuCPLGNpUVHmFrhjQEftge0rzFRmuO8frMp+7Z5Qwu3BscOFaP1qCRyxhQOWErpXJyNW1Egw667tF2NhNoYkV17IQUkZx+nTN8O5ozYscA638kF88HFm7g1CWgsVXSNdULfqVOTdnm86Dhv73qb5cnLcdW5ck3Pa7gs9jLCPJp/ZhXiHsLVPa/m6p5Xk5CTwFf7v+Lr/V/zw8EfuLLHldzU5ybcDQ0bobjeY0wdgdPWfE7sTm/yPjreX4fZxJ5ldxF+NAZpyScyPBopOt7L0J5VpSSTZehMMIfRj76Nnw7+SN9EbzyDguk2YrSjw3MYncGAJsgT0gtB08YvEZZkwar/QtQY6HsplWVGDm3NIChjG0FXN36WxDJjGa/veJ3Zv89mfcp6bu57MysuXsH9g+9vckEwVVVhMhrrHHqil38v5o2Zx8I5C5kcOZnP4j9j5q8z+S3xt2YNVeE57Tx8Cg6Scii/yUOZdLwzhW2fsKwinT7H+mAkjZG3XQcf73N0VIoNZXz6OhUuc4gcaKDMYuTvrSsYV+TF8CsuRWPnViCtXXDXblRuKUAX7LC5rGxjxZNQVQYzXwMhOLAlA7NF0Fkk4Tp8+Lm3r2VDygae2fIMGaUZzOk6h7sH3t3gyznSYiE/I52MI4fIOppIzonjFGSmU5qfj+lks18hcHJ1xc3LB7+wCAI7dyG0e0/rECueEbw45kWu7nE18/6ex5ObnmTRkUU8PfJpwj0aP7KCU+fOBLoUk2HSEmhu2n2zjlUUijMwr36Obe7+jDGX42wIwq9LZ0AVhXYj6wDJCeXgC10umMqyo8vokmigTGugx5iO3Q8FoGfv4aRv3I6/5oCjQ2m65I2w9zsYfR8ExFpbBv2ZhGfRUSIvmdzgRgRlxjJe2vYSvxz+hWivaL6a/hX9A/ufc7uKkhISt/1F0q5tnEiIo6KkGACd3oBfeCTBXbrh4eePs5v1UpCpqpLKsjKKc3PISTnO4b83A+Ds5k7XoSPpN2U6vbr04ovpX/DToZ94Y8cbXLzwYh4a8hAXxlzY6EYRUaNi2BsPvcqbdjbYsYrC8sfYpZOM+jsMi8wneuBsR0ek2JKUyMX3kaadgTtFeAa4snj59/TOduEv737o9B23t/pJEbG9AfAvbH7LHIcwVcHi+6zznYx9EID0xAIK8s30zPkbrzmvNWg3+3L38eC6BzlRfIIbe9/I7f1vr2lSWheL2UzSru0krF1J0s5tWMwm3P386TJoGKHdexLctRt+oeFotOc+E60oKeHE/jgOb93Mwc3riV+zgk6xPRl5yZVc0vsSxoSO4clNT/L0X0+zJX0LT414qlH3GoL+NZlOKxYQ5ta0of87TlE4shrif2ZD2Fi8yzpRoE9l2OWqKLQre76jdO9u8jzuJjbcxIG8A+h3Z4LOm3jPXo6OrlXwCe6Ek6sb/vlttAn2lvcg5yBc8X3NfCdxK5PRmcqJGRmO1v3sH55SSn44+AMvbXsJX2dfPjvvMwYH1z/jXllRIXv/XMaeVX9QkpuDq5c3A6bNpPvIcQR1iWlS02Znd3dihowgZsgIKstKSVi3im2LfuGn554gqt9AJl5/C/Onzuez+M94d9e77M/bz1sT3qKLd5cG7d8QEcGIYTq+Odzo0ICOUhRMlbDkAcy+nfH6M58CJy/cvTrjGxLo6MgUWynPhxVPcLRyClKjp/PoSL7b+z1dUt2JHTuWimPte47thhIaDWOuvI7vFx93dCiNV3Ac1r0M3c+vme+kvLiKpL15dMrYSsDD15x180pzJc9veZ5fE39ldOhoXhj9Aj7OdQ+WV15cxNZff2DPn8swVVUS2XcAE6+/hegBQ9DacBhuJ1c3Bk7/F30nTWPPn0vZ/OM3fPHAHYy89GpumHU9AwIHcP/a+7lyyZW8OOZFJkY0bF6I4McfY9sjTWtFaNdmN0KIaUKIg0KIRCHEI/WsM14IsVsIkSCEsM8UnxvfhLwj7Pb7Fx4l/ZCWAgZMO88uh+poWk2OVz0D5XkcMw1Da6kkaGgEh9euQ2cRDD+/fQ+d3Fj9pkznhEvDW9S0mhwve9j6b635TvZvSsMiBV38C3GKial309zyXG5cfiO/Jv7KLX1v4b1J79VZEMwmI9sX/cKnd93EzqULiR0xmutee5+LH3+WmCEjbFoQatMZDAyaOYfr3/iQ6IFD2fDNAr5/+lG6ijC+P/97or2iuWfNPSyIX2CTiXTOGou9diyE0ALvAVOAFGCbEGKhlHJfrXW8gfeBaVLK40KIRn91HzVvNakF9ffeixQZrHB6BdFpBrz9B2kxExEmLf2mqpuOzdVSOT6nlB2w/XMsg28h41gIQR5FrE75k85HDXh364x/eCQQb/PDdgStJscHlsLBpTDlmZr5TqRFEr8yCa+CRCKur38OkKTCJG5feTu55bm8Nu41pkZNrXu9XdtY+8Un5Ken0rn/IMZefUP1e6fluPv4Muu+R9m/cS2rPv2ALx/6P6bcdAefT/ucxzc+zms7XiOlJIVHhz5qt/GU7Hn5aCiQKKVMAhBCfAfM5tSmPlcCv0gpjwNIKbMae5DUgnKS59XzhpASvr6YwgQ9mb+XkND5Gkym9UT0HoyTaxu9ptq6tEiOz8pihiX3gkcwadpZVBqqiOxh5MuVXxBeoWPc7KttergOyPE5riq1niUE9jxlvpOUQ/kUl0Cfsjg8Jt1Q56a7snZx56o70Wv0fD7tc3r79z5jncKsTFZ//iFJO7fhExLKBQ8/RfTAITZ9Co0hhKDnmAmExvZk6TuvsuTtVxg0czYvXTmPTu6dWJCwgLyKPOaNmXfWm+NNZc+iEAqcqPX/FKwzuNXWDdALIdYCHsBbUsovT9+REOJm4GaAiIiIhkew73fMB1axYdcsCnzGkO8ClJYz4LwpjXkeSv0cn+Ntn1jHv7lkAUd+TAPpi8f4EJzeyEb4+NLFgX/c7YTjc7z+FSg8DtcvO2W+k7hlh9AbS4id1rvO6TbXp6znvrX3EewWzIeTPzyjE5rZZGLnsoVs/vFrBIKxV9/AwOmz0OpaRys1r8AgLn3qRdZ99Sk7lvxOXloqd93zCIGugby87WVKqkp4c8KbuOqb1sqoPvYsCnXdlj/9YpgOGARMAlyAv4QQW6SUh07ZSMr5wHyAwYMHN+yCWmUxeb+/ydL0tyiMCkdoK8kyfUKolzedB9Tf2kBplBbJcX2XCAPIZ5XTU+yy9OXar/Q8klaOQaZx/Xc/ckGBE2sDuvP2Y8sACPVWN5qbyLF/x1kHYPM70P8qiBxZ83BpYSXJB0sIy9qG36V3n7HZ0qSlPL7xcbr5duODyR/g6+x76m6Tk/jj/TfIPnaU6IFDmHTjbXj6t76GJ1qdjonX34J/eCQrP3mfH599nIsffRpPgydzN8/l1pW38v6k95s9PEZt9iwKKUDtLnlhQFod6+RIKUuBUiHEeqAfcIhmSvvpfRYeexgNRnILd7J3xnqGL7HQd85su90s6oBaJMf1XiL86QbYb2Hc7QuIM/rz5dM76O6TwvCS45gNOn569REMzqoYNJPj/o6lhCX3g8Hdei+hlv3rjiHR0C1Gi87/1N7Hvx7+lac2P8WgoEG8M/GdUz4wpZRsX/QLG7/7ChcPD/51/2N0HTKi1Y+a23fyNFy9vFn81kv8+MxjXPzEc7iMfYWH1z/MLX/ewgdTPsDTYJvh0O3Z+mgbECOE6CyEMACXAwtPW+d3YIwQQieEcMV6Wrq/2UfOiGPrBgPaqnImem5l6cAQnA/mISTcvk1P1CNLTvlR3yKbzHE5ru53wpj7wK8LBxfvAsAYXUxQiobAYf1VQbANx+V4z3dwbCNMfhrc/vnglxZJ/OpjeOcfIuKaU/sa/XDwB+ZunsvITiP5YPIHpxSEqopyFr8xj/Vff06XQUP59yvvEjN0ZKsvCCd1HTKcOQ8+SX5aKj8+8xhj/Efw6vhX2Ze3j9v+vI2SqhKbHMduX5mllCYhxJ3AckALfCalTBBC3Fq9/EMp5X4hxB/AXsACfCKlbF4zEYuFgp+eI41b6JK3kugP5nLTof+R8po7Ib16sXdu+5+ztaU4LMfGCljyAPhGw6h7AEiKy8e1rIItWVtwkXD+xbc06xCKlcNyXN3vhLAhMPDUCbCO78+ltEJLf81RXPr/k+cfD/3Is1ueZWzYWF4f/zpO2n96bRfn5fDrS8+QcyyZcVffwKDzL2gzxaC2qH4DmfPwXH6d9zS/znuai594jlfHvcoDax/g9lW38+HkD5t9j8Gu11GklEuBpac99uFp/38FeMVmB931FXFHQhAWE916OaNxdmb35pVEVegYMk31YLY1h+R401uQdwSu/hn0zpQXV5FT4UGkIYmMfblYugXgH9xOJpFpBRyS4+p+J8z8FU4b6nzv7wnoq4rpfuHQmg/2Xw//yjN/PcPYsLG8Mf6NU1rlZB87yi/znqaqvIwLHnmKzv0H2SxMR4js05+Z9zzMotdeZNEb87jgobm8NPYlHlz/IHetvov3Jr93SkFsrPY1ZnRpLsYVz7O/YioB2bsJmDqW/Ip8nPfkgJcLXQad3mhCaXNyj8CG16DXBdB1MgCJ6w4jhYY898MYTBpG/etyBwepNEt1vxOG3QohfU9ZVJJfwYnjRkLzduBz/gwAFict5qnNTzGq06gzCsKJhL1895S109tlT7/U5gvCSTFDRjD5pttJ3r2D1Z9/xJTIKTw36jm2ZmzlgbUPnDJVaGO1rzuuK+eSXRKIUTrTqXAvbiPu5uft3xKc50y3OeMbNFiV0opJCcseAq0Bznux5uHDm0/gVFZAakUKZQGCkYOnOTBIpVlq9TthwmNnLI774xBSQvehfmhcXFh1bBVPbHyCIcFDeHPCm6cUhMNbN7Pk7ZfxCgrhoseewdO/6ZPZt0Z9J02jICOdbQt/xi8snFnTZlFmLOO5rc/x1KangBFN2m/7KQrHt8Cu/5HV6WXIheB+EWicnNi/8k+cNZJJM1UnpjZv3++QuNI6zIFnCABVFSYy87R4lv+NXgOhM4e3yWvFSrVa/U5wOnX+YovZwr5N6fjmHyL8yYvZnLaZB9c/SC//Xrwz8R2cdf/MJhe3ZgV/fvQuwV1juOCRp3Fxt91cyK3JmCuuJTflOGu//ISAqGgu634ZBZUFvLv7XQwBJcCsRu+zfVw+Mhutc7V6hZNV1RNDVRH+E0dSXl6K4VAB5lh/XD29HB2l0hyVxfDHoxDcB4bcVPPwiYQczFJDvj6ZIlcTF8y46Sw7UVq14gxY/Rx0mQQ955yxOGlnBhUmPV38CtnvlMM9a+6hs1dn3p/0/ik3V3cu/Z0VH75NRJ9+XPLE8+22IIB1gMPpd96PV2AQi9+YR2lBPjf3vZnb+9+Oqahfk/bZPorClg8gax9Mf4ns1HLci0/g0q8va1b9gN4k6D52vKMjVJpr7TwoTofz3wTtPye4SRuOICqPUmmuonJAAIFura8DktJAyx+zjmg84xWo42xv72/xOFXk4T27O3esugN/F38+mvIRXk7/fOHb+tuPrPniY7oOGcGch+aid24Hc1Gfg7ObO7Pue4zK0lL++OBNkJLb+t2GpTK4Sftr80UhhFzrB0a3aZi7TqewRINnVRb6sDAOrF9DsauJiSMvcHSYSjN0F8ethX/QtRD2T290aZEcTyxFlG6gUmdm7LTGz82rtA6jNXHWfiej7wW/M+cNyM8sJT1XR2hFArcXfYBeo+ejKR+dMm3mXz99y8Zvv6D7qHHMuveRDjWpUkBEFOOuuZHk3TvYuWxRs/bV5ovCU/ovQVpg+svkpZUi0eDrIyjKyUYey6O0mwdezt6ODlNpKouF5/WfgosPTHrqlEXZJ4opqyyhXORyNLqKSV3qHv1SaeWMFTyj+9za72T0vXWusufnPQiLmb0Rf1NiKuWDyR+cMofxXz9/y+Yfv6bXuElMv/O+DtmopN/UGXQZPIwN3y4gLy2lyftp20Xh0HKmabfBuAfBJ5LsY4UABET7smONdYKJrqNGOzJCpbl2/49BmsMw9VlwPXX8mqM70jFX7kIKScTYEc1qm6040Oa3idZkwIxXQX/m5R5TlZlDe4vwzd/Db7FpvD3hbbr7dq9Z/vfvP7H5h6/pOXYi5916Nxo7DSnd2gkhmHLTnegNTiz/4C2EtDRpP227KAR0Z4FpKoz4PwAy96WhNVfi37czCZvWkulTwdhe6ttjmxY2hE9M06HfmT3Rk7YdxVIZR75nKbP6qYl02qwuE3nLdAF0nVTn4v2rDmHEQJrrBuZOfIGhIUNrlu36YxEbvllA7MixnHfb3QhN2/5Iay43bx8mXHczaYf207eoaZ3K2/Yr6BPJ06brQGdtm5yTXIB7SQrlAb5UZeaRGQGxvrGOjVFpnsAePGe65owbjxWlRrLSE5CYOD7IlX4BTWtpobQCYYN5w3RJvYu3LNqDa2k6IddMZHrn6TWPx69dyerPP6LL4OFMv+O+DnuGcLoeYybQd9I08vXeTdq+bReF0xQUgltFFkdOHEUiCRnQF41oV09RqXZ8Xy7myj3oLZIxI+eovgnt1Jd/fk2VJRAPTTyXT7qr5vFDWzay4sO3iew7gPPveViNfFyLEIIpN9/JcddGzFlRS7v5xKwsM1Jl0eHhDgmb15LhV8nQrup+QnuVsHoT0pJHoVsu50ef7+hwFDtYfXw1Kb8lozFXMuHGWTWFP3n3Dpa8/SohMbHMvv/xDtXKqCW0m6JQlFMBgN5PQ0lmFkdDShkeMtzBUSn2IKXkRMIGNFJP5dBwOrl3cnRIio0l5CTw5Oqn8DYOJKTiML5jrEM2pB7Yx++vvYBfWDgXPPJUh+iH0NLazTlXfnIOABUuZQDIKF/1YdFOpew/gbHyCH4VLnSedJmjw1FsLK0kjTtX38mEw0ORGif6TIhACEFWchK/vvRfPPz8ufjxZ3F2s91sY8o/2s2ZQt6RTAAKqvIpdjMzoKs6S2ivdi77A5CgyWJKtBr8rj0prirmjlV3UGmsJCZnJB5laURdcR75GWn8/MJc9C4uXPzEs7h6eTs61Har3RSFwrRCdJUFpGemkupXxrAQNUx2eyQtFo7t3YBWE4LoG4ib3s3RISk2YrQYeWDdAyQXJvOs3xOUCB9iosyUl5fx03NPIi0WLn782VY5l3J70m6KQlFuJbryw5iNRtL8yxkSPMTRISl2cGJfPMaKfLyrvOgxRfVNaD8kL259kc1pm5k7Yi4Vq0rQmiuJvWIEv7z4FOXFRVz46H/xCw0/966UZmk3RaG4XAukIQG36FB8nH0cHZJiB7uW/wHCCd/SYgaNvNDR4Sg2ovfdwI+HfuTG3jcy3W8Sxws8CdGn8ucPn5GbmsK/7n+M4C4xjg6zQ7BrURBCTBNCHBRCJAohHjnLekOEEGYhRJO++plNFsotzlRpcsnzMjIwUl06aiktlWOAyrIyknb+hVYfiyGgAq223bSTaNXsneNVx1fhFLiMqZFTuWvgXcR9vhqzRk+Fx2FS9sUz7fZ7iOo7oPlPRGkQuxUFIYQWeA+YDvQErhBC9KxnvZewTgzeJEU55UhMlJsLSfMrU5eOWkhL5hjg0NaNWExG9LquRI9QPZhbQkvkuKCiAHN5BM+Pfh6B4GB8KZrSFaQkJzD26hvoMXp8M5+F0hj2PFMYCiRKKZOklFXAd8DsOtb7P+BnIKupB8o/mo00ZSKRZPlUMTho8Lk3UmyhxXIMsG/9GtB64F1aRvgYNaZVC7F7ji/qdhHlx27BWefMiUUbyCWLcmMC/abOZPD5atj7lmbPohAKnKj1/5Tqx2oIIUKBC4APm3OgvMPpWEypAHhFh58y6YZiVy2W46LsLFL2xaHV98ar7DjOPbqfeyPFFloox9aPoi2/rsNUtpqI3gOYeN3NavgSB7BnUagrm/K0/78JPCylNJ91R0LcLITYLoTYnp2dfcbywtQCLKYTlLgY6R+hLh21oBbL8b4NawDQGnoSGKRDqLFuWkqL5fjE2nWcKNuFweDD7Ace7ZBzIrQG9vzLSgFqtx8LA9JOW2cw8F31twF/YIYQwiSl/K32SlLK+cB8gMGDB5/+hqQotxRpSictuIJLg9WloxbUMjmWkoT1qyh3dcNZ40HYgGibPgnlrFokx87mChbOXwBCx5Qb7sfg4oriGPYsCtuAGCFEZyAVuBy4svYKUsrOJ38XQiwAFp/+RmqIoqICJEYy/CoZFDioWUErjdIiOfavyqEgPQ2dR0/cyjLxHq5y3ILsnmOzycisjCVUmCvx9JpN7Pi+NglcaRq7FQUppUkIcSfW1gha4DMpZYIQ4tbq5c26xlxbSaX1VNQ1KgRvNfVmi2mpHMeWHEZqwF0Mwas0EZfe9Y+9r9hWS+R4wzdfEFyVhd5tOv0mDFL3ERzMrhdmpZRLgaWnPVbnm0hKeV1TjqGRUGXOAXT0iVaXjlqavXNssZjpVnqIDF8Tnc1++PscQhgMTQtWaRJ757jvuMkk/bKdCp9Yes3o0bQgFZtp8z2avU0mpDkTi07HIHU/od1J2ZeAu7mc8ur5mUN6BTk4IsXWzBs2Y/KdTnikATcvNc+2o7X5JhydS3ORlgJK3XQMClLXmtubguwMSp0sdGUIWlM5IaPV9eb2JqPSD6NBT++Z6iyhNWjzZwqR5dYhs6uC9Pi7+Ds4GsXWirq58tPEE3iXheNZcgKXfqonc3tTGRJLgcZCZG/199satPmi4Gu03mT27t/FwZEo9lBqLEWWh1Nu8sLPtQKNk7q80N4MnhHFZx6VaDTqBnNr0OaLgrMlD6HxoWf/UY4ORbGD86LOI+DATUihJbCLGvm2vTKretBqtOmiIKVEyCJ0wpvBnVRP5vaqb0khAKEjYh0ciaK0f226KBTnZANVaDVuBLsFOzocxU4iqiwYqgrxUyOjKordtemikJZ4AAAng5qSsT1z03rgoylE6+Li6FAUpd1r001SK331GFxn4OF3xnBISjtRlpWPydmPgACTo0NRlA6hTReFjKNH0Dh1J7hTvqNDUewkdc0eAEL6Rzg4EkXpGNr05aNuZdbBG4M6hzk4EsVeslJKAAgb18fBkShKx9Cmi0KFxnovwScm9BxrKm3ViHtm8Jl7Ga7+no4ORVE6hDZdFKIm9eVHt0p8Y0IcHYpiJxqthlydasSuKC2lTRcFFw8DyXoLeoOaoUlRFMUW2nRRUBRFUWxLFQVFURSlhioKiqIoSg1VFBRFUZQaqigoiqIoNexaFIQQ04QQB4UQiUKIR+pYfpUQYm/1z2YhhBrxrI1ROW7/VI47FrsVBSGEFngPmA70BK4QQvQ8bbWjwDgpZV/gWWC+veJRbE/luP1TOe547HmmMBRIlFImSSmrgO+A2bVXkFJullKeHLhoC6DGq2hbVI7bP5XjDsaeRSEUOFHr/ynVj9XnRmBZXQuEEDcLIbYLIbZnZ2fbMESlmVSO2z+V4w7GnkWhrrEJ6hzjWggxAeub6eG6lksp50spB0spBwcEBNgwRKWZVI7bP5XjDsaeQ2enAOG1/h8GpJ2+khCiL/AJMF1KmWvHeBTbUzlu/1SOOxh7nilsA2KEEJ2FEAbgcmBh7RWEEBHAL8A1UspDdoxFsQ+V4/ZP5biDsduZgpTSJIS4E1gOaIHPpJQJQohbq5d/CMwF/ID3hRAAJinlYHvFpNiWynH7p3Lc8dh15jUp5VJg6WmPfVjr9/8A/7FnDIp9qRy3fyrHHYvq0awoiqLUUEVBURRFqaGKgqIoilJDFQVFURSlhioKiqIoSg1VFBRFUZQaqigoiqIoNVRRUBRFUWqooqAoiqLUUEVBURRFqaGKgqIoilJDFQVFURSlhioKiqIoSg1VFBRFUZQaqigoiqIoNVRRUBRFUWqooqAoiqLUUEVBURRFqaGKgqIoilLDrkVBCDFNCHFQCJEohHikjuVCCPF29fK9QoiB9oxHsT2V4/ZP5bhjsVtREEJogfeA6UBP4AohRM/TVpsOxFT/3Ax8YK94FNtTOW7/VI47HnueKQwFEqWUSVLKKuA7YPZp68wGvpRWWwBvIUSIHWNSbEvluP1TOe5gdHbcdyhwotb/U4BhDVgnFEivvZIQ4mas30AASoQQB2st9hcvkWOTiO3PH9pErKe/ppH1rKdyfCaVY5Xj1qKhOT6FPYuCqOMx2YR1kFLOB+bXeRAhtkspBzc+vJbXVmJtRJwqx6dpK7GqHDddW4m1qXHa8/JRChBe6/9hQFoT1lFaL5Xj9k/luIOxZ1HYBsQIIToLIQzA5cDC09ZZCPy7uvXCcKBQSpl++o6UVkvluP1TOe5g7Hb5SEppEkLcCSwHtMBnUsoEIcSt1cs/BJYCM4BEoAy4vgmHqvN0tJVqK7E2KE6V4zq1lVhVjpuurcTapDiFlGdc+lMURVE6KNWjWVEURamhioKiKIpSo80UhbbS1b4BcY4XQhQKIXZX/8x1UJyfCSGyhBDx9Sxv8ddT5djmcaoc2y/O9ptjKWWr/8F6g+sIEA0YgD1Az9PWmQEsw9pmejiwtZXGOR5Y3Ape07HAQCC+nuUt+nqqHKscqxy3jhy3lTOFttLVviFxtgpSyvVA3llWaenXU+XYxlSO7Rpnq2CPHLeVolBfN/rGrmNvDY1hhBBijxBimRCiV8uE1mgt/XqqHLc8leO6degc23OYC1uyWVd7O2tIDDuBSClliRBiBvAb1tElW5uWfj1VjlueynHdOnSO28qZQlvpan/OGKSURVLKkurflwJ6IYR/y4XYYC39eqoctzyV47p16By3laLQVrranzNOIUSwEEJU/z4Uaw5yWzjOhmjp11PluOWpHDcxzvac4zZx+Ui2XFf7lojzYuA2IYQJKAcul9XNBFqSEOJbrC0o/IUQKcBTgL5WnC36eqoc257KsV3jbLc5VsNcKIqiKDXayuUjRVEUpQWooqAoiqLUUEVBURRFqaGKgqIoilJDFQVFURSlRpstCkKIx4UQCdUj/+0WQgyz8f43V/8bJYS4stbjg4UQb9vyWKcd9/Tj9a/uMVnf+jXxCCGeFkI80Mjj3SOEcG16xPah8ntmPO0pv6ByXFc8rSHHbbIoCCFGAOcDA6WUfYHJnDq+R7NJKUdW/xoFXFnr8e1SyrtseazTnHI8oD/WdsZnEELobBDPPUCr+tBQ+bVqr/kFleOTWmWOzzWMamv8AS4EFtWzbBCwDtiBtfNJSPXja4GXgL+BQ8CY6sd7VT+2G9gLxFQ/XlL97xagsHr5vVQPmYu1oCYD3rWOnQgEAQHAz1h7Rm4DRtURZxSwAesYKjuBkXUc72HgOJBd/f/LgKexzr26AviGWkP4Vi/7ClgNHAZuknUM8wu8C1wH3AVUAXHAmuplU4G/qmP6EXBX+VX5VTnuODl2+Ad8E99Q7tUv8CHgfWBc9eN6YDMQUP3/y7D2Rjz5hnqt+vcZwMrq398Brqr+3QC4nPaGOj0ZtRP4FnB99e/Dau3zG2B09e8RwP46noMr4Fz9ewywvZ7jXQe8W+v/T2P9Y3GpI56nsY797gL4Y/3m1am+N1T178mAf/Xv/sB6wK36/w8Dc1V+VX5VjjtOjtvEMBenk9aRCQcBY4AJwPfCOjvSdqA38Gf1sCRaoPY4H79U/7sDa5UHa0V9XAgRBvwipTzciFC+B+YCn2MdH+X76scnAz2rYwDwFEJ4SCmLa22rB94VQvQHzEC3Rhx3oZSyvJ5lv1cvKxdCrME6NnxBA/c7HOgJbKqO3YD19WlRKr/tO7+gckwrznGbLAoAUkoz1m8Oa4UQccC1WN8oCVLKEfVsVln9r5nq5y6l/EYIsRWYCSwXQvxHSrm6gWH8BXQVQgQAc4Dnqh/XACPOknSwnsZmAv2q169o4DEBSs+y7PRxSyRg4tT7R871bCuAP6WUVzQiFrtQ+a1Xu8gvqByfZZlDc9xWbzTHCiFqj13eHzgGHAQCqm9iIYTQi3NMfiGEiAaSpJRvYx1RsO9pqxQDHnVtK63nZ78Cr2M9vTw5SuIK4M5ax+hfx+ZeQLqU0gJcg/UbUV3Hq/f49ZgthHAWQvhhPeXchvW16SmEcBJCeAGT6tn/FmCUEKJrddyuQojGfPuxCZXfs2rz+a0+tspx/Rya4zZZFLBej/xCCLFPCLEX6+nS09I6dd7FwEtCiD1Yr1mOrH83gPWaZbwQYjfQHfjytOV7AZOwzrB0bx3bfw9czT+nnWC9+TO4uqndPuDWOrZ7H7hWCLEF62nnyW8Opx9vDdY3w24hxGXneC5gveG2BOub41kpZZqU8gTwQ/W+vwZ21Vp/PrBMCLFGSpmN9frnt9Wv65bq16SlqfzWrz3kF1SOz8ahOVajpCqKoig12uqZgqIoimIHqigoiqIoNVRRUBRFUWqooqAoiqLUUEVBURRFqaGKgqIoilJDFQVFURSlxv8DifY01N7XlRkAAAAASUVORK5CYII=",
      "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": 13,
   "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": 14,
   "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": 15,
   "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": 16,
   "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": 20,
   "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": "iVBORw0KGgoAAAANSUhEUgAAAXoAAAEPCAYAAABMTw/iAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAAA5zklEQVR4nO3dZ3gc1fn38e+9TbvqkiVLtop7wQ0X4W4QLZhqeodQgjGJKemkkPB/QkIqCR0MmBp6SDDGQAiguHdcMG5yl5ss25Isafue58UuRMiyvbIlrbS6P1x7STNzZuZeefhpdGZ2jhhjUEopFb8ssS5AKaVUy9KgV0qpOKdBr5RScU6DXiml4pwGvVJKxTkNeqWUinO2WBfQmKysLNO9e/dYl9EktbW1JCUlxboMpZpMj934sGzZsgpjTHZjy9pk0Hfv3p2lS5fGuowmKSkpobi4ONZlKNVkeuzGBxHZdqRl2nWjlFJxToNeKaXinAa9UkrFOQ16pZSKcxr0SikV5zTolVIqzsVV0P/ny73sr/HGugyllGpT4iboD9b6uOeNFVz59AJ2V7ljXY5SSrUZcRP0GUkOpt90CnurvVz+5AK27a+NdUlKKdUmxE3QA4zskcmrt42izhfgiqcWsH7PoViXpJRSMRdXQQ8wJD+dN28fA8BV0xawckdlbAtSSqkYi7ugB+iTk8LbU8aS4rRx3bOLWLh5f6xLUkqpmInLoAco7JTIW7ePJTfNybenL+azdeWxLkkppWIiboMeIDfNyZu3j6FPTjK3vbSUmat2xbokpZRqdXEd9ACZSQ5evW00wwrTueu1z3lz6Y5Yl6SUUq0q7oMeINVp56VbRjG+TzY/eXsVLy/YGuuSlFKq1XSIoAdwOaw8c+MIzh6Qw33vrmHa7E2xLkkppVpFVEEvIhNFZL2IlIrIvY0s7y8iC0TEKyI/arAsXUTeFpF1IrJWRMY0V/FNlWCz8sR1w7lgSBd+N2sdD/9nI8aYWJWjlFKt4phDCYqIFXgcOBsoA5aIyAxjzJf1mh0A7gIubmQTDwMfGmMuFxEHkHjCVZ8Au9XCw1cPw2m38tf/bMDtD/LTif0QkViWpZRSLSaaMWNHAqXGmM0AIvI6MAn4OuiNMeVAuYicX39FEUkFTgVuirTzAb5mqfwEWC3CHy8bgtNu4an/bsLjD/KrCwZgsWjYK6XiTzRBnwfUv1WlDBgV5fZ7AvuA50XkZGAZcLcxJuYPorFYhN9MGoTLbuWZOVvw+IP89pLBWDXslVJxJpqgbyz5ou3YtgHDgTuNMYtE5GHgXuC+w3YiMhmYDJCTk0NJSUmUuzgxYxMN5b3svL5kB1t27OK6AQmkOpoe9jU1Na1Ws1LNSY/d+BdN0JcBBfWm84FoP3lUBpQZYxZFpt8mHPSHMcZMA6YBFBUVmeLi4ih3ceJOPx36l2ziDx+uY0WFh0uG5XHL+B70zUmJehslJSW0Zs1KNRc9duNfNEG/BOgjIj2AncDVwLXRbNwYs0dEdohIP2PMeuBM6vXttyV3FPfi7AGdeW7uVt5ZXsbrS3YwoU8Wt47vwWl9s/VirVKq3Tpm0BtjAiIyFfgIsALTjTFrRGRKZPlTIpILLAVSgZCI3AMMMMZUA3cCf4/ccbMZuLll3sqJ6905hQcvHcyPz+nHq4u28dKCbdz0/BJ6d07m5nHduXRYPi6HNdZlKqVUk0hbvI+8qKjILF26NNZl4AuEmLlqF8/N3cKaXdWkOm1cPCyPK0YUMCgv9Rtn+frnr2qv9NiNDyKyzBhT1NiyaLpuOiyHzcKlw/O5ZFgei7Yc4NVF23l9yQ5eWrCN/rkpXFlUwMXD8shMcsS6VKWUOiIN+iiICKN7dmJ0z05U1fmZsWoXby3dwf+b+SUPfrCWs07KoX9CgPHBEDZrh3mqhFKqndCgb6K0RDs3jO7GDaO7sW5PNW8tLeOfn+/kg1of8/Yv4pXvjMJh07BXSrUdmkgnoH9uKvddMICFPzuTGwY4WLz1AL+btTbWZSml1DfoGX0zcNgsnFlox5bRlefnbWVEtwwuPLlrrMtSSilAz+ib1c/OPYkR3TK49x+rKC2viXU5SikFaNA3K4fNwuPXDsdpt3LHK8uo9QZiXZJSSmnQN7fcNCePXDOMTftq+Pk/V+vz7pVSMadB3wLG9c7iB2f35d0Vu3hl4bZYl6OU6uA06FvId4t7c0b/zvy/mV+yYkdlrMtRSnVgGvQtxGIRHrryZHJSnXz3lWUcqI35eCtKqQ5Kg74FpSc6eOK64VTU+LjnjRUEQ9pfr5RqfRr0LWxIfjq/vmgAszfs46qnF/DM7M2Ulh/Si7RKqVajH5hqBdeOLKTOG+TtZWX8dtZafjtrLQWZLk7v15nT+3dmTM9OOO36+GOlVMvQoG8FIsJtp/bktlN7srPSzWfryilZX85bS8t4acE2nHYL43pl8ZOJ/emXG/2oVkopFQ0N+laWl+7i+tHduH50Nzz+IIu2HOCzdeW8t3IXlz85n6duGMG43lmxLlMpFUei6qMXkYkisl5ESkXksDFfRaS/iCwQEa+I/KiR5VYR+VxEZjZH0fHCabdyWt9s7r9oIO/dOZ6u6S6+PX0xby3dEevSlFJx5JhBLyJW4HHgXGAAcI2IDGjQ7ABwF/DnI2zmbkAf63gUXdNdvHXHGEb37MSP317FQx9v0Au2SqlmEc0Z/Uig1Biz2RjjA14HJtVvYIwpN8YsAfwNVxaRfOB84NlmqDeupTrtPH/zKVw+Ip9HPtnID99aiS8QinVZSql2Lpo++jygfl9CGTCqCfv4G/AT4KhXGUVkMjAZICcnh5KSkibsIvZqamqarebzswzB3nbeWb6TtVt3M3WYkyS7HHtFpY5Dcx67qm2KJugbS5io+hRE5AKg3BizTESKj9bWGDMNmAbhwcHb22DFzT3A8umnw4TlZfz0H6v422oLz998CvkZic22faW+ooODx79oum7KgIJ60/nArii3Pw64SES2Eu7yOUNEXmlShR3YpcPzefHmkeyp9nDx4/OZuWqX9tsrpZosmqBfAvQRkR4i4gCuBmZEs3FjzM+MMfnGmO6R9T41xlx/3NV2QGN7Z/GPO8aSnZLA1Fc/59pnFrF+z6FYl6WUakeOGfTGmAAwFfiI8J0zbxpj1ojIFBGZAiAiuSJSBvwA+KWIlIlIaksW3pH0zUlh5p3j+c3Fg1i7p5rzHpnD/TPWUOU+7Nq3UkodJqoPTBljZgGzGsx7qt73ewh36RxtGyVASZMrVABYLcINo7txweAu/OXj9by0YCszVu7iJ+f048qiAiwWvVirlGqcPtSsnclIcvDAxYOZMXU8vbKTuPed1Vz8xDx95r1S6og06NupQXlpvHn7GB6+eih7qz1c+fQCNu/TAcmVUofToG/HRIRJQ/N4b+p4nDaLjlGrlGqUBn0c6Jzq5GfnncTCzQd4a2lZrMtRSrUxGvRx4qqiAkZ2z+S3s9ay75A31uUopdoQDfo4YbEIv7t0MG5fkN/M/DLW5Sil2hAN+jjSu3My3zu9NzNW7uKz9eWxLkcp1UZo0MeZKcU96d05mV/+8wtqvYFYl6OUagM06ONMgs3Kg5cOZmelm79+vCHW5Sil2gAN+jh0SvdMrhtVyPR5W1hdVhXrcpRSMaZBH6d+MrE/WckJ3PvOKgJBHbxEqY5Mgz5Opbns/N9FA1mzq5rp87bEuhylVAxp0MexiYNyOXtADg99vIEdB+piXY5SKkY06OOYiPD/Jg3EKsLV0xby2/e/ZMGm/fi1K0epDiWqxxSr9qtLmounbhjBtNmbeXH+Np6Zs4UUp41T+2Rzev/OFPfLJis5IdZlKqVaUFRBLyITgYcBK/CsMeb3DZb3B54HhgO/MMb8OTK/AHgJyAVCwDRjzMPNV76KxoQ+2Uzok02tN8Dc0go+XVvOZ+vLeX/1bkRgSH46d57em7MG5MS6VKVUCzhm0IuIFXgcOJvw+LFLRGSGMab+5+wPAHcBFzdYPQD80BizXERSgGUi8nGDdVUrSUqwcc7AXM4ZmIsxhjW7qvl0XTkzVu5i8stL+e0lg7lmZGGsy1RKNbNo+uhHAqXGmM3GGB/hQb4n1W9gjCk3xiwB/A3m7zbGLI98f4jwUIR5zVK5OiEiwqC8NO46sw8zpo7j1L7Z/Oyd1TxRUqqPOlYqzkQT9HnAjnrTZRxHWItId2AYsKip66qWleiw8cyNRUwa2pU/frie376/llBIw16peBFNH31jg5E2KQVEJBn4B3CPMab6CG0mA5MBcnJyKCkpacouYq6mpqbd1dzQpBxDbaGNZ+duYe3mHdw8yIFNx6KNe/Fw7Kqjiyboy4CCetP5wK5odyAidsIh/3djzDtHameMmQZMAygqKjLFxcXR7qJNKCkpob3V3JjTiw2PflrKQx9vwJmayePXDcdpt8a6LNWC4uXYVUcWTdfNEqCPiPQQEQdwNTAjmo2LiADPAWuNMQ8df5mqtYgId53Zh99cPIhP15dz43OLqXL7j72iUqrNOmbQG2MCwFTgI8IXU980xqwRkSkiMgVARHJFpAz4AfBLESkTkVRgHHADcIaIrIi8zmuxd6OazQ2ju/HoNcP4fMdBrp62UEetUqodi+o+emPMLGBWg3lP1ft+D+EunYbm0ngfv2oHLhjSlTSXnckvLeO6Zxfy2m2j6aQfrlKq3dFHIKijmtAnm+k3ncL2A3Vc/9xiKut8sS5JKdVEGvTqmMb06sQzNxaxaV8NN2ifvVLtjga9isqEPtk8ff0I1u2p5qbnF3PIo2GvVHuhQa+idnr/zjx+7XBWl1VxywtLdExapdoJDXrVJN8amMvDVw9j2baDfOfFpbh9wViXpJQ6Bg161WTnD+nCX68aysIt+5n88lI8fg17pdoyDXp1XCYNzeOPlw1hzsYK7nhlmYa9Um2YBr06blcUFfC7Swbz2fp9XPOMfqhKqbZKg16dkGtHFfLkdcNZu7uaix+fx/o9h2JdklKqAQ16dcLOHdyFN28fgy8Y4rIn51OyvjzWJSml6tGgV81iSH46735vHIWZidzywhJenL811iUppSI06FWz6Zru4q0pYzijf2d+PWMNv3r3CwLBUKzLUqrD06BXzSopwcbTNxRx24QevLRgG7e+uJRq/RStUjGlQa+andUi/OL8ATx46WDmlVZw6RPz9SKtUjGkQa9azDUjC3nplpFU1vm48LG5vDh/qw48rlQMaNCrFjW2dxYf3H0qY3t14tcz1vCdF5eyv0bvt1eqNUUV9CIyUUTWi0ipiNzbyPL+IrJARLwi8qOmrKviX3ZKAs/fdAr3XziAOaUVTHx4DrM37It1WUp1GMcMehGxAo8D5wIDgGtEZECDZgeAu4A/H8e6qgMQEW4a14N3vzeOdJedG6cv5oGZX+IN6KMTlGpp0ZzRjwRKjTGbjTE+4HVgUv0GxphyY8wSoOHtFcdcV3UsJ3VJ5b07x3PjmG48O3cLlzw+n9LymliXpVRci2bM2DxgR73pMmBUlNuPel0RmQxMBsjJyaGkpCTKXbQNNTU17a7mWDojDTKGJzB9dTWTHv0vPx/pIi9FLxnFgh678S+aoG9scO9ob52Iel1jzDRgGkBRUZEpLi6OchdtQ0lJCe2t5lgrBi47s47Ln5rPI6tDvD1lNAWZibEuq8PRYzf+RXMKVQYU1JvOB3ZFuf0TWVd1AIWdEnn51lF4/CGue3YR5dWeWJekVNyJJuiXAH1EpIeIOICrgRlRbv9E1lUdRL/cFF64+RQqarzc8NxiKut8sS5JqbhyzKA3xgSAqcBHwFrgTWPMGhGZIiJTAEQkV0TKgB8AvxSRMhFJPdK6LfVmVPs1rDCDZ24sYktFLTc9r+PRKtWcoumjxxgzC5jVYN5T9b7fQ7hbJqp1lWrMuN5ZPHrtML779+Xc/vIynrupiASbNdZlKdXu6W0Oqk05Z2Auf7xsCHNLK7j7tRX69EulmoEGvWpzLhuRz68vHMCHa/bws3dWEwrp83GUOhFRdd0o1dpuHteDKrefv/1nI75giP+7aCDpiY5Yl6VUu6RBr9qsu8/sg1WEv32ykfmb9vPAxYM4Z2BurMtSqt3RrhvVZokId57Zh3e/N47s5ARuf3kZU19drk+/VKqJNOhVmzcoL413p47jh2f35aM1ezj7r7OZsXKXPtteqShp0Kt2wW61cOeZfXj/rgkUZLi467XPmfzyMv0krVJR0KBX7UrfnBT+ccdYfn5ef2Zv2MdZD/2Xf32+U8/ulToKDXrV7tisFiaf2osP7p5An5wU7nljBXe9voKqOh2EXKnGaNCrdqtndjJvTB7Nj77Vlw9W72biw7OZX1oR67KUanM06FW7ZrNamHpGH/5xx1hcdivXPruI376vI1cpVZ8GvYoLJxekM/Ou8Vw3qpBn5mxh0mPzWL/nUKzLUqpN0KBXcSPRYeO3lwxm+k1FVNR4ufCxuTw3d4teqFUdnga9ijtn9M/hw3tO5dQ+Wfxm5pf8btZaDXvVoWnQq7iUlZzAMzcWceOYbjwzZwsPf7Ix1iUpFTP6rBsVt0SE+y8cSJ0vyN/+s5Ekh43bTu0Z67KUanVRndGLyEQRWS8ipSJybyPLRUQeiSxfJSLD6y37voisEZEvROQ1EXE25xtQ6mgsFuEPlw3h/CFd+O2stbyycFusS1Kq1R0z6EXECjwOnAsMAK4RkQENmp0L9Im8JgNPRtbNA+4CiowxgwAr4XFjlWo1Vovw1yuHcmb/ztz37he8s7ws1iUp1aqiOaMfCZQaYzYbY3zA68CkBm0mAS+ZsIVAuoh0iSyzAS4RsQGJwK5mql2pqDlsFh6/bjhjenbiR2+t5IPVu2NdklKtJpo++jxgR73pMmBUFG3yjDFLReTPwHbADfzbGPPvxnYiIpMJ/zVATk4OJSUlUb2BtqKmpqbd1dwR3djDUL7fwtRXl3P38ASGZOtlKj124180R7k0Mq/hvWqNthGRDMJn+z2ASuAtEbneGPPKYY2NmQZMAygqKjLFxcVRlNZ2lJSU0N5q7qjGjPNz3bMLeXxlDS/cPIwxvTrFuqSY0mM3/kXTdVMGFNSbzufw7pcjtTkL2GKM2WeM8QPvAGOPv1ylTlyay85Lt4yiMDORG55bxB2vLGPOxn06Nq2KW9EE/RKgj4j0EBEH4YupMxq0mQHcGLn7ZjRQZYzZTbjLZrSIJIqIAGcCa5uxfqWOS2aSg9cmj+amsd1ZsHk/Nzy3mNP/UsKTJZuo0BGsVJw5ZteNMSYgIlOBjwjfNTPdGLNGRKZElj8FzALOA0qBOuDmyLJFIvI2sBwIAJ8T6Z5RKtaykhP45QUD+NE5/fhozR7+vmg7f/hwHQ99vJ5vDczlupGFjO7ZCYulsZ5JpdqPqK5EGWNmEQ7z+vOeqve9Ab53hHV/Dfz6BGpUqkU57VYmDc1j0tA8SssP8eqiHfxjeRnvr9rNgC6p/PHyIQzKS4t1mUodN30EglL19O6cwq8uHMCin5/Jn684mYoaL5Men8efP1qvjz5W7ZYGvVKNcNqtXD4in4+/fxoXD83jsc9KueCRuazYURnr0pRqMg16pY4iLdHOX648medvPoUab4BLn5jHg7PW4vHr2b1qPzTolYrC6f0689H3T+WqUwp4evZmznt4Dku3Hoh1WUpFRYNeqSilOu08eOkQXrl1FN5AiCueXsBf/r1e779XbZ4GvVJNNL5PFv/+/qlcMSKfRz8t5Z43VuiFWtWm6YM+lDoOSQk2/nDZEHpmJ/P7D9axp8rD0zeMICPJEevSlDqMntErdZxEhCmn9eLRa4axoqySy56cz7b9tbEuS6nDaNArdYIuPLkrf//OKA7U+bjkifks334w1iUp9Q0a9Eo1g1O6Z/LP744jxWnjmmkL9Xn3qk3RoFeqmfTISuKdO8YysGsq3311Oc/M3kz46SBKxZYGvVLNqFNyAq/eNprzBoXHqH3wg3Ua9irm9K4bpZqZ027l0WuG0SnZwbTZmwmGDL88/yTCT+pWqvVp0CvVAiwW4f8uGohFhOfmbiFkDL+6YICGvYoJDXqlWoiI8OsLB2ARYfq8LYRChvsvGqhhr1pdVH30IjJRRNaLSKmI3NvIchGRRyLLV4nI8HrL0kXkbRFZJyJrRWRMc74BpdoyEeG+C07itgk9eHHBNu579wt9ZIJqdcc8oxcRK/A4cDbhsWGXiMgMY8yX9ZqdC/SJvEYBT0a+AjwMfGiMuTwyFGFiM9avVJsnIvz8vJOwWISn/7uZkIEHJg3SkatUq4mm62YkUGqM2QwgIq8Dk4D6QT8JeCky0tTCyFl8F6AWOBW4CcAY4wN8zVe+Uu2DiHDvxP5YRXiiZBOhkOF3lwzWsFetIpqgzwN21Jsu439n60drk0d4nNh9wPMicjKwDLjbGKOfE1cdjojw43P6YbUIj35aGrkbZwBpifZYl6biXDRB39gpR8NOxiO1sQHDgTsjA4U/DNwL3HfYTkQmA5MBcnJyKCkpiaK0tqOmpqbd1axiY7jdMKmXnbeWlfHO8jJOyrQyIsfKsBwr6Qmt/9EWPXbjXzRBXwYU1JvOB3ZF2cYAZcaYRZH5bxMO+sMYY6YB0wCKiopMcXFxFKW1HSUlJbS3mlXsnH463FpWyazVe/jwi928+GUdL62Fom4ZnDMwl3MG5lKQ2TqXs/TYjX/RBP0SoI+I9AB2AlcD1zZoMwOYGum/HwVUGWN2A4jIDhHpZ4xZD5zJN/v2leqwhuSnMyQ/nZ9O7MeGvTV8+MUePlyzhwfeX8sD76/llO4ZPH7tcDqnOmNdqmrnjhn0xpiAiEwFPgKswHRjzBoRmRJZ/hQwCzgPKAXqgJvrbeJO4O+RO242N1imVIcnIvTLTaFfbgp3n9WHbftr+eCLPTz6yUaumraQV28bRZc0V6zLVO1YVB+YMsbMIhzm9ec9Ve97A3zvCOuuAIqOv0SlOpZunZKYclovTumeyU3TF3Pl0wt49TujW60rR8UffaiZUm3UiG4ZvPKdUVTV+bnq6QVsrdCb1dTx0aBXqg07uSCd1yaPxu0PctW0BZSW18S6JNUOadAr1cYN7JrG65PHEAwZrp62kPV7DsW6JNXOaNAr1Q70y03h9cljsAhcPW0Ba3ZVxbok1Y5o0CvVTvTunMybt4/BZbdyzbSFLNt2INYlqXZCg16pdqR7VhJv3D6GVJedy55cwKTH5vL8vC1U1HhjXZpqwzTolWpnCjITmTF1PL847yT8QcP/vfclo373CTc9v5h3V+ykzheIdYmqjdGBR5RqhzKTHNx2ak9uO7Un6/cc4l8rdvLu5zu5+/UVJDqsTByYyy3jezAoLy3Wpao2QINeqXauX24KP53Ynx9/qx9Lth7gXyt2MnPVbt5btYufTuzPreN76KhWHZx23SgVJywWYVTPTjx46RDm/OR0ivt15oH313LbS0s5WKvDQHRkGvRKxaH0RAfTbhjB/RcOYPaGCs57ZA5LtupdOh2VBr1ScUpEuGlcD9757lgSbBaunraQxz7dSFDHrO1wNOiVinOD8tJ4787xnD+4C3/+9wa+PX0x5Yc8sS5LtSINeqU6gBSnnYevHsofLhvM0m0HOO/hOczdWBHrslQr0aBXqoMQEa46pZAZU8eTkejghumL+OvHGwgZ7cqJdxr0SnUwfXNSeHfqOC4dls/Dn2zkT0s82pUT56IKehGZKCLrRaRURA4b81XCHoksXyUiwxsst4rI5yIys7kKV0odv0SHjb9ceTJ/vHwIpZUhzn9kLvM3aVdOvDpm0IuIFXgcOBcYAFwjIgMaNDsX6BN5TQaebLD8bmDtCVerlGpWVxYV8KsxLlKcNq5/dhGPfrKRkN6VE3eiOaMfCZQaYzYbY3zA68CkBm0mAS+ZsIVAuoh0ARCRfOB84NlmrFsp1UwKUiy8N3U8F57clb98vIFvP7+Y/fqQtLgSzSMQ8oAd9abLgFFRtMkDdgN/A34CpBxtJyIymfBfA+Tk5FBSUhJFaW1HTU1Nu6tZKQgfu0sWzOXiHEPGQAevrK3gzD99wvg8G0M7W+mZZsGij1Bo16IJ+sb+hRv+bddoGxG5ACg3xiwTkeKj7cQYMw2YBlBUVGSKi4/avM0pKSmhvdWsFHzz2D0duGJXFQ/MXMsHWw8wc7OfrGQHp/frzJkn5TChTxZJCfqIrPYmmn+xMqCg3nQ+sCvKNpcDF4nIeYATSBWRV4wx1x9/yUqpljSwaxqvTR5NZZ2P/27Yx3/WlvPhmj28tawMh9XC6F6dOG9QLpePyMdm1Rv32oNogn4J0EdEegA7gauBaxu0mQFMFZHXCXfrVBljdgM/i7yInNH/SENeqfYhPdHBpKF5TBqahz8YYunWg3yydi+frCvn3ndW88qibfzhsiEM7KqPQm7rjvnr2BgTAKYCHxG+c+ZNY8waEZkiIlMizWYBm4FS4Bnguy1Ur1IqBuxWC2N6deKXFwzg0x+exhPXDWdPlZeLHpvHHz9ch8cfjHWJ6iii6mwzxswiHOb15z1V73sDfO8Y2ygBSppcoVKqTRERzhvchbG9OvHA+2t5omQTH36xh99fNoSRPTJjXZ5qhHawKaWOS3qigz9fcTIv3zoSXzDElU8v4Bf/XM0hjz/WpakGNOiVUidkQp9s/v39U7l1fA9eXbydsx+azWfry2NdlqpHg14pdcISHTbuu2AA79wxllSXjVteWMKL87fGuiwVoUGvlGo2wwozePd74znrpBx+PWMND36wVh+p0AZo0CulmpXLYeWp60dw/ehCnv7vZn7w5gp8gVCsy+rQ9CNuSqlmZ7UIv5k0iC5pLv700Xoqanw8ef1wUpz2I66zfX8dz8zZzNvLyhhWmM6vLhxA/9zUVqw6fukZvVKqRYgI3zu9N3+6fAgLN+/nyqcXsrf68Ofef7GziqmvLqf4z5/xxpIdnHFSZ77cXc15D8/hvn99wYFaXwyqjy96Rq+UalFXFBXQOdXJHa8s49In5vPiLafQKzuZuaUVPP3fzcwtrSAlwcZtp/bklnE9yEl1Ulnn42//2cjLC7fx7oqdfP/svlw/uht2feTCcdGgV0q1uNP6ZvPG5DHc/MJiLntyAfkZLtbsqqZzSgL3ntufa0cVklqvWyc90cH9Fw3k2lGF/Gbml/zfe1/y90Xbue+CAZzWNzuG76R90qBXSrWKwflpvHPHOG5+YTFuX5DfXzqYS4bnkWCzHnGdvjkpvHTLSD5ZW84D73/Jt6cvZkKfLLp3SiIQMoRChqD539dgyJCZ5OD7Z/UlI8nRiu+ubdOgV0q1msJOiXz8/dMQCffhR0NEOGtADhP6ZvHCvK08P28rX+yswmqR8EsES73vdxyso2T9Pp65sYh+uUcdBqPD0KBXSrUqi+X4BjFJsFm5/bRe3H5ar6O2W779IFNeXsYlT8zjoStPZuKgLse1v3iiVzaUUnFleGEG7905nr45KUx5ZTkPfbyhw39oS4NeKRV3clKdvD55NJePyOeRTzZy+yvLqPEGYl1WzGjQK6XiktNu5U+XD+HXFw7g03XlXPL4PLZW1DbaNhQy7KnysHz7Qarq4u/pm9pHr5SKWyLCzeN60C8nhe++upyLHpvL1DN6U+MJUFbpZlelm52VbvZUefAHw907nVMSePGWkZzUJX4+lRvVGb2ITBSR9SJSKiL3NrJcROSRyPJVIjI8Mr9ARD4TkbUiskZE7m7uN6CUUscytncW700dT9d0F7+btY7HPitl4ab9BEOG4YUZfGdCT35z8SAeuWYYFhGufHoBi7cciHXZzeaYZ/QiYgUeB84mPAj4EhGZYYz5sl6zc4E+kdco4MnI1wDwQ2PMchFJAZaJyMcN1lVKqRZXkJnIzDvHs6/GS3ZywhEHNh9emM6N0xdzw3OLePSaYXxrYG4rV9r8ojmjHwmUGmM2G2N8wOvApAZtJgEvmbCFQLqIdDHG7DbGLAcwxhwiPOZsXjPWr5RSUbNZLXRJcx0x5AHyMxJ5e8pY+ndJZcory3hjyfZWrLBlRNNHnwfsqDddRvhs/Vht8oDdX80Qke7AMGBRYzsRkcnAZICcnBxKSkqiKK3tqKmpaXc1KwV67B7JHf0Mj7mt/PQfq1myah3n97RH/SGvtiaaoG/snTW8KfWobUQkGfgHcI8xprqxnRhjpgHTAIqKikxxcXEUpbUdJSUltLealQI9do/mjOIQP357JW+v2EVK5zzuO3/AcX/gK5aiCfoyoKDedD6wK9o2ImInHPJ/N8a8c/yldlwBtwfvwUMkddWHOSnVmhw2C3+9ciidkhKYPm8L+2t8/P6ywSQ62tcNi9FUuwToIyI9gJ3A1cC1DdrMAKaKyOuEu3WqjDG7Jfx3znPAWmPMQ81Yd7tTsXozNWUVWO1WLHYbFocNq92ONcGGNcGOWITqrXs5uGUfB8sOcHDfIWrcNjyk4nOkY8RKuncTQ4u7cdK1Z2Cxt68DTan2ymIR7rvgJLJTEvjDh+t4f/Vu+uakMLQgnWEF6QwtTKdXdjLW4zzT31vt4fPtB/l8eyXVHj8PXjqkmd9BFEFvjAmIyFTgI8AKTDfGrBGRKZHlTwGzgPOAUqAOuDmy+jjgBmC1iKyIzPu5MWZWs76LNqymrJwPH3iVvWYQSDTXvh1ALjZ/EhKqICBb8IQqEKBGRlOywMaCknfoXehm5JTzSeyS1cLvoGk8FZXsW7mZ/Rt2c7CsmsoDXvx+ISPTSnb3dHKHdid7RF+sCfpkQdV+iAh3FPdiRLcM5mzcx4odlcxctYvXFocv1CYn2Bicl8aQgjRyUpykJ9pJT7ST5nKQkWgnPdFBqtNG0BjW7Krm8+2VLN9+kBXbK9lZ6QYDp3hDDCNI6OLBzd49FNVpYSSYZzWY91S97w3wvUbWm0vj/fetKuDxsmvBKrYtW0n+oJMoKC7C5kxo0X0GvX5mP/g8G8q6ELAOxOKfDV13EgwYgkFDMAihkBAKWQiFBIMQctVi7eQmpdBFly49KMweREHXYjIzehIIePh03l9Z9d5G7O6xrNnbi7W/WkKufQujrjuNruMGNrnGqs27WPXyHDZtgwSLn179kxhw9TiS8ztHtb5nfzWlMxaxY/VeKqsNNaFkfI60yFIXmATsvv1gvFRUZrNhlR1WlWN5voyU0AEykgNk5SWTkpuCCYEJhgiFQhB5/KyJvFwZSWT0ziFzQHccqUlNfp+tyRhDyOPFV12Dv6qWoD8IJvJeIl8JhTAGEHBmpuLKycCW6Drh/Vat2cSWz9awe+NB9h1yYpcAeXlCr9P60rV4GBZbfP8VaIJBAvsP4K+uwZ6Zhi01FWnm9zyyRyYje2QC4U/Tbtlfy4rtlawsq2TFjkqmz93y9QevGmO1CMHIc3fy0l0MLUznloI0rAt3UetPIqlmG75DtTjTkpu1bglndNtSVFRkli5delzr+mrcbJ+9iE0LV3BwdwC3vxNuR1eM5X+DGliCPlz+MlKTq+g2qBu9zx5DWq9v3vUZ9Pio3ryLyi17qdy+l/0792JChp6jBlFwxlAcKYnfaF//gtbaNz5iwQf7cDu74nCvx1W0hqtu/yN2xzfXOV4bNv2bD95+Adu6AVhsRYSsDlI82+iSG6LnmAEUnjUUe1LjwREKBNn0z/ms/mQze0JdMBYbdncpIsn4nLlIKEiW2UnfEZ3pf8V4nJ2++enAg+u2seG95WxdX8l+S/jnag24sfh347eUU51QTkVyOd6MCpxdfRSm5+KyOVlZUUr1ThddK/LJqckj2Z9H0F5A0NaEn4kJkRA4RJLUkewKkprhIDUnmaAviOeQB0+NH487hNcH3oAVn7ETxEaypZaMdOhUmErO4EJyivpiTznyL4xQIIB7934O7SinrrwK98FaPJVuPDVePHUBfO4gXq/B57cQCFkIYCWAjaDYCVocBK1NPIkwIWxBD/aQBzs+HJYgDluIBIfB6bLiTLbjSnPhykgkMSuZpM7pJHXtRN2eA2z971p2baxkX10SdQnhv+6sQQ+dbFV4A1aqrOF5Tl8luUnVdB+WQ68LR+PMzvh69611Mdb4/fiqDuE9cAhn50wc6U17hLAJBCifv4Id8zdSe9CDuzaIxwsevxWvceCzJOJ3JGPEioQC2AN12IPuyM/UH/mZCo4EwWq3YrdbsDqs2BKs2BLs2F12bE4HzowkUvI7kVyYiy0zA7FE/6SYYMhwyOOnss5PpdtPZZ0v/H2dj0q3n0DQMCgvlWGFGVj2VjFn2kJ2H0ohwXMA3DM4OHApU380F1diZlN/vIjIMmNMUaPL4iXo3ZUHeO2emXgcXTCW8EAG1kAdVv8OjG0njk7VpHVzUbm9Dl9FOpZAd/wJBRhL+Dd+gnc/TioIGCc+Sxp+e+oRu1ok5CfJt5PM9Dp6FfWj+9kjWLx2FUOyuvHRX9/ngH0Adu9+AtkfcekP7yE3Z9CJ/UCOoLp6J++9/yDl/7WS7BmGLyEfxIIl6CM1WEbXvAR6jO1HfvEQ3HsrWfHif9m4VXAnZGH11+BhMSt7z+ekPqnU+dzsKjX03z6C5FARfkcGlqCXbNlO36IC9m7ew849dmqd4V+Idu8+ai2r2Jr7BY6+VfTJ7EbPrIH07DqKgrxR2G3Ow+oNhYKUbvmU5ZveZ/m+lSz37MNWlUGnmhRClhBBCWHEEBJDUEKErAaDIfdQEgXVWWTWZePyZyEmi4C1E3572je2L6EAtmAttlAdVuqwiBskQDCUjdvemVDkl72EgiQFDpDu8pKUbMXrDuL2gCdgw4sTny3p67aHMSFsQTe2kBsrXqx4AC8GL0HxELB48Fk8eCxe3FYfVgniEsFltZNoTcBlTyQxIZUkVxoJjjS8NR7ch7x4PEF8PsEfsBEIOQjgJGBxEbAmHrPLzxp0k2x24EjbS7BbBe68g/jwkpdawMlZl7BvYS3b1hyg3JtB0JqAJeijkyknNdngcFqp8VSR370rzlQXzowkXJkpONISqSuvpGZ3JbUVNdRVuqk75MftDger39gQQlgwWAghYrDUexkEf9CC31gJ4CAgDgJWJyFruMvOEvSRHtxH5yxD14E5FBYPIanb4Y8Trtm0nc0fLGfHl/vZW5eC2/m/rkpLyE8CHpxWPwl2gytRcKU4cLhseGv9eOsCeD3hX/y+gAWfseMngeCR/m0bEBPE7qshwbhxWnw4Ewwul4WQAb/f4A8I/kD4PfqNjYA4CImNZKrJygiR0zuTvJG9yRzSC4v1f4OrHNq5n7mPl7B5fxrWoBdr3UesOulTbho2gRFn/g5cGUep6ij1doSgB3jmpt+BvQZndi25J+cycMI5dMkd2uhvZI+7klUr32H9f5dSs82OpbYAi+RgzCGCcpCQvRJcNVhSvDizraR3SyfoD7J3WSVU5OII9MKfUBj+pWJCuLy78drDd8WE+A+jbh1C0egbT/AnEZ1QKMjajTNZtOw99n/uxbG/O4mhvvgioWwNegiJ7euz9+0Z85Chuzl3yOWMGnIzVpv96+2sK51FyRdvsPvzWrJ3DsMhQwnak8GEsHu2cNC1GnePzfQcUsjovpfQp8eZTTrjqc8Yw649n7OrfDVef134FajFG/DgDbjx+t14gh4O+ao54KvmgL+Wg0EPBwlwEAN+B3kH0/HYA+xPrsHj8B+xo9ASEnqWZ9OnvCv51V1J8ucTsnTFZ0/DHjiEJXgIY6rxWarx2A5R6zjEIWc11c5aqlx1VCXWcjDRTa3TC3L4/zMJxpBhLGSIjTRLAhm2RFLtSVT5a9jtr2Z3yEuFGEJNvA9bjJDkcZFZm0RmbTKp7iRSPMkk+ZLwW/2s6bqJjTk7MUf5JxgQFMal9GJswURSdg9g2+Jd7N5nxSOJBKyH/0I+EmvQGw49qx+H3WBMpPvRQMjI1y8T+UewW4LYrSEcdrAnCI4EKw6nDUeijUP76thbAdWSgZHw/0Mpvn1kp3jp3C2Vyj017N5noSohF8SCNeQjw7KHatdKPslbRUXqfhwWLy6ERCy4xIpLrCRa7DjEhtcE8IUCeEwAnwnhIYjPGDwYfFjx4yBoHASDdhwBB06fA6ffjjNgJ8WdSKe6FDI9yST507CHUhGTStCSit+ajJggtpAXGz5s+LFZAl+/T6vVQlWNgypL5tcnC3Z/DRmWSrKzrYTEwobydEJiw1Y3h9n9P+D8Pl254uyHsWV2b9Kx0VCHCfoTEQz42bd/HZkZPXE4jt0PvGfvSpYt/wfbF+4gsKsTCb6eBKWKrNMruPS6338dnrHgdley/MvXWLayhENf2Emp7E1I/BzovZJR407h9FPuJNF17D8NK/ZvYPbS6WxfuJ3kHk6KRkxkUL9J2Gwte30jWnWeSqoqtwFgtTmx2RKw2VzYbE5sNidWi41QKMCe8i8oK1/JzgPr2Vm1jZ11e9npr6bMeKkGchByLE5y7SnkurLITepKblp3cjL7kprSJfyBkFAIE/kvFApiMOFf8K5M0lMLcUVxzPiDPvbt38jufV+w58BGKmp347S5wmf4CWkkOTNIcnUi0dWJ5KRsEhyp+ANuAgE3fr8bf8CNz1+HP+jFH3BjjMHpSMHhSCLBkYLDkYwzIRWHLRG71c6GrZ8xb91bzKtYxUpTR1CElFCI0ZZUxnYeTrorC5/fR9nmXXSyZxCoNoRqBOO2YHxWLIlB7OngyLKRmOMiKSWFREcaroRUEhxJBIMBgiEfoVCAQMhPKBggGPITDAWwWmwkuTJJSexMclIOiUnZWJzpYP1mn7mvxsOOOWsoW7aNvTt9HAikhbu+TIh0DtC1q+DJ/oJ/2WYwPyGA3RjOcOWTYk+iLuDBHfTiDnmpC/lxhwK4TQAfBgcWnGLBIVYSLDYSLPbIy0GC1Y7TkkCCLQGX1UmCzYnT5sJpc5Fgc1HrrWJvzU721JWz11fJ3qCbvQQJRPlLOiUUIs9vY3B5N/L29SChtgBfsCtuR2cQC3b353za+z36d/NzV/GfyCwc26Tj/kg06FvBR/9+i1MnnIXrOP/sakn7D2zCYrGQkd4j1qWoGKmq3cui1S8zb9unzK3bQXkrP6BcjCHJGJJDhmSEzpYEuiVk0j25gO6d+tMtdxi5XU4BRyoVq7ZB0gE+WPMnXj/4BTttFjob4aoup3LZuF/QKbn1R4wKmRAHanazd98a6jwH8fpq8Ppq8fvr8Abq8Abc+Pxu3P5ayt372OOtZE+glj34qYzcQZPocZBRl0RGejU/H/59Bp/87WatUYO+FeinC1V7YYxh664l+Hw12O2JrFr1JaNHT8BmS8RuT8Juc2Cz2PD463B7DlLnPoDbcxC3p4o6bxVubzXegBubxYbFYsNmtWMRK1aLA5s1PC8Y8lPjPkiN5wA13ioOeaup9ddyKFBLTcDNbv8hthkvtfVOkh0hQ2HIkCMJLBMvHouFEZZkrj3pes4YNhmbNXZ/JZ8It7eavfvWsKdiHcGQnzEn34LF2vx3QB0t6OP7fiul1GFEhB55I7+e3l7qITezz2HtHFYHqc50aKG/BI0x7D+0k627FrF170q2HdzI1trdlPmrOT+5F9eM/DH9Cie0yL5bkyshle75Y+iePyZmNWjQK6ViQkTISs0nKzWfov6XxbqcuKZDCSqlVJzToFdKqTinQa+UUnFOg14ppeKcBr1SSsU5DXqllIpzGvRKKRXnNOiVUirOtclHIIjIPmBbI4vSgKombCra9tG0O1abLKAiyrrai6b+vNv6fptju8e7DT12W1esjt2W3PexttvNGNP4wNLGmHbzAqa1RPto2h2rDbA01j+fWP+82/p+m2O7x7sNPXZb9xWrY7cl930i221vXTfvtVD7aNo1dd/xIFbvuaX22xzbPd5t6LHbumL5ntvc8dsmu27aIxFZao7w5Dil2jI9duNfezujb8umxboApY6THrtxTs/olVIqzukZvVJKxTkNeqWUinMa9EopFec06FuBiFwsIs+IyLsi8q1Y16NUtESkp4g8JyJvx7oWdfw06I9BRKaLSLmIfNFg/kQRWS8ipSJy79G2YYz5lzHmNuAm4KoWLFeprzXTsbvZGHNry1aqWpredXMMInIqUAO8ZIwZFJlnBTYAZwNlwBLgGsAKPNhgE7cYY8oj6/0F+LsxZnkrla86sGY+dt82xlzeWrWr5qWDgx+DMWa2iHRvMHskUGqM2QwgIq8Dk4wxDwIXNNyGiAjwe+ADDXnVWprj2FXxQbtujk8esKPedFlk3pHcCZwFXC4iU1qyMKWOoUnHroh0EpGngGEi8rOWLk61DD2jPz7SyLwj9oEZYx4BHmm5cpSKWlOP3f2Anpy0c3pGf3zKgIJ60/nArhjVolRT6LHbAWnQH58lQB8R6SEiDuBqYEaMa1IqGnrsdkAa9McgIq8BC4B+IlImIrcaYwLAVOAjYC3wpjFmTSzrVKohPXbVV/T2SqWUinN6Rq+UUnFOg14ppeKcBr1SSsU5DXqllIpzGvRKKRXnNOiVUirOadCrNkdEXhCRpTGu4W0RKTmB9YtFxIjIoGO0+7OIbK03PVJE7m+k3f0iUnG89aiOTYNeqZaxHBgDbGrieiOBXzd/Oaoj04eaKdUCjDHVwMJY16EU6Bm9asMiQzCuExGPiMwVkQH1lv1QRJaISJWI7BWR90Skd4P1SyJdMNdGRlOqFpEPRCS/QbsCEZklIm4R2Soi32mwvGekG2ZsvXmvReYNqTfvPRH5e+T7w7puRCRdRF4VkVoR2S0iv2iwn5uARyPfm8irpEGbYSKyUETqRORzEZnQ5B+s6nA06FVb1Q14CPgNcC2QBnwkIs7I8nzgMWAScBvhEZLmiUhag+2MIvxslx8Ck4HhwLSvFkYGhXkXGATcCvwAuJtwtwsQHk4P2AnUD9UJgOereZHtjAPmHOU9PQ+cC9wTqeVbhB8q9pX3gb9Evh8TeX233vJE4EXgaeAywAv8U0QSj7JPpcAYoy99takX8ALhZ6SPrTevGxAApjTS3gq4gEPAjfXmlwBVQEa9efdEtu2KTJ8XmR7VyL5K6s17DZgZ+b4nEASeAF6PzBsS2c7AyHRxZHpQZHpgZPqqettMBg4AW+vNmxr+3/Kw93h/ZP0z6s0bGpk3Mdb/Zvpq2y89o1dtVbkxZv5XE8aYbcAywhcrEZHRIvKxiOwnHMp1hIOzb4PtLDHGHKw3/WXk61ejKo0E9hpjFjWyr/rmAONExAKcCqwC3uN/Z/mnEg7tL2ncKZGvXz8S2BhTA3x8hPaN8RP+5dXwveQf3lSp/9GgV21V+RHmdRGRQuDfhEdLup1wl8kpkeXOButUNpj2Rb5+1S73KPuqbzaQTriLZwLh4J8H5IpIz8i8ucaYIz0ONhc4ZIxxH2M/R1NtjAl9NWGMafhelGqU3nWj2qrOR5i3BphIuL96kjGmFkBEbEDmcexnz1H2VT+U1xA+Y59A+Oz9Z8aYahFZFZk3gfA1haPtJ0VEXA3CvrF9K9Ws9IxetVWdG9zlUkj4Qupiwv3xIcJdNl+5kuM7cVkC5IjIqEb29bXImfq8yH56Ez7DJ/L1FqALR78QuyTy9aJ6+0kGzm7QzhdZpmfpqtnoGb1qqyqAl0XkPsJn1v+PcDfHC0AfwhdgnxeR5whf6PwRh3fTRGMWsBJ4S0R+SvhOmq/21dBs4E/AemPMV8vnAHcRvkaw/Eg7McasEZEZwJMikgrsBn4cWa++dZGvd4vIp4S7a9Yfx/tS6mt6Rq/aqm2Eg/B+4HWgGjjHGOMxxqwGbiZ86+RMwrdfXkH4DpsmiZypX0T4wuZ04G+Eb9tc0Ejzr87YZzcyb5Exxn+M3d1E+NrC34DngE8Iv7eG+/gT4Vs8FxG+lVKpE6JDCSqlVJzTM3qllIpzGvRKKRXnNOiVUirOadArpVSc06BXSqk4p0GvlFJxToNeKaXinAa9UkrFOQ16pZSKc/8fffO6GmBglcsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "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
}