{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "%matplotlib inline\n",
    "import matplotlib\n",
    "import matplotlib.pyplot as plt\n",
    "import torch\n",
    "import hypergrad as hg\n",
    "import numpy as np\n",
    "from sklearn.model_selection import train_test_split\n",
    "import torch.nn.functional as F"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# Helper functions to deal with cuda and double precision\n",
    "cuda = False\n",
    "double_precision = False\n",
    "\n",
    "default_tensor_str = 'torch.cuda' if cuda else 'torch'\n",
    "default_tensor_str += '.DoubleTensor' if double_precision else '.FloatTensor'\n",
    "torch.set_default_tensor_type(default_tensor_str)\n",
    "\n",
    "def frnp(x):\n",
    "    t = torch.from_numpy(x).cuda() if cuda else torch.from_numpy(x)\n",
    "    return t if double_precision else t.float()\n",
    "\n",
    "def tonp(x, cuda=cuda):\n",
    "    return x.detach().cpu().numpy() if cuda else x.detach().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# synthetic data generation\n",
    "seed = 1\n",
    "n, d = 1000, 2\n",
    "val_perc = 0.5\n",
    "np.random.seed(seed)\n",
    "\n",
    "w_oracle = np.random.randn(d)\n",
    "x = np.random.randn(n, d)\n",
    "y = x  @ w_oracle + 0.1 * np.random.randn(n)\n",
    "y = (y > 0.).astype(float) # binary classification output\n",
    "\n",
    "x_train, x_val, y_train, y_val = train_test_split(x, y, test_size=val_perc)\n",
    "x_train, x_val, y_train, y_val = frnp(x_train), frnp(x_val), frnp(y_train), frnp(y_val)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "# problem definition\n",
    "hparams = [torch.ones(d).requires_grad_(True)]\n",
    "inner_lr = 0.1\n",
    "\n",
    "val_losses = []\n",
    "def val_loss(params, hparams, x=x_val, y=y_val):\n",
    "    val_loss = F.binary_cross_entropy_with_logits(x @ params[0], y)\n",
    "    val_losses.append(tonp(val_loss))\n",
    "    return val_loss\n",
    "\n",
    "inner_losses = []\n",
    "def fp_map(params, hparams):\n",
    "    w = params[0]\n",
    "    loss = F.binary_cross_entropy_with_logits(x_train @ w, y_train) +\\\n",
    "           0.5 * (w.unsqueeze(0) @ torch.diag(hparams[0]) @ w.unsqueeze(1)).sum()\n",
    "    inner_losses.append(tonp(loss))\n",
    "    return [params[0] - inner_lr*torch.autograd.grad(loss, params, create_graph=True)[0]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "t=0: inner loss = 0.6931472420692444\n",
      "t=10: inner loss = 0.6285591125488281\n",
      "t=20: inner loss = 0.6243906021118164\n",
      "t=30: inner loss = 0.6241106390953064\n",
      "t=40: inner loss = 0.6240913271903992\n",
      "t=50: inner loss = 0.6240900754928589\n",
      "t=60: inner loss = 0.6240900754928589\n",
      "t=70: inner loss = 0.6240899562835693\n",
      "t=80: inner loss = 0.6240898966789246\n",
      "t=90: inner loss = 0.6240898370742798\n",
      "t=99: inner loss = 0.6240898370742798\n",
      "reverse_unroll - reverse (should be 0): 0.0\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"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYcAAAEWCAYAAACNJFuYAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAgAElEQVR4nOy9d3xdxZnw/31uVe+ybMmW5Q62Mc3YdEgINQETAsEpC2QhJJuQ8m7ypi75sSzskk3fF5JdCISSECAENg6Q0DvY2DQbGxe5qvcu3Xrm98c5V7q61pWubDXbz/fj45kz88ycOVf3znNmnmfmiDEGRVEURYnHNdkNUBRFUaYeqhwURVGU/VDloCiKouyHKgdFURRlP1Q5KIqiKPuhykFRFEXZD1UOhyEiskhE3hWRLhH5uoj8t4jcOA7XuUlEfj/W9cbVf4aIbBuv+g8VROReEbllstsxEcR/p0SkXES6RcQ92e06EvFMdgOUceE7wEvGmOMnuyEHgzHmVWBRKrIicjbwe2PMzHFtlDJhGGP2AVljUZeIvIT9/fjtWNR3JKAjh8OT2cDmyW7EkYqIHHYPXQdyT4fj53AkocrhMENEXgA+AtzuDMkXxk9LiMh3RWRt7IcrIv8kIptFJM05P1lE3hCRdhF533kij9U9R0RedqarngWKUmhPhYgYEbleRGpFpE5EvhWX7xeRXzp5tU7c7+SdLSLVcbJ7ROTbIrJRRDpE5GERSRORTOBvQKlzz90iUjpEWz7uTLd1ikiViNw0inbeJCKPOtfsEpF3ROTYhLZ9V0Q2Aj0i4hGRo0XkJeez3CwilziyPhF5T0S+5py7ReR1EfnRMB9lvog86Vx7nYjMc8reISI/S7jPv4rIN+Pa9X0R2SIibSLyu9jf2sn/hNOWdufvvmyEezohbsryT87nEftunS0i1U6ZeuB3IpIvIk+ISJNz/SdEZGbcNZJ+p+L+JrHvaq6I3O38bWpE5BZxppxE5BoReU1EfupcZ7eIXOjk3QqcwcBv4vZhPmclhjFGj8PsAF4Cros7vxe4xYm7gFeAm4AFQBtwvJNXBrQAFzly5zrnxU7+m8DPAT9wJtCFPVQfri0VgAH+CGQCxwBNwMec/JuBtcA0oBh4A/g3J+9soDqurj3AW0ApUAB8CHx5KNkkbTnbub4LWAY0AJem2M6bgDBwOeAFvg3sBrxxbXsPmAWkOzKVwA8AH/BR5/Na5MgvdT77o4EfOp+BO0m77wVagRXYU8F/AB5y8lYAtYDLOS8CeoGSuHZ94LSrAHg97rtwAtAIrATcwNWOvD/JPfmAvcA3nPu7DAjF1Xc2EAF+jP0dSQcKgU8BGUA28Cfgf+PuLel3Ku5v4nHO/xf4H+fvMw37u/AlJ+8a5+/zRede/sn5XGSo34QeKfQjk90APcbhjzqMcnDOK5zO5kPg+3Hp3wUeSKjraafTKHd++JlxeQ+SunI4Ki7tP4G7nfhO4KK4vPOBPU78bPZXDp9PqOe/h5JN8XP6JfCLFNt5E7A2Ls8F1AFnxLXtH+PyzwDqcTptJ+2PwE1x598CtmIriQXDtPNe4Ldx5xcBW+POPwTOdeI3AE8lfGZfTii704n/BkcRx+VvA85Kck9nAjWxDtdJe43ByiEEpA1zL8cBbU582O9U3N/EA5QAQSA9TvYzwItO/BqgMi4vwyk7fajfhB4jHzqtdARijNkDvIj947sjLms2cIUzxdAuIu3A6cAM7Kf1NmNMT5z83lFctiqhXGzapzShnvi8oaiPi/cyCoOliKwUkRedKY4O4MvsPzWWrJ2D8owxFlCdLN9Jr3Lk4usrizu/D/tv8JQxZscIzR/uvu8DPu/EPw88kFA22T3NBr6V8PeeNcI91Rintx0iH6DJGBOInYhIhoj8j4jsFZFO7FFrnjMdNJrv1Gzs0UpdXFv/B3sEEaP/MzLG9DrRMTFoH4mocjgCEZGLgFOA54GfxGVVYY8c8uKOTGPMbdhPyfnO/H6M8lFcdlZCuVonXov9wx8qbzSksr3wg8AaYJYxJhf4b0BSbOegPBFxATMT8uPbUAvMcuTi66uJO/818ARwvoicnkL7k/F7YJVjAzkae/olnmT3VAXcmvD3zjDG/DFOPv6e6oAyEYn/zOLrTpQHe3S0CFhpjMnBHn2A/bmP5jtVhT1yKIpra44xZkkS+UR0++lRosrhCENEioC7geuwp4sudpQF2J3MxSJyvmMkTXOMjDONMXuBDcC/OgbV04GLR3HpG52nyCXAF4CHnfQ/Av8iIsVO237ktGO0NACFIpI7jEw20GqMCYjICuCzo2gnwIkicpljIP0mdme1Nsm11gE9wHdExCu2Yf9i4CEAEfkH4ETs6ZCvA/eJyAE95RpjqoH12COGPxtj+hJEvioiM0WkANsGErunu4AvOyMqEZFMsY322Uku9SYQBW5wjNOrsG0ew5EN9AHtzvX/v7h2p/ydMsbUAc8APxORHBFxicg8ETlrhOvHaADmpiiroMrhSORO4C/GmKeMMS3AtcBvRaTQGFMFrMLuQJqwn9b+LwPfk89iGy9bsX/k94/iui9jG2ifB35qjHnGSb8Fu4PYCGwC3nHSRoUxZiu2otnlTDsMNTX1FeBmEenCVkKPjKKdAH8BrsS2EfwDcJkxJpykPSHgEuBCoBl7lHCVMWariJRj2zuuMsZ0G2MexP4MfjHa+47jPmwjeuKUEtgjpmeAXc5xi9PGDdgG3Nude6rEVlZD4tzTZdjfmXbsKawnsJVkMn6JbZhuxlakf0/IH8136ipso/gWp72PYk95psKvgMsdT6b/SrHMEU3Mkq8o44KIVDDg1ROZ3NYkZ6R2iu32Ot8Y8/nEvKmAiJyJPeKqiLdziMgebEPsc+N03XXYTgG/G4/6lclDRw6KcogjIl5s99LfJhjAx+NaZ4nIdGda6Wpsl+DE0YByGKDKQTloRORzMrD4LP7QVdrjjIgcjT3FMwN7Cme8WQS8D3RgG5svd+wBymGGTispiqIo+6EjB0VRFGU/UtoYS0QuwLb2u7HnNW9LyPdjexmciL3dwpXGmD0iUojtUXAScK8x5gZHPht4Na6KmdirIr8pItdg+97H/MFvNyPspFhUVGQqKipSuRVFURTF4e233242xhQPlTeicnBWMt6Bvc9ONbBeRNYYY7bEiV2LvdJxvoisxt5b5UogANyIvY/M0piwMaYLexl97BpvA4/F1fdwTJGkQkVFBRs2bEhVXFEURQFEJOkuB6lMK63A3rNkl+Pn/BC2L3w8q7D9rMEeKZwjImKM6THGvIatJJI1bgH2EvhXk8koiqIoE0sqyqGMwfunVDN4f5hBMo6PeAf2boyp8BnskUK8ZfxTYm/L/KiIJC7PB0DsrZU3iMiGpqamFC+lKIqipEIqyiFx7xnYf5+SVGSSsRp7ZWuMv2Iv5FkGPMfAiGRw5cbcaYxZboxZXlw85JSZoiiKcoCkohyqGby5VuJmY4NknH1ncrGXww+Ls1GYxxjzdizNGNNijIktx78L28itKIqiTCCpKIf1wAKx39jkw37SX5MgswZ7EzewX4bygkltAcVnGDxqQETi90q5BHuvekVRFGUCGdFbyRgTEZEbsF/64gbuMcZsFpGbgQ3GmDXYu3w+ICKV2COG1bHyzt4uOYBPRC4FzovzdPo09stH4vm62K9TjDh1XXMQ96coiqIcAIfFCunly5cbdWVVFEUZHSLytjFm+VB5KS2CUxTFxhiDFY1iRSJYVpRoJIKxLCeM2nlRC8uKYiwLYw3ErWjUfgWjZWEsg7Hsc8uynFczWmDZYb8cQH++8wpMYzAYjGUAY/9LyMMYBp774s/7X6PpyA66uf57HOq+SZaeUH4/mfirpPgsmvyh9cAfZqfuc/DBNWzeCSuYPn/hGLVlAFUOymFBJBQi2NtDsLeXUJ9zBAKEY2EwdgSJhIJEgkEnHiIaDhEJhYiEQ0TDEaKRMNFwmEgkjBVxziMRrEgUKzpldx1XDmVkKIfP1MjKL1DloBwZGGPo6+qkp62VnvY2etrb6O3soK+zg97ODgLdXQS6u+jr6iLY002wp4dIOJRS3S63B6/fj8fvx+Pz4fH68Pj8eHxefOkZuLM9uL1e3B4vbq8XjxN3eTy4PR5cbjcudyy0426PG3G57XyXC3G5cLndiMuFuNy4XC4nPZYmiEh/nh23ywH9dYCA2OeIIAjiEsAuj8RCELHrAfrz+uN2BCEma9fhJA/qmCTmlR5LSswTSUwm3pNdknVyEh9NsSNMUlfSayhjiioHZcKxolE6m5tob6ijo6GezuZGOpsa6WppoqulhZ62FqKR/Z/QXW4PGTk5pGfnkJadQ+HMWaRlZuHPzCItMwtfRgb+jEx86Rn409PxpWfgTUuzD799uD36lVeUVNBfijJuRMJhWmuqaK7aS0vVXlprq2mtqaa9oQ4rGu2Xc7ndZBUUkVNcTNmio8kqKLSP/AIy8vLJzM0jIzcPX3qGPjUqygShykEZE6xolKa9u6mr3E7Drkoadu2gpXpfvxJwuT3kzyilcGY58086mbzppeSVTCe3ZAZZBQW4XO5JvgNFUeJR5aAcENFIhLrKbezb9D41WzdTt2Mb4aC9v2Jadg4lc+Yx57gTKZ49h+LZc8ibXqpTOopyCKG/ViVlOpub2P3uena9s56qzZtsZSBC8ew5LDn7HEoXLaZ0wSJyikt0+kdRDnFUOSjD0t5Qz7Y3X2X7m6/RuGcnALnTSlh81jnMXnosM5ccQ3pW9iS3UlGUsUaVg7IfgZ5utr7+Cptfepb6nTsAmLFgEWd89hrmnbiSgrKZOjJQlMMcVQ5KP3WV23j370+wY+3rRMIhissrOPPz/8iik08np3jaZDdPUZQJRJXDEY4VjbLjrTd4+6m/ULd9K770DJZ85FyO+ci5TJszT0cIinKEosrhCMWKRtn6+susfewh2upqySuZwUeu+RJLzz4HX3rGZDdPUZRJRpXDEYYxhu1rX+f1h++nra6W4vIKLv7n77PgpFP6t29QFEVR5XAEUb9zBy/dfxc1W7dQOLOcS771A+YvP1mVgqIo+6HK4Qgg2NvDK7//HRuf/zvpObl87LqvcsxHz8Pl1lXJiqIMjSqHw5zK9Wt5/u5f09PezokfX8Upl38Wf0bmZDdLUZQpjiqHw5RQXy/P3f0bPnz1RYrKK1j17X8Zlz3fFUU5PFHlcBjSsKuSJ371YzoaGjj5U5/h5Ms+jdvjnexmKYpyCJGSJVJELhCRbSJSKSLfGyLfLyIPO/nrRKTCSS8UkRdFpFtEbk8o85JT53vOMW24upTUeO/pJ3nwX75NJBTi0z/6d0779OdUMSiKMmpGHDmIiBu4AzgXqAbWi8gaY8yWOLFrgTZjzHwRWQ38GLgSCAA3AkudI5HPGWM2JKQlq0sZhmgkwov33cX7zzzJnOOXc+FX/5n07JzJbpaiKIcoqYwcVgCVxphdxpgQ8BCwKkFmFXCfE38UOEdExBjTY4x5DVtJpMqQdY2i/BFHoLubx267ifefeZLlF1/Gpd+5URWDoigHRSo2hzKgKu68GliZTMYYExGRDqAQaB6h7t+JSBT4M3CLMcYcRF1HJN2tLTx664201dVy/pe/wdKPnDvZTVIU5TAgFeUw1FO7OQCZRD5njKkRkWxs5fAPwP2p1iUi1wPXA5SXl49wqcOTjsYG/nTLD+nt6OBTP7iZ8qXLJrtJiqIcJqQyrVQNzIo7nwnUJpMREQ+QC7QOV6kxpsYJu4AHsaevUq7LGHOnMWa5MWZ5cXFxCrdxeNFaW81DN32XQHcXV/zLLaoYFEUZU1JRDuuBBSIyR0R8wGpgTYLMGuBqJ3458IIzRTQkIuIRkSIn7gU+AXxwIHUdibQ31PPIv36faDjMp3/0H8xYsGiym6QoymHGiNNKzrz/DcDTgBu4xxizWURuBjYYY9YAdwMPiEgl9lP+6lh5EdkD5AA+EbkUOA/YCzztKAY38Bxwl1MkaV0K9LS38eit/0I0EuHKm26jaNbsyW6SoiiHIXI4PJQvX77cbNiQ6BF7+BHo6eaRm75He0M9V9x4q44YFEU5KETkbWPM8qHydDvOQ4RIOMz//ue/0VJTzSXf/qEqBkVRxhVVDocAxhiev/s31GzdzIU3/DMVy46f7CYpinKYo8rhEOC9Z57kgxef4eTLruSoU8+c7OYoinIEoMphilO1eSMv3nsnc09cwalXfG6ym6MoyhGC7so6helqbeavv7iN/BllXHTDt/WNbYoyVZhqjjzjsMOQKocpirEs/n7HLwiHgqz+9g/xZ2RMdpMODawohHsh3DdwRPogEoRIICEMQjQE0bATOnEr7KQ5cSviHNGEuHNunLiJgmWBsey4sZz0WJqJi8cdmLh8E5dmBucNSnNCiEsjLo/982PE5w/q5BI6vGR5STvGJOkpd6RTrMM9VPj4z+Gka8e8WlUOU5QNT/4v+z54n3Ov/xoFpTMnuzkTR7gPepqhtxl6W6GvzT4C7RDosI9gl30EOiHU7Rw99hEZzR6PSXB5wOUFt9eOx0KXG8TtxJ1zl3MuLifPOcTrhE66uOynO3HFxd3OE19iustJIy4vJjdUyNB5MPiJctDTZXx+MhmGyUvypJr0CTbFJ9tRPwFP4p6cU2U/0NLxcVBR5TAFadi9k9f+eD/zTzqFYz563mQ3Z2yIRqCrFtqroKPajnfWQVcddDdCd4MdhnuS1+FJh7Rc8GdDWo4dZk0DXxb4MgcObwZ4050wzS7nTQNPGrj94PHbcY/PPnc7iiAWnyo/ekWZRFQ5TDHCoSBP/ddPyMjJ4bwvfY1Dardyy4KOKmjeAc3boKUSWndB625bIZjoYHl/DmTPgOwSmLkcMqdBZhFkFNphegGk5ztHnt2pK4oyIahymGKs/fNDtNZW86kf/tvUfidDJASNm6HmHajfBA2boXGLPcUTIy0PCubaHf8xl0NeOeTOso+cUvBnTV77FUUZFlUOU4jmfXvY8NfHWHLWOVNvoVtPM+x7E/attY/6jbYBF2wlULIUjvscTDsaihdB0UL76V9RlEMSVQ5TBGNZPHvXHfgyMjnz8/842c2xPXn2vg47X4BdL9mjA7Dn5ctOhJVfhrITbGNY3mydp1eUwwxVDlOETS88Q+32Dzn/n75JRk7u5DQi2AXb/gZbn4TK5yHUBW4fzFoJH70RKk63lYHO/SvKYY8qhylAT3sbrzz4O2YuXsqSs86Z2ItHQrDjadj0J9j+tO0KmlUCSy+DRRfBnDNsDyBFUY4oVDlMAd740x8IBwJ87LqvTpx3UstOeOc+ePcP9pqCzGI44SpY+imYuQJ0NbaiHNGocphkWqqr2PTCMxx77kUUls0aucDBYAzseQ3e+H/2aEHcsOhCOOFqmPdRcOvXQVEUG+0NJplX/3gvXr+fUy7/zPhdxBjbjvDKT6DuPcgogrN/ACdeDdnTx++6iqIcsqhymESqt3zAzg3rOH31VeNjhDYGdj4PL9wCte9CwTy4+Few7Ep7BbGiKEoSVDlMEsYYXv7DPWQVFHLCRZeM/QWatsHfvmO7oeaWw6o7YNlqnTpSFCUltKeYJHase536yu2c/+Vv4PWnjV3FgU54+cew7r9tL6MLfgzLv6Dup4qijIqUXFJE5AIR2SYilSLyvSHy/SLysJO/TkQqnPRCEXlRRLpF5PY4+QwReVJEtorIZhG5LS7vGhFpEpH3nOO6g7/NqYUxhrWPPUx+6UwWn/XRsat454vw61PgzTvguM/C196Bk7+sikFRlFEz4shBRNzAHcC5QDWwXkTWGGO2xIldC7QZY+aLyGrgx8CVQAC4EVjqHPH81Bjzooj4gOdF5EJjzN+cvIeNMTcc1J1NYXa9s56mvbu54Cv/B5fLffAVBrvh2R/BhruhcAFc+yzMOung61UU5YgllZHDCqDSGLPLGBMCHgJWJcisAu5z4o8C54iIGGN6jDGvYSuJfowxvcaYF514CHgHOCJeWmCMYd1jD5NTXMJRp5118BU2bIY7z4IN98ApN8CXX1XFoCjKQZOKcigDquLOq520IWWMMRGgAyhMpQEikgdcDDwfl/wpEdkoIo+KyJDO/yJyvYhsEJENTU1NqVxqSrDvg/epq9zGilWfwu05SJPP+w/DXefY215c8wScf6t6ISmKMiakohyGWrKb+D6/VGT2r1jEA/wR+C9jzC4n+a9AhTFmGfAcAyOSwZUbc6cxZrkxZnlxcfFIl5oyrHv8ETLzC1hy1scOvJJoBJ78Njx+vb0J3pdetfc9UhRFGSNSUQ7VQPzT+0ygNpmM0+HnAq0p1H0nsMMY88tYgjGmxRgTdE7vAk5MoZ5DgtrtH1K1eSMnXXwZHp/vwCoJ9cBDn4X1d8GpX4Or/mK/LEdRFGUMSUU5rAcWiMgcx3i8GliTILMGuNqJXw68YMzwbxUXkVuwlcg3E9JnxJ1eAnyYQhsPCTY88ThpWdksO+eCA6uguxHu/ThUPmu/VPy8W3TdgqIo48KIPYsxJiIiNwBPA27gHmPMZhG5GdhgjFkD3A08ICKV2COG1bHyIrIHyAF8InIpcB7QCfwQ2Aq842w2d7sx5rfA10XkEiDi1HXNGN3rpNLZ3ETl+rUs/8Qn8aYdwLqGjmq49xPQVQ+rH7T3RFIURRknUnrsNMY8BTyVkPajuHgAuCJJ2Yok1Q65/agx5vvA91Np16HExuf+BgaOPfei0RfuqLFHDL2tcPVf1RtJUZRxR+ckJoBIKMTG5/7O3BNXkDttlPaBztoBxfAPj9vvY1YURRlndNP+CWDbm6/S19XJ8Rd8YnQFu5vsqaSeZvj8Y6oYFEWZMHTkMAG89/QTFJTOpHzpsakXCvXCH1fbI4er/qJTSYqiTCg6chhn6nZso37nDo674BOpv+XNisJjX4Sat+FTd0H5yvFtpKIoSgI6chhn3n/2KXzp6Sw5cxQb7D1zI2x9As7/Dzj64vFrnKIoShJ05DCOhAJ9bF/7OotOOQNfekZqhd79A6y9A1Z8CU75yvg2UFEUJQmqHMaRHeveIBwMsPisc1Ir0LAZnvwWVJwBF/zH+DZOURRlGFQ5jCObX36evJIZlC1aPLJwsAseuQrScuBTd8NYbOWtKIpygKhyGCc6mxqp2ryRxWd9dGRDtDGw5uvQugsuv0f3SlIUZdJR5TBObH7F3oF88RkpGKLf/T1sfgw+eqPurqooypRAlcM4YIxhyysvMGvxMSOviO6ohqd/ALNPh9O+ObysoijKBKHKYRyo3fYh7fV1IxuijYG/fgOsCKy6HVz651AUZWqg6xzGgS2vvIDH72fhylOHF3zvD1D5HFz4EyiYMzGNUxRFSQF9VB1jrGiU7W+9wfzlJw+/tqGjBv7uTCeddN3ENVBRFCUFVDmMMVVbNhHo6mThytOGF3zmhxANwqr/p9NJiqJMObRXGmN2rHsDj99PxXEnJBfa8xpsfhxO/z9QMHfiGqcoipIiqhzGEMuKsuOtN5h73HK8/iRve4tG4G/fhdxyOO0bE9tARVGUFFGD9BhSu+1DejvaWXDyMFNK79wLDR/AFfeBN33C2qYoijIadOQwhmxf9zpur5e5xyd5KU9vK7xwi7130uJVE9s4RVGUUaDKYYwwlsWOt96k4tgTk3spvfJTCHTABbdBqu92UBRFmQRSUg4icoGIbBORShH53hD5fhF52MlfJyIVTnqhiLwoIt0icntCmRNFZJNT5r/E2YBIRApE5FkR2eGE+Qd/m+NPXeV2uluak69t6KyD9b+FYz8L05dObOMURVFGyYjKQUTcwB3AhcBi4DMikrjN6LVAmzFmPvAL4MdOegC4Efj2EFX/BrgeWOAcFzjp3wOeN8YsAJ53zqc8O956A5fbw9wTVwwt8OrPwEThrP87sQ1TFEU5AFIZOawAKo0xu4wxIeAhIHHCfBVwnxN/FDhHRMQY02OMeQ1bSfQjIjOAHGPMm8YYA9wPXDpEXffFpU9pKte/Sfkxx5KWmbV/ZnsVvHMfHP95yK+Y8LYpiqKMllSUQxlQFXde7aQNKWOMiQAdQOEIdVYnqbPEGFPn1FUHTBuqAhG5XkQ2iMiGpqamFG5j/Girq6G9vo65J5w0tMCrP7XDM4YaQCmKokw9UlEOQ1lOzQHIHIz8/sLG3GmMWW6MWV5cXDyaomPO7nc3ADDnuCG8lFp321tyn3A15M2a4JYpiqIcGKkoh2ogvlebCdQmkxERD5ALtI5Q58wkdTY4006x6afGFNo4qex+723yS2eSVzJ9/8zXfg7ihjP+eeIbpiiKcoCkohzWAwtEZI6I+IDVwJoEmTXA1U78cuAFx5YwJM50UZeInOx4KV0F/GWIuq6OS5+ShIMBqrZsYs5xJ+6f2d0I7z8Ex38OckonvnGKoigHyIgrpI0xERG5AXgacAP3GGM2i8jNwAZjzBrgbuABEanEHjGsjpUXkT1ADuATkUuB84wxW4B/Au4F0oG/OQfAbcAjInItsA+4YixudLyo2rKJaDg8tHJY/1uIhuDkr0x8wxRFUQ6ClLbPMMY8BTyVkPajuHiAJJ24MaYiSfoGYD+Hf2NMCzDCW3KmDrvf3YDH72fm0Qm3Eu6zlcPCC6FoweQ0TlEU5QDRFdIHgTGG3e+9TfmSZXh8vsGZ7z8EvS1wylcnp3GKoigHgW68dxC01dXS0VDP8o9/cnCGZcHaX8P0ZVBx+uQ0TgFsBY5lMBEDUQsTNZioBRE7NFEnPzG07DA+boeAceLGgMGJY8sbgzG2TL+s6W+MLRcrZ8COMJAeS4o32cWXH3Qed4+JsvHyiekMLbOfSCr+g8lNi0nkRyc+boy23VOYzBUzSFs49htJqHI4CPpdWI9PsDdUPgvN2+Gyu3QPpRQxlsEEo1h9EaxABKsvYp8Ho5hAxA5DUUwwiglZWCHnPGzZR8TChKNxcYOJWBC1pk6HJNjfh9hXQmTg65GQjiR8dcT5T4Y+l/7/EuQSr52sXftHB9oyEqP9ih/QT2IcfkeHyU/T6ouMS72qHA6C3e9toKB0JrnTElxY1/4Gskth8SGxuHvcsEJRrM4Q0c4Q0a4g0a4wVneYaHcIqydsH70RrN6w/aaOqAYAACAASURBVAUfqRMXEJ8b8bkQnxuX14l7XbjSfYjXhXhc/SEeF+IRxB07F8Rtn+NxIS77nFjoFsQVO3eBy+mkYzJih7gYiDudrghOnhMXGejwxZFXlEMIVQ4HSCQUoubDzSw798LBGW17YNeLcPb3weMbsuzhgolYRFoDRJr7iLQGiLYGiLQFiLYHiXYEsXqHeKJxCa4sL+5ML65ML948P64ML64MD65050jzIGluJ/Tg8rsRv9vu9LWTVZQJQZXDAVJXuY1IOET50mWDM979PSBw3OcmpV3jgYlYhBt7Cdf3EGnoJdzQS7ipl2hrYNDTvvjcuPP9ePLT8M3OwZ3rx53j6z9cWT5c6R776VxRlCmNKocDpGrzRhCh7KglA4nRCLz7B5h/ziG7VYaxDJHmPkL7Ognt6yJU0024vgeijhZwC97idHxlWXiOLcZTnIGnMA1PQRquTK8+2SvKYYIqhwOkassmplXMHbwL687noasWLvxx8oJTDGMZwvU9BHd1ENzZTnBPJ8YxcEmaB9/MLLJOK8NXmom3NAtPYZo9H68oymGNKocDIBIKUbdjG8ed/4nBGe/cD5nFsPCCoQtOEaxAhMC2NgLbWglsb8PqDgPgKUwjfUkh/oocfOU5eIrSdQpIUY5QVDkcALXbtxINh5m1+JiBxK4G2PY3e9HbFDREW71h+ja30PdBM4HKdogaXBke/AvySVuYj39eHp48/2Q3s5+oZegLR+kLRQmEY4dFIBIlGLYIRWOhRShih+GIRThqCFsW4YghYtnnkahFxLLPo5YhEjVELUPUGCKWwbIGwqix8yxjsCyIGoMxxlnCMDi0Bp3b6xksY4gtX4jF7WUNTr5lT8+ZhDz64/THndig5Q2xNQ1JlzMkWbeQilv//uschi40Ws/gqbKkwEwZn+ax5YcXLeaqUyvGvF5VDgdA1ZZNiLiYeXScveH9B+03vZ1w1eQ1LAETtQhsa6P33Ub6trRA1ODO95N1ainpSwrxleeM28ggEI7S0hOirSdEW2+Itt4wHb0hOvrCdPSF6QpE7CMYoTsQpicYpTsYoScYpjcUJRQdmx+yy3EjHVhiIPu57gt2hxcLE4nrpwd1MPutMYvv6PvPFWV8qW7vG5d6VTkcANVbNjFtzjz8GZl2gjG2Ibr8lCmxj1K0M0TPW3V0v1WP1RnClekl6+QZZBw/DW9Z1kEZjY0xNHeHqGnvo9Y56joCNHYFaegM0NgZoLkrSHcomrQOl4DH7cIdt3LLcp7io9aBd6cel+B1u/B5XHjddtzjFrwuO/T0h3bc5QKPy4XbJQOH2KHLJbgE3DIQd4m91sFeAhFTOOKk0y+DE7rilJHzgnTs5RADaZKwBiKmwGLx2Cc0EN9fucGAAowvN/DpDsgMRTL5YQWTiYwoMeoqxxQ5XFa+xXFSxdivjgZVDqMmHApSt2Mrx194yUBi/SZo2THp+yiF63voeqmK3o3NYBn8C/PJunQ+aYvyR21E7g5G2N7QRWVjN7uaetjV1M2+1l72tvTQF7YGybpd4HPbaxCiliEUsZLUCmleFzlpXnLTvWSnechO85KV5iHb7yEzdvjcZPjcpPs8ZPjcpHldpHnd9uFx43fO/R5bEfjc9uFS+4iijBmqHEZJ3fatRCMRZi2Jszd88GdweeDoS5IXHEdCVV10vrCPwIetiM9N1qmlZJ08A09Rekrlm7qCbKppZ2N1Bx/UdPBhXRc1cUNVl0Ca1w1AcIiOPy/dR0lOGiU5fqZlp1Gc7acoy0dhlp/CTB8FWT7yM3zkpnv761EUZWqjymGUxOwNZYsce4MxsPkxmHs2ZA732uyxJ9zUS+fTe+j7oAVXhoecj5WTdWoprgxv0jLGGPa09PLGzmbe3tPGhr1t7Gvt7c/P8LmxEiyIPo+L2YWZzC3KpLwwg/KCDGblZ1CWn86M3DTt8BXlMESVwyip2ryRkrnz8Gdk2Ak1b0P7Pnu7jAnC6g3T8cxeet6qQzxuWymcUYbLP/SfszsY4ZXtTby4tZHXdjRR1xkEwO9x2XPkDi6BWfkZLC7NYdH0bBZNz2bBtCxKc9N1ykZRjjBUOYwC296wnRMuips++uDP4PbBUR8f9+sbY+h9p5GOp3Zj9YXJXDmDnHPKcWft7zrb3hviqU31/H1zPW9WNhO2DF63bWyNkZ3m4aSKAk6cnc9xs/JYXJpDhk+/EoqiqHIYFQ27KrGikYEtMywLNj8O88+FtNxxvXakNUDrn7YT2t2BrzybvEuX4ivNGiQTilg8u6WBx96p5uXtjUQsSPe6iDkApXvdnDqviNMWFHHavELmFGXqdheKogyJKodRULdjGwClCxbZCfvehK46WHrZuF3TGEPv2w20r9kFAnmXzSdz+fRB6xOqWnv5w7p9/GnDPlp6wvg9AwqhKMvPuYunc+7iEk6qyMejW18oipICqhxGQd32reSWTCcjN89O2PwYeNLHbbsMqy9C26Pb6dvcgn9uLvlXLMSTn9af/35VO3e+sounNtUB4PXYHX9OupeLl5VyyXGlHDszV0cHiqKMmpSUg4hcAPwKcAO/NcbclpDvB+4HTgRagCuNMXucvO8D1wJR4OvGmKdFZBHwcFwVc4EfGWN+KSI3AV8Empy8Hxhjnjqw2xs7jDHU7tg6sGWGFYUtf4GF54M/a/jCB0C4vofmB7YQbQ+Se9Ecsk4v6x8tvLuvjZ8+s43XK1vwxI0gTp9fxGdWlPORRcU6QlAU5aAYUTmIiBu4AzgXqAbWi8gaY8yWOLFrgTZjzHwRWQ38GLhSRBYDq4ElQCnwnIgsNMZsA46Lq78GeDyuvl8YY3568Lc3dnS1NNHT1krpwqPshJq3oacJjr54zK/V+34jbY/uQNI8FF+/DP/sHAC2N3Txk6e38eyWBrz28mJ8HhefWVHOF06rYGZ+xpi3RVGUI5NURg4rgEpjzC4AEXkIWAXEK4dVwE1O/FHgdrHnMlYBDxljgsBuEal06nszruw5wE5jzN6DuZHxJmZvmLHAUQ7b/gbitt/dMEYYY+h6oYrOZ/fim51D4eeOxp3jozMQ5hfPbue+N/b0u55m+Dxcf+ZcPr9yNrnDrGtQFEU5EFJRDmVAVdx5NbAymYwxJiIiHUChk742oWxZQtnVwB8T0m4QkauADcC3jDFtiY0SkeuB6wHKy8tTuI2Do27HVjxeH8Wz59gJ25+G2adC+tjsa2IsQ/tfKulZV0/GCdPIv2wBuIW/vFfDzU9soaU7hAh43S6+cvYcrjtzLjlpqhQURRkfUpmYHsqambg7WjKZYcuKiA+4BPhTXP5vgHnY0051wM+GapQx5k5jzHJjzPLi4uLkrR8jardvpWTefNwej73orXHzmBmiTdii5fcf0rOunuyzZ5J/xUJaA2Guv38D33joPTp67fctXLl8Fq9+9yP883mLVDEoijKupDJyqAbi33k5E6hNIlMtIh4gF2hNoeyFwDvGmIZYQnxcRO4CnkihjeNKJBymcffOgc32tv3dDhddeNB1m4hF8wNbCO5oI/fiuWSfVsZzWxr4zp/fp63HVgqLpmfzb5cu5YTy8dl9UVEUJZFUlMN6YIGIzME2HK8GPpsgswa4GtuWcDnwgjHGiMga4EER+Tm2QXoB8FZcuc+QMKUkIjOMMXXO6SeBD0Z3S2NP4+6dRCMRSmP2hu1/g8L5UDjvoOo1EXvEENzeRv5lC/CfOI1/f+pD7nxlV/8W0t86bxHXnzl30MpmRVGU8WZE5eDYEG4AnsZ2Zb3HGLNZRG4GNhhj1gB3Aw84BudWbAWCI/cItvE6AnzVGBMFEJEMbA+oLyVc8j9F5Djs6ac9Q+RPOAPG6EUQ7II9r8GK6w+qThO1aHlwK4GtreRdOo/gkgK+eM863tjZCsC84kx+eeXxLC7NOej2K4qijJaU1jk46wyeSkj7UVw8AFyRpOytwK1DpPdiG60T0/8hlTZNJLU7tpJdVExWQSFsWQPR0EFNKRljaPvzDgJbWsi7eC41Fdlc/atXaegKAPC5leX86OLF+D2626miKJODrpBOgbodWwdcWLf/3d5HaVaiw1bqdL1QRe87jeR8rJytZelc/evX6QtH8biEWy89hk+fNGvkShRFUcYRXUY7At1trXQ1N9n7KVmW7cI6/1xwH5i3UO+7jXQ+u5eM46exvtTPZ+5aS184Sn6mj0e/fKoqBkVRpgQ6chiBhl2VAJTMWwD1G6G3GRace0B1Bfd00ProdnxzcnljQRZff+BtjIHywgz+cN1KXeGsKMqUQUcOI9C4ZyeIMG32HNj9sp0456xR1xPtCtHyhw/x5Kex8aRCvvan97AMLC3L5fGvnKaKQVGUKYWOHEagcfdO8qeX4kvPgF0vQ9EiyJkxqjqMZWh9aCtWX5S955Tx5Uffxxg4qSKfe7+wgswkb3BTFEWZLHTkMAINu3cybc48iITs9zfMHf2oofO5vQR3dtB++nSu+usmIpbhuJl5qhgURZmyqHIYhr6uTrqam5hWMReq10O4d9RTSoHtbXS9WIVZWsjqN3cQjhoWz8jh/utUMSiKMnVR5TAMjbt3AVAyZ75tbxAXVJyecnmrN0zrn7bjKkrnCzUNdAejVBRm8OAXV+reSIqiTGlUOQxD456dAEybM9e2N8w4DtLzUi7f/sQurJ4QP/OHqGzrJSfNwwPXriQvwzdeTVYURRkTVDkMQ8PunWQXFZPuE6jZAHPPTrls35YWet9p5J2ydP5c3YbbJfzuCycxq0C9khRFmfqochiGxj27KJkzD/a+AVYkZWO01Rum7fEdBPP9fKPK3mT2Z1ccy4mzC8azuYqiKGOGKockhAJ9tNXVMK1inj2l5PanvGWGPZ0U4fqedgzwhdMquPT4xHccKYqiTF1UOSShac9uMMZ2Y939MpSvBG/6iOWCezvpfaeRx7MNO0NhFpVk8/0Lj56AFiuKoowdqhyS0LDbNkaXlORCwwcpubDGXvXZ7Xfxi45O/B4Xd121HJ9HP2ZFUQ4t1NE+CY27d5KRm0dm13Y7IQUX1p719YRre/gK3VjAT69YRnmhGqAVRTn00EfaJDTu2cm0irlI1Tpw+2w31mGwesN0Pr2HF3wWu7D4+DEzuPhYtTMoinJoosphCCLhMC3V+2x7w751UHo8eNOGLdPx7F6CvWFuDXWT5ffw7588ZoJaqyiKMvaochiClqq9WNEoJbNmQd17MGvFsPKRlj561tVziytAELjtsmPIzdAV0IqiHLqozWEImvbtAWB6Ro/9StBZJw8r3/ncPvZZUZ4nzClzC/n4stHt2qrYGGOwLIMVMUQjFlbUYEVjoZMXNRjLjpshzo3BCQ3GGqgTY8eNAZxw4DwuTnw+gF1PfBsdEbscTiGzv8zgexssE38yhHiSz2e0GUnERyV9gEzIRRSAimVFlFSM/bvmVTkMQUv1PtxeL1k99ot+hlvfEG7oofvdBr5LD1638PMrj0VEJqilE48xhnAgSrAvQrA3QqgvTLAvSqgvQjgQIRSIEg5GCQeihEN2PBKKEglbdhiyiEYsImGLaOyIWESjFlZEe5TDisP3ZzClyMzzT55yEJELgF8BbuC3xpjbEvL9wP3AiUALcKUxZo+T933gWiAKfN0Y87STvgfoctIjxpjlTnoB8DBQAewBPm2MaTuIexw1zVV7KSibhav6LSiYB1nFSWU7nt3Lq0SowvCdjy1iRu7IayGmIqG+CF1tAXragvR0BOnpCNHbEaKvyz56u8IEesIEe8JY0RE6cQGv343X58YTC30uPD4XGTk+PF4X7tjhGThcHrFDt+B226F9xMVdgrgS4k5oHyAiiNCfh2CHOHmODNgydtQJnQ4tVgfCIGVvpwlOkX7Z2H33S8Z1jMJA/uD0+M9Mhk4f4rMdMvkwfiBRJocRlYOIuIE7gHOBamC9iKwxxmyJE7sWaDPGzBeR1cCPgStFZDGwGlgClALPichCY0zUKfcRY0xzwiW/BzxvjLlNRL7nnH/3IO5x1LRU7WPmUYuh6glYcH5SuVBNN90fNPMTAhRk+rjujLkT2MrRYYyhpz1Ee2Mv7Q29tDf20tnUR2dLgK6WAKG+yH5lfOkeMnJ8pGd7yS/JIC3bS1qGl7RML/5MD/4MD/50D750D740O/T6bUWgnZWiHNqkMnJYAVQaY3YBiMhDwCogXjmsAm5y4o8Ct4vdO6wCHjLGBIHdIlLp1PfmMNdbBZztxO8DXmIClUOwt4eulibKpvlha4u9MjoJHc/s4c+EaMdwx6olU2axWzRs0VLbTePeLpqru2mt6aaltmeQAvB4XWQXpZNTlEbp/DyyCvxk56eRle8nM89vP+H73JN4F4qiTCapKIcyoCruvBpI7DH7ZYwxERHpAAqd9LUJZWPO/wZ4RkQM8D/GmDud9BJjTJ1TV52ITBuqUSJyPXA9QHl5eQq3kRot1fsAmOFvtxOSGKNDdT20bmvlLoIsmJbFRcdMnhG6rytEbWU7dZUd1O3soLmqq3/qx5fuobAsk4UnlVBQmkne9AzypmWQledHXPp0ryjK0KSiHIbqQRInnZPJDFf2NGNMrdP5PysiW40xr6TQHrsSW5ncCbB8+fIxs2Q2V9nKITe4F9LyoGjhkHIdL1XxO4IEgJ9cvmxCp1GiEYvaHe3s29JK9dZWmqu6AXB7XJTMyeHYc2YxbXYOxeXZ5BSl6RSPoiijJhXlUA3MijufCdQmkakWEQ+QC7QOV9YYEwsbReRx7OmmV4AGEZnhjBpmAI2jvquDoKVqLx6/H1/zRttLybX/VFGkPUjN+w08SojT5hVyXHn+uLcrHIqyd1MLu95rYu8HLYT6Irjcwox5uaxcNZeyhflMK8/G7Z0aU1ujxRjbLTXm2RQNx3k0RZxzJ7SiMVdXi2gkwd01ahF14ibeBdYawgXWOO6vFnZ6nPtrolssjmtrcnfYOPfXOHfX/rIMTu93gx3kAhsn058YHx/8DDTgehuXNvgkyWed9I8w+DSJ2GiFxtQHbZRuu0cCZ3x6IYtPLx3zelNRDuuBBSIyB6jBNjB/NkFmDXA1ti3hcuAFY4wRkTXAgyLyc2yD9ALgLRHJBFzGmC4nfh5wc0JdtznhXw7mBkdLc/U+ZpRNQ5qfg2VXDinT8Wo1DxEkAvzbpUvHrS3GMlRvb2P72np2vtdEOBAlLcvL3OOLmXtsETOPKsDrn3y7QCQUJdATdo4Iod4Igd4wob4Iwb4IoT7HxTXm6hpzdw1FicTCkIWxxu6H73I8msTxanK59/ds6o/HeTbF4vFeTS637WYkwqD8mCdTv7OSa8CLqT8f+j2R+r2fiM9jwPspVrY/PpQXVIJXU5wjFEPIJPeOGvpzk8SMVAadKciM6dhVR8KDKCjNHJd6R1QOjg3hBuBpbFfWe4wxm0XkZmCDMWYNcDfwgGNwbsVWIDhyj2AbryPAV40xUREpAR53pjs8wIPGmL87l7wNeERErgX2AVeM4f2OSEvVXpYflQ0dDLm+wQpEqF5bw58Jc/LcAuYWZ415GwI9Yba+WccHL9fQ0dSHL83NvBOmsXBFCWUL8/vdMscTYxl6u0L0tAfpbgvS0x6ktzNET4cd9nWG6OsK09cdIhKyhq3Ll+bu92TypnnwpblJz/Y6nk2DXV09Prfj6mqnuT22y6vHM+D66nLLINfXwW6vMtB5K4pywKS0zsEY8xTwVELaj+LiAZJ04saYW4FbE9J2AccmkW8BzkmlXWNNX1cnPe1tzMhwQYfAjP2b2LW2lseiQcLAv16yZEyv39nSx3vPVvHh67VEwhYz5uVy0ifmMO/44nHxHIqGLdqbeulo6KO9yXFtbbbdW7tbg0Qjgzt9EUjP8ZGR4yMj20f+9EzSsr2kZ9nurbaLq9d2cc3w4M/w4vO71fCtKIcgukI6jhbHGJ1nGqFwPqQNXnVoohZ7X9rHw4Q4oTyPRdPHZlViZ3Mf65/czfZ19itFF548nWM/OouimWMzKjGWoaOpj6aqLlpre2ip6aa1tofO5r5BU7hpmV5yitIompnNnGOLyS6wXVtj7q3p2b4JGbUoijL5qHKIo9lxY03v2jnk+6J7N7ewJhAgANx8ycHbGgI9YTb8bQ+bXqpGRFh6VhnHnVtOdsHwO8CORE9HkIZdndTv6qBhTyfNVV2EAva6QxHIK8mgaFYWC04qIX96BnklGeROy8CfPnW/DrbBOooVjdgGaCuKiUbtNCuKsSwnbmFihzF2uhWN228pGmdwtmWwLGxbcMzu4eQ7VmhjYiF2Xuzcbtig+MDeS7E9l2IG5gHLskncaGnIfZlMfPGhPpC44qOzPKdu0x0jG5AakceVWUuWUTx7zpjXO3V7g0mguWoveVluXD0NULr/+xsqX9zLQwRZMiObpTNzD/g6xjJ88EoN69bsItgX4ehTZrDi4rlk5fsPqL7ezhDV21qp2dZOzbY2Opr6AHC5haJZ2SxcMZ3i2dkUz8omf0YGHu/BT1EZY4iEQwR7egj19RLq7SXY10s4ECAc6CMUCBAO2kckGCQcChIJBomEQkTCIaLhsBMPEw2HiUZiYQQrYofRSAQrGiUaCWOs4e0ainKk8rHrvqLKYbxpqd7LvFKngy49flBepKWP1+o66AZ+8PHFB36N2m5e+v1W6nd1MvOofE6/YgGFZaObPjKWoWFvJ3s3tbD3gxaa9nUBtuG3dGE+S84oY/q8XIrLs1JWBMay6Ovuoru1hd72Nno62ulpb6Ovq5O+zk76ujoIdHcT6O4i0NNNsKebaGT/LTeGwuX24PX78fh8zmHH3V4fHq8Hf3o6bq8Pt8eD2+vF7fHgcnvs0OOEbjculxuXx4PL5XJCN+Jy2XluOy4uFy6Xy/E2ciEut30eSxMn7hIEW4b+vZhcjidRzBvJ8VqKxWEgL+ZxJAOeTLaM9NcX89GJ33tpUNpQ+y851xhULgmD8kdpgE/ZYD9Ghv39vKCUMcPjP7CHyhHrHZdaD0GMMTRX7ePEo8PQJTB92aD8uleq+DMhpmX6OHVe4ajrtyzDO0/vZf0Tu/GlefjYNUezcOX0lH+kxjLU7eyg8p1Gdr3bRE97EBGYPjeXlZfMZdbiAorLs5PaBIxl0dXaTHt9Pe0NdXQ2NdDZ1EhncxNdLU10t7ZiRffv7N1eL+k5uaRn55CelU1ReQVpmVn4s7LwZ2TaR3o6vowMfOkZ+NLS8aal40tLw5uWhsfnx+3Rr5miHGror9aht6OdQFcnRe5uKFoA/oGneROxWLehll1Y/ODMuaN2k+xpD/Ls7zZTs62d+cuncebqhaRn+VIq297Yy7a19WxbV09XSwC310X54gLmXTqX2ccUkZY5+KVCxrLoaGqked8emvbtpqVqH6211bTV1RIJBfvlXG43WQVF5BQVU7ZoMVmFRWTlF5JVUEBmbj4ZeXlk5ubhTUtXt1BFOQJR5eAQ21MpK7APFn5sUF7npiaeiAbxu4SrTq0YVb37trTw7D1biISifPSqozjqlBkjdrZW1GLPxhY2vVxN9dY2RGDm0QWsvGQuc44twpc28GfraW+jZtsW6nZso3F3JQ27dhLs7bEzRcidVkJB6UzKlx5L/owy8qbPIK9kOtmFxbjck7+ATlGUqYkqB4eWmioyPSE8gRaYMdgY/e5zu3mFCB9fMoO0URhzN75YzWuPbKegNJPzv7iU/OnDr2QMBSJsea2W95+vorstSFa+n5WXzOWoU2b0G6t72tvYuf499m56n5qtm2lvqAPA7fFQPHsOR512FtPmzKW4fA6Fs8rxpR2a75dQFGVyUeXg0FZXQ2l2yD6JM0ZHWgM839KFAb5z4VEp1WVFLV57ZAebXq6hYlkR5/7j4kFP+4kEesK8/0IVm16sJtgboWxhHmdcuZCKYwoRgfqdO3jv6XXsfPstmp1XmKZlZTPz6CUce+6FlB21hGlz5uL26HurFUUZG1Q5OLTV1TK/yAIEph/Tn77tpT38lTBHF2cyqyBjxHoi4Sh/v/MD9m5q4fhzyzn5k/OSGonDoSgbX6ji3Wf2EeyNMPe4Yo4/v5ySihzqK7fz0gOPsX3t6/S0tSLiouyoxZzx2WuYfcxxFFfMweXSaSFFUcYHVQ4ObXU1TC/pgdyF/cZoYwwvv1tPO4Z/P2/RiHWEQ1Ge+vVGqre1cdZnF7H0zLIh5Yxl2Lq2nrV/2UlvR4iKYwpZuWoeaZkhNr/0NE/+4lnaG+pwezzMOX45C1aexpzjTiQ9e+zfE6soijIUqhyASDhMZ2Mj+dMaofSi/vRAdRevhoNku1ycv2T6sHWEAhGe+vVGane0c85VR3PUKUO//KepqotX/rid+l0dlMzJ4bzrlmDCNbz+0K/Y+fY6jGUxa8kyVn7y08xfcQppmWO/sZ+iKMpIqHIAOhrqyHD34Yt0DloZ/dZzu1lHhAsWTsM9zJ5CkVCUJ25/n/pdnXzsHxez8KT9FUkkFGXdml28/3wVaVlePvL5Rbhdu3jpdzdTv3MH6dk5LP/EJznmo+eRP2PoEYeiKMpEocoBaK2roSTNfptazFPJWIZXdzRjAV8/P/mUkmUZnr1nC3U7Ozjv2iUsWF6yn0zDnk6ev3cLbfW9LD59BtNmNfHW47fSUr3v/2/vzKPrqs5D//vOuaPmwZI8ypZnG2MwthlDGAI1NAFDgUCDIU1oyGvTleGFlbFpkw7rJX1pmuSlKw1JCJmBEEJMSTA4mBk8U+N5kG1ZlizL1jzc4dzzvT/OudKVriTLRsJG2r+1tvf07X33vlve390zxZMmc91ff4KFV11LMDQ6Jx0NBoPhdDHKAWiuO0pZ2D8bMNG7UK9pz0nWuQmmRoLMnzTwXL+q8vKje6l+s5H3fHBOlmJwXWXzHw+x8elD5BaGuPSmEDtf/i+2PHWAkinT+MCnv8CcSy475xaWVZVUKkUymSSZTOI4To/tOA6pVKrHzjSu6/bYAxlVdR/8pAAAIABJREFU7bH7u/ubdDkGc2eW9VTu/nV7N3OuH0g818s3Flm6dCmzZ88e8XyNcsDbqTQrPwlF0yGcD8Cfnq3mAC4fXzZ90HRb1hxm+4tHWXJ9JRdcO61PXHdHguce2smRnU3MWBzG6XqJF372KgVlFdzwt59hwZVXj6pSUFVisRgdHR10dXXR2dlJV1cX3d3dPSYWixGPx4nFYiQSCeLxOIlEgkQiMeKdaPqOovS9Rz33Hw1k0mky7Mwup0/3ozpwXL/yi/beXTqYjBfW80+/sL7h2UGn+L4Gyvc0OdcV29su3Tlev3OVtoJCMMphdGiuP0pZpBsq/Cklx+X1+lZs4H9dM2vANIfeOsEbT1YzZ3kFl93aV+bYwVbWPLidrrYEM847woE3nkJdl8vvuJvlN99GIDS8qzOGwnVdWltbaWpqorm5mZaWFlpbW2ltbaWtrY2Ojg6cQS7GCwQCRKNRIpEI4XCYnJwcioqKCIfDhEIhgsFgjx0MBLAdB8txsJNJrEQCicex4nHfTkAshiTiSCwO8TgS64ZYHGIxSMQhnoB4HE0k0EQCN5lAk0lIJNGkbxzHdA4Gwxkwcc6cUcnXKAegtb6G/MmtUO7dtnpo8zHWkeS8ohyKc7PXAdpOdLP2JzuZMC2Pa++Z3+els/2bj7P2JzuJ5HaSX7CO3a/sZuZFy7n2Ix+nsHzoHU8Doaq0trZy7Ngxjh07RmNjI42NjZw8eZJUKtUjZ1kWBQUFFBYWMm3aNPLz88nLyyMvL4/c3Fxyc3PJyckhbFlIczNOYyPOiROkTp7EOXGSVHMzqZZmnOZmUq2tuC2tnt3ZOWC50hdop3oLgBWNItEoVjiMRCJIOIQVjiDhMJKX64UHQ0jIN8EgEgggoSASDEIggAT8sIDt+wOIbYNtI3YAsS2wbC/esnv9fWwLxMp2p29XtXrdiHdDa6+/762siHh5ZDzWLJItn6b3BtaM8D52pmzGFzrUDavDuX11kPBBJ3nOZPrnnZgyMtNSp88ofWfjXjnEOjuIxuqxcKHCUw5/fPkQLShfuDr7jvT0ITeAG+4/v+f5TlVl63M1vP7EAXILDtBavwbLsrjhbz/DwvdeO+y52GQySW1tLUeOHOHIkSPU1tbS3d3dE19cXExZWRlz5syhtLSU4uJiSkpKyM/Px7IsUh2dJI/UkDhyhOSu3SSPHiVZX09XfT1t9fWkWlsH/Fy7sBC7uBi7qIhgeQX2nLlYhQXY+QXYBflYeflY+XlYubnYublYeXlYOTlYOTlINOp19uY/tsEwZhj3yqGlvo4J6cXo8vNQV9l6ooMIcOuyaVnyLz+6j8aadv78bxdTWObdW6SutzC97YVDRKOvc/LwJioXLWbF33yaggnlQ36+qtLQ0MC+ffuorq6mpqamZ0QwYcIE5s2bx+TJk5k0aRIVFRWE/CmpVFsb8b17ib/xBt379tFyoJrEwYM4x4/3yd8qKCA4aRLBSZOILrmQYEUFgbJyAuVlBCZMwC4tJVBSgphrtQ0GQwbD6hFE5AbgO4AN/EhVv94vPgz8DFgKnATuVNVDftwXgfvwZiA+qaprRGSaLz8Rb4biQVX9ji//VeBjQKOf/ZdU9Q9vo45D4q03dKFWECmdxdEdx1mPw8KiHMKBvgvG1W82svOVOi66YTpViycA3o6kF36xmx0v7yZoraGlvpZLbr2Tyz/4oUEXnFWV2tpaduzYwe7du2lpaQGgoqKC5cuXU1VVRWVlJdGop3zc7m5i27fT9swzxLbvILZzJ8kjR3rys/LzCc+cSe7llxOqqiI0fTqhymkEp07FLjCnqs81MndeDRQ3VLrh5D1SnOsL4AYP27axR+GG5VMqBxGxgf8ErgdqgY0islpVd2aI3Qc0q+psEbkL+AZwp4gsBO4CzgMmA2tFZC7gAJ9V1S0ikg9sFpHnMvL8D1X95khVciia6uuYHO6ECfPADvL0uoO0oXzg0so+ct0dCV745W4mTMvj4pu86SbXVZ7/6S52vboVN7Eax4ZbPvcVZi29ZMDPamlp4c0332Tbtm00NTVh2zYzZ87kyiuvZO7cueTnezulUh2ddG/cSMP69XRt2Ehs1y7wF5eD06YRWbiQottvJzJ/HuG5cwlMHP6jQSOF67o9W1wzTXq7a6YZbOtr/+2vQ22DzdwKe7rbYoezXbb/NtlTbZ09nW21BsNo8v73v5/ly5ePeL7DGTlcDOxX1WoAEXkEWAlkKoeVwFd99+PA98TrrVYCj6hqHDgoIvuBi1X1daAeQFXbRWQXMKVfnu8IzfVHuTAnhkw8z1s3ONZGCLjrsr5bWF9+ZC/xLoebP7UE27ZwXWXtT3ay+7XXScX+QH5JMX/xxa9RMnlqn3SqysGDB9mwYQN79uxBVamqquLKK69kwYIFRCIRVJXEwYOcfOw3dLz0El2bN3vKIBgkesFiSu+7j+iFFxC98EICxcUjUu9kMklXV1ePGWyLa3p7a+Y210QiQTKZfNtlsPwnPW3b7mNnhqe3vVoZz3+m3YFAYMBtsZZl9eSfVprpsEy5wfyZ4Zlh/eMHixvKPVjYUMp9OIr/dH8cvNM/Jsx61OgxderUUwudAcNRDlOAIxn+WqD/T+MeGVV1RKQVKPXD3+iXts/dECIyA1gCrM8I/jsRuRfYhDfCaO5fKBG5H7gfoLKysn/0sOmsqyY32g3lCzl5uI2NrsP8vAg54d6vZv/m4+zbdJxLbp7JhKl5qCqvPLaPXa/8Cad7LeUzqviLL3yV3KLejtt1XXbv3s2LL75IQ0MDOTk5XHHFFSxbtoyioiJUlfjefTSueYa2Z9aQqK4GIDx3LqV/9WFyL7+c6JIlWNHTe4/BcZw+W1rb2tpob2+nvb2djo4OOjs76ejoGLJzt22bSCTSs9U1HA4PvtW1nwkEAlkmPezNdKc7foPBcG4yHOUw0P/g/mPmwWSGTCsiecBvgU+rapsf/H3gn325fwb+HfhoViaqDwIPAixbtuyMxvCqit28D6JAxXk89ew+TqL81ZJe/RXrSPLir/dQVpnPRSs8JbT5mcNsXfNHnK7nmL54CTf/7y8Siub05Llnzx7WrVtHQ0MDJSUlrFy5kkWLFhEMBnGammj66U9peeJ3xPfsAcsiZ/lyilfdTf7VVxOcPPmU5XYchxMnTnDy5Mke09zcTHNzM+3t7VnykUiE/Px88vPzKS4u7tnampubSzQaJScnh2g02nP2IRg070IYDOOd4SiHWiBz285UoG4QmVoRCQCFQNNQaUUkiKcYfqmqT6QFVLUh7RaRHwL/PdzKnC6dzU0UW/6gpHwhGw7vJADce83MHpn1q6uJdzms/PQCLNti56t1vPbYUzhda5lx4VJWPvD3BPzO9Pjx4zzzzDNUV1dTWlrKrbfeyqJFi7Asi+433+T4z39B23PPQTJJZNEiKr7y9xSsWEFgwoRBy9je3k59fX3POYeGhgaampr6zGnn5+dTUlLCrFmzKCoqoqioqOfMQ0FBgensDQbDaTMc5bARmCMiVcBRvAXmD/WTWQ18GHgduB14XlVVRFYDvxKRb+EtSM8BNvjrET8GdqnqtzIzEpFJqlrve28Ftp9Z1U5Nc/1RJoQ7SQXz6IoXsiWVZG4kRGGOt130RG07O14+yqKrpjJhah5H9zSz9qEnSXY9S+WiC1j52S8TCAZJJBI8//zzrF+/nnA4zI033siyZcuwgLZnnqHpJw8T274dKz+fkg/9JYW33UZk7tys8qRSKY4dO8bhw4epra2ltraWtra2nvji4mIqKio477zzKCsro6ysjJKSkp7trQaDwTBSnFI5+GsIfweswdvK+pCq7hCRfwI2qepqvI7+5/6CcxOeAsGXewxvodkBPqGqKRF5D3AP8JaIvOl/VHrL6r+JyIV400qHgI+PYH370Fxfx4RwF1o2n9VrDtCActt5Fel68/Kj+wjnBLn4piram2I89d3VJDv+yNQFi7jlc39PIBSipqaGJ598kqamJpYuXcq1115LTjhM29NPc+L7/0Xi4EFCVVVM/Md/oPDmm7Fye9+RVlVOnDjB/v37OXDgADU1NSQS3lOlRUVFVFZWMmXKFCZPnkxFRQWRSGS0vgqDwWDow7DOOfid9h/6hf1DhjsG3DFI2n8F/rVf2CsMcrJfVe8ZTplGgkheHuU5MezJF7Bh0wks4MMrvHtKDmxppG5fC1f95VwCQYvHv76GzpO/p2RKJbd+/itYgSBr167l1VdfpaCggHvvvZeqqio6XniB6v/7TRLV1YTnzWPKt79N/p9d713ZgDc6qKmpYdeuXezZs4dW/8TyhAkTWLx4MTNmzGD69Ok921oNBoPhbDCuj8XOnT8dnkngli9kdyxBpW1TURDFSaR49bf7KJ2Sx4L3TObZH26gYd8vieTmcPuXv0bSVX79i19w8OBBlixZwooVK+DwYWo++lG6Xn+D0IwZTPnud8i/7jrEslBVampq2LZtGzt37qSrq4tAIMCsWbO48sormT17NkVFRWf76zAYDIYexrVy4Lh3rGJfUzl7cbmpwuug33rxKB1Ncd73mYXserWGXS/9EMuKc/uX/432eIJHf/ZzOjo6uOWWW1g8bx4nvvc9Tv7kYey8PCq+/GWK77oTCQbp6Ohgy5YtbN26lebmZgKBAPPnz2fhwoXMnj3brBUYDIZzlvGtHBp2APCHXTkocd5/xQyS8RRbnz3M1PnF5JeEeeL/PIimGrjps1+mJZniN796iNzcXO677z4Ka2qovnklySNHKLz9NioeeAC7qIgjR46wfv16du7cieu6zJgxg6uuuooFCxYQDpvX3gwGw7nP+FYOF94NExez+WGXPITrlkzmf56robs9ybI/r+LJbz5KsnsbF/zZLXRHcvndI48wadIkPnTHHXT+8EfUPPQQwemVVD78MDmXXMz+/ft55Xe/4/Dhw4TDYS6++GKWLVvGhCG2qhoMBsO5yPhWDvkVdGghO1LPMy8aIpVIsfW5GioXlrBv425OHFpNyZTZ5C08jyeeeIKqqir+4ooraPzY/cS2b6forjup+PznOVhXx59++EPq6uooKChgxYoVLF26dHxOG6mCmwLXATfp2SnH9zugKT8+5budDLcL6npu9d1u2q394nw/2iur6j8YlGm7A4Rl2gwSRm9Y//qlw/rcn3SKdKeUH/QLHSJuOOlPI5/hYu6NOreYfR1MvnDEsx3fygH449oDNKNcPLuUt16oJdaRZMYFxTz3g69iB4PMuulmnlmzhvnz57OirIy6O+8C22bKd79D5/nn84vf/Ibq6moKCwu5+eabWbx4MYFz7frrVBJibRBvhXgHJDp67USnZ5JdkOzutZ2Yb8c9d9pOxcFJQCrh5ZvKcLtJzx7JjshgMAxNtNgoh9HgtV3e+we3vbeKF769jWkLS3jtN79CU40suP2jPP/iS8ybN4/3dXRy7Gv/RHjBfMr+/d95cccONv3gB0SjUVasWMHy5cvfGaXgpqDzBHQcg45G6PRN1wnoOgldzdDdBN0tEGuBWKvX4Q8LgWDUM4EoBCOeHQh7JlIAdhgCIc+2Q57bCoId9PxWwHNbgX5uuzdMbN9v+24/Xqy+pk9Y2i0ZYf7LapaN/0SbF97jll73UDYMEkc/d+ZX1f+la/rJDZJuKPlBm2U4d1ANQ2ZE77Iy92KdM4zSW/TjXjnsbo9TKRbtu9qIdzqEQifpaHyN4kWXsX77dqZXVnLFtrc48bvfkbdiBU2r7ua3jz9OV1cXl1xyCddcc83IHk5LdkPzIWg+DC2HoaUGWo9AWx20HoWOBm9qpT92CHJKPRMthtJZEC2CSBFECiFc4HXu4XwI5fXaoRwI5np2IGKeaTQYDMA4Vw5795xgLymuL8ln2wtHKKvMYdfLP4C8UupEKZ9Qxns3bKTzhRfI/Zu/4dWKcnY//TRTpkxh1apVTJo06cw/vLsZGnZC4y5o3OOZkwegrbavXCAKhVOgYArMugbyJ0L+JMir8EzuBMgt8zp707EbDIYRYlwrh9UvVJMCLp5USMeBkyQ6tuBoM+7sS8gNhbl6wwYSb6wn9sADPN3STPe+fVx//fVcdtllPe8DDIvuZji6GY5ugbqtcOwtbzSQJpQPE+bAjCugZBaUzITiGVA83ev4TadvMBjeYca1ckjkBimzLPKOJkhFWmmtfwl33kUkHIf37d5NatNmDn/qk2yoPUJ5eTmrVq1i4sSJp864rR4OvQKHX4XDr8GJPX6EeEpg2iWw/D6oOB/K53ujAqMADAbDOcS4Vg5fWrWEjx5s5fGvbyLVvZZERSUJC95z9CiBt7az8f6PcejYMS666CJuvPHGwa++dhKeIti/Fg4833PymnABVF4Kiz8IU5fB5CXe/L/BYDCc44xr5QDw1rpa1D1Id7CVRMlsFnR2kr9lK+vuuJ2OtjZuuukmli5dmp0wGYN9a2DXU7D3WW+bqB2G6ZfBBXdB1VUw8fxR20lwLqOquOri4r/rjOdPu3tsMt50TsvQ743mDPn+4ZnxmWG+J8OZnT6rzBkJBstnqDRDfRdvh+F8xjvBuVIOQzbl0XKKIiN/N9u4Vg6dLXH2bqgjHnuF+IwqSp0UE19/g3U3fQA7EOCvVq1i2rSMt4pcFw69DNse9ZRCvA2iJbDgJpj/fph5tbfrZxRIuSk6nU66kl10OV10O910J7vpdrqJpWLEnBjxVLyPSaQSPXbSTZJMJUm6SRzX8fy+23EdHHVIuSlSmsJxHVKa6vFnul11SWkKVc2yXVxcdUel/gaDYWC+culX+OC8D454vuNaOWx/6SjJ2FZiZYVgWUzftJmXr7+O/IIC7rnnHkpKSjzBzhOw9Rew+WFoPugtIC+8Gc6/A2ZcCfbwv0ZXXVrjrZzoPsHJ2EmaY800xZpoibfQGm/1TKKV9kR7j+lMdtLtdJ92/QJWgJAVImSHCFkhgnaQoBUkYAUIWr1u27IJS9hzi90TZolFQDy3LZ7fEivLLSI9ttDXbYnV1430vB2d6e9jZ8gAWeHSb499ZlifdAPIDRQ+kPxQ+fRLdEqGTD8M3m76kcK8+X1uMr9k/qjkO66Vw9R5EWKhPTgF06g8dIity5cxceJE7r77bvLy8qBxL7z+/+B/HvFOAVdeDtd8yRspBKMD5hlPxTnSdoTajlrqOuqo66ijvrOehq4Gjncdp7G7Ecd1stIJQn4on8JwIQWhAgpCBVTkVJAfyicvmEduMLfH5ARyiAaiRINRooEoETtCJBAhbIeJ2BHCgTAhK4Rt2agqjkJCXZKuklTFUSXpeuFpv6NKyk27IZUOw3N7xnO7gOv7XRS3j+3FaR+Z3jDNctMz6aNKT7hmyPTG9U5u9ExyZNx44U0x+e5+M0NZ6eg75TPYpMmQF1sMEjnYFMyZTMyMxmSOuf1ibBEtKOrzFvNIMa6Vw7pHHyNWMYmcji5qpk+ncto07l61inDTbnjqG7Dnae9g2JJVcPHHvZ1FPp3JTvY272Vf8z6qW6s50HKAQ22HaOhs6NM5hO0wk3InUZFTwfKJyymLllGWU0ZptJTSSClF4WJCwSKwculyod1J0Z5y6UilaE86tCQTtCbjNDkOHSmHru4UXakUXSmXuKvE3CRxTZBw20gqvhEc36QQ9Bz55XlKMu4kkqzuPF2LAbv5jBpqhtW3F5QBu9ozUQsDfe6ZpB8mpjc3DEFe0uU9xdeOeL7jWjmUXziTA5ua6M6JMGXSJO6+4RLCv/8Y7Py9d7L4qs/D8o+RiBayq2kX23b+nLca32Jn005q2mp6lEA0EGVW4SyWVixlWt50CnJnEAyVEyOHpqRLfTxGYzzBNsehtVtp74Qu16ZbXRLaBtJx6sKqg2gcceOIJkATSI9Jgib7uR2COITU8dM62LhYolhoj9sGbLQnXFAColiAJXiyApYIFt47sSL48uKnSct6cTYCot5UEool+FNCvizi3W5B2qT9faeMMqeBBprSGGgqaaD4/u5+QqdMOxQjNdVyrkwdGd59fKBs5ajkO66VQ+m+faBKeUkxqybuJfyjL0Iwh+SVD/A/c97LxqadbHjlc2xr3EbC9d52LsuZxqTiJVxUdhNJq5R2ojQ7QbalbF5LRog3R6ElfUAu7ts24oK43VipDiy3gxBxCiRJRFLkWi45tpJnCXkBizzbpiBgkx8IUBAIkR8MkBeIELJDROwIITuXkF3cZy2h/zpC2g5YgZ51A4PBYBgu41o5RP7seir+8CT3xh8k8dZxnj3/Rl4qLOG1hj/QVvdHnOBUcvMWQsWVOFYpHVJEo1XIToCkn4kbJ5A6SVRbmGDFKQ64lAUtKsJBJoejTM3JYVq0gPJoCQWhGRSEC8gJ5JjFvVMw/C2gIzXlYqZuDO9WBJHTuLFhmAxLOYjIDcB38GYVfqSqX+8XHwZ+BiwFTgJ3quohP+6LwH1ACvikqq4ZKk8RqQIeAUqALcA9qpp4e9UcmKkNj1Nh/ZiPVcxjU+RSklYVqXgVTvltpOxiAFoBcTvJdZuYLA1MDtQxIyzMygmwICfMzJwoeYEo6tq4bjzDdOK6zbhuAjeWRLsStKlDqyZR18HVBKopz7hJzyaFuilUHRTXj/feMFDSbtePcyFtq+ItE6sf3mv3uvHdCj2y2fP6fcMywxkgPDPMdw32ZoHpfA2GUWHevH9m6pQPjXi+p1QOImID/wlcD9QCG0VktaruzBC7D2hW1dkichfwDeBOEVkI3AWcB0wG1orIXD/NYHl+A/gPVX1ERP7Lz/v7I1HZ/tzrRthy4cMkA2VegKbIS9Uzxd3LND3KDKljtlXLRDmO2AlAvRFDEuiALmB7+nvql7c3457uEL3ZehHL1/C+7but9Ox7xnXTknF9tGTMznsfJAg2vc0nGVHep/adw5Y+ctnh/ZEsV/+l1yFTSjpN/7jTHS31XYIeGB2iNGfyaQbDu4uu1Oj85Q5n5HAxsF9VqwFE5BFgJZCpHFYCX/XdjwPfE2/eZCXwiKrGgYMist/Pj4HyFJFdwLVAWg3+1M93VJTDpcc7YPI+ZuvTzGIvVRwkZI/KIMVjkAfCeqI1c0+O+LJC7+/+3vcH0nt6st0DdaiZe3kGdmenGSjtwOEDBelQckNwZuOLkfnPYcY2hncjJ9tjzD212GkzHOUwBci4QpRa4JLBZFTVEZFWoNQPf6Nf2im+e6A8S4EWVXUGkO+DiNwP3A9QWVk5jGpkc2NoDte/tRfbLcTW92C712JpGEsDgIW4NqI2qIWoBWp7MzIpB005kEygTgKSCUjGIRH3wpIxSHQjiSSaiqPJhHf/khMHJ+n5UwnU98uInCoeaIunwWAY6wS+FPTmZkY632HIDPSzLHvGYGCZwcIHWj0ZSj47UPVB4EGAZcuWnVGPeOEHPzJQvmg8hdvl4Hb3Go357piDxlK97ngKN57y4uMpNJ5Ck6fZ2VsgtoAt3oNntoD/8Bm2H2/hbQ/1Z54QBUv9mSftMd46t+/3hypipe8ecnvHFek0GesRaN90vX6y4oTMw15u9qm0HlmPzDMG2ntqrd9ptWGsUfRbqNb+p92GkeaMZYb8kOEkffcq7rd7R5Rh9Mi7aMmo5Dsc5VALfQ7gTQXqBpGpFZEAUAg0nSLtQOEngCIRCfijh4E+a1QRESQSwIqc+UYuTSmaTKGJVK/CSLi4fpgmXDTpeu6kizq+23F7/Y76/hSk3Y6L6yg4LppyUe/IMuq4oO+CGfM+L2tmHHTwzzn0Ce8nN/CLmv1l+zj6LrFkLoaceqml3wcOLjeo1OnuRnunm+9d8OcyOoy9imuqfFTyHU4PuBGY4+8iOoq3wNx/aXw18GHgdeB24HlVVRFZDfxKRL6FtyA9B9iA10JZefpp1vl5POLn+fu3Wcd3HLEFsQMQCfBOnS5QV8FVNOV6CiOlXpjjZsQp6TsrNOV6P/jTcerZuOoNJtQfAaRl/Lst1A/L8uP73YyRRloubaXvx/DFe3ZBpU8z9wxiMk85DzE66CfX9wsZxqhi8PsvBmcYV26c9uDinf5VbgYBYworOjonEk6Zq7+G8HfAGrxJjodUdYeI/BOwSVVXAz8Gfu4vODfhdfb4co/hLV47wCdUvQeQB8rT/8jPA4+IyL8AW/28DadALAFLkMDI73c2GAzjDxkLc4nLli3TTZs2ne1iGAwGw7sKEdmsqssGijM/Mw0Gg8GQhVEOBoPBYMjCKAeDwWAwZGGUg8FgMBiyMMrBYDAYDFkY5WAwGAyGLIxyMBgMBkMWY+Kcg4g0AofPMPkEvGs7xhvjtd4wfutu6j2+GE69p6tq2UARY0I5vB1EZNNgh0DGMuO13jB+627qPb54u/U200oGg8FgyMIoB4PBYDBkYZSD/ybEOGS81hvGb91NvccXb6ve437NwWAwGAzZmJGDwWAwGLIwysFgMBgMWYxr5SAiN4jIHhHZLyJfONvlGS1EZJqIrBORXSKyQ0Q+5YeXiMhzIrLPt4vPdllHAxGxRWSriPy3768SkfV+vR8VkdDZLuNIIyJFIvK4iOz22/2y8dDeIvIZ/298u4j8WkQiY7W9ReQhETkuItszwgZsY/H4rt/XbRORi06V/7hVDiJiA/8J3AgsBP5SRBae3VKNGg7wWVVdAFwKfMKv6xeAP6nqHOBPvn8s8ilgV4b/G8B/+PVuBu47K6UaXb4DPKOq84EL8Oo/pttbRKYAnwSWqeoivFcm72LstvfDwA39wgZr4xvxnmmeA9wPfP9UmY9b5QBcDOxX1WpVTeC9Wb3yLJdpVFDVelXd4rvb8TqKKXj1/akv9lPglrNTwtFDRKYC7wd+5PsFuBZ43BcZc/UWkQLgvfhP7KpqQlVbGAftjff0cVREAkAOUM8YbW9VfQnvWeZMBmvjlcDP1OMNoEhEJg2V/3hWDlOAIxn+Wj9sTCMiM4AlwHqgQlXrwVMgQPnZK9mo8W3gc4AMsRQ2AAAC5UlEQVTr+0uBFlV1fP9YbPeZQCPwE3867UcikssYb29VPQp8E6jBUwqtwGbGfntnMlgbn3Z/N56VgwwQNqb39YpIHvBb4NOq2na2yzPaiMgHgOOqujkzeADRsdbuAeAi4PuqugToZIxNIQ2EP7++EqgCJgO5eNMp/Rlr7T0cTvvvfjwrh1pgWoZ/KlB3lsoy6ohIEE8x/FJVn/CDG9JDS98+frbKN0pcAdwsIofwpg2vxRtJFPnTDjA2270WqFXV9b7/cTxlMdbb+zrgoKo2qmoSeAK4nLHf3pkM1san3d+NZ+WwEZjj72QI4S1crT7LZRoV/Hn2HwO7VPVbGVGrgQ/77g8Dv3+nyzaaqOoXVXWqqs7Aa9/nVfVuYB1wuy82Fut9DDgiIvP8oPcBOxnj7Y03nXSpiOT4f/Ppeo/p9u7HYG28GrjX37V0KdCann4ajHF9QlpE/hzvl6QNPKSq/3qWizQqiMh7gJeBt+ide/8S3rrDY0Al3n+sO1S1/wLXmEBErgYeUNUPiMhMvJFECbAVWKWq8bNZvpFGRC7EW4QPAdXAR/B+DI7p9haRrwF34u3Q2wr8Nd7c+phrbxH5NXA13tXcDcA/Ak8yQBv7yvJ7eLubuoCPqOqmIfMfz8rBYDAYDAMznqeVDAaDwTAIRjkYDAaDIQujHAwGg8GQhVEOBoPBYMjCKAeDwWAwZGGUg8EwCojIjMzbMg2GdxtGORgMBoMhC6McDIZRRkRm+hfgLT/bZTEYhotRDgbDKOJfYfFbvBOpG892eQyG4RI4tYjBYDhDyvDutrlNVXec7cIYDKeDGTkYDKNHK94d+lec7YIYDKeLGTkYDKNHAu8lrjUi0qGqvzrbBTIYhotRDgbDKKKqnf6jQ8+JSKeqjuXrog1jCHMrq8FgMBiyMGsOBoPBYMjCKAeDwWAwZGGUg8FgMBiyMMrBYDAYDFkY5WAwGAyGLIxyMBgMBkMWRjkYDAaDIYv/D5KCWhB5pnF3AAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "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": [
    "# inner optimization\n",
    "T = 100\n",
    "\n",
    "inner_losses = []\n",
    "params_history = [[torch.zeros(d).requires_grad_(True)]]\n",
    "for t in range(T):\n",
    "    new_params = fp_map(params_history[-1], hparams)\n",
    "    params_history.append(new_params)\n",
    "\n",
    "    if t % 10 == 0 or t == T-1:\n",
    "        print(\"t={}: inner loss = {}\".format(t, inner_losses[-1]))\n",
    "\n",
    "\n",
    "plt.title('inner loss')\n",
    "plt.xlabel('t')\n",
    "plt.plot(inner_losses)\n",
    "plt.show()\n",
    "\n",
    "plt.title('params_history')\n",
    "plt.xlabel('t')\n",
    "plt.plot([tonp(p[0]) for p in params_history])\n",
    "plt.show()\n",
    "\n",
    "# hypergradients comparison\n",
    "K = T\n",
    "final_params = params_history[-1]\n",
    "for hg_name, hg_alg in (('reverse', hg.reverse),\n",
    "                        ('fixed_point', hg.fixed_point),\n",
    "                        ('CG', hg.CG)):\n",
    "    h_grads = []\n",
    "    for k in range(1, K):\n",
    "        if hg_name == 'reverse':\n",
    "            h_grad = hg.reverse(params_history[-k-1:], hparams, [fp_map]*k, val_loss)\n",
    "        else:\n",
    "            h_grad = hg_alg(final_params, hparams, k, fp_map, val_loss)\n",
    "\n",
    "        h_grads.append(tonp(h_grad[0]))\n",
    "\n",
    "    plt.title(hg_name + ' approx hypergradient')\n",
    "    plt.xlabel('k')\n",
    "    plt.plot(h_grads)\n",
    "    #plt.legend()\n",
    "    plt.show()\n",
    "\n",
    "# check that reverse K=T and reverse_unroll have same output\n",
    "h_grad_reverse_unroll = hg.reverse_unroll(params_history[-1], hparams, val_loss)\n",
    "h_grad_reverse = hg.reverse(params_history[-T-1:], hparams, [fp_map]*T, val_loss)\n",
    "h_grad_diff = torch.sum(h_grad_reverse_unroll[0] - h_grad_reverse[0]).item()\n",
    "print('reverse_unroll - reverse (should be 0):', h_grad_diff)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "#HPO\n",
    "import time\n",
    "outer_steps = 1000\n",
    "eval_interval = 10\n",
    "T, K = 100, 10\n",
    "\n",
    "hparams = [torch.ones(d).requires_grad_(True)]\n",
    "outer_opt = torch.optim.SGD(lr=1., momentum=.9, params=hparams)\n",
    "total_time, val_losses = 0,  []\n",
    "hparams_history = [tonp(hparams[0].clone())]\n",
    "for o_step in range(outer_steps):\n",
    "\n",
    "    step_start_time = time.time()\n",
    "\n",
    "    inner_losses = []\n",
    "    params_history = [[torch.zeros(d).requires_grad_(True)]]\n",
    "    for t in range(T):\n",
    "        new_params = fp_map(params_history[-1], hparams)\n",
    "        params_history.append(new_params)\n",
    "\n",
    "    t1 = time.time() - step_start_time # inner loop time \n",
    "    outer_opt.zero_grad()\n",
    "    #hg.reverse_unroll(params_history[-1], hparams, val_loss, set_grad=True)\n",
    "    hg.reverse(params_history[-K-1:], hparams, [fp_map]*(K), val_loss, set_grad=True)\n",
    "    #hg.CG(params_history[-1], hparams, K, fp_map, val_loss, set_grad=True)\n",
    "    #hg.fixed_point(params_history[-1], hparams, K, fp_map, val_loss, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 #hypergrad estimation time \n",
    "    outer_opt.step()\n",
    "    hparams[0].data.clamp_(min=1e-8)\n",
    "\n",
    "    step_time = time.time()-step_start_time # ~= t1 + t2\n",
    "    total_time +=step_time\n",
    "    hparams_history.append(tonp(hparams[0].clone()))\n",
    "\n",
    "    if o_step % eval_interval == 0 or o_step == outer_steps:\n",
    "        print('o_step={}({:.2e}s)({:.2e}, {:.2e}) val loss={} '.format(o_step, step_time, t1, t2, val_losses[-1]))\n",
    "\n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "plt.plot(val_losses)\n",
    "plt.show()\n",
    "\n",
    "plt.title('reg hparams')\n",
    "plt.xlabel('outer steps')\n",
    "plt.plot(hparams_history)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "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": [
    "# check test performance\n",
    "n_test = 1000\n",
    "x_test = np.random.randn(n_test, d)\n",
    "y_test = x_test  @ w_oracle + 0.1 * np.random.randn(n_test)\n",
    "y_test = (y_test > 0.).astype(float) # binary classification output\n",
    "x_test, y_test = frnp(x_test), frnp(y_test)\n",
    "\n",
    "test_losses = []\n",
    "for p in params_history:\n",
    "    test_losses.append(tonp(val_loss(p, hparams, x=x_test, y=y_test)))\n",
    "\n",
    "plt.title('test loss')\n",
    "plt.xlabel('outer steps')\n",
    "plt.plot(test_losses)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "def inner_solver(hparams, steps=100):\n",
    "\n",
    "    params = [torch.zeros(d).requires_grad_(True)]\n",
    "\n",
    "    for t in range(steps):\n",
    "        params = fp_map(params, hparams)\n",
    "\n",
    "    return params\n",
    "\n",
    "\n",
    "#HPO\n",
    "import time\n",
    "outer_steps = 600\n",
    "eval_interval = 10\n",
    "T, K = 100, 10\n",
    "mu = 0.05\n",
    "\n",
    "hparams = [torch.ones(d).requires_grad_(True)]\n",
    "#hparams = [torch.Tensor.uniform_(hparams[0], 0, 2).requires_grad_(True)]\n",
    "outer_opt = torch.optim.SGD(lr=1., momentum=.9, params=hparams)\n",
    "total_time, val_losses = 0,  []\n",
    "hparams_history = [tonp(hparams[0].clone())]\n",
    "for o_step in range(outer_steps):\n",
    "\n",
    "    step_start_time = time.time()\n",
    "\n",
    "    inner_losses = []\n",
    "    #params_history = [[torch.zeros(d).requires_grad_(True)]]\n",
    "\n",
    "    params = inner_solver(hparams, steps=T)\n",
    "    t1 = time.time() - step_start_time # inner loop time\n",
    "\n",
    "    outer_opt.zero_grad()\n",
    "\n",
    "    hg.ZeroOrderHypergradient(params, hparams, val_loss, inner_solver, mu=mu, T=T, set_grad=True)\n",
    "    t2 = time.time() - step_start_time - t1 # hypergrad estimation time \n",
    "\n",
    "    outer_opt.step()\n",
    "    hparams[0].data.clamp_(min=1e-8)\n",
    "\n",
    "    step_time = time.time()-step_start_time\n",
    "    total_time +=step_time\n",
    "    hparams_history.append(tonp(hparams[0].clone()))\n",
    "\n",
    "    if o_step % eval_interval == 0 or o_step == outer_steps:\n",
    "        #print('o_step={}({:.2e}s) val loss={} '.format(o_step, step_time, val_losses[-1]))\n",
    "        print('o_step={}({:.2e}s)({:.2e}, {:.2e}) val loss={} '.format(o_step, step_time, t1, t2, val_losses[-1]))\n",
    "\n",
    "print('total time = {}'.format(total_time))\n",
    "\n",
    "plt.title('validation loss')\n",
    "plt.xlabel('outer steps')\n",
    "plt.plot(val_losses)\n",
    "#plt.savefig('plots/val_loss2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "plt.title('reg hparams')\n",
    "plt.xlabel('outer steps')\n",
    "plt.plot(hparams_history)\n",
    "#plt.savefig('plots/hyperparams_history2.png', bbox_inches='tight')\n",
    "#plt.close()\n",
    "plt.show()\n",
    "\n",
    "\n"
   ]
  }
 ],
 "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
