{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Using backend: pytorch\n"
     ]
    }
   ],
   "source": [
    "import pickle\n",
    "import higher\n",
    "import os\n",
    "import copy\n",
    "\n",
    "from util import *\n",
    "from nonneg_sgd import *\n",
    "from bilevel_gcn import *\n",
    "from evaluation import *                           \n",
    "from flow_estimators import *\n",
    "from gcn import *\n",
    "from bilevel_mlp import *\n",
    "from flow import *\n",
    "from mlp import *\n",
    "from tikhonov import *\n",
    "\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]=\"2\"\n",
    "CUDA_LAUNCH_BLOCKING=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Reading traffic data\n",
    "data_folder = \"../data/\"\n",
    "\n",
    "G = read_net(data_folder+\"lac_comp.csv\")\n",
    "\n",
    "pfile = open(data_folder+\"features_traffic.pkl\", 'rb')\n",
    "features = pickle.load(pfile)\n",
    "pfile.close()\n",
    "\n",
    "pfile = open(data_folder+\"flows_traffic.pkl\", 'rb')\n",
    "flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Preprocessing\n",
    "G, flows, features = make_non_neg_norm(G, flows, features)\n",
    "features = normalize_features(features)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "#WARNING: Creating new folds\n",
    "train_test_folds = generate_folds(flows, 10, .1)\n",
    "\n",
    "pfile = open(data_folder+\"folds_traffic.pkl\", 'wb')\n",
    "pickle.dump(train_test_folds, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Reading existing folds\n",
    "pfile = open(data_folder+\"folds_traffic.pkl\", 'rb')\n",
    "train_test_folds = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Registering nonnegative sgd optimizer on higher\n",
    "higher.register_optim(NONNEGSGD, DifferentiableNONNEGSGD)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "learning_rates = [1, 1e-1, 1e-2, 1e-3]\n",
    "num_nodes = [4, 8, 16]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "best_res = None\n",
    "\n",
    "for lr in learning_rates:\n",
    "    min_div_params = {}\n",
    "    min_div_params['n_iter'] = 3000\n",
    "    min_div_params['lr'] = lr\n",
    "    min_div_params['early_stop'] = 10\n",
    "    min_div_params['nonneg'] = False\n",
    "    min_div_params['min_lamb'] = 0.\n",
    "    min_div_params['max_lamb'] = 3.\n",
    "    min_div_params['priors'] = zero_prior(G)\n",
    "    \n",
    "    min_div = MinDiv(G, {}, min_div_params)\n",
    "    \n",
    "    min_div_res_avg, min_div_res_std,\\\n",
    "        min_div_pred_flows = ten_fold_cross_validation(train_test_folds, G, flows, min_div)\n",
    "    \n",
    "    if best_res is None or min_div_res_avg['RMSE'] < best_res[0]['RMSE']:\n",
    "        best_res = copy.deepcopy([min_div_res_avg, min_div_res_std,min_div_pred_flows])\n",
    "        \n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'mlp_traffic.pkl'\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(best_res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'min_div_traffic.pkl'\n",
    "pfile = open(results_file, 'rb')\n",
    "min_div_res_avg, min_div_res_std, min_div_pred_flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.945832849488524,\n",
       " 'MAE': 0.04166463658489552,\n",
       " 'MAPE': 1.2368809684446587,\n",
       " 'PEARSON': 0.763432278108148,\n",
       " 'RMSE': 0.07109697736378903,\n",
       " 'TRAIN-TIME': 424.36859662532805,\n",
       " 'TEST-TIME': 0.09057497978210449}"
      ]
     },
     "execution_count": 25,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "min_div_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f9346397668>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "corr, x, y = correlation(flows, min_div_pred_flows, {})\n",
    "\n",
    "plt.close('all')\n",
    "plt.scatter(x, y, color='red')\n",
    "plt.xlabel(\"True flow\", fontsize=28)\n",
    "plt.ylabel(\"Predicted flow\", fontsize=28)\n",
    "plt.ylim(None,1.05)\n",
    "plt.xlim(None,1.05)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "\n",
    "\n",
    "plt.savefig(results_folder+'min_div_traffic_scatter.pdf', bbox_inches='tight', dpi=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#MLP\n",
    "\n",
    "best_res = None\n",
    "\n",
    "for lr in learning_rates:\n",
    "    for n in num_nodes:\n",
    "        mlp_params = {}\n",
    "        mlp_params['n_iter'] = 5000\n",
    "        mlp_params['lr'] = lr\n",
    "        mlp_params['early_stop'] = 10\n",
    "        mlp_params['n_hidden'] = n\n",
    "        mlp = MLPFlowPred(G, features, mlp_params)\n",
    "\n",
    "        mlp_res_avg, mlp_res_std, mlp_pred_flows = ten_fold_cross_validation(train_test_folds, G, flows, mlp)\n",
    "        \n",
    "        if best_res is None or mlp_res_avg['RMSE'] < best_res[0]['RMSE']:\n",
    "            best_res = copy.deepcopy([mlp_res_avg, mlp_res_std, mlp_pred_flows])\n",
    "            \n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'mlp_traffic.pkl'\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(best_res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'mlp_traffic.pkl'\n",
    "pfile = open(results_file, 'rb')\n",
    "mlp_res_avg, mlp_res_std, mlp_pred_flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 5.693612603908283,\n",
       " 'MAE': 0.055613352592793416,\n",
       " 'MAPE': 1.1303974222264288,\n",
       " 'PEARSON': nan,\n",
       " 'RMSE': 0.083462658115158,\n",
       " 'TRAIN-TIME': 21.946645188331605,\n",
       " 'TEST-TIME': 0.1023705244064331}"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mlp_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAacAAAElCAYAAABAly1LAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4xLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvAOZPmwAAIABJREFUeJzt3Xu4HVV9//H3NzcgFy45CTdjTiQSwIoiBANSaUJqimgLRbHVgOCllASBWryU0lbhMUrVYhRFiDYKJtSf2gptRaEqQa6FUKg3LhZMQEAICZIAIQnJ9/fHWsPe2dmz98zs2Wfvffbn9TzzTM7MmrXWnHOyv2fNWrOWuTsiIiLdZESnKyAiIlJLwUlERLqOgpOIiHQdBScREek6Ck4iItJ1FJxERKTrKDiJiEjXUXASEZGuo+AkIiJdZ1SnK9CrJk2a5NOmTet0NUREespdd931lLtPbpZOwamgadOmsXLlyk5XQ0Skp5jZ6izp9FhPRES6joKTiIh0nZ4JTmb2djO7xMxuMrP1ZuZmtqxgXlPMbKmZPWZmm8xslZktNrM9yq63iIjk10t9Tn8HvBZ4FvgNcGCRTMxsOnArsCdwDXAf8HrgHOBYMzvK3deWUmMRESmkZ1pOwAeBGcCuwIIW8rmUEJjOdvcT3P1v3P0Y4HPAAcCilmsqIiIt6Zng5O43uPuvvIXVEc1sP2AesAr4Us3pjwHPAaeY2bjCFRURkZb1THAqyTFxf727b6s+4e4bgFuAscARQ10xERGp6LfgdEDcP5By/ldxP2MI6iIiIin6LTjtFvfPpJxPju9e76SZnW5mK81s5Zo1a0qvnIiIBP0WnJqxuK/br+XuS9x9prvPnDy56ewbIiJSUO7gZGaHm1mvBrWkZbRbyvlda9KJiEgHFHnP6b+BDWZ2M7AibnfVDjDoUvfHfVqf0v5xn9YnJSIiQ6DoS7gTgGPjBvBsjwSrG+J+npmNqK6jmU0AjgI2Ard3onIiIhIUeTz3J8DFwN2EvhmjEqwuInywP21m3zOzD3fiMaCZjTazA+NsEC9x9weB64FpwJk1l10AjAOudPfnhqSiIiJSl7XwTitmtitwNDA7bodQCXjVGT8L3Azc4O6fLVjWCcAJ8cu9gT8CHgJuiseecvcPxbTTgF8Dq919Wk0+tdMX3QvMAuYQHue9Icv0RTNnznQtmSEiko+Z3eXuM5umayU41Sm0UbACcHcfWTDvjxNmcUjzUiBqFJzi+ZcDFxJaewPA48DVwAXuvi5LfRScRETy60hwqircgEOB44GzCKPgjBaCU7dRcBIRyS9rcCptVnIzO4TQWpoDvJHKcO3k3aFNwG1llSciIsNX4eBkZq8hBKLZhEd5yawKSTDaTBh2voIwSu42d99UtDwREekfuYOTmf0r8AdAsjBfdTC6kxCIVgC3uvsLJdRRRET6TJGW059SGUJ+K5WW0a3uvrG8qomISL9q5f0jJ8yoMCNu08qokIiISJGW02cIj/UOBSYDbwfeBmBma6jMEnGDu99fPwsREZF0uYOTu38UIK4W+0Yq7zQdSnix9R3ASTHNE8CNxH4od9ecdSIi0lTh0Xpxip8fxK02WM0BXkeYyeEdccPMHnf3Ka1VWUREhrvS3nOqE6x2B84B/orKO0/7lFWeiIgMX2W+hJvMCjGbyou44+PpZHSfiIhIUy0Fp5pZIY6mslgfbL+q7M+oDDkXERFpqMhLuGcRgtEfUJkVArYPRj+nMmrvxqyTqYqIiECxltPn2f4xnQO/oBKMVigYiYhIK4o+1vsl2wejpusfiYiIZFUkOO3p7k+VXhMREZEo9/RFCkwiItJuZQ4lHwdMjF+ui+89iYiI5NbKxK+Y2cFmdrmZPQSsB1bFbb2ZPWRml5nZwa1XU0RE+knh4GRmFwH/A7yfMCO51WzTgL8A7jazT7VaURER6R+FHuuZ2eeBD1AZTn4fcDvw23hsL2AWcFD8+iNmtou7/1XLNRYRkWGvyEu4RwJnEd5vug843d1vTkl7FHA58CrgLDP7prvf3kJ9RUSkDxR5rPeXcf8IcFRaYAJw91sIc+ytjofOKFCeiIj0mSLB6WhCq+kid3+6WeKY5tOEx3tHFyhPRET6TJHgtHfcr8xxzZ0114qIiKQqEpw2x/1OOa5J0m5umEpERIRiwenhuD82xzV/FPerG6ZqwsymmNlSM3vMzDaZ2SozW2xme+TM5/fN7Jp4/Qtm9rCZXWtmee5JRETapEhwup7Qf/RBMzu8WWIzex3wQUI/1XUFykvymQ7cBbwHuAP4HPAQYbXd28xsIGM+C4CbgLlx/zngRsISIN83s/OL1lFERMph7p7vArMpwAOER3UbCYMd/tndH61Jty/wXuAjhBVxNwIzatPlKPc6YB5wtrtfUnX8YkLwu9zdG44GNLPRwJpY90Pc/f6qcwcBdwPbgD3cfVOjvGbOnOkrV+bpdhMRETO7y91nNk2XNzjFzN8FfKPm8GPAk4QW0l7AvknyeGy+u38zd2GhvP2ABwlTI013921V5yYAj8dy9mw0p5+Z7UV4Ufin7v7aOud/ChwMTGq2DIiCk4hIflmDU6Hpi9z9KuAtwKNUpit6GfA64ND47+T4b4Djigam6Ji4v746MMW6bABuAcYCRzTJ50lCy2mGme1ffcLMZgD7A/dofSoRkc4qPCu5u/8gtmhOAN4EvJqqWckJS7X/F3C1u7/YYj0PiPsHUs7/ivDIbwbwowZ1djM7E1gG3GVm3yW0+F4G/ClhRd8/b7GuIiLSopaWzIhB5ztxa6fd4v6ZlPPJ8d2bZeTu3zazx4B/Ad5ddeoJ4GuEQRYiItJBLS2Z0UWSCWibdqCZ2cnADwkj9Q4iPA48iNDi+iKQ+vjRzE43s5VmtnLNmjUtV1pEROrrleCUtIx2Szm/a026umK/0lLC47tT3P0+d9/o7vcBpxCGqp9kZrPrXe/uS9x9prvPnDx5ct57EBGRjHolOCVDvmeknE8GN6T1SSXmAaOBG+sMrNgG/CR+eViRSoqISDlS+5zMbGsbynN3L9LPdUPczzOzEXWGkh9FeI+q2XIcyTRKac2e5LimWRIR6aBGLafalW3L2nJz9wcJM1NMA86sOX0BMA64svodJzM70MwOrEl7U9y/3cxes93Nmh0CvJ3Qb/XjIvUUEZFyNGrFXDBktchmIXAr8AUzmwvcS1htdw7hcV7ttEP3xv1LAdHd7zCzrxGmQLozDiVfTQh6JwBjgMXu/os23oeIiDSRGpzcvauCk7s/aGYzgQsJk84eR5gZ4gvABe6+LmNW7yP0LZ1GmJB2ArAeuBn4SosvC4uISAka9Tkl7wBd7e7rh6g+Dbn7I4RWT5a0dR8hepiv6etxExGRLtTosd7XCf0vK4FfJgfN7Mfx+HvdvaUlMEREROopMnJuNiE4jSu3KiIiIkGj0XrJkhEThqIiIiIiiUbB6Tdxf/RQVERERCTR6LHeD4G/BBbFFW/vB7ZUnV9oZk/mLdDdL8x7jYiI9JfUxQbN7OXA/wADbD+hauZJVutx95FFrus2WmxQRCS/lhcbjMO2DwW+SliBdguVVW1hCGeIEBGR/tJwtF4MUKdXHzOzbYQAdbC7/7LuhSIiIi3olVnJRUSkjxR5zymZoeE3DVOJiIgUlDs4ufsV7aiIiIhIQo/1RESk6yg4iYhI11FwEhGRrqPgJCIiXUfBSUREuo6Ck4iIdB0FJxER6ToKTiIi0nUUnEREpOsoOImISNdJnb7IzJa2oTx39/e1IV8RERlGGs2tdxoFFxRMkawFpeAkIiINNQpOD9M4OI0FJld9vRlYRwhCewBj4nEHngKeL15NERHpJ6nByd2npZ0zs8OAbxOC0FeApcA97r41nh8JvJbQSvoL4DngJHe/q7Sai4jIsJV7yQwz2xe4FpgAzHP3FbVpYpD6H+B/zOxbwPeB75nZ69z98daqLCIiw12R0XrnEh7nLa4XmGq5+43AYmBP4MMFynuJmU0xs6Vm9piZbTKzVWa22Mz2KJDXwWZ2pZk9EvN60sxuNLN3t1JHERFpXZHg9FZCP9L3clyTpH1LgfIAMLPpwF2ElXjvAD4HPAScA9xmZgM58joNuBs4AbgJ+CfgO4T+suOK1lFERMpRZJn2KXG/Kcc1SdopDVM1dimh9XW2u1+SHDSzi4EPAouAM5plYmZHAF8Ffg4c6+6/rTk/uoU6iohICYq0nJ6L+1k5rjki7guN2DOz/YB5wCrgSzWnPxbrdIqZjcuQ3aeBkcDJtYEJwN23FKmjiIiUp0hwupPw+OtvzWzvZonNbB/gPMKjwDsLlAdwTNxf7+7bqk+4+wbgFsLQ9iNqL6ypyxTgjcBK4BdmNsfMPmRm55rZXDPTjBkiIl2gyIfxF+N+b+BOM/vzeo/CzGyUmf0ZcDuwTzz8hWLV5IC4fyDl/K/ifkaTfA6vSv/juH0G+CzwQ+AeM3tlwTqKiEhJcgcnd/8+YfSdAfsCy4GnzOwmM/tXM/uOmd0ErAWuAl4eL/2Cu/+gYD13i/tnUs4nx3dvks+ecf8O4CDgxJj3K4FvAAcThryPqXexmZ1uZivNbOWaNWuy1l1ERHIqMiACd/9rM3sY+AThcdoE4A01ySzuNwJ/7+4XF65lc0lZzaZbGlm1f7+7/2f8er2ZnUoIWDOBtwH/Unuxuy8BlgDMnDmzzKmdRESkSuE+FndfDLwC+AhwPfBbwhRGm4EngP8CPgq8ooTAlLSMdks5v2tNujRPx/0mwovEL3F3B66JX74+bwVFRKQ8hVpOCXdfQ+iv+Ww51Ul1f9yn9SntH/dpfVK1+WyoHVgRJcFrlxx1ExGRkvXK6LQb4n5e7Yg6M5sAHEV4fHh7k3x+SpiEdpKZ7VXn/KvjflXxqoqISKt6Iji5+4OER4fTgDNrTl8AjAOudPfkHSzM7EAzO7AmnxeBy+OXn64OdGZ2MGGZkBcJs0WIiEiHtPRYz8zmAO8FjiQMLd8ZeI27/7IqzdGEFsl6d1/WQnELgVuBL5jZXOBewovAcwiP886vSX9vUoWa458E5gLvBg42sxWEuQLfFut/rrv/Xwv1FBGRFhUKTma2C/A14KTkUNzXG8G2lfBulJvZ7UU/+N39QTObCVwIHEuYA+9xwrtTF7j7uoz5PB+D20eAPye0xF4gBL5/ikPlRUSkg4q2nK4C/oQQlO4EfkKYrXwH7n6Lmf0c+D3Ce0WfLlgm7v4IYeLXLGlrW0zV554HPh43ERHpMrn7nMzsj4Hj45cL3X2WuzdbCuPfCIHsD/KWJyIi/afIgIjT4v6b7n5ZxmuSFXBfVaA8ERHpM0WC0yxC39JVOa5JVr+dXKA8ERHpM0WC06S4fzTHNckLry2NDhQRkf7QynpOTZfLqDIt7tcWKE9ERPpMkeD0UNz/Xo5rkgEUvyhQnoiI9Jkiwek6wsi7s8ys6WM6MzsKeCehn0rvEImISFNFFxt8nrBO09fMbKe0hGZ2CvCfhL6mp4GvFKmkiIj0l9wDFNz9t2Z2JmGGiHcBbzKz6uUn/tLMxgN/CEwhtLK2Ae9z92dLqLOIiAxzRRcbvMLMAL5EWF32VCpTF30g7qsXG3y/u1+DiIhIBq0sNngFcADwT8CDhGBUvT1CeAR4oLvvsKqsiIhImlYXG3wU+DDwYTPbldCKGgk85e4aNi4iIoWU9lKsu68H1peVn4iI9K8iE78uNbN/NrN9clwzObkub3kiItJ/ik78ehqwR45rdq26TkREpKGeWKZdRET6y1AFp53jftMQlSciIj1sqILTUXH/xBCVJyIiPSzL3Hj/kHJqoZk92eTynYDphCXdHbglX/VERKQfZRlK/nEqsz8kDFiQoxwDXgA+k+MaERHpU1kf61XP/OBxq50Rot62CVgFLAeOdPf/LbHuIiIyTDVtObn7dgHMzLYRgtOr3f2X7aqYiIj0ryIzRDxMCE6bS66LiIgIUGzJjGltqIeIiMhL9BKuiIh0nSJz602K8+QtNbOXZUj/sqr5+HYrVs2X8poS83rMzDaZ2SozW2xmeaZSqs3zaDPbamZuZp9opX4iIlKOIi2nEwlz5L0uLpnRUExzSLzmTwuUB4CZTQfuAt4D3AF8DngIOAe4zcwGCuQ5AbiCsOy8iIh0iSLB6XjCgIjv5LjmW4Sh5ScWKC9xKWG9qLPd/QR3/xt3P4YQpA4AFhXI8/PAbsCnWqiXiIiUrEhw2j/u78hxzcqaa3Mxs/2AeYR3pr5Uc/pjwHPAKWY2LkeexxNaYWcDjxWpl4iItEeR4JT0MzWbuqjamppr8zom7q93923VJ9x9A2FapLHAEVkyM7M9ga8AV7v7soJ1EhGRNikSnLbE/YQc1yRprUB5EB7bATyQcv5XcT8jY35LCPd+RsH6iIhIGxUJTskgiMNzXPP6uH+8QHkQ+oUAnkk5nxzfvVlGZvZeQr/ZQnfPNUu6mZ1uZivNbOWaNWuaXyAiIoUUCU4/IbSAPmBmOzVLbGY7A2cSBlH8pEB5WSQtstoJamvrMg1YDHzb3b+VtxB3X+LuM9195uTJk3NXUkREsikSnP457qcB347DseuK574FvCIeWlqgPKi0jNLek9q1Jl2apcBGYGHBeoiIyBAoMn3RSjP7OuG9pbcA95vZUuAmwmM7B/YFjiaMhtsrHvsXd7+1YD3vj/u0PqVkFGBan1TiUEKAW2NWt/vrfDM7H7jG3U/IXUsRESlFkYlfIQwkmEwITnsD58WtVhIBfgC8r2BZADfE/TwzG1E9Yi+2zo4itIhub5LPlYRRfbX2JwTTewgv+t7dQl1FRKRFhYKTu28G/tjMFgIfAaamJH0Y+LS7X1qwfkl5D5rZ9YR3nc4ELqk6fQEwDrjc3Z9LDprZgfHa+6ryObte/mZ2GiE4fc/d/66VuoqISOuKtpwAcPdLzezLwGsIj8ySUQJPEVogP3X3hoMUclgI3Ap8wczmAvcCs4A5hMd559ekvzfuiw5fFxGRDmkpOAHE4PO/cWub2HqaCVwIHAscR+jj+gJwgbuva2f5IiIydFoOTkPJ3R8hDLLIkjZzi8ndvw58vVitRESkbFrPSUREuk5qy8nM3p38292vrHe8iOq8RERE6mn0WO/rhPeTnDAEu/Z4EbV5iYiI7KBZn1Nav41GwImISNs06nN6Rdz2SzleZKvNS6Q/LV8O06bBiBFhv3x5p2tUvn64R2mb1JaTu6/Oc1xEMlq+HE4/HZ5/Pny9enX4GmD+/M7Vq0z9cI/SVhqtJ9KqvC2E88+vfGgnnn8+HB8u+uEepa166j0nka5TpIXw8MP5jveifrhHaSu1nERaUaSFMDVlKsq0472oH+5R2qrRe04/bkN57u5z25CvSGcUaSEsWrR9awtg7NhwfLjoh3uUtmr0WG824b2kRsPGa993SluRNtNKtSI9Z+rU8Civ3vE0yeO+888PQWzq1PChPZwGCvTDPUpbWdqk4Wa2gsbBZF8qi/w5sAp4ghCI9iSslGvx3P8BjwG4+5yWa90FZs6c6StXrux0NaTTavucILQQlizRB7FIHWZ2l7vPbJau0VDy2Q0yfzNwFbAeWAR8zd2fqkkziTBJ698SltL4K3f/fqbai/QKtRBE2iK15ZR6gdkMwlpNLwJHufsvm6Q/CLiFEAhnunuzpdR7glpOIiL5ZW05FRmtdy5h5dmLmgUmAHe/F/hHYDzwoQLlSb++aV/0vvvp+9VP9yr9xd1zbcBDwFZgVo5rZgHbgIfyltet22GHHeZDYtky97Fj3aGyjR0bjg9nRe+7n75f/XSvMmwAKz3DZ2yRltM+cZ9n8tck7d4FyutvvfKmfdl/wRe97yzX1atrL7ZAeuV3Q6SAIn1OjxNG453v7hdlvOY8wsCJJ9x9n2bpe8GQ9TmNGBH+Jq5lBtu2tb/8LNoxYs1S/vZpdt9p3y8Ix+vVdfTokO/mzdunHxiAz3++ewc39MLvhkiNdvY53URoCX3UzF6VoSKvAj5CGFJ+c4Hy+lva+zIjRnT+r/uktXHyycX+gk+uN4NRo8J+2jRYuDA9ODWbYSDtvFkor15rY8uWHQMTwNq14d4mTer897oezcIgw1mWZ3/VG3AEYaTeVuAZ4G+Aveuk2xv4KPA7Qn/TFuCIvOV169b2Pqdly9wHB0M/gtn2/Qrd0L9Qr7+j3lbvuuS+8m5m2fqc0r5facezbGPGuA8MhDwGB7ujX0d9TtKDyNjnVOiDGfhgDDhbq7ZHCEPMV8Z/J8e3xe2vi5TVrVtbg1PWD34IH5SdkCXAjBxZCUZm4cN9xIjiASK53wULQl7JsfHj3ceNay3fvFu3BIEFC8L3Ofl+L1jQ6RqJNNTW4BTy50+B31QFn7TtUeDEouV069bW4JSnZWHWvno00korpBu3UaPyX9OpPwwSWVtO1X8gdEurT/pW1uCUe0BENTMbDRwP/CFwMDCR0B+1DvgZ8EPganffUriQLtXWARFp/S31DAzAU081T1e2adPqzynXq0aPhp12gmefzX5NpwcepP0MBgdh1arw73oDQKD7B3vIsNXy9EVZxKDznbhJGZYvDx96LfzRMCQWLYL3vCcMJhgOtmyBffcNAWrt2mzXdHrgQZYZ0esNAIFwj1qZVrqY1nPqBtXv2Jx6ar7AtG5d26rV0Pz54YN8OHn44dCaGDt2x3Mjav6rdMPyD1lG6zVaukPvREkXKyU4mdkIM5tkZlPNbGQZeaaUM8XMlprZY2a2ycxWmdliM9sj4/XjzGy+mV1lZveZ2XNmtsHMVprZuWY2pl11T5U8dlm9OgSlrVvzXd/qX+9pL58uXx6GUJuFbfz48PWIEWE/aVK+R2C9IAlAp566/aPVnXeGXXapfD0wUP6s40VeAl60qH4gffbZyvXNfj+0Mq10qywdU/U2YCRh1vGbgBcII/NeBF5Vk+6twKcJL+22Ut50wpIcDlwNXAT8OH59HzCQIY9jY/q1hEeRFwFLgMfj8VuAnbPUp7QBEUWHVRcZMVbbMb5gwY4d6mbur3pV5wcodPOW5/ueZTBCs4ENjfJYtmz7kYu11y9bFobBtzKoQwMqpES0eSj5pBiUqoeKJ0PLa4PTq6vOvbZIeTGf62IAOavm+MXx+GUZ8jgEmA+MqTk+gTAM3oFzs9SntOBUdNTbwED+wFQvEHX6g76XtyTANwocacG/evh32jD4JL/a4DJmzPblpP2Bk1w/enT985qrUDqgbcGJ8Cjw5hhwXgT+H3BmWnCK19wWz30sb3nx+v1i4Pg1MKLm3ATgWeA5YFyR/GM+74pl/EeW9B1vOaX9xVv7l3QSxFppoWnLvlV/cJfxPR8/vv7xgYHKz7zRS8dpdUjeQSv6+1nGMHq1yPpSO4PTKTEQbQaOqzreKDidF8//V97y4vXvj4Hj8pTzSatqbpH8Yx4nxTy+myV9acFp2bJiH1r13m9K+yu50WMdbeVvyQd3u1umiUYBpFHgyqLV6xv93qtF1peyBqciAyLeGT/Ev+Lu12a85u64P7BAeQAHxH3aQoW/ivsZBfMHeG/c/6CFPPKbPz90sOc1ceKOHejnn19/aPfmzTCybeNUpFYyyGCohprXGxiRjCZsdf69ds3fpxnVe9NQzt6fJYJVb8BvCS2kN9Ucb9RyOjSefz5vefH6JYSA+P6U84vi+fMK5v+BeP3dwOgG6U4nTM+0curUqa3+AVGxYEG+v5jHjNmxhaT+o+7ZRo6sTNeU9Zq80zpVP9ZzT39E1moLpV0tnHa1yKR9SvpdoI2P9TbFIHRIzfFGwenwNgenT8bzf1Mg7xMJfWePA/tlva7Ux3p5HrsNDOT70NPW+pZ82OeZ8zDZsgadZGBFlrSjR7c2SjNvYGlH31A7+7KkPUr6mbUzOD0Zg9Bba443Ck7vjOcfzltevP4zMfjUHUkHfDGeX5Az3xMIfWePAQfkuba04JQ30KSNvNJW/lbvP1294fjNgsrAQGV0Xr0tmaw17S/TRiMCe5X6nHpPSa3ddganZAj539ccbxScvhvP/3ve8uL1pQ+IIAyA2EKYQX3/vHUqJTgVHQzR6sze2ppveSdQbRSgzLL/x+6nEWz9dK/DQQ+0nJKRd09SNXQ7LTgRZi9Pls+o+1guQ5nTY/D5NelDyZ8n41BywrDxF4HVeR7lVW8tB6cij4i0tbbl6ZerF5ga/aXfKO9GrSY9xpJe0QN9TrsCT8Vg80PiQoO1wQkYD/x9VR/Vampefs1Zbq6XcAkjAw+sk8+psT4PAYNF69NycNJ7R9271QsYaT+vZGBCkX5APcaSXlNCazdrcCq0ZIaZ/RHwH4QpjLYAtwKzY5D4LrAHcCSwE2EJjc3AMe5+a+7CKmVOj+XsCVwD3AvMAuYQhpi/wd3XVqV3AHe3qmNzCAF1BLCU8Eiv1u/cfXGz+rS8ZMaIEeEjSrrL2LH1581r9PNasAC++tV8M7QPDoah3poRXPpM1iUzCq/nZGZzgW8QlmOHEJi2SxL3TwLvcPefFCpo+zJfDlxImCNvgDDC7mrgAndfV5O2XnA6Dfhak2JWu/u0ZnVpOTgNt/WQetWYMTBhQpjdferU9IDR6Oc1cmS+CXs7vQ6USAdlDU6FZyV39x8R+oI+QGiNPEMISEbo/7kZ+BAwvYzAFMt8xN3f4+77uPsYdx9093NqA1NMa9WBKR77enK8wTatjLo2tWhRvkUFZXvjx7eex+AgLF0aFmvcti0s0JfWkmm0PMZQzyQv0gdaWjLD3Te6+6XuPs/dJwJjgF3cfYK7H+3uF7v7c+VUdZiZPx/OOKPTtehNZnDZZSG4mKXPftFoVgyzxsGoVqOZPPLMvtEN60CJ9IDcwcnM/iRur6k95+4vuvumcqrWBy69tJwWQL+ZOLH5Glhjx4Y0aa3TIq2XegsRNisHKucGB8tfB0pkmCrScrqaMOjh4JLr0p8uuyz0e5ShyBx9vSYJDvWWHh85MgSCJAhcemlondYGjiytl3pziM2fH/JNWmzNyoHwM/nGN0IQzdNSE+l3WYb0VW/A7whDsQ/Ne+1w2kp7CTcZolzGi7W9MDw9bQmIelvtu0NmYbaEvG+q5x3+WvR9Dr1UKtIU7RpKbmY/A14FzPGSBjr0opZH6yVt3nwRAAAWs0lEQVTLs9drARRlFh55rV3bPG0njBgBV14ZWhlFl3gfHAz7eiPnBgdD66RVaSPzyspfpI+1c7Tef8T9mwpcK4l6Swa0asSI7g1MEEbEnXJK8cAEYTmKRktElCFZ8iLrcREpXZHg9HlgLXCOmb225Pr0j3a845R3SHMn5Gyp72Dq1PS+n7L6c9q1hpGIZJY7OLn7E8BbCe813Wxmf2dmryi9ZsNdmYv/9ctCgtWto/nzwyO2Zu8nFdHullmvGMqF5URqjMp7gZk9FP+5EzAOuAC4wMyepTJYIo27+/TctRyO8rZy0mYhGDcOnuuDV8lGjhy6YdhJGeefHx7lNZo5Yriq7RNdvTp8Df31fZCOKTIgopV5V9zdh8Wf+S0PiBg1Kl+AmjsXbrtt+36qvNPmFGUWHscNDMAzz8CLL7aeZzJXXb3fv6S8RNp8d9I+GhQibZJ1QETulhNwRYFrpFbeoLJiRbgmCUiDg/BIvXlrS7LTTrB5846thuXL4ZxzWh94kTa33NixcOqpcO21/dtq6QYaFCIdljs4uft72lGRvjM4mG9QRBLMtm6t9H+cfHJ76pUWDJYvD4+61q0L6Y47Dr785fr5jB8fWloPPxyGtz/9dPPJTseNg513Di8mT50aXl5VUOqMqVPr/35qUIgMkZbm1pMWtNK5/vzzIUiMKPnHlzyySQtM1VMGrV6dHpggBJhkwEIysWozzz8fWmRJ/qefrk74TtGgEOmwwktm9LuW+5ygtVnJzcKHRZmDIRot5ZB3iY/q36vly4u38tTH0TlJS1mPV6VEpa7nZGY7Ae8D3gwMEhYZfAz4MbDEqxb56xcdD06Dg+FDo8w/LhoFgjyLIw4MhNZSopW1q7T2kciwUtoMEWY2A/gFcAlwHPB7hCXQjwE+AfxfXGFWhkryeKXR8/9kEtSBgbAlL6umTQ5r1viRTSt9DVk60cucPVxEel7D4BRbTNcA+1FZSLB22w34NzOb0t6qDkNFl8tI+pyOOy49zbZtlf6e6sX06i37YBbmu2v0yKZRWbXW1az92CzADA6G8tXHISJRs5bTycABhCXY7yDMpzcB2Bl4PSFwAewKnNumOg5Py5fDphaWvlq9Gq64IoxwqyctICRT/1S3oCZOhKOOalzetddmr1tt2WmBbe5cWLYs/Puyy2CXXbZv5endJpH+1WjKcsIkr9uAnwM7paT595hmVZZp0IfL1vKSGQMD+ZebqLcNDGRb3qF6OYeBAfcxY/ItCZG2TEW9bcGC7a9NW8oja91FZNgg45IZzVpOryW0mhZ7+gq3n4z7l5vZbi3Gyv6wfHl5s4evXRtaHImBgR1bHLXDwNeuDS/YVkseFabJ0/dT3cpavjx9MMTatTvOzN6sHiLSF5oFp0lxf0+DNNXn+mAp1hKU/eFbHeg2bqxfXpblORqNqKv33kuaZABEEhTz0iwEIn2vWXDaOe5TP9nc/YU66aWRdn741mt5ZC3PLP2l16SvKssM6Ekrq1FQHDs2feSgRuiJ9D3NENEJ7f7wrQ1GWctzb9yqmz+/+TtH1SPsGgXFJUvqjxzUCD0RQcGpM9r94VsbjIo8ksuad7XaEXZpaQcHQ5p2LxooIj0r68SvC83syTLSufuFGcscvubPb8+krYlXvnLHY7vsUnnEljxOqzcoo1kra9Gi7df5gfQlLdLSVgfnJEiJiFRrNJSPMER8a5lbliGEDeozBVhKmDppE7AKWAzskTOfifG6VTGfx2K+U7Lm0fJQ8jKGkWcZzr1sWf3h2gsW7DicfMyYbMO4q4elDw42viZPWhEZ9sg4lLzh3HotLixYj3vBxQbNbDpwK7An4eXf+wgvAs8B7geO8gxz/JnZQMxnBmFuwDsJ0zEdDzwJHOnuD6XnELQ8t14r8+plNTgYWkfPPrvjuYEBWL8etmypHBs5EnbfPczwoIk+RaQNylpssJvmzLuUEJjOdvdLkoNmdjHwQWARcEaGfD5JCEyfc/e/rsrnbODzsZxjS6z3joZqGYhGQ8PrPdLburVyXMtyi0gH9cSSGWa2H/Ag4THcdHffVnVuAvA4YZ6/Pd09dQ0JMxsHrCE8rtzH3TdUnRsRy5gWy2jYemqp5TR+fLlLXbSTlqwQkRKVNit5lzgm7q+vDkwAMcDcAowFjmiSz5HALsAt1YEp5rMNuD5+2d4WY68EJggtKLPhuY0eHZYCSTs/bVqllbtwIYwaFY6PGAETJoR9dZrly2HSpMr1kyaFY8uXh3TV6RsdM6uUVZ1/PfXyySPP9a2W1apOly9DK0vHVKc34DOEaZTOTTn/xXh+QZN8zozpLkk5/6F4/h+b1amlARHtHgyhrbxt7Fj3uXObp1mwwH306B3PjRq14/ExY3Y8Nnr0jgNUqvOvN5AkbbBL1kEnea5vtaxWdbp8KQ0ZB0Q0TdANG7AkBo33p5xfFM+f1ySfv43pPpFy/i/i+cub1UnBSdt228iR7c1/cHDH36O0CXXrpa0nz/WtltWqTpcvpckanHrlsV4zydA3b2c+Zna6ma00s5Vr1qxpsSgZVrZubW/+9V6OTnthOut0VXmub7WsVnW6fBlyvRKcnon7tFnPd61J15Z83H2Ju89095mTJ09uUpT0lSxzDrai3svRaS9MZ52uKs/1rZbVqk6XL0OuV4LT/XE/I+X8/nH/wBDl05p9921r9lKisWPDoojN0px+ehhgUWvUqB2Pjxmz47HRo8PxtPzrTXlVb1qqPHMT5rm+1bJa1enyZehlefbX6Q2YTnjU9mtgRM25CcCzhJnTxzXJZ3xM9ywwoebciJi/A/s1q1PLM0Tsu297+yi0Nd9GjWq8iGL1jBYLFlT6lczcx4/fcdaLZcu2X0RyYCAcqzdLRqNjUCmr3TNw9NJsH50uX0pBGTNEdBMzuw6YR/pLuJe7+xlVxw8EcPf7avK5HDgduNjdz606nryEe527N30Jt+UZIkRE+lBZM0R0k4WEaYe+YGZzgXuBWYR3kh4Aatd6uDfua+cJ+ltgNvDXZnYIcAdwEJXpi85sR+VFRCS7nmk5AZjZy4ELCdMLDRBmhrgauMDd19WkdQB332ESOzObCHwMOAHYB1gLfB/4B3f/Tca6rAEazA+U2STgqRLy6SX9ds+63+Gv3+65lfsddPemI8p6KjgNR2a2MksTdzjpt3vW/Q5//XbPQ3G/vTJaT0RE+oiCk4iIdB0Fp85b0ukKdEC/3bPud/jrt3tu+/2qz0lERLqOWk4iItJ1FJxERKTrKDiVzMymmNlSM3vMzDaZ2SozW2xme+TMZ2K8blXM57GY75R21b2IVu/XzMaZ2Xwzu8rM7jOz58xsQ5z9/VwzS5lwrjPK+vnW5Hm0mW01MzezT5RZ3zKUec9mdrCZXWlmj8S8njSzG83s3e2oexEl/h/+fTO7Jl7/gpk9bGbXmlnTGWiGipm93cwuMbObzGx9/B1cVjCvcv9vZJnjSFuuOQCfIMzPdzVwEfDj+PV9wEDGfAYIk9Q68KOYz9Xx6yfIMPdfr9wv4YVqJ7wI/Z2YxxLCC9ZOWOV4507fa5k/35o8JxDmdNwQ86m71thwuGfgNOBFYD1wFfBJ4FLgJ8A3O32vZd4vsCBe8yzwDeBTcf9cPH5+p+811vOeWJ8NhFl1HFjWyd+Tl/Ls9DdnOG3AdfGHcVbN8Yvj8csy5nN5TH9xzfGz4/EfdPpey7pf4BBgPjCm5vgE4K6YT90VkHvxfuvkuRRYR5OFMHv9noEjYmC6B9i7zvnRnb7Xsu4XGA38DtgIHFBz7iDgBcIE1Dt1wf3OIazGYIRp3YoGp/L/b3T6mzNcNmC/+EP4Nekzpz9H85nTx1HSzOm9cL9NynhXLOM/hsvPt+a642OeJxNaFV0VnMq8Z0LryIFXd/q+2n2/wF4xn/9NOf/TeD53a6LN918oOLXrs0B9TuU5Ju6vd/dt1SfcfQPh8dRYwl+QjRwJ7ALcEq+rzmcbcH38ck7LNW5NWffbyJa4f7GFPMpS6v2a2Z7AV4Cr3b3QM/4hUMo9x37SNwIrgV+Y2Rwz+1DsU5xrZt3yOVTWz/hJYA0ww8z2rz5hZjMILZV73H1tKbXuvLZ8FnTLL8VwcEDcpy1U+Ku4T1vosOx82m0o6vneuP9BC3mUpez7XUL4/3dGs4QdVNY9H16V/sdx+wzwWeCHwD1m9soW6lmWUu7XQ5PhTMLP9y4zu8LMPmVmVxIeVf8COKmE+naLtnwW9NKSGd0uWfo9ban45PjuQ5RPu7W1nmb2AcJgiXsI/TKdVtr9mtl7CY/0/szdnyihbu1S1j3vGffvIMxkfSJhoM9kwuoApwDfM7OD3X1z8eq2rLSfsbt/28weA/4FqB6J+ATwNeChopXsQm35LFDLaegkS3e0OiVHWfm0W+F6mtmJwGLgt8Db3H1Lk0u6Qab7NbNphHv7trt/q811aresP+ORVfv3u/t33X29uz8InEp43DcDeFt7qlmazL/TZnYyoVV4E2EQxNi4/xHwReCbbapjNyr0WaDgVJ7kr4PdUs7vWpOu3fm0W1vqaWYnEP7jPgnMdvdu+QuzrPtdShjFtbCMSrVZWff8dNxvAq6tPhEfgV0Tv3x93gqWrJT7jf1KSwmP705x9/vcfaOHVblPITzaO8nMZrde5a7Qls8CBafy3B/3ac9Vk47RtOeyZefTbqXX08xOAr5NePTxB+5+f5NLhlJZ93so4THXmvjCo8eFMb8Wz58fj13dWnVLUfbv9IbaDvMoCV675KhbO5R1v/MIw8lvrDNAYBth5CLAYUUq2YXa8pmlPqfy3BD388xsRPUvpZlNAI4i/MV8e5N8bo/pjjKzCdUj9uKopnk15XVKWfebXPMu4ErgUWBOF7WYEmXd75WERzy19geOJvSx3QXc3XKNW1fWPf+U0Nc0ycz2qtPP9uq4X9V6lVtS1v3uFPdpq70mxzvZv1amUj8LXtLpsfXDaSPni2jAgcCBdfJJXsL9p5rjPf0SboP7PRXYSugkHuz0fbX7flPyPo0ue8+p5J/xJ2L6K6h6FwY4OH5wbQFeORzul/B40gnvK76m5twh8X63Ab/X6futqdtsGrznRGgNHghMb/X7lmXTkhklMrPpwK2ExzbXEKYDmUV4J+kB4A1e9W5DfJyDu1tNPgMxnxmEYbd3EDpTjyf0xbzBQ2dyR5Vxv2Y2h9BxPILwnP6ROkX9zt0Xt+k2Mivr55uS92mER3uL3P3vSq98QSX+To8lDAY4gtAqXEFoQbyN8DjvXHe/uM2301SJ97sUeA+hdfRdYDUwDTgBGAMsdvcPtvl2mop9vCfEL/cG/ojwR+JN8dhT7v6hmHYa4UXb1e4+rSafXN+3TDodrYfbBryc8CHzOOEXczXweWBinbRO7BOuc25ivG51zOdxwof3lE7fY5n3S6XF0Ghb1en7LPvnWydt8n3oqpZTmfdMeJz5ccJca5sIHeQ/BN7c6Xss+34JI9ROIwThpwkvkq8jBOg/7/Q9VtXz41n/7xGCa+r/xzzftyybWk4iItJ1NFpPRES6joKTiIh0HQUnERHpOgpOIiLSdRScRESk6yg4iYhI11FwEhGRrqPgJNLnzGyMmX3YzFaa2YaqCWmvjucPqTp2QrP8RMqgiV9l2KmaZqVVr3D3VSXk07XMzIB/J0xbI9I1FJxE+tubqQSmfwMuJczf6MD6TlVKRMFJhqNHCbNdp7kO2Bd4jMYthkfLrFSX+sO4fxaY7+4vdLIyIgkFJxl2PCzr/vO082aWLPu+xd1T0/WJl8X9wwpM0k00IEKkvyUL421pmEpkiCk4iTRgZovjKLXfxa8nmtkFZnaPmf0unjstnss8qi1e33Q5djObamafNrO7zexpM9tkZo+Y2bfMbF6jaxvkuXvV8vDHx8OvrV42Pm6758x3JzM7y8xWmNkaM9tsZk+Y2XVm9h4zG5ly3c2xvLqrO5vZkVV12mhmO9dJM8bMno9pPpWn3tKd9FhPJCMzOxj4PpVHYe0u7wPAZ6m0bhJTgJOAk8xsOfA+d980FHVKY2b7A9cCr6w5tScwL25nmtlb3f23NWlWEJbyPtLMdq7zeHF21b93JixYuKImzSzCooXUOSc9SC0nkWxGE0azTSIsPf2HwEzgncD9ZRdmZmcDlxAC04PAB4FjgcOAEwmrjQLMB76YM/v1hAEjBxNWWoZwDwfXbJlG65nZROAGKoHp34A/jnV9O2GBPeLX15tZbbBdEfc7AUfWKWJ2k6+rj70I3JKl3tLlOr0SozZtQ70Bq8i4wi6wmMqqoJuB32+Q9pCqtCc0yfeemO7qOucOIKwU68BlwKiUPM6rKu+wgt+Lq+P19xS9L+DyqvP/kJJHdZq/rzm3S9X9XlhzbhSwIZ67Ju5vrJP/j+K52zr9+6WtnE0tJ5HsvuTuNw9BOR8CxhCC6Fnu/mJKuouotNreOwT12oGZ7QqcEr+8B/hEStK/ojI0f2F1/5O7bwTuiF/OrrnucGA8sBH4dDw2q7rfyczGUGlxrch9E9KVFJxEsls2ROX8Sdxf42FYfF0emgxJsKz3OGwo/D6Vvp6l7r6tXqIYgL4Rv9ybHd9DWxH3s8xsbNXx2XF/C3A78Azh8d8bqtKov2kYUnASycaBn7a7EDMbJAwiADinzgi67TbgfTHt3u2uW4pXV/379iZpq8+nBacxbB94Zifn3X0rlWA8u04a9TcNIwpOItk816gVU6I9myepa2zzJG0xserfTzZJWz1Kb2LNuVsJfXoAcwDMbBSVQLWiZj+76trk3yvd/dkmdZAeoaHkItlsHaJyqt8F+hRwVcbrhqp+jXiT85Z6oftGM/tv4I1Ugk3S3/Q8lT6p5F2oWWa2C+G+1d80DCk4iZSnur+l2VOJcSnHn6r69y7e/dMrrav6917Aww3S7pVyXWIFITgdbmbjqOpvqmq13k3od9qN0KrajPqbhiU91hMpz4aqf++Rlij+xT+YcvrXwO/iv3thGYvq4DmrSdrq8z+rc35F3I8mDLSYHb9+aeaIOODiJ/HLOai/adhScBIpz6NU+k0Ob5DuJMIH8A5ip/9/xi8PMrPj66XrIjcThnkDnBbXh9pBHPp9cvzyCeoHp1sJ7zsBvIkwawTs2CJKvp6N+puGLQUnkZK4+2bgtvjlO81sSm0aM3sl8JkmWX2K0BIA+KqZHdoosZnNNbPX561vGdx9PZUh4ocBH01J+jng5fHfX4pBuDavF4D/jl++n/Do8zngzpqkK+L+9ai/adhScBIp1yVxvytwU5zw9FAzO9rMPkb4oN1Mg74Zd/8lcHb8chJwm5l91cxOiHm9Pv57kZndB/wQmNG+W2rqPCov2H4qTkr7lljXE83seuCMeP5nVF6mrWdF3O8W9zfXeQn5HuBpQutT/U3DlAZEiJTI3f/VzP6Z8P7RNGBpTZLHCfPOfR2Y2iCfL5vZBuDLhBFr76PyTtMOydm+v2tIufs6M5tDZeLXk+JW6y7grd54ktoVwD/UfF1b3jYzu4nKy8rqbxqG1HISKd9fAO8m9MesJ/TJPEB4nHeIu9+TJRN3X0YYOHEe4UP6ScK6SxsJUxt9jzDV0XR3v6Z+LkPD3X9FeCH3bOBGYC2hrmuA6wmBdZbvOCN5rduo9DtBeouoenkN9TcNQxZmQBEREekeajmJiEjXUXASEZGuo+AkIiJdR8FJRES6joKTiIh0HQUnERHpOgpOIiLSdRScRESk6yg4iYhI11FwEhGRrqPgJCIiXUfBSUREus7/BwcJODLZ3iwrAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f93480d94a8>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "corr, x, y = correlation(flows, mlp_pred_flows, {})\n",
    "\n",
    "plt.close('all')\n",
    "plt.scatter(x, y, color='red')\n",
    "plt.xlabel(\"True flow\", fontsize=28)\n",
    "plt.ylabel(\"Predicted flow\", fontsize=28)\n",
    "plt.ylim(None,1.05)\n",
    "plt.xlim(None,1.05)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "\n",
    "plt.savefig(results_folder+'mlp_traffic_scatter.pdf', bbox_inches='tight', dpi=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#GCN\n",
    "\n",
    "best_res = None\n",
    "\n",
    "for lr in learning_rates:\n",
    "    for n in num_nodes:\n",
    "        gcn_params = {}\n",
    "        gcn_params['n_iter'] = 5000\n",
    "        gcn_params['lr'] = lr\n",
    "        gcn_params['early_stop'] = 10\n",
    "        gcn_params['n_hidden'] = n\n",
    "        gcn_params['nonneg'] = True\n",
    "        gcn = GCNFlowPred(G, features, gcn_params)\n",
    "\n",
    "        gcn_res_avg, gcn_res_std, gcn_pred_flows = ten_fold_cross_validation(train_test_folds, G, flows, gcn)\n",
    "        \n",
    "        if best_res is None or gcn_res_avg['RMSE'] < best_res[0]['RMSE']:\n",
    "            best_res = copy.deepcopy([gcn_res_avg, gcn_res_std, gcn_pred_flows])\n",
    "            \n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'gcn_traffic.pkl'\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(best_res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'gcn_traffic.pkl'\n",
    "pfile = open(results_file, 'rb')\n",
    "gcn_res_avg, gcn_res_std, gcn_pred_flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 5.707152288958258,\n",
       " 'MAE': 0.04095569377622045,\n",
       " 'MAPE': 0.9409347849270866,\n",
       " 'PEARSON': nan,\n",
       " 'RMSE': 0.0663434630464057,\n",
       " 'TRAIN-TIME': 2.4303510665893553,\n",
       " 'TEST-TIME': 0.09094491004943847}"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gcn_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f93380b3c50>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "corr, x, y = correlation(flows, gcn_pred_flows, {})\n",
    "\n",
    "plt.close('all')\n",
    "plt.scatter(x, y, color='red')\n",
    "plt.xlabel(\"True flow\", fontsize=28)\n",
    "plt.ylabel(\"Predicted flow\", fontsize=28)\n",
    "plt.ylim(None,1.05)\n",
    "plt.xlim(None,1.05)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "\n",
    "plt.savefig(results_folder+'gcn_traffic_scatter.pdf', bbox_inches='tight', dpi=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "bil_mlp_params = {}\n",
    "bil_mlp_params['inner_n_iter_train'] = 300\n",
    "bil_mlp_params['inner_n_iter_pred'] = 3000\n",
    "bil_mlp_params['outer_n_iter'] = 10\n",
    "bil_mlp_params['inner_lr'] = 1e-2\n",
    "bil_mlp_params['outer_lr'] = 1e-2\n",
    "bil_mlp_params['early_stop'] = 10\n",
    "bil_mlp_params['nonneg'] = True\n",
    "bil_mlp_params['n_hidden'] = 8\n",
    "bil_mlp_params['n_folds'] = 10\n",
    "bil_mlp_params['priors'] = zero_prior(G)\n",
    "bil_mlp_params['lambda'] = 0.1\n",
    "\n",
    "bil_mlp = BilMLP(G, features, bil_mlp_params)\n",
    "\n",
    "bil_mlp_res_avg, bil_mlp_res_std, bil_mlp_pred_flows = ten_fold_cross_validation(train_test_folds, G, flows, bil_mlp)\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'bil_mlp_traffic.pkl'\n",
    "\n",
    "res = [bil_mlp_res_avg, bil_mlp_res_std, bil_mlp_pred_flows]\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Saving just the neural network part of the model\n",
    "models_folder = \"../models/\"\n",
    "model_file = models_folder+\"nn_bil_mlp_traffic.pt\"\n",
    "torch.save(bil_mlp.lf.net, model_file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'bil_mlp_traffic.pkl'\n",
    "pfile = open(results_file, 'rb')\n",
    "bil_mlp_res_avg, bil_mlp_pred_std, bil_mlp_pred_flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.81000064436862,\n",
       " 'MAE': 0.03765527861922939,\n",
       " 'MAPE': 1.0511460617048463,\n",
       " 'PEARSON': 0.7878979467154307,\n",
       " 'RMSE': 0.06894988947157465,\n",
       " 'TRAIN-TIME': 1860.1802561759948,\n",
       " 'TEST-TIME': 0.08285408020019532}"
      ]
     },
     "execution_count": 35,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bil_mlp_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f9331bd9d68>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "corr, x, y = correlation(flows, bil_mlp_pred_flows, {})\n",
    "\n",
    "plt.close('all')\n",
    "plt.scatter(x, y, color='red')\n",
    "plt.xlabel(\"True flow\", fontsize=28)\n",
    "plt.ylabel(\"Predicted flow\", fontsize=28)\n",
    "plt.ylim(None,1.05)\n",
    "plt.xlim(None,1.05)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "\n",
    "\n",
    "plt.savefig(results_folder+'bil_mlp_traffic_scatter.pdf', bbox_inches='tight', dpi=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "bil_gcn_params = {}\n",
    "bil_gcn_params['inner_n_iter_train'] = 300\n",
    "bil_gcn_params['inner_n_iter_pred'] = 3000\n",
    "bil_gcn_params['outer_n_iter'] = 10\n",
    "bil_gcn_params['inner_lr'] = 1e-2\n",
    "bil_gcn_params['outer_lr'] = 1e-2\n",
    "bil_gcn_params['early_stop'] = 10\n",
    "bil_gcn_params['nonneg'] = True\n",
    "bil_gcn_params['n_hidden'] = 8\n",
    "bil_gcn_params['n_folds'] = 10\n",
    "bil_gcn_params['priors'] = zero_prior(G)\n",
    "bil_gcn_params['lambda'] = 0.1\n",
    "\n",
    "bil_gcn = BilGCN(G, features, bil_gcn_params)\n",
    "\n",
    "bil_gcn_res_avg, bil_gcn_res_std, bil_gcn_pred_flows = ten_fold_cross_validation(train_test_folds, G, flows, bil_gcn)\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'bil_gcn_traffic.pkl'\n",
    "\n",
    "res = [bil_gcn_res_avg, bil_gcn_res_std, bil_gcn_pred_flows]\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'bil_gcn_traffic.pkl'\n",
    "pfile = open(results_file, 'rb')\n",
    "bil_gcn_res_avg, bil_gcn_pred_std, bil_gcn_pred_flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.835228424078617,\n",
       " 'MAE': 0.034274532430493956,\n",
       " 'MAPE': 0.8601326983441465,\n",
       " 'PEARSON': 0.8268230269638746,\n",
       " 'RMSE': 0.062386220656423144,\n",
       " 'TRAIN-TIME': 1870.1263268709183,\n",
       " 'TEST-TIME': 0.08910362720489502}"
      ]
     },
     "execution_count": 37,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bil_gcn_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f9332256f60>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "corr, x, y = correlation(flows, bil_gcn_pred_flows, {})\n",
    "\n",
    "plt.close('all')\n",
    "plt.scatter(x, y, color='red')\n",
    "plt.xlabel(\"True flow\", fontsize=28)\n",
    "plt.ylabel(\"Predicted flow\", fontsize=28)\n",
    "plt.ylim(None,1.05)\n",
    "plt.xlim(None,1.05)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "\n",
    "\n",
    "plt.savefig(results_folder+'bil_gcn_traffic_scatter.pdf', bbox_inches='tight', dpi=50)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "bil_gcn_prior_params = {}\n",
    "bil_gcn_prior_params['inner_n_iter_train'] = 300\n",
    "bil_gcn_prior_params['inner_n_iter_pred'] = 3000\n",
    "bil_gcn_prior_params['outer_n_iter'] = 10\n",
    "bil_gcn_prior_params['inner_lr'] = 1e-2\n",
    "bil_gcn_prior_params['outer_lr'] = 1e-2\n",
    "bil_gcn_prior_params['early_stop'] = 10\n",
    "bil_gcn_prior_params['nonneg'] = True\n",
    "bil_gcn_prior_params['n_hidden'] = 8\n",
    "bil_gcn_prior_params['n_folds'] = 10\n",
    "bil_gcn_prior_params['priors'] = gcn_pred_flows\n",
    "bil_gcn_prior_params['lambda'] = 0.1\n",
    "\n",
    "bil_gcn_prior = BilGCN(G, features, bil_gcn_prior_params)\n",
    "\n",
    "bil_gcn_prior_res_avg, bil_gcn_prior_res_std, bil_gcn_prior_pred_flows = ten_fold_cross_validation(train_test_folds, G, flows, bil_gcn_prior)\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'bil_gcn_prior_traffic.pkl'\n",
    "\n",
    "res = [bil_gcn_prior_res_avg, bil_gcn_prior_res_std, bil_gcn_prior_pred_flows]\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'bil_gcn_prior_traffic.pkl'\n",
    "pfile = open(results_file, 'rb')\n",
    "bil_gcn_prior_res_avg, bil_gcn_prior_res_std, bil_gcn_prior_pred_flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 3.2939914844162685,\n",
       " 'MAE': 0.03543616443486591,\n",
       " 'MAPE': 0.9102316281812817,\n",
       " 'PEARSON': 0.8240890364007643,\n",
       " 'RMSE': 0.06257622894495152,\n",
       " 'TRAIN-TIME': 1886.1021346330642,\n",
       " 'TEST-TIME': 0.09517905712127686}"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bil_gcn_prior_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f9331c14d68>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "corr, x, y = correlation(flows, bil_gcn_prior_pred_flows, {})\n",
    "\n",
    "plt.close('all')\n",
    "plt.scatter(x, y, color='red')\n",
    "plt.xlabel(\"True flow\", fontsize=28)\n",
    "plt.ylabel(\"Predicted flow\", fontsize=28)\n",
    "plt.ylim(None,1.05)\n",
    "plt.xlim(None,1.05)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "\n",
    "plt.savefig(results_folder+'bil_gcn_prior_traffic_scatter.pdf', bbox_inches='tight', dpi=150)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
