{
 "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\n",
    "import sys\n",
    "# sys.setrecursionlimit(300000000)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "source": [
    "def generate_data(num, mean, cov):\n",
    "    # Fix the seed to reproduce the results\n",
    "    rand = np.random.RandomState()\n",
    "\n",
    "    x, y = rand.multivariate_normal(mean, cov, num).T\n",
    "\n",
    "    return x, y"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "source": [
    "def plot_err(xaxis, results, labels, xylabels, title=None, path=None, plottype=None, legend=False):\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",
    "        if legend:\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": 3,
   "source": [
    "def gaussian(x, mu, sig):\n",
    "    return 1 / np.sqrt(2*np.pi) / sig* np.exp(-np.power(x - mu, 2.) / (2 * np.power(sig, 2.)))"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "source": [
    "num = int(1e3)\n",
    "mean = [0.5, 1.0]\n",
    "cov = [[1, 0.5], [0.5, 2.0]]\n",
    "x_train, y_train = generate_data(num, mean, cov)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "source": [
    "eg_length = 50\n",
    "np_x = np.linspace(-4, 4, 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 = (cov[0][0] * mean[1] + cov[0][1] * (np_x - mean[0])) / cov[0][0]"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "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/Gaussian'\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": 9,
   "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(-2, 0, 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",
    "        # print(estimator)\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/Gaussian'\n",
    "xaxis = bws\n",
    "plot_err(xaxis, results_err, labels, xylabels, title, path, plottype='loglog')"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZoAAAEUCAYAAAASvPDLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAABDIklEQVR4nO3dd3xUVdrA8d8z6SGFkkIJhB4EUUoAkSLSFBURu7LLi4qAIoplXeuC7KogooIoCFYUVkVBxAURhYD0qihFinSk15AEUs77x52EyWQCk2Qmk/J8P59h5vbnDpN55txz7jlijEEppZTyFpuvA1BKKVW2aaJRSinlVZpolFJKeZUmGqWUUl6liUYppZRXaaJRSinlVf6+DqAkioqKMrVr1/Z1GEopVezOnj1LhQoVCrXt2rVrjxpjop3na6JxoXbt2qxZs8bXYSilVLFLSkqiU6dOhdpWRHa7mq+XzpRSSnmVJhqllFJepYlGKaWUV2micSAiPUVk0qlTp3wdilJKlRmaaBwYY2YbYwZERkb6OhSllCozNNEopZTyKm3e7EF7j6dw/Ox5/GyCTQQ/m8NDBJsNh9fWs5+f/dm+jb/NWqaUUmWFJhoPemfhdj5fvdcj+8pOOP4uEpLzwz87SfkJfjabtU32tjnP9vl+QoBN8PezEeCXvdx6bc2zEegnBNhfB/hfmA70txHk70eQf/Zr+3SA9TokwI+QQD9CAvwQ0WSplLJoovGgfu1q061xLJlZhixjyMyCjKysnNdZWYZMYxyWOzyMsZZnQWZWFpnGkJFlzcv1bAwZmRf2k/3IyHKeziI9M4vUdPt0pjUvI/t1pv11liE9MytneXqmZwbCCwnwIzTQj2D7c2iQPxHB/oQH+xMeFEBEiD/hwQGEB/sTERxAZEgAVcICiQoLokpYIKGB+tFUqqzQv2YPalQ1gkZVI3wdRpEYY0jPTjoZhvOZVsI6n2E9n8vI4lxGpv05i3PpF6bT0jNJOW89rNcZpJzPJPV8JmfPZ3ImLZ2/TqVxJi2d06kZpKZn5htHaKAfVcICqVIhiKiwQGIigomrFELNSqHEVQohrlIoUWGBWnJSqhTQRKNyEREC/YVAbBDo3WOlZ2ZxJi2DM2npnExJ59jZcxxNPs+x5PMcSz7HsbPnOZp8jv0n01i7+wQnUtJzbR8cYCPOnnjqR4dxWbUILqsWQf2YMAL9tZ2LUiWFJhrlMwF+NipXCKRyhUDiq1x6/eRzGew/kcre4ynsO5HCvhOp7DuRyp7jKSzfcYxzGVn2/Qr1osNobE88jatH0LxWRb0cp5SP6F+eAxHpCfSsX7++r0NRLoQF+ZNQNZyEquF5lmVkZrHz6Fk2/XWazX+dYfNfp1my/Sgz1u8HrOTTolYl2tePon2DKJrWiMTfT0s9ShUHMcYzlb9lSWJiotHem8uGY8nn+G3/KZbvOMaS7UfZeOA0AOHB/lxdrwrt60fRoUE0taMK1y26UmVNEXtvXmuMSXSeryUaVaZVCQuiU0IMnRJiACvxLNtxjCXbjrJk+1HmbTwEQItaFbkzsSY3XVmdsCD9s1DKk/QvSpUrVcKC6HlldXpeWR1jDLuPpfDDpoN8uWYfz8z4jRHfbeLGptW4q1VNWsZX0lZtSnmAJhpVbokItaMqMKBjPR7sUJd1e07y5eq9fLfhANPX7qNudAXuTKzJbS3iiA4P8nW4SpVaWhuqFFbSaRlfiVG3X8Gq57vy2u1XUDk0kJFzt9B+1AJGfb+F02npl96RUioPLdEo5aRCkD93JtbkzsSabD+czDsLtzMhaQdfrN7Lo53rc2+beL1PR6kC0L8WpS6ifkwYb97VjNmPtCchNpzhszfR/c1FzP3tL7TFplLu0USjlBuaxkUy7cE2fNgvkQA/Gw9NXcftE5ezdvcJX4emVImniUYpN4kInRvFMvexDrx6a1N2H0vhtgnLeOKLXzh7LsPX4SlVYmmiUaqA/P1s3NO6Fov+0YnB19bjm1/2c8s7S9l+ONnXoSlVImmiUaqQKgT584/rGvHpA204fvY8vcYv4X8b/vJ1WEqVOJpolCqidvWj+O7R9iRUDWfwtHWMmL2J9MwsX4elVImhicaBiPQUkUmnTp3ydSiqlKkWGcLnA9rS7+rafLh0J/dMWsHBU2m+DkupEkETjQNjzGxjzIDIyEhfh6JKoUB/G8NvbsLb9zRn01+nuentn1m2/aivw1LK5zTRKOVhPa+szrePtKNiaCB/+2Aln67Y7euQlPIpTTRKeUH9mHBmDW5H50YxvPjN73y5Zq+vQ1LKZzTRKOUlFYL8eadPCzo0iOKZrzdoizRVbmmiUcqLgvz9mPT3RFrGV+Kxz9ezYMshX4ekVLHTRKOUl4UE+vFBv1ZcVi2CQZ+tY9kObSCgyhdNNEoVg4jgAKbc35raVULp/8ka1u3RPtJU+aGJRqliUqlCIJ890Ibo8CD6fbiKTQdO+zokpYqFJhqlilFMRDBT+7ehQpA/f/9gJTuOaP9oquzTRKNUMYurFMrU/m0QgT6TV7L/ZKqvQ1LKqzTRKOUDdaPD+PSBNpw9l8Gj/11PhvaNpsowTTRK+chl1SL4T+/LWbv7BOMWbPd1OEp5jSYapXyoV7Ma3NYijvELtrHyz2O+Dkcpr9BEo5SPvdSrCfFVKjD0i184mXLe1+Eo5XGaaJTysbAgf8bd3Zyjyef459cbMMb4OiSlPKrMJxoRmSAi+0VE/3pVidU0LpKnr2vEvI2HmLZqj6/DUcqjynyiAf4LtPB1EEpdygPt69ChQRQjZm9i66Ezvg5HKY8pkYlGROqLyHsi8quIZIpIUj7rNRaRn0QkRUQOiMgIEfFzXMcYs9gYoz0ZqhLPZhPG3Hkl4cH+PPrf9aSlZ/o6JKU8okQmGqAJcAOw1f7IQ0QqAT8CBugFjACeBF4qphiV8riY8GBev+NKthw8wytzNvs6HKU8oqQmmtnGmJrGmDuAjfmsMwgIAW41xsw3xkzESjJPiEhEcQWqlKd1Soihf/s6TFm+m/mbtDCuSr8SmWiMMe7cJt0DmGeMceyZ8HOs5HONVwJTqpj84/oEmlSP4B9f/cqRM+d8HY5SRVIiE42bGgFbHGcYY/YAKfZlSpVaQf5+jL27OWfPZTB63pZLb6BUCebv6wCKoBJw0sX8E/ZlAIjI+8D19tf7gO+NMf2dNxKRAcAAgNjYWJKSkjwfsVIF1K2WP1+u2Ucj/6PUreh36Q2UKqLk5GSPf/+V5kQDVkMAZ+I431VScbkjYyYBkwASExNNp06dPBGfUkWS2DaD1a8n8e3+YGbcfDU2m/g6JFXGJSUl4envv9J86ewEUNHF/Ehcl3SUKnXCgvx5tkcjftl7khnr9/s6HKUKpUCJxn7fyt9F5DkRqWqfV19Ewr0T3kVtwakuRkRqAhVwqrtxl4j0FJFJp06d8kB4SnnGLc1q0KJWRUbO3cKZtHRfh6NUgbmVaEQkTES+BH4D3gf+DVS3L34FGOad8C5qLnCdU5K7C0gFFhVmh8aY2caYAZGRkZ6ITymPsNmE4Tc34djZc7ytwwmoUsjdEs0bwNVAVyAcqx4k2xzsle2eIiKhInK7iNwO1ACis6dFJNS+2kTgHDBDRLraK/OHA284NXlWqtS7Iq4idyXW5MMlO9l+WId/VqWLu4nmVuCfxpiFgHO/GLuBeI9GBTHAdPvjKqCxw3QMgDHmBNAF8ANmY92s+Sa+KV0p5XVPXZdASKAfI77bpD08q1LF3UQTAuQ3KlM4eZNPkRhjdhljJJ/HLof1NhljOhtjQowx1YwxLxpjCh2L1tGokiwqLIihXRuyeOsRftp82NfhKOU2dxPNaqBvPstuB5Z5Jhzf0joaVdL1bRtP/ZgwRny3STvdVKWGu4nmBeBWEfkR6I91n8oNIvIpcAd6uUqpYhHgZ2NYz8bsOZ7CB0t2+jocpdziVqIxxizBqg8JAsZjNQZ4CagLdDXGrPZahEqpXDo0iOa6JrGMX7Cdv06l+jocpS7J7ftojDFLjTEdgAggDgg3xrQzxiz1WnTFTOtoVGnxwo2NyTSGV+doP2iq5CtwzwDGmFRjzAEgSESaiUiQF+LyCa2jUaVFzcqhDOhQl29/PcDv+/WHkSrZ3L1h8yURGekw3RnYA6wF/hSRJl6KTymVjwHX1CUi2J+3fnQ5NqBSJYa7JZo+5O7WZQywBGhnn/+qh+NSSl1CRHAAAzrW5cfNh/l170lfh6NUvtxNNNWBPyGnP7ErgWHGmBVYvQZc5Z3wlFIX069dHSqFBvDGfC3VqJLL3URzBqtXZIDOwAljzCr7dBoQ6nKrUkYbA6jSJizIn4HX1GPR1iOs3X3c1+Eo5ZK7iWYR8IyI3Ag8BcxyWNYQ2OvpwHxBGwOo0qhv23iiwgJ5c/42X4eilEvuJprHsTqw/BxrrJfnHZb1BRZ7NiyllLtCA/0ZdE09lmw/yso/8+spSinfcfeGzf32PsXCjTEdjDF/OSy+DhjinfCUUu7421XxRIcHMWb+Vu1wU5U4RR5h0xhz2hhz3hPBKKUKJzjAj8Gd6rFq53GW79BSjSpZ/N1dUUTuBHpjjQ8T7LzcGNPag3EppQro7ta1eG/xn4yZv5W29aogIpfeSKli4Faisd+s+TRWL87bgTJZghGRnkDP+vXrX3S906dPc/jwYdLTdVhdVbKM6xHDyZR0fvltI8EBfrmWBQQEEBMTQ0REhI+iU+WVuyWa+4HnjTFl+sZMY8xsYHZiYuKD+a1z+vRpDh06RI0aNQgJCdFfjapEyTKGrQfP4O9no150hZzPpzGG1NRU9u/fD6DJRhUrd+to0rG6myn3Dh8+TI0aNQgNDdUko0ocmwgxEUGknM/gTFpGznwRITQ0lBo1anD4sA6apoqXu4lmLNBf9JuV9PR0QkJCfB2GUvmqGBpIoL+NQ6fT8rRACwkJ0Uu+qti5denMGPOaiLwObBGRRVj30jitYv7p6eBKKs23qiSziRATHsy+EymcTssgMiQgZ5l+dpUvuNsYoA8wFMgCwsjbGMAA5SbRKFXSVQoN4MgZPw6dTiMi2F8TjPIpdy+djQS+AKoYY2oYY+o4Pep6MUZVzg0fPpyoqChfh1GqiAgx4UGkpWfmqqtRyhfcTTQRwIfGmDPeDMbXtFPNkql///7MmzfP12GUOpGhAQT62Th85pz2FqB8yt1E8zVwrTcDKQm0U82SKS4ujpYtW/o6jFLHJkJ0uNUC7ew5LdUo33E30cwD+ojI+yJyr4jc4PzwZpDKO8aPH0/NmjWpUKECt9xyCz/99BMiQlJSEgBjxoyhVatWREZGEhsbS8+ePdm+fXuufdSuXZunnnoq17yPP/4YESE5ORmwWuo99dRT1KpVi6CgIKpXr07v3r05f96q6jt58iT9+/enevXqBAcHU6tWLR588MKtTM6Xzs6ePcsjjzxCQkICoaGh1KlTh8GDB3P69OlccYgIY8eO5bnnniM6OpqYmBgGDx7MuXPnPPYelnSVQgMJsJdqlPIVd2/Y/K/9+X77w5kB/FzMVyXUzJkzGTJkCA8//DC9evViyZIlPPDAA7nW2bdvH4888gjx8fGcPn2aiRMn0q5dO7Zu3UpBSn2vvvoqU6dOZeTIkdSpU4eDBw8yZ84cMjMzAXjiiSdYtmwZb775JlWrVmXv3r0sXpx/h+ApKSlkZmby8ssvEx0dzd69e3n55Ze544478lxiGzNmDJ07d+azzz5jw4YNPPvss8THx/P0008X4N0qvWw2ISosiL9OpXL2XAYVgtzudUopzzHGXPIBxF/q4c5+SsujZcuWJj+bNm3Kd1lpkpiYaG644YZc8x566CEDmIULF+ZZPyMjw6SkpJiwsDDzySef5MyPj483Tz75ZK51P/roIwOYM2fOGGOMufHGG80TTzyRbyxNmjQx48aNy3f5sGHDTJUqVfJdnp6ebpYsWWIAs3v37pz5gOnQoUOudXv16mXatGmT777KoozMLLNx/0mz80iyMabsfIaVd7j6+3cXsMa4+E519z6a3R7PcGXIS7M3sunA6Uuv6AWNq0cwrGeTAm2TmZnJL7/8wvjx43PNv/nmm5kwYULO9IoVK3jxxRdZt24dx49fGL1x69aCDRvcrFkzJkyYQGxsLNdffz1NmzbN1dy2WbNmjB49Gj8/P7p27UrDhg0vuc9PP/2UN954g23btnH27NlcsdWqVStnunv37rm2a9y4MWvWrClQ/KWdn02oEhbEodNppJ7XuhpV/Io8TIAqfY4cOUJGRgbR0dG55jtO79mzh+7du2OM4b333mPp0qWsXr2amJgY0tLSCnS8F154gcGDB/Puu+9y5ZVXUrNmTcaOHZuzfPz48dxyyy2MGDGChIQEGjRowOeff57v/mbOnEnfvn1p27Yt06dPZ8WKFcycORMgT2wVK1bMNR0YGFjg+MuCKmGB+IloXY3yCb1g6wEFLVH4WnR0NP7+/hw5ciTXfMfp77//npSUFGbNmkWFChUAyMjIyFWyAQgODs6p1M/map0RI0YwYsQItm3bxsSJExk6dCgJCQlcf/31VKxYkXHjxjFu3Dg2bNjAa6+9Rp8+fbjiiito3LhxnvinT59OmzZtePfdd3PmLVq0qHBvRjnhb7NRJSzQSjSZWb4OR5UzWqIph/z8/GjWrBmzZs3KNf/bb7/NeZ2amorNZsPf/8JvkS+//JKMjNyXXuLi4ti8eXOuefPnz8/32A0aNOD1118nKCiITZs25Vl+xRVXMHr0aLKystiyZYvLfaSmphIUFJRr3tSpU/M9prJEhQVhE9EbOFWx0xJNOfXcc89x66238sgjj3DzzTezdOlS/ve//wFgs9no3LkzmZmZ3HfffTzwwANs3LiR119/Pc+lqN69ezNkyBBeeeUVWrVqxYwZM9i4cWOedVq2bEnz5s0JCQnhq6++IiMjg44dOwLQvn17evfuzeWXX46IMHnyZCpUqEDr1q7H0uvWrRuDBw/m5Zdfpk2bNsyZM4effvrJ829SGePvZ6NyhUAOns9k7/EUalYO9XVIqpzQEo2D8tQzQO/evRk3bhzffPMNt9xyC6tXr+b1118HrLFKmjZtykcffcTKlSu56aabmDZtGtOnT8/TrHnAgAEMHTqUcePGceeddxIYGMgLL7yQa52rr76ab775hnvvvZdevXqxdu1avv76axITEwFo27YtH3/8Mbfffjt33nknR48eZe7cucTFxbmMfeDAgTz55JOMHTuWW2+9ld27dzNt2jQvvEtlT1RYEAhMXLTD16GockSMm11TiEgw0BGII+9QzsYYMyHvVqVTYmKiya9l0ubNm7nsssuKOaLi8Z///IeXX36Z48eP61AIZdiytb/Sb8YBfv7ntcRG5BmVXZVzSUlJdOrUqVDbishaY0yi83x3e29uD8wA8uvZ0ABlJtGUB0eOHOHVV1/l2muvJTQ0lJ9//plRo0bxwAMPaJIp48KD/Mk0hsmL/+SFm/I2tlDK09ytoxkH7AC6AZuMMTpyUikXGBjIli1bmDJlCqdOnaJatWo89thj/Pvf//Z1aMrL/P1s3Hxldaau3MPD19ancoVAX4ekyjh3E00CcKsx5ldvBqOKT2RkJHPmzPF1GMpHHu5Uj5nr9/Phkp08dV2Cr8NRZZy7jQE2AFW9GYhSqvg0iA2nx+VV+WTZLk6l6AUK5V3uJpqHgMdF5BpvBqOUKj5DOjfgzLkMPlq209ehqDLO3UQzH2gALBCRNBE57PzwYoxKKS9oXD2C7o1j+XDJTk6naalGeY+7dTTvYLUsU0qVIY92acAPmw7xydJdDOnSwNfhqDLK3d6bh3s5DqWUD1xeI5IujWJ4f8lO7mtfhzAdr0Z5QYF6BhCRQBFpKSLd7M/aLlKpUu7RLg04lZrOlOW7fB2KKqPcTjQi8jRwCFiFNbTzauCQiPzDS7EppYrBlTUr0ikhmvd/3snZc9rhpvI8txKNiAwFXgWmAdcClwGd7NOvisijXopPecmXX37Jxx9/7Na6w4cPJyoqv04hCs9b+1UFN6RzA46fPc/UlTrGofI8d0s0g4GRxpjBxpjFxpg/7M+DgVFAmUg05alTzYIkmv79+zNv3jzvBqR8qmV8JTo0iGLS4j9JPZ/p63BUGeNuoqkJLMxnWRJWR5ulnjFmtjFmgHMPxeVVeno6mZmZxMXF0bJlS1+Ho7zs0S4NOJqspRrlee4mmj1A93yWdbMvV6VEv379+Prrr1m0aBEigogwfPhwOnXqxO23386kSZOoV68ewcHBHDhwwOUlrmPHjjFw4ECqVatGcHAwCQkJvPXWWwDs2rULEeG7777Lc9zsoQEcLV26lBYtWhAcHEyzZs1YsmRJnnXef/99mjRpQlBQEPHx8bz22muee0MUAK1qV+bqelV4b/GfpKVrqUZ5TkE61RwnIpWBr7AaBcQAdwD9KCOXzsqLF198kT179nDy5Mmc4ZDj4uJISkpi6dKl7Nixg1GjRhEaGppn/BmwRrjs1KkThw8fZtiwYTRq1Ijt27ezffv2AseSkpLC3/72N5599lmqVavGmDFj6NGjB9u2baNqVavXo9GjR/Pcc8/x9NNP06lTJ9auXcuLL75IaGgojzzySNHeDJXLo10acPekFXy+ag/92tXxdTiqjHD3PprxInIOGAbcj3XzpgAHgEHGmPe9F2IpMPcZOPibb45dtSn0GFmgTerVq0flypXJysriqquuyrXs5MmTrF+/PudL3pUpU6awceNG1q1bR7NmzQDo3LlzgUMHK2m9/PLL3HvvvQBce+211KpVi7feeouRI0dy+vRpXnrpJV544QWGDRsGWCNspqSk8J///IeHHnoIPz+/Qh1b5XVV3Sq0rlOZCYt2cHfrWgQH6Huris7t5s3GmMlYdTXxQFv7c81yn2TKmJYtW140yQAsWLCA5s2b5ySZourdu3fO67CwMLp168aqVasAWL58OWfPnuWOO+4gIyMj59G5c2cOHTrEvn37PBKDuuCxLg04dPoc09fqe6s8o0C3ARtrOM699ofKVsASRUkWGxt7yXWOHTtGtWrVPHK8sLCwPAOtxcTEsGHDBgCOHj0KQJMmTVxuv3fvXuLj4z0Si7JcXa8KifGVmLBwO3cmxhHkr6UaVTT5JhoReRiYbow5Yn99MWVqKOfyTEQuuU6VKlUuWh8THGwND3z+/Plc848fP55n3eTkZFJTU3Mlm8OHD+ckssqVKwPw3XffuUyCCQk6loqniQiPdmlA3w9X8eXqvfy9bW1fh6RKuYuVaMYDa4Aj9tcXo0M5lzKBgYGkpaUVatsuXbowffp0NmzYwBVXXJFneUxMDAEBAWzevDlnXnJyMsuXL3dZ+pg5c2ZOHU1ycjLz589nwIABALRt25aQkBAOHDjAjTfeWKh4VcF1aBBF69qVGfvTdm5tEUcF7QNNFUG+nx5jjM3Va1U2NGrUiFmzZvHNN98QFxdH9erV3d62b9++vPPOO3Tv3p3hw4eTkJDAzp072bp1KyNHjsRms9GrVy/efPNN4uPjqVixImPGjMlziQwgJCSE559/nuTkZKpXr87rr7/O+fPneeyxxwCoWLEiw4cP57HHHmP37t107NiRrKwstm7dysKFC5k5c6bH3hN1gYjwzA2NuPXdZUz++U+Gdm3o65BUKaY/U8qphx9+mPXr13P//fdz4sSJnBZd7ggODmbBggU888wz/Otf/+L06dPUrl2bhx++cIV1/PjxDBgwgIcffphKlSrx/PPPs2zZMn7//fdc+woNDWXKlCkMGTKEzZs306hRI+bMmZOrDujpp5+mevXqvPnmm4wZM4bg4GAaNmzIXXfdVfQ3QuWrRa1K3NC0KpMW/0mfNvFEhwf5OiRVSolVv3+JlUQ6AJWNMbPs01FY99Y0Bn4CnjHGlJmRkxITE82aNWtcLtu8eTOXXXZZMUeklOcU5DO88+hZur2xiHta1+Lft1zu5chUSZCUlESnTp0Kta2IrDXG5Lkr291LYq8Bjp+ysUAXYAXWDZsvFSoqpVSJVieqAve0rsW0VXv480iyr8NRpZS7iSYBWAsgIqFAb+AxY8wg4GlAr2EoVUY92qUBwf42Rs/7w9ehqFLK3UQTCGQ3UWqHVbfzP/v0VsAzN1UopUqc6PAgBnSsx9zfD7Juzwlfh6NKIXcTzRbgevvrPsByY8wZ+3R1IO8NEiWEiFwuIutEZJuIfCsi4b6OSanSpn+HOkSFBTFyzhbcqddVypG7iWYE8LiIHAHuBRxvhb8eWO/pwDxoIvCCMaYBVsJ82sfxKFXqVAjyZ2jXBqzadZyfNh/2dTiqlHEr0RhjvsUaVXMQcLkxZq7D4uXAy54MSkTqi8h7IvKriGSKSFI+6zUWkZ9EJEVEDojICBHxc1geC9Qxxsyxz/oAuM2TsSpVXtzVqiZ1oyow8vstZGRm+TocVYoUpFPNP40xXxtjtjrNn2SMWeHhuJoAN2DV/2x1tYKIVAJ+xOqVoBdWqetJcreAiwMcewbcg9UxqFKqgAL8bDx9fQLbDyfzlXa4qQrArUQjIreJyAMO03VEZJmInBSRr0Wkoofjmm2MqWmMuQPYmM86g4AQ4FZjzHxjzESsJPOEiERkh4qViJRSHnBdk6q0qFWRN3/cqkM+K7e5W6J5AYhwmH4biMKqq2mBhy+dGWPcKZf3AOYZY047zPscK/lcY5/eR+4STC1yl3CUUgUgIjx3w2UcOn2OD5fu9HU4qpRwN9HUBX4DEJFIrGGdHzfGjASeB3p6J7yLaoRVuZ/DGLMHSLEvwxhzENglIjfYV3kAmFGcQSpV1iTWrky3xrFMSNrB0eRzvg5HlQIF6ess+xLUNUAmVv0IWCWEaE8G5aZKwEkX80/Yl2V7CPhERMYCf2A1z85DRAYAA8AakyUpKcnlQSMjIzlz5ozLZWXJ1KlTeeihhzhw4ABhYWEcOXKEyZMn06dPnwKP/xIREcHo0aMZOHCg28crbQYNGsTmzZtZtGgRAGvWrOGHH37gueeey7XeK6+8wqRJk9i1a5cPorSkpaXl+/l2V+fKWSzYnMGQDxYy8MpgzwSmSoTk5OQifz6cuZtofgX6iMgKoD+w0BiT/VOmFuCr9o6u6l9y1csYYzYAzS+5I2MmAZPA6ussv75+Nm/eTHh42b8V57bbbqNZs2bExsZis9nYvXs3I0eO5LrrruPyywve51VwcPBF3zfn45U2I0aMIDU1NeccN27cyMiRI3n11VdzrRcUFISI+PQzFBwcTPPml/yTuKSDQVsZ+9M2BvVowjUNffFbU3lDUfo6y4+7ieY5YDbwf0Ay1qWzbLcAKz0alXtOABVdzI/EdUlHFUB0dDTR0cX35VHcx/O0evXq+TqEYvfwtfWYveEAz8/8jR8e70hooHYGr1xz9z6aJVgll9ZAvDHGMbF8iNVYoLhtwV4Xk01EagIVcKq7cZeI9BSRSadOnfJAeCXb8uXLufnmm6levToVKlSgWbNmTJ06NWf5xx9/jIiQnJzMrl27aNq0KQDXXnstIpJrJM5jx44xcOBAqlWrRnBwMAkJCbz11lu5jpeZmclzzz1HdHQ0MTExDB48mHPnzrk8XrZXX32V+vXrExwcTGxsLNdffz0HDx7MWb5z505uueUWIiIiCA8Pp2fPnnlG/hQRxo4de9FjX8qUKVNo3749lStXplKlSlx77bU49+7dr18/EhMTc85lyJAhOccXkXx/IRpjGDJkCJUqVWLlSuvP6vjx4wwcOJDY2FiCg4O5+uqrc5Z58ryKKsjfj1d7N2XfiVTG/rit2I6rSh+3f4LYu5xZK5bqwGFjTIbDzZDFbS7wDxEJd+gO5y4gFVhUmB0aY2YDsxMTEx/0UIwl1u7du2nXrh2DBg0iODiYpUuXct9992Gz2bjnnntyrVutWjWmTp1Knz59eOedd2jRokXOstTUVDp16sThw4cZNmwYjRo1Yvv27Xm+8MeMGUPnzp357LPP2LBhA88++yzx8fE8/bTrjhqmTJnCK6+8wqhRo2jSpAnHjh1jwYIFnD17FoBz587RpUsXAgICmDx5Mv7+/gwbNoxrrrmG3377LWcI6MIc29muXbvo27cv9erV4/z580ybNo2OHTvy+++/U7du3Tzr33jjjTz55JOMGTOG5cuXA1Y9lbOsrCwGDhzIN998w4IFC2jevDnnzp2ja9eunDx5ktGjRxMTE8OECRPo2rUr27Zto2rVqh47L09oU7cK97SuyftLdtLzyupcXiOy2I6tSg+3E4295dYwoBngh1W6WScik4DFxpjPPBWUvYfo7JZiNYAIEbndPj3HGJOC1bXMo8AMERmF1TJuOPCGU5Nnrxu1ahRbjheqEFVkjSo34p+t/1ng7e6+++6c18YYOnbsyL59+5g8eXKeRBMUFJQzZHPjxo256qqrcpZNmTKFjRs3sm7dOpo1awZA586d8xyvdu3afPzxxwBcd911LF26lBkzZuT7pbhq1Sq6d++eazC1W2+9Nef1Rx99xJ49e9i6dWvOl32bNm2oW7cu7733Hs8++2yhj+3sX//6V87rrKwsunXrxurVq/nss89yLcsWHR1N7dq1AXK9V44yMzPp168f8+fPJykpiSZNmgDw2Wef8fvvv7Nx40YaNGgAQNeuXUlISGDMmDGMHj3aY+flKc9cfxnzNx3m2Rm/8c3gdvjZ5NIbqXLF3Rs2+wLfYl2SGuC03TasZsOeFANMtz+uwhpgLXs6BsAYcwJrTBw/rPqjl4A3sZKhuoQTJ07w6KOPEh8fT0BAAAEBAUyaNImtW112xJCv7F/i2UkmP927d8813bhxY/bty/+WpmbNmjFnzhyGDRvGqlWryMzMfXPgqlWraNGiRa4SRVxcHO3atWPJkiVFOrazzZs307t3b2JjY/Hz8yMgIIA//vijwO9VtszMTO6++26SkpJYvHhxTpIB+PHHH2nZsiV16tQhIyODjIwMAK655po8l+uKel6eEhkawPCbG/Pb/lN8vGxXsR9flXzulmieB0YbY5619yX2kcOyjcBTngzKGLMLq/XYpdbbBOT9+VxIItIT6Fm/fv0CbVeYEoWv9evXjxUrVvDiiy/SuHFjIiIimDBhArNmzSrQfo4dO5Zr2OX8VKxYMdd0YGAgaWlprlcG7r//fs6cOcOkSZMYMWIEVapU4aGHHmL48OH4+fnx119/ERsbm2e72NhYdu/eXaRjOzpz5gzdu3cnNjaWN954g/j4eIKDg+nfv7/b+3CWkpLC3Llzue2222jYsGGuZUePHmXFihUEBATk2c65wUFRzsvTbmxajRmN9jPmhz+4rkkscZVCfRKHKpncTTTxwPx8lqWRu9eAUqu81NGkpaXxv//9j/HjxzNo0KCc+VlZBe8osUqVKnnqYzzBZrPx+OOP8/jjj7N3716mTp3K888/T40aNRg0aBDVqlVj48a8vRMdOnQoV/1MUS1fvpx9+/Yxf/58GjW60PakKA1GwsPD+eKLL7jxxhupVq0aI0de6Ay9cuXKJCYmMmHChDzbBQUFFfqY3iYijOjVhO5vLuZfszbywf8l5mowoso3d29Y2Ev+96IkAp7/plFec+7cOTIzM3N9cZ05c4Zvv/02320CAwMB8vxi7tKlC+vXr2fDhg3eCRaoWbMmzzzzDPXr12fTpk2AVR+zdu1adu680A3K/v37WbZsGe3bt/fYsVNTU4HcX/LLli275A2X+b1f2bp06cL06dMZM2YML7/8cq7527dvp1atWiQmJuZ6ZLf8K6niKoXyZPcEFmw5zP9++8vX4agSxN0SzQfAMBE5BHxjnyci0gVrfJcRXohNeUlkZCStWrVixIgRREREYLPZGDlyJJGRkZw+7bodRa1atQgJCeGTTz4hMjKSgIAAEhMT6du3L++88w7du3dn+PDhJCQksHPnTrZu3Zrrl3pBDRw4kMqVK3PVVVcRGRnJwoUL2bZtG6NGjQKsS3+jRo2iR48ejBgxAj8/P4YPH05UVNRFeyAoqKuuuoqwsDAefPBBnn76afbt28fw4cOpUaPGRbfLLv2MHTuWzp07ExERQUJCQq51evbsyaeffkqfPn2IiIhgyJAh9O3bl4kTJ9KpUyeeeuop6taty7Fjx1i1ahVVq1bl8ccf99i5eUO/q2sz65f9DP92Ex3qRxMZmvcSoCp/3C3RjAI+BT7hwmiay4B5wBfGmHFeiE150bRp06hTpw59+/blscce47bbbqNv3775rh8cHMzkyZNZu3Yt11xzDa1atcqZv2DBAnr27Mm//vUvevTowWuvvUb16tWLFF/btm1ZvHgx9913HzfccAMzZ85k8uTJ3HLLLYBVwvjxxx9p1KgRDzzwAP/3f/9HfHw8SUlJHr10Fhsby/Tp0zl48CC9evXirbfeYuLEiVyqHq9Dhw784x//YOzYsbRp0ybf5Hf33XczadIkhg4dyscff0xwcDALFy6kW7duDBs2jO7du/PYY4+xbds2Wrdu7bHz8hY/m/BK76acSDnPq3M3+zocVUJIQYZlFZF6WC29orASzgLn8WlKM4fGAA9u2+b6BrTNmzdz2WWXFW9gSnlQcXyGX527mfcW/cl7f2/JdU2qXnoDVWIUpQsaEVlrjEl0nn/JS2ciEgycAu4yxnwD7ChUBKVAeWkMoJS3PdGtIct3HOOp6b9yWdUIalXRVmjl2SUvnRlj0rA6zczwfjhKFa/MzMyc+1WcH8737ij3Bfn78c69LRBg8LR1nMvQ97I8c7eO5j3gURHRmj1VptSrVy/nhlXnR3nsKNOTalYO5fU7ruS3/ad4+X9aX1OeudvqrCJwOdYgYj8Bh8jdRb8xxpS+uxZVuTd79ux8O6IsyfetlBbdm1TlwQ51mPzzTlrVrkzPK4vWSESVTu4mmtuA7L/GDi6WG6DUJ5rC9gygSq+Sfm9KWfD09Y1Yu/sEz874jSbVI6gbXfoGtlNF4+4wAXUu8cjbhW0pZIyZbYwZEBl58R5oC9JST6mSxBef3QA/G+PvbUGAn/Dw1HWkpWt9TXlT+oYy9LGAgICcu8WVKm1SU1Nd9qPmbdUrhvDGXc3YcvAMw7/N23WQKtvcunRm7705P1nAaeBXY8zui6xXJsTExLB//35q1KhBSEiI9uekSgVjDKmpqezfv99lZ6TF4dqEGB7uVI93k3bQuk5lbm0R55M4VPFzt47mYy5U/jt+szrOMyLyHdDHGJNMGZU9gNWBAwdIT0/3cTRKuS8gIIDY2FiXg7AVlye6NWTN7hM8P/N3mtaIpEFsuM9iUcXH3UTTAvgCeB9rXJojQDTQC+gPDAKqA+OwuqsZ7PFIi4G7jQEiIiJ8+seqVGnl72fj7Xuac+O4nxnw6Vq+GtSWKmHauq+sc7eOZgzwrjFmtDHmD2PMcfvza8C7wDD7CJsvA729Fay3udsYQClVeLERwUz4W0sOnEzl/o9Xc/ac3gte1rmbaNoC+d1xtRloZX+9FqhS1KCUUmVbq9qVGX9vC37bf4pBn63lfEbBx0JSpYe7iWYf0C+fZffZlwNUAo4VMSalVDnQrXEsr97alJ+3HeUfX/1KVpbeNlBWFWQo5/+KyOXAbC7U0fQEGgN329frBvzs6SCVUmXTXa1qcTT5PKPn/UGVCkG8eNNl2pKzDHIr0RhjpovITqy7/+8FqgIHgdXAfcaYtfb1HvZWoEqpsunhTvU4mnyOD5fuJDo8iIc6aR9zZY27JRqMMWuAO7wYi1KqHBIRXryxMceSzzPq+y1UCQvkzsSavg5LeZDbiQZARCphda5ZE5hrjDlhH6/mvDFGa/OUUoViswmv33ElJ1LO8+yM36gcGkjXxr65sVR5nluNAUTET0Rew6r0X4Q1rHMd++KvgWHeCa94iUhPEZl06tQpX4eiVLkT6G9jwt9a0qR6BIOnrWPVzuOX3kiVCu62OnsFeBB4BKhL7t4BZmE1Cij19D4apXwrLMifj/q1okalEP7vw1Us2nrE1yEpD3A30fQFnjHGfATsdVq2Ayv5KKVUkVUJC+KLAW2pE1WB/p+s5rsNB3wdkioidxNNRayE4kog4OeRaJRSCogOD+K/A66iWc2KDPnveqat3OPrkFQRuJtofsfq18yVHsA6z4SjlFKWyJAAptzfhk4No3lu5m+8m7Rdx4IqpdxtdfYf4GsRCQGmY/Xa3ExEegMDgZu9FJ9SqhwLCfRjUt9Enpr+K699/wcnU9J5tkcjvamzlHH3hs1ZInIv8Bpwv332+8B+4O/GmHleik8pVc4F+Nl4885mRAQHMGnxn5xMOc8rvZvi76fjNpYWl0w0IhIAtAaWGGNqi0hDIAo4DvxhtCyrlPIym00Y0asJFUMDeHvBdk6nZvDW3c0IDtDq4dLAnZ8EmcAC4DIAY8xWY8wyY8wWTTJKqeIiIjzZPYEXb2rM9xsPcvekFRw8lebrsJQbLplo7Hf8bwPK/G26esOmUiXfA+3rMKFPC7YeOsNNby/RGztLAXcvcj4P/EtEmnozGF/TGzaVKh16NK3GN4PbER7sz72TV/DJsl3aIq0EczfRvIA1oNkvIrJHRFaLyCrHhxdjVEqpPBrGhvPN4HZc0zCaYd9u5Mnpv5KWnunrsJQL7jZv/t3+UEqpEiMyJIDJfRMZt2Abb/24ja2HzjDxby2JqxTq69CUA3ebN9/n7UCUUqowbDZhaNeGNK0RydDPf6Hn20t4594WXF0/ytehKTttiK6UKhO6XBbLrEfaERUWxN8+WMnr8/7gfIaOXlISaKJRSpUZdaPDmDm4Hbe2iGP8wu3c8s5S/jh4xtdhlXuaaJRSZUpYkD+v33Elk/smcvhMGj3fXsLERTvIzNJWab6iiUYpVSZ1axzLvKEd6dwohpFzt3DXe8vZfeysr8MqlzTRKKXKrCphQUz4WwvevOtK/jh0hh5jf+azFbv1nptipolGKVWmiQi9m8fxw+MdaRlfiRe++Z2+H65i51Et3RQXTTRKqXKhWmQIU+5vzb9vuZz1e07S/c1FjJy7hbPnMnwdWpmniUYpVW6ICH+/Kp4FT11Dr2Y1mLhoB53HJPHN+v16Oc2LNNE40E41lSofYsKDef2OK5nx8NXERgQz9ItfuGPicn7fr3/73qCJxoF2qqlU+dKiViW+ebgdo25rys6jZ7l5/BKen/kbx8+e93VoZYomGqVUuWazCXe1qsWCpzrxf1fX5vPVe7nmtYWM+eEPTqZowvEETTRKKYXVQeewnk2Y+1gHOjSM4u0F22k/aiGj523hhJZwikQTjVJKOWgYG867fVoyb2hHrkmI5t2kHbQftYBR32/RS2qF5O4wAUopVa4kVA3nnXutkTzfXrCdiYt28MmyXfy9bTz929clOjzI1yGWGlqiUUqpi2gYG87b9zTnh6Ed6XpZLJMW/8nVI3/ikWnrWL7jmDaLdoOWaJRSyg0NYsMZd09zhnZtwNSVe/hq7T6+2/AXdaMr0KdNPLe3iCMyNMDXYZZIWqJRSqkCqBsdxos3NWblc10Yc8eVRIYE8O/vNtH6lR95avqvrNtzQks5TrREo5RShRAc4MdtLeO4rWUcGw+cYtrKPXyzfj9frd1HfJVQrmtSleuaVKV5zYrYbOLrcH1KNPPmlZiYaNasWePrMJRSpUzyuQy++/UAc38/yLIdR0nPNMSEB9GtcSzXX16Vq+pWIcCvZF9ISkpKolOnToXaVkTWGmMSnedriUYppTwkLMifu1vX4u7WtTidls7CLYf5/veDzFi3n6kr9xAR7E+Xy2JpW7cKLWtXom5UBUTKfmlHE41SSnlBRHAAvZrVoFezGqSlZ7J46xHmbTzEgi2HmLl+PwBVKgTSMr4SibUrkVi7MpdXjyTQv2SXeApDE41SSnlZcIAf3ZtUpXuTqmRlGf48mszqXSdYs+sEa3Yf54dNhwAI8rfRtEYk9WPCqBtdgbpR1nPNyqEl/pLbxWiiUUqpYmSzCfVjwqkfE849rWsBcPhMGmt3nWD1rhNs2HeSHzYdytULgb9NqFUllLpRYdSsHEKVCoFUrhBE5QoBuZ4jQwLwK2TDA2MM5zKyyPJCvb0mGqWU8rGY8GB6NK1Gj6bVcuadTDnPjiNn+fNIMn8etT8fOcvyHUc5ez7T5X5sYpWe/G1CgJ8NP/uzv5/kzEvPzOJ8ZhbnMxwemVmkZ1oJ5p+tguns4fMr84lGRCYANwPVjTFlv9ZNKVUmVAwNpGW8VYfjLC09kxMp5zl+Nu8j9XwmGVmG9MwsMjINGVmGjCzrdXpmFgF+NgL9bQRmP/vnno5K3ePxcynziQb4LzAcOOjjOJRSyiOCA/yoFhlCtcgQj+87KWmfx/dZ7LVLIlJfRN4TkV9FJFNEkvJZr7GI/CQiKSJyQERGiIhfQY9njFlsjDlU5MCVUkoVii9KNE2AG4AVQKCrFUSkEvAjsAnoBdQDxmAlxheKJ0yllFKe4ItEM9sYMwtARL4ColysMwgIAW41xpwG5otIBDBcRF6zz0NElgBxLrb/yRjzgHfCV0opVRDFnmiMMVlurNYDmJedUOw+B0YB1wCz7ftq7/kIlVJKeVJJbQzQCFjgOMMYs0dEUuzLZnv6gCIyABgAEBsbS1JSkqcPoZRSJV5ycrLHv/9KaqKpBJx0Mf+EfZnbROR94Hr7633A98aY/s7rGWMmAZPA6lSzsJ3KKaVUaVaUTjXzU1ITDYCr21Mln/n578RFUlFKKVV8SmrnOSeAii7mR+K6pKOUUqqEKqmJZgtWXUwOEakJVLAv8woR6Skik06dOuWtQyilVLlTUhPNXOA6EQl3mHcXkAos8tZBjTGzjTEDIiMjvXUIpZQqd4q9jkZEQrFu2ASoAUSIyO326TnGmBRgIvAoMENERgF1sbqRecOpybNSSqkSzheNAWKA6U7zsqfrALuMMSdEpAswHqsp80ngTaxko5RSqhTxxQ2bu7Baj11qvU3g8d6qL0pEegI969evX6jtR826ly0ntwECIg7P5J7n8uD2Z2P/xxgXz04biOOGzkzu/eWaZ1y/do4zJ15xiM9xXyb3/o3TcXCxjXG1bfZym3VMERCb/bi2C++hMWCyLrwfjq9x2C7n4TDt8v00Tufv9H+U6/xdvC+5/j9dxeS8//w4fkac5znsmyz7MVwcx2HV3C/s74HN8X3xu/Aa8nlPs1x85grDMTbnz6HjcpNP7I7vt8P/aXYDVJN1IVbH12TlPleb34Vpm5+1H+P0/5Tn/y4rn/1nOcTn8Jl1/vy6er9tNms9DJhMyMpyOo7D/nPi4UI8ud6ni8j1N0Tu2PL8f+R+3yuHNKUTndw4iPtKcvPmYmeMmQ3MTkxMfLBQO8jKtB65EsPFkgUX1sl+yvmjgot+qVkB590HOKwHuRKd87Q4JivHluMOf3jOsV/0i9jp2LmO53g+TufmeA6uvuyyMi+sa/Mj9x9N9h+Uiy+GrEww6dZ0niSRvQ+/3Md3/MPOysodV058zknEuIjJMTZ3XOz/1OkLTfxcfy6c3+uc2LPsX2iZud+T7C80V1+SiP1L8WK/Cd36xnOKzc3PZk7sLn5cZD9y4gwgz48LxGHdTIdzP3/hy91Vgsj1g8XfRdJwSND5JX7HGHPe70yH/4es3Pty/BFg8wMJuBCH8/PFfqw6/r+4+pzmxGl/j13+qIEsW4H7Lr4kTTQe9M/eX/g6BKWUKhJv9IpSUludKaWUKiM00TjQ+2iUUsrzNNE40PtolFLK8zTRKKWU8ipNNEoppbxKE41SSimv0kTjQBsDKKWU52micaCNAZRSyvPEeKSbibJFRI4Au30dRykRCZS3ImBpO+eSEm9xx+HN43lj357Ypyf2EQUcLeS28caYaOeZmmhUkYjIJGPMAF/HUZxK2zmXlHiLOw5vHs8b+/bEPj20jzXGmMSi7MOZXjpTRTXb1wH4QGk755ISb3HH4c3jeWPfnthnSfm/zkVLNEoppXJoiUYppZS3TfL0DrVEo5RSyqu0RKOUUsqrNNEopZTyKk00yqdEpK6IfCAiX/k6luJU2s67tMXrCeXxnC9FRC4XkXUisk1EvhWRcHe200RTjohITRFZKCKbRWSjiDxWhH19KCKHReR3F8uuF5E/RGS7iDxzsf0YY/40xjxQ2DjcISLBIrJKRH61n/dLRdhXsZ23iPiJyHoR+a40xFtUIlJRRL4SkS32z2jbQu6n1JxzKTQReMEY0wDYAjzt1lbGGH2UkwdQDWhhfx0ObAUaO60TA4Q7zavvYl8dgRbA707z/YAdQF0gEPgVaAw0Bb5zesQ4bPeVF89bgDD76wBgJXBVST9v4AlgGvCdi2UlLl4P/D99AvS3vw4EKpb1cy6OB1AfeM9+vplAUj7rNQZ+AlKAA8AIwM9heSyw32E6AdjkVgy+fhP04bsHMAvo5jTvDmABEGyffhCYk8/2tV38MbcF5jlMPws860YsxfLHDIQC64A2Jfm8gTj7H33nfBJNiYrXA/8vEcBO7C1h81mnTJ1zcT2AXsBeYDqw2VWiASrZk8uPQDdgEHAW+I/DOi2BlQ7TIcAZd2LQS2fllIjUBppj/brPYYyZDnwPfC4ifYD7gTsLsOsaWB/qbPvs8/KLo4qITASai8izBThOgdgvQ/0CHAbmG2NK+nm/hXVZIsvV9iUw3qKqCxwBPrJfLnxfRCo4rlAGz7m4zDbG1DTG3AFszGedQViJ41ZjzHxjzETgJeAJEYmwryNAoe6H0URTDolIGPA1MNQYc9p5uTHmNSANmADcbIxJLsjuXczL98NpjDlmjBlkjKlnjHm1AMcpEGNMpjGmGVZJobWIXO5inRJx3iJyE3DYGLP2YgcsKfF6iD/W5a4JxpjmWL+m89ShlLFzLhbGGJc/Vpz0wCrtOX4ffI6VfK6xT+8Dajosr2Wfd0maaMoZEQnASjJTjTEz8lmnA3A5MBMYVsBDOH8Y47CK5CWCMeYkkARc77ysBJ13O+BmEdmF9cfeWUQ+c16pBMXrCfuAfQ4lza+wEk8uZeycS5JGWJX7OYwxe7DqaxrZpw8Cu0TkBvsqDwAuv0OcaaIpR0REgA+AzcaYN/JZpzkwGeu67n1AZRH5TwEOsxpoICJ1RCQQuBv4tmiRF42IRItIRfvrEKArTn9UJem8jTHPGmPijDG17ftZYIz5W0mN1xPsX2J7RSTBPqsLsMlxnbJ2ziVMJeCki/kn7MuyPQS8LCLbsBoPvObOzjXRlC/tgL9j/UL+xf64wWmdUOAOY8wOe5H7/3AxNo+I/BdYDiSIyD4ReQDAGJMBPALMw6p4/NIYk9914eJSDVgoIhuwvmzmG2OcmwyXtvMubfG6Ywgw1f7/1Ax4xWl5WTznksTVZcRc9TLGmA3GmObGmAbGmJuMMW6NfaN9nSmlVDkh1s2nUcaYTk7zDwPvGGNecpqfDLxkjBldlONqiUYppdQW7HUx2USkJlABp8vMhaGJRiml1FzgOsndpcxdQCqwqKg79y/qDpRSSpVcIhIKZNfF1gAiROR2+/QcY0wKVtcyjwIzRGQU1n1Nw4E3XN0CUeAYtI5GKaXKLvvN2TvzWVzHGLPLvl5jYDxWDwongfeB4caYzCLHoIlGKaWUN2kdjVJKKa/SRKOUUsqrNNEopZTyKk00SimlvEoTjVJKKa/SRKOUUsqrNNEopZTyKk00SrkgIh+LyBofx/CViCQVYftOImJcDfLmtN7r9rFvsqdbi8hwF+sNF5GjhY1HlV+aaJQqu9Zh3eW9o4Dbtabgg4oplS/t60ypMsreR9UKX8ehlJZolLoIEblFRLaISJqILLH3B5W97EkRWS0ip0TkkIjMFpH6Ttsn2S+B3Ssi20XktIjMFZE4p/VqisgcEUkVkV0i0t9peV37ZbCrHeb91z7vCod5s0Vkqv11nktnIlJRRKaJyFkR+UtEnnc6Tj/gbftrY38kOa3TXERWiEiKiKy3D6+sVL400SiVv3jgDeDfwL1AJDBPRILty+OwOiHsBTwI+AFLRSTSaT9tsEZ2fBIYALQAJmUvtA+xPQu4HGsc9ieAx7AuewFgjPkT2A84fql3ANKy59n30w74+SLn9BHQAxhqj6U71pDG2f4HjLG/bmt/POywPBT4BHgPuA04B8y09xCslEt66Uyp/EUBvYwxywBEZC1WfUc/YKIx5vHsFUXED5gPHMZKPFMc9hMB3GiMOWFftyrwpoiEGGNSsb74mwNXGWNWOh1rm8N+fsZKKqNEpC7WENXv2ee9AzTFGt/dZaIRkSbALcDdxpgv7PMWAnuA0wDGmCPZDQOMMa4uu4UAQ40xC+zb/wWsBzoC37t+G1V5pyUapfJ3ODvJABhjdgNrsSrLEZGrRGS+iBwDMoAUIAxo6LSf1dlJxm6T/bmG/bk1cCg7yTgdy9HPQDsRsWF9sW8AZnOhlNMROO6wf2et7M/fOhwnGStBuisdSHJxLnF5V1XKoolGqfwdzmdeNRGpBfwACDAQ65JVK/vyYKdtTjpNn7c/Z69X9SLHcrQYqIh1ia0DVuJZClS1l3A6AEtM/mN/VAXO2EtRFzvOxZw2xmRlTxhjnM9FqTz00plS+YvJZ95G4Hqs+opexpizACLiD1QuxHEOXuRYjklhI1aJpQNW6eVZY8xpEdlgn9cBq07pYscJd7hk53gcpbxGSzRK5S/GqZVXLayK/FVYdRVZWJfMst1J4X68rQZiRaSNi2PlsJdUltqPUx+rhIP9+X6sOpuLNQRYbX++2eE4YUA3p/XO25dpKUV5hJZolMrfUeBTEXkRq2QxAusy08dAA6xWZh+JyAdAE+Ap8l4mc8cc4Fdguoj8E6slWfaxnC0GRgN/GGOyl/+MNd57CtZNmi4ZYzaKyLfABBGJAP4C/mHfztEW+/NjIrIA63LZH4U4L6UALdEodTG7sb6IhwOfY7XMus4Yk2aM+Q24D6vp8ndYzZ/vAE4V9CD2ksrNWBXrHwJvYTWbXu5i9ewSy2IX81YaY9Ivcbh+WHVLbwEfAD9hnZvzMUZjNbFeidWyTalCk/zrDZVSSqmi0xKNUkopr9JEo5RSyqs00SillPIqTTRKKaW8ShONUkopr9JEo5RSyqs00SillPIqTTRKKaW8ShONUkopr/p/EE85Ym2ioUMAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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": 11,
   "source": [
    "# eg_length = 50\n",
    "# np_x = np.linspace(-4, 4, eg_length)\n",
    "length = max(np_x) - min(np_x)\n",
    "pdf_true = gaussian(np_x, mean[0], np.sqrt(cov[0][0]))"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "source": [
    "bws = [0.1, 0.2, 0.5]\n",
    "kernels_kde = ['gaussian', 'cosine', 'linear', 'exponential']\n",
    "fig, ax = plt.subplots(nrows=1, ncols=2) # figsize=(10, 5)\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(bbox_to_anchor=(-0.2, 1.3, 13.0, .102), ncol=6, mode=\"expand\", prop={'size': 20}, 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/Gaussian/pdf_est.pdf')\n",
    "plt.show()"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABM8AAAFUCAYAAAAzjhvpAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAACfCUlEQVR4nOzdeXydZZ3//9fnrNn3NG2TpimlLGUrbVlb2ZFNFpVREHF+MoiMg6gMmwvMfMetKDqAAoq4jCCDOoqyiUCLIGVpi2wtUFpKl6Rt9n056/X74yQlpEmbNGdJyvv5ePTRc+77uq/rk9znPufcn1yLOecQERERERERERGRnXkyHYCIiIiIiIiIiMhEpeSZiIiIiIiIiIjICJQ8ExERERERERERGYGSZyIiIiIiIiIiIiNQ8kxERERERERERGQESp6JiIiIiIiIiIiMwJfpAIbz0ksv1Xi93ss8Hs8ZzrniTMcjIiIiIiIiIiJ7HzNrjcfjf4nFYnctWLBg47BlnHNpDmvXXnrppRq/3//HioqKoqKios5AIBAxs0yHJSIiIiIiIiIiexHnHOFw2N/W1pZfX1/fFolEPjZcAm3CDdv0er2XVVRUFFVUVLQEg0ElzkREREREREREJOnMjGAwGKmoqGipqKgo8nq9lw1XbsIlzzwezxlFRUWdmY5DREREREREREQ+GIqKijo9Hs8Zw+2bcMkz51xxIBCIZDoOERERERERERH5YAgEApGR5t2fcMkzSHSbExERERERERERSYdd5aImZPJMRERERERERERkIlDyTEREREREREREZARKnomIjMFVV1013cwWPPzww/mZjkUkk3QtyESydu3agJkt+PjHP14zsO3jH/94jZktWLt2bSCDoYnIXiBZn3l6X5LRGO4zbVduu+22UjNbcNttt5WmOLQPNF+mA5D3M7MFYyl/6623brzyyiubUxWPiIiIiIjI3uy2224r/dKXvlSje6uJ7chvP3lIQ2dowiYep+QHwyu+fsrrmY5jrK666qrp//3f/z3toYceevsjH/lIZ6bjmaiUPJtgvvKVr2wbuu1nP/vZlK6uLu9nP/vZhqKiotjgfQsXLuxJX3Qics011zRcfPHFLfvuu28407GIZJKuBZnofvjDH9Z94xvf2F5TU6NV3EVkXPSZNzE0dIYCG5ec9VKm4xhJzfWPjKkjTLJcdNFFbR/60IfWVFdX6/MuhZQ8m2B++MMfbh267be//W1pV1eX97rrrqvff//99YYtkkHTpk2LTps2LZrpOEQyTdeCTHQzZ86MzJw5UzcSIjJu+syTiay0tDRWWloa231JGQ/NeTaJHXnkkfub2YK+vj67+uqrp9XU1BwcCATmD4yN3tXY/F2No+7s7PR89atfnXrAAQfMzc7OPjwnJ+fwefPmHfDTn/60JPU/lUxm8Xicb37zm1Nmz559UDAYnD9lypRDP/OZz1Q3Nzd7KysrD6msrDxkoGxzc7P3hhtuqDj66KP3q6ioONTv988vLi4+7KSTTtp36dKluUPr3t3Y/4HrYWg8P/rRj0oPP/zwA4qLiw8LBoPzp06deujixYvn/OxnPyseXPbFF1/MPvvss2dVVlYeEggE5hcXFx82d+7cAy+55JIZoVBox5rFI11X99xzT9G55547q6am5uCB6+aggw468Fvf+taUWGznz7LBc158//vfL9tvv/3mBoPB+aWlpYddeOGFM5ubm72j/b3LB9dTTz2Vc9ZZZ+0zZcqUQwOBwPzy8vJDFy1aNOfuu+9+3+v77rvvLl64cOH++fn587Kysubvt99+c7/61a9O7e3t3Wk97vFeC2a24Mgjj9x/27ZtvgsvvHBmeXn5oYFAYP6+++570K233jriXBx/+MMfCo4//vh9i4uLDwsEAvNnzJhx8Oc///mqpqYmXQuyR4abW2jwZ8natWsDH/nIR/YZ+Hw4+OCDD/zf//3fwpHq++lPf1py1FFH7VdQUDAvGAzO32effQ669tprpw13He3pZ8Ibb7wR+Pa3vz1lv/32m5uVlTX/yCOP3D9pvxDZqyxbtiz39NNP36esrOwwv98/f+rUqYd+6lOfmrlx40b/QJlTTjlltpkt+Pa3vz1l6PFf+tKXppvZgk9+8pMzB7Y9/PDD+Wa24Kqrrpr+5JNP5h577LH75efnz8vNzT188eLFc5555pmc4WJpbm72/tu//VtlTU3NwcFgcH5BQcG8xYsXz/nTn/600z3I4Daee+657BNOOGHf/Pz8ednZ2YcfccQR+z/xxBM7fQcEiEQiLFmypPywww47IC8v7/Ds7OzDDzzwwLnf+c53yodeU2O9zo888sj9v/SlL9X0/15qzGzBwL+B949kff8TGavRvIZHmvNsNN/pKisrD/nv//7vaQBnn332foNf/4Preu2114KnnXba7IKCgnnZ2dmHH3744Qfcf//9hSO1PXDv19LS4rn00kurKisrD/H5fPOvuuqq6QAbN270X3311dPmz59/wMD72JQpUw49++yzZ/3jH//IGu73MHBdr1mzJnj66afvU1RUNC83N/fwRYsWzVm5cmUWwNatW3d8/xz4fT300ENJmZ9XPc/2Ameeeebs1157LfeEE05oLy8vj0yZMmWP/yrS1NTkPe644/Z78803c+bOndvziU98oikej9vTTz9dcPnll89as2ZN1m233bZT7zgRgM985jPVv/nNb8rLy8sjF154YWMgEHCPP/540QknnJAbiUTM7/e7gbKvvPJK1pIlSyqPOOKIrpNPPrm9qKgoumXLlsDSpUuLTjvttIL7779//fnnn98xnniuvPLKyttvv31qZWVl+CMf+UhrYWFhbPv27f5XX3019w9/+EPx5z73uVZIfLAcf/zxB5qZO/nkk9tnzpwZ6ujo8L777rvBe+65p/y///u/64LBoNtVWzfeeGOlx+Nh3rx53dOnTw+3t7d7ly9fXnDDDTfMWLVqVe6f/vSnd4c77itf+UrV3//+94KTTjqp/fjjj+9Yvnx5/v3331/27rvvBl944YW3x/Pzy97tBz/4Qdl111030+PxuJNPPrlt9uzZocbGRt+rr76ae9ddd0259NJLWwGuuOKKyttvv31qUVFR9JxzzmnJy8uLL1u2rHDJkiWVS5cuLfz73//+9sDrOxnXAkBHR4f3mGOOOSAQCMTPPPPM1lAo5Hn00UeLv/zlL9d4PB6++MUvvm8+mauvvnraD37wg+mFhYWxk046qa28vDy6Zs2a7Lvuuqti6dKlhStWrHizpKQknprfpHwQ1dbWBo455pgDZ8yYEfrYxz7W0tra6n3kkUdKPv3pT++bl5f39tlnn/2+OV8+8YlPzPz9739fVlFRETn99NNbCwsLYy+99FLe97///elPP/10/rPPPvu2378jZ7HHnwlXXHFF9cqVK/NOPPHE9lNOOaXd61XuWHZ26623lv77v/97jd/vj59yyiltlZWVkXfeeSf429/+tuzJJ58sXL58+Vtz5swJ/+Y3v9l4+OGHz/2v//qvqhNOOKFz0aJFvQB//vOf83/84x9Pmz17dt/dd9+9ZWj9q1atyv3xj3889dhjj+3453/+58YNGzYEH3/88eIPf/jD+X/605/ePv3007sGyjY1NXmPPvroA955552sgw8+uOfMM8+sb25u9j3yyCMlH/vYx/a76aabNl1zzTVNQ9t4+eWXc+68886KefPmdV944YVNtbW1gb/+9a/FZ5999v4vvvjimsMOOyw0UDYUCtkpp5yy77PPPltQU1PTd8455zRnZWW55cuX53/961+vXrFiRd5w19Ror/NPf/rTTQUFBdGlS5cWnXzyyW2HHnpo70Adu+vNs6fXushojPWzarDRfqf7/Oc/X//www8Xr1y5Mu9jH/tY88yZM3ca6fbyyy9nnXjiiQe0t7d7TzjhhPaDDjqod+PGjcGLL7549vHHH98+UgyRSMSOO+64/dva2nzHHXdcR35+fmzWrFkhgMcffzzv9ttvn3rUUUd1nnHGGT15eXmxd955J+uxxx4rXrp0adHSpUvfOuaYY3qH1rlly5bg4sWLD9hnn336/umf/qlp8+bNwSeeeKLowx/+8P7PPPPMW2eeeeacvLy8+Nlnn93a2trqffjhh0vOP//8OatXr149Z86ccY3iU/JsL1BbWxt4/fXX1ySjK/HnP//5GW+++WbO17/+9dpvfetb9QPbe3p67LTTTtv3xz/+8bQLLrig9dhjj93phSwfbI899ljeb37zm/KZM2eGVq1a9WZZWVkMoK+vr27x4sX7NTY2+qdPn77jDWvevHl9mzdvfm3o6/add97xH3PMMQdee+21M84///w144np3nvvLZ8yZUrkzTffXJOfn/++G+9t27bteP+7++67S0OhkN1zzz0bPv3pT7cNLtfY2OjNy8vb7U37ww8/vP6ggw4KDd4Wi8X4p3/6p5oHHnigdNmyZQ0nnXRS99DjXn755dx//OMfbwy8mUciEY455pj9X3zxxfynnnoq58QTT9S8hrKTl156Keu6666rzs3NjS1duvSthQsX9g3e/8477/gBnnzyydzbb7996tSpU8Mvvvjim9XV1VGASCRSe9ppp+371FNPFf7Hf/xHxZIlS7ZDcq4FgLVr12Z/4hOfaPrNb36zyefzDcRcf9RRRx10yy23TB2cPHvooYfyf/CDH0yfN29e9xNPPLFu4L0D3pvA+Zprrqn8+c9/vtMNnsieWrFiRf5VV1219Qc/+MGOuWb/8Ic/tJx//vlzbr755orBNyS33XZb6e9///uyU089te2Pf/zjhry8vB0J5IFJlpcsWTLlhhtuaBjYvqefCatXr85ZuXLlGwcccICm6ZBhvfbaa8Grr7565vTp00NPP/302lmzZu0Ymvzggw/mf/SjH93vC1/4wownnnjinYqKitj//M//bDjjjDP2v+iii2a/+uqrb3R1dXkuvfTSWYFAIH7//fe/M/T7EcDf//73gm9/+9ubv/a1rzUObLv33nuLLr744tmf//znazZs2LB6ILF75ZVXVr3zzjtZF154YdO99967yeNJDGx6/fXXtx977LEHfv3rX68+55xzOoZOPfO3v/2tcOjk/N///vfLrr322pnf//73K+69997NA9u/+tWvTnv22WcLPvOZzzT8/Oc/3zLwuRKNRvnUpz418/e//33Zvffe2zr0c2u01/lADEuXLi0655xz2sayYMCeXusiozGWz6qhRvud7sYbb2xoa2vzrVy5Mu+zn/1s83ALBnzhC1+obm9v9y5ZsmTzddddt+N94Xe/+13BJz/5yTkjxdDY2Ojfd999+5577rm1BQUF73uvOeusszr/6Z/+6dXi4uL3bX/++eezTz755AOuu+66qmeeeWbd0DpXrlyZd+2119bddNNN2we2XXPNNdNuvvnm6YsXLz7wrLPOarnnnns2D7xH3X777R1XXHHFrCVLllSM97vk5Eqe/enfZtDwxrDdhSeMKXN7OO/2tH7Bv/HGG7cmI3G2fft275///OfSgw46qGdw4gwgJyfHfe9736s99thj5/76178uPfbYY2vH294HxQ3Lb5ixvnX9hH7d7lu8b883F31zXK/bX/7yl6UAV1999bbBN79ZWVnuO9/5Tu1pp512wODyI/0lb/bs2ZEzzzyz9X/+53+mrFu3LjDuvxD4fM7n8+3UU2a4ayYnJ2enL5Dl5eWj6nM/9IsTgNfr5aqrrmp44IEHSh999NGC4b48XXPNNdsG/4x+v5+LL7646aWXXsp7/vnnc5U8G5utX/v6jNC6dRP6egvOmdMz/TvfHtf1dtttt5XHYjG76qqrtg5NnEHiOgK4++67ywD+/d//fdtA4gwSr7Nbbrlly+GHH1547733lg8kzwaM51oAyMrKit955507bnAAFixY0Hf44Yd3rVq1Kq+1tdUz8GXptttumwLws5/9bOPg9w5I3NDceeedFQ888ECJkmdjt/TXb85oqeua0NdDSWVez8mfOTDt53b69Onhm2666X2LNH384x/vmDZtWvi1115737CxO++8s8Lr9br77rtv4+DEGcD3vve9rb/85S/Lf/e735UOTp7t6WfCF7/4xe1KnO2Zv955y4ymLZsm9Ou9bMbMntP+9cvjer3feuutU6LRqH3ve9/bMjhxBnDOOed0nnTSSW1PPfVU0cD77Kmnntp97bXXbv3ud79befHFF89sbm72NTU1+X/wgx9sGu7zA6C6ujo0+AYZ4NOf/nTbbbfd1rVy5cq8xx57LO+ss87qCoVC9sADD5Tk5OTE//u//7t2IHEGcMghh4QuueSShttuu23az372s9Kbb775fdfb/Pnzu4Ymqa688srmr371q9WvvPLKjmswFovxy1/+srysrCxy9913v+9zxefzcccdd9T+3//9X9l9991XMjRBMJbrfE/t6bUuMhrJeA2P9zvd+vXr/S+88EJ+dXV16Oqrr37f+8InPvGJjltuuaXj+eefLxjp+B/84AdbhibOACorK4fNXxxzzDG9Rx99dOfy5csLQqGQDR3xMH369PC3v/3t931vveyyy5pvvvnm6eFw2G6//fbawb22P//5z7d86Utfqlm9enX2KH/kEU2u5JkM60Mf+lBS3pCfffbZ3FgshpkxMBZ5sEgkYgBvv/32TmOQRVavXp0DcNJJJ+3014qTTjqp2+v17pTAevzxx3NvueWWin/84x95LS0tvoHX2IBNmzb5x5M8O++885r/53/+Z8r+++9/0Nlnn9164okndp544ondQxN3n/rUp1p++ctfVlx00UWzTz/99NaTTz6588QTT+wa7gvRSLZv3+79r//6r6lPPvlkYW1tbbC3t/d9c0pu3bp12GW1jz766J2u34Hu0q2trXqPlmG99NJLeQDnnHPOLoc2v/766zkAp59++k7X5aGHHhqqqKgI19XVBZqamrxlZWWxZFwLADNnzgwNN8xyoPdpc3OzdyB59vLLL+f5fD533333ldx333071RWJRKy1tdW3fft279SpUzWBjCTFgQce2DP4JnzAtGnTwq+88krewPPOzk7P2rVrs4uKiqLf+c53Koary+/3uw0bNrzvu9GefiYcc8wxusmWXVq1alUuwN/+9rf8FStW7HTz3Nzc7I/FYqxevTrrQx/6UA/At771re1///vf8x966KESgI985CMtV1111U5DKQcceeSRXcMNGV68eHHnypUr81566aWcs846q+vVV1/N6uvr88yfP7+roqJip/fnU045pfO2226b9uqrr+6U1DzssMN2+uNgMBh0paWl0fb29h2Nv/baa1ltbW2+mTNnhq677rqd7k/6j4uvX79+p/uT0V7n47Gn17rIaIznNZys73QrVqzIgUTCe7j3hWOOOaZrpORZMBh0Rx111Igj1u6///7Cu+66q/z111/PaW1t9cVisffdC27fvt03dOGfuXPn7vQ7qampCff/Hxrak83n81FaWhrdvn37uK/FyXVjluYeXZPFjBkzkrKSVGNjow8SSZCBRMhwuru7tdDEGIy3R9dk0dnZ6QWoqqra6a8IPp+PoqKi932p+vWvf1302c9+dnYgEIgvWrSoY9asWaHc3Ny4x+Ph2WefzV+5cmVeX1/fuF5rd99995bZs2eH7r333rI77rhj6h133DHV6/W6448/vv3WW2+tPfjgg0MAJ554Ys9jjz321re//e1pjz32WPGf/vSnUoCampq+66+/ftvnP//5ll2109TU5F24cOHcurq6wCGHHNL9sY99rLmkpCTq8/loa2vz/vKXv5wyeKL1wYbrgTfwgTD0A0R2b7w9uiaLgett4MvC7sqNtHR5eXl5ZNu2bYGWlhZvWVlZbLzXwoCCgoJhk1wDvUAHv7bb2tq8sVjMBiarHUlHR4eSZ2OUiR5dk0VhYeGwryWv10s8/t737qamJq9zjtbWVt/uXqODj9nTz4SqqiqtDrqHxtuja7Joa2vzAfz0pz8dNpk7oKOjY8d3KI/HwznnnNP67LPPFgBcddVV9SMfCVOmTBn2dTh16tQIwEByq7W11bur8gOv546Ojp3uuId+Lxzg8/lcPB7fcX00NjZ6ATZt2hTc1TXY3d29Uxujvc731HiudZHRGM9rOFnf6dra2gau82F7ilVUVIw4Aq6kpCQyuEfqYN/61rem3HDDDTMKCgpiixcv7qiqqgrn5OTEzYxHH320aO3atdl9fX07XT/DfcccmHM0Pz9/xPeVaDQ67mtxciXPZFgjvSA9Ho+DxHwAQw23kt/Ah9i//Mu/1N99990aliljkpeXFwOora31zZ0793039NFolLa2Nm9FRcWOd/lvfvOblX6/3y1fvvzN+fPnv2/YwKc+9amZK1eufN9fUwZe5yO98Q33xczn83HDDTc03HDDDQ11dXW+J598Mu+3v/1tyV/+8pfiM888M3vt2rVrsrOzHcApp5zSfcopp6zv7e21Z599NueRRx4p/MUvfjHl8ssvn1VRURE577zzRpxT4Lbbbiurq6sLfOUrX9n2wx/+8H0Lajz55JO5v/zlL3da5UpkPAa+HGzcuDFQXFw87LCbweW2bNniH+4vjY2NjX6AkpKSHV82xnMt7OnPEo/Hrb29/ZVk1iuSDAPXxoEHHtjzxhtvvDmaY8bzmWCm+2zZtYH39ebm5pdHu5DK66+/HvzP//zPGQUFBbGuri7v5z//+ZpXXnnlzZycnGEXgGloaPAPt3379u1+eO+Gvri4OLar8rW1tf7BMe+JgTZOPfXUtscff/ydPa0nFfT9Tya6ZHynG7jeGxoahs0d1dfXj5hTGukzLRKJ8L3vfW96WVlZZNWqVW8O7V22YsWK3LVr1457mGWyqQfRXmzgw2bTpk07dVF84YUXdurmfdxxx3V7PB5eeOGFpCzlKh8sBx98cA/AsmXLdnr9LFu2LHdoL6rNmzcHZ8+e3Ts0cRaLxVixYsVO3ZDLysqiMHz395aWFs+mTZuCu4qvsrIy+s///M9tjz766Iajjz66c8uWLcFVq1bt9KacnZ3tTj311O5bbrll63e/+93NAA888EDRrupev359EOCCCy5oHbpvuN+HyHgtWLCgC+DBBx8ccY4JeO+6fPzxx3d6Ha5evTpYX18fqKysDA+dawz27FrYE/Pmzevu6Ojwrlq1SlMCyIRTWFgY33ffffvWr1+fXV9fP6qlL/WZIKk0f/78bhj+fX04vb299slPfnKf3t5ezy9/+csN//Zv/7Zt3bp12ZdeeumMkY5ZuXJlXiy2c77r2WefzQdYsGBBD8Chhx7al5WVFX/rrbdyBnqIDbZ06dJ8gHnz5u3x/K3z5s3ry8/Pj73yyiu5qezFNTC9yFh6/etal8lid9/pBr3+dzr2qKOO6gH4xz/+Mez7wvPPPz/mIdDbtm3zdXZ2eufPn989NHHW3t7uWbNmzYScv1LJs73YwLwZ99xzT1kk8t5rcv369f7vf//7O3V7rqysjJ5zzjnNa9asybnmmmumDT5mwJo1a4JvvfWWxu7LTv75n/+5GeDmm2+eNrhnY19fn33961+vGlp++vTpoU2bNmVt3Lhxx18r4/E4V1999fR33nlnp5vo4uLi+KxZs/pefvnlvJdeemnH/mg0yr/+67/OGDrEs7e31/785z/nD+3SHAqFbGDIQ25ubhwSK4UO1xuzvr7eD8NPtDnYwNC5J5544n1flJYvX579ox/9aOqujhXZE1deeWWj1+t1P/zhD6cPvh4GDKy2eemllzZB4rrcunXrjr8MRqNRvvzlL1fF43EuuuiiHZO/jvda2BNf/vKX6wE+97nP1Qx+PxjQ0dHhWbp0aVImdhbZE//2b/+2PRKJ2EUXXVTT1NS00/XR2NjoffbZZ3d80ddngqTSV77ylQafz+euv/76Ga+99tpOfzjs6+uzxx57bMfN7OWXX1715ptv5lx++eXbP/axj3X88Ic/3Dp//vyu//3f/y2/++67i4drY9OmTcGbbrqpfPC2e++9t2jlypV51dXVodNPP70LEotCnXfeeS09PT2eq6+++n3zka1Zsyb485//fIrP53OXXnrpqFevHMrv93PJJZc0NDY2+i+55JIZXV1dOyW3Nm3a5B/us3AsBv6ItHnz5lHf5+hal4lsLN/pSktLo5AY0TC0/L777hs58sgjOzdv3hy8+eab3/e+8H//938Fu1osYCSVlZXRrKys+OrVq3Pa29t33MOFQiH73Oc+N2PgXm2imZBBSXKcdNJJ3QsXLuxatWpV3mGHHXbg4sWLOxsaGvxLly4tPO644zoeffTRnS6On//855vffffdrJtvvnn673//+9Ijjjiia8qUKZFt27b5161bl7169eqcn/70pxu0EpQMddZZZ3VdeOGFTf/7v/9bNnfu3IPOPPPMVr/f7x5//PGi/Pz8WHl5eWRw190vfOEL9ddee+3MBQsWzD3jjDNa/X6/W7lyZd4777yTdeKJJ7Y/9dRThUPbuPLKK7d/5StfqTnxxBMPOOuss1qDwWD8ueeey49EIrb//vv3Du7e293d7TnvvPP2mz59evjwww/vnjFjRqivr8/zzDPPFGzYsCHrpJNOahvo9XbzzTdXLF++vODII4/snDlzZjgvLy/21ltvZT/zzDOFBQUFsSuuuGLESXUhscLLHXfcMfXGG2+c8fTTT+fPnj2775133sl66qmnCk877bS2Rx55ZNgvpyJ7asGCBX033XTT5muvvXbmMcccM/eUU05pmz17dqi5udn72muv5ebm5sZefPHFt0899dTuyy+/fPtPfvKTqYcccshBZ555Zmtubm582bJlBevWrcueP39+1//7f/9vx9w3470W9sS5557b+bWvfa3uu9/9buWBBx548AknnNA+c+bMcFdXl6e2tjawYsWK/AULFnSdfPLJOy1XLpIOX/7yl5tfeuml3Hvvvbd83333PeRDH/pQ+4wZM8Ktra2+TZs2BVatWpV//vnnNy1evHgz6DNBUuvwww/vu/XWWzd+6Utfqpk/f/5Bxx13XMfs2bP7IpGI1dbWBlatWpVfXFwceffdd9fcc889Rb/+9a+nHHrood233nprHSSmtPjtb3+7YeHChQd95StfmXnsscd2D51u40Mf+lDHf/7nf854/PHHCw8++ODeDRs2BB9//PHiYDDofvKTn2wcPGn4LbfcUvviiy/m/frXv57yyiuv5C5evLizubnZ98gjjxR3d3d7v/Od72we733DTTfdtO3111/Pvu+++8qffPLJomOPPbZj+vTpkcbGRt+GDRuyXn755bzrrruubsGCBdt3X9vwTjrppK6srKz43XffPaWlpcU7MI/Tdddd1zDSCvG61mUiG8t3ug9/+MOdX//61/nmN79ZtXr16uyBEWzf+973tgHccccdm0888cQDrr/++uq//vWvhQcddFDvxo0bA4899ljxySef3LZ06dKikaaSGo7X6+WSSy5puOOOO6bOnTv3oNNOO60tHA7bc889l9/e3u476qijOl988cUJ13tTybO93F/+8pf1V1xxRdXjjz9e9Ktf/WrKzJkzQ//xH/9Re/bZZ3c8+uijO72hl5SUxF944YW1P/zhD8t+//vflz722GNFoVDIU1paGqmpqQn9v//3/7bsbnU3+eC65557Nu2///69v/rVr8p/85vflBcVFUVPO+20tltuuaWuurr60JKSkh1zLl1zzTVNwWDQ3XHHHRV/+MMfSrOysuILFy7s+sUvfrHx/vvvLx4uefblL3+52Tlnt99+e8Uf/vCH0oKCgtiHP/zhth/+8Ie155xzzr6Dy+bn58e//vWv1z7zzDMFL730Uu4TTzxRlJOTE6uurg7ddNNNm6+88sodHxhf+MIXGouKimIvv/xy7j/+8Y+8aDRqFRUVkU9/+tMNX/va1+r322+/XX7pq6mpiSxduvSta665pmrVqlV5f//73wv22WefvptuumnzWWed1aEvT5IK//7v/9502GGH9X7/+9+f+sILL+Q/8cQTRcXFxdH999+/95JLLtnx+r7zzjvrDj/88J6f/vSnU/74xz+WRqNRmzFjRujaa6+t+4//+I/6rKysHXPejPda2FPf/va3tx933HFdt95665RVq1blPfnkk768vLxYRUVF5FOf+lTjZz7zmVFNaiuSKvfcc8/mM888s/2uu+4qX758eUFnZ6e3sLAwNm3atPDll1++/bOf/eyO16g+EyTVvvCFL7QsXLiw96abbqp4/vnn85999tmC7Ozs+JQpUyJnnnlm6wUXXNCybt26wBVXXFGTl5cX++1vf7thYEJtSPQk+fGPf7zx4osvnv3JT35y9sqVK98a/FmwcOHC7htvvHHrjTfeWPmrX/1qinOOo446quM73/lO3fHHH/++IZgVFRWxFStWvHXDDTdMffTRR4t/9rOfVQSDwfghhxzSffXVV9d/7GMfG/d9QzAYdE888cQ7d955Z8m9995btmzZsqKenh5PcXFxdMaMGaFrrrmm7pJLLtnj3m0A5eXlsXvuueedb33rW9N///vflw2smvkv//IvzSMlz3Sty0Q2lu908+fP7/vRj3707m233Tb1nnvu2bHQxUDybMGCBX1PP/30W9ddd13l888/n//888/n77///r333HPPO2+88UbW0qVLi0Za3GAkt9xyS115eXn0nnvuKbvvvvvK8/LyYosXL+743ve+V/fVr3512JV1M82cG3aeyIx59dVXNx522GFJ/8u2iGTO66+/Hjz00EMP/shHPtLy0EMPvZvpeERERETk/R5++OH8s88+e7/hJsAXmQiO/PaThzR0hibsFEJT8oPhFV8/5fVMx5FO55xzzqyHHnqo5JVXXll92GGH7bQ41WT06quvlh122GE1Q7er55mIJM3mzZt9lZWV0cHd+Ts7Oz1f/OIXZwCce+65bZmKTUREREREJq8PWmJqoojFYtTV1fmqq6ujg7f/+c9/zn/00UdLZs+e3be3JM52RckzEUmaJUuWVPzpT38qOfroozunTp0aqa+v9y9fvrygvr7ef9xxx7VfcsklO61GJCIiIiIiIhNTKBSyffbZ59Cjjjqqc86cOX0+n8+99dZb2c8991yB3+93t9xyy+ZMx5gOSp6JSNKcdtppHatXr875+9//XtDe3u7zer2upqYm9LnPfa7+G9/4RsNYJpIUERERERGRzAoEAu6iiy5qXL58ecFrr72W29vb6ykuLo6eccYZrV/72te2LVq0qDfTMaaD5jwTEREREREREZEPvJHmPFM3EBERERERERERkREoeSYiIiIiIiIiIjICJc9ERERERERERERGMCGTZxNtHjYREREREREREdl77SoXNeGSZ2bWGg6H/ZmOQ0REREREREREPhjC4bDfzFqH2zfhkmfxePwvbW1t+ZmOQ0REREREREREPhja2try4/H4X4bbN+GSZ7FY7K76+vq2+vr6klAo5NcQThERERERERERSTbnHKFQyF9fX19SX1/fFovF7hqunE3E5NRLL71U4/V6L/N4PGc454ozHY+IiIiIiIiIiOx9zKw1Ho//JRaL3bVgwYKNw5aZiMkzERERERERERGRiWDCDdsUERERERERERGZKJQ8ExERERERERERGYGSZyIiIiIiIiIiIiNQ8kxERERERERERGQESp6JiIiIiIiIiIiMQMkzERERERERERGRESh5JiIiIiIiIiIiMgIlz0REREREREREREag5JmIiIiIiIiIiMgIlDwTEREREREREREZgZJnIiIiIiIiIiIiI1DyTEREREREREREZARKnomIiIiIiIiIiIxAyTMREREREREREZERKHkmIiIiIiIiIiIyAiXPRERERERERERERqDkmYiIiIiIiIiIyAiUPBMRERERERERERmBkmciIiIiIiIiIiIjUPJMRERERERERERkBEqeiYiIiIiIiIiIjEDJMxERERERERERkREoeSYiIiIiIiIiIjICJc9ERERERERERERGoOSZiIiIiIiIiIjICCZt8szMNprZKROxHTP7iZndsIv9zsz2TWabexud372fzrGIiIiIiIhMBpM2eTaROecud859czRlzexXZvatVMRhZieb2Vtm1mNmT5nZzF2UvcLMVplZyMx+lYp49haT7fyaWdDMfm5mm8ys08xeNrMzUhHT3mKyneP+sn8zsz4z6+r/tzYVMYmIiIiIiHzQKHm2lzKzMuCPwA1ACbAK+O0uDtkKfAv4Reqjk/Ea4/n1AVuA44HC/mN+Z2Y1qY9U9tQeXMMAVzjn8vr/7Z/qGEVERERERD4IJnvy7Agze8PMWs3sl2aWZWbFZvawmTX2b3/YzKoGDujvnfFNM1ve3wvn8f6b1IH9F/f30Gk2s68P2p5l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",
      "text/plain": [
       "<Figure size 432x288 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "source": [
    "def true_DP(cov, mean, np_x):\n",
    "    # cond_mean = (cov[0][0] * mean[1] + cov[0][1] * (np_x - mean[0])) / cov[0][0]\n",
    "    # pdf_true = gaussian(np_x, mean[0], np.sqrt(cov[0][0]))\n",
    "    # DP_true = np.sum(np.abs(cond_mean - mean[1]) * pdf_true) / np.sum(pdf_true)\n",
    "    DP_true = 2*cov[0][1]/np.sqrt(2*np.pi*cov[0][0])\n",
    "    return DP_true"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "source": [
    "def error_bw_single(bw, cov, mean, num, kernels_kde, kernels_regression):\n",
    "    x_train, y_train = generate_data(num, mean, cov)\n",
    "\n",
    "    eg_length = np.floor(8 / bw).astype(int)\n",
    "    np_x = np.linspace(-4, 4, 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",
    "    # cond_mean = (cov[0][0] * mean[1] + cov[0][1] * (np_x - mean[0])) / cov[0][0]\n",
    "    # pdf_true = gaussian(np_x, mean[0], np.sqrt(cov[0][0]))\n",
    "    # DP_true = np.sum(np.abs(cond_mean - np.mean(y_train)) * pdf_true) / np.sum(pdf_true)\n",
    "    DP_true = true_DP(cov, mean, np_x)\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",
    "    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",
    "    error = np.abs(DP_true - DP_ests)\n",
    "    return error"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "source": [
    "def error_bw(bw, cov, mean, num, kernels_kde, kernels_regression, times=100):\n",
    "    errors = Parallel(n_jobs=1)(delayed(error_bw_single)(bw, cov, mean, 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": 17,
   "source": [
    "def error_optbw(bws, cov, mean, 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, cov, mean, 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": 18,
   "source": [
    "kernels_regression =  ['tricube', 'aitchison_aitken_reg']\n",
    "kernels_kde = ['linear', 'cosine']\n",
    "num = int(1e2)\n",
    "mean = [0.5, 1.0]\n",
    "cov = [[1, 0.5], [0.5, 3.0]]\n",
    "bw = 0.1\n",
    "bws = np.exp(np.linspace(-2, 0, 40))\n",
    "# bws = [0.01, 0.05, 0.1, 0.5]\n",
    "errors = []\n",
    "for bw in bws:\n",
    "    error = error_bw(bw, cov, mean, num, kernels_kde, kernels_regression)\n",
    "    errors.append(list(error))\n",
    "# error = Parallel(n_jobs=1)(delayed(error_bw_single)(bw, cov, mean, num, kernels_kde, kernels_regression) for _ in range(10))"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "source": [
    "labels = ['histogram', 'tri-lin', 'tri-cos', 'aa-lin', 'aa-cos']\n",
    "xylabels = ['bandwidth', 'DP_error']\n",
    "title = 'DP_error'\n",
    "# path = 'results/Gaussian'\n",
    "xaxis = bws\n",
    "errors_trans = list(np.array(errors).T)\n",
    "plot_err(xaxis, errors_trans, labels, xylabels, title, path, plottype='semilogx', legend=True)##semilogx"
   ],
   "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": 36,
   "source": [
    "with open('results/Gaussian/errors_trans.npy', 'wb') as f:\n",
    "    np.save(f, errors_trans)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "source": [
    "kernels_regression =  ['tricube', 'aitchison_aitken_reg']\n",
    "kernels_kde = ['linear', 'cosine']\n",
    "mean = [0.5, 1.0]\n",
    "cov = [[1, 0.5], [0.5, 3.0]]\n",
    "# bw = 0.1\n",
    "bws = np.exp(np.linspace(-2, 0, 40))\n",
    "nums = np.floor(np.power(10, np.linspace(3, 5, 10))).astype(int) ## num = [10, 50, 100, 500, 1000, 2000, 5000]\n",
    "errors_opt, width_opt = error_optbw(bws, cov, mean, nums, kernels_kde, kernels_regression, times=100)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "source": [
    "labels = ['histogram', 'tri-lin', 'tri-cos', 'aa-lin', 'aa-cos']\n",
    "xylabels = ['Samples numbers', 'DP_error']\n",
    "title = 'DP_opt'\n",
    "# path = 'results/Gaussian'\n",
    "xaxis = nums\n",
    "plot_err(xaxis, errors_opt, labels, xylabels, title, path, plottype='loglog')##semilogx"
   ],
   "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": 37,
   "source": [
    "with open('results/Gaussian/errors_opt.npy', 'wb') as f:\n",
    "    np.save(f, errors_opt)\n",
    "with open('results/Gaussian/width_opt.npy', 'wb') as f:\n",
    "    np.save(f, width_opt)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "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": [
    {
     "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": null,
   "source": [
    "# bw = 1.0\n",
    "# eg_length = np.floor(8 / bw)\n",
    "# np_x = np.linspace(-4, 4, 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",
    "# cond_mean = (cov[0][0] * mean[1] + cov[0][1] * (np_x - mean[0])) / cov[0][0]\n",
    "# pdf_true = gaussian(np_x, mean[0], np.sqrt(cov[0][0]))\n",
    "# DP_true = np.sum(np.abs(cond_mean - np.mean(y_train)) * pdf_true) / np.sum(pdf_true)\n",
    "\n",
    "# (hist_pdf, bins, patches) = 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",
    "# results_regression = []\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",
    "# 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",
    "\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"
   ],
   "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
}