{
 "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 matplotlib.pyplot as plt\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",
    "import os\n",
    "import copy\n",
    "\n",
    "os.environ[\"CUDA_VISIBLE_DEVICES\"]=\"1\"\n",
    "CUDA_LAUNCH_BLOCKING=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Reading power data\n",
    "data_folder = \"../data/\"\n",
    "G = read_net(data_folder+\"power_net.csv\")\n",
    "\n",
    "pfile = open(data_folder+\"features_power.pkl\", 'rb')\n",
    "features = pickle.load(pfile)\n",
    "pfile.close()\n",
    "\n",
    "pfile = open(data_folder+\"flows_power.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_power.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_power.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": [
    "#Hyperparameters\n",
    "learning_rates = [1, 1e-1, 1e-2, 1e-3]\n",
    "num_nodes = [4, 8, 16]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Min-Div\n",
    "\n",
    "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+'min_div_power.pkl'\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(best_res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'min_div_power.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": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.45543516852653,\n",
       " 'MAE': 0.0148257152804069,\n",
       " 'MAPE': 1419.2155885245324,\n",
       " 'PEARSON': 0.925992353202808,\n",
       " 'RMSE': 0.034042029081282954,\n",
       " 'TRAIN-TIME': 364.27952659130096,\n",
       " 'TEST-TIME': 0.01086740493774414}"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "min_div_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAbgAAAElCAYAAACWMvcuAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDIuMS4xLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvAOZPmwAAIABJREFUeJzt3Xm4XWV99//3JyEMCZOcBFExiQwBrFSrURAsBlBEagVRrHpAAS1CEBCxDg8+VXyM+KhFQEVN+0SBHOuvTmArVaoQRZBqUqlDGSyYQEUhgMiQMCXf3x/3vTk7O3tce+2z99nn87quda2z13Cve+Uk+5t7VkRgZmY2bKb1OwNmZma94ABnZmZDyQHOzMyGkgOcmZkNJQc4MzMbSg5wZmY2lBzgzMxsKDnAmZnZUHKAMzOzobRFvzMwlc2ePTvmz5/f72yYmU0qq1atuici5rS6zgGuj+bPn8/KlSv7nQ0zs0lF0pp2rpsyVZSSXifp05KukfSApJC0vGBau0paJulOSY9KWi3pfElPKTvfZmZWzFQqwX0AeC7wEPA/wN5FEpG0O3AdsDNwOXAT8CLgDOBwSQdGxL2l5NjMzAqbMiU44ExgAbA9cEoX6VxECm6nR8RREfG+iDgE+BSwF7Ck65yamVnXpkyAi4irI+LX0cX6QJJ2Aw4DVgOfrTn9QeBh4DhJswpn1MzMSjFlAlxJDsn7KyNiY/WJiHgQuBaYCew/0RkzM7NNOcB1Zq+8v6XB+V/n/YIJyIuZ2eQzNgbz58O0aWk/NtazR02lTiZl2CHv/9jgfOX4jo0SkHQScBLA3Llzy8uZmdmgGxuDk06CdevS5zVr0meA0dHSH+cSXLmU9w3b+SJiaUQsjIiFc+a0HKdoZjY8zj57PLhVrFuXjveAA1xnKiW0HRqc377mOjMzq7j99s6Od8kBrjM3532jNrY9875RG52Z2dTVqFmmR801HQc4SS+UNFUD49V5f1jtn4Gk7YADgfXA9ROdMTOzgbdkCcycuemxmTPT8R4oEqj+HfiDpG9L+pthDHiSZkjaO89a8qSIuBW4EpgPnFpz2znALOCSiHh4QjJqZjaZjI7C0qUwbx5Iab90aU86mACo03HPkirjv6pvfAj4EbAib6tqx4n1m6SjgKPyx12AVwC3AdfkY/dExLvztfOB3wBrImJ+TTq1U3XdCOwHHEyqmjyg3am6Fi5cGJ5s2cysM5JWRcTCVtcVGSbwamBR3p5HKgVuBxyeN4CHJA1awHse8JaaY7vlDWAN8O5WiUTErZIWAh8mve8RwO+AC4FzIuK+0nJsZmaFdVyC2+RmaXvgIDYPeFC/hHd1RHyy8AOHjEtwZmada7cE11WAq/PQZgEPICJiemkPnOQc4MzMOtfLKsqGIuIB4F8kfRt4PnAkcBppfJia3WtmZlam0gKcpOeRSm0HA3/O+GDoSmB7FPhxWc8zMzNrpnCAk/SnpGC2iFQtWZl/sRLQHiMNKVhBGj/244h4tOjzzMzMOtFxgJP0deClwFMqh/L+MeCnpGC2ArguIh4pIY9mZmYdK1KCew2ph6RI48FWkILadRGxvrysmZmZFdfNDCRBmntxQd7ml5EhMzOzMhQpwX2CVEX5fGAO8DrgtQCS1jI+uPvqiLi5fhJmZma91XGAi4j3AkiaReotuShvzydNX/V64Jh8zV3AD8jtchHhWfbNzGxCFO5FmScU/k7eagPewcCfkeZ8fH3ekPS7iNi1uyybmZm1Vto4uDoBb0fgDOCdjI+Je1pZzzMzM2umzIHeIlVTLmJ8sPe2+XSl16WZmdmE6CrA1cxechBpSq4nT+d9AL9gfDiBmZlZzxUZ6H0aKaC9lPHZS2DTgPZLxntT/sBLyJiZ2UQrUoK7gE2rHAP4FeMBbYUDmpmZ9VvRKsr/YtOA1tYK1mZmZhOlyEwmO0fEvhFxWkR8fTIFN0m7Slom6U5Jj0paLel8SU9pffcm6bxE0uX5/kck3S7pCkmHt77bzMwmQscBLiLu6UVGek3S7sAq4ATgJ8CngNtIQxl+LGmkzXROAa4BDs37T5EGs78U+FdJZ5efezMz61SZwwRmATvlj/flcXGD5CLSTCunR8SnKwclnQecCSwBTm6WgKQZwLnAI8ALqqcik/RR4GfA2ZI+6aWBzMz6q5vJlpG0r6QvSLoNeABYnbcHJN0m6fOS9u0+m92RtBtwGClvn605/UHgYeC4HKSb2Yk0aP2W2nk2I+JG4BZgG8bH/5mZWZ8UDnCSPgb8B/A20koCqtnmA38N/EzSud1mtEuH5P2VEbGx+kREPAhcC8wE9m+Rzt3AWmCBpD2rT0haQFpd4YbJ1C5pZjasClVRSroAeAfjQwVuAq4Hfp+PPRXYD9gnf36PpG0i4p1d57iYvfK+0WTPvyaV8BYA32+USESEpFOB5cAqSd8E7gSeQVon71fAG8rKtJmZFVdkoPeLgdNI499uAk6KiB81uPZA4AvAs4HTJH0lIq7vIr9FVebC/GOD85XjOzY4/6SI+KqkO4F/BN5cdeou4IukjitmZtZnRaoo3573dwAHNgpuABFxLWlOyjX5UNNOHH1UPWi9+YXSscD3SD0o9yFVbe5DKvl9BvhKi/tPkrRS0sq1a9d2lWkzM2usSIA7iBQIPhYRf2h1cb7m46QgclCB55WhUkLbocH57Wuuqyu3sy0jVUUeFxE3RcT6iLgJOI40DOEYSYsapRERSyNiYUQsnDNnTifvYGZmHSgS4HbJ+5Ud3PPTmnsnWqXH44IG5ysdRlotyHoYMIM0v2ZtZ5WNwA/zxxcUyaSZmZWnSIB7LO+36uCeyrWPNb2qdyqrGBwmaZN3lrQdcCCwntRRppnKezQqelWO9+s9zcwsKxLgbs/7TqalekXer2l6VY9ExK3AlaShC6fWnD4HmAVcUj04XdLekvauufaavH+dpD+tPpGXDnodqfr2qvJyb2ZmRRQZJnAl8BzgTEnfioifNrtY0p+RZgoJ4LsFnleWxcB1wIWSDgVuJA1lOJhUNVk7xdaNef/kQq0R8RNJXyRN9/XTPExgDSlwHgVsCZwfEb/q4XuYmVkbipTgzidNVbUNcLWkv5X0jNqLJD1d0gdI8zTOyvdc0E1mu5FLcQuBL5EC21nA7sCFwIs7GJz9VlKA+zGpZHoW8HLgR8AbI+LMcnNuZmZFKKJlz/jNb5LeBFxac/hO0kwfQRro/fTK5fnYaEQ07UI/1SxcuDBWruykr46ZmUlaFRELW11XaCaTiPiypPuApcCu+fAz8lbrf4C/joh+Vk+amdkUU3g1gYj4Tp7E+ChSFd1zqFpNAPgl8G/AZRHxRLcZNTMz60RXy+XkwPW1vJmZmQ2MrpbLMTMzG1QOcGZmNpQc4MzMbCg1bIOTtKEHz4uI6Krdz8zMrB3Ngo2anDMzMxtozQLcOROWCzMzs5I1DHAR4QBnZmaTVrM2uDfnHy+LiAcmKD9mZmalaFZF+SXSHJIrgf+qHJR0VT5+YkT0ZfkbMzOzVor0aFxECnCzys2KmZlZeZqNg3s077ebiIyYmZmVqVmA+5+8P2giMmJmZlamZlWU3wPeDiyR9ELgZuDxqvOLJd3d6QMj4sOd3mNmZtaphgueSnom8B/ACKnN7clTed/5SqlAREwvct8w8oKnZmada3fB04ZVlBFxB/B84B+A1aTSW2V1bvLPRba+kbSrpGWS7pT0qKTVks6X9JQCae0r6RJJd+S07pb0g6rhFWZm1kdNe1HmIHdS9TFJG0lBbt+I+K+6Nw4gSbsD1wE7A5cDNwEvAs4ADpd0YETc22Zax5MC/zrgX0j/AdiRtOjrEcAlJWffzMw6NJUmPr6IFNxOj4hPVw5KOg84E1gCnNwqEUn7k4LbL4HDI+L3NednlJlpMzMrpshyOScAJzLey3LgSdoNOIxU0vpszekPAg8Dx0lqZ2zfx4HpwLG1wQ0gIh7f/BYzM5toHQe4iLg4b5Np+q5D8v7KiNhYfSIiHgSuBWYC+zdLRNKuwJ+TZnf5laSDJb1b0lmSDpXk9fXMihobg/nzYdo0mD07bdOmpWNjY/3OnU1CU6WKcq+8v6XB+V+TSngLgO83SeeFVddfRZrVpdovJB0dEf9dMJ9mU9PYGJx0Eqxblz7fW9UcvmZNOgcwOjrxebNJa6qUOHbI+z82OF85vmOLdHbO+9cD+wBH57T3AC4F9gW+LWnLRglIOknSSkkr165d207ezYbf2WePB7d61q1L15h1YKoEuFbaHds3vWr/toj4ZkQ8EBG3Am8hVV0uAF7bKIGIWBoRCyNi4Zw5c7rNt9lwuP32cq4xqzJVAlylhLZDg/Pb11zXyB/y/lHgiuoTkUbMX54/vqjTDJoNneo2tXrtaNXnp7XxVTR3bg8yacNsqrTB3Zz3Cxqc3zPvG7XR1abzYG1nlawSALfpIG9mw6e2Ta22Ha32/IYNzdObOROWLOldfm0oTZUS3NV5f1htT0dJ2wEHAuuB61uk83PgHmC2pKfWOf+cvF9dPKtmQ6Bem9q6dXDGGY3PA0yfDhKMjKRNgnnzYOlSdzCxjk2JAJfbyK4E5gOn1pw+h7S23SUR8XDloKS9Je1dk84TwBfyx49XB0tJ+wLHA08AXyv5FcwmlzUN1kK+995UemvUnrZxY9ruuSdtGzfC6tUOblbIlAhw2WLgbuBCSZdJOjevTn4mqWqytovWjXmr9VFSSe/NwEpJ50m6FPh3YGvgvR4mYFNSpU1NLaacPfvsxu1pbmezEk2ZAJdLcQuBLwH7AWcBuwMXAi9udx7KiFgHHEoq+c0klQhfTZrn8oiIOK/0zJsNsrGxNCj72GMbl9yq3X57ak+bOXPT425ns5JNlU4mwJOTR5/Q5rUN/xuag9yH8mY2ddV2FmnH3LnjVY5nn50C3ty5Kbi5KtJK1DDASVrWg+dFRLy1B+maWT+0GqBdq7qUNjrqgGY91awEdzwFFzVtoLKWnAOc2bDoZPD1yAhccIGDmk2YZm1wt7fY7mHThUwfB+4ideR4nE0XOL0HWJPvM7PJpNmA7XY6hUyfDsuXp16RDm42gZqt6D0/Ip5VbwNeR1pi5gngc6RJiGdFxNMj4mmkbvcL87kN+drX5XvNbDKo7TwSMT5guxLk6nUWqTZzJlx8sQOb9UXHvSglPZ00TdUuwGERcWpErIqIJ6ciiIgNEfEfEXEq8PJ87bclPa2sjJtZD1U6j9xbp3Nx9cTHo6NpEPa8eR6gbQOnyDCBs4A5wPkRsaLVxRHxA+B80kz8f1PgeWbWS/WqIFt1HqluexsdTYOxPUDbBkyRAPcqUmeRb3dwT+XavyjwPDPrlUpJrboK8oQTWo9n84BsmwSKBLhd8/7RDu6pXLtr06vMbGLVK6k9/njzezwg2yaJIgGuMl/jfh3cs3/edzBgxsx6rtM11kZG3K5mk0aRAPdTUvf//yVpl1YX544l7ydVa/60wPPMrFc6qWp0V3+bZIoEuM/k/S7ATyW9QdKM2oskbSHpr0gTE1d6T15YLJtm1hOtuvlXzJvnwGaTTsdzUUbEv0o6H3gn8HRgDPiCpJ+TBnkH8FTgT4FtGR/sfWFEfKeUXJtZOWrnhNxpJ3jwQXjssfFr3OZmk1Sh1QQi4l3Au0iLhArYDjgAOAp4Tf55u3xuPfDuiDizjAybWclqu/kvWzY+rs1j2WwSK7xcTkScDzwLeA9pMdHfA4/l7S7g34D3As/yEjJmE6jZ1FrtqA54Hstmk1hX68FFxNqI+GREHB4Rz4iIbfL29Ih4RUR8IiLuLiuzZlNOp8Gq3ri26qm1zKaQKbPgqdmkUyRY1RvXVj21ltkUMqUCnKRdJS2TdKekRyWtlnS+pKd0keZBkjZICkkfKTO/NsUVCVaNxrV1Ot7NbAh0FeAkHSzpUkn/LekhSU9IenbNNQdJWizp2O6y2h1JuwOrSCt6/wT4FHAbcAbwY0kjBdLcDrgYD2C3XugkWFWqMqPBEo6eWsumoEIBTtI2kr4CfA94E7AbMJPxIQHVNpDGzl0saY+iGS3BRaQJn0+PiKMi4n0RcQgp0O0FFOkHfQGwA3Buedk0yxoFpdrj1VWZ9bibv01RRUtwXwaOIQW0lcDfNbowIq4Ffpk/Hl3weV2RtBtwGLAa+GzN6Q+Sph87TtKsDtI8klQaPB24s5ycmlU54ojUVb9avWDVbOZ/T61lU1iR9eD+Ejgyf1wcEftFRKtlcL5BCoYv7fR5JTkk76+MiI3VJyLiQeBaUgl0/9ob65G0M/D3wGURsbzMjJoBsHgxfP7zm1Y5SvCWt2werJq1r61f35v8WXm6HdZhDRUpwR2f91+JiM+3ec+qvH9206t6Z6+8v6XB+V/n/YI201tK+rM7uZtM2RRX74utsor25z63eXtaBFxxxebpNGtfcw/KweZhHT1VJMDtR5qO68sd3PO7vJ9T4Hll2CHv/9jgfOX4jq0SknQiqQS7OCLu6jQjkk6StFLSyrVr13Z6uw2Lel9sxx6btnqraFfUK621mk/SPSgHl4d19FSRADc773/bwT2VasGO576cIJWGjgZd0PJF0nzS6uRfjYh/KvKgiFgaEQsjYuGcOf2K99Z3Z5zRfMXsRuqV1kZHUzvb9Ont32ODwcM6eqqb9eBaLpVTZX7eN/mvaU9VSmg7NDi/fc11jSwjza25uIxM2RQ1Nta8lNaI1Lg35OgoXHzx5iU596AcbO32lLVCigS42/L+Tzq4p9Ip5VcFnleGm/O+URvbnnnfqI2u4vmkoQZr88DukBTAF/P5s/Oxy7rLrg21otVPJ5/cvDdkpSTniZInj3rVy/5PSWmKVBl+F3gBcJqkCyLiiWYXSzoQeCOp+u9fCzyvDFfn/WGSplX3pMyDtQ8klcyub5HOJaTelrX2BA4CbiB1qPlZ1zm24TI2lqoli5TcIHX3v+ii1teNjjqgTSa1yxXNnZuCm3+HpSgS4D5DWgvumcAXJb0tIh6td6Gk40iLnG4B3EfqWj/hIuJWSVeSxsKdCny66vQ5wCzgCxFRqX5F0t753puq0jm9XvqSjicFuG9HxAdKfwGb3MbG4M1vTrPzFyHBBReUmycbHP5PSc8UWfD095JOJVXLvQl4uaTqvstvl7Qt8DJgV1IHjo3AWyPioRLyXNRi4DrgQkmHAjeSeoQeTKqarK03ujHv683OYtba2Fj6n3mjGUbaIbWumjSzuooueHoxaRaP9aQ2qbcw3gPxHaSxcs9kfMHT4yLi8m4z242IuBVYCHyJFNjOAnYnlTBfHBH96gBjk1mjsWxbbZW6/BcNbpU2tEsvba9q0sw2o2g0OWs7N0vPIFVXHgnUzjN5B3A58ImIuKPwQ4bYwoULY+XKlf3OhlVUSlzttoVUxrJVd/efNq14VSSkDgbuGGLWlKRVEbGw1XXdLnj624j4m4hYQBokvQDYB5gTEfMi4nQHN5sUylp7rZvgVqTXo6d5MmuoqxKcdccluAEyf3796sSRvIpSpffjyAi8/vVpyqxu2taqFS211StBugRoU0C7JbiOA5ykZaT2tg9ExO9aXZ/vmQP8XyAi4q0dPXCIOcANkGnTGq+l1mvLlxcLSI2C8rx5sHp1t7kyG1i9rKI8Pm+drIK9fdV9ZoOnXzNHnHJK8dKWp3kya6qrNjizodFqwuKyTZuWgls3PSQ9zZNZUxMV4LbO+7oDws36rt40V9tuW176UqoCrWwbNnTf/X8YpnlyJxnroYkKcAfmfcfLy5hNmNHR1Ha1cSPssQc8VOK8BL0oVU32uSe9Fpr1WMtOJpL+tubQh0idTD4H3N0i/a1Ig6lfnX/+x4g4tlBOh5A7mQyQxYtTcNiwofu0KqW1CvdsrM+dZKygdjuZtDNV14fYfJ00Aad0kh/gEeATHdxj1ltlTKUFaejAAw/A44+nzxHjQW7ePE+e24g7yViPtTsXZfV8jFHnWCOPkFbzvg74ZET8Zwd5M+udemPIipBSW13tKgGV4OaSSGNz59b/z4U7yVhJWrbBRcS06o3xwPac2nN1tpkRsXtEHOfgZgNhbAxmz07zRHYb3CBVPzYqAbok0twwdJKxgVakk8nteXus5LyY9dbYWApsRddkq+fhhxufc0mkucneScYGXscBLiLmR8SzIuK/e5Ehs55YvDgFt4kyDCWRiejCX91zdfVqBzcrlQd623Cp/VJevBi23ho+97neP3uYSiLuwm9DoMhclLOBj+eP/zsiftvi+mcA/4fUOeVdEfHHIhkdRh4mULKxMTjxRHisy9pzKa3Ddtxxnc1POUwTl7sLvw2wXs5FeTRpTsk/axXcIC2pAzwv3/OaAs8zG7d4MWyxRQpCW2yRPle8/e3dB7ettkrBbXS0sza0yqoDw8Jd+G0IFAlwR5JKY1/r4J5/IvW+PLrA80ojaVdJyyTdKelRSaslnS+prYmjJc2SNCrpy5JukvSwpAclrZR0lqQte/0OU9rixamqsTIYe8OG9Hnx4rQ16/DRjuXL4ZFHxqsW252fcsYMuOCC7p7dK0Xb0TzPpQ2DiOhoA24BNgAv7+CelwEbgRs7fV5ZG2lGlbtIwfky4GPAVfnzTcBIG2kcnq+/lxTgPwYsJY31C+BaYOt28/SCF7wgrAPTp1fP5ljeJkWcckr9Zy5fHjFvXuN7p09P1/RLJX9S2lfnZfnyiJkzN83vzJnt5bebe816DFgZ7Xzvt3PRJjfAwznAPbeDe56bA9wDnT6vrA34bg5Cp9UcPy8f/3wbaTwPGAW2rDm+HbAqp3NWu3lygKtR+2V9yimbfu5FcKsNCs3yNmhf+K3y1OjPbN689tNvFDzN+qiXAe7+HOBe0sE9L8kB7sFOn1fGBuyWg89vgGk157YDHsqBe1YXz3hTfsY/t3vPlA9w1V+gIyMRW27ZmyBWb+v0y3r58pTHyv0jI9194ZcRPBoFsOnTU7rNSqxmk1i7Aa5IG1ylY8kLO7jnRXnf1grgPXBI3l8ZERurT0TEg6SqxZnA/l08I09EyBNdpDF11HZDv/fe7juItKt6kdF22qgqea0eIL5+ffHnl9UFv1GHjw0bmvfodDuaTRFFAtwPSR1G3iFpq1YXS9oaOJVUuvlhgeeVYa+8v6XB+V/n/YIunnFi3n+nizR6YxDX3Dr77HKmymqH8uxy06dvusjo2BiccMKmgebYYzftmdkor+vWpeNFlJVekUA1DAPQzdrVTjGvegMWkqobNwDfArZrcu12+ZrK9Qd0+rwyNlJHkADe1uD8knz+/QXTf0e+/2fAjBbXngSsBFbOnTu3w4J5Af1uO6pXFXfKKRNXFdmsvam6yrFeFWarDiZFq/oaVR92ml69322zvLodzYYEvWqDS2mzrCpo3Ql8BHgF8KfAvvnnJfnchrwtL/KsMrY2AtxH8/n3FUj7aFK15O+A3Tq5d0La4LrtaNCNTr6Ae7G1CuTN7h0ZaZ33on+GZf5Oqv8D0aiX6UT8rs0mULsBruhUXScD3yZVVe4CvB+4Ipdgbsg/vy+fE6kH41sLPqsMldlTdmhwfvua69oi6SjgK6SFXxdFxG3FstdD/RywO5HVkLVGRrqbLuvee5vnvZuqvjJn0a+ey/Hiiz07v1mVQgEuIh6LiL8kVc3dTgpi9bbbgXdExBER8Wg5WS7k5rxv1Ma2Z943aqPbjKRjgK+Sxta9NCJubnFLf/RzwG63C4l2YmRkfB7I5cvhnntaB7eis4/Um2uy0s4ppbY+KW2zZ2/e5tmrWfQ9O7/Zptop5jXbSIHsucAJwHvydmI+pm7TL2MjDfIOmg8TWEebwwRIQwKeANbQYbVk9TYhVZT9aoNbvrx5V/VetLXVe6dWA6G32GLztGbMaNw+V6+6r1VV7IwZbvsyKxG9bIObjBsdDvQG9gb2rpPOW0htircB87rJ04SNg+vHgN1eDczupM2tneDeaHxbo3trB5+36ojSThCeKB64bUPCAW7zwFQ7Vde5jE/VdTM1U3Xl41Fz7OAc3AL4f8CH6mzvbDdPQz3QeyJLb41KWO105mhVwqukUenAUftenXai6dfsJ/3uTVubFwda64IDXL2XhWcCXyT1eHwsVzFeAOxU59p6Ae74yvEm2+p28zOUAa6TEk0vtuqu9q2647dbwmsVxDqdI7MfvRr72Zu22iAFWpu02g1wDdeDk/Tmqna6S+odL6I6ralu0q0HNzaWekbefnvqpLJkSerAUDk+kZ1KGqler6zVmmbtrHnW6JpaM2e232NUSr0eJ9K0aSmc9DsvXmfOStDuenDNSjuVcW5PNDheZHuinag7VbbSS3CnnDJempg+PX0uqzqo0f+8Dz10YqojKx01qt+xVfVfvTxX8tqqlFlJp513q22Lmzat9fUTbVBKcGUNcrcpjW6rKHMg2whsaHC8yLahnUxNla3UANdodpDaXoJFq4P6Xe1YbzmbTtvPOtkqf06t3rvZn+cgVccNQl6WL/dgdCtFGQFuXmVrdLzI1k6mpspWaoAr0g7U7pfb8uWdB4iyt06+AMuaQaXyZ9SsFNjqz3CQOlT0My/Nfidug7MOdR3gvE2yAFfkC7zyxVKvtFNZj63ZfI0TudVWYS1fHrHVVptes9VW5XZyqe6MMihBarJqtrSP/zytQ+0GuIadTKz3Su1kssUWaZmUTo2MpKVf+jWlVrsqnRDGxuDtb4eHH65/nZS+OjtNu1HHhyVL6nessc4MSicXGwrtdjIpOhelDZqTTqp/fIstmt/Xas7FiXbooZvPpyilADR7Nrz5zY2DG6Qv0enT23/eyEjjuSGPOKKcdduaGcSljHqhn1PG2ZTlADcsLrooBYdqhx4KX/pSKolMBtOnw/e/v3nArfzP/9572/vf/oYNmwesLbdMQaTW61/feA7HK64odx24WmUtfDoZlDnBtFmbmo2Du6oHz4uIOLT1ZVNDqVWUlS/L6i/kmTPHJ9utd35YVVctrlmTAueGDTBr1ualv+o/o1q9rlabamPCGo2jNOtQmePgmnb7r9laHm+nYXCqbKV2Mml3Wqp+dxaZiM4olU4L7fambNRDs9djx9oZE+YOLmaboc1OJs0aaH4INGutfzrjy8wEsJo016OAnYH5+ecAfk0ps+THAAAbCklEQVRa/NR6YfHixrNt1K77VinNDKuTTx4vFbS7Hl2jtfGWLKlfKi6rWm3u3Pq/t0q7VG2pu1KFCS75mLWjnShYuwGvBP4A3A/8DTC7zjWz87k/APcBryzyrGHeSinBNRrgXd0Ne5C6+3e7bbllxKxZjc9Xl67anWGlWYmslyWoVoOvB2X2EbMBQ6/GwZEWDX0wB65nt3H9PjnAPQAs6PR5w7yVEuCKzNIxWbfqANMseHW6jE1liZx+aBZAPa2VWV3tBrgivSjPAmYBH4uI/2qjhHgj8H+BbYF3F3ieNTPM1Y2QOoYsX56+2levHq+aa9a9fM0aOO442GOPzXvuzZiR0qx2773Fey92281/dDS918aNm74fuGu9WZeKBLiXAwGs6OCeyrUvK/A8a6aTMV/9VjuMoZUIeOih+u1NS5ak3ozN7r3qKnjLWzbt/v/FL6bxdLWKdP/vdTd/d60360qRAPe0vG/y7bKZyrW7FHieNbNoUb9z0J5p0+CEE9J4tGq1nytGRpqXjEZHU1BpJiKNZastITXqVNLoeCP1OrGUOU6u0fg8dzAxa0uRAHd/3i/q4J6D8/6PBZ5njYyNwTXX9DsX7dm4MVUbPvbYpscbVbHef3/rklE7A9jrBa2yqv7KCpTNNKvCNLOmigS4a0glsvdKenari/M17yFVa/6owPOskZNP3jxgDLJ6Ja5GAa72eL2S0RFHtH5mvaBVVtWf28jMBlqRAHceadD29sCPJb1P0mZVj5J2kfRe4Dpgh3zP33WT2W5J2lXSMkl3SnpU0mpJ50t6Sofp7JTvW53TuTOnu2uv8r6ZsbHUPjWVrFmzaXXlFVc0v75R0Cqr6s9tZGaDrZ2ulrUbcCabz1hyB7AKWJl/rp3F5F1FnlXWBuxOGogewGXAx4Cr8uebgJE20xkBbs73fT+nc1n+fBewW7t56mqYwLCMayuyVcaKtTNUoNc804jZhKPXy+VIeg3wadKMJs38DjgtIr5R6EElkfRd4DDg9Ij4dNXx80gB+wsRcXIb6XwBOAn4VES8q+r46cAFwHcj4vB28tTVXJTNehAOg2nTms/3WGl/m0pzOZoZ0P5clF2tBydpBnAkqfv/vsBOpPa5+4BfAN8DLouIxws/pASSdgNuJU0ntntEbKw6tx0pCAvYOSIarsUiaRawllQifVpEPFh1blp+xvz8jNta5csBromREdh228ZTkElw6aXNJ5g2s6E0IevBRcTjEfG1iDg5Ig6MiH0iYu+IOCAi3h4RX+13cMsOyfsrq4MbQA5S1wIzgf1bpPNiYBvg2urgltPZCFyZPx5ce6NVqbR91Vu+puK++1IprFFPyblz3Y3ezJqaKuvB7ZX3tzQ4/+u8XzBB6Qy/RsGrUn24cSNccknjkmilJ2KrjhzuRm9mDZQS4CRNkzRb0lxJgzi1xg5532gcXuX4jr1OR9JJklZKWrl27doWj5ukZs6Et7+9dQ/D0dE01KE2yNUGMJfSzKyAwgFO0nRJJ0i6BlhH6kF4G+OlnMp1r5L0cUklTe/QE5Vv2OINkm2mExFLI2JhRCycM2dOl4/rs0pgGhlJW3UAuuii9gLTRReltrRm17mUZmYFNFsPriFJs4FvAgfQesqu1cC3gJD0LxHxn0We2aVKyWqHBue3r7mu1+lMHlIqZV10UecrMo+OtheM2r3OzKwDHZfgcm/By4ADSSWVrwKnNbo+In4J/Hv+eFSBPJbh5rxv1DZWWbi1Udta2ekMlsps/RHp5+rS1KWXpuAGLkmZ2aRSpIpylFRyewJ4dUT8VUR8tsU93yKV9F5S4HlluDrvD8sB+kl5mMCBwHrg+hbpXJ+vOzDfV53ONNI4u+rnTT7tBrFmy8R0u4SMmVkJigS4N5JKbn8fES3mSnrSz/J+7wLP61pE3Erqwj8fOLXm9Dmk9e0uqR4DJ2lvSZvkNyIeAi7N13+oJp135PS/284YuIFS5jIxvV5CxsysTR0P9Jb0e2AOcHhE/FvV8Y2kwLdv1CyEKun5pCm8HomImq51E0PS7qR5MXcGLgduBPYjjVm7BTggIu6tuj4AIkI16YzkdBaQpvr6CWnV8iOBu3M6t7aTp64Ges+enRbqLEsnfw/mz288gwh4dhEz66leDvSuTEzcSR/3vg8dyEFnIfAlUmA7izQ/5YXAi6uDW4t07iUN+L4Q2COnsx/wReAF7Qa3rl1wQXlpdbpoarNlYiZiCRkzszYUCXCVHoKdzJy/R97fU+B5pYmIOyLihIh4WkRsGRHzIuKMiLivzrWqLb1Vnbsv3zcvp/O0iDgxIv6n92+RldnBo9GSNY00WybGS8iY2YAoEuAqPQn/rIN7Xp/3NxR4njXSacmrkXYWDq3WbHYRLyFjZgOiSIC7gtQj8rQ8+XBTedWBV5Pa575V4HnWSDslLwlOOQVmzKh/fsaMzoNPs9lFPPOImQ2IIp1MtifNWPIUUnf4YyPi97WdTCRtS1qG5gOkAeX/A+wZEZNoCere6qqTCTTu7FFRO0j7jDM27ZgyMpLa8hx8zGwS6Vknk4h4gDQWbgOpB+JqSVdVXfJhSd8n9Sj8EDADeBx4o4NbyY44ovG56uAGKYjdc8+my4Lec4+Dm5kNrUJzUUbEd4FXkuaf3BJYxPj8i6/Jn7cmVWXeDRwWEdd1mVerdUWTYYgRzc+bmQ25wpMtR8T3Sd3s30Fa2PSPpIAm0uTLPwLeTVr884fdZ9U206rrvbvmm9kUVmiy5YqIWA9clDckbQFMj4hHS8ibtbLTTs0He7trvplNYR0HOEmvzj+ujoifV5+LiCdIc1Rav7lrvplNcUWqKC8jLZWzb8l5sU7dt9n49HHumm9mU1yRAPdA3t9YZkasgEZVkPPmtRfcPOu/mQ2xIgHujrzftsyMWAHdzBriWf/NbMgVCXD/nPcvLzMjVkA3s4acfTasW7fpsXXrOl86x8xsQBWZyeSpwC9I49z+PCL+sxcZmwq6nsmkG9Om1V8iR0qLnZqZDahezmRyF/Aq0ri3H0n6gKRnFcij9ZNn/TezIVdkmEBlteqtSCtbnwOcI+kh4H7SFF6NRETs3nEurXxLlqQ2t+pqSg8tMLMhUmSg9/yaz5U107bLWzOd1Yda71Ta6c4+O814MnduCm4eWmBmQ6JIgLu49FxMAEkHkFY22J/UfvjfwDLg0xHR1oqfkp4BHA0cAewDPA14CPgP4HMR8Y0eZL13KsvbmJkNoY4DXESc0IuM9JKkI4GvA48A/x9wH/CXwKeAA4Fj2kzqNOC9wG9ISwX9HphHCnovk/SpiHhXubk3M7MiupqLcjLI69f9PaltcFFErMzH/zdwFfA6SW+IiK+0kdxPcho/qHnGPsD1wJmSxiJiVakvYWZmHSu8msAk8jpgDvCVSnADiIhHSFWWAKe0k1BEfKM2uOXjN5JKhpCWCjIzsz5rqwQnaSvgraQ14OYB04E7SSWgpRHRZEr7vjsk779T59wPSUv7HCBpqy5XQXg87z3ZtJnZAGgZ4CQtAK4Aase67U0KHu+RdHREXN2D/JVhr7y/pfZERDwh6TfAnwC7UXB+zVwN+lpSL9ErC+bTzMxK1LSKMpfcLid9+avBtgPwDUm79jarhe2Q939scL5yfMciiUsS8A/AU0k9KZsGSUknSVopaeXatWuLPNLMzNrQqg3uWFIJKEgdLF5OGuu2NfAiUvAD2B44q0d5RNJqSdHBtryT5PO+6Bi9vyP1wrwGaNmDMiKWRsTCiFg4Z86cgo80M7NWWlVRHpX3NwIvrWmjWgm8RtK3SFN3vQY4s/wsAnArqYt/u+6s+rlSQtuh3oWk4Fx9XdskfYL0zj8E/sIrmZuZDY5WAe65pJLN+U2+vD9KCnDPlLRDRHQcKFqJiEO7uP1mYCGwANik+76kLUhti08At21+a2OSPgW8kzQe7lURsa7FLWZmNoFaVVHOzvsbmlxTfW6ku+z0xFV5f3idcwcBM4Hr2i19KfksKbj9G6nk5uBmZjZgWgW4rfO+4Rd4Hk9We/0g+RpwD/AGSU8uryBpa+Aj+ePnqm+QNFPS3pLm1hwXsBRYDPwr8OqIWN/LzJuZWTFDP5NJRDwg6a9JgW6FpK+Qpup6NakDzdcYH6Rd8SJS1eMP2HTg9t8CbwPWk0qu70sxbxM3RMRlJb+GmZl1aOgDHEBEXCbppcDZpPFqlcmW3wVcGO2v+loZC7gN8P4G11wMOMAVNTbmFQ7MrBTtBrjFku4u47qI+HCbzyxVRFxLWgWgnWtXMD58oPr48cDxZebLqoyNbbpG3Zo16TM4yJlZx9Ss8CJpIyWv4RYR08tMbzJbuHBhrFy5svWFU8X8+Smo1Zo3D1avnujcmNmAkrQqIha2uq6dEtxmJZkueMFTa+z22zs7bmbWRKsAd/CE5MIMUptbvRLc3LmbHzMza6FpgKu3NIxZzyxZsmkbHMDMmem4mVmHpsJ6cDZZjI7C0qWpzU1K+6VL3cHEzAqZEsMEbBIZHXVAM7NSuARnZmZDyQHOzMyGkgOcmZkNJQc4MzMbSg5wZmY2lBzgzMxsKDnAmZnZUGo62bL1lqS1QJ25qTo2m7So61Qx1d4Xpt47+32HXzfvPC8i5rS6yAFuCEha2c7M2sNiqr0vTL139vsOv4l4Z1dRmpnZUHKAMzOzoeQANxyW9jsDE2yqvS9MvXf2+w6/nr+z2+DMzGwouQRnZmZDyQHOzMyGkgPcgJG0q6Rlku6U9Kik1ZLOl/SUDtPZKd+3OqdzZ053117lvahu31nSLEmjkr4s6SZJD0t6UNJKSWdJ2rLX79CJsn7HNWkeJGmDpJD0kTLz260y31fSvpIukXRHTutuST+Q9OZe5L2oEv8dv0TS5fn+RyTdLukKSYf3Ku+dkvQ6SZ+WdI2kB/LfweUF0yr330ZEeBuQDdgduAsI4DLgY8BV+fNNwEib6YwAN+f7vp/TuSx/vgvYrd/vWuY7A4fn6+8FvpbTWAr8Lh+/Fti63+9a5u+4Js3tgN8AD+Z0PtLv9+zF+wLHA08ADwBfBj4KXAT8EPhKv9+17HcGTsn3PARcCpyb9w/n42f3+11zPm/I+XkQuDH/vLyff1eeTLPffzjeNvkFfzf/Mk+rOX5ePv75NtP5Qr7+vJrjp+fj3+n3u5b5zsDzgFFgy5rj2wGrcjpn9ftdy/wd19y7DLgP+F8DGODK+ju9fw5uNwC71Dk/o9/vWuY7AzOA+4H1wF415/YBHgHWAVsNwPseDOwJCFjURYAr/99Gv/9wvD35S9wt/xJ/A0yrObdd/l/cw8CsFunMyn/xHwK2qzk3LacfDEAprqx3bvGMN+Vn/PMwvi9wZE7zWFIJZ2ACXJnvSyqlBfCcfr/XRLwz8NSczn82OP/zfL7jUk2P379QgOvVd4Hb4AbHIXl/ZURsrD4REQ+Sqtlmkv4n28yLgW2Aa/N91elsBK7MHw/uOsfdK+udm3k875/oIo2ylPq+knYG/h64LCIKtXn0WCnvm9uN/xxYCfxK0sGS3p3bVw+VNEjfY2X9ju8G1gILJO1ZfULSAlKJ6YaIuLeUXPdfT74LBukvxlS3V97f0uD8r/N+wQSlMxEmIq8n5v13ukijLGW/71LSv+GTu8lUD5X1vi+suv6qvH0C+CTwPeAGSXt0kc8ylfLOkYoup5J+v6skXSzpXEmXkKrdfwUcU0J+B0VPvgu2KJwdK9sOef/HBucrx3ecoHQmQk/zKukdpA4oN5DaqfqttPeVdCKpevKvIuKuEvLWC2W97855/3rS7PNHkzpPzQE+CBwHfFvSvhHxWPHslqK033FEfFXSncA/AtW9RO8CvgjcVjSTA6gn3wUuwU0eyvtup54pK52JUDivko4Gzgd+D7w2Ih5vccsgaOt9Jc0nvdtXI+KfepynXmr39zu9av+2iPhmRDwQEbcCbyFVXS4AXtubbJaq7b/Tko4llVCvIXUsmZn33wc+A3ylR3kcRIW+CxzgBkflfyg7NDi/fc11vU5nIvQkr5KOIv3jvxtYFBGD8j/dst53Gal33eIyMtVDZb3vH/L+UeCK6hO5Ku/y/PFFnWawB0p559zOtoxUFXlcRNwUEesj4iZSiXUVcIykRd1neSD05LvAAW5w3Jz3jeqYKw3Njeqoy05nIpSeV0nHAF8lVeO8NCJubnHLRCrrfZ9PqrZbmwfVhqQgVVsBnJ2PXdZddrtW9t/pB2s7IGSVALhNB3nrlbLe+TDSUIEf1Ol0sZHUqxTgBUUyOYB68r3lNrjBcXXeHyZpWvVfaknbAQeS/td+fYt0rs/XHShpu+qelLm32WE1z+unst65cs+bgEuA3wIHD1DJraKs972EVF1Va0/gIFKb4yrgZ13nuDtlve/PSW1vsyU9tU6b43PyfnX3We5aWe+8Vd43WrW6crzfbY5lKfW74En9HjfhbZPxHh0NdAT2Bvauk05loPff1Ryf9AO9m7zzW4ANpIb3ef1+r16/b4O0j2eAxsGV/Pv9SL7+YqrGSQH75i++x4E9+v2+Zb0zqbo1SGNa/7Tm3PPyO28E/qTf71uTt0U0GQdHKpXuDeze7Z9bO5uXyxkgknYHriNVP11OmvZmP9KYtVuAA6Jq3EuuliIiVJPOSE5nAalL9U9IjdNHktqlDojUQN93ZbyzpINJjfHTSO0Wd9R51P0RcX6PXqNtZf2OG6R9PKmacklEfKD0zBdQ4t/pmaTOFfuTSqYrSKWY15KqJs+KiPN6/DptKfGdlwEnkEpp3wTWAPOBo4AtgfMj4swev05Luc37qPxxF+AVpP9oXpOP3RMR787XzicN5l4TEfNr0unoz60t/Y743jb7X8wzSV9SvyP9xV4DXADsVOfaILez1zm3U75vTU7nd6Qv/137/Y5lvzPjJZdm2+p+v2fZv+M611b+HAamBFfm+5KqZT9EmpfwUVKHg+8Br+z3O/binUk9B48nBfM/kCYruI8U6N/Q73esyueH2v23RwrQDf89dvLn1s7mEpyZmQ0l96I0M7Oh5ABnZmZDyQHOzMyGkgOcmZkNJQc4MzMbSg5wZmY2lBzgzMxsKDnAmVlXJG0p6W8krZT0YNUE0Jfl88+rOnZUq/TMyuLJls1qVE0n1K1nRcTqEtIZWJIEfIs0PZPZQHGAM7NuvJLx4PYN4CLSfKcBPNCvTJmBA5xZPb8lzVLfyHeBpwN30rzk8tsyMzWgXpb3DwGjEfFIPzNjVs0BzqxGRDwO/LLReUmP5x8fj4iG100Rz8j72x3cbNC4k4mZdaOyMOfjTa8y6wMHOLMeknR+7j14f/68k6RzJN0g6f587vh8ru3ehvn+J3sqNrlurqSPS/qZpD9IelTSHZL+SdJhze5tkuaOlXyS1hgEeG5V3ivbjh2mu5Wk0yStkLRW0mOS7pL0XUknSJre4L4f5efVXaVe0our8rRe0tZ1rtlS0rp8zbmd5NsGl6sozSaIpH2Bf2W8Wq/Xz3sH8EnGS1kVuwLHAMdIGgPeGhGPTkSeGpG0J3AFsEfNqZ2Bw/J2qqRXRcTva65ZARwIvFjS1nWqShdV/bw1adHUFTXX7EdaOJU652yScgnObGLMIPUynA2cR+qcsRB4I3Bz2Q+TdDrwaVJwuxU4EzgceAFwNGnFZIBR4DMdJv8AqRPOvqQV4yG9w741W1u9KCXtBFzNeHD7BvCXOa+vIy3wSf58paTagL0i77cCXlznEYtafK4+9gRwbTv5tsHnEpzZxJgJzAMOiYgfVR1fVfaDJO0FfCJ//ALwjoh4ouqS/wC+Ken9wEeBt0n6fES0lZeI2EjuhCPpwXz4kS463JzLeKn2gxHx4Zq8fl3SF4CTSIHzPcD/qbrmWtLqz1sCB5OCJTl/WwAH5I/fAl6dr/lQTR4W5f3KiHio4HvYgHEJzmzifLYmuPXKu0lf9quB02qCW7WPMV56PHEC8rUZSdsDx+WPNwAfaXDpOxkfdrG4uj0uItYDP8kfF9Xc90JgW2A98PF8bL/qdjhJWzJe8lvR8UvYwHKAM5s4yyfoOa/O+8vzkIe6IiKASsCtV7U3EV7CeNvXslw63EwOYpfmj7uw+TjFFXm/n6SZVccX5f21wPXAH0lVmQdUXeP2tyHlAGc2MQL4ea8fImkeqWMGwBl1ejZusgFvzdfu0uu8NfCcqp+vb3Ft9flGAW5LNg1eiyrnI2ID4wF9UZ1r3P42ZBzgzCbGw81KUyXaufUldc1sfUlP7FT1890trq3uPblTzbnrSO1wkNrYatvfVtTsF1XdW/nZ7W9Dxp1MzCbGhgl6TvVYsXOBL7d530Tlr5locV4Nb4xYL+nfgT9nPGBV2t/WMd5GV+mAsp+kbUjv7fa3IeUAZzY4qtufWtWuzGpw/J6qn7eZBFOJ3Vf181OB25tc+9QG91WsIAW4F0qaRVX7W1Xp+WekdrgdSKW7x3D729ByFaXZ4Hiw6uenNLoolzzmNTj9G+D+/PNkWMKmOgDv1+La6vO/qHN+Rd7PIHVeWZQ/PzlsIHdi+WH+eDBufxtqDnBmg+O3jLcjvbDJdceQvsQ3kztS/Ev+uI+kI+tdN0B+ROrCD3B8Xl9uM7lb/7H5413UD3DXAZUZWV5Omt0ENi+ZVT4vwu1vQ80BzmxARMRjwI/zxzdK2rX2Gkl7MD6Iu5FzSSUSgH+Q9PxmF0s6VNKLOs1vGSLiAca7/78AeG+DSz8FPDP//NkcyGvTegT49/zxbaRq3IeBn9ZcuiLvX4Tb34aaA5zZYPl03m8PXJMnGX6+pIMkfZD0Zf0YTdqqIuK/gNPzx9nAjyX9g6Sjclovyj8vkXQT8D1gQe9eqaX3Mz6I+9w8EfRf5LweLelK4OR8/heMD9iuZ0Xe75D3P6oz0P0G4A+kUrDb34aYO5mYDZCI+Lqk/0canzYfWFZzye9I8zR+CZjbJJ3P5Wm0PkfqSfhWxse8bXY5m7b/TaiIuE/SwYxPtnxM3mqtAl7VYmLoFcDf1nyufd5GSdcwPiDe7W9DyiU4s8Hz18CbSe1TD5DaqG4hVU0+LyJuaCeRiFhO6ozyftIX/d2kddvWk6bx+jZpWq/dI+Ly+qlMjIj4NWnQ9+nAD4B7SXldC1xJCs771VlJoNaPGW+Hg8Yls+qlddz+NqSUZusxMzMbLi7BmZnZUHKAMzOzoeQAZ2ZmQ8kBzszMhpIDnJmZDSUHODMzG0oOcGZmNpQc4MzMbCg5wJmZ2VBygDMzs6HkAGdmZkPJAc7MzIbS/w+eJRU2BnOaQQAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f0b927e4f98>"
      ]
     },
     "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",
    "plt.savefig(results_folder+'min_div_power_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_power.pkl'\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(best_res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'mlp_power.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": 26,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.771801675627011,\n",
       " 'MAE': 0.043324454424963674,\n",
       " 'MAPE': 8334.460721207613,\n",
       " 'PEARSON': 0.6089470986917831,\n",
       " 'RMSE': 0.06922483713125999,\n",
       " 'TRAIN-TIME': 12.329836106300354,\n",
       " 'TEST-TIME': 0.013430428504943848}"
      ]
     },
     "execution_count": 26,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mlp_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f0b82ad84a8>"
      ]
     },
     "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_power_scatter.pdf', bbox_inches='tight', dpi=150)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "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'] = False\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_power.pkl'\n",
    "\n",
    "pfile = open(results_file, 'wb')\n",
    "pickle.dump(best_res, pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'gcn_power.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": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.798944624180741,\n",
       " 'MAE': 0.042785358062161584,\n",
       " 'MAPE': 5622.262921680323,\n",
       " 'PEARSON': 0.6431914930070677,\n",
       " 'RMSE': 0.06917950787881441,\n",
       " 'TRAIN-TIME': 0.7712153911590576,\n",
       " 'TEST-TIME': 0.012035322189331055}"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "gcn_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f0b927658d0>"
      ]
     },
     "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_power_scatter.pdf', bbox_inches='tight', dpi=150)"
   ]
  },
  {
   "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'] = False\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_power.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": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Saving just the neural network part of the model\n",
    "models_folder = \"../models/\"\n",
    "model_file = models_folder+\"nn_bil_mlp_power.pt\"\n",
    "torch.save(bil_mlp.lf.net, model_file)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'bil_mlp_power.pkl'\n",
    "pfile = open(results_file, 'rb')\n",
    "bil_mlp_res_avg, bil_mlp_res_std, bil_mlp_pred_flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.4298460808460494,\n",
       " 'MAE': 0.011031462993243327,\n",
       " 'MAPE': 758.5706355139173,\n",
       " 'PEARSON': 0.9549232740502489,\n",
       " 'RMSE': 0.027407829626460677,\n",
       " 'TRAIN-TIME': 323.6902468919754,\n",
       " 'TEST-TIME': 0.007717275619506836}"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bil_mlp_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f0b927c1f60>"
      ]
     },
     "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",
    "plt.savefig(results_folder+'bil_mlp_power_scatter.pdf', bbox_inches='tight', dpi=150)"
   ]
  },
  {
   "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'] = False\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_power.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": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Loading results\n",
    "\n",
    "results_folder = \"../results/\"\n",
    "results_file = results_folder+'bil_gcn_power.pkl'\n",
    "pfile = open(results_file, 'rb')\n",
    "bil_gcn_res_avg, bil_gcn_res_std, bil_gcn_pred_flows = pickle.load(pfile)\n",
    "pfile.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.4294652068590374,\n",
       " 'MAE': 0.010713203421484041,\n",
       " 'MAPE': 788.0548603545475,\n",
       " 'PEARSON': 0.954802692772535,\n",
       " 'RMSE': 0.02733061314132671,\n",
       " 'TRAIN-TIME': 346.74141478538513,\n",
       " 'TEST-TIME': 0.006672573089599609}"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bil_gcn_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f0b82683048>"
      ]
     },
     "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",
    "plt.savefig(results_folder+'bil_gcn_power_scatter.pdf', bbox_inches='tight', dpi=150)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f0b8266ed30>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "corr, x, y = correlation(flows, bil_mlp_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_mlp_prior_power_scatter.pdf', bbox_inches='tight', dpi=150)"
   ]
  },
  {
   "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'] = False\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_power.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_power.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": 41,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'DIV': 2.4294112314106955,\n",
       " 'MAE': 0.010787770957146685,\n",
       " 'MAPE': 691.5293013379412,\n",
       " 'PEARSON': 0.9545316034519724,\n",
       " 'RMSE': 0.027230013178072943,\n",
       " 'TRAIN-TIME': 334.14690909385683,\n",
       " 'TEST-TIME': 0.00688779354095459}"
      ]
     },
     "execution_count": 41,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bil_gcn_prior_res_avg"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<matplotlib.figure.Figure at 0x7f0b8263a5f8>"
      ]
     },
     "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_power_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
}
