{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from utils import introduce_missing_data\n",
    "from utils import normalization, renormalization\n",
    "from utils import compute_normalised_rmse\n",
    "from utils import log_likelihood_model1, log_likelihood_model2, log_likelihood_model3\n",
    "\n",
    "from sklearn.impute import KNNImputer\n",
    "from sklearn.experimental import enable_iterative_imputer\n",
    "from sklearn.impute import IterativeImputer\n",
    "from sklearn.ensemble import ExtraTreesRegressor\n",
    "from sklearn.linear_model import BayesianRidge\n",
    "\n",
    "from warnings import simplefilter\n",
    "from sklearn.exceptions import ConvergenceWarning\n",
    "simplefilter(\"ignore\", category=ConvergenceWarning)\n",
    "\n",
    "import os\n",
    "os.chdir(\"GAIN\")\n",
    "from gain import gain\n",
    "os.chdir(\"..\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# kNN Impute"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 "
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset1.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_neighbors = np.linspace(start=2, stop=100, num=50, dtype=int)\n",
    "nb_repeat = 30\n",
    "\n",
    "rmse_list = np.zeros((nb_neighbors.shape[0], nb_repeat))\n",
    "for n1 in range(nb_neighbors.shape[0]):\n",
    "    print(n1, end=\" \")\n",
    "    nb_n = nb_neighbors[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        imputer = KNNImputer(n_neighbors=nb_n)\n",
    "        norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb of neighbours\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_neighbors, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_neighbors, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"Dataset 1\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 "
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset2.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_neighbors = np.linspace(start=2, stop=100, num=50, dtype=int)\n",
    "nb_repeat = 30\n",
    "\n",
    "rmse_list = np.zeros((nb_neighbors.shape[0], nb_repeat))\n",
    "for n1 in range(nb_neighbors.shape[0]):\n",
    "    print(n1, end=\" \")\n",
    "    nb_n = nb_neighbors[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        imputer = KNNImputer(n_neighbors=nb_n)\n",
    "        norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb of neighbours\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_neighbors, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_neighbors, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"Dataset 2\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 "
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset3.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_neighbors = np.linspace(start=2, stop=100, num=50, dtype=int)\n",
    "nb_repeat = 30\n",
    "\n",
    "rmse_list = np.zeros((nb_neighbors.shape[0], nb_repeat))\n",
    "for n1 in range(nb_neighbors.shape[0]):\n",
    "    print(n1, end=\" \")\n",
    "    nb_n = nb_neighbors[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        imputer = KNNImputer(n_neighbors=nb_n)\n",
    "        norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb of neighbours\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_neighbors, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_neighbors, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"Dataset 3\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MissForest"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3 4 5 6 7 8 9 "
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset1.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_trees = np.linspace(start=5, stop=50, num=10, dtype=int)\n",
    "nb_repeat = 5  # too long otherwise...\n",
    "\n",
    "rmse_list = np.zeros((nb_trees.shape[0], nb_repeat))\n",
    "for n1 in range(nb_trees.shape[0]):\n",
    "    print(n1, end=\" \")\n",
    "    nb_t = nb_trees[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        estimator = ExtraTreesRegressor(n_estimators=nb_t)\n",
    "        imputer = IterativeImputer(estimator=estimator, max_iter=10, tol=1e-1, verbose=0)\n",
    "        norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb of trees\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_trees, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_trees, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"MissForest for Dataset 1\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3 4 5 6 7 8 9 "
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset2.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_trees = np.linspace(start=5, stop=50, num=10, dtype=int)\n",
    "nb_repeat = 5\n",
    "\n",
    "rmse_list = np.zeros((nb_trees.shape[0], nb_repeat))\n",
    "for n1 in range(nb_trees.shape[0]):\n",
    "    print(n1, end=\" \")\n",
    "    nb_t = nb_trees[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        estimator = ExtraTreesRegressor(n_estimators=nb_t)\n",
    "        imputer = IterativeImputer(estimator=estimator, max_iter=10, tol=1e-1, verbose=0)\n",
    "        norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb of trees\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_trees, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_trees, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"MissForest for Dataset 2\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 1 2 3 4 5 6 7 8 9 "
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset3.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_trees = np.linspace(start=5, stop=50, num=10, dtype=int)\n",
    "nb_repeat = 5\n",
    "\n",
    "rmse_list = np.zeros((nb_trees.shape[0], nb_repeat))\n",
    "for n1 in range(nb_trees.shape[0]):\n",
    "    print(n1, end=\" \")\n",
    "    nb_t = nb_trees[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        estimator = ExtraTreesRegressor(n_estimators=nb_t)\n",
    "        imputer = IterativeImputer(estimator=estimator, max_iter=10, tol=1e-1, verbose=0)\n",
    "        norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb of trees\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_trees, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_trees, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"MissForest for Dataset 3\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# MICE"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Mean normalised RMSE = 0.07521119940325265\n",
      "Stddev normalised RMSE = 0.00421902983871838\n"
     ]
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset1.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_repeat = 100\n",
    "\n",
    "rmse_list = np.zeros(nb_repeat)\n",
    "for n1 in range(nb_repeat):\n",
    "    miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "    norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "    norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "    estimator = BayesianRidge()\n",
    "    imputer = IterativeImputer(estimator=estimator, max_iter=10, tol=1e-1, verbose=0)\n",
    "    norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "    norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "    rmse_list[n1] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list)\n",
    "std_rmse = np.std(rmse_list)\n",
    "print(\"== MICE for Dataset 1 ==\")\n",
    "print(f\"Mean normalised RMSE = {mean_rmse}\")\n",
    "print(f\"Stddev normalised RMSE = {std_rmse}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "== MICE for Dataset 2 ==\n",
      "Mean normalised RMSE = 0.2504018927561988\n",
      "Stddev normalised RMSE = 0.009820879200879032\n"
     ]
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset2.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_repeat = 100\n",
    "\n",
    "rmse_list = np.zeros(nb_repeat)\n",
    "for n1 in range(nb_repeat):\n",
    "    miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "    norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "    norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "    estimator = BayesianRidge()\n",
    "    imputer = IterativeImputer(estimator=estimator, max_iter=10, tol=1e-1, verbose=0)\n",
    "    norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "    norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "    rmse_list[n1] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list)\n",
    "std_rmse = np.std(rmse_list)\n",
    "print(\"== MICE for Dataset 2 ==\")\n",
    "print(f\"Mean normalised RMSE = {mean_rmse}\")\n",
    "print(f\"Stddev normalised RMSE = {std_rmse}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "== MICE for Dataset 3 ==\n",
      "Mean normalised RMSE = 0.2926184623714979\n",
      "Stddev normalised RMSE = 0.009391964108715341\n"
     ]
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset3.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "nb_repeat = 100\n",
    "\n",
    "rmse_list = np.zeros(nb_repeat)\n",
    "for n1 in range(nb_repeat):\n",
    "    miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "    norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "    norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "    estimator = BayesianRidge()\n",
    "    imputer = IterativeImputer(estimator=estimator, max_iter=10, tol=1e-1, verbose=0)\n",
    "    norm_imputed_data = imputer.fit_transform(norm_miss_data)\n",
    "    norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "    rmse_list[n1] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list)\n",
    "std_rmse = np.std(rmse_list)\n",
    "print(\"== MICE for Dataset 3 ==\")\n",
    "print(f\"Mean normalised RMSE = {mean_rmse}\")\n",
    "print(f\"Stddev normalised RMSE = {std_rmse}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# GAIN"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:00<00:00, 244.70it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 240.06it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 233.45it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 230.35it/s]\n",
      "100%|██████████| 100/100 [00:00<00:00, 223.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:00<00:00, 318.85it/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 314.68it/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 264.44it/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 303.65it/s]\n",
      "100%|██████████| 200/200 [00:00<00:00, 317.42it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:00<00:00, 394.15it/s]\n",
      "100%|██████████| 300/300 [00:00<00:00, 382.55it/s]\n",
      "100%|██████████| 300/300 [00:00<00:00, 373.95it/s]\n",
      "100%|██████████| 300/300 [00:00<00:00, 374.82it/s]\n",
      "100%|██████████| 300/300 [00:00<00:00, 373.68it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 400/400 [00:00<00:00, 428.98it/s]\n",
      "100%|██████████| 400/400 [00:00<00:00, 417.29it/s]\n",
      "100%|██████████| 400/400 [00:00<00:00, 403.50it/s]\n",
      "100%|██████████| 400/400 [00:01<00:00, 362.55it/s]\n",
      "100%|██████████| 400/400 [00:01<00:00, 264.32it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [00:01<00:00, 450.54it/s]\n",
      "100%|██████████| 500/500 [00:01<00:00, 449.01it/s]\n",
      "100%|██████████| 500/500 [00:01<00:00, 451.59it/s]\n",
      "100%|██████████| 500/500 [00:01<00:00, 430.58it/s]\n",
      "100%|██████████| 500/500 [00:01<00:00, 424.11it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 600/600 [00:01<00:00, 463.77it/s]\n",
      "100%|██████████| 600/600 [00:01<00:00, 451.75it/s]\n",
      "100%|██████████| 600/600 [00:01<00:00, 432.36it/s]\n",
      "100%|██████████| 600/600 [00:01<00:00, 450.63it/s]\n",
      "100%|██████████| 600/600 [00:01<00:00, 443.29it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 700/700 [00:01<00:00, 479.09it/s]\n",
      "100%|██████████| 700/700 [00:01<00:00, 478.70it/s]\n",
      "100%|██████████| 700/700 [00:01<00:00, 470.68it/s]\n",
      "100%|██████████| 700/700 [00:01<00:00, 455.68it/s]\n",
      "100%|██████████| 700/700 [00:01<00:00, 435.13it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 800/800 [00:01<00:00, 478.75it/s]\n",
      "100%|██████████| 800/800 [00:01<00:00, 463.74it/s]\n",
      "100%|██████████| 800/800 [00:01<00:00, 469.62it/s]\n",
      "100%|██████████| 800/800 [00:01<00:00, 491.73it/s]\n",
      "100%|██████████| 800/800 [00:01<00:00, 470.33it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 900/900 [00:01<00:00, 513.30it/s]\n",
      "100%|██████████| 900/900 [00:01<00:00, 509.36it/s]\n",
      "100%|██████████| 900/900 [00:02<00:00, 378.15it/s]\n",
      "100%|██████████| 900/900 [00:02<00:00, 317.58it/s]\n",
      "100%|██████████| 900/900 [00:02<00:00, 395.78it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9 "
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:02<00:00, 447.48it/s]\n",
      "100%|██████████| 1000/1000 [00:02<00:00, 387.94it/s]\n",
      "100%|██████████| 1000/1000 [00:02<00:00, 437.71it/s]\n",
      "100%|██████████| 1000/1000 [00:02<00:00, 401.95it/s]\n",
      "100%|██████████| 1000/1000 [00:02<00:00, 480.23it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset1.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "gain_parameters = {\"batch_size\": 128, \"hint_rate\": 0.9, \"alpha\": 100, \"iterations\": 10000}\n",
    "nb_iters = np.linspace(start=100, stop=1000, num=10, dtype=int)\n",
    "nb_repeat = 5\n",
    "\n",
    "rmse_list = np.zeros((nb_iters.shape[0], nb_repeat))\n",
    "for n1 in range(nb_iters.shape[0]):\n",
    "    print(f\"{n1}/{nb_iters.shape[0]}\")\n",
    "    gain_parameters[\"iterations\"] = nb_iters[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        norm_imputed_data = gain(norm_miss_data, gain_parameters)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb iterations\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_iters, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_iters, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"GAIN for Dataset 1\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 92.52it/s]\n",
      "100%|██████████| 100/100 [00:01<00:00, 96.31it/s]\n",
      "100%|██████████| 100/100 [00:01<00:00, 79.36it/s]\n",
      "100%|██████████| 100/100 [00:01<00:00, 93.86it/s]\n",
      "100%|██████████| 100/100 [00:01<00:00, 89.88it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:01<00:00, 166.36it/s]\n",
      "100%|██████████| 200/200 [00:01<00:00, 163.73it/s]\n",
      "100%|██████████| 200/200 [00:01<00:00, 161.76it/s]\n",
      "100%|██████████| 200/200 [00:01<00:00, 158.25it/s]\n",
      "100%|██████████| 200/200 [00:01<00:00, 157.32it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:01<00:00, 213.99it/s]\n",
      "100%|██████████| 300/300 [00:01<00:00, 209.84it/s]\n",
      "100%|██████████| 300/300 [00:01<00:00, 209.54it/s]\n",
      "100%|██████████| 300/300 [00:01<00:00, 207.24it/s]\n",
      "100%|██████████| 300/300 [00:01<00:00, 201.50it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 400/400 [00:01<00:00, 249.01it/s]\n",
      "100%|██████████| 400/400 [00:01<00:00, 250.12it/s]\n",
      "100%|██████████| 400/400 [00:01<00:00, 210.72it/s]\n",
      "100%|██████████| 400/400 [00:01<00:00, 243.83it/s]\n",
      "100%|██████████| 400/400 [00:01<00:00, 240.31it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [00:01<00:00, 275.98it/s]\n",
      "100%|██████████| 500/500 [00:01<00:00, 273.87it/s]\n",
      "100%|██████████| 500/500 [00:01<00:00, 269.74it/s]\n",
      "100%|██████████| 500/500 [00:01<00:00, 272.22it/s]\n",
      "100%|██████████| 500/500 [00:01<00:00, 258.56it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 600/600 [00:01<00:00, 301.45it/s]\n",
      "100%|██████████| 600/600 [00:02<00:00, 297.67it/s]\n",
      "100%|██████████| 600/600 [00:02<00:00, 295.28it/s]\n",
      "100%|██████████| 600/600 [00:02<00:00, 290.45it/s]\n",
      "100%|██████████| 600/600 [00:02<00:00, 277.73it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 700/700 [00:02<00:00, 312.80it/s]\n",
      "100%|██████████| 700/700 [00:02<00:00, 312.36it/s]\n",
      "100%|██████████| 700/700 [00:02<00:00, 310.10it/s]\n",
      "100%|██████████| 700/700 [00:02<00:00, 307.62it/s]\n",
      "100%|██████████| 700/700 [00:02<00:00, 299.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 800/800 [00:02<00:00, 324.35it/s]\n",
      "100%|██████████| 800/800 [00:02<00:00, 322.68it/s]\n",
      "100%|██████████| 800/800 [00:02<00:00, 329.81it/s]\n",
      "100%|██████████| 800/800 [00:02<00:00, 325.60it/s]\n",
      "100%|██████████| 800/800 [00:02<00:00, 324.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 900/900 [00:02<00:00, 347.00it/s]\n",
      "100%|██████████| 900/900 [00:02<00:00, 344.40it/s]\n",
      "100%|██████████| 900/900 [00:02<00:00, 338.98it/s]\n",
      "100%|██████████| 900/900 [00:02<00:00, 301.00it/s]\n",
      "100%|██████████| 900/900 [00:03<00:00, 281.71it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:03<00:00, 331.05it/s]\n",
      "100%|██████████| 1000/1000 [00:02<00:00, 346.85it/s]\n",
      "100%|██████████| 1000/1000 [00:02<00:00, 336.21it/s]\n",
      "100%|██████████| 1000/1000 [00:03<00:00, 330.90it/s]\n",
      "100%|██████████| 1000/1000 [00:03<00:00, 330.05it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset2.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "gain_parameters = {\"batch_size\": 128, \"hint_rate\": 0.9, \"alpha\": 100, \"iterations\": 10000}\n",
    "nb_iters = np.linspace(start=100, stop=1000, num=10, dtype=int)\n",
    "nb_repeat = 5\n",
    "\n",
    "rmse_list = np.zeros((nb_iters.shape[0], nb_repeat))\n",
    "for n1 in range(nb_iters.shape[0]):\n",
    "    print(f\"{n1}/{nb_iters.shape[0]}\")\n",
    "    gain_parameters[\"iterations\"] = nb_iters[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        norm_imputed_data = gain(norm_miss_data, gain_parameters)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb iterations\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_iters, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_iters, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"GAIN for Dataset 2\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Dataset 3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 100/100 [00:01<00:00, 54.32it/s]\n",
      "100%|██████████| 100/100 [00:01<00:00, 53.47it/s]\n",
      "100%|██████████| 100/100 [00:01<00:00, 52.29it/s]\n",
      "100%|██████████| 100/100 [00:01<00:00, 52.19it/s]\n",
      "100%|██████████| 100/100 [00:01<00:00, 51.10it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 200/200 [00:02<00:00, 96.14it/s]\n",
      "100%|██████████| 200/200 [00:02<00:00, 95.44it/s]\n",
      "100%|██████████| 200/200 [00:02<00:00, 93.13it/s]\n",
      "100%|██████████| 200/200 [00:02<00:00, 93.04it/s]\n",
      "100%|██████████| 200/200 [00:02<00:00, 91.69it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 300/300 [00:02<00:00, 129.40it/s]\n",
      "100%|██████████| 300/300 [00:02<00:00, 129.61it/s]\n",
      "100%|██████████| 300/300 [00:02<00:00, 127.56it/s]\n",
      "100%|██████████| 300/300 [00:02<00:00, 124.52it/s]\n",
      "100%|██████████| 300/300 [00:02<00:00, 120.85it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "3/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 400/400 [00:02<00:00, 153.71it/s]\n",
      "100%|██████████| 400/400 [00:02<00:00, 159.38it/s]\n",
      "100%|██████████| 400/400 [00:02<00:00, 156.77it/s]\n",
      "100%|██████████| 400/400 [00:02<00:00, 155.59it/s]\n",
      "100%|██████████| 400/400 [00:02<00:00, 153.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [00:02<00:00, 182.03it/s]\n",
      "100%|██████████| 500/500 [00:02<00:00, 181.01it/s]\n",
      "100%|██████████| 500/500 [00:02<00:00, 178.59it/s]\n",
      "100%|██████████| 500/500 [00:02<00:00, 177.30it/s]\n",
      "100%|██████████| 500/500 [00:02<00:00, 178.48it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 600/600 [00:03<00:00, 199.52it/s]\n",
      "100%|██████████| 600/600 [00:02<00:00, 201.39it/s]\n",
      "100%|██████████| 600/600 [00:03<00:00, 198.70it/s]\n",
      "100%|██████████| 600/600 [00:03<00:00, 198.21it/s]\n",
      "100%|██████████| 600/600 [00:03<00:00, 156.74it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "6/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 700/700 [00:03<00:00, 216.41it/s]\n",
      "100%|██████████| 700/700 [00:03<00:00, 208.98it/s]\n",
      "100%|██████████| 700/700 [00:03<00:00, 215.12it/s]\n",
      "100%|██████████| 700/700 [00:03<00:00, 215.18it/s]\n",
      "100%|██████████| 700/700 [00:03<00:00, 204.90it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 800/800 [00:03<00:00, 227.81it/s]\n",
      "100%|██████████| 800/800 [00:03<00:00, 228.24it/s]\n",
      "100%|██████████| 800/800 [00:03<00:00, 223.81it/s]\n",
      "100%|██████████| 800/800 [00:03<00:00, 223.86it/s]\n",
      "100%|██████████| 800/800 [00:03<00:00, 221.98it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 900/900 [00:03<00:00, 243.12it/s]\n",
      "100%|██████████| 900/900 [00:03<00:00, 238.70it/s]\n",
      "100%|██████████| 900/900 [00:03<00:00, 240.84it/s]\n",
      "100%|██████████| 900/900 [00:03<00:00, 239.03it/s]\n",
      "100%|██████████| 900/900 [00:03<00:00, 233.44it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9/10\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 1000/1000 [00:03<00:00, 250.28it/s]\n",
      "100%|██████████| 1000/1000 [00:04<00:00, 203.91it/s]\n",
      "100%|██████████| 1000/1000 [00:04<00:00, 209.63it/s]\n",
      "100%|██████████| 1000/1000 [00:05<00:00, 193.79it/s]\n",
      "100%|██████████| 1000/1000 [00:04<00:00, 217.65it/s]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEWCAYAAAB8LwAVAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjMsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+AADFEAAAgAElEQVR4nOy9d3hj53ng+3vRQRLsbXrTzKiPJI+Ke2y5yEWW7cSxEydxysbxxkqc62Rj517HN/Hu3c06GyfejdzixKmO4lixrTKSXNStOqPpjcM2rCDBAqL39/4BcARxSBAgARIkv9/z4CHOwTnn+wAC33veLqqKwWAwGAxzsaz2BAwGg8FQnRgBYTAYDIZ5MQLCYDAYDPNiBITBYDAY5sUICIPBYDDMixEQBoPBYJgXIyAMhjxE5AMiMigiIRG5cbXnYzCsJkZAGKoGEfmIiLwgImERGc89/20RkTnH/YmIqIjcMmf/r4rIM3nb/SIyJiK1efv+k4g8UWAa/wu4W1XrVPVoGd7TEyISE5GgiARE5IiIfFZEnCVcQ0XkiuXOZbnjiMhbROSkiPhFZFJEviciWyo9L8PqYQSEoSoQkd8Hvgz8OdAJdACfAF4POPKOE+CXgSngY0Vc2gZ8qoSp7ABOl3D8JUTEusBLd6uqB9gE/D7wEeDQXMG3BjgDvFNVG4HNwAXgq6s7JUMlMQLCsOqISAPwBeC3VfW7qhrULEdV9aOqGs87/I1kF6dPAR8REcd818zjz4E/EJHGRebgFJEQYAWOi0hPbv9VOS3ALyKnReR9eef8vYh8VUQOiUgYeEuhMVQ1rKpPAO8DXgu8J3edW0TkudwYoyLy17PvS0Seyp1+PGf2+rCINInIgyLiE5Hp3POtefP6VRHpzWktfSLy0bzXfl1EzubOe1REdiw0zjzzH1PVkbxdaaDimo1h9TACwlANvBZwAj8o4tiPAQ8A/5bbfu8ixx8GngD+oNBBqhpX1brc5gFV3SMi9txYPwTagd8B/kVE9ued+ovA/wd4gGcoAlUdyM3rjbldaeD/AlrJfha3A7+dO/ZNeXOqU9V/I/u7/RZZbWc7EAX+GiBnTvvfwLtyWsvrgGO5194P/N/AB4E24GngXwuMcxkisl1E/Lkx/wD4YjHv2bA2MQLCUA20AhOqmprdISLP5u6ooyLypty+GuBDwLdVNQl8l+LMTJ8HfkdE2kqc121AHfBnqppQ1ceAB4FfyDvmB6r6U1XNqGqshGuPAM0AqnpEVZ9X1ZSq9gNfB9680ImqOqmq96lqRFWDZAVU/vEZ4FoRcavqqKrOmsx+C/gfqno291n/d+CGWS2iGFR1IGdiagU+B5wr+h0b1hxGQBiqgUmgVURssztU9XW5hWiSV76nHwBSwKHc9r8A71ps4VfVU2QX9s+WOK/NwKCqZvL2XQTyHbODJV5zli1k/SiIyL6cmcgrIgGyC3frQieKSI2IfF1ELuaOfwpoFBGrqoaBD5P134yKyEMicmXu1B3Al3OC158bX+a8n6JQ1SngH4Af5P/fDOsLIyAM1cBzQBy4a5HjPkb2jn5ARLzAvwN2Xn1HvxD/L/CblLYYjgDbRCT/d7IdGM7bLrkcsohsA15D1sQDWUfvOWCvqtaTNQMVcmD/PrAfuDV3/Kx5SABU9VFVfTtZp/g54G9yrw8Cv6WqjXkPt6o+W+p7yGEja3qrX+L5hirHCAjDqqOqfuBPga+IyM+JSJ2IWETkBqAWIBdOeTtZn8MNuccB4H9ShJlJVbvJ+i1+t4SpvQCEgT8UEbuI/AxwJ3BvCde4RO7O/81kfS0v8oom5AECQCh3t/+f55w6BuzO2/aQ9QH4RaSZrPCbHaNDRN6X80XEgRBZHwfA14A/EpFrcsc2iMiHCowzd/4fFJH9uf9NG/Al4GhOmzCsQ4yAMFQFqvpF4NPAHwLjZBerrwOfAZ4lG9p6TFV/qKre2QdZh+z1InJtEcN8gZzAKXJOCbIRR+8CJoCvAL+iqqXa3f9aRIJk39NfAfcBd+SZrv6ArLM7SPZuf66D+E+Af8iZhn4+dw13bk7PA4/kHWshq2GMkDUhvZlXHN7fIytQ782Zpk7l3ttC48xlS26sIHCSrK/jA6V8EIa1hZiGQQaDwWCYD6NBGAwGg2FejIAwGAwGw7wYAWEwGAyGeTECwmAwGAzzsm4SXFpbW3Xnzp2rPQ2DwWBYUxw5cmRCVedNNl03AmLnzp0cPnx4tadhMBgMawoRubjQa8bEZDAYDIZ5MQLCYDAYDPNiBITBYDAY5sUICIPBYDDMixEQBoPBYJgXIyAMBoPBMC9GQBgMBoNhXoyAMBgMBsO8GAFhMBiKZmAywqmhmdWehmGFMALCYDAUzdHBaR7vGl/taRjyUFXOeQNUorePERAGg6Fozo0G6ZsIE0umFz/YsCJcnIzwby8Oks4YAWEwGFaJUDyFLxTHKsLQdGS1p2Mgqz08fGoUfzRZkesbAWEwGIpixB8FQAS6x0OrPBsDQN9EmAvjISwiFbm+ERAGg6Eo+ifCWATqXXZODhtH9Wqjqhw6OUqtw0ZlxIMREAaDoUjOjgaoc9qocVgZC8QIxipj1jAUR48vRO9EmKYae8XGMALCYDAsSiyZZmg6Sq3ThuTMGYNT0VWe1cZFVTl0wkud45X/RyUwAsJgMCyKdyaGwCVbt81ioWsssLqT2sBcGA/RPxWmsYLaA1RYQIjIHSJyXkS6ReSz87z+CRE5KSLHROQZEbk677XrReQ5ETmdO8ZVybkaDIaFGZgKkx9EWe/O+iEqEXtvKEwmozx0YhSPs7LaA1RQQIiIFbgHeBdwNfAL+QIgx7dV9TpVvQH4IvCl3Lk24J+BT6jqNcDPAMbgaTCsEmdHg9Q4rJe2XTYLM9Ek0xHzs1xpusaDDE5HaHBXVnuAymoQtwDdqtqrqgngXuCu/ANUNV9HrYVLNynvAE6o6vHccZOqajJzDIZVIJXO0DcRps71Sgt7EQEVBqZMPsRKkskoDx4fpd5lr7j2AJUVEFuAwbztody+VyEinxSRHrIaxO/mdu8DVEQeFZGXReQP5xtARD4uIodF5LDP5yvz9A0GA8BYME46o9gsr14uHDYLZ0dMuOtKcs4bZGQmSn2esK4klRQQ84m3ywyWqnqPqu4BPgN8LrfbBrwB+Gju7wdE5PZ5zv2Gqh5U1YNtbW3lm7nBYLjE8HSE+VwNDW47Z71BMhUo8WC4nHRGeejECA0rpD1AZQXEELAtb3srMFLg+HuB9+ed+6SqTqhqBDgE3FSRWRoMhoKc8wZx2S9fKhw2C5FEmvFgfBVmtfE4OzrDaCBG/Qr4HmappIB4CdgrIrtExAF8BLg//wAR2Zu3+R7gQu75o8D1IlKTc1i/GThTwbkaDIZ5yGSUrrEgHtdCi5JycTK8onPaiKQzyoMnRlfEMZ1PxQSEqqaAu8ku9meB76jqaRH5goi8L3fY3bkw1mPAp4GP5c6dJhvR9BJwDHhZVR+q1FwNBsP8TIYTxJMZHLb5lwq33cbpEZMPUWlODfvxBePULyioK0NFPR2qeoiseSh/3+fznn+qwLn/TDbU1WAwrBLD/ujljsM86l02usaCpNIZbFaTd1sJUukMD530rrj2ACaT2mAwFODCWBBHgYXfZrWQziijM7EVnNXG4uTQDJOheAEzX+UwAsJgMMzLbKcyzyIhlarQN2HKf1eCZDrDQydHaaxxrMr4RkAYDIZ5CURTzERTOBfwP8xS57Jxatj4ISrBiUE/05EEdc6VyXuYixEQBoNhXob9UQQWjbn3OG30T5o2pOVmVntoWiXtAYyAMBgMC9DjK65TmcUiqGYFiqF8HB3wMxNNUrtK2gMYAWEwGBagGP9DPj2mDWnZSKQyPHxylOba1dMewAgIg8EwD5FEirFA/FUVXAth2pCWl6MD0wRiSWocq6c9gBEQBoNhHkaK9D/MUuu0MjoTIxRPVXZiG4B4Ks2hk6O01DpXeypGQBgMhsvpL7F8hoggwKAp/71sjvRPE46ncBepvVUSIyAMBsNlnB0JlhxaaRHhgvFDLItYMs3Dp700162+9gBGQBgMhjkkUhkGpyMlC4h6t41TQ6YN6XJ4qX+KSDyF27762gMYAWEwGOYwOhNFNRu+Wgpuu5WpSIKZqGlDuhRiyTSPnvbSWiXaAxgBYTAY5jA4FV2SFpB1aKtpQ7pEnu+dJJZI46oS7QGMgDAYDHM45w1Qs8TkLIfVyllT/rtkook0PzozVlXaAxgBYTAY8khnlB5fCM8SBUS928aZ0YDxQ5TIc70TxFMZnFWkPYAREAaDIY/xYIxURpfc28FpsxJOpPGZNqRFE46n+PGZMVrrVjdrej4qKiBE5A4ROS8i3SLy2Xle/4SInBSRYyLyjIhcndu/U0Siuf3HRORrlZynwWDIMjyddVAvC8X4IUrg2Z4JEmnFaasu7QEqKCBExArcA7wLuBr4hVkBkMe3VfU6Vb0B+CLZNqOz9KjqDbnHJyo1T4PB8ArnvMFFy3svhtth5fSIKbtRDKF4isfOjtNWZb6HWSqpQdwCdKtqr6omgHuBu/IPUNV8b1YtFOxuaDAYKoiq0jUWXHbf43qXjfPeEOmM+TkvxrPdE6QyumDP79WmkrPaAgzmbQ/l9r0KEfmkiPSQ1SB+N++lXSJyVESeFJE3zjeAiHxcRA6LyGGfz1fOuRsMG47JcIJoIr3sxcpmtZBMZxidMeW/CxGMJXns3HjVRS7lU0kBMV+WzWW3FKp6j6ruAT4DfC63exTYrqo3Ap8Gvi0i9fOc+w1VPaiqB9va2so4dYNh4zFSxn4OitI/YfwQhXjmwgTpKtYeoLICYgjYlre9FRgpcPy9wPsBVDWuqpO550eAHmBfheZpMBiAC+MhbCVmTy9ErcPGKVP+e0FmokmeOD9Om6d6tQeorIB4CdgrIrtExAF8BLg//wAR2Zu3+R7gQm5/W87JjYjsBvYCvRWcq8Gw4Tk3GsSzTP/DLB6Xnd6JEPGUaUM6H09f8KGAfYnhxCtFxbpRqGpKRO4GHgWswN+p6mkR+QJwWFXvB+4WkbcBSWAa+Fju9DcBXxCRFJAGPqGqU5Waq8Gw0QnEkkyHE2xudJXletbZNqTTUXa31ZXlmusFfyTBU10TVRu5lE9F2xWp6iHg0Jx9n897/qkFzrsPuK+SczMYDK8wPB1FLMU3CCqW3omQERBzeLLLByw9GXElqf4ZGgyGitM3EZ43qmQ5eFw2Tg6Zukz5TIcTPNO9NrQHMALCYDAAZ0cDZfM/zFLntDHsjxBJmDakszxxfhwLrAntAYyAMBg2PNFEmtGZGLVlbnGZNVcJg1MmHwJgMhTn2d5JWqs8cikfIyAMhg3OyEwUkfL7HwCsFugeD5b9umuRx8+PY0GwWdbOsrt2ZmowGCrCwGSkYkVu6l12Tg4bP4QvGOeF3qmqz3uYixEQBsMG5+xogNol9n9YDLfdykQozkxkY7chffzcOFaLYC1TIuJKYQSEwbCBSaYz9E9GqKuQgJg1Ww1Ob9yyG+PBGC/2T1V1zaWFMALCYNjAeGdiqGpF72ztFuHc6MY1Mz12dhzbGtQewAgIg2FDM7QCjX0a3HZOj2zMNqRjgRiH16j2AEZAGAwbmnPeIO4K90F22q2E4ikmQomKjlON/OjMGHarZU1qD2AEhMGwYclklG5fiDpXRSvuANlmRAOT4YqPU02MzkQ5OjC9ZrUHMALCYNiw+EJxEunMilQUddmtnN5gfogfnh7DYbNgWaPaAxgBYTBsWIamIqyUW6Debee8N7hh2pAO+6OcGPKvae0BjIAwGDYsXWNBnCvUzcxutZBIZRgLxFZkvNXm0dNenDYLlgpkp68kC347ROStec93zXntg5WclMFgqCyqStdYCM8K+B8ujQn0T6x/P8TgVITTwzO0rHHtAQprEP8r7/nc3gyfowhE5A4ROS8i3SLy2Xle/4SInBSRYyLyjIhcPef17SISEpE/KGY8g8FQHNORJMF4EqetshFM+dQ4rJwaWd9tSFWVH5724rRZ17z2AIUFhCzwfL7ty0/Otgy9B3gXcDXwC3MFAPBtVb1OVW8Avgh8ac7rfwk8vNhYBoOhNEb8UYr4GZeVepednvEwiVRmRcddSQanopwZDdBa51jtqZSFQgJCF3g+3/Z83AJ0q2qvqiaAe4G7XnUR1fywhtr864rI+8n2oT5dxFgGg6EEuseD2FY4usZqETKqOeG0/lBVHj49isturUhl3NWgkAFyt4jcT/Y2Y/Y5ue1dC592iS3AYN72EHDr3INE5JPApwEH8NbcvlrgM8DbgQXNSyLyceDjANu3by9iSgaDAbIJcqX6H1SVgakIW5tqlpX41TcRZmdr7ZLPr1YuTkY4Pxpka5N7tadSNgppEHcBf0HWFzH7fHb7/UVce75v0GWah6reo6p7yAqEWd/GnwJ/qaqhQgOo6jdU9aCqHmxraytiSgaDIZvVHC85g3rYH+X7x0Y4Nbx0P0Kd08bJZZxfragqh06NUuNYP9oDFNAgVPXJ/G0RsQPXAsOqOl7EtYeAbXnbW4GRAsffC3w19/xW4OdE5ItAI5ARkZiq/nUR4xoMhgIMT0cRpOSFrGc8G4F0fizIgW2NSxq7zmVjcCpCNJHGXeYOdqtJ70SY7vEQWxvXj/YAhcNcvyYi1+SeNwDHgX8EjorILxRx7ZeAvSKyS0QcwEeA+/MPEJG9eZvvAS4AqOobVXWnqu4E/gr470Y4GAzloX8yTKk3uapKz0QIi8DoTIxAdGn9HSwiIDC0jsp/qyqHToxS67CtK+0BCpuY3qiqsw7iXwO6VPU64DXAHy52YVVNAXcDjwJnge+o6mkR+YKIvC932N0iclpEjpH1Q3xsqW/EYDAUx9nRQMn9H3zBOMFYioM7moFskt1SEeDCeEHr8ZqixxeibzJMU419tadSdgp9S/JLL74d+HcAVfUWKyVV9RBwaM6+z+c9/1QR1/iTogYzGAyLEkumGZ6O0tngKum8Hl8YAQ5sa2BwOsL5sSAHdzYvaQ71Ljunhmd493WblnR+NZHVHrzUOdef9gCFNQi/iLxXRG4EXg88AiAiNmB9GdoMhg3C6EwMEUpO4uqZCLG50U2Nw8a+Dg8ToQSTofiS5lDjsDIejBGIrf02pBfGQ/RPhWl0rz/tAQoLiN8iayL6FvB7qurN7b8deKjSEzMYDOXn4mSYUuvl+SMJJkMJ9rRlQ1P3ttchQNfY0sxE2TttYXAFmhVVkkxGefD4CJ51qj1AAQGhql2qeoeq3qCqf5+3/1FV/f0VmZ3BYCgr50aDJfsfen3Z6KXdbXUA1DptbGuu4fxYcMld4mwW4bx36X6MauDksJ8hf5SGdao9QAEfhIj870Inqurvln86BoOhUqTSGfomwrR5Sisi1+ML0VrneNVCuK+jjh+fHWcsEC/ZnwHZNqSnhmf4wI1b1uTddzyV5gfHRmiucazJ+RdLIRPTJ4A3kM1dOAwcmfMwGAxrCG8gRka1pCzoSCLFyEyMPTntYZYr2uqwinB+idFMTpuFQCzFVHhttiF9vmeKmWiS2hK1sbVGoXe3CfgQ8GEgBfwbcJ+qTq/ExAwGQ3kZmooWVUQtn1nz0lwB4bRb2dlaQ9dYkDfubS3Z6Z29686W7lhrZbGDsSSPnBotWRNbixTyQUyq6tdU9S3Ar5LNaD4tIr+8UpMzGAzl49xYoOTyGj2+EPUu27zVSfd3eIgksmGzS8Fps3JmDbYhffzcOGnVFS2Vvlos2k5KRG4Cfg/4JbKlt415yWBYY2QySvd4aQ2CEqkMg9NRdrfVzWtn39Vai926dDNTvcvO2dEAmTXUhnQ8GOPpCxMbQnuAwqU2/lREjpDNcH4SOKiqv6GqZ1ZsdgaDoSxMhOPEkxns1uJbjF6cDJPOKFfMMS/NYrNa2NNWR/d4iFSm9B4PDpuFWDLDWHBttCFVVQ6dHMVmsWCzbIxuzYXe5R8DDcAB4H8AL4vIiVwHuBMrMjuDwVAWhqejJYek9vjCuO1WNhWIUtrf4SGeyjAwucScBoWLE2sjH+LiZIQTgzO0etZHM6BiKKRvFtPzwbDOSKQy3HdkiKlInK1NNWxtctNc66S51kG9a/0mBK13LoyFcJRgM09nlL7JMFe01WEpEPW0rbkGl93C+bHgpTyJUphtQ3rbnpaSz11JMhnlB8dGqHXa1kUr0WIpVO774nz7c61EPwLM+7ph7RJPpfnn5y5yZjRAvcvO4FSUVCaDICjgsAqdDW62NrnZ1uSmpc5JS60Tj8tWcBExrC6qyjlvoCT/w9B0hEQqcyl7eiGsFmFvu4ezowESqQwOW2mmF4/bRvd4iGS6NPPXSnN6ZIb+yTDb1lEzoGIolChXD3ySbGe4+4EfkS298QfAMeBfVmKChpUhnkrzj89d5NxogC2NbkSE+jkZoql0Bn8kwag/yrM9SjZQMZsV29ngYluTm61NNTnBkU2sMoJj9ZmJJgnEUmwuIaGt1xfGZhG2N9cseuz+Dg8nh2fonQhxZWd9SXOzWSykVRn1x9jesvhYq0EileH7x4bXfVLcfBS6pfgnYBp4DvhPwH8h2xb0LlU9tgJzM6wQsWSaf3yuny5v6JJwmA+b1YLHasHjmiM4MhmC0RRHAn6e651Ecs0ERaCzwcXWxhq2Nblp9WRNVY01jmW1rDSUxrA/ikDRi9ts74cdLTXYirir39zoos5po2usdAGRHRB6J0JVKyBe7JvEH0mytak651dJCvakzvV/QES+CUwA21V1bRdQMbyKWDLN3/+0n25fkM0FhEMhbBYLdS4LdXNMGOmMEomnOTbo58W+qVc1qemod7Glyc22phracoKjqcZe1IJkKI0eX7gku/lYIE44nr4sOW4hRIT9HR6ODk4TTaZLzrWoc9o4NTzDz+xvL+m8lSAUT3HolJe2NZbMVy4KCYhLtXhVNS0ifUY4rC+iiTTferaPPl+YzQ1LEw6FsFqEWqftsnIEmYwSTaY5NTzDkf7pVwmOVo+DLY1utjfX0FrnwuOyUZe7Rqn2bUOWc6Ol+R96fCFEsnkOxbKvs44jA9N0j4e4bktDSfOrc9q4OBkhlkzjKlG4VJonz4+TTGVw1lXXvPKJJdOE46mKXLvQt+aAiMymOQrgzm0LoKq6qC4pIncAXwaswDdV9c/mvP4Jsn6ONBACPq6qZ0TkFuAbeWP/iap+r4T3ZViEaCLN3/60j4sTYTY1uFbUtmpZSHCoEkumOTca5PhgtrG9CKhmH067hQa3naYaO821DprrnDS47ZcESJ3DRo3TWtXOzpUmHE8xHoyX5H/o8WV7K5eyWLfVOWmqsdPlDZYsIGb9VEPTUa5oLz0SqlJMhOI80eWjvYqT4maiSX5wbJiMZjX2cid3F4piWtZQuWine8h2oxsCXhKR++ck2n1bVb+WO/59wJeAO4BTZBPzUiKyCTguIg/k2pgalkkkkeJvn+ljcCqy4sKhEBYRahw2ahyXfy1VlXRGSaQzDPtj9E1ESKQzgF4yn6hCRqHGYaGxxkFjjZ3m2qzDvN5tp9ZhvSSY6py2DeEHGfFny2AU+z+eCieYjiQ5sLWxpHFmzUzP900RiqUuMzcufoGsYKomAfHIKS9Wkao1e3pnYtx/fISMKrftaqnI97mSpQhvAbpVtRdARO4F7gIuCQhVzS/EUks2KAZVzc+ccc3uNyyfcDzFN5/uZcQfo7O+eoTDYogINuviP1ZVJZVRook0gWgyF0KpuWvMqr/ZL1Stw0pDjeOSRtJS68Djsl8SILVOK7WOtR3C2z8ZppR/ca8v2wRo9yLhrfOxrzMrILrGg9y0vamkc+tddk4O+XnnNZ0lj1sJBiYjvDwwzZbG6gxr7fGFeOSUlxqHlbtu2Eo0ka7IOJUUEFuAwbztIeDWuQeJyCfJlvNwAG/N238r8HfADuCX59MeROTjwMcBtm/fXs65r0tC8RR/81Qv3pkonQ3V+cVfLiKC3SqLmplUlWRaicRT+CMJznuDJNMZLPLK3fasINnRUsNvvnF31dnHi+FMiQ2Cenxh2j3OyyLViqGpxkG7x8l5b+kCotZhZWQmRjCWXNLY5SSbFDdMjd1alUlxxwb9PNnlo6PeyZ3Xb6bWaWM4sbSCiYtRSd1pvk/2Mk1AVe9R1T3AZ4DP5e1/QVWvAW4G/khELjOiquo3VPWgqh5sa2sr49TXH8FYkm881cNYYP0Kh1IQERw2C7VOG001DjrqXWxtqmFzYw2bGtxsanCzudHN5gYX/RNhnr7gW+0pl0w8lWZ4OkLdPCa7+QjFU3gDl/d+KIX9nR7Gg3GmI6X1eRDJBkcPTlVmoSuFs6MB+ibCNNdWV0mNjCpPdvl4ssvHnrZafvamrRXvR1FJATEEbMvb3kq2+dBC3Au8f+5OVT0LhIFryzq7DUQgluTrT/UyHojTUW+EQymICB31Ln50ZgxfML7a0ykJ70wMhaJNZLPmpcWypwuxr90DQNcS2olaLELXEivDlotkOsP3jw/TWGOvKvNrMp3h0MlRjg36uWFbI+++btOKBGMUquYaFJHAQo8irv0SsFdEdomIg2x5jvvnjLE3b/M9wIXc/l0iYss93wHsB/pLemcGIBvl8PUne5gMxumoL701pAHsVgtWsXD/8eEl92BeDQYmI2gJRVZ7fWEa3PZl3TnXuWxsaXQvqV91gyvbhnQ1P+PD/VNMhVbfzJVPJJHivpeH6PGFedPeVt68r23FTF+Fopg8ACLyBcBLNrNagI8CnsUunItAuht4lGyY69+p6unc9Q6r6v3A3SLyNrI5F9PAx3KnvwH4rIgkgQzw26o6scT3uGGZiST52lM9+CMJ2o1wWBZtHgenhwOcHQ1w9ebSwjhXi7PeILXO4vwm8VSawekIN25rWvad8/5OD4+dG8cXitPuKf5757JbGPHH8EeSNK2CeSccT/HQidF5myOtFtPhBN8/Nkwkkea9129alvlvKRRjwHqnquY7l78qIi8AX1zsRFU9BByas+/zec8/tcB5/0RWIBmWiD+S4GtP9hCIpkr6kRrmR0RorLHzHy8Ps6e9ruq7iaXSGXp9IVqKXOz6JyJkdGnRS3O5on6r6P4AACAASURBVL2OJ86P0+UNlfTdExFEYGAqsioC4qkuH7FUhpYqSYobno7ywIkRLCL87E1b6Swhl6VcFGPESovIR0XEKiIWEfko2cQ2Q5UyHU7w1Zxw2Cidr1YCj8uOP5rgqa7qd1iPB+PZxKkiG9v0+ELUOKxlWYTcdivbm2uWZGayWy2r0oZ0KpzgsfPjVZMUd94b5HtHh6lxWPnwzdtWRThAcQLiF4GfB8Zyjw/l9hmqkKlwgq882U3ICIeK0O7JOqwnQtXtsB6ejqBFpg+lMhn6J8Psbq0tm217f6eHUDzFiL+0bnEN7tVpQ/ro6VGssnh4dKVRVV7qn+KR0146G1z8/MFtNLhXzx+y6Kehqv2qepeqtqpqm6q+X1X7V2BuhhKZDMX5yuPdROJpWo1wqAhZh7Vw/7GRqnZYn/UGcRVpBhucipJMa1nt27tb67BZSu9X7bBZiCTS+FZQAA9ORXipb3rVC/KlM8pPzo3zbM8k+zs8vP/Gzauee7OogBCRfSLyExE5ldu+XkQ+t9h5hpVlIhTnK090E02mad2glSdXijaPk5PDM3SNhVZ7KvOiqnSPh4qOxOn1hbBbha3N5QuBdtgs7G6tpXs8RHoJ2sDAZLhscymEqvLAiRHcDuuqZszHU2keOD7C6ZEAN+9s4p3XdFRF3+tiZvA3wB+Rq+6qqifIhqwaqoTxYIyvPN5NPJUxwmEFmHVYf/fIIPFU9bnjJsMJIol0UdVvM6r0+MLsbKkt+4K0v9NDNJlmcKq0ntNuu5VTIyvjhzg/FqR7LETLKibFBWNJvntkiIHpCLdf2c7r9rRWTQ5GMd+IGlV9cc4+UzSvShgPxPjq4z0k0xlaao1wWCnqXXamwgl+2l190dfD09Giq5d5Z2JEk8X3fiiF7S01OG2Wks1M9S4bXWNBUukSkjiWQCqd4ftHh2lwr15SnC8Y5zuHhwhEU9x1YDPXllgJt9IUIyAmRGQPua+ciPwcMFrRWRmKYiwQ457Hu0mr0myEw4rT7nHxyKkxJqvMYd09HsJuK27B6/GFsAjsbC1/tzSbxcIV7XX0+EIlLfY2q4VUWhmdKc3BXSpHBqYZD8Qva627UlycDPPdI0MA/NxrtrKjZfkhxuWmGAHxSeDrwJUiMgz8HvCfKzorw6J4Z7LCQTVbJM2w8jhsFiwCD5yoHoe1qnJ2NFCU/0Fz5qVtTTUVy+vY3+EhmVb6Jkr1KSj9JZ9TPNFEmgePj65aMMepkRl+cHyEereNnz+4tWojDouJYupV1bcBbcCVqvoGE8W0uoz4o9zz+AWAVUkoMrxCu8fJ8cEZLoxXh8M6EEvhjyZxFeF/mAonmIkmy5IctxBbmtzUOqwlm5lqnXZOjcxUaFbw9AXfktqjLhdV5dmeCX5ydpztTTX83Gu2VlVZj7kUE8X0KRGpByLAX4rIyyLyjspPzTAfw/4oX3miG4uI0RyqABGh0W3nviNDJFKVtZkXw4g/ilBcg6AeX/YOvZLlGywi7O3w0D8ZIZ4s3qFf57TRNxGuSBDAdDjBj8+ufFJcKpPh0dNjvNQ/zTWb67nzwOaqz8gvxsT067nGPu8A2oFfA/6s8CmGSjA0HeErj3djFaHRCIeqod5tZzIUrwqHdW+un3Qx9PhCdNa7Kl4yen+Hh3RG6fYVr2VZLYJqtg1pufnhmTEEVjQpLpZM8/2jI5wfC/K6PS3cfmX7muhoWMwnNPsu3g18S1WPM3+vB0MFGZyK8JXHe7BbLUY4VCFtHhePnPYyFS6tD0K5OecNUl+EySIYSzIejC+rtHexdNRne4cvJW+ktwShUgzD/igv9k2uqM1/JprkO4cH8c7EuOOaTm7e2Vw1YayLUYyAOCIiPyQrIB4VEQ/ZCquGFeLiZJivPNGN02ZZ1bR7w8I4bBYEePD46jmso4k0ozNRahyLmy16V8C8NIuIsK+jjsGpCOF48RHyHpeNk8Pl80OoKg8eH8Fps67Y3bt3Jsa/vTRIJJHmAzduYX/nooWwq4piBMRvAJ8Fbs71inaQNTMZVoD+iTBfe7IHl926auF4huJo8zg5Ouinp8x3vcUy7I8iSFF3p92+EM01jhULctjf4UGhJGd+ndPGiD9WklApxIXxEOe9wRUr593jC3Hfy0PYrcKHD25jS9Paa9ZVqGHQlbmnN+T+7haRm8j2iK6s0dIAQF9OOLjt1qLMBobVxSJCg9vOvx8ZIlnhJK/5KLY8RSyZZtgfrWj00lxa6py01jlK6hh3qQ3pdGmZ2PMxmxRXv0JJcUcHpnnwxCgtdQ4+fPO2NRttWGih/33gN4G/mOc1Bd5akRkZgOzdx9ef7KHOaavqMDjDq2lw2xmajvBs9yRv3r+yfdLPjAaoK8Lh3DcRRnVlzEv57Ovw8GzPJDPRZNGmUosIF8ZCXNlZv6yxjw768c7E2NZc/oTAfDKqPH1hgmODfva01fLOazpXvULsclhw5qr6m7m/b5nnUZRwEJE7ROS8iHSLyGfnef0TInJSRI6JyDMicnVu/9tF5EjutSMisqGEUfd4kK8/2YPHZTfCYQ3S5nHy8KlRplfQYZ1IZRiYihQVkdTjC1HrtNJRv7Jhnvs7cv2qS9Ai6t22ZbchjSWzhfCKbZ60VFarb3QlWfDbJCIfLHSiqv5HoddFxArcA7wdGAJeEpH7VfVM3mHfVtWv5Y5/H/Al4A5gArhTVUdE5FqybUu3FPF+1jxd3gDffKaPepe94uGHhsrgtFlRkhw6Ocov3rp9RUwa3pkYqizqfE2lM1ycjHD1pvoVj6Spd9vZ1ODi/FiQm3c2F3WO225lZCbGTDS55Oi9py/4iCTSFc0bCsdTPHBihLFAnDfva+OGbY0VG2slKbQC3VngNQUKCgjgFqBbVXsBRORe4C7gkoDI5VfMUpu7Lqp6NG//acAlIk5Vra6iN2XmzMgM3/ppPw1uIxzWOu0eJ4cvTnPr7hauaK+8KSdrp1/8LntgKkIqoyvqf8hnf4eHJ7p8TITiRVUeFhFQZXAquiQBMRNJ8pOz4xXt9TAVTvCDVewbXUkWXIVUdbmRSluAwbztIeDWuQeJyCeBT5ONjprPlPSzwNH5hIOIfBz4OMD27duXOd3VQ1V5ssvHD46N0FrnoMZhhMNaZ9Zhfd/Lg3z67fsrbmo45w3gLuJ70+ML47BZ2NpUWVv8QlzRXseTF3x0jQWLLk1vt1k46w1w3dbSK53+6KwXVS2q9PlSqIa+0ZWkqE9NRN4jIn8oIp+ffRRz2jz7LrvFUdV7VHUP8BngVY2IROQa4H8CvzXfAKr6DVU9qKoH29pW1iFYLhKpDN85PMQPjo2wqcFlhMM6osFtZ2wmzvO9kxUdJ53JNQhaROvMZJTeiRC7WmpXLYu31mljW1MNXWOhov0KDW47p0dK90OMzkR5vmeSNk9lFu1eX6gq+kZXkmJqMX0N+DDwO2QX/Q+RDXVdjCFgW972VmCkwPH3Au/PG3cr8D3gV1S1p4jx1hyBWJJvPN3LS32TbG1yr3mHluFy2uudPHRiFH+kcg5rXzBOKq3YFvn+jMxEiSUzK5I9XYj9HR5moknGAsVZjJ02K5F4aW1IVZUHT4zisFkqIgwD0SSPnhmjpc6x6n2jK0kxK9LrVPVXgGlV/VPgtbx64V+Il4C9IrJLRBxku9Ddn3+AiOzN23wPcCG3vxF4CPgjVf1pEWOtOUb8Ub784y6GpiJsbnSXrVm8obpw2qyoKodOVq6FyvB0hGJurnt8YawWWfW+A3vasxrMeW/x0UwKDEwWnw/R4wtxdjRQkQ6L6Yzy8CkvKLz7uk2r3je6khQjIGarZUVEZDPZ1qO7FjtJVVPA3WQjkM4C31HV0yLyhVzEEsDdInJaRI6R9UN8bHY/cAXwx7kQ2GMi0l7826puTo/M8OWfXCCZVjrqXWumLothabR7XBzuny57XaFZzo0FcdoL/5RVlV5fiG1N7orZ44vFabOys6WGrvEgmSLNRi6bhTNFtiFNZ5TvHx3B47RV5Lf1fO8k3kCM269qX7eawyzFGLwfzN3R/znwMllh/s1iLq6qh4BDc/Z9Pu/5pxY4778B/62YMdYSmYzyZNc4D5wYpaXWOKM3ChaL4HHZ+O6RIT799n2LmoJKQVXpGgvicRX+Lk2EEgRiKW7eVVx4aaXZ3+GhxxdmaDrK9iKS1+rdds6PBUlndFGT0fFBPyP+aEWS4gamIhy+mC3Xva9jbdVVWgrFNAz6r6rqV9X7yPoerlTVP6781NYX8VSa7xwe5P7jI3TWG2f0RqOxxoE3EOP5vvI6rKfCCcLx9KJ9BWbrQ+1urY62lrtaa3FYLUWbmexWC4lUBm+gcBvSWDLN/ceHaa5AaYtIIsWjp7001zh48761GRRTKouuUrmEt/cAO2ePFxFU9UuVndr6YSaa5B+f66d/IszWphrjb9igtNc5efD4KNdtbqShpjymiRF/jGLyH3p8ITZXUZSczWphT1st3b4Qb8m0YbMUp1X1T4TZ0rhw0bvneiYIxVNsaSyv9qCq/PDMGPFUhg/cuGXDBJQU8y4fAH4VaAE8eQ9DEQznnNEj/ihbjDN6Q+O0Zx3WD58qn8P6wnhw0cV1JppkIpSougSufZ0eEqlsZncx1DisBct/z0STPHp6jLa68oebHh3wc3Eywhv3tlbE8V2tFHM7sVVVr6/4TNYhp4Zm+KcXLuKyWWivUCy2YW3R7nHxYv8Ut+5uYVcZzD3nvIv7Hy6Zl1Y5vHUu25pqcNutnPcGixJeHpedXl+IRCozr6P9sbNjZCqQFDcWiPHTngn2tNVy/ZbSk/XWMsV8kg+bHtSlkckoPzk7xt/+tI8Gl910gDNcwmIR6pw27jsySGqZJcGDsSRT4TjuRcIse31hWuocVfc9tFqEve119E2Ei+rnPduGdNh/eRvS7CI+WfYbsXgqzcOnvNQ4bLztqo4NF3FYjIB4HvieiERFJCAiQREpLt5sAxJPpfnXlwZ48MQomxtcuIvo7mXYWDTVOBjxx3ixb2pZ1ymmQVAkkWLEH2VPa3WZl2bZ1+khlcvwLpa+OeHCqspDJ0awW6WsSXGqyuPnfASiSe64tnNd5zssRDEC4i/IJsfVqGq9qnpUdXnF2dcpM5EkX3uih6MDfrY2ucsazmhYX7R5nDxwYoSZaHLJ1+jzhVnshrZvIozCqmdPL8TmBhcel63oaKb52pD2ToQ5ORwoe0G+s6NBzo8FuXV3c0HH+HqmmBXsAnBKV6vR7hphcCrCX/24i7FA3DijDYvisltJZ5RHTnmXfI1z3iAeZ+FoqB5fGI/LRpunPItnNJkmGFu6UJtLtl+1h4GpCNFketHja502BqejRBLZNqSZjPKDo8N4XOVNipsOJ3j8/DhbG91FlyZfjxQjIEaBJ0Tkj0Tk07OPSk9sLXF80M//eewCCmX7IW5UVJWJUJwTQ35ODPmLsk2vVdo9Ll7om+Rika1C85ltG1rjXNjsMdtEaE9rXdkWz8lQnJlokkymfPeL+zs8ZBS6xxY3M83eeA1NZ/0QJ4b8DE1HaSxjRnMqk+HhU15sVuGd13Ru6Ju9YqKY+nIPR+5hyJHJKD85N8ahk6O0eVyLOgsNl5POKOPBGMP+KCP+GCP+KPE8ofBszyQHtjVyw9bGdefPsVqEOkc2w/pTt+8tySQ54o8iUHDxGpiKkC5j74dwPEVjjZ1dLXWcGpmho748DuHWOgfNNQ7OjwWLKultEbgwFmRHSw33Hx+hudZRVu3hpxcm8YXi3HlgE3WLRIitdwq++1ySXJ2q/pcVms+aIZZM893DQ7w8MM3mBuNvKJbZbNisQIjinYmRyt2NNtbYuaK9js2NbrY0uokkUhy5OM2LfVO8nCtvcNP2JurXUf2bploHg1MRDvdPcdue1qLPG5haPHegxxfCZbOUzX7ujyT40MFt7Gqr5diQv6iyF8UgIuzrrOP53imCseSibXbrXXZODQeoc9qZiSbL2tui1xfi2FC2ZejuKnXsryQFBYSqpkXkppWazFrBH0nwrZ/2M+yPsrXJveFC30ohmkgzMhO9JBDGg3FUs3Xj2zxOrt3SwOZGF5sb3Jd10Wtw23nv9W6mwgmOXJzm5PAMJ4Zn2N/h4TU7mtZNwlKbx8n9x0e4eksD9UX2ID87GijYdTCdUfomwuxuq8VShkU8nkzjclg5sK0Rl93KbbubebFvik0N5RE++zs8PN87xYWxEDftaCp4bI3Dyog/xsOnRstq0g3GkvzozBhtHievv6KlbNddyxSjPx0TkfuBfwcuGUsX60m9XhmcivDNp3tJpHXDRjYUIhBNMuKPXjIZTeX6IFgtQme9i4M7mtjS6KazwbVo/aBZmmsdvP3qDm7b3czRQT+nhmc45w2ys6WGgzvXfoSJy25lOpLgh6e9/NxrFq+kn0xn6J+IFFwch3OmunJlT0+EE7z7uldCPd96ZQcv9E2RSmfKoj031jjoqHdyfiy4qICYvSFTpejv0GJkVHn09BhpVd51bWfRpT/WO8UIiGZgkle3Ay2mJ/W649jANN9+cYAah412j3HHqCpT4cQlYTDsjxKKZ6NLHFYLmxpdXLnJw+ZGNx31zmX/6DwuO2/a28YtO5s5MTTDsUE/3z0yxKaGrODZ1Vq7ZrW5do+LZ7snuWVnC9tbCptMvDMxMlrYvNPrC2GzSFGVUhcjmc5gFXlVNE9zrYM37W3j6S4fm8okoPd1eHj6wgTTkQRNiyT1bW4sb0LcS31TDPujvOPqjkXH3kgsKiDK0Jt6zZPJKD86O8Yjp7y0e5wbMmEGsmYLXzB+yVw04o8SyzmUaxxWtjS6L/kPWuocFYv+cNmt3LKrmRu3N3JmJMCRgWkeODFKc62Dgzua2NfhWbWWmkvFahFqnTbue3mQ3719X8H5D09HC5bnU1V6fGF2tNSUpajcZCjOG/a2XeYbeNO+Np65MEEynSnLOLMC4rw3yG27C5t4ynkjMDwd5YW+Ka7s9HDVJpPilU8x1Vy3Av8HeD1ZzeEZ4FOqOlThuVUFsWSa77w0yNHBjeeMTqYzjM7ELpmM8h3KDW47u9vq2NzoYkujmwa3fcXv3u1WCwe2NXLtlgYujAc5fHGaH54Z49meSW7ant2/lqpuNtXYc/0Gprh118IL5FlvoGDE3HgwTiie4rVty7ejpzNKWuF1ey6/VoPbzluvaufHZ8bYXAYtos5pY2uTO5uctqt5Rb5P0WSaR057qXfbecv+ddOTrGwUY2L6FvBtsr2oAX4pt+/ti50oIncAXwaswDdV9c/mvP4J4JNAGggBH1fVMyLSAnwXuBn4e1W9u7i3U16mwwm+9WwfI/4Y25pq1qz5olhUldGZGD2+EMP+KL5gnNlw97Y6J9dsrr+kJRRykK40VotwZWc9+zs89E9GOHJxmqcuTPBi3xQHtjVyYI2EyIoIbR4XDxwb4epN9fNG82QySvd4qGAnsx5fCIGyFAOcDMe5aXsjLQsEBLzhilaeOD9OPLV4T4pi2N/h4SfnxvEF47SXKYx2IVSVH58ZI5JI8fMHt616p71qpJhfeZuqfitv++9F5PcWOykXInsPWUEyBLwkIver6pm8w76tql/LHf8+4EvAHUAM+GPg2txjxRmYjPDNZ3pJbQBndCCa5Jw3yNnRAP5oEqsIHfVObtqedShvaizeobyaiAi7WmvZ1VrL6EyUw/3TvNA3xZGL01y7uYEbtzdWfYis227FH0nw6AIO64lQnESqsEmn15ftmbDcvBxVJZHK8OYCd9a1ThvvuLqTh06OluV3ckV7HY+fH+f8WLDiAuLE0Ay9E2HeuLe1bDkd641iBMSEiPwS8K+57V8g67RejFuAblXtBRCRe4G7gEsCQlXzi/7Vkut8oqph4BkRuaKIccrOyxen+dcXB6hz2mhap87oRCpDd66x+2xW6mxZgSva69b83dSmBjd3HnAzGYpzZGCaE8N+Tgz72bcGQmTbPS6e65nk1l0tl7XNHPJHKVT1ZjqSYDKcKEvHs6lwgn2dnkUX/tfuaeGxc+PEkull++dcdis7WmrpGgvxhitaK6a1+4Jxnu6eYGdLDTdua6zIGOuBYgTErwN/Dfwl2QX82dy+xdgCDOZtDwG3zj1IRD4JfJpslvZb575eCBH5OPBxgO3bt5dy6rykM8qPznh55JSXjnrXunNGqypD01HOjgbo9oVIppUGt53bdjdzVWd91d9dL4WWOifvuLqT1+5u4eUBP6dHsiGyu1prObijqSy283JjtQhuu5X7jgzxO7fvfZXDussbxFFAm+v1ZSPRl9taVFWJJNPcfmXHose67FbuuLaD7708zJYyJK3t7/DQNxFmxB9jS1P5/z/JdIaHT43isll4+9Ubr4R3KRQTxTQAvG8J157vU7/s1kdV7wHuEZFfBD4HfKzYAVT1G8A3AA4ePLis4jCxZJp7Xxzg+NAMW5rc6yoOejqS4OxogHPeIMFYCofVwr4OD1dvqmdTg2tD/EA8Ljtv3tfGLbuaOTHo59iQn38/Es6GyO5sYldLdYXINtc6GJiO8PLA9KXwUlXlvDdIfYHyDz2+EG0e57KFfSCWYkuju+gqsAd3NvOjnD1/uW1Nd7fVYrMI58eCFREQT5z3MR1J8sEbt1RNC9ZqZcFPR0Q+X+A8VdX/usi1h4B8I+pWYKTA8fcCX13kmhUhGEvy9ad68c7E2LZOMqPjyTRdYyHOegOMzsQQYHtzDa/f08qettoNFY2Vj9tu5dbdLdy0o4nTIwFeHpjmgeOjtNQ6eE0VhciKCK21Tu4/NsxVm+qpc9rwR5IEYyk8C+QAhOMpRmdi3LZr+dVHg7EkP3vTlqJ/C06blXdft5l/e2lg2Yuu3Wphd1stF8aDvHlfW1n/H+e9Qc6MBrh5Z9Nl5jvD5RT6T85XYrIW+A2y/akXExAvAXtFZBcwDHwE+MX8A0Rkr6peyG2+h2xp8RVndCaGdyZa9kbnK00mowxMRTgzGqB3Ikw6ozTXOnj9FS1c2ZldZAxZ7FYLN2xr5LotDVwYeyVE9rneSW7a3sQ1m+tXPUTW7bAyHU3wozNjfODGLdkGQbJwDkDvRPYnu6d9ednTs0X5Ss0JuHF7Iz887SUUTy37u7a/w0PXWIiBqUhZorEgWyLnsXPjbGpwcVuBMGLDKyz4X1TVv5h9LiIe4FPAr5G90/+Lhc7LOz8lIncDj5INc/07VT0tIl8ADqvq/cDdIvI2IAlMk2deEpF+oB5wiMj7gXfMiYAqK2u5pO9EKH7JhBRJpHHZLFy7uZ6rNtXT7nGuC42oUlgtwpWb6tnfmQ2RPdw/xZNdPl7om+TA1kYObGtc1Sq9HR4Xz1zwcfPOJrrHQwXrKvX4suGvLbXLC6yYLcpXqpZpt1p47/Wb+KfnLy5bQOxoqcVps9A1FiyLgEhnlEdOexGBO67pLEt9qo3AYtVcm8k6kD8K/ANwk6pOF3txVT0EHJqz7/N5zz9V4NydxY6zEYkkUlkT0miA8WAci8DOllqu2lTPrtbaqjCTrCXyQ2RH/FEOX3wlRPbmnc3cvLNpVQTtrMP6P14eJpJIL+h/iKfSDE1FuX5bw7LmmV+Ubylct7WRds8YgWhyWX6Q2X7V58eCZcnUfq5nkrFAnHdf17kugzEqRSEfxJ8DHyTrBL5OVYtvGmuoCLMVOs+OBuifDJPRbCXQN+1tZX+nxzjcysTmRjfva8yGyD7fN8Vzvdn+AO+4umNVzE7NtQ76J7LtRRcKOb04GSGtuuzifHOL8pWK1SLceWAz33y6d9ld3vZ1eDg1EqBvIsy+Ds+Sr3NxMsyRgWmu29LA3valX2cjUmhF+X0gTjay6P/J+0cLWSe1KVqyAqgq48GsCen8WJBYMkONw8oN2xq5alN9Vcfzr3Va6py8+9pOjg74ebp7gkA0yZ3Xb17xJjIiQqvHSTCaWnDB7fGFcNutbGpYesLXfEX5lsKVnR62NdfgjyRoXEbhuy1NbmodVrrGgksWEOF4ikdPj9FS6+BNe4vvt2HIUsgHsTHDXKqEUDzF+Vx282Q4gdUi7G7NmpB2NNcYG+oKISLctKOJxlo7j5zycu9LA7z3wGY6Vzjz1m23LugLSWWy5b/3dtQty5e2UFG+UrFYhPdev4mvPtmzrBpdFhH2dng4OTRDPJnGWaJWo6o8esZLMp3hXddu2bCRe8vB2CSqiFQ6Q48vzFlvgIHJCApsanDx1v3t7O2oW3eJe2uJ3a11/PzBbTxwfITvHhniHVd3LMvsUU6Gp6Mk0plltRYtVJRvKVzRXsfutlrGZuI0L8Npvr/Tw7FBP92+ENdsXrwdaT5HLk4zOBXl9ivbF6wlZSiMERBVQDqjHBv082L/FIlUhjqnjYM7m7hqU72pTV9FtNY5+fDN23jwxCgPn/IyFU6sWNXRQnT7QtitwvZlZDFPhAoX5SsVEeE9123mrx+7QFPN0rWIDo+TBred82PBkgTE6EyU53on2dtexzWbjTV8qRgBscoMTkV44ryPqUiCnS013LS9ybQxrWJqHDY+eNMWHjs3zgt9U0yFE7x9lZzXkDWj9PrC7GhZevKjqpJMFy7KtxR2ttRw5aZ6+nzhJbcGFRH2d3h4qX+KcDxVVBXheDLNI6e81Dpt3H5lu/ktLQNjlFslgrEkD58c5T+ODpPKZLjz+k3cdcMWtjWv/7Liax2bxcLbr+rgDVe0cmE8xHePDBGKpVZlLt5AjEgiXXRJjPkotihfqYgI77q2k3gqTaZAgcHF2N/pQYEL44sHUqoqPzk3TjCe4l3XdpbstzC8GiMgVph0Rjl8cYp/ev4iPRNhbt3VzC/ftoPdZeodbFgZRITX7Gjizus3MR1JcO9LA4wFYis+jx5f+FIOzFIopSjfUtjaVMOBrY1MhOJLvkZzrYPWOgfnvcFFjz09EuDCeIjX7m5hU0P1FWJcaxgBsYIMTEX4lxcuUKu3BAAAHJpJREFU8tPuSbY21fDLt+3gtt0tJrpiDbO7Leu8tliEfz8yRNfY4otYuVBVesZDbG2qWXIAQ6lF+ZbCO67pJJnKkM4sQ4vo8OANxJiJJhc8ZjIU58kuH9ua3Rzc0bTksQyvYFamFSAYS3Lo5CjfOzpMRuF9BzbzvgObC3YFM6wdWuucfOTmbbR7nDx8ysvzvZMFezaUi+lIEn80uazopWAsyTsqXPK6s8HFwZ3N+IJL1yJmI8bOLyCAU+kMD5/yYrdaeOfVncZMWyaMgKgg6YzyUv8U//jcRXonwty2u5lfunV72YqPGaqHWef1VZ0eXuib4pFTXlLpTEXH7PFlbfJ7WpdmnlxqUb6l8LarO8ioksos7TOpd9vZ1OCiawEz01MXJpgMJ3jHNR1V1Q53rWM+yQpxcTLME10+/JEku1tredO+NqMxrHNslmwDmuY6Bz/tnsQfTXLngc0Vq6Lb4wvRUe9ccma3P5LgQzeXXpRvKbTWOXndnhae65lk0xKd4fs7PDzR5WMiFH9VBYHu8RAnh2e4aXvjkn0xhvkxGkSZCcSSPHRilO8fG0EV7jqwmTuNOWnDICIc3NFcced1MJZkLBBfcu2lS0X5tq5cu823XNkOIkvWrPZ21CHCq5zVgViSH58do93j5HV7TCmNcmMERJlIZf7/9u49OK76SvD493S31K33+y3rLfn9RPgBOAZjwLyTkEBCkiHALGEWmDC7s1NJbc1kN1uZ2pnsZLIzxWRDZUlqZ8NAQlIzDEOAwBA2EB42EwLG2NjYxpZlyZb1bvW7z/5xb9tt0TLqtlrdUv8+VV3qvn1v6/bVVZ/+/c7vnl+UN44M8/evfsiR0162dFTxxU0ttJnupJzUUVPMZy9agkOEJ97s48AcJ6/PzP2QYoAY8gbZvqx2Xq/OLy/MZ1tPNSdTHNFUmO+ipaKQ9wcnUFWiUeWZPQOowrWr6k0F4zQwAWIOHDnt5cevHeXVD07TWmWNTtrYXmlGJ+W4mhI3t/UuoabEzdN7Bnh9DpPXh055KS/Mo6Iw+ZbpXBXlS8XWnhqcIgTDqbUieupLGPeHGRj38/rhYU6M+bliWc0FFQU0ZpbWTzAR2Ski+0XkoIh8LcHz94rIOyLyloi8LCIr4p77ur3dfhG5Jp37mapxX4in3u7nn96yZlL95LpGbljTaOrNG2cUuV18en0Ty+pLeO3wMM+8e+HJa38oQt/IFJ01xSmN1hmaCHBZd/UFF+VLRaknjyuX13IqxVZEZ40118mvDwzxxpFhljeUsKzelNJIl7QlqUXECTwEXIU1P/UuEXly2qxwj6rq/7LXvwn4DrDTDhSfA1YCjcDzItKjqpF07W8ywpEo/3Z0lF1HhgGrwNn6lnJcDtNiMD7K5XRw9Yo6qoryeeWD04z5QtywJvXkdWwukFSuXYhElegcFuVLxaVd1by4/xSBcAS3K7kuLrfLSXtVEQdPTVJRmMflPXNbHiQZgVCEwQk/LocDVfDkOSjx5JHvWjyfA+kcxbQROKiqhwBE5DHgZuBMgFDV8bj1i4BY+/tm4DFVDQCHReSg/XqvpnF/Z+XIkDU6acwXoqummK091ZRm4JuYsbCICL1tlVQU5fPsuwM8vusYN65poDaFsuEfnPJSmO9MqeT40GSADa1zV5QvFYX5Lq5ZUc8/v308pXngVzWVcnzUx7WrGjL2YTwVDDPsDXL7plYayjz0j/rYPzjBwcFJhiat77EOEUo8LgrznQv2uox0Bogm4Fjc4z5g0/SVROQ+rGlN84Htcdu+Nm3bpvTs5uyM+0K89P4pDg1Zfb+fXNdIqxlSZySp005eP/m7fn76Zh9Xr6xLapazcCTKh6e9LK0vSfpDJ11F+VKxqaOSF/YN4gtFkp7zu7WqiH+3tT1jH7qT/jDj/hB3XdZ+psJsc0UhG9urUFVGpkL0j/o4POTl/cEJToz5EYGoQlG+k2K3a8HkJ9MZIBL99T6SoVPVh4CHROR2rNnr7pjttiJyD3APQEtLywXt7EzCkShvHh1h15ERBNOdZFy4mhLryuun3j7B0+8MsKUjNOs5r4+OTBGKKF0pjF5KV1G+VHjynFy7qp4n3uyjOYUy5ZkKDmO+EP5QhHsv70w4gkxEqCzKp7Ion1VNVvDwhyKcGPNzbNjLvoFJDg9NEo4qGlXyXU6KPS48LkdWtjLSGSD6gCVxj5uB/vOs/xjwvWS2VdWHsebMpre3d85rGxwe8vKS3Z3UXVvM1gwl9ozFp8jt4pYNTbyw7ySvHjrNaW+Aq5bXfew3y0OnvOQ7HUl/qKa7KF8qLmqt5Jd7B2ddxjvThr1BQLnvii6WVM7++HvynLRXF9FeXcQnemqJRJWhyQD9oz4Onpzk/cFJ+ketVoaIdW4U57uyYtbIdP5VdgHdItIOHMdKOt8ev4KIdKvqAfvh9UDs/pPAoyLyHawkdTfwRhr39RxjdnfS4SEvFYV5fGp9Ey1JnBCGMRux5HVlUT6/sZPXN65pnPHDMmrP/dBWXZj0mP/5KMqXrHyXg+tXN/DoG0ezPkAMTQZwuxx8ZVsXdRc43azTIdSVeqgr9bC+xSoqOO4PcWLUz4envewfmODYyBSqVreJx5W55Hfa/iqqGhaR+4FnASfwiKq+KyLfBHar6pPA/SKyAwgBI1jdS9jr/QQroR0G7puPEUzhSJTdH46w+8MRHAKXdlWxfkmFuQDHSBuxr0eoKLSS14/tOsaNaxuoLfnoh9CJUT++UCSli+Mm/CFu2dCUdd0Ya5eU8+zeQSb8oaxtnQ+O+ykvzOOeT3Re0PSp51PqyaO0Po+l9SVcvbKeYDjK4Lif4yM+3j85wcGTVvJbsQJMiXt+kt9pDduq+jTw9LRlfxZ3/6vn2fZbwLfSt3fn6h/18cyeAcb9YXpqizM2TtzITV21xZQV2Mnr3X1cs7KertpzA8EHQ5M4RWitSq41O59F+ZLlcjq4YU0DP/rNkaz7f1NVBsb9NJQVcPfW9nkdrZjvcrCkspAllYVs7rSS38PeICfG/Bwa8rJ/YJz+MT+C1crQj6Zo50R2t+vmwclxP3/6j3t4/fAwlYX5fHp9U1L9i4YxV+KT1//yzgm2dFSdSV7HphZtrixI+tqB+SzKl4qVjWU0lHoY84WypmaZqtI/6qejtogvX9JGYX5mPypFhKpiN1XFbiv5vbYRXzDCiTEffSNTDE0GcaShNZHzAaIg30nfiI+1zWVs7a4x3UlGRsWS18/byethb5Ady2sZ9YUY84W4KMmJcDJRlC9ZTodw47pGHn7pEKUeV8a7waKq9I/4WNVcxu2bWpIOyPOlIN9JR01xWmejzPkAUeLJ4wd39PLDVw6b4GBkBZfTwTV28vpVO3ldW2pd2NaRZPHHIW+Q61bXz2tRvlQsrSuhtaqI094AFRmsqxSJKsdHfWxqr+SWi5rJy9JW13zJ7XdvM4EhOwXCkXmZmS0biQgb2yq5fnUDQ5MB3u4bo6HMk9Ron1AkisuRmaJ8yRIRrl/TwKQ/nLG/eTgSpW/Ux+VLa/hs75KcDw5gWhBGFgpHogyM+3E5HYTCURrLC3I2iHfVFlNa0Mwv9w6yprksqW2HJgJs7anJuuTvTDpriuiuK+b4iG/eS4EEw1EGxn1ct6qBq9I8BetCYkKkkTVUldOTAQYnAly9sp5v3LiCrT3VHB/xpVweejGoLfHwhU2tSVUtzYaifMkSEa5b3YAvNL8tx0AowsC4j1suajbBYRrTgjCyQiAc4eR4gJbKQm69eAmNdjmIT65roq7Uw8/e7KO8MD9t03cuNtlQlC8VLZWFrGws5eDJSWoSXAsy12JF9764uS3pAQC5wPy3GRmlqpyaCBJV5dMbmtjcUXXOcEwR4ZLOampL3Dzy8hGC4QiVRQvrQ2++ZVNRvmSJCNesauDd594nGtW0lpuIFd27+7J2VjQm132XK0wXk5ExvmCEYyM+2msK+U87l3JZd82MY/W7akt48KpuitwuToz5cjZ5PRvZVJQvFU3lBaxvKWcoxUmFZmPMF2IqFObeyztNcDgPEyCMeRdVZWDMx1QwzO9tbuX3L+ugehZdIbUlHh7Y3k1XbTF9oz4iURMkpsvGonypuHpFHaGopuVvPOwNEolGue+KrpTn9M4VJkAY82rCH7IuTFxSzp9cu4z1rRVJdSMUuV3cdWk7W7trOD7qIxDOikkGs0Y2FuVLRW2ph43tlSlPTTqToYkAeU7hge3dKZUZzzUmQBjzwroAaQqAe7d18vmNLSnXtnE5HXxyXSO39jZzaiLAZCA8l7u6oE34Q1yzcnGMxLlyWS1R1QuewztmcNxPaaGLB7Z3pzSTXy4ySWoj7UamgngDYbb11HDVinoK8i/8ql4RYUtnNTUlHh55+TCBcISqHE9ex4ryJTMcNptVFbu5rKuaVw4O0VCWej4lk0X3FjrTgjDSJhSJcnxkimK3iz+8spub1jXNSXCI11VbzINXdVNskteMTgW5emV91hblS8XlPbUI1rmUClXl+KifjupivrKtwwSHJC2eM8nIGqrWjFmnJgJcu7qBB3f0pHX+7ljyuru2JGeT1wuhKF8qygrzuHxpLScnks9FRNWqq7SqqZQ7L8t8RdaFyAQIY04FQhH6Rnw0lHn442uWcuXyunmZCavI7eLOS9vY1pObyeshb4Dty2qzvihfKrb21JDnkKSupo9Elb6RKS5uq+RLm1uztiJrtkvrf66I7BSR/SJyUES+luD5/yAie0XkbRF5QURa4577CxHZY99uS+d+GhdOVRkc9zPmC3FrbzN/cPmFT82YLJfTwU1rG7ktlrz250byOhSJ4nQ4FkRRvlQUu13sWFE36xFN4UiUvpEprlhay6292TsPxkKQtjaXiDiBh4CrgD5gl4g8qap741b7LdCrqlMi8gfAXwK3icj1wAZgHeAGXhKRX6jqeLr2N5NUlclAmHF/GBTyXEKpJw+3y7EgRqN4A2FOe4OsbirjU+ubqEjTtIyzISJs7qymOpa8jiz+5PVCK8qXiks6q/nXfSfxhyLnbSUFw1EGxvxcv6aBHcsXx2iuTEpnaN0IHFTVQ6oaBB4Dbo5fQVVfVNUp++FrQLN9fwXwkqqGVdUL/A7YmcZ9zYhAyJoRqn/MT0G+k1s2NPOlLa1c1FpBKBKlf8xP/6iPgXE/U8HMlUGeSTSqnBjzEYxEuevSNu68tC2jwSFeLHld4nExMObPumM3VxZiUb5UFOQ72bmqntOTwRnX8YciDIz7uaW3yQSHOZLOrE0TcCzucR+w6Tzr3w38wr7/O+AbIvIdoBC4Atg7fQMRuQe4B6ClpWUOdjn9wpEow94goUiUIreLK5fXsba5nLpS95kTeu2ScnSDMu4L0zc6xQenvLzXP07/mA9BEIESdx5F7vRPWj6TcV+IUV+QLZ3VXLe6ISuL6NWWeLj/im4eff0o750YX5RlwxdqUb5UXNxWyfN7B5kKhj+ScI4V3fvS5lY2mKJ7cyad/9WJ/hMTfo0TkS8CvcA2AFV9TkQuBn4DnAJeBT7SoayqDwMPA/T29mbtV8SoqlX7JRDB5RTWLSmnt62S9uqiGT+wRISywjzKCstY2VjGTWsbmQyEOT7i4/DQJO/225OW27OWF7tdFLtdaS1uBlaAG5wIUFGYx31XdNFVW5LW33ehYsnrf3nnBL/ad5K6Ms+iSVgu5KJ8qfDkObluTQOP7zp2ToCY8IeYDIT5/a3tLG8wdZXmUjoDRB+wJO5xM9A/fSUR2QH8Z2Cbqp7JQqnqt4Bv2es8ChxI477OOVVlKhhh1BcCoKumiC2dVSytL015pEmx28XS+hKW1pewc1UDvmCE/jEfHw552XtinKPDUyigUShyOyn2uHA55q4XcdgbxBcMs3153YIaMRNLXteXevjJ7mOUFeQtiv76YW+QpfWlC7YoXyo2tFTw3LsDeANhitwuxnwhAuEI927rTOvczLkqnQFiF9AtIu3AceBzwO3xK4jIeuD7wE5VPRm33AmUq+ppEVkDrAGeS+O+zplAOMKwN0RUlaqifG5e18iqxrK09M0X5DvprCmms6aY7cvrCIQjDIz5OXp6ir0nxjk85CUSVRQoyHNS4nGlNI1iMBxlcMJPc3kBX9nWsSBr2IgImzqqqC5x88jLhwl6Aws6eR0ryrd9WW60HmLynA5uWN3I/339Q3sos3DfFV0L8pxcCNIWIFQ1LCL3A88CTuARVX1XRL4J7FbVJ4FvA8XAT+2+9KOqehOQB/zaXjYOfFFVs3bMYiSqDHuDBCPWCIttPdWsXVJOU3nBvOYI3C4nrVVFtFYVsbWn5szUnX3DPvYNjnNgcJJgJIoquF0OSjyu83a3xC54C0eVm9c2cWlX1YIfMthZU8yDO3p45JVDnBjzUV/qWZDJzMVSlC8Vq5vLqH3PTSAc5d5PdJq6Smkki2V0R29vr+7evTulbd8fnOAHvz6UVL0XVWXcH2YyEMIhDtY0l7Gx3corZOtk59GocmoyQN/wFPsGJ3h/YAJvMIIALue5Q2t9oQinJgIsrS/hlg3N1JQs3G/biUwFwzz6+lHe7R+naQEmr/tGprjz0jZWNS2uK6dn6+S4H7fLSVnhwu8qzDQReVNVexM9l31DT7LcVDDM6FQIVWirLuKmtQ0sayhdEJfxOxxCXamHulIPF7VVWnNAe4McH/FxYHCC9wbGOT0WBIV8l4PbN7VwUUty5bgXisJ8F1++pI2n3znBiwsseb3YivKlwrQa5kf2f6plgWA4yvBUgEgUygvyuG51A6uby2Y1yU02ExGqi91UF7utobVqDa3tH/PRWFaw6L+duZwOblzbSN0CS16PTAW59WJzhbCRfiZAzCASVUamggRCEdx5TrZ0VLGhpZLmioJF+Y0a4ofWZv+H5FyJT17/8OXDnM7y5HUgFKFgERblM7KTCRBxVJUJf5iJQAhBWNlYyqaOKjpriuel4JyROZ01xXx1Rw+PvHI4q5PXQ94A169uXDBDjI2FzQQI22QgQv+Yn6byAq5dXc/yhtIF0d1gzJ2aEjcPbO/K2uR1KBLF5XDQ22auFDbmhwkQQE2xm9t6m1neUEpNiTsrvzka8+Oc5PX+k9SVZk/yOheK8hnZxQQIoKIoP2fKFRgfL5a8ri/18PjuPko9rjNdOjq9WoyeWz9Gz1l+9plEo8lnXPcjd6y7uVCUz8guJkAYRgIiwkY7ef347mNMBcM47JalCGdamRJ7jIBArEdKHCB2seRzt7O2Orvd2deLtVvPri/EGrMC9PSU5ERRPiN7mABhGOfRUVPM169dnundMIyMMENzDMMwjIRMgDAMwzASMgHCMAzDSMgECMMwDCMhEyAMwzCMhEyAMAzDMBIyAcIwDMNIyAQIwzAMI6FFM6OciJwCPsz0flygamAo0zuRRczxOJc5HmeZY3GuCzkerapak+iJRRMgFgMR2T3T1H+5yByPc5njcZY5FudK1/EwXUyGYRhGQiZAGIZhGAmZAJFdHs70DmQZczzOZY7HWeZYnCstx8PkIAzDMIyETAvCMAzDSMgECMMwDCMhEyDmkYgsEZEXReQ9EXlXRL5qL68UkV+KyAH7Z4W9XETkb0TkoIi8LSIbMvsO5p6IOEXktyLylP24XURet4/F4yKSby93248P2s+3ZXK/00FEykXkCRHZZ58jW3L83Pgj+/9kj4j8g4h4cun8EJFHROSkiOyJW5b0+SAid9jrHxCRO5LZBxMg5lcY+I+quhzYDNwnIiuArwEvqGo38IL9GOBaoNu+3QN8b/53Oe2+CrwX9/gvgL+2j8UIcLe9/G5gRFW7gL+211ts/ifwjKouA9ZiHZecPDdEpAn4Q6BXVVcBTuBz5Nb58SNg57RlSZ0PIlIJfAPYBGwEvhELKrOiquaWoRvwT8BVwH6gwV7WAOy3738f+Hzc+mfWWww3oNk+ybcDT2FNvTwEuOzntwDP2vefBbbY9132epLp9zCHx6IUODz9PeXwudEEHAMq7b/3U8A1uXZ+AG3AnlTPB+DzwPfjlp+z3sfdTAsiQ+wm8HrgdaBOVU8A2D9r7dVi/yQxffayxeK7wJ8AUftxFTCqqmH7cfz7PXMs7OfH7PUXiw7gFPBDu8vtByJSRI6eG6p6HPgfwFHgBNbf+01y9/yISfZ8uKDzxASIDBCRYuBnwIOqOn6+VRMsWxTjkkXkBuCkqr4ZvzjBqjqL5xYDF7AB+J6qrge8nO0+SGRRHw+7G+RmoB1oBIqwulGmy5Xz4+PM9P4v6LiYADHPRCQPKzj8WFV/bi8eFJEG+/kG4KS9vA9YErd5M9A/X/uaZpcCN4nIEeAxrG6m7wLlIuKy14l/v2eOhf18GTA8nzucZn1An6q+bj9+Aitg5OK5AbADOKyqp1Q1BPwcuITcPT9ikj0fLug8MQFiHomIAP8beE9VvxP31JNAbHTBHVi5idjy37NHKGwGxmLNy4VOVb+uqs2q2oaVfPxXVf0C8CLwGXu16ccidow+Y6+/aL4hquoAcExEltqLrgT2koPnhu0osFlECu3/m9jxyMnzI06y58OzwNUiUmG3yq62l81OppMwuXQDLsNq3r0NvGXfrsPqK30BOGD/rLTXF+Ah4APgHawRHRl/H2k4LpcDT9n3O4A3gIPATwG3vdxjPz5oP9+R6f1Ow3FYB+y2z49/BCpy+dwA/iuwD9gD/D3gzqXzA/gHrPxLCKslcHcq5wNwl31cDgJ3JrMPptSGYRiGkZDpYjIMwzASMgHCMAzDSMgECMMwDCMhEyAMwzCMhEyAMAzDMBIyAcLIGSKiIvJXcY//WET+i33/RyLymRk3ttZpFJEn7PvrROS6Ody3chH594l+l2FkigkQRi4JAJ8WkepUNlbVflWNBZF1WNewzFrcFcCJlANnAsS032UYGWEChJFLwlhz9/7RDM/vEJFfi8j7dq2oc4hImz03QT7wTeA2EXlLRG4TkSK7fv8uu9jezfY2XxaRn4rIPwPPiUixiLwgIv8mIu/E1gP+O9Bpv963Y7/Lfg2PiPzQXv+3InJF3Gv/XESesWv9/6W93Gm3iPbY28z0fg3jvM73jcYwFqOHgLdjH6bTtAHbgE7gRRHpUlX/9JVUNSgif4Z1ter9ACLy51jlHe4SkXLgDRF53t5kC7BGVYftVsSnVHXcbsm8JiJPYhXmW6Wq6+zXa4v7lffZv3e1iCzDCjQ99nPrsKoCB4D9IvK3WBU+m9SaRwF7fwwjaaYFYeQUtarn/h+syWim+4mqRlX1AHAIWJbES18NfE1E3gJ+hVX6ocV+7peqGiscJ8Cfi8jbwPNYpZfrPua1L8MqNYGq7gM+BGIB4gVVHbMD2V6g1d73DhH5WxHZCZyvYrBhzMgECCMXfRerrk3RtOXT684kU4dGgFtUdZ19a1HV2Ex53rj1vgDUABfZrYVBrGDyca89k0Dc/QjWZDojWDPS/Qqr9fGD2b8NwzjLBAgj59jf5n/C2ekqYz4rIg4R6cQqCrf/PC8zAZTEPX4WeMCuPIqIrJ9huzKseTBCdi6hdYbXi/f/sAILdtdSy/n2ze66cqjqz4A/xSobbhhJMwHCyFV/BUwfzbQfeAn4BXBvovxDnBeBFbEkNfDfgDys/MYe+3EiPwZ6RWQ31of+PgBVPQ28YieWvz1tm78DnCLyDvA48GVVDTCzJuBXdnfXj4Cvn2ddw5iRqeZqGIZhJGRaEIZhGEZCJkAYhmEYCZkAYRiGYSRkAoRhGIaRkAkQhmEYRkImQBiGYRgJmQBhGIZhJPT/ARYj8ISvhNO0AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "original_data = np.genfromtxt(\"datasets/dataset3.csv\", delimiter=\",\")\n",
    "miss_rate = 0.2\n",
    "\n",
    "gain_parameters = {\"batch_size\": 128, \"hint_rate\": 0.9, \"alpha\": 100, \"iterations\": 10000}\n",
    "nb_iters = np.linspace(start=100, stop=1000, num=10, dtype=int)\n",
    "nb_repeat = 5\n",
    "\n",
    "rmse_list = np.zeros((nb_iters.shape[0], nb_repeat))\n",
    "for n1 in range(nb_iters.shape[0]):\n",
    "    print(f\"{n1}/{nb_iters.shape[0]}\")\n",
    "    gain_parameters[\"iterations\"] = nb_iters[n1]\n",
    "    \n",
    "    for n2 in range(nb_repeat):\n",
    "        miss_data = introduce_missing_data(original_data, miss_rate)\n",
    "        norm_miss_data, norm_params = normalization(data=miss_data)\n",
    "        norm_original_data, _ = normalization(data=original_data, parameters=norm_params)\n",
    "        \n",
    "        norm_imputed_data = gain(norm_miss_data, gain_parameters)\n",
    "        norm_rmse = compute_normalised_rmse(norm_original_data, norm_miss_data, norm_imputed_data)\n",
    "        rmse_list[n1, n2] = norm_rmse\n",
    "\n",
    "\n",
    "mean_rmse = np.mean(rmse_list, axis=1)\n",
    "std_rmse = np.std(rmse_list, axis=1)\n",
    "\n",
    "plt.figure()\n",
    "plt.xlabel(\"Nb iterations\")\n",
    "plt.ylabel(\"Normalised RMSE\")\n",
    "plt.plot(nb_iters, mean_rmse, color=\"C0\")\n",
    "plt.fill_between(nb_iters, mean_rmse-std_rmse, mean_rmse+std_rmse, color=\"C0\", alpha=0.5)\n",
    "plt.title(\"GAIN for Dataset 3\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
