{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "import torch.nn.functional as F"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.datasets import load_boston\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "dict_keys(['data', 'target', 'feature_names', 'DESCR', 'filename'])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "bos = load_boston()\n",
    "bos.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>CRIM</th>\n",
       "      <th>ZN</th>\n",
       "      <th>INDUS</th>\n",
       "      <th>CHAS</th>\n",
       "      <th>NOX</th>\n",
       "      <th>RM</th>\n",
       "      <th>AGE</th>\n",
       "      <th>DIS</th>\n",
       "      <th>RAD</th>\n",
       "      <th>TAX</th>\n",
       "      <th>PTRATIO</th>\n",
       "      <th>B</th>\n",
       "      <th>LSTAT</th>\n",
       "      <th>Price</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.00632</td>\n",
       "      <td>18.0</td>\n",
       "      <td>2.31</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.538</td>\n",
       "      <td>6.575</td>\n",
       "      <td>65.2</td>\n",
       "      <td>4.0900</td>\n",
       "      <td>1.0</td>\n",
       "      <td>296.0</td>\n",
       "      <td>15.3</td>\n",
       "      <td>396.90</td>\n",
       "      <td>4.98</td>\n",
       "      <td>24.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.02731</td>\n",
       "      <td>0.0</td>\n",
       "      <td>7.07</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.469</td>\n",
       "      <td>6.421</td>\n",
       "      <td>78.9</td>\n",
       "      <td>4.9671</td>\n",
       "      <td>2.0</td>\n",
       "      <td>242.0</td>\n",
       "      <td>17.8</td>\n",
       "      <td>396.90</td>\n",
       "      <td>9.14</td>\n",
       "      <td>21.6</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.02729</td>\n",
       "      <td>0.0</td>\n",
       "      <td>7.07</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.469</td>\n",
       "      <td>7.185</td>\n",
       "      <td>61.1</td>\n",
       "      <td>4.9671</td>\n",
       "      <td>2.0</td>\n",
       "      <td>242.0</td>\n",
       "      <td>17.8</td>\n",
       "      <td>392.83</td>\n",
       "      <td>4.03</td>\n",
       "      <td>34.7</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.03237</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.18</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.458</td>\n",
       "      <td>6.998</td>\n",
       "      <td>45.8</td>\n",
       "      <td>6.0622</td>\n",
       "      <td>3.0</td>\n",
       "      <td>222.0</td>\n",
       "      <td>18.7</td>\n",
       "      <td>394.63</td>\n",
       "      <td>2.94</td>\n",
       "      <td>33.4</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.06905</td>\n",
       "      <td>0.0</td>\n",
       "      <td>2.18</td>\n",
       "      <td>0.0</td>\n",
       "      <td>0.458</td>\n",
       "      <td>7.147</td>\n",
       "      <td>54.2</td>\n",
       "      <td>6.0622</td>\n",
       "      <td>3.0</td>\n",
       "      <td>222.0</td>\n",
       "      <td>18.7</td>\n",
       "      <td>396.90</td>\n",
       "      <td>5.33</td>\n",
       "      <td>36.2</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      CRIM    ZN  INDUS  CHAS    NOX     RM   AGE     DIS  RAD    TAX  \\\n",
       "0  0.00632  18.0   2.31   0.0  0.538  6.575  65.2  4.0900  1.0  296.0   \n",
       "1  0.02731   0.0   7.07   0.0  0.469  6.421  78.9  4.9671  2.0  242.0   \n",
       "2  0.02729   0.0   7.07   0.0  0.469  7.185  61.1  4.9671  2.0  242.0   \n",
       "3  0.03237   0.0   2.18   0.0  0.458  6.998  45.8  6.0622  3.0  222.0   \n",
       "4  0.06905   0.0   2.18   0.0  0.458  7.147  54.2  6.0622  3.0  222.0   \n",
       "\n",
       "   PTRATIO       B  LSTAT  Price  \n",
       "0     15.3  396.90   4.98   24.0  \n",
       "1     17.8  396.90   9.14   21.6  \n",
       "2     17.8  392.83   4.03   34.7  \n",
       "3     18.7  394.63   2.94   33.4  \n",
       "4     18.7  396.90   5.33   36.2  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df = pd.DataFrame(bos.data)\n",
    "df.columns = bos.feature_names\n",
    "df['Price'] = bos.target\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = df[df.columns[:-1]]\n",
    "data = data.apply(\n",
    "    lambda x: (x - x.mean()) / x.std()\n",
    ")\n",
    "\n",
    "data['Price'] = df.Price"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "X = data.drop('Price', axis=1).to_numpy()\n",
    "Y = data['Price'].to_numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(404, 13)\n",
      "(102, 13)\n",
      "(404,)\n",
      "(102,)\n"
     ]
    }
   ],
   "source": [
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "X_train, X_test, Y_train, Y_test = train_test_split(X, Y, test_size=0.2, random_state=42)\n",
    "print(X_train.shape)\n",
    "print(X_test.shape)\n",
    "print(Y_train.shape)\n",
    "print(Y_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_train = X_train.shape[0]\n",
    "X_train = torch.tensor(X_train, dtype=torch.float)\n",
    "X_test = torch.tensor(X_test, dtype=torch.float)\n",
    "Y_train = torch.tensor(Y_train, dtype=torch.float).view(-1, 1)\n",
    "Y_test = torch.tensor(Y_test, dtype=torch.float).view(-1, 1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([404, 13])\n",
      "torch.Size([102, 13])\n",
      "torch.Size([404, 1])\n",
      "torch.Size([102, 1])\n"
     ]
    }
   ],
   "source": [
    "print(X_train.shape)\n",
    "print(X_test.shape)\n",
    "print(Y_train.shape)\n",
    "print(Y_test.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def accuracy(model, data_x, data_y, pct_close):\n",
    "    n_items = len(data_y)\n",
    "    X = torch.Tensor(data_x)  # 2-d Tensor\n",
    "    Y = torch.Tensor(data_y)  # actual as 1-d Tensor\n",
    "    oupt = model(X)       # all predicted as 2-d Tensor\n",
    "    pred = oupt.view(n_items)  # all predicted as 1-d\n",
    "    n_correct = torch.sum((torch.abs(pred - Y) < torch.abs(pct_close * Y)))\n",
    "    result = (n_correct.item() * 100.0 / n_items)  # scalar\n",
    "    return result "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Net(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super(Net, self).__init__()\n",
    "        self.hid1 = torch.nn.Linear(13, 10)  # 13-(10-10)-1\n",
    "        self.hid2 = torch.nn.Linear(10,10)\n",
    "        self.oupt = torch.nn.Linear(10, 1)\n",
    "        self.dropout= torch.nn.Dropout(p=0.1)\n",
    "        #torch.nn.init.xavier_uniform_(self.hid1.weight)  # glorot\n",
    "        #torch.nn.init.zeros_(self.hid1.bias)\n",
    "        #torch.nn.init.xavier_uniform_(self.hid2.weight)\n",
    "        #torch.nn.init.zeros_(self.hid2.bias)\n",
    "        #torch.nn.init.xavier_uniform_(self.oupt.weight)\n",
    "        #torch.nn.init.zeros_(self.oupt.bias)\n",
    "    def forward(self, x):\n",
    "        x = F.relu(self.hid1(x))\n",
    "        x = F.relu(self.hid2(x))\n",
    "        x = F.relu(self.oupt(x))  # no activation, aka Identity()\n",
    "        return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Boston regression using PyTorch \n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\"\\nBoston regression using PyTorch \\n\")\n",
    "torch.manual_seed(1)  \n",
    "np.random.seed(1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Creating 13-(10-10)-1 DNN regression model \n",
      "\n"
     ]
    }
   ],
   "source": [
    "print(\"Creating 13-(10-10)-1 DNN regression model \\n\")\n",
    "net = Net()  # all work done above"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "#import torch\n",
    "from torch.optim.optimizer import Optimizer, required\n",
    "import math\n",
    "\n",
    "\n",
    "class SPPA(Optimizer):\n",
    "  \n",
    "    def __init__(self, params, lr=required, weight_decay=1):\n",
    "        if lr is not required and lr < 0.0:\n",
    "            raise ValueError(\"Invalid learning rate: {}\".format(lr))\n",
    "        if weight_decay < 0.0:\n",
    "            raise ValueError(\"Invalid weight_decay value: {}\".format(weight_decay))\n",
    "\n",
    "        defaults = dict(lr=lr,weight_decay=weight_decay)\n",
    "        \n",
    "        super(SPPA, self).__init__(params, defaults)\n",
    "\n",
    "    def __setstate__(self, state):\n",
    "        super(SPPA, self).__setstate__(state)\n",
    "  \n",
    "\n",
    "    @torch.no_grad()\n",
    "    def step(self, closure,e):\n",
    "        \"\"\"Performs a single optimization step.\n",
    "        Arguments:\n",
    "            closure (callable, optional): A closure that reevaluates the model\n",
    "                and returns the loss.\n",
    "        \"\"\"\n",
    "        # Make sure the closure is always called with grad enabled\n",
    "        closure = torch.enable_grad()(closure)\n",
    "        #closure2 = torch.enable_grad()(closure2)\n",
    "        t=2\n",
    "        for group in self.param_groups:\n",
    "            lr = group['lr']\n",
    "            for p in group['params']:\n",
    "                #print('Shape of Parameters', p.shape)\n",
    "                if p.grad is None:\n",
    "                    continue\n",
    "                d_p = p.grad              \n",
    "                previous = p\n",
    "                \n",
    "                for k in range(5): #till convergence of the inner optimization problem\n",
    "                    #print(\"weight decay \",weight_decay)\n",
    "                    #orig_loss = closure()\n",
    "                    #func_value = closure2()\n",
    "                    if (weight_decay == 1): #1 denotes 1/t decay\n",
    "                    #    print(\"wd is one\")\n",
    "                        lr= 1.0 / 10*(e+1)\n",
    "                    if weight_decay == 2: #2 denotes 1/sqrt t decay \n",
    "                        lr= 1.0 / 10*math.sqrt(e+1)\n",
    "                    if p.grad is None:\n",
    "                        continue\n",
    "                    d_p = p.grad\n",
    "                    orig_loss, func_value = closure()\n",
    "                    if func_value==0:\n",
    "                        continue\n",
    "                    #numerator = func_value - torch.matmul(d_p.view(1,d_p.shape[0]*d_p.shape[1]),(p.data-previous).view(d_p.shape[0]*d_p.shape[1],1))\n",
    "                    #numerator = func_value - torch.matmul(d_p.flatten(),(p-previous).flatten())\n",
    "                    numerator = orig_loss - torch.matmul(d_p.flatten(),(p-previous).flatten())\n",
    "                    denominator= 1.0/lr +torch.matmul(d_p.flatten(),d_p.flatten())\n",
    "                    '''\n",
    "                    print('Multip ',torch.flatten((p-previous)).shape)\n",
    "                    print('Gradient ', d_p.flatten().shape)\n",
    "                    \n",
    "                    print('Previous theta ', previous.shape)\n",
    "                   \n",
    "                    \n",
    "                    \n",
    "                    print('Scalar ', numerator/denominator )\n",
    "                     \n",
    "                    '''\n",
    "                    #print('Function value ',func_value)\n",
    "                    #print('Numerator ',numerator[0].item())\n",
    "                    #print('Denominator ',denominator.item())\n",
    "                    #print('Alpha',(-1.0)*numerator[0].item()/denominator.item())\n",
    "                    #print('Before p : ', p.data)\n",
    "                    p.data=torch.add(input=previous, other=d_p, alpha=(-1.0)*numerator.item()/denominator.item())\n",
    "                    #p.data.add_(other=d_p, alpha=(-1.0)*numerator[0].item()/denominator.item() )\n",
    "                    #print('After p : ', p.data)\n",
    "                #print('For loop ended.')\n",
    "                #p.add_(d_p, alpha=-group['lr'])\n",
    "\n",
    "        return loss"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "device(type='cpu')"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "device"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_batch = np.array_split(X_train, 404)\n",
    "label_batch = np.array_split(Y_train, 404)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "404"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(train_batch)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial loss  14.831270217895508\n",
      "Epoch: 1/20..  Training Loss: 1.150.. \n",
      "Epoch: 2/20..  Training Loss: 0.081.. \n",
      "Epoch: 3/20..  Training Loss: 0.060.. \n",
      "Epoch: 4/20..  Training Loss: 0.049.. \n",
      "Epoch: 5/20..  Training Loss: 0.043.. \n",
      "Epoch: 6/20..  Training Loss: 0.040.. \n",
      "Epoch: 7/20..  Training Loss: 0.038.. \n",
      "Epoch: 8/20..  Training Loss: 0.036.. \n",
      "Epoch: 9/20..  Training Loss: 0.035.. \n",
      "Epoch: 10/20..  Training Loss: 0.034.. \n",
      "Epoch: 11/20..  Training Loss: 0.033.. \n",
      "Epoch: 12/20..  Training Loss: 0.032.. \n",
      "Epoch: 13/20..  Training Loss: 0.032.. \n",
      "Epoch: 14/20..  Training Loss: 0.031.. \n",
      "Epoch: 15/20..  Training Loss: 0.031.. \n",
      "Epoch: 16/20..  Training Loss: 0.031.. \n",
      "Epoch: 17/20..  Training Loss: 0.030.. \n",
      "Epoch: 18/20..  Training Loss: 0.030.. \n",
      "Epoch: 19/20..  Training Loss: 0.030.. \n",
      "Epoch: 20/20..  Training Loss: 0.029.. \n"
     ]
    }
   ],
   "source": [
    "torch.manual_seed(1)\n",
    "model = Net()\n",
    "criterion = torch.nn.MSELoss()\n",
    "optimizer = torch.optim.SGD(model.parameters(),  lr=0.001, momentum=0.9)\n",
    "epochs = 20\n",
    "\n",
    "train_losses = []\n",
    "\n",
    "for e in range(epochs):\n",
    "    model.train()\n",
    "    train_loss = 0\n",
    "    for i in range(len(train_batch)):\n",
    "        optimizer.zero_grad()\n",
    "        train_batch[i]=train_batch[i].cpu()\n",
    "        label_batch[i]=label_batch[i].cpu()\n",
    "        output = model(train_batch[i])\n",
    "        #loss = torch.sqrt(criterion(torch.log(output), torch.log(label_batch[i])))\n",
    "        loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "        if (i==0  and e==0):#Append the initial loss\n",
    "            train_losses.append(loss.item())\n",
    "            print('Initial loss ',train_losses[i])\n",
    "\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        \n",
    "        train_loss += loss.item()\n",
    "        \n",
    "    else:\n",
    "        test_loss = 0\n",
    "        accuracy = 0\n",
    "        '''\n",
    "        with torch.no_grad():\n",
    "            model.eval()\n",
    "            predictions = model(X_val)\n",
    "            test_loss += torch.sqrt(criterion(torch.log(predictions), torch.log(y_val)))\n",
    "        '''        \n",
    "        train_losses.append(train_loss/len(train_batch))\n",
    "        #test_losses.append(test_loss)\n",
    "\n",
    "        print(\"Epoch: {}/{}.. \".format(e+1, epochs),\n",
    "              \"Training Loss: {:.3f}.. \".format(train_loss/len(train_batch)),\n",
    "              )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial loss  14.831270217895508\n",
      "Epoch: 1/20..  Training Loss: 5.739.. \n",
      "Epoch: 2/20..  Training Loss: 1.698.. \n",
      "Epoch: 3/20..  Training Loss: 0.746.. \n",
      "Epoch: 4/20..  Training Loss: 0.401.. \n",
      "Epoch: 5/20..  Training Loss: 0.251.. \n",
      "Epoch: 6/20..  Training Loss: 0.179.. \n",
      "Epoch: 7/20..  Training Loss: 0.140.. \n",
      "Epoch: 8/20..  Training Loss: 0.119.. \n",
      "Epoch: 9/20..  Training Loss: 0.105.. \n",
      "Epoch: 10/20..  Training Loss: 0.096.. \n",
      "Epoch: 11/20..  Training Loss: 0.090.. \n",
      "Epoch: 12/20..  Training Loss: 0.085.. \n",
      "Epoch: 13/20..  Training Loss: 0.082.. \n",
      "Epoch: 14/20..  Training Loss: 0.078.. \n",
      "Epoch: 15/20..  Training Loss: 0.076.. \n",
      "Epoch: 16/20..  Training Loss: 0.073.. \n",
      "Epoch: 17/20..  Training Loss: 0.071.. \n",
      "Epoch: 18/20..  Training Loss: 0.069.. \n",
      "Epoch: 19/20..  Training Loss: 0.067.. \n",
      "Epoch: 20/20..  Training Loss: 0.065.. \n"
     ]
    }
   ],
   "source": [
    "torch.manual_seed(1)\n",
    "model = Net()\n",
    "criterion = torch.nn.MSELoss()\n",
    "optimizer = torch.optim.SGD(model.parameters(),  lr=0.001)\n",
    "epochs = 20\n",
    "\n",
    "train_losses2 = []\n",
    "\n",
    "for e in range(epochs):\n",
    "    model.train()\n",
    "    train_loss = 0\n",
    "    for i in range(len(train_batch)):\n",
    "        optimizer.zero_grad()\n",
    "        train_batch[i]=train_batch[i].cpu()\n",
    "        label_batch[i]=label_batch[i].cpu()\n",
    "        output = model(train_batch[i])\n",
    "        #loss = torch.sqrt(criterion(torch.log(output), torch.log(label_batch[i])))\n",
    "        loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "        if (i==0  and e==0):#Append the initial loss\n",
    "            train_losses2.append(loss.item())\n",
    "            print('Initial loss ',train_losses2[i])\n",
    "\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        \n",
    "        train_loss += loss.item()\n",
    "        \n",
    "    else:\n",
    "        test_loss = 0\n",
    "        accuracy = 0\n",
    "        '''\n",
    "        with torch.no_grad():\n",
    "            model.eval()\n",
    "            predictions = model(X_val)\n",
    "            test_loss += torch.sqrt(criterion(torch.log(predictions), torch.log(y_val)))\n",
    "        '''        \n",
    "        train_losses2.append(train_loss/len(train_batch))\n",
    "        #test_losses.append(test_loss)\n",
    "\n",
    "        print(\"Epoch: {}/{}.. \".format(e+1, epochs),\n",
    "              \"Training Loss: {:.3f}.. \".format(train_loss/len(train_batch)),\n",
    "              )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial loss  14.831270217895508\n",
      "Epoch: 1/20..  Training Loss: 0.730.. \n",
      "Epoch: 2/20..  Training Loss: 0.155.. \n",
      "Epoch: 3/20..  Training Loss: 0.114.. \n",
      "Epoch: 4/20..  Training Loss: 0.096.. \n",
      "Epoch: 5/20..  Training Loss: 0.085.. \n",
      "Epoch: 6/20..  Training Loss: 0.078.. \n",
      "Epoch: 7/20..  Training Loss: 0.072.. \n",
      "Epoch: 8/20..  Training Loss: 0.068.. \n",
      "Epoch: 9/20..  Training Loss: 0.065.. \n",
      "Epoch: 10/20..  Training Loss: 0.063.. \n",
      "Epoch: 11/20..  Training Loss: 0.061.. \n",
      "Epoch: 12/20..  Training Loss: 0.059.. \n",
      "Epoch: 13/20..  Training Loss: 0.058.. \n",
      "Epoch: 14/20..  Training Loss: 0.056.. \n",
      "Epoch: 15/20..  Training Loss: 0.055.. \n",
      "Epoch: 16/20..  Training Loss: 0.054.. \n",
      "Epoch: 17/20..  Training Loss: 0.053.. \n",
      "Epoch: 18/20..  Training Loss: 0.052.. \n",
      "Epoch: 19/20..  Training Loss: 0.052.. \n",
      "Epoch: 20/20..  Training Loss: 0.051.. \n"
     ]
    }
   ],
   "source": [
    "torch.manual_seed(1)\n",
    "model = Net()\n",
    "model.to(device)\n",
    "\n",
    "criterion = torch.nn.MSELoss()\n",
    "weight_decay=0\n",
    "optimizer = SPPA(model.parameters(),  lr=0.001, weight_decay=0)\n",
    "epochs = 20\n",
    "\n",
    "train_losses_SPPA_lr001 = []\n",
    "\n",
    "for e in range(epochs):\n",
    "    model.train()\n",
    "    train_loss = 0\n",
    "    for i in range(len(train_batch)):\n",
    "        def closure():\n",
    "            optimizer.zero_grad()\n",
    "            #train_batch[i]=train_batch[i].cuda()\n",
    "            #label_batch[i]=label_batch[i].cuda()\n",
    "            output = model(train_batch[i])\n",
    "            loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "            loss.backward()\n",
    "            return loss, output\n",
    "            \n",
    "        optimizer.zero_grad()\n",
    "        #train_batch[i]=train_batch[i].cuda()\n",
    "        #label_batch[i]=label_batch[i].cuda()\n",
    "        output = model(train_batch[i])\n",
    "        \n",
    "        loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "\n",
    "        if (i==0 and e==0):#Append the initial loss\n",
    "            train_losses_SPPA_lr001.append(loss.item())\n",
    "            print('Initial loss ',train_losses_SPPA_lr001[i])\n",
    "        loss.backward()\n",
    "        optimizer.step(closure,e)\n",
    "        \n",
    "        train_loss += loss.item()\n",
    "        \n",
    "    else:\n",
    "        test_loss = 0  \n",
    "        train_losses_SPPA_lr001.append(train_loss/len(train_batch))\n",
    "        print(\"Epoch: {}/{}.. \".format(e+1, epochs),\n",
    "              \"Training Loss: {:.3f}.. \".format(train_loss/len(train_batch)),\n",
    "              )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial loss  14.831270217895508\n",
      "Epoch: 1/20..  Training Loss: 0.307.. \n",
      "Epoch: 2/20..  Training Loss: 0.067.. \n",
      "Epoch: 3/20..  Training Loss: 0.055.. \n",
      "Epoch: 4/20..  Training Loss: 0.050.. \n",
      "Epoch: 5/20..  Training Loss: 0.047.. \n",
      "Epoch: 6/20..  Training Loss: 0.044.. \n",
      "Epoch: 7/20..  Training Loss: 0.043.. \n",
      "Epoch: 8/20..  Training Loss: 0.040.. \n",
      "Epoch: 9/20..  Training Loss: 0.039.. \n",
      "Epoch: 10/20..  Training Loss: 0.038.. \n",
      "Epoch: 11/20..  Training Loss: 0.037.. \n",
      "Epoch: 12/20..  Training Loss: 0.035.. \n",
      "Epoch: 13/20..  Training Loss: 0.034.. \n",
      "Epoch: 14/20..  Training Loss: 0.033.. \n",
      "Epoch: 15/20..  Training Loss: 0.032.. \n",
      "Epoch: 16/20..  Training Loss: 0.032.. \n",
      "Epoch: 17/20..  Training Loss: 0.032.. \n",
      "Epoch: 18/20..  Training Loss: 0.031.. \n",
      "Epoch: 19/20..  Training Loss: 0.031.. \n",
      "Epoch: 20/20..  Training Loss: 0.031.. \n"
     ]
    }
   ],
   "source": [
    "torch.manual_seed(1)\n",
    "model = Net()\n",
    "model.to(device)\n",
    "\n",
    "criterion = torch.nn.MSELoss()\n",
    "weight_decay=2\n",
    "optimizer = SPPA(model.parameters(),  lr=0.001, weight_decay=2)\n",
    "epochs = 20\n",
    "\n",
    "train_losses_SPPA_lr2 = []\n",
    "\n",
    "for e in range(epochs):\n",
    "    model.train()\n",
    "    train_loss = 0\n",
    "    for i in range(len(train_batch)):\n",
    "        def closure():\n",
    "            optimizer.zero_grad()\n",
    "            #train_batch[i]=train_batch[i].cuda()\n",
    "            #label_batch[i]=label_batch[i].cuda()\n",
    "            output = model(train_batch[i])\n",
    "            loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "            loss.backward()\n",
    "            return loss, output\n",
    "            \n",
    "        optimizer.zero_grad()\n",
    "        #train_batch[i]=train_batch[i].cuda()\n",
    "        #label_batch[i]=label_batch[i].cuda()\n",
    "        output = model(train_batch[i])\n",
    "        \n",
    "        loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "\n",
    "        if (i==0 and e==0):#Append the initial loss\n",
    "            train_losses_SPPA_lr2.append(loss.item())\n",
    "            print('Initial loss ',train_losses_SPPA_lr2[i])\n",
    "        loss.backward()\n",
    "        optimizer.step(closure,e)\n",
    "        \n",
    "        train_loss += loss.item()\n",
    "        \n",
    "    else:\n",
    "        test_loss = 0  \n",
    "        train_losses_SPPA_lr2.append(train_loss/len(train_batch))\n",
    "        print(\"Epoch: {}/{}.. \".format(e+1, epochs),\n",
    "              \"Training Loss: {:.3f}.. \".format(train_loss/len(train_batch)),\n",
    "              )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial loss  14.831270217895508\n",
      "Epoch: 1/20..  Training Loss: 0.307.. \n",
      "Epoch: 2/20..  Training Loss: 0.067.. \n",
      "Epoch: 3/20..  Training Loss: 0.056.. \n",
      "Epoch: 4/20..  Training Loss: 0.051.. \n",
      "Epoch: 5/20..  Training Loss: 0.046.. \n",
      "Epoch: 6/20..  Training Loss: 0.043.. \n",
      "Epoch: 7/20..  Training Loss: 0.042.. \n",
      "Epoch: 8/20..  Training Loss: 0.040.. \n",
      "Epoch: 9/20..  Training Loss: 0.039.. \n",
      "Epoch: 10/20..  Training Loss: 0.038.. \n",
      "Epoch: 11/20..  Training Loss: 0.036.. \n",
      "Epoch: 12/20..  Training Loss: 0.035.. \n",
      "Epoch: 13/20..  Training Loss: 0.035.. \n",
      "Epoch: 14/20..  Training Loss: 0.034.. \n",
      "Epoch: 15/20..  Training Loss: 0.034.. \n",
      "Epoch: 16/20..  Training Loss: 0.033.. \n",
      "Epoch: 17/20..  Training Loss: 0.035.. \n",
      "Epoch: 18/20..  Training Loss: 0.035.. \n",
      "Epoch: 19/20..  Training Loss: 0.035.. \n",
      "Epoch: 20/20..  Training Loss: 0.036.. \n"
     ]
    }
   ],
   "source": [
    "torch.manual_seed(1)\n",
    "model = Net()\n",
    "model.to(device)\n",
    "\n",
    "criterion = torch.nn.MSELoss()\n",
    "weight_decay=1\n",
    "optimizer = SPPA(model.parameters(),  lr=0.001, weight_decay=1)\n",
    "epochs = 20\n",
    "\n",
    "train_losses_SPPA_lr = []\n",
    "\n",
    "for e in range(epochs):\n",
    "    model.train()\n",
    "    train_loss = 0\n",
    "    for i in range(len(train_batch)):\n",
    "        def closure():\n",
    "            optimizer.zero_grad()\n",
    "            #train_batch[i]=train_batch[i].cuda()\n",
    "            #label_batch[i]=label_batch[i].cuda()\n",
    "            output = model(train_batch[i])\n",
    "            loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "            loss.backward()\n",
    "            return loss, output\n",
    "            \n",
    "        optimizer.zero_grad()\n",
    "        #train_batch[i]=train_batch[i].cuda()\n",
    "        #label_batch[i]=label_batch[i].cuda()\n",
    "        output = model(train_batch[i])\n",
    "        \n",
    "        loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "\n",
    "        if (i==0 and e==0):#Append the initial loss\n",
    "            train_losses_SPPA_lr.append(loss.item())\n",
    "            print('Initial loss ',train_losses_SPPA_lr[i])\n",
    "        loss.backward()\n",
    "        optimizer.step(closure,e)\n",
    "        \n",
    "        train_loss += loss.item()\n",
    "        \n",
    "    else:\n",
    "        test_loss = 0  \n",
    "        train_losses_SPPA_lr.append(train_loss/len(train_batch))\n",
    "        print(\"Epoch: {}/{}.. \".format(e+1, epochs),\n",
    "              \"Training Loss: {:.3f}.. \".format(train_loss/len(train_batch)),\n",
    "              )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Initial loss  14.831270217895508\n",
      "Epoch: 1/20..  Training Loss: 7.906.. \n",
      "Epoch: 2/20..  Training Loss: 1.032.. \n",
      "Epoch: 3/20..  Training Loss: 0.240.. \n",
      "Epoch: 4/20..  Training Loss: 0.113.. \n",
      "Epoch: 5/20..  Training Loss: 0.087.. \n",
      "Epoch: 6/20..  Training Loss: 0.075.. \n",
      "Epoch: 7/20..  Training Loss: 0.065.. \n",
      "Epoch: 8/20..  Training Loss: 0.058.. \n",
      "Epoch: 9/20..  Training Loss: 0.052.. \n",
      "Epoch: 10/20..  Training Loss: 0.047.. \n",
      "Epoch: 11/20..  Training Loss: 0.043.. \n",
      "Epoch: 12/20..  Training Loss: 0.040.. \n",
      "Epoch: 13/20..  Training Loss: 0.038.. \n",
      "Epoch: 14/20..  Training Loss: 0.036.. \n",
      "Epoch: 15/20..  Training Loss: 0.034.. \n",
      "Epoch: 16/20..  Training Loss: 0.033.. \n",
      "Epoch: 17/20..  Training Loss: 0.031.. \n",
      "Epoch: 18/20..  Training Loss: 0.030.. \n",
      "Epoch: 19/20..  Training Loss: 0.029.. \n",
      "Epoch: 20/20..  Training Loss: 0.028.. \n"
     ]
    }
   ],
   "source": [
    "torch.manual_seed(1)\n",
    "model_adam = Net()\n",
    "criterion = torch.nn.MSELoss()\n",
    "optimizer = torch.optim.Adam(model_adam.parameters(), lr=0.001)\n",
    "epochs = 20\n",
    "\n",
    "train_losses_adam = []\n",
    "for e in range(epochs):\n",
    "    model_adam.train()\n",
    "    train_loss = 0\n",
    "    for i in range(len(train_batch)):\n",
    "        optimizer.zero_grad()\n",
    "        output = model_adam(train_batch[i])\n",
    "        #loss = torch.sqrt(criterion(torch.log(output), torch.log(label_batch[i])))\n",
    "        loss = criterion(torch.log(output), torch.log(label_batch[i]))\n",
    "        if (i==0 and e==0):#Append the initial loss\n",
    "            train_losses_adam.append(loss.item())\n",
    "            print('Initial loss ',train_losses_adam[i])\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "        \n",
    "        train_loss += loss.item()\n",
    "        \n",
    "    else:\n",
    "        test_loss = 0\n",
    "        accuracy = 0\n",
    "    \n",
    "        train_losses_adam.append(train_loss/len(train_batch))\n",
    "\n",
    "        print(\"Epoch: {}/{}.. \".format(e+1, epochs),\n",
    "              \"Training Loss: {:.3f}.. \".format(train_loss/len(train_batch)),\n",
    "              )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "X=[]\n",
    "for i in range(len(train_losses_SPPA_lr001[:5])):\n",
    "    X.append(i)\n",
    "\n",
    "plt.figure(figsize=((12,9)))\n",
    "\n",
    "plt.plot(X, train_losses_SPPA_lr001[:5], label=\"SPPA-GN (lr=0.01)\",linewidth=2.5, color=\"purple\")\n",
    "#plt.plot(X, train_losses_SPPA_lr[:5], label=\"SPPA-GN (1/t)\",linewidth=2.5, color=\"red\")\n",
    "plt.plot(X, train_losses_SPPA_lr2[:5], label=\"SPPA-GN (1/sqrt(t))\",linewidth=2.5, color=\"red\")\n",
    "plt.plot(X, train_losses_adam[:5], label=\"Adam\",linewidth=2.5, color=\"darkorange\")\n",
    "plt.plot(X, train_losses[:5], label=\"SGD with Momentum \",linewidth=2.5, color=\"blue\" )\n",
    "plt.plot(X, train_losses2[:5], label=\"SGD \",linewidth=2.5, color=\"green\" )\n",
    "plt.xticks(fontsize=26)\n",
    "plt.yticks(fontsize=26)\n",
    "\n",
    "plt.title(\"Boston House Prices Dataset \\n Regression\",fontsize=26)\n",
    "plt.xlabel(\"Epoch (Batch Size 1) \", fontsize=26)\n",
    "plt.ylabel(\"MSE Loss\", fontsize=26)\n",
    "plt.grid(linestyle=\"--\")\n",
    "plt.legend(fontsize=18)\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"BostonSPPA.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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eeSRoFHsfHGN2AXa66s8vPfee7Ro0cJLFxFhzpw5jB07loULF7JixQqefPJJJkyYwHPPPVduh9CT5OTkctfxPN9GjRqVu75LJ38REoPlRRunSxTBmKVGjRrUbRAHOY2g2PKXd2gkwbAR6FcfJTyovs6i+jqHaussqq+z+I5yiAiZmZkA7uAkTvHWW2+Rl5fHpEmTmDdvXql03nnnMXv2bHfAgQceeIDFixd7JdcD+KBBgwBr4+DK0rt3by6//HJeeeUVd7CZUHBNk3QFT4HS+oZCcXExH330EX/84x/95nfu3Jn777+fjz76iF27dpGens7YsWPd+S1atCArK8sduMHFrl27vAI8hEKwQQl/5xtKPRebN28mMTHR7+hZsDwXFdE2EsTyCNZG4KwyyjwCXAH8BrjiTVb+J4iTSPfu3TnULAtMHGSfAalb7b2w1MEKB/72CVHCT6ehCgAAIABJREFUh+rrLKqvc6i2zqL6OsPixYvp27cv1atX9zqen5/PokWLAOc3eZ4xYwb16tXjnnvuIS4urlR+dnY2I0aMYP78+QwcOJCOHTsG3G9p5MiRvPTSS0ycOJFu3br5DdVenqlsEydOZOHChTz44IMh10lLS6Nt27Z89dVX7mO++obC8uXLOXDggNf0QLBGderUqePlvKSmppKens62bdsoKCggMTGRAQMGMHnyZObMmcOQIUPcZSdNmlRuW1w/cBw8eLDUesjevXsD8NVXX5VyBoPVc/HVV19x9tlnU61atXLluaiItpEgZh0sY0w+8G2wMiLicqYKjDFBy56qfPnll6S1tn/pO5xuOVgngLw9kH8QqlVsEaJi8eWXX9KjR49ImxGzqL7Oovo6h2rrLKqvM9x1110cOHCASy+9lK5du5KcnMyuXbuYO3cuWVlZDB06lM6dOzvW//fff8/q1asZMWKEX+cKYMCAAdx8883MmDGjlLPhS/Xq1VmwYAH9+/dnwIAB9O3bl379+tGwYUOys7P56aefePvtt4mLi/OaQhiITp06MWTIEF5//fVyndfVV1/NxIkT2bt3Lw0aNCA3N9ftbHzwwQfusPZbt27FGONep5aamsptt90GWNMD69evz/nnn+/V9syZM3n++ecZOHAgGRkZJCQksGTJEv773/8yePBg93q5sWPH8tZbb3HjjTfy9ddf065dO5YsWcLXX39d7oAU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4osvZu/evQC8++675ObmEhsby+DBg3nllVeCG4IQhkiBZXPTp0+37qfEOFpXNpYNt55r6SQo12EFonW+IvgkX7MkX3MkW7MkX7Pi4+N59dVXiY+P55prriE9PZ0rrriC119/nebmZrexP/rRj3jggQc466yzePLJJ7nqqqtYuHAhq1ev9njf9evXs3HjRq644gqeeuopfvWrXxEZGcltt93Gr3/9a69zWbBgATt37uSBBx7gJz/5Cf/85z/55je/yfLly1m4cCFXXXUVTz31FCkpKdx+++22WD4aHx/f3VMIWXbJNqK7JyC6ZteuXYwfPx6A1Ph6KMdzLyxwNLoYfvUZn5/dtc5XBJ/ka5bka45ka1aPyXfd3VC0o7tn4SnzHLjo2YBfXlpayooVK7jmmmuspgELFizgvffe4+9//zuXXXYZAHv37uX5559n5syZrFmzhvDwcACuvvpq8vLyPN53/vz5fP/733d77p577mHmzJk8/vjj/OQnP/HYKDYrK4vVq1ejlOO68fT0dH74wx+ycOFCdu3axcCBjuvKr7vuOgYOHMiLL77I1KlTA/7ez4Samhri4uK6exohyS7ZSoFlc8XFxdb91ORmOAJUDESh0GgKIhKASiiWRheBaJ2vCD7J1yzJ1xzJ1qwek2/RDijc0N2zCLr33nuPsrIyFixYYD33n//5n2RkZPDaa69ZBdaqVavQWvOjH/3IKq7A0eXxkksuYc2aNW7v27rDW21tLadPn0ZrzaWXXsqGDRvYs2ePR+F81113WcUVwLRp0wCYNWuWVVwBZGRkMHLkSPbv3x+EBMxqamrq7imELLtkKwVWCEnvGw67gKYoklUWpfoY+RHx0FQprdqFEEIIf2We090z8K6L81q+fDkZGRkMGDCAf//739bzl156KW+//TanTp0iPT3danoxatQoj/cYM2aMR4FVVVXFww8/zJ///GcOHz7s8ZrS0lKP54YOHer2OCUlBYAhQ4Z4jE1JSaGgoMCH71CI7iUFls3l5ORY9zMGxFj3k+qzKY08Rr7rMrvSPdDcBGHhbd9CdKB1viL4JF+zJF9zJFuzeky+XViG11MdPHiQjRs3orVmxIgRXse88cYb3H333X6/99y5c3n//ff53ve+x/Tp00lLSyM8PJwPPviAZ555xuP6LsDtzJgvz2utvT7fk8TGxnb3FEKWXbKVAsvmKisrrX/tyRrecuFfXEUWpEF+fQ2EA421UFEAyUPbeSfhTet8RfBJvmZJvuZItmZJvuYsXboUrTW///3vSU5O9jj+4IMP8tprr3H33XdbZ5f27NnDsGHD3Mbt3u2+MqasrIz333+f+fPn8/LLL7sd++ijj4L8XfRsTU1NRETIr9gm2CVb6SJoc633rEgZnkY0tQBElGQBcKS2nMbWjS6EX2RPELMkX7MkX3MkW7MkXzOam5tZtmwZY8eO5dZbb+Xb3/62x5/rr7+eL7/8ks8//5xZs2ahlOLpp592u/Zl+/btHkWT64xT2zNMx44d89qmPZTV19d39xRCll2ylQIrhMQM608GJwEIK8oGoEk3OfbCAimwhBBCiF5szZo1HD58mFmzZrU75pprrgEcmxCPGjWKhQsXsnbtWmbOnMnzzz/Pgw8+yMyZMz2WcSYkJHDppZfyxhtvcPvtt7NkyRL+3//7f+Tk5Hi9nkqIUCYFls0NHjzYuh85oJ9VYDUWDbCez49MctwpkU6C/mqdrwg+ydcsydccydYsydeMV199FWgporwZN24cI0aM4K233qKmpobnnnuORx55hPz8fH7605+ycuVKXnzxRa9F2htvvMEtt9zC//7v/3LnnXeycuVKHn30URYuXGjse+qJoqKiunsKIcsu2So7XCzY0+Tl5emtW7d29zQAqKioIDEx0fGgoYFvRq1lDd9kePZH7P/eJQAs6zeSBZV7IWsizNvcjbO1H7d8RdBJvmZJvuZItmad6Xy//vprRo8efca+Xndrampqt4mE6DrJ15wzma0v/11QSm3TWntsCidnsGxu+/btLQ8iI0lVJQCcPnW29XR+RILjTsnXIAW1X9zyFUEn+Zol+Zoj2Zol+ZpVXV3d3VMIaZKvOXbJVgqsEJMaXgFAWX0m/eL7AZCPs9Kvr4SqI901NSGEEEIIIUKeFFg217aNbUrUaQCqieOsxMEA5DfUtgyQRhd+kTbBZkm+Zkm+5ki2Zkm+ZsnyNbMkX3Pskq0UWDbXtotPamyNdb9v9CAACmpa7ZwujS780mM2uwxRkq9Zkq85kq1Zkq9ZcXFx3T2FkCb5mmOXbKXAsrkNGza4PU5NbLTuJ+uBAByuPEpjlPNiYTmD5Ze2+YrgknzNknzNkWzNknzNqqys7O4phDTJ1xy7ZCsFls217QKZlt5yP6bS0aq9sbmRo4nOphdSYPlFumyaJfmaJfmaI9maJfkKIexMCiybU0q5PU7v17I/QNiJTOt+QVyW407xbukk6Ie2+YrgknzNknzNkWzNknyFEHYmBZbNzZgxw+1x30Gx1v3mw2nWfWuz4doSqDl5RuYWCtrmK4JL8jVL8jVHsjVL8jUrISGhu6cQ0iRfc+ySrRRYNrdz5063x2nDU4ikHoCG/Jb1gvmqVdcVWSbos7b5iuCSfM2SfM2RbM2SfM2yy15CdiX5mmOXbKXAsrnS0lK3x9FDsknnFADlJ6Lo26cvAPkN9S2DiqWToK/a5iuCS/I1S/I1R7I1S/I1q6mpqbunENIkX3Pskq0UWCEmenA2GTiWAJaUhTEo2dmqvboYIpytLeUMlhBCCCGEEEZIgWVzubm5bo9VZkZLgXU6msHJgwHIL8uH1FGOQSVSYPmqbb4iuCRfsyRfcyRbsyRfs+yyl5BdSb7m2CVbKbBsrqSkxP2J1FSrwCqtjWNw0mAADpUfoslVYMkSQZ955CuCSvI1S/I1R7I1S/I1q7GxsfNBIeCmm27yqyOlv+Pb01vy7Q52yVYKLJvLz893fyIiglRVBkBpY7x1BquhuYFj8Y6Nhzl9DGplfbsvPPIVQSX5miX5miPZmiX5mnPgwAG+//3vM2rUKOLi4khJSWH06NEsWLCAdevWeX3Nxx9/zLx58xgyZAixsbHExcVx9tlnM3fuXFauXOmxb5lSyvoTFhZGQkICQ4cOZfbs2SxdupSampoz8a16tXLlSh5++GFj779s2TJiYmJQSvGb3/zG65gvvvjCyuemm24yNpfu9vDDD7Ny5cqgvmd9fX3ng3oAKbBCUEqkY5frKh1Pdp9B1vMFrlbtIGexhBBCiF5m69atjB8/nvfee49LL72UZ555hoceeoiZM2fy2Wef8c4777iNb25u5o477mD69Ols3LiRq6++mmeffZbnnnuOOXPmsGfPHmbPns3jjz/u8bXOOeccli9fzh/+8Ad++9vfMnfuXI4cOcItt9zC+PHjz0inyN///vcexdzKlStZtGiR8a8dExPD0qVLvR577bXXiImJMT6H7rZo0aKgF1h2EdHdExBdM3ToUI/nUqKrcXZqJ7F5sPV8vorkAteDkq+h/38Yn5/dectXBI/ka5bka45ka5bka8aiRYuorq5my5YtnH/++R7Hjx8/7vb4l7/8JS+99BLz5s3j1VdfJTo62u34Y489xrp16zh69KjHe/Xv358bbrjB7blHHnmEt99+m3nz5nHZZZexa9cuUlJSgvCdeRcZGUlkZKSx9+/I7Nmz+eMf/8iWLVuYOHGi9XxdXR0rVqzg6quvZsWKFd0yNzuLiorq7in4pMefwVIOo5VSC5RSLyqlPldK1SmltFKq1ofXj1JK3auU+kApdcj52tNKqT1KqVeUUuecie/DFG8brqX0aTl9Gl19lnU/v74Gwp1/MaWToE/ssqGdXUm+Zkm+5ki2Zkm+Zuzfv5+0tDTOPfdcr8ezsrKs+0VFRTzxxBMMGTLEa3HlctFFFzFv3jyf53Dttddy7733cuzYMV588cUOx27YsAGllMeZoJEjR6KU4r333vOY/2WXXWY9bntN1YUXXsjrr78OuC9jXLZsmdv7lJeX84Mf/IDMzExiYmK44IIL2Lx5s8/fI8B//dd/kZ6e7jH3VatWUVJSws0339zua5csWUJubi6xsbEkJSVx6aWX8sknn3iMcy0xXLt2LVOmTCEuLo4BAwbwxBNPAI7tDr773e+SmZlJXFwcV1xxhddiuLy8nPvuu4+zzz6b6OhoMjIyuP766zlw4IDbuGXLlqGUYu3atfzmN79h2LBhREdHM2LECCtXcCzxdeX++uuvu2Xd+ri3pZoPP/wwSim3ZcKuz7G4uJjbbruN9PR0EhISuOqqq6x/FHjllVcYPXo0MTExjBo1ilWrVrWb75nQ4wssYBCwG1gG3AHkAT6Vr0qpHwNfA08AlwEDna+NA0YCtwHblFIPB3vSZ4q3U+xpyS17BJw6FEF6nGPD4YKKw5AywnGgRJYI+kI2uzRL8jVL8jVHsjVL8jVj2LBhFBcX86c//anTsX/961+pra1l/vz57RZXgbr11lutr9GRKVOmEBsby9q1a63nCgsL2bdvH2FhYW7P79q1ixMnTjBz5sx23+/nP/8506ZNA2D58uXWn+nTp7uN++Y3v0lhYSG/+MUv+NnPfsZXX33F5ZdfTmVlpc/fY2RkJDfccANvvfUWtbUt5wNee+01zj33XM45x/u/7993333cdtttREZG8thjj/HjH/+Y3bt3c9FFF/HBBx94jP/iiy+49tprufDCC/ntb3/L8OHDuf/++3nuuee4+OKLKS0t5eGHH+b73/8+f/vb37jxxhvdXl9eXs5//Md/sHjxYi6//HJ+97vfceedd7J27VomTZpEQUGBx9d84IEHWL58ObfffjtPPvkkYWFh3HTTTXz66acAZGRksHz5cgCmTZvmlnVXfOtb36K0tJRf/vKX3Hbbbbz//vvMnj2bp556iqeeeooFCxbw+OOPU19fz7e//W0OHjzYpa/XFXZbIlgIfA6kA9N8GO/6J7C9wB+AfwAHgXBgBvAIMAx4SCl1Smv9QtBn3A3SM8Ngj+P+0QP1DE4ZzKnqU85W7WPg1FdyBksIIYToxN13w44d3T0LT+ecA88+6//rHnzwQT788ENuuOEGFi1axNSpUzn//PO58MILGT16tNvYr776yvm1PAuB8vJyGhoarMcREREkJyf7PI/BgweTkJDAvn37OhwXFRXFBRdc4NZ8Y+3atYSHhzNnzhz+8Y9/uD0PdFhgXXLJJbz55pt8/PHHHssXW8vNzWXx4sXW4zFjxjBnzhxWrFjB7bff3un353LLLbfw7LPP8u677zJ37lwKCwv58MMPee6557yO37t3L0899RQXXHABa9eutZbD3XrrrYwZM4Y77riD//u//yM8PNx6zZdffsmmTZuYNGkSAN/97ncZNGgQ99xzD3feeSfPP/+829d45pln2Lt3LyNHjgTgF7/4BQcOHOCf//wnOTk51ribbrqJ8ePH89BDD3mc4aurq+Pzzz+35vftb3+boUOH8sILL3DBBRfQp08fbrjhBubPn8/QoUM7zNofEydO5PHHH3c7w/3MM89w5MgRvvrqKxITEwHH34GcnBxeeeUVfv3rXwfla/vLDgVWMXAVsFlrfRzAecbJlwJrP3CV1trbecK3lFIfAdtxnNn6lVLq91rruuBM+8xIS0vzeC5jQMu/NB07WMPgIYPZenSro8Aa5rwKq6IA6qsgKv7MTNSmvOUrgkfyNUvyNUeyNaun5LtjB2zY0N2zCJ4pU6awbds2nnjiCT788EOWLl1qLWGbNm0ay5Yts65/q6ioALB+aW3t4osvZtu2bdbjsWPHWgWZrxITEzlx4kSn42bOnMlHH31kFQVr164lNzeXa665hj/+8Y8cO3aMfv36sW7dOlJSUtpd/uiPe+65x2MO4Fhi6Y/x48eTl5fH0qVLmTt3Lq+//jqRkZHMmzePpqYmj/GrVq1Ca829997rdq1RdnY2N998M88++yxffPEFeXl51rEpU6ZYxRU4itKJEyeyevVq7rrrLrf3nzZtGs888wz79+9n5MiRaK158803mT59Ov379+fUqVPW2D59+jB58mTWrFnjMc877rjDbX79+/dnxIgRfufjr7vvvtutuHR9PzfeeKPb39MJEyaQmJhofD4d6fEFlta6EghoIaXW+s1Ojp9SSj0DPA0kA5MBW/2ndOzYsR7PpQ9NIIwmmgmnKL/a2guroLyA5tSRLetCS/dC3/PO2FztyFu+IngkX7MkX3MkW7N6Sr7trOLqdl2Z1/jx41m+fDlKKQoKCtiwYQNLlizh448/5sorr2Tbtm1ERUVZv7C6Cq3WFi9ebD0f6NmJiooKr8VbW67iZu3atYwcOZJ169Zx/fXXc9FFF1nXA11//fVs2LCBGTNmEBbW9atf2jZZcRX8xcXFfr/XzTffzH//939TUFDAsmXLuPLKK0lJSXErZlxcS9q8/f13PXfgwAG3AstrszNn45AhQ4Z4fd71fZw8eZLi4mLWrFlDRkaG1/l7y9Pb10xLS/O6nDCYhg4d6jaf9r5P17FAPq9g6fEF1hnQeq1cdrfNIkAbN27kwgsvdHsuelA/0jlFEX0pPt7I2GRHq/b6pnpOxPaln2tg8W4psDrhLV8RPJKvWZKvOZKtWT0l30CW4dlBVVUVCQkJDBo0iBtvvJH58+czbdo0Pv30U7Zs2cLUqVMZN24cADt27GD27Nlur2/dFS+QduP5+flUVlYyZcqUTsfm5eWRmJjI2rVrueSSSzh06BAzZ84kNTWVnJwc/vGPfzB69GhKSko6XB7oj9ZnSVpru9+XL+bOncuPf/xjbrvtNv7973/zwgvBvRqlvbl2dMz1fbhuv/GNb3Dfffd1+Wv6mk9Hmzl3tJFweHg4lZWVHk1wgvl5BYsUWNC31X3Pf6axoegh/cngpKPAKsHabBggX4fRT4WDbpLrsIQQQgiBUopJkybx6aefcuTIEQAuv/xyYmJiWL58OQ888EBQG10sWbLE+hqdCQ8PZ/r06axbt46PPvqIqKgopk6dCjiWKv7lL3+xzu74UmB19Mu9CcnJyVbL9oEDB3LJJZe0O9Z1ZmjXrl0MGzbM7dju3bvdxgRDRkYGycnJVFRU8I1vfCNo79uZ1NRUAEpKSjyOte1caFd26CJo2jXO22ZgS3dOJBAREZ41csSALDI4CUBJRYR7gVV5FJKdP7Sy2XCnvOUrgkfyNUvyNUeyNUvyNePDDz/0eoagpqbGutZmzJgxAGRmZnLvvfdy8OBBbrnlFurqvF+i7u9Zgrfffpsnn3yS7OxsFi5c6NNrZs6cSXFxMc8//zyTJ08mLi7Oer6goIDXXnuNvn37+rS0ND7ece25t1/uTbn//vt56KGHeOGFFzpcwjhr1iyUUjz11FNuTUSOHTvG0qVLGTRoUFCuMXMJCwtj3rx5bNmyhb/85S9exxQVFQX8/vHx8V5zTkhIICsri7Vr17r9/Tlw4EDIbEzcq/8LppSaBsxyPnxXa32yO+cTCNe/4rhJSyMDR4vb0ppYBiWlW4cKygsgbQyU7oMSOYPVGa/5iqCRfM2SfM2RbM2SfM245557KC4uZtasWYwfP564uDgOHz7MihUr2LdvHzfeeCPjx4+3xj/00EMUFRXx8ssvs3HjRubMmWN1nyssLGT16tUcOnSIK664wuNrHTlyhDfeeANwFHCHDh1izZo1bNmyhbPPPpt3333X586DrjNTX3/9Ndddd531/PTp04mIiGD37t185zvf8em9Jk+ezAsvvMAdd9zB5ZdfTmQoBeeDAAAgAElEQVRkJJMmTfJ6HU+wTJgwgQkTJnQ6buTIkfz0pz/lySefZPr06Vx33XVUVlbyyiuvUFVVxZtvvtnhksBAPProo3z66afMmTOHOXPmMHnyZKKioigoKOCDDz7gvPPO8+gi6KvJkyfz0Ucf8cQTT3DWWWehlLI+pzvvvJMHH3yQyy67jKuuuoqjR4/y8ssvM27cOD7//PN239Mue+T12gJLKZUGvOF8WAX4vvi0B9m+fTu5ubnuT6akkI7j4snShj4kRCeQGptKSU2Js1X7aGAllP0fNNZChP/rp3sLr/mKoJF8zZJ8zZFszZJ8zXj66adZtWoVGzdu5J133qGsrIykpCQmTJjAfffdx0033eQ2PiwsjJdeeonvfOc7vPLKK7zzzjscP34cpRTZ2dlMnDiRRYsWMWvWLI+vtWPHDubPnw84OtJlZGSQk5PDq6++yvXXX09sbKzP854wYQLp6emcOnXKbRlgfHw8EydO5LPPPvP5+qvrr7+eL774grfeeou3336b5uZmli5darTA8scTTzzB2WefzeLFi7n//vuJiopi0qRJrFixwtrDK5iSkpL49NNP+e1vf8uf//xnVq1aRUREBAMGDGDq1KnWnmWBWLx4MQsXLuTRRx+19hBzFVj33Xcf5eXlLF++nPXr1zNmzBheffVVtm3b1mGBdfr0afr06RPwnM4U1Z0XgAXK2ab9IaBOa+13daCUigT+Brh+Gudrrd/o4CUopb4HfA8gOzv7vDffdDQoHDp0KAkJCdamiGlpaYwdO5aNGzcCjmUOU6dOZfv27VbHnby8PE6cOMHhw4cBGD58ONHR0VaL08zMTEaMGGHt2h0dHc2UKVPYunUrVVVVAEyaNInCwkL27t1LfHw8I0eOJDw83Fqj++HMz3hMP+C4/+EG7vzydvZW7GVy+mRey5rJ6PzHADg4bRUF1Y4uPmPGjKGpqYm9e/cCjrabAwYMsHYvj4+PJy8vj02bNllLBaZOncq+ffusU8jjxo2jrq7Oao05cOBA+vbty9atWwFHW9bc3Fw++eQTa5nC9OnT2bVrl9XtJScnh8rKSmsd7uDBg0lNTWX79u2AozNMTk4OGzZsQGuNUooZM2awc+dOSktLAcceFiUlJdZO4IF+Tp9++qm17rwrn5NrTXvbzykrK4shQ4awadMmAGJjY5k0aRKbN2+mpqYGcLRgPXjwoLVbeSh9Tk1NTQwbNqzLn1Owfp5C7XOqqqriggsu6DE/T6H0OX300UfWxf095ecplD6n5uZmsrOzz9jPU1JSEiNGjKBPnz5um8nGx8dTU1NjtdSOjY2lqamJ+vp6wNESOyIigurqasBxvVBcXJzbeyQkJFBdXW29R1xcHI2NjW7vER4ebn3v4eHhxMbGWnm63uP06dM0Nzdb79HQ0GAtI4uOjkYpZW1oGxERQUxMjPUeSini4+Ot92hqaiIxMZH6+voO3yM6OprTp0+7vUdVVZW1rKtPnz7U1dVZf69jYmLQWlufQWRkJFFRUdZ7hIWF0adPH7f3iI+Pp7a2tsP3iIyMtDJ2vUdP/pwaGhqsr9GVz8mVsXxO7hs8h4eHn5Gfp6+++ory8vIO/7t3/vnnb9Nat7R1dOp1BZZyXN24HJjnfGqR1vphf94jLy9Pu/7H2d3Wr1/vtdPSb2N/zk9qHwXg2DFYuPEa3v36XUamjWTPtSvgDWf3wMvfglHXebxeOLSXrwgOydcsydccydasM53v119/7bHRbijz1olNBI/ka86ZzNaX/y4opbwWWL2xycUztBRXv/O3uOppWu+F0FpKbI11/+RJGJTkaNVeUF6AThnRMlA6CXaovXxFcEi+Zkm+5ki2Zkm+ZrmaRAgzJF9z7JJtryqwlFIPAT90Plze6r5ttbcLempCS5egY4WNVifB2sZaiupPQ6LjMSXSSbAjvuwyLwIn+Zol+Zoj2Zol+ZrVukOdCD7J1xy7ZNtrCiyl1F3Aw86Hq4BbtB3XR7bhWifflnPTcQAKD9S7t2ovy3d0EgQ5g9WJ9vIVwSH5miX5miPZmiX5mmWXX1LtSvI1xy7Z9ooCSyl1I+Daj/0fwHVa6/a3ig4BaX1bGkQezW+wlgiCs1V7qnNNaek+aA7pKIQQQgghhDhjQr7AUkrNAl4FFLAZuEpr7X23PBsaPny41+czBsWhcHRHOVFQw6DklgLL7QxWc4OjXbvwqr18RXBIvmZJvuZItmZJvma5uuMKMyRfc+ySrS32wVJKjQESWz01oOWQmtxm+BeuAsq5kfCfcHyf+4Brnc/Ht/Olau12Zqu9v2gxZ2WSSgnFpHPySD3JMVkkxyRTVlvmKLCGTG8ZXLwbUkeemQnbjF1+kO1K8jVL8jVHsjVL8jXL0VBZmCL5mmOXbO1yBmsxsKnVn+86n49q8/wmoF+r130XcLVxHwEcAio7+HODyW/CBNfeJG1FDcomg5MAFJ907BXgug7LcQarVdtJaXTRrvbyFcEh+Zol+Zoj2Zol+Zrl2kNJmCH5mmOXbO1SYAk/RQ7qZxVYJWXhgHurdqKTID7bMVgaXQghhBBCCBEUtlgiqLW+MMDX3QTcFMy59DSZmZlenw/rm0kG/wKg9HQU4H4GS2uNSh0DVUelwOpAe/mK4JB8zZJ8zZFszZJ8zYqIsMWvf7Yl+Zpjl2zlDJbNjRgxwvuBtDTrDFZpnWNTNleBVd1QzanqUy3LBEv2gG42PVVbajdfERSSr1mSrzmSrVmSr1kxMTGdDxIBk3zNsUu2UmDZ3CeffOL9QHIy6ZwCoLwpnqYmPFu1uzoJNtZARYHpqdpSu/mKoJB8zZJ8zZFszZJ8zaqqquruKYQ0ydccu2QrBVaoCgsjJbwCAE0YJSV4bjac2qrRhSwTFEIIIYQQosukwLK5jlrZpkRXW/dPnvRSYLnOYAEUSydBb6RVsFmSr1mSrzmSrVmSrzkHDhzgrrvuYtSoUcTFxZGSksLo0aNZsGAB69at8/qajz/+mHnz5jFkyBBiY2OJi4vj7LPPZu7cuaxcuRKttdt4pZT1JywsjISEBIYOHcrs2bNZunQpNTU1Z+Jb7TZ2aSVuR3bJ1h5Xiol2TZkypd1jKX3qwFljFZ3QjB6dTGJ0IhV1FY4CKy4DYtOh5pScwWpHR/mKrpN8zZJ8zZFszZJ8zdi6dSszZswgMjKSG2+8kbFjx1JTU8P+/ftZs2YNCQkJXHTRRdb45uZm7rzzTl566SUGDBjAnDlzGDFiBGFhYRw8eJC//e1vzJ49m8cee4yf/exnbl/rnHPO4cc//jEA1dXVHDp0iDVr1nDLLbfw6KOP8s4775CTk3NGv/8zJT6+ve1WRVfZJVspsGxu69at5OXleT2WltSMs88FhQfrURdFMyhpEF8Wfem4BgscywSPfAwlUmB501G+ouskX7MkX3MkW7MkXzMWLVpEdXU1mzZtYvLkyR7Hjx8/7vb4l7/8JS+99BLz5s3j1Vdf9Tiz+Nhjj7Fu3TqOHj3q8V79+/fnhhvctxd95JFHePvtt5k3bx6XXXYZu3btIiUlJQjfWc9y+vRp+vTp093TCEl2yVaWCNpcRxf7pWa0fLxHCxqANpsNQ8syweKvoc0pfmGfiyntSvI1S/I1R7I1S/I1Y//+/aSlpTF27Fivx7Oysqz7RUVFPPHEEwwZMsRrceVy0UUXMW/ePJ/ncO2113Lvvfdy7NgxXnzxRf++AZtobpbOzKbYJVspsEJYRnaUdf94YSPguReWVWDVVzj2xBJCCCFESBo2bBjFxcWsXr2607F//etfqa2tZf78+UG/Ju7WW2+1voYQoUiWCNrcpEmT2j0WMzCNZEopI4Wiw3VAS6v2qvoqSmtLSW3dSbDka0job3S+dtNRvqLrJF+zJF9zJFuzekq+d//tbnYc39Hd0/BwTtY5PPutZ/1+3YMPPsiHH37IDTfcwKJFi5g6dSrnn38+F154IaNHj3Yb+9VXXzm+1jnneLxPeXk5DQ0N1uOIiAiSk5N9nsfgwYNJSEhg3759fn8PdmCHJWx2ZZdspcCyucLCQoYPH+71WOTAfmRwkjJSOHXc/QwWOM5ipbp1EtwNg75hcrq201G+ouskX7MkX3MkW7N6Sr47ju9gQ8GG7p5G0EyZMoVt27bx5JNPsmbNGpYuXcrSpUsBmDZtGsuWLWPo0KEAVFQ4tnpJTEz0eJ+LL76Ybdu2WY/Hjh1rFWS+SkxM5MSJE4F+Kz1afX29bTbEtRu7ZCsFls0dOXKk3f8JRQ3OJoOT7GcEJcWO59oWWLlZ50JUomOJoHQS9NBRvqLrJF+zJF9zJFuzekq+52R5nr3pCboyr/Hjx7N48WISEhIoKChgw4YNLFmyhI8//pgrr7ySbdu2ERUVZRVWrkKrtcWLF1vPt21k4auKigqvxVsoaGhosEURYEd2yVYKrBAW0T+LDI4BUFLl+Kg99sJSCtJGw7HNjiWCQgghhAAIaBmenQwaNIgbb7yR+fPnM23aND799FO2bNnC1KlTGTduHAA7duxg9uzZbq+bOHGidT+QX3bz8/OprKyUdvwiZEmTC5sbOXJk+wfT08lw9mkvq4kFIDU2lT6RjvWrBWWuVu2uToJyBqutDvMVXSb5miX5miPZmiX5mtW2aYVSyrru7ciRIwBcfvnlxMTEsHz5curq6oL69ZcsWWJ9jVAkG2WbY5dspcCyufDw8PYPti6wGvrQ3Oz4j6jVSbA83zHOdR1WzSmoPmlusjbUYb6iyyRfsyRfcyRbsyRfMz788EMaGxtRSrk9X1NTw5o1awAYM8bxO0FmZib33nsvBw8e5JZbbmm3yNJ+bvHy9ttv8+STT5Kdnc3ChQsD+C56vrb5iuCxS7ayRNDmdu/eTWZmpveDiYmk47j4qolwysogNdWxTHDXyV2t9sJq00kwLsPspG2kw3xFl0m+Zkm+5ki2Zkm+Ztxzzz0UFxdz2WWXkZubS1xcHIcPH2bFihXs27ePG2+8kfHjx1vjH3roIYqKinj55ZfZuHEjc+bMsc4uFhYWsnr1ag4dOsQVV1zh8bWOHDnCG2+8ATgKuEOHDrFmzRq2bNnC2WefzbvvvutX50E7qa2tJTIysrunEZLskq0UWKFMKVIiq8DZSfXkyZYCC1otEWzbSXDA9DM7TyGEEEIY9/TTT7Nq1So2btzI6tWrKSsrIykpiQkTJnDfffdx0003uY0PCwvjpZde4jvf+Q6vvPIK77zzDsePH0cpRXZ2NhMnTmTRokXMmjXL42vt2LGD+fPnA47W2hkZGeTk5PDqq69y/fXXExsbeya+ZSG6hRRYNtd613VvkmNq3AqskSNb9sIqryunrLaM5MRBEBELjTVyHVYbneUrukbyNUvyNUeyNUvyNePSSy/l0ksvpaamxq8CZ8aMGcyYMcPn8f4uGww1ERHy67UpdslWrsGyuSFDhnR4PDW+ZSPA40eaAG+dBMMgdZTjiWLpJNhaZ/mKrpF8zZJ8zZFszZJ8zbJLowC7knzNsUu2UmDZ3KZNmzo8nprW8q9IhQfrAS8FFrQsEyyRM1itdZav6BrJ1yzJ1xzJ1izJ16zTp0939xRCmuRrjl2ylQIrxKX3bTmVeuxwIwCDkgdZz7W0anc2uqg6CnXlZ2x+QgghhBBChBIpsGyuszXUcdkpJODYbf3EEUeBlRGXQWyE43UeZ7BAlgm2IhfhmiX5miX5miPZmiX5mmWXVtd2JfmaY5dspcCyOdfGgO0Jz8609sI6edRxPVaHe2GBNLpopbN8RddIvmZJvuZItmZJvmbFx8d39xRCmuRrjl2ylQLL5jZv3tzh8ciz+lkFVvGpluuxrALLdQYreRiEOfcVKJEzWC6d5Su6RvI1S/I1R7I1S/I1q6qqqrunENIkX3Pskq0UWDZXU1PT4fHWBVZJWcvH7WrVbl2DFRYBKSMc9+UMlqWzfEXXSL5mSb7mSLZmdUe+vam1eG/6XruD5GvOmcq2q19HCqwQF9a3ZYlgWXVLa0vXGazS2lLKa51NLVzLBKXAEkII0YtERETQ2NjY3dMQQvQQDQ0NhIeHB/x6KbBsbsqUKR0PSE+3CqzS+jhcBXnrVu0F5W06CVYUQIM92mCa1mm+okskX7MkX3MkW7POdL4xMTG2WXoUDH369OnuKYQ0ydecM5VtRUUFCQkJAb9eCiybO3jwYMcDWhVYjTqCCkdDQe+t2q1GFxpK9gZ5pvbUab6iSyRfsyRfcyRbs850vhkZGZw8eZLq6upesbyrrq6uu6cQ0iRfc0xmq7Wmvr6eU6dOUVpaSmpqasDvFdH5ENGTHT9+nFGjRrU/ID6eNFUCzv9fnDwJSUmdbDYMjmWCfXODPl+76TRf0SWSr1mSrzmSrVlnOt+YmBj69u3L8ePHe8Uvx7W1tcTExHT3NEKW5GuO6WzDw8NJSEjgrLPOIjo6uvMXtEMKrFCnFClRp8H5/4uTJ+Hss6Fvn77ERMRQ21jbUmCljAAVBrpZOgkKIYToVZKSkkhKSuruaZwR69ev59xzz+3uaYQsydccu2QrSwRtbsyYMZ2OSY5t+de4ohOOU1lKKauToLUXVkS0o107SKMLJ1/yFYGTfM2SfM2RbM2SfM2SfM2SfM2xS7ZSYNlcU1NTp2NSk1o6Ix0paLDuu67Dsq7BgpZGF1JgAb7lKwIn+Zol+Zoj2Zol+Zol+Zol+Zpjl2ylwLK5vXs7b0aRlt7yMR871FJgDU4aDLS6BgtarsMq+z9oDP116J3xJV8ROMnXLMnXHMnWLMnXLMnXLMnXHLtkKwVWLxCflUAs1QAcO9JS+bsaXRTXFFNV72xP6yqwdBOU7T+T0xRCCCGEEML2pMCyuf79+3c6JqxfJpkUAVB0rNl63murdtcSQZBlgviWrwic5GuW5GuOZGuW5GuW5GuW5GuOXbKVAsvmBgwY0OmY8P5Z1l5YxSc8z2BBq2WCqa3a4hZLJ0Ff8hWBk3zNknzNkWzNknzNknzNknzNsUu2UmDZ3ObNmzsdE3VWS4FVUtryvNcCKyoeEp1ntuQMlk/5isBJvmZJvuZItmZJvmZJvmZJvubYJVspsHqBiFZnsEqrIq3ns+KziAqPAto0unAtE5S9sIQQQgghhPCLFFg2Fx8f3/mg9PSWAqs2Fu3YCoswFcZZSWcBUFDeqlW7q9FF6V5obqQ38ylfETDJ1yzJ1xzJ1izJ1yzJ1yzJ1xy7ZCsFls3l5eV1PqhVgVXfHMnp0y2HXMsEvbZqb6qHsgPBmahN+ZSvCJjka5bka45ka5bka5bka5bka45dspUCy+Y2bdrU+aBWBRbAyZa73vfCat1JsJcvE/QpXxEwydcsydccydYsydcsydcsydccu2QrBZbN1dX5sBlwXBypYWXWw9YFlqtV+8nqk1Q3OPbKIk1atbv4lK8ImORrluRrjmRrluRrluRrluRrjl2ylQKrN1CKlOhq66HbGaxWnQStvbBiUqBPP8f9Xl5gCSGEEEII4Y8eX2Aph9FKqQVKqReVUp8rpeqUUlopVevH+/RVSj2plNqjlKpWSp1SSm1QSt2slFImvweTpk6d6tO4lD4N1v3jRzvZCwtazmL18iWCvuYrAiP5miX5miPZmiX5miX5miX5mmOXbHt8gQUMAnYDy4A7gDwgyp83UErlAf8CfgqMBGKBNGA68BrwgVIqOnhTPnP27dvn07jUlGbr/pH8lmKr3QIr1dnoovhr0C2v7W18zVcERvI1S/I1R7I1S/I1S/I1S/I1xy7Z2qHAaq0QeA/42NcXKKXSgdVAJlAM3AD0A0YBLzqHfQv4XVBneoYUFRX5NC4+I5YoHOtWjxe2nMHqF9+PiLAIoG2rducZrMZqqDgUnMnakK/5isBIvmZJvuZItmZJvmZJvmZJvubYJVs7FFjFwFVAP631QK311cBaP15/P46Cqhm4Qmv9ptb6uNZ6r9b6TuAl57jvKqXGB3XmPUhY3wwycfylPHGspcAKDwu39sLy2qodev0yQSGEEEIIIXzV4wssrXWl1nqV1vq4v69VSkUCtzofrtJa/9PLsIeABhxZ3B74TLvHuHHjfBoX3i/TatV+ski7HetwLyzo1Y0ufM1XBEbyNUvyNUeyNUvyNUvyNUvyNccu2fb4AquLpgFJzvt/8TZAa30S2OB8OOtMTCqYfG1XGTEwyyqwik+5F1iDkhyt2t2WCMZmQEyq434vLrDs0g7UriRfsyRfcyRbsyRfsyRfsyRfc+ySbagXWLmt7m/uYJzr2EDnNVu2sX//fp/GRZ7VzyqwSivC3Y65zmAdrzpOTUON40mlWs5iFffeJYK+5isCI/maJfmaI9maJfmaJfmaJfmaY5dsQ73AGum8bQYKOhh30MtrQkpYRoZVYJVVuzdMbN1J8FB5q4YWrgKrZDdo97NeQgghhBBCCE+hXmC5zkaVaq0bOxjXuiVJmsH5BN3AgQN9G5iebhVYNU1R1NS0HGq/Vbuzk2BdOZz2+xK4kOBzviIgkq9Zkq85kq1Zkq9Zkq9Zkq85dsk2orsnYFgf521nGxK3KjeI9zZAKfU94HsA2dnZrF+/HoChQ4eSkJDAzp07AUhLS2Ps2LFs3LgRgIiICKZOncr27dupqKgAIC8vjxMnTnD48GEAhg8fTnR0NF999RUAmZmZjBgxgk8++QSA6OhopkyZwtatW6mqqgJg0qRJFBYWcvjwYQ4fPszIkSMJDw9n927H9VJZWVkMGTKETZs2AZBUUWEVWACrV2/iqqtyOXjwIEfzj1rP/+vQv4gudJzhGh6ZRH/n8zvWrqAxewZ5eXls2rTJWgM7depU9u3bZ7XNHDduHHV1ddYp3IEDB9K3b1+2bt0KQGJiIrm5uXzyySc0Njpq3unTp7Nr1y6Ki4sByMnJobKykgMHDgAwePBgUlNT2b59OwApKSnk5OSwYcMGtNYopZgxYwY7d+6ktLQUgNzcXEpKSsjPz+/S51RfX2991l35nI4cOQLQ6ecUGxvLpEmT2Lx5MzXOKnjKlCkcPHiQ48cdRe6YMWNoampi7969APTv358BAwawebNjpWt8fLxtPqdRo0aRn5/f5c8pWD9PofY5NTc3k5qa2mN+nkLpc6qsrLT+29BTfp5C6XOaMGECe/bs6VE/T6H0OTU3N5Odnd1jfp5C7XMqKyvj8OHDPebnKZQ+p/POO69H/Ty1R2kbLv1SSj2Mo/tfndY6poNxa4BLgCNa6wEdjPsG8KHz4Tyt9YqOvn5eXp7uKNQzaf369Vx44YWdD6yuZmWfucxmJQBbt8J55zkONTY3EvNIDE26iZ9N/RmPXfyY40BlIbzi/JeCi56H3P8O/jfQw/mcrwiI5GuW5GuOZGuW5GuW5GuW5GtOT8tWKbVNa53X9vlQXyJ42nnbbhHmFNvqfpWhuXSvuDhSwsuthydbTmYRERbBwCRHIeW2RDC+P0QlOO7LXlhCCCGEEEJ0KtQLrFPO22SlVEfLITNa3S82OJ+gS0xM9HlsSkzLSsmiEz60aleq5TqsXtqq3Z98hf8kX7MkX3MkW7MkX7MkX7MkX3Pskm2oF1h7nbfhwFkdjBvi5TW2kJub2/kgp5SkJuv+0UPuPT+8bjYMrVq1984Cy598hf8kX7MkX3MkW7MkX7MkX7MkX3Pskm2oF1jbW92f1ME417HDWutTHYzrcVwX3PkiKSWcCBoAOHbYe4F1tPIodY2tNnFzncGqOQnVtoomKPzJV/hP8jVL8jVHsjVL8jVL8jVL8jXHLtmGeoH1MeC68Ojb3gY4Nxae4Xy4+kxMKphcnVl8odLTSXeumjxxrMntWKd7YUGvvA7Ln3yF/yRfsyRfcyRbsyRfsyRfsyRfc+ySbUgXWFrrBmCJ8+GVSqmJXoY9DEQBGvifMzS1bqGyMsl0bvlVdML9mOsaLGhzHVba6Jb7vXSZoBBCCCGEEL6yxT5YSqkxQOur2ga0HFKT2wz/Qmvdao0bjwNzgX7AX5VSPwT+4Xy//wYWOsct0Vp/GfTJGzZ9+nSfx4Zn97X2wjp1yr3JRbubDScOhogYaKztlWew/MlX+E/yNUvyNUeyNUvyNUvyNUvyNccu2drlDNZiYFOrP991Ph/V5vlNOAopi/OaqllAEZAOvAkcB/bhKLAA/tbqvq3s2rXL57GRA7OsAqu0TLkdG5A4gDDl+OvgVmCFhUPKKMf9XngGy598hf8kX7MkX3MkW7MkX7MkX7MkX3Pskq1dCqwu0VpvBSYAv8FRWNUAJTiu0boF+M82Z71sw7Ubti9an8EqrYpyOxYZHkn/hP5AmyWC0LJMsBcWWP7kK/wn+Zol+Zoj2Zol+Zol+Zol+Zpjl2xtsURQa31hEN7jBPBT559eSaWnk8FXAJxuiKKuDqKjW44PTh7M4YrD7bdqrzoCdRUQbY89CIQQQgghhDjTesUZrFCWk5Pj++D0dOsMFsCpNl3XO90LC3rddVh+5Sv8JvmaJfmaI9maJfmaJfmaJfmaY5dspcCyucrKSt8HtymwTp50P+wqsI5UHKG+qb7lQGrrToK9q8DyK1/hN8nXLMnXHMnWLMnXLMnXLMnXHLtkKwWWzR04cMD3wWlpHRZYrlbtGk1hRWHLgeSzIcy5mrSXXYflV77Cb5KvWZKvOZKtWZKvWZKvWZKvOXbJVgqs3iQmhpSIlsq/vTNY0GaZYHgkpIxw3C/pXQWWEEIIIYQQ/pACy+YGDx7s1/iUuJalf8ePNbm/V3sFFrQsE+xlSwT9zVf4R/I1S/I1R7I1S/I1S/I1S/I1xy7ZSoFlc6mpqX6NT0qGMByF1dGCRrdjA5MGonDsj9Vuo4vyg9BQHdBc7cjffIV/JF+zJF9zJFuzJF+zJF+zJF9z7JKtFFg2t337dr/Gq9QU0nDsIXD8iPsZrKjwKLITsgFve2G5OglqKNkb0FztyN98hX8kX7MkX3MkW7MkX7MkX7MkX3Pskq0UWPg7oqwAACAASURBVL1NejqZFAFQdEJ7HG63VXvrToK9rFW7EEIIIYQQvpICy+ZSUlL8Gh+W1dfqJNh2HyzooMBKGQHK+delF3US9Ddf4R/J1yzJ1xzJ1izJ1yzJ1yzJ1xy7ZCsFls35u+FaRP+WAqu4RHkcd7VqP1JxhMbmVtdoRcZC0hDH/V5UYNllQzu7knzNknzNkWzNknzNknzNknzNsUu2UmDZ3IYNG/waHzEwyyqwSisiPI67zmA16Sb3vbAAUp3XYfWiJYL+5iv8I/maJfmaI9maJfmaJfmaJfmaY5ds/SqwlFIxSqkJSqnx7Rz/T6XUJqVUqVLq30qpXymlooMzVeGN1p7XUXUkrG+mVWBV1kXR0OB+vMNW7a5GF6X7oame3sDffIV/JF+zJF9zJFuzJF+zJF+zJF9z7JKtv2ew5gFfAM+3PaCUugT4X2AikAQMBR4A3u3iHEUHlPJc5teh9HSrwAIoLnY/3HGB5Wx0oZscRVYv4He+wi+Sr1mSrzmSrVmSr1mSr1mSrzl2ydbfAutbzts/eTn2JKCAk8BzwPvOx99SSl0T8AxFh2bMmOHfC9LS3AqskyfdDw9MGmjdLyhrr1U7vWaZoN/5Cr9IvmZJvuZItmZJvmZJvmZJvubYJVt/C6yxzttNrZ9USo0FcoAmYIbW+h6t9SxgKY4ia35XJyq827lzp38vaHMGq22BFRMRQ7/4fgDkl+e7H0wd1XK/lzS68Dtf4RfJ1yzJ1xzJ1izJ1yzJ1yzJ1xy7ZOtvgZXhvG3T/YBvOG/Xa61b70L7P87bXH8nJnxTWlrq3ws6OYMFHbRqj0qABOcZruLecQbL73yFXyRfsyRfcyRbsyRfsyRfsyRfc+ySrb8FVpLztu0VZtOcz33Y5vmDztsMRM8QFUVK1GnrYVGR58WCg5Idrdo9lghCyzLBkt5xBksIIYQQQgh/+FtgVThv+7ueUI6rzVwLIj9rM97123vvaDnXDXJz/T85mBTfZN0/drjJ4/jgpMEAHK447L4XFrQqsPZCs+drQ00g+QrfSb5mSb7mSLZmSb5mSb5mSb7m2CVbfwusXc7bq1s99y0gDagBtrQZP8B5e8z/qQlflJSU+P0alZxEKo72gccKGz2Ou5YINjY3crTyqPvBVGcnwaY6KD9IqAskX+E7ydcsydccydYsydcsydcsydccu2Trb4H1FxxNK36ulHpKKfUj4DUcZ6re1Vq3PVM1yXl7oGvTFO3Jz8/3/0WtrsM6cazZ47BPe2FBr2h0EVC+wmeSr1mSrzmSrVmSr1mSr1mSrzl2ydbfAutlYBsQAfwIeAroi2Pp4MNexl+Do/haF/gURbCp9HQyKQK8N7lwXYMFXq7Dcp3Bgl5RYAkhhBBCCOEPvwosrXUDcBHwa2AH8CXwB+BcrbXbWSql1Egc3QUVns0vRJAMHTrU79eEZfe1zmAVl3hu2DYoqaXA8jiDFZsKcX0d93vBXliB5Ct8J/maJfmaI9maJfmaJfmaJfmaY5dsI/x9gda6Cvi5809H4/bi/xky4aeEhAS/XxPRP8sqsErLwz2Ox0bG0rdPX06cPuFZYIFjmWD1iV5xBiuQfIXvJF+zJF9zJFuzJF+zJF+zJF9z7JKtFEA2F8iGa+HZmVaBVV4dSZOXZoBWq/ZyL63aXcsES74G7XkNVyixy4Z2diX5miX5miPZmiX5miX5miX5mmOXbINeYCmlRiqlrlRKTVVKeZ4eEd1OZWRYBZZG4a0hS7ubDUNLo4uG01DZds9pIYQQQgghei+/Cixn8fS0UuqXXo5FKqXeAnYD7wIbgP1KqfOCM1XhTVpamv8vSk+3Cizw3ujCtRfWofJDNLXd76oXdRIMKF/hM8nXLMnXHMnWLMnXLMnXLMnXHLtk6+8ZrOuAHwJZXo79HJiDo6mF689g4K9KqZQuzFF0YOzYsf6/yJcCy3kGq6G5gWNVbbYxS+s9nQQDylf4TPI1S/I1R7I1S/I1S/I1S/I1xy7Z+ltgXey8fb/1k0qpKOAuHC3Z/wycC1wLlAIZwB1dm6Zoz8aNG/1/Uat9sCCAVu1xfSHGWTOHeCfBgPIVPpN8zZJ8zZFszZJ8zZJ8zZJ8zbFLtv4WWAOdt1+2ef4iIBkoARZorXdqrd8BfoHjTNblXZqlCK7UVJ/PYIGX67CUglTnMsEQP4MlhBBCCCGEP/wtsDKct8Vtnp/hvH1fa13X6vk1ztuR/k5M+CYiwu9O+xAZSVJ0rfXwxDHPNoId7oUFLcsES74Grf2fg00ElK/wmeRrluRrjmRrluRrluRrluRrjl2y9bfAcn1XbZvQT8exPHB9m+dd50bi/fw6wkdTp04N6HXhifEkUQbA0cOeBVafqD6kx6UD7bRqdzW6qC117IkVogLNV/hG8jVL8jVHsjVL8jVL8jVL8jXHLtn6W2Add96Ocj2hlEoGJjofbmozvo/z1ksjcBEM27dvD+h1zcktywRPHPWyERY+tmqHkF4mGGi+wjeSr1mSrzmSrVmSr1mSr1mSrzl2ydbfAuufOK6p+olSyvXan+A4s1Wgtd7XZrxraWCbNnQiWCoqKgJ7YXpLo4uiIu9DOiywUlt3EgzdRhcB5yt8IvmaJfmaI9maJfmaJfmaJfmaY5ds/S2wXnbeXgoUKqX+BfwMx/LAl72Mv8h5+6/ApidMUX0zycRRWZ0qVl7HuPbCKigvoFk3ux9MGAiRzpWfIXwGSwghhBBCCH/4VWBprTcAD+IoqLKAcTjOaL0PPN16rFJKAdc7x34YjMkKT3l5eQG9LjwrwzqDVVLm/a+Bq1V7fVM9J6raXGelVKtGF6FbYAWar/CN5GuW5GuOZGuW5GuW5GuW5GuOXbL19wwWWuvHgLE4Nhz+ETBTa32l1rqxzdBhwMfAH2jpJiiC7MSJwBpMRAzsZxVYZVURNDd7jumwVTu0LBMM4SWCgeYrfCP5miX5miPZmiX5miX5miX5mmOXbP0usAC01nu11r/TWj+rtV7fzph/a61vdv7xstOSCIbDhw8H9LqwzJYzWM06jLIyzzGdFliuRhfVJ6Cmbef+0BBovsI3kq9Zkq85kq1Zkq9Zkq9Zkq85dsk2oAJLhID09E43G269F5bXVu29pNGFEEIIIYQQvurSbl1KqdHANOAsHHtjVQIFwCdaa/mN+wwYPnx4YC/0UmCNbLMddEJ0AqmxqZTUlHTeqr3kaxhgj70J/BFwvsInkq9Zkq85kq1Zkq9Zkq9Zkq85dsk2oAJLKXUe8DtgUgdj/gncpbXeFuDchA+io6MDe6EPZ7DAsUyw3QIraQiER0NTXch2Egw4X+ETydcsydccydYsydcsydcsydccu2Tr9xJBpdTVwGc4iivl/FMBHHXeup6bAnymlLoqaLMVHr766qvAXuhHgQXtXIMVFg6pztNeIVpgBZyv8Inka5bka45ka5bka5bka5bka45dsvWrwFJKnQW8AUQCxTi6CA7UWqdorQdqrVOAAcA9wEnnuDeVUgODO+3AKKUGK6WeVkr9SylVqZSqV0odV0r9XSl1s1IqvLvneMakpJDOKethUZH2Osx1HVZBeQFaexmT6lwmWCIrQoUQQgghhPD3DNaPgRgc11md5+wieKT1AK31Ua31c8B5znExOAqxbuU8k/YVjuJvPBCPowDsi2Pj5NeAT5VSKd02yQBkZmYG9sLwcCLiooinEoBjhU1eh7nOYNU21lJ0ushzgOs6rMrDUF8Z2Fx6sIDzFT6RfM2SfM2RbM2SfM2SfM2SfM2xS7b+FliX4tg4+H6tdYd9ErXWhcD9OJYLfjOw6QWHUmoI8EegD1AE/AAYhaO4ugB42zl0EvA/3THHQI0YMSLg1zYlpljLBE8c6bjAgvZatbfqJFiyJ+C59FRdyVd0TvI1S/I1R7I1S/I1S/I1S/I1xy7Z+ltguZb6rfNxvGtcdy8RvA3HmbRm4Aqt9cvOvbyKtNafaa3nAO86x16jlErvtpn66ZNPPgn4tTolraXAOtHxEkHoZC8sCMnrsLqSr+ic5GuW5GuOZGuW5GuW5GuW5GuOXbL1t8Bqdt76eq2Sa5z3397PnBzn7X6t9eftjHnDeRsGDDM/pR4gPZ1MHMv+Tp3yPmRQcid7YSWfDWHOZpQhWGAJIYQQQgjhD38LLNdv2Jf4ON41zstv5mdUrfO2uYMxrY+101Ov5+lKu8qwrAzrDFZxqfe/CskxySTHJAPtnMEKj3IUWRCSmw3bpR2oXUm+Zkm+5ki2Zkm+Zkm+Zkm+5tglW38LrL/huKbqcaVUh2d5lFJDgV/jOHv1QWDTC5rtztsRSqkJ7YyZ47zdD+Qbn1GQTJkyJeDXhvfPsgqs0soIvDUJhE5atUPLMsGS0DuD1ZV8ReckX7MkX3MkW7MkX7MkX7MkX3Pskq2/BdZvgEoczSG2K6UWKaVylFKRAEqpSKXUBKXUIhxFTT/n+KeDOekALAZO4Viy+L9KqblKqX5KqVil1Dil1O+BuUAN8AOtdUdnunqUrVu3Bvza8FZnsBqbwqio8D6udat2r1wFVtkBaKgJeD49UVfyFZ2TfM2SfM2RbM2SfM2SfM2SfM2xS7YR/gzWWp9QSl0DrAQSgAedf1BKNbZ5P4WjYLlGa30iONMNjNa6VCk1A3gHR/fAN9sMaQbeAx7RWm9v+/qerKqqKuDXqowMMmg563TyJCQleY5rfQZLa41Syn1AqquToIbSfZCZQ6joSr6ic5KvWZKvOZKtWZKvWZKvWZKvOXbJ1q8CC0Br/ZFSKhf4LXAZLWfBIlsNawbeB36qtd7X5VkGgdZ6t3MvrGXA5DaHw3BskDyYluWEbpRS3wO+B5Cdnc369esBGDp0KAkJCezcuROAtLQ0xo4dy8aNGwGIiIhg6tSpbN++nQrnKaK8vDxOnDjB4cOOTvfDhw8nOjra2p06MzOTESNGWJ1SoqOjmTJlClu3brX+Yk2aNInCwkKqqqpYv349I0eOJDw8nN27HQVTVlYWQ4YMYdOmTQDExsYyadIkNm/eTE2N4yzTBUlJ1hksgL17S+jTp469e/cC0L9/fwYMGEDjqUYAqhuqOVV9in//69/U1dUBMHXqVArKo62uIBX5m6lsSGf//v0ADBw4kL59+1r/4pCYmEhubi6ffPIJjY2O950+fTq7du2iuLgYgJycHCorKzlw4AAAgwcPJjU1le3bHR9NSkoKOTk5bNiwwSr4ZsyYwc6dOyktLQUgNzeXkpIS8vPzu/Q51dXVWZ91Vz6nI0cc28UF8jlNmTKFgwcPcvz4cQDGjBlDU1OTx+e0efNmAOLj48nLy2PTpk1un9O+ffsoKnI0NRk3bhx1dXXd/jk1NTWRn5/f5c8pWD9PofY5VVVVUVpa2mN+nkLpc6qtrbX+29BTfp5C6XNqbm5mz549PernKZQ+p6qqKmpqanrMz1OofU6u3816ys9TKH1OQI/6eWqP0u1deOMDpVQm8B/AIBwb91bhuH5pk9bay6603Ucp9RDwEI4GFg8Cf8cx3xE4NkK+1jn0Xq31Ux29V15enu4ppyhramqIjY0N7MWffcbnF/yQiTgaK65aBbNmeQ5buWcls/80G4Att27h/P7nuw9oqIHn+wAaJj8IF/wqsPn0QF3KV3RK8jVL8jVHsjVL8jVL8jVL8jWnp2WrlNqmtc5r+7y/12C5ce4jtVJr/ZzW+lHn7aoeWFzdDzyMY8nidK3177XWh7TWJVrrfzr3wVrqHP64Uuqc7pqrvwoLCwN/cXq62xmsk+30Tmy9F5bX67AiYyFpiON+iHUS7FK+olOSr1mSrzmSrVmSr1mSr1mSrzl2ybZLBVZnlFLnKaVKlFLFJr9OJ3OIAu5zPlyhtd7bztBfOG/DgBuNTyxIXKeMA+JjgeW6Bgt86CRYvCvw+fRAXcpXdEryNUvyNUeyNUvyNUvyNUvyNccu2RotsHBc45Xs/NNdxrT6+u02sNBaFwKuM2+j2xsXUpKTiVO1xFINwInj3psnJsckkxidCPhQYJX9G5rqgz1TIYQQQgghbMF0gdUT+LNQ09UezzZt2keOHBn4i8PCaOyTaJ3FOna4yeswpZTvrdqbGx1FVojoUr6iU5KvWZKvOZKtWZKvWZKvWZKvOXbJtjcUWMdb3c9tb5BSaiCQ4Xx4yOiMgig8PLxLr29OSrEKrKJ2zmCBH5sNAxSHzobDXc1XdEzyNUvyNUeyNUvyNUvyNUvyNccu2YZ8gaW1PggcdD6cq5Qa3s7QRa3u/93srILH1aYzUDo1raXAaucaLPDcC8tD6qiW+yFUYHU1X9ExydcsydccydYsydcsydcsydccu2Qb8gWW0yPO2zhgo1Lqu0qpgUqpFKXUJKXUn4GbnWO+AFZ3yyy7gcrIINN56VlxiWp3nKvAqqqvoqSmxHNAVAIknOW4H0IFlhBCCCGEEP7we6NhO9Jav6aUGgo8AGQBS9oZugu4Smttm2uwsrKyuvT6sH6Z1hms0ooItAblpc5q26o9LS7Nc1DaGKg8FFIFVlfzFR2TfM2SfM2RbM2SfM2SfM2SfM2xS7a95QwWWusHgYnAq8Be4DTQiGPj4X8APwDytNa2uf4KYMiQIV16fXh2X6vAqmsI4/Rp7+P8atVeutfR7CIEdDVf0THJ1yzJ1xzJ1izJ16z/z96dx1dV3/kff32zJySBJJewK6CAIkqFaIpSwAXB1trababavdZfVzvtzNRu02XambbTVZ0udl9sre3YalstWBdAFFFEUQEBWRQQCCQBEghZv78/zs1CSG62+7n3ntz38/HII9vNOYfXTfrox3Pu96ivLfW1E5a2aTNgAXjv13nvr/fen+W9L/TeZ3vvy733l3vvf+S9P5HsYxyoNWvWDOnnM8pHx/9eWK1NcHjHkI4rVQy1r8SmvrbU147a2lJfW+prS33thKVtr5cIOuceisP2i+OwDbHUw82Ge/qPA6X5pYzIHsGx5mO8dLiPpdoBajZD6fQ4H6yIiIiISGqL9RqsRUAPy8VJKsnPH8htvnrQw4DVE+cck0dNZuPBjew6sqvnB5V2uT9z9SY48w1DO7YUMOS+EpP62lJfO2prS31tqa8t9bUTlraxBqyX0YCV8iorK4e2gX4OWEDngNXbJYJ5o2DEODi2b9gsdDHkvhKT+tpSXztqa0t9bamvLfW1E5a2vb4Gy3s/2Xs/JV5vifxHpZO1a9cObQMDHLAgxmuwoPMywWEyYA25r8SkvrbU147a2lJfW+prS33thKVtWi1yMRw1NDQMbQORCEXUkUMjAFVVvZ+0bF+q/WjjUQ6fONzzg9oHrJrNEJ7V7ns15L4Sk/raUl87amtLfW2pry31tROWthqw0t3IkZCR2XEWa//e3oeiAa0k2NIAR3tZDENEREREZJjSgBVy8+bNG9oGnKOlcGTHgHXgldZeHzqgAQuGxWWCQ+4rMamvLfW1o7a21NeW+tpSXzthaasBK+R27tw55G20jSrtGLCqqnp/3OmjTu/4uNel2kuH14AVj77SO/W1pb521NaW+tpSX1vqaycsbTVghdz+/fuHvpGyMsoJJqtD1a7Xh40uGE1+VrA8Zq9nsAoikD86+HgYDFhx6Su9Ul9b6mtHbW2pry31taW+dsLSVgOW4MpHd5zBqjnS+69E+72wgN7vhQXDbiVBEREREZH+0oAVcjNnzuz7QX3IHD+mY8BqaMwk1gItA16q3Yf7Vmrx6Cu9U19b6mtHbW2pry31taW+dsLSVgNWyLW29r4oRX9ljC3v972w2pdq7/U1WNA5YDXXQ92eIR9fMsWjr/ROfW2prx21taW+ttTXlvraCUtbDVght2XLliFvw40ePeCbDdeeqOXIiSM9P6jrSoI14b5MMB59pXfqa0t97aitLfW1pb621NdOWNpqwBIoKxvwgAXw0pFezmINs6XaRURERET6SwNWyE2YMGHoG4lE+n+JYH+Wai8YA3klwcchH7Di0ld6pb621NeO2tpSX1vqa0t97YSlba8DlnPuC9G3rBiPKXbOFcf4fq5z7k/OubuGeqDSs4kTJw59IwMYsPp1s2HnOu+HFfIBKy59pVfqa0t97aitLfW1pb621NdOWNrGOoP1JeCLQE5P33TOjQAOAzUxtpEFvDH6JgbWrl079I1EIoziMFk0A7EHrDEjxpCXlQekx0qCcekrvVJfW+prR21tqa8t9bWlvnbC0jYelwj2fmdaCYdIBAdEOARA1YG2Xh/qnOtYSbBf98JqPAzHwnFTOBERERGRodJrsEKusLBw6BspKqItM6vjMsF9e3ofsKDzdVj9WqodQn2ZYFz6Sq/U15b62lFbW+prS31tqa+dsLTVgBVyFRUVQ9+Ic7QWl3QMWLHOYAFMHjkZ6OclghDqASsufaVX6mtLfe2orS31taW+ttTXTljaasAKuTVr1sRlO35U54B16FDsqz7bF7qobqimvqm+5wcVToCcouDjEN8LK159pWfqa0t97aitLfW1pb621NdOWNpqwAq5xsbG+GwoEqGcKgCqa2P/WvRrqXbnTl7oIqTi1ld6pL621NeO2tpSX1vqa0t97YSlrQYsASBjTHnHGaz6hkxi/f72a6l26LJU++ahH6CIiIiISAhowAq5+fPnx2U7GePHnHQvrEOHen9svwes9jNYDQfheIy131NYvPpKz9TXlvraUVtb6mtLfW2pr52wtO3PgDXJOXda9zdgUvsDnHN9PkZsbN26NS7bySgf3e+bDY8tHEtOZnB7tNgD1tmdH9eE8yxWvPpKz9TXlvraUVtb6mtLfW2pr52wtO3PgLUJ2NnD20ag/Q6yu2I8RgxVVVXFZ0ORSL8HrAyXwWkjTwPgpSPDe6n2uPWVHqmvLfW1o7a21NeW+tpSXzthadvXgOXi8CZhMIABCzovE4x5Bqv4dMjKDz4O6YAlIiIiIjIQWTG+9+WEHYUM2qxZs+KzobKygQ1Y/bkXlsuA0rOhan1oB6y49ZUeqa8t9bWjtrbU15b62lJfO2Fp2+uA5b3XgBUC8VymvZQaMmiljcw+B6z2pdoPHj/IsaZjjMgZ0fMDy2aGesAKy3KgYaW+ttTXjtraUl9b6mtLfe2Epa1WEQy5bdu2xWdDkQgZeMqoBqCqysd8eNeVBF8+8nLvD2x/HdaxfXCidqhHmXBx6ys9Ul9b6mtHbW2pry31taW+dsLSVgOWBCIRgI7LBA/sa4v58AEv1Q66H5aIiIiIDHuxXoM1IM65+cD5QAHwCvCQ935vvLYvPZs0KU4r4Y8YQVtWDqNbug5Ymb0+fHAD1iaYcNHQjjPB4tZXeqS+ttTXjtraUl9b6mtLfe2EpW2vA5ZzLhf4p+inj3rvt/fyuLOA3wPndvtWm3PuR8C/eO9b43GwcqoxY8bEZ0PO0TqyhNHVwYDV12uwxhWOIysji5a2lthLtY+cApm50NoINeF7HVbc+kqP1NeW+tpRW1vqa0t9bamvnbC0jXWJ4MXAL4EfA8d6eoBzbgzwEMFw1X159kzgw8Bt8Ttc6W7dunVx25YvLaOc4P4C1TWxrx7NzMjsuBdWzDNYGVlQOiP4OIQLXcSzr5xKfW2prx21taW+ttTXlvraCUvbWP8vemH0/d+99/t7ecxXgLHRj7cBbwVmAlcAqwgGrfc65yricKxizHW5F9aR+kyam2M/vl/3wgIojV4mGMIBS0RERERkIPo6g+WBv/T0TedcIXBd9DEHgXne+7u89y947x8gGLI2RB/+rvgdsnRVXFwct21ljC0/6V5Y1dWxH3/6yGCp9j4HrPbXYdXthsajQzjCxItnXzmV+tpSXztqa0t9bamvLfW1E5a2sQas6dH3T/Ty/UVAfvTjH3rva7p+03vfBHyX4CzWvCEco8QwZ86cuG0rY+zogd1sOHoG68CxAzQ0N/T+wK4LXdS8MIQjTLx49pVTqa8t9bWjtrbU15b62lJfO2FpG2vAikTfv9LL9y/u8vHfennMo9H3UwZyUNJ/q1evjtu23OjBDVjQz3thQeguE4xnXzmV+tpSXztqa0t9bamvLfW1E5a2sQas9jW6R/Ty/fbXVTUCz/TymEPR90UDPC7pp5aWlvhtrMtrsGBgA1bMywRHnRksdgGhG7Di2ldOob621NeO2tpSX1vqa0t97YSlbawBq/2Sv8ndv+GcywQuJHj91TMxlmEviL4PR410N8ABq/01WEDspdozs6EkesVpCJdqFxERERHpr1gD1rPR99f18L3L6TwrtSLGNiZH3x8Y0FFJvy1YsCB+G4tEKKNzZYu+BqwJxRPIdMGJzn4vdBGyM1hx7SunUF9b6mtHbW2pry31taW+dsLSNtaAdQ/BAhXvcc5d1f7F6L2vvtblcX+IsY2Lou9TamUD59wS59zvnHM7nXMNzrlq59yzzrkfO+eWJvv4BmLjxo3x21hZGVm0UhodsvoasLIyspg0Mrijdr+Xaj+yC5p7vK1aSoprXzmF+tpSXztqa0t9bamvLfW1E5a2sQasXwA7gRzgHufcC865J4DtwGyCywMf8N739vorgH+KPu7xOB3vkDjnRjjn7gKWAW8nOMOWB5QS3Cz5A8Cnk3aAg1Dd11rqAxEJ1jVpv0yw6oDv80f6fS+sjoUuPNRsGeQBJl5c+8op1NeW+tpRW1vqa0t9bamvnbC07XXA8t43ANcQLFThCJZtn0vwuioH7AWu7+3nozcXbl8I4x9xOt5Bc87lEKx2+CagCfgWwevIRgPjCS57/CEQjmfOQrcBa/8rbX3+SPvrsGK+BgtCvZKgiIiIiEh/ZcX6pvf+Wefc2cC/AJcRLN1eAzwIfNd7H2sYuQZ4CjjqvV8Tp+Mdik8T3LvrOLDEe999ncd9BP+uUJk9e3b8NlZQQFtOHqObomewqvp/BuuVuldobGkkNyu35weWTAeXAb4tVANWXPvKKdTXlvraUVtb6mtLfW2pr52wtI11azOmkgAAIABJREFUiSAA3vsa7/0XvPcXe+9neO/nee8/38dwhff+c977C7z3l8XvcAfHOVcGfCb66Vd6GK5Cq66uLq7baxtV0nEGq7ra9fn4ft8LKys3WK4doGbzUA4xoeLdV06mvrbU147a2lJfW+prS33thKVtnwPWMPFOgtdaNQE/SvKxxNWOHTviuj1fGqGcKgBqj2bQ2tsC/FH9XqodQrmSYLz7ysnU15b62lFbW+prS31tqa+dsLRNlwGrfWXAJ733h9u/6JzLdM71fZomjbjyznthee+oqYn9+H7fbBig9Ozg/eEXoaVx8AcpIiIiIpKi0mXAmht9v8k5l+Oc+6xzbgvQCDQ757Y6577hnIsk8RgHZfLkyXHdXsbY8gHdbHhi8UQyXPBr1O+VBH0b1G4dwlEmTrz7ysnU15b62lFbW+prS31tqa+dsLTtdZEL51w8r+Py3vtz4ri9fnPO5RMszgHBJYKPEKwe2NU04FPAO51zV3rvNyTwEIektLQ0rtvLKB/NaDpfI9XXgJWdmc3E4om8fOTlASzVTnCZ4OhzB3+gCRLvvnIy9bWlvnbU1pb62lJfW+prJyxtY53BOguYEX0fj7dkGdnl4w8QDFd3AecBucBpwH8CbcA4gnt+FSX6IAdr/fr18d1gJDKgM1gwgKXaS88iWOGf0LwOK+595STqa0t97aitLfW1pb621NdOWNrGXKY96giwHGgwPhYrXYfIHOAvwFu99+1rkO8GvuicO0pwb6zTgRuAb3fdiHPuhujXGT9+PCtWrABg6tSpFBUVsWFDcNKrrKyMc845h1WrVgGQlZXF/PnzWb9+PUePHgWgoqKCAwcOsHv3bgCmTZtGbm4uzz//PADl5eVMnz6d1auDxQ5zc3OZN28e69ato76+HoDKykr27NlDfX09K1asYMaMGWRmZrJpUzC4jB07lilTprBmTbBCfn5+PpWVlaxdu5aGhuCpnDdvHjt37mT//v0AzJw5k9zs7JMGrL17m1ix4jEACgsLqaioYM2aNTQ2Bq+hmj9/PiWuBIAtB7Zw6NAhGhsb2bZtGwCTJk1izJgxrFu3Lthn3nhyT+zl0NZVPN8cNFywYAEbN27suHnc7Nmzqaur63gh4+TJkyktLe34oyopKWH27NmsXLkS7z3OORYuXMiGDRuora0FYM6cOdTU1LBr164hPU+NjY0dz/VQnqe9e/cCxO15am1tZcuW4IbNEyZMYOLEiaxduzbm87R161aqqoIFTGbNmhXzeSouLmbOnDmsXr2alpYWs+eptbWVXbt2Dfl5itff03B7nurr66mtrU2Zv6fh9DydOHGi438bUuXvaTg9T21tbbzwwgsp9fc0nJ6n+vp6GhoaUubvabg9T+3/3yxV/p6G0/MEpNTfU29c55zR7RvOtd9l1gP1wJ+B3wIP+N5+KAU550YCh7t8aY73/ukeHpcDvAKUAY947xf0ts2KigofK2oibdiwIb73BLjzTpr++Z3k0gTAl78MX/hC7B/5wsNf4CurvoLDceLzJ8jJzOn9wX++CnbcG1wu+J6N8TtuI3HvKydRX1vqa0dtbamvLfW1pb52Uq2tc+4p731F96/HukTwDOBLwDagiGCp82XAHufct51z51scqIE6iE4LwaD4TE8P8t43AWujn87s6TGpKO6/ZJEIOTQzMjqTDuQSQY9nz9E9sR9cGk1buxVam4dypAmRSn/Ew5H62lJfO2prS31tqa8t9bUTlra9Dlje+53e+//03p8FVALfBw4SvE7pX4B1zrlN0RX5JifiYAfDe98GtC9Zd7iPs2+10ffFtkcVPytXrozvBiPBeiDtlwkePNj3ycoBLdXevtBFW0uwXHuKi3tfOYn62lJfO2prS31tqa8t9bUTlrb9Wqbde/+k9/5GYALwOuBOgtdknQV8BdjunHvEOff/nHOpuLxH+/V8JX3c96os+v6I8fHETdyv1iwLErQPWPtfMRqwIBQLXYToathQUl9b6mtHbW2pry31taW+dsLSdkD3wfLet3rv/+69vxYYA7wHeJBgBb6LgR8Arzjn7nYuuvJBargn+n4EcMp1kgDOuVyCM3XQy2WEqSju90nuNmBVHej7F3nSyEm46OqAfQ9YZ3d+HIIBS/ehtqW+ttTXjtraUl9b6mtLfe2Epe2gbzTsvT/mvf+19/4KYBLwr8BLBCv1vR4YHZ9DjIv7gJ3Rj7/inOvp3/3vQPtQ+PuEHFUcLFy4ML4bzM+nLa+gY8A6dKjvH8nJzGF80XigH0u15xRB0aTg4xAMWHHvKydRX1vqa0dtbamvLfW1pb52wtJ20ANWu+gqfVcBbyC4p1TKiS5g8QmCFRGXAH9zzr3aOVfinDvLOfctgnthATwF/DpJhzpg7ctQxlPbqFLKCZbhrDmcQVtbHz9A52WC26q39f3g9ssEa1J/wLLoK53U15b62lFbW+prS31tqa+dsLQd1IDlnMtxzr3JOfcnYD9wG7CAYIBZDrwL2BG3o4wD7/09BItztABXAmuAGmAzwdk3R3Bp4Bu896m/vF1U+30A4ipS1nEGq7XNcfhwH48Hzh8bLCr55CtPUtdYF/vBHQPWlmCxixRm0lc6qK8t9bWjtrbU15b62lJfO2FpO6AByzm3yDn3E4Kh6o/AG4FcgrM+/wJM8N5f6b3/rfc+5f6fs/f+FoLXWf0aeJlg+fbDwCPAR4BK7/3e5B1hanBjyk+62XB/lmpfeuZSAFraWnh418OxH9y+VHtrIxzZGfuxIiIiIiIhktXXA5xz5wHXAW8nWEWw/dVl24HfAbd77/txXVhq8N6vB96d7OOIlzlz5sR9mxljRp8yYM2YEftnFk1eRE5mDk2tTSx/cTlXz7i69wd3X0mwZNoQj9iORV/ppL621NeO2tpSX1vqa0t97YSlba9nsJxzNznnngWeJlgAYiJQTXA/rIu899O8918M03A1HNXU1MR9my4SGfAZrBE5I5h/2nwAlm1fFvvBIVpJ0KKvdFJfW+prR21tqa8t9bWlvnbC0jbWJYJfA84BjgN3ENz/aqz3/mPe+8cTcXDSt127dsV/o4MYsACWnhFcJrijdgcv1sS4iXBeCYwYF3yc4gOWSV/poL621NeO2tpSX1vqa0t97YSlbX9eg5UDXAPcBdQ7544P4u2Y7T9D4mqQA9aSM5d0fLz8xeWxH9x+mWCKD1giIiIiIgPR14DlgGwgLw5vYmDq1Knx32gkQh6NFBKsBtjfAevc8nMZVxicmer7MsH2lQQ3g+/HOvBJYtJXOqivLfW1o7a21NeW+tpSXzthaRtrkYsvJ+woZNCKioriv9FIBIDRHKSeon4PWM45lpy5hF8+80se3vkwTa1N5GTm9Pzg9gGrpQGOvgQjp8ThwOPPpK90UF9b6mtHbW2pry31taW+dsLSttcBy3uvASsENmzYwKJFi+K70S4D1k6mUlXl6Vw8MrYlZwQD1rHmYzz68qNcMuWSnh940kqCm1N2wDLpKx3U15b62lFbW+prS31tqa+dsLQd1I2GZZgrKwPoeB3WgX39v4Rv8dTFuOgwtuzFGJcJlnZbql1EREREZBjQgBVyZdFhKM4bBToHrP5eIghQVlDGBRMuAGD59hgLXRREID84U5bKA5ZJX+mgvrbU147a2lJfW+prS33thKWtBqyQO+ecc+K/0dxc2goKOwas6poMvO//jy85I1hNcMOBDeyr29f7AzsWukjdAcukr3RQX1vqa0dtbamvLfW1pb52wtJWA1bIrVq1ymS7bSWllFMFQHOL4+jR/v/s0jOXdnx8//b7e39g16XaBzLBJZBVXwmory31taO2ttTXlvraUl87YWmrAUt65EYP7l5YABdOuJCRuSOBPi4TbH8dVlMd1O8dzGGKiIiIiKQUDVghl5UVa6X9wcsYUz7oASsrI4vLp14OBGewWttae35gWeovdGHVVwLqa0t97aitLfW1pb621NdOWNpqwAq5+fPnm2zXlY8e9IAFnZcJVjdUs37f+p4fFIIBy6qvBNTXlvraUVtb6mtLfW2pr52wtNWAFXLr1/cyvAxVWdmQBqz2hS4gxmWCI8ZC7qjg4xQdsMz6CqC+1tTXjtraUl9b6mtLfe2Epa0GrJA7OpDVJwYiMvjXYAFMGjmJmaODM1S93g/LuZMXukhBZn0FUF9r6mtHbW2pry31taW+dsLSVgOW9CwSYQTHyec4MPABCzrPYj2+53GOnDjS84O6LtWeoisJioiIiIj0lwaskKuoqLDZcCS4CfBgbjbcrn3AavWtPLjzwZ4f1D5gnaiF4wcGvhNjZn0FUF9r6mtHbW2pry31taW+dsLSVgNWyB04YDSUnDJgDfzs0oLTF5CXlQfEuEwwxRe6MOsrgPpaU187amtLfW2pry31tROWthqwQm737t02G+42YB3YP/ABKz87n4WnLwSChS58T5cAlqb2gGXWVwD1taa+dtTWlvraUl9b6msnLG01YEnPug1YVYP8Dwbtlwm+fORltlRvOfUBRRMhuzD4OAUHLBERERGRgdCAFXLTpk2z2XBpKdA5YB2qcYNag6L9fljQy2WCKb6SoFlfAdTXmvraUVtb6mtLfW2pr52wtNWAFXK5ubk2G87Opq2wmHKqAGhsdBw7NvDNnBU5i0nFk4AY98NK4QHLrK8A6mtNfe2orS31taW+ttTXTljaasAKueeff95s2750aDcbBnDOdVwmuGLXChqaG059UPuA1XAQjg9iJ4Ys+4r6WlNfO2prS31tqa8t9bUTlrYasKRXrnxoNxtu136Z4ImWEzzy8iOnPqDrSoI1mwe3ExERERGRFKABK+TKy8vNtu3GlMdlwLps6mVkukwAlr/Yw2WCKbxUu2VfUV9r6mtHbW2pry31taW+dsLSVgNWyE2fPt1s2y4SnzNYo/JG8eqJrwZg2fYeFrooPh2y8oOPU2zAsuwr6mtNfe2orS31taW+ttTXTljaasAKudWrV9ttPE4DFnQu177p4CZ2H+l2DwOXAaVnBx+n2IBl2lfU15j62lFbW+prS31tqa+dsLTVgCW9KyujiDpyaASGOGCduaTj4/u339/DvqKXCeo1WCIiIiISYhqwQs50ucpIBEfnvbCGMmDNHTeXsvwyoJfLBNsHrPpX4MThwe8ozsKyHGhYqa8t9bWjtrbU15b62lJfO2FpqwEr5ObNm2e38UgEiM+AlZmRyeIzFgPwwI4HaGlrOfkBKbqSoGlfUV9j6mtHbW2pry31taW+dsLSVgNWyK1bt85u490HrCo/pM21vw7r8InDPLn3yZO/2f4aLEip12GZ9hX1Naa+dtTWlvraUl9b6msnLG01YIVcfX293ca7DVgH9sdnwAJY9mK3ywRHTYXMnODjFBqwTPuK+hpTXztqa0t9bamvLfW1E5a2GrCkd93PYB0a2ubGFY3jvDHnAbB8e7f7YWVkQcmM4OMUGrBERERERAZCA1bIVVZW2m28pATvXMeAdbwhg4aGoW2y/SzWE3ufoPp49cnfbH8dVgoNWKZ9RX2Nqa8dtbWlvrbU15b62glLWw1YIbdnzx67jWdl4YtGUk5Vx5eGstAFwNIzlwLg8Tyw44GTv9k+YNW9DE11Q9tRnJj2FfU1pr521NaW+tpSX1vqaycsbTVghdzevXttd1BWFrebDQNcPOliCrILgB4uEzxpJcEXhrajODHvm+bU15b62lFbW+prS31tqa+dsLTVgCUxuTGj4zpg5WblcumUS4FgwPK+y8IZXQesFLpMUERERESkvzRghdyMGTNMt+9Gx3fAgs7XYb1S9wrPVz3f+Y1RZwaLXUDKDFjWfdOd+tpSXztqa0t9bamvLfW1E5a2GrBCLjMz03YHkYjZgAXdLhPMzIFR04KPU2TAMu+b5tTXlvraUVtb6mtLfW2pr52wtNWAFXKbNhkPIpEIozhMFs1AfAasM0vPZGrJVKCH+2Gl2EqC5n3TnPraUl87amtLfW2pry31tROWthqwJLZIBAdECG6CFY8ByznXcRbrkZcf4VjTsc5vtg9YR3ZC8/Gh70xEREREJIE0YIXc2LFjbXdQVgZ0udlwHAYs6LxMsKm1iZUvreyyv/aFLjzUbInPzobAvG+aU19b6mtHbW2pry31taW+dsLSNm0HLOfcmc65Buecj769J9nHNBhTpkyx3UEkAnQdsHysR/fbpVMuJSu6oMVJlwmetFR78k8Dm/dNc+prS33tqK0t9bWlvrbU105Y2qbtgAX8EMhL9kEM1Zo1a2x30G3AOnAgPpstyi3i4kkXA90WuiiZDi76a5kCr8My75vm1NeW+tpRW1vqa0t9bamvnbC0TcsByzn3DuByYGeyjyXldT+DVRW/TbdfJri1eis7a6NPRVYejDoj+DgFBiwRERERkYFIuwHLOVcCfBtoBT6R5MMZsvz8fNsddBuw6uodjY3x2fTSM5d2fHzSWazS1FlJ0LxvmlNfW+prR21tqa8t9bWlvnbC0jbtBizgm0A5cCuwIcnHMmSVlZW2Oxg1Cp+RQTmdp64OHYrPpmePnU35iHKg24DV/jqswy9CS5ymuUEy75vm1NeW+tpRW1vqa0t9bamvnbC0TasByzk3H3gfsA/4YpIPJy7Wrl1ru4PMTPzIkrjfbBggw2V0XCb44I4HaW4N7rXVMWD5NqjdGp+dDZJ53zSnvrbU147a2lJfW+prS33thKVt2gxYzrls4DbAAZ/03h9N8iHFRUNDg/1OImUmAxZ0vg6rrqmONXuiL1zsupJgki8TTEjfNKa+ttTXjtraUl9b6mtLfe2EpW3aDFjAp4CZwAPe+98n+2DCxJWPNhuwFp+xuOPj5S9GLxMsPYtgDibpA5aIiIiIyECkxYDlnDsD+DzQBHw0yYcTV/PmzTPfh4tEzAas8hHlzB03F4Bl26P3w8ougJGTg49rNsdvZ4OQiL7pTH1tqa8dtbWlvrbU15b62glL26xkH0CCtN/z6r+991sGswHn3A3ADQDjx49nxYoVAEydOpWioiI2bAjWyygrK+Occ85h1apVAGRlZTF//nzWr1/P0aPBVYkVFRUcOHCA3bt3AzBt2jRyc3N5/vnnASgvL2f69OmsXr0agNzcXObNm8e6deuor68Hghf57dmzh+3bt5OXl8eMGTPIzMxk06bgjM/YsWOZMmVKx/0C8vPzqaysZO3atR2nV+fNm8fOnTvZv38/ADNnzqS1tZUtW4JEEyZMYOLEiRxubmYMNWTQShuZPP30HlaseBGA+fPns3XrVqqqgkUwZs2aRWNjI9u2bQNg0qRJjBkzhnXr1gFQXFzMnDlzWL16NS0tLQBcMfUKntr3FOv3refP9/+ZRRcsIq9gCvlHdnLs5Sc5uGsXpaWlrF+/HoCSkhJmz57NypUr8d7jnGPhwoVs2LCB2tpaAObMmUNNTQ27du0a0vP03HPP0RhdNnEoz9PevXsBTJ+n9uuSCwsLqaioYM2aNR3HHo/nacGCBWzcuJHq6moAZs+eTV1dHTt27ABg8uTJA36eSkpKGDly5JCfp3j9PQ235+nEiRNUVlYO+XmK19/TcHqennjiCVpbW+PyPEF8/p6G0/MUiUTIyspKqb+n4fQ8nThxgoULF6bM39Nwe56qqqrIy8tLmb+n4fQ8jRkzhsbGxpT5e+qN8973+s3hwDl3LfBbYBcw03vf0OV7k+m8F9Z7vfe/7M82KyoqfKyoibRixQoWLVpku5NPfxq+8Q3KOcBByrnhBrjttvhtftVLq1j4y4UA3H7N7Vx33nWw8t9h3bcgIxtuPAaZ2fHb4QAkpG8aU19b6mtHbW2pry31taW+dlKtrXPuKe99RfevD+tLBKP3vPpO9NMbuw5XMgDdbzYcx0sEAeZNnEdRThHQ5TLB9oUu2prh8Pb47lBERERExMiwHrCALwBjgL947/+a7IOxMHPmzL4fNFTGA1Z2ZjaXTb0MgPu330+bbzt5JcGa5C10kZC+aUx9bamvHbW1pb621NeW+toJS9vhPmBNib6/2jnnu7/ReXkgwC+6fG9ywo90kNpfA2CqrAzoOmDF/7LS9uXaq45VsWH/Big9u/ObSVxJMCF905j62lJfO2prS31tqa8t9bUTlrbDfcAa9tpfoGiq2xmsqgPx30X7gAWw7MVlkFsMhRODLyRxwEpI3zSmvrbU147a2lJfW+prS33thKXtcB+wPgGcH+PtdV0e+8UuX38lsYeZ4roNWLWHHc3N8d3FlJIpTC+bDsDy7dH7YbVfJqh7YYmIiIhISAzrZdq99ztjfd85d7jLpy97758xPqS4mzBhgv1Oug1YANXVMHZsfHez9IylbK3eyqO7H+Vo41GKy2bCS/dDzQvQ1goZmfHdYT8kpG8aU19b6mtHbW2pry31taW+dsLSdrifwRr2Jk6caL+TkSPxmZmUU9XxpXgvdAGw5MzgMsGWthYe3vlw5xms1kY4EnNWNpOQvmlMfW2prx21taW+ttTXlvraCUtbDVgh135TOFMZGfiS0pPOYFkMWAtPX0hOZg4QvUyw60qCSbpMMCF905j62lJfO2prS31tqa8t9bUTlrYasKRfXCRiPmCNyBnBgtMXAMFCF77krM5v6nVYIiIiIhICaT1gee93ee9d9O2XyT6ewSgsLEzIftxo+wELOlcT3Hl4Jy821MCI6Au9knQvrET1TVfqa0t97aitLfW1pb621NdOWNqm9YA1HFRUVCRmR5EIZVR3fGo9YEG3ywSTdAYrYX3TlPraUl87amtLfW2pry31tROWthqwQm7NmjWJ2VEkQhatlESHLKsBa1b5LMYXjQei98MqbR+wNoNvs9lpDAnrm6bU15b62lFbW+prS31tqa+dsLTVgBVyjY2NidlRdKn28uhlglYDlnOu4yzWw7sepnHUtOAbLcfh6Ms2O40hYX3TlPraUl87amtLfW2pry31tROWthqwpH+63QvLasCCzssEjzcf59GW1s5vaKELEREREUlxGrBCbv78+YnZ0SkDljfb1eVTLyfDBb+ay6q3d34jCQNWwvqmKfW1pb521NaW+tpSX1vqaycsbTVghdzWrVsTs6OyMqBzwKo6YLirgjIuGH8BAMtffgTyg+EuGQNWwvqmKfW1pb521NaW+tpSX1vqaycsbTVghVxVVVVidtTtDFZ1DbS2xvqBoVl65lIAnj3wLK8UnxF8MQlLtSesb5pSX1vqa0dtbamvLfW1pb52wtJWA5b0T7cBy3tHTY3d7rou136/yw8+qN4E3u7SRBERERGRodKAFXKzZs1KzI46VhHs/C8HlgtdXDDhAkbljQJg+fGjwReb6qB+r91Oe5CwvmlKfW2prx21taW+ttTXlvraCUtbDVghl7DlKouL8VlZHWewwHbAysrIYvHUxQDcX72N1vYTV9Wb7Xbag7AsBxpW6mtLfe2orS31taW+ttTXTljaasAKuW3btiVmR85BWVnCBizovEywprGOp9rvMZzg12ElrG+aUl9b6mtHbW2pry31taW+dsLSVgOW9N/o0YkdsM7sfB3WcvKCD3QvLBERERFJYRqwQm7SpEkJ25crKyPCoY7PrQesicUTOWf0OQAs89nBFxM8YCWybzpSX1vqa0dtbamvLfW1pb52wtJWA1bIjRkzJnE7i0TIoZlijgD2AxZ0Xia49kQ9hz1QvTGhKwkmtG8aUl9b6mtHbW2pry31taW+dsLSVgNWyK1bty5xO+u2VHtCBqzoZYKteB5sBU7UwvHE3QMhoX3TkPraUl87amtLfW2pry31tROWthqwpP+6LdWeiAFrwekLyM8K7oO1rCX6Rb0OS0RERERSlAaskCsuLk7czpJwBisvK4+FkxcCsLw1enVgAgeshPZNQ+prS33tqK0t9bWlvrbU105Y2mrACrk5c+YkbmenDFiJeS3U0jOWArDbw+YED1gJ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\n",
      "text/plain": [
       "<Figure size 864x648 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "X=[]\n",
    "for i in range(len(train_losses_SPPA_lr001)):\n",
    "    X.append(i)\n",
    "\n",
    "plt.figure(figsize=((12,9)))\n",
    "\n",
    "plt.plot(X, train_losses_SPPA_lr001, label=\"SPPA-GN (lr=0.01)\",linewidth=2.5, color=\"purple\")\n",
    "#plt.plot(X, train_losses_SPPA_lr, label=\"SPPA-GN (1/t)\",linewidth=2.5, color=\"red\")\n",
    "plt.plot(X, train_losses_SPPA_lr2, label=\"SPPA-GN (1/sqrt(t))\",linewidth=2.5, color=\"red\")\n",
    "plt.plot(X, train_losses_adam, label=\"Adam\",linewidth=2.5, color=\"darkorange\")\n",
    "plt.plot(X, train_losses, label=\"SGD with Momentum \",linewidth=2.5, color=\"blue\" )\n",
    "plt.plot(X, train_losses2, label=\"SGD \",linewidth=2.5, color=\"green\" )\n",
    "plt.xticks(fontsize=26)\n",
    "plt.yticks(fontsize=26)\n",
    "\n",
    "plt.title(\"Boston House Prices Dataset \\n Regression\",fontsize=26)\n",
    "plt.xlabel(\"Epoch (Batch Size 1) \", fontsize=26)\n",
    "plt.ylabel(\"MSE Loss\", fontsize=26)\n",
    "plt.grid(linestyle=\"--\")\n",
    "plt.legend(fontsize=18)\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"BostonSPPA20.png\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
