{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7c42a7ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "from reluNets.plotting.network_plotting_functions import plot_single_metric_axis, save_figure\n",
    "import matplotlib.colors as colors\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader\n",
    "from torchvision import datasets, transforms\n",
    "import numpy as np\n",
    "import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d3663df",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters in layer 1: 401408\n",
      "Number of parameters in layer 2: 5120\n"
     ]
    }
   ],
   "source": [
    "# hyperparameters\n",
    "input_size = 784\n",
    "hidden_size = 512\n",
    "output_size = 10\n",
    "leak = 0.1\n",
    "bias_magnitude = 0\n",
    "lr = 0.0005\n",
    "init_scale = 0.0002\n",
    "bias_init_scale = 0.0002\n",
    "has_bias = False\n",
    "num_epochs = 10\n",
    "\n",
    "# define a pytorch model and initialize weights as small gaussian\n",
    "class ReluNet(torch.nn.Module):\n",
    "    def __init__(self, input_size=input_size, hidden_size=hidden_size, output_size=output_size, has_bias=False):\n",
    "        super(ReluNet, self).__init__()\n",
    "        self.fc1 = torch.nn.Linear(input_size, hidden_size, bias=has_bias)\n",
    "        self.fc2 = torch.nn.Linear(hidden_size, output_size, bias=False)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = x.view(-1, input_size)\n",
    "        x = torch.relu(self.fc1(x))\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        x = x.view(-1, input_size)\n",
    "        return torch.relu(self.fc1(x))\n",
    "    \n",
    "# initialize the model\n",
    "model = ReluNet()\n",
    "# initialize the weights\n",
    "init_weights_1 = torch.randn_like(model.fc1.weight.data)*init_scale\n",
    "init_weights_2 = torch.randn_like(model.fc2.weight.data)*init_scale\n",
    "\n",
    "# intialize the biases\n",
    "if has_bias:\n",
    "    init_bias_1 = torch.randn_like(model.fc1.bias.data)*bias_init_scale\n",
    "    model.fc1.bias.data = init_bias_1\n",
    "\n",
    "model.fc1.weight.data = init_weights_1\n",
    "model.fc2.weight.data = init_weights_2\n",
    "\n",
    "# copy and detach weights to keep them for later use\n",
    "init_weights_1 = init_weights_1.detach().clone()\n",
    "init_weights_2 = init_weights_2.detach().clone()\n",
    "\n",
    "print(f\"Number of parameters in layer 1: {model.fc1.weight.data.numel()}\")\n",
    "print(f\"Number of parameters in layer 2: {model.fc2.weight.data.numel()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "315154f7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computing per-pixel means...\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Computed means for 60000 images. Mean range: [0.0000, 0.5473]\n",
      "Masking 140 pixels (out of 784) with mean > 0.5\n",
      "Masked pixel positions: [180, 181, 182, 183, 184, 185, 186, 207, 208, 209]...\n"
     ]
    }
   ],
   "source": [
    "# First, load raw MNIST data without normalization to compute pixel means\n",
    "raw_transform = transforms.Compose([transforms.ToTensor()])\n",
    "raw_train_dataset = datasets.MNIST(root='./data', train=True, download=True, transform=raw_transform)\n",
    "\n",
    "# Compute per-pixel mean across entire training set\n",
    "print(\"Computing per-pixel means...\")\n",
    "pixel_sums = torch.zeros(784)\n",
    "num_samples = len(raw_train_dataset)\n",
    "\n",
    "# Use a dataloader to efficiently compute means\n",
    "temp_loader = DataLoader(raw_train_dataset, batch_size=1000, shuffle=False)\n",
    "for images, _ in temp_loader:\n",
    "    # Flatten images and accumulate pixel sums\n",
    "    flattened = images.view(-1, 784)\n",
    "    pixel_sums += flattened.sum(dim=0)\n",
    "\n",
    "# Compute per-pixel means\n",
    "pixel_means = pixel_sums / num_samples\n",
    "print(f\"Computed means for {num_samples} images. Mean range: [{pixel_means.min():.4f}, {pixel_means.max():.4f}]\")\n",
    "\n",
    "\n",
    "# Custom transform that subtracts per-pixel means\n",
    "class PerPixelNormalizeBias:\n",
    "    def __init__(self, pixel_means, bias_magnitude):\n",
    "        self.pixel_means = pixel_means\n",
    "        self.bias_magnitude = bias_magnitude  # Bias pixel magnitude\n",
    "    \n",
    "    def __call__(self, tensor):\n",
    "        # Flatten, subtract means, return flattened\n",
    "        flattened = tensor.view(-1)\n",
    "        flattened = flattened - self.pixel_means\n",
    "        # add a bias pixel by concatenating a bias pixel\n",
    "        bias_pixel = torch.ones(1) * bias_magnitude\n",
    "        flattened = torch.cat((flattened, bias_pixel))\n",
    "        return flattened\n",
    "\n",
    "class PerPixelNormalize:\n",
    "    def __init__(self, pixel_means):\n",
    "        self.pixel_means = pixel_means\n",
    "    \n",
    "    def __call__(self, tensor):\n",
    "        # Flatten, subtract means, return flattened\n",
    "        flattened = tensor.view(-1)\n",
    "        flattened = flattened - self.pixel_means\n",
    "        return flattened\n",
    "\n",
    "class AddBias:\n",
    "    def __init__(self, bias_magnitude):\n",
    "        self.bias_magnitude = bias_magnitude  # Bias pixel magnitude\n",
    "    \n",
    "    def __call__(self, tensor):\n",
    "        # Flatten and add a bias pixel\n",
    "        flattened = tensor.view(-1)\n",
    "        bias_pixel = torch.ones(1) * self.bias_magnitude\n",
    "        flattened = torch.cat((flattened, bias_pixel))\n",
    "        return flattened\n",
    "\n",
    "# Create transform with per-pixel mean subtraction\n",
    "transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    PerPixelNormalize(pixel_means),\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1be892b8",
   "metadata": {},
   "outputs": [],
   "source": [
    "train_dataset = datasets.MNIST(root='./data', train=True, download=True, transform=transform)\n",
    "test_dataset = datasets.MNIST(root='./data', train=False, download=True, transform=transform)\n",
    "\n",
    "# create data loaders\n",
    "batch_size = 64\n",
    "train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3c3c954",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10], Loss: 0.3476\n",
      "Epoch [2/10], Loss: 0.1429\n",
      "Epoch [3/10], Loss: 0.1181\n",
      "Epoch [4/10], Loss: 0.1074\n",
      "Epoch [5/10], Loss: 0.0987\n",
      "Epoch [6/10], Loss: 0.0913\n",
      "Epoch [7/10], Loss: 0.0848\n",
      "Epoch [8/10], Loss: 0.0794\n",
      "Epoch [9/10], Loss: 0.0748\n",
      "Epoch [10/10], Loss: 0.0709\n",
      "Epoch [1/10], Loss: 0.3475\n",
      "Epoch [2/10], Loss: 0.1436\n",
      "Epoch [3/10], Loss: 0.1184\n",
      "Epoch [4/10], Loss: 0.1074\n",
      "Epoch [5/10], Loss: 0.0986\n",
      "Epoch [6/10], Loss: 0.0910\n",
      "Epoch [7/10], Loss: 0.0845\n",
      "Epoch [8/10], Loss: 0.0791\n",
      "Epoch [9/10], Loss: 0.0746\n",
      "Epoch [10/10], Loss: 0.0707\n",
      "Epoch [1/10], Loss: 0.3473\n",
      "Epoch [2/10], Loss: 0.1426\n",
      "Epoch [3/10], Loss: 0.1182\n",
      "Epoch [4/10], Loss: 0.1075\n",
      "Epoch [5/10], Loss: 0.0988\n",
      "Epoch [6/10], Loss: 0.0912\n",
      "Epoch [7/10], Loss: 0.0847\n",
      "Epoch [8/10], Loss: 0.0792\n",
      "Epoch [9/10], Loss: 0.0747\n",
      "Epoch [10/10], Loss: 0.0709\n",
      "Epoch [1/10], Loss: 0.3498\n",
      "Epoch [2/10], Loss: 0.1433\n",
      "Epoch [3/10], Loss: 0.1183\n",
      "Epoch [4/10], Loss: 0.1077\n",
      "Epoch [5/10], Loss: 0.0990\n",
      "Epoch [6/10], Loss: 0.0915\n",
      "Epoch [7/10], Loss: 0.0850\n",
      "Epoch [8/10], Loss: 0.0795\n",
      "Epoch [9/10], Loss: 0.0748\n",
      "Epoch [10/10], Loss: 0.0709\n",
      "Epoch [1/10], Loss: 0.3485\n",
      "Epoch [2/10], Loss: 0.1437\n",
      "Epoch [3/10], Loss: 0.1186\n",
      "Epoch [4/10], Loss: 0.1080\n",
      "Epoch [5/10], Loss: 0.0993\n",
      "Epoch [6/10], Loss: 0.0917\n",
      "Epoch [7/10], Loss: 0.0851\n",
      "Epoch [8/10], Loss: 0.0796\n",
      "Epoch [9/10], Loss: 0.0748\n",
      "Epoch [10/10], Loss: 0.0709\n"
     ]
    }
   ],
   "source": [
    "# define the optimizer\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr)\n",
    "\n",
    "# define the loss function\n",
    "loss = torch.nn.MSELoss(reduction='sum')\n",
    "n_runs = 5\n",
    "# loss = torch.nn.MSELoss()  # Use BCEWithLogitsLoss for multi-label classification\n",
    "\n",
    "# train the model\n",
    "def train(model, train_loader, test_loader, optimizer, num_epochs=num_epochs):\n",
    "    model.train()\n",
    "    losses = []\n",
    "    test_losses = []\n",
    "    # hidden_activations = []\n",
    "    step = 0\n",
    "    epoch_losses = []\n",
    "    for epoch in range(num_epochs):\n",
    "        epoch_loss = 0\n",
    "        epoch_test_loss = 0\n",
    "        for inputs, labels in train_loader:\n",
    "            step += 1\n",
    "            optimizer.zero_grad()\n",
    "            outputs = model(inputs)\n",
    "            # convert labels to one-hot encoding\n",
    "            labels_onehot = torch.zeros(labels.size(0), 10)\n",
    "            labels_onehot.scatter_(1, labels.unsqueeze(1), 1.0)\n",
    "            loss_val = 1/2 * loss(outputs, labels_onehot)\n",
    "            loss_val.backward()\n",
    "            optimizer.step()\n",
    "            batch_size = inputs.size(0)\n",
    "            loss_per_sample = loss_val.item() / batch_size\n",
    "            losses.append(loss_per_sample)\n",
    "            epoch_loss += loss_per_sample\n",
    "        epoch_loss /= len(train_loader)\n",
    "        epoch_losses.append(epoch_loss)\n",
    "        print(f\"Epoch [{epoch + 1}/{num_epochs}], Loss: {epoch_loss:.4f}\")\n",
    "    hidden_activations = []\n",
    "    return epoch_losses, losses, test_losses, hidden_activations\n",
    "\n",
    "    # return epoch_losses, losses, test_losses, np.concatenate(hidden_activations)\n",
    "\n",
    "# train(model, train_loader, test_loader, optimizer, num_epochs)\n",
    "\n",
    "# def train(model, train_loader, optimizer, n_epochs=num_epochs):\n",
    "#     losses = []\n",
    "#     for epoch in range(n_epochs):\n",
    "#         epoch_loss = 0\n",
    "#         for inputs, labels in train_loader:\n",
    "#             optimizer.zero_grad()\n",
    "#             outputs = model(inputs)\n",
    "#             labels_onehot = torch.zeros(labels.size(0), 10)\n",
    "#             labels_onehot.scatter_(1, labels.unsqueeze(1), 1.0)\n",
    "#             loss_val = 1/2 * loss(outputs, labels_onehot)\n",
    "#             loss_val.backward()\n",
    "#             optimizer.step()\n",
    "#             loss_per_sample = loss_val.item() / batch_size\n",
    "#             losses.append(loss_per_sample)\n",
    "#             epoch_loss += loss_per_sample\n",
    "#             # print every 1000th epoch\n",
    "#             # if epoch % 1000 == 0:\n",
    "#             #     print(f\"Epoch {epoch}, Loss {loss_val.item()}\")\n",
    "#         print(f\"Epoch [{epoch + 1}/{num_epochs}], Loss: {epoch_loss:.4f}\")\n",
    "#     return losses\n",
    "\n",
    "\n",
    "def train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs):\n",
    "    losses_list = []\n",
    "    hidden_acts = []\n",
    "    for i in range(n_runs):\n",
    "        # initialize the weights\n",
    "        model.fc1.weight.data = torch.randn_like(model.fc1.weight.data)*0.0002\n",
    "        model.fc2.weight.data = torch.randn_like(model.fc2.weight.data)*0.0002\n",
    "        _, losses ,_ , hidden_activations = train(model, train_loader, test_loader, optimizer, num_epochs)\n",
    "        losses_list.append(losses)\n",
    "        # hidden_acts.append(hidden_activations)\n",
    "    return losses_list, np.array(hidden_acts)\n",
    "\n",
    "# model = ReluNet(input_size=input_size, hidden_size=hidden_size, output_size=output_size, has_bias=False)\n",
    "\n",
    "losses_relu_no_bias, hidden_activations_relu_no_bias = train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ec8db07f",
   "metadata": {},
   "outputs": [],
   "source": [
    "hidden_size_scaled = int(hidden_size / 2)  # Reduce hidden size for linear model\n",
    "class LinearNet(torch.nn.Module):\n",
    "    def __init__(self, input_size, hidden_size, output_size):\n",
    "        super(LinearNet, self).__init__()\n",
    "        self.fc1 = torch.nn.Linear(input_size, hidden_size, bias=has_bias)\n",
    "        self.fc2 = torch.nn.Linear(hidden_size, output_size, bias=False)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = x.view(-1, input_size)\n",
    "        x = self.fc1(x)\n",
    "        x = self.fc2(x)\n",
    "        return x\n",
    "    \n",
    "    def get_hidden(self, x):\n",
    "        return self.fc1(x)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3fdddc4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10], Loss: 0.3797\n",
      "Epoch [2/10], Loss: 0.2652\n",
      "Epoch [3/10], Loss: 0.2526\n",
      "Epoch [4/10], Loss: 0.2492\n",
      "Epoch [5/10], Loss: 0.2473\n",
      "Epoch [6/10], Loss: 0.2462\n",
      "Epoch [7/10], Loss: 0.2455\n",
      "Epoch [8/10], Loss: 0.2450\n",
      "Epoch [9/10], Loss: 0.2447\n",
      "Epoch [10/10], Loss: 0.2444\n",
      "Epoch [1/10], Loss: 0.3794\n",
      "Epoch [2/10], Loss: 0.2651\n",
      "Epoch [3/10], Loss: 0.2525\n",
      "Epoch [4/10], Loss: 0.2492\n",
      "Epoch [5/10], Loss: 0.2473\n",
      "Epoch [6/10], Loss: 0.2463\n",
      "Epoch [7/10], Loss: 0.2455\n",
      "Epoch [8/10], Loss: 0.2450\n",
      "Epoch [9/10], Loss: 0.2446\n",
      "Epoch [10/10], Loss: 0.2444\n",
      "Epoch [1/10], Loss: 0.3797\n",
      "Epoch [2/10], Loss: 0.2651\n",
      "Epoch [3/10], Loss: 0.2525\n",
      "Epoch [4/10], Loss: 0.2492\n",
      "Epoch [5/10], Loss: 0.2474\n",
      "Epoch [6/10], Loss: 0.2462\n",
      "Epoch [7/10], Loss: 0.2456\n",
      "Epoch [8/10], Loss: 0.2450\n",
      "Epoch [9/10], Loss: 0.2446\n",
      "Epoch [10/10], Loss: 0.2444\n",
      "Epoch [1/10], Loss: 0.3803\n",
      "Epoch [2/10], Loss: 0.2651\n",
      "Epoch [3/10], Loss: 0.2525\n",
      "Epoch [4/10], Loss: 0.2492\n",
      "Epoch [5/10], Loss: 0.2474\n",
      "Epoch [6/10], Loss: 0.2463\n",
      "Epoch [7/10], Loss: 0.2455\n",
      "Epoch [8/10], Loss: 0.2450\n",
      "Epoch [9/10], Loss: 0.2447\n",
      "Epoch [10/10], Loss: 0.2443\n",
      "Epoch [1/10], Loss: 0.3800\n",
      "Epoch [2/10], Loss: 0.2650\n",
      "Epoch [3/10], Loss: 0.2525\n",
      "Epoch [4/10], Loss: 0.2492\n",
      "Epoch [5/10], Loss: 0.2474\n",
      "Epoch [6/10], Loss: 0.2462\n",
      "Epoch [7/10], Loss: 0.2455\n",
      "Epoch [8/10], Loss: 0.2450\n",
      "Epoch [9/10], Loss: 0.2446\n",
      "Epoch [10/10], Loss: 0.2443\n"
     ]
    }
   ],
   "source": [
    "model = LinearNet(input_size=input_size, hidden_size=hidden_size, output_size=output_size)\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr)\n",
    "test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "losses_linear_no_bias, hidden_activations_linear_no_bias = train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d186d44",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of parameters in layer 1: 401920\n",
      "Number of parameters in layer 2: 5120\n",
      "Epoch [1/10], Loss: 0.3254\n",
      "Epoch [2/10], Loss: 0.1390\n",
      "Epoch [3/10], Loss: 0.1016\n",
      "Epoch [4/10], Loss: 0.0889\n",
      "Epoch [5/10], Loss: 0.0805\n",
      "Epoch [6/10], Loss: 0.0742\n",
      "Epoch [7/10], Loss: 0.0694\n",
      "Epoch [8/10], Loss: 0.0654\n",
      "Epoch [9/10], Loss: 0.0619\n",
      "Epoch [10/10], Loss: 0.0590\n",
      "Epoch [1/10], Loss: 0.3260\n",
      "Epoch [2/10], Loss: 0.1401\n",
      "Epoch [3/10], Loss: 0.1022\n",
      "Epoch [4/10], Loss: 0.0892\n",
      "Epoch [5/10], Loss: 0.0810\n",
      "Epoch [6/10], Loss: 0.0748\n",
      "Epoch [7/10], Loss: 0.0698\n",
      "Epoch [8/10], Loss: 0.0657\n",
      "Epoch [9/10], Loss: 0.0622\n",
      "Epoch [10/10], Loss: 0.0592\n",
      "Epoch [1/10], Loss: 0.3252\n",
      "Epoch [2/10], Loss: 0.1393\n",
      "Epoch [3/10], Loss: 0.1017\n",
      "Epoch [4/10], Loss: 0.0893\n",
      "Epoch [5/10], Loss: 0.0811\n",
      "Epoch [6/10], Loss: 0.0750\n",
      "Epoch [7/10], Loss: 0.0698\n",
      "Epoch [8/10], Loss: 0.0657\n",
      "Epoch [9/10], Loss: 0.0622\n",
      "Epoch [10/10], Loss: 0.0590\n",
      "Epoch [1/10], Loss: 0.3241\n",
      "Epoch [2/10], Loss: 0.1382\n",
      "Epoch [3/10], Loss: 0.1015\n",
      "Epoch [4/10], Loss: 0.0889\n",
      "Epoch [5/10], Loss: 0.0808\n",
      "Epoch [6/10], Loss: 0.0747\n",
      "Epoch [7/10], Loss: 0.0698\n",
      "Epoch [8/10], Loss: 0.0657\n",
      "Epoch [9/10], Loss: 0.0622\n",
      "Epoch [10/10], Loss: 0.0593\n",
      "Epoch [1/10], Loss: 0.3258\n",
      "Epoch [2/10], Loss: 0.1400\n",
      "Epoch [3/10], Loss: 0.1016\n",
      "Epoch [4/10], Loss: 0.0888\n",
      "Epoch [5/10], Loss: 0.0805\n",
      "Epoch [6/10], Loss: 0.0745\n",
      "Epoch [7/10], Loss: 0.0695\n",
      "Epoch [8/10], Loss: 0.0654\n",
      "Epoch [9/10], Loss: 0.0618\n",
      "Epoch [10/10], Loss: 0.0587\n"
     ]
    }
   ],
   "source": [
    "bias_magnitude = 10\n",
    "transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    PerPixelNormalizeBias(pixel_means, bias_magnitude),\n",
    "])\n",
    "train_dataset = datasets.MNIST(root='./data', train=True, download=True, transform=transform)\n",
    "test_dataset = datasets.MNIST(root='./data', train=False, download=True, transform=transform)\n",
    "\n",
    "input_size = 784 + 1  # +1 for the bias pixel\n",
    "output_size = 10\n",
    "train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "model = ReluNet(input_size=input_size, hidden_size=hidden_size, output_size=output_size)\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr)\n",
    "\n",
    "# print number of parameters in layer 1 and 2\n",
    "print(f\"Number of parameters in layer 1: {model.fc1.weight.data.numel()}\")\n",
    "print(f\"Number of parameters in layer 2: {model.fc2.weight.data.numel()}\")\n",
    "\n",
    "losses_relu_bias, hidden_activations_relu_bias = train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c7bf12b5",
   "metadata": {},
   "outputs": [],
   "source": [
    "bias_magnitude = 10\n",
    "transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    PerPixelNormalizeBias(pixel_means, bias_magnitude),\n",
    "])\n",
    "train_dataset = datasets.MNIST(root='./data', train=True, download=True, transform=transform)\n",
    "test_dataset = datasets.MNIST(root='./data', train=False, download=True, transform=transform)\n",
    "\n",
    "# create data loaders\n",
    "input_size = 784 + 1  # +1 for the bias pixel\n",
    "output_size = 10\n",
    "train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "model = LinearNet(input_size=input_size, hidden_size=hidden_size, output_size=output_size)\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr)\n",
    "losses_linear_bias, hidden_activations_linear_bias = train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "33b448f3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10], Loss: 0.1770\n",
      "Epoch [2/10], Loss: 0.0799\n",
      "Epoch [3/10], Loss: 0.0649\n",
      "Epoch [4/10], Loss: 0.0559\n",
      "Epoch [5/10], Loss: 0.0500\n",
      "Epoch [6/10], Loss: 0.0457\n",
      "Epoch [7/10], Loss: 0.0425\n",
      "Epoch [8/10], Loss: 0.0399\n",
      "Epoch [9/10], Loss: 0.0377\n",
      "Epoch [10/10], Loss: 0.0359\n",
      "Epoch [1/10], Loss: 0.1777\n",
      "Epoch [2/10], Loss: 0.0802\n",
      "Epoch [3/10], Loss: 0.0650\n",
      "Epoch [4/10], Loss: 0.0560\n",
      "Epoch [5/10], Loss: 0.0501\n",
      "Epoch [6/10], Loss: 0.0458\n",
      "Epoch [7/10], Loss: 0.0425\n",
      "Epoch [8/10], Loss: 0.0399\n",
      "Epoch [9/10], Loss: 0.0378\n",
      "Epoch [10/10], Loss: 0.0360\n",
      "Epoch [1/10], Loss: 0.1773\n",
      "Epoch [2/10], Loss: 0.0797\n",
      "Epoch [3/10], Loss: 0.0643\n",
      "Epoch [4/10], Loss: 0.0555\n",
      "Epoch [5/10], Loss: 0.0496\n",
      "Epoch [6/10], Loss: 0.0454\n",
      "Epoch [7/10], Loss: 0.0423\n",
      "Epoch [8/10], Loss: 0.0398\n",
      "Epoch [9/10], Loss: 0.0377\n",
      "Epoch [10/10], Loss: 0.0359\n",
      "Epoch [1/10], Loss: 0.1769\n",
      "Epoch [2/10], Loss: 0.0798\n",
      "Epoch [3/10], Loss: 0.0645\n",
      "Epoch [4/10], Loss: 0.0556\n",
      "Epoch [5/10], Loss: 0.0497\n",
      "Epoch [6/10], Loss: 0.0455\n",
      "Epoch [7/10], Loss: 0.0423\n",
      "Epoch [8/10], Loss: 0.0397\n",
      "Epoch [9/10], Loss: 0.0375\n",
      "Epoch [10/10], Loss: 0.0358\n",
      "Epoch [1/10], Loss: 0.1778\n",
      "Epoch [2/10], Loss: 0.0804\n",
      "Epoch [3/10], Loss: 0.0649\n",
      "Epoch [4/10], Loss: 0.0561\n",
      "Epoch [5/10], Loss: 0.0501\n",
      "Epoch [6/10], Loss: 0.0459\n",
      "Epoch [7/10], Loss: 0.0426\n",
      "Epoch [8/10], Loss: 0.0401\n",
      "Epoch [9/10], Loss: 0.0380\n",
      "Epoch [10/10], Loss: 0.0362\n"
     ]
    }
   ],
   "source": [
    "standard_transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize((0.1307,), (0.3081,))  # MNIST normalization\n",
    "])\n",
    "train_dataset = datasets.MNIST(root='./data', train=True, download=True, transform=standard_transform)\n",
    "test_dataset = datasets.MNIST(root='./data', train=False, download=True, transform=standard_transform)\n",
    "\n",
    "# create data loaders\n",
    "train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "test_loader = DataLoader(test_dataset, batch_size=batch_size, shuffle=False)\n",
    "\n",
    "input_size = 784\n",
    "output_size = 10\n",
    "\n",
    "model = ReluNet(input_size=input_size, hidden_size=hidden_size, output_size=output_size)\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr)\n",
    "losses_relu_no_bias_standardized, hidden_activations_relu_no_bias_standardized = train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "34ca1df0",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10], Loss: 0.2465\n",
      "Epoch [2/10], Loss: 0.2015\n",
      "Epoch [3/10], Loss: 0.1989\n",
      "Epoch [4/10], Loss: 0.1977\n",
      "Epoch [5/10], Loss: 0.1969\n",
      "Epoch [6/10], Loss: 0.1963\n",
      "Epoch [7/10], Loss: 0.1960\n",
      "Epoch [8/10], Loss: 0.1957\n",
      "Epoch [9/10], Loss: 0.1954\n",
      "Epoch [10/10], Loss: 0.1953\n",
      "Epoch [1/10], Loss: 0.2462\n",
      "Epoch [2/10], Loss: 0.2015\n",
      "Epoch [3/10], Loss: 0.1989\n",
      "Epoch [4/10], Loss: 0.1976\n",
      "Epoch [5/10], Loss: 0.1970\n",
      "Epoch [6/10], Loss: 0.1964\n",
      "Epoch [7/10], Loss: 0.1960\n",
      "Epoch [8/10], Loss: 0.1958\n",
      "Epoch [9/10], Loss: 0.1954\n",
      "Epoch [10/10], Loss: 0.1951\n",
      "Epoch [1/10], Loss: 0.2459\n",
      "Epoch [2/10], Loss: 0.2013\n",
      "Epoch [3/10], Loss: 0.1987\n",
      "Epoch [4/10], Loss: 0.1977\n",
      "Epoch [5/10], Loss: 0.1969\n",
      "Epoch [6/10], Loss: 0.1965\n",
      "Epoch [7/10], Loss: 0.1960\n",
      "Epoch [8/10], Loss: 0.1957\n",
      "Epoch [9/10], Loss: 0.1954\n",
      "Epoch [10/10], Loss: 0.1952\n",
      "Epoch [1/10], Loss: 0.2460\n",
      "Epoch [2/10], Loss: 0.2015\n",
      "Epoch [3/10], Loss: 0.1990\n",
      "Epoch [4/10], Loss: 0.1977\n",
      "Epoch [5/10], Loss: 0.1969\n",
      "Epoch [6/10], Loss: 0.1964\n",
      "Epoch [7/10], Loss: 0.1960\n",
      "Epoch [8/10], Loss: 0.1958\n",
      "Epoch [9/10], Loss: 0.1954\n",
      "Epoch [10/10], Loss: 0.1952\n",
      "Epoch [1/10], Loss: 0.2461\n",
      "Epoch [2/10], Loss: 0.2014\n",
      "Epoch [3/10], Loss: 0.1989\n",
      "Epoch [4/10], Loss: 0.1978\n",
      "Epoch [5/10], Loss: 0.1970\n",
      "Epoch [6/10], Loss: 0.1964\n",
      "Epoch [7/10], Loss: 0.1960\n",
      "Epoch [8/10], Loss: 0.1957\n",
      "Epoch [9/10], Loss: 0.1954\n",
      "Epoch [10/10], Loss: 0.1952\n"
     ]
    }
   ],
   "source": [
    "model = LinearNet(input_size=input_size, hidden_size=hidden_size, output_size=output_size)\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr)\n",
    "losses_linear_no_bias_standardized, hidden_activations_linear_no_bias_standardized = train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2742b9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10], Loss: 0.1765\n",
      "Epoch [2/10], Loss: 0.0799\n",
      "Epoch [3/10], Loss: 0.0646\n",
      "Epoch [4/10], Loss: 0.0557\n",
      "Epoch [5/10], Loss: 0.0499\n",
      "Epoch [6/10], Loss: 0.0457\n",
      "Epoch [7/10], Loss: 0.0426\n",
      "Epoch [8/10], Loss: 0.0400\n",
      "Epoch [9/10], Loss: 0.0380\n",
      "Epoch [10/10], Loss: 0.0362\n",
      "Epoch [1/10], Loss: 0.1771\n",
      "Epoch [2/10], Loss: 0.0804\n",
      "Epoch [3/10], Loss: 0.0650\n",
      "Epoch [4/10], Loss: 0.0560\n",
      "Epoch [5/10], Loss: 0.0501\n",
      "Epoch [6/10], Loss: 0.0460\n",
      "Epoch [7/10], Loss: 0.0427\n",
      "Epoch [8/10], Loss: 0.0402\n",
      "Epoch [9/10], Loss: 0.0381\n",
      "Epoch [10/10], Loss: 0.0363\n",
      "Epoch [1/10], Loss: 0.1767\n",
      "Epoch [2/10], Loss: 0.0800\n",
      "Epoch [3/10], Loss: 0.0649\n",
      "Epoch [4/10], Loss: 0.0559\n",
      "Epoch [5/10], Loss: 0.0499\n",
      "Epoch [6/10], Loss: 0.0457\n",
      "Epoch [7/10], Loss: 0.0425\n",
      "Epoch [8/10], Loss: 0.0399\n",
      "Epoch [9/10], Loss: 0.0379\n",
      "Epoch [10/10], Loss: 0.0361\n",
      "Epoch [1/10], Loss: 0.1768\n",
      "Epoch [2/10], Loss: 0.0802\n",
      "Epoch [3/10], Loss: 0.0650\n",
      "Epoch [4/10], Loss: 0.0562\n",
      "Epoch [5/10], Loss: 0.0502\n",
      "Epoch [6/10], Loss: 0.0461\n",
      "Epoch [7/10], Loss: 0.0428\n",
      "Epoch [8/10], Loss: 0.0403\n",
      "Epoch [9/10], Loss: 0.0381\n",
      "Epoch [10/10], Loss: 0.0364\n",
      "Epoch [1/10], Loss: 0.1778\n",
      "Epoch [2/10], Loss: 0.0801\n",
      "Epoch [3/10], Loss: 0.0647\n",
      "Epoch [4/10], Loss: 0.0557\n",
      "Epoch [5/10], Loss: 0.0500\n",
      "Epoch [6/10], Loss: 0.0458\n",
      "Epoch [7/10], Loss: 0.0427\n",
      "Epoch [8/10], Loss: 0.0402\n",
      "Epoch [9/10], Loss: 0.0382\n",
      "Epoch [10/10], Loss: 0.0364\n"
     ]
    }
   ],
   "source": [
    "standard_bias_transform = transforms.Compose([\n",
    "    transforms.ToTensor(),\n",
    "    transforms.Normalize((0.1307,), (0.3081,)),  # MNIST normalization\n",
    "    AddBias(bias_magnitude=bias_magnitude),\n",
    "])\n",
    "train_dataset = datasets.MNIST(root='./data', train=True, download=True, transform=standard_bias_transform)\n",
    "test_dataset = datasets.MNIST(root='./data', train=False, download=True, transform=standard_bias_transform)\n",
    "\n",
    "# create data loaders\n",
    "train_loader = DataLoader(train_dataset, batch_size=64, shuffle=True)\n",
    "test_loader = DataLoader(test_dataset, batch_size=64, shuffle=False)\n",
    "\n",
    "input_size = 784 + 1\n",
    "output_size = 10\n",
    "\n",
    "model = ReluNet(input_size=input_size, hidden_size=hidden_size, output_size=output_size)\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr)\n",
    "losses_relu_bias_standardized, hidden_activations_relu_bias_standardized = train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a832f690",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10], Loss: 0.2460\n",
      "Epoch [2/10], Loss: 0.2022\n",
      "Epoch [3/10], Loss: 0.1993\n",
      "Epoch [4/10], Loss: 0.1980\n",
      "Epoch [5/10], Loss: 0.1972\n",
      "Epoch [6/10], Loss: 0.1967\n",
      "Epoch [7/10], Loss: 0.1963\n",
      "Epoch [8/10], Loss: 0.1960\n",
      "Epoch [9/10], Loss: 0.1956\n",
      "Epoch [10/10], Loss: 0.1954\n",
      "Epoch [1/10], Loss: 0.2459\n",
      "Epoch [2/10], Loss: 0.2019\n",
      "Epoch [3/10], Loss: 0.1994\n",
      "Epoch [4/10], Loss: 0.1980\n",
      "Epoch [5/10], Loss: 0.1972\n",
      "Epoch [6/10], Loss: 0.1966\n",
      "Epoch [7/10], Loss: 0.1963\n",
      "Epoch [8/10], Loss: 0.1959\n",
      "Epoch [9/10], Loss: 0.1956\n",
      "Epoch [10/10], Loss: 0.1954\n",
      "Epoch [1/10], Loss: 0.2461\n",
      "Epoch [2/10], Loss: 0.2021\n",
      "Epoch [3/10], Loss: 0.1994\n",
      "Epoch [4/10], Loss: 0.1981\n",
      "Epoch [5/10], Loss: 0.1971\n",
      "Epoch [6/10], Loss: 0.1968\n",
      "Epoch [7/10], Loss: 0.1963\n",
      "Epoch [8/10], Loss: 0.1959\n",
      "Epoch [9/10], Loss: 0.1956\n",
      "Epoch [10/10], Loss: 0.1954\n",
      "Epoch [1/10], Loss: 0.2458\n",
      "Epoch [2/10], Loss: 0.2020\n",
      "Epoch [3/10], Loss: 0.1996\n",
      "Epoch [4/10], Loss: 0.1981\n",
      "Epoch [5/10], Loss: 0.1973\n",
      "Epoch [6/10], Loss: 0.1966\n",
      "Epoch [7/10], Loss: 0.1962\n",
      "Epoch [8/10], Loss: 0.1960\n",
      "Epoch [9/10], Loss: 0.1956\n",
      "Epoch [10/10], Loss: 0.1954\n",
      "Epoch [1/10], Loss: 0.2458\n",
      "Epoch [2/10], Loss: 0.2019\n",
      "Epoch [3/10], Loss: 0.1994\n",
      "Epoch [4/10], Loss: 0.1979\n",
      "Epoch [5/10], Loss: 0.1973\n",
      "Epoch [6/10], Loss: 0.1966\n",
      "Epoch [7/10], Loss: 0.1964\n",
      "Epoch [8/10], Loss: 0.1958\n",
      "Epoch [9/10], Loss: 0.1957\n",
      "Epoch [10/10], Loss: 0.1953\n"
     ]
    }
   ],
   "source": [
    "model = LinearNet(input_size=input_size, hidden_size=hidden_size, output_size=output_size)\n",
    "optimizer = torch.optim.SGD(model.parameters(), lr=lr)\n",
    "losses_linear_bias_standardized, hidden_activations_linear_bias_standardized = train_n_runs(n_runs, model, train_loader, test_loader, optimizer, num_epochs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7ff73f93",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "def bucket_mean_se(runs, bucket_size=None, n_buckets=None, ddof=1, keep_remainder=True):\n",
    "    \"\"\"\n",
    "    runs: list of 1D arrays (one per run), all same length T\n",
    "    bucket_size: number of steps per bucket (exclusive with n_buckets)\n",
    "    n_buckets: alternatively, split T into this many near-equal buckets\n",
    "    ddof: 1 for sample std (recommended), 0 for population\n",
    "    keep_remainder: if bucket_size doesn't divide T, keep the last (short) bucket\n",
    "    \"\"\"\n",
    "    X = np.asarray(runs, dtype=float)          # shape (R, T)\n",
    "    R, T = X.shape\n",
    "\n",
    "    if (bucket_size is None) == (n_buckets is None):\n",
    "        raise ValueError(\"Specify exactly one of bucket_size or n_buckets.\")\n",
    "\n",
    "    if n_buckets is not None:\n",
    "        pieces = np.array_split(X, n_buckets, axis=1)\n",
    "    else:\n",
    "        n_full = T // bucket_size\n",
    "        pieces = [X[:, i*bucket_size:(i+1)*bucket_size] for i in range(n_full)]\n",
    "        if keep_remainder and T % bucket_size:\n",
    "            pieces.append(X[:, n_full*bucket_size:])\n",
    "\n",
    "    # per-run means for each bucket -> shape (R, B)\n",
    "    per_run_bucket_means = np.stack([p.mean(axis=1) for p in pieces], axis=1)\n",
    "\n",
    "    mean = per_run_bucket_means.mean(axis=0)                     # shape (B,)\n",
    "    se   = per_run_bucket_means.std(axis=0, ddof=ddof) / np.sqrt(R)\n",
    "    return mean, se\n",
    "\n",
    "\n",
    "buckets = 5\n",
    "configs = {\n",
    "    \"linear_bias\": losses_linear_bias,\n",
    "    \"linear_no_bias\": losses_linear_no_bias,\n",
    "    \"relu_no_bias\": losses_relu_no_bias,\n",
    "    \"relu_bias\": losses_relu_bias,\n",
    "    \"relu_no_bias_standardized\": losses_relu_no_bias_standardized,\n",
    "    \"linear_no_bias_standardized\": losses_linear_no_bias_standardized,\n",
    "    \"relu_bias_standardized\": losses_relu_bias_standardized,\n",
    "    \"linear_bias_standardized\": losses_linear_bias_standardized,\n",
    "}\n",
    "\n",
    "results = {name: bucket_mean_se(runs, bucket_size=buckets) for name, runs in configs.items()}\n",
    "\n",
    "losses_relu_no_bias_plot,  se_losses_relu_no_bias_plot  = results[\"relu_no_bias\"]\n",
    "losses_relu_bias_plot,     se_losses_relu_bias_plot     = results[\"relu_bias\"]\n",
    "losses_linear_bias_plot,   se_losses_linear_bias_plot   = results[\"linear_bias\"]\n",
    "losses_linear_no_bias_plot,se_losses_linear_no_bias_plot= results[\"linear_no_bias\"]\n",
    "losses_relu_no_bias_standardized_plot, se_losses_relu_no_bias_standardized_plot = results[\"relu_no_bias_standardized\"]\n",
    "losses_linear_no_bias_standardized_plot, se_losses_linear_no_bias_standardized_plot = results[\"linear_no_bias_standardized\"]\n",
    "losses_relu_bias_standardized_plot, se_losses_relu_bias_standardized_plot = results[\"relu_bias_standardized\"]\n",
    "losses_linear_bias_standardized_plot, se_losses_linear_bias_standardized_plot = results[\"linear_bias_standardized\"]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "7db5bddb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmsAAAFTCAYAAABmjUu5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAB7CAAAewgFu0HU+AACMEUlEQVR4nOzdeXxU1fn48c+dPZns+0ICJISEhH1fRVRArfuKYBUVtC5VW622+vUHit9aq/3aqkVbtWhVFCoudUFQMez7FiAkJCELkD1k32a7vz9iBsYkkECWSXjer1deJOfee+4ZbubkmXvPeY6iqqqKEEIIIYRwS5qeboAQQgghhGibBGtCCCGEEG5MgjUhhBBCCDcmwZoQQgghhBuTYE0IIYQQwo1JsCaEEEII4cYkWBNCCCGEcGMSrAkhhBBCuDEJ1oQQQggh3JgEa0IIIYQQbkyCNSGEEEIINybBmhBCCCGEG5NgTQghhBDCjUmwJoQQQgjhxiRYE0IIIYRwYxKsCSGEEEK4MQnWhBBCCCHcmARrQgghhBBuTII1IYQQQgg3JsGaEMD8+fNRFIV33323p5sihBC8++67KIrC/Pnze7opwg1IsCb6lAEDBqAoSosvLy8vhg8fzh/+8AfKysp6uplCiE52+nv/888/b3O/yy67rNs+mDV/CPz5l8lkIjY2lrvvvptDhw51eTtE76fr6QYI0RXi4uIICQkBwOFwUFBQwIEDBzhw4ADvv/8+mzZtYsCAAc79w8PDiY+Px9fXt4daLIToLIsXL+baa69FUZSebgoAISEhxMXFOX8uLS0lOzubZcuW8cEHH/DZZ5/xi1/8wuUYX19f4uPjCQ8P7+7mCjckd9ZEn/TUU0+xadMmNm3axJYtW8jOzmbPnj1ERERw4sQJnnjiCZf9X3jhBdLS0rj++ut7qMVCiM6g1WrZv38/q1at6ummOF1xxRXO/mjTpk2kpaWRk5PDJZdcgtVqZeHChdjtdpdjrr/+etLS0njhhRd6qNXCnUiwJi4Yo0aN4umnnwbg+++/7+HWCCG6wm233QbAs88+i6qqPdyatoWHh/Paa68BUFBQII9DxRlJsCYuKP379wfAYrG4lLc1waC+vp6PPvqIOXPmEB8fj5eXF15eXowcOZLnn3+e2traVs9TVlbG448/TkJCAiaTCbPZzIABA7j88stZunRpl7w2IQTcfffdDBgwgIMHD7Jy5coOH//1119z+eWXExQUhNFoZODAgTzwwAMcO3as09va3B9Byz7pTBMMvvvuOx566CFGjBhBQECAcwzc/fffT15eXqvnstls/O1vf2P8+PF4e3tjNBqJiIhg8uTJLFq0iIqKis58aaKTSbAmLii7du0CICEhoV377969m7lz57Jq1Srq6uoYMmQIERERHDp0iGeeeYaLLrqI+vp6l2MqKyuZMGECf/nLX8jOziY2NpaEhATq6+tZu3YtTz31VKe/LiFEE71e77yD/uyzz+JwONp97B/+8Aeuuuoq1qxZg4eHB8OGDaO4uJg33niDESNGOPuPztJcn06nIzY2tt3HXXHFFSxdupTCwkL69+9PXFwcRUVFvPnmm4wePZrU1NQWx8yZM4dHH32UnTt3EhoayogRI9DpdOzYsYPnnnuOnJycznpZogtIsCb6PIfDQX5+Pm+88QYvvvgiiqLwhz/8oV3HRkVFsXLlSsrLyzl27Bg7d+7kyJEjHDt2jJtuuok9e/bw5z//2eWYt99+m6ysLGbNmuV8vLF7926KiorIyclh8eLFXfAqhRDN5s+fT0xMDIcPH+bjjz9u1zFfffUVf/rTn9DpdHzwwQccO3aMXbt2UVBQwPXXX095eTk333xziw9n56KsrIyvvvqKu+++G4D7778ff3//dh+/dOlSjh8/TlFREXv37uXAgQOUlJTwv//7v5SVlfHggw+67L97925WrVpFVFQUqampZGZmsmPHDvLy8jh58iRvvfUWgYGB5/26RBdShehD+vfvrwJtfo0bN05ds2ZNi+PuvPNOFVCXLVvW7nPV1dWpBoNBjYuLcym/7777VED94osvzvflCCHaqfm9v3HjRlVVVXXZsmUqoMbHx6s2m82536WXXtrqe33KlCkqoD7yyCMt6q6trVWDgoJUQH3nnXfa3abmfqWtr4iICHXp0qWqw+FocWxz+++88852n09VVXXq1KkqoB4/ftxZ9tFHH6mA+pvf/KZDdQn3Iak7RJ90euoOaJoqn5OTw+7du1m6dCnjxo1r9ydZh8PBl19+ydq1azl69Cg1NTXOgcuKopCRkUFdXR2enp5A0904gM8++4wrr7wSnU7eZkJ0t1/+8pf88Y9/JD09nQ8//JA77rijzX1ramrYunUrAL/+9a9bbPf09GThwoW88MIL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",
      "text/plain": [
       "<Figure size 640x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "color_list = matplotlib.colormaps['cividis_r'](np.linspace(.09, .85,3))\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(3.2, 1.8), dpi=200)\n",
    "# plot the dataset\n",
    "# make a symbol list with plus and minus for the scatterplot\n",
    "y_tick_fontsize = 7\n",
    "x_tick_fontsize = 7\n",
    "\n",
    "plot_single_metric_axis(ax1, \n",
    "                        metric_array=losses_relu_bias_plot, \n",
    "                        se_array=se_losses_relu_bias_plot,\n",
    "                        y_label=\"Loss, $\\mathcal{L}$\",\n",
    "                        fig_title = \"\",\n",
    "                        log_interval=buckets, \n",
    "                        legend_str=\"ReLU\",\n",
    "                        chance_level=None, \n",
    "                        line_width=1.4, \n",
    "                        x_tick_fontsize=y_tick_fontsize,\n",
    "                        y_tick_fontsize=y_tick_fontsize, \n",
    "                        x_label_fontsize=9,\n",
    "                        y_label_fontsize=10)\n",
    "ax1.plot(np.arange(0, num_epochs * len(train_loader),buckets), losses_linear_bias_plot, color=color_list[1], label=\"Linear\", linewidth=1)\n",
    "# # add shading for the se\n",
    "ax1.fill_between(np.arange(0, num_epochs * len(train_loader),buckets), \n",
    "                 losses_linear_bias_plot - se_losses_linear_bias_plot, \n",
    "                 losses_linear_bias_plot + se_losses_linear_bias_plot, \n",
    "                 color=color_list[1], alpha=0.5)\n",
    "# ax1.plot(np.arange(0, num_epoch * len(train_loader),buckets), losses_linear_bias_scaled_plot, color=color_list[1], label=\"Linear scaled\", linewidth=1)\n",
    "\n",
    "# ax1.fill_between(np.arange(0, num_epoch * len(train_loader),buckets), \n",
    "#                  losses_linear_bias_scaled_plot - se_losses_linear_bias_scaled_plot, \n",
    "#                  losses_linear_bias_scaled_plot + se_losses_linear_bias_scaled_plot, \n",
    "#                  color=color_list[1], alpha=0.5)\n",
    "\n",
    "ax1.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax1.set_xlim([-25, 1000])\n",
    "# ax1.set_ylim([0.05, 0.55])\n",
    "# set title \n",
    "ax1.set_title(\"Bias\", fontsize=8)\n",
    "# ax1.xaxis.get_offset_text().set_fontsize(10)\n",
    "\n",
    "# set x and y limits\n",
    "plot_single_metric_axis(ax2, \n",
    "                        metric_array=losses_relu_no_bias_plot, \n",
    "                        se_array=se_losses_relu_no_bias_plot,\n",
    "                        y_label=\"Loss, $\\mathcal{L}$\",\n",
    "                        fig_title = \"\",\n",
    "                        log_interval=buckets, \n",
    "                        legend_str=\"ReLU\",\n",
    "                        chance_level=None, \n",
    "                        line_width=1.4, \n",
    "                        x_tick_fontsize=y_tick_fontsize,\n",
    "                        y_tick_fontsize=y_tick_fontsize, \n",
    "                        x_label_fontsize=9,\n",
    "                        y_label_fontsize=10)\n",
    "ax2.plot(np.arange(0, num_epochs * len(train_loader),buckets), losses_linear_no_bias_plot, color=color_list[1], label=\"Linear\", linewidth=1.4)\n",
    "# add shading for the se\n",
    "ax2.fill_between(np.arange(0, num_epochs * len(train_loader),buckets), \n",
    "                 losses_linear_no_bias_plot - se_losses_linear_no_bias_plot, \n",
    "                 losses_linear_no_bias_plot + se_losses_linear_no_bias_plot, \n",
    "                 color=color_list[1], alpha=0.5)\n",
    "# remove teh y_label from the second plot\n",
    "ax2.set_ylabel(\"\")\n",
    "# remove the tick labels from the y axis\n",
    "ax2.yaxis.set_ticklabels([])\n",
    "\n",
    "# ax2.plot(np.arange(0, num_epoch * len(train_loader),buckets), losses_linear_no_bias_scaled_plot, color=color_list[1], label=\"Linear scaled\", linewidth=1)\n",
    "# # add shading for the se\n",
    "# ax2.fill_between(np.arange(0, num_epoch * len(train_loader),buckets), \n",
    "#                  losses_linear_no_bias_scaled_plot - se_losses_linear_no_bias_scaled_plot, \n",
    "#                  losses_linear_no_bias_scaled_plot + se_losses_linear_no_bias_scaled_plot, \n",
    "#                  color=color_list[1], alpha=0.5)  \n",
    "ax2.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax2.set_xlim([-25, 1000])\n",
    "# ax2.set_ylim([0.05, 0.55])\n",
    "# set title \n",
    "ax2.set_title(\"No Bias\", fontsize=8)\n",
    "# ax2.xaxis.get_offset_text().set_fontsize(10)\n",
    "# fix y axis to be the same for both plots\n",
    "ax1.set_ylim([0.05, 0.55])\n",
    "ax2.set_ylim([0.05, 0.55])\n",
    "\n",
    "# make title for both subplots with less space below\n",
    "# fig.suptitle(\"MNIST, pixel-wise norm.\", fontsize=10, y=.9)\n",
    "plt.tight_layout()\n",
    "save_figure('/relu_nets_bias/', 'MNIST_bias_vs_no_bias_pixelwise_v2', fig)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "727099fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAn4AAAFTCAYAAACnCgEVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAB7CAAAewgFu0HU+AACOv0lEQVR4nOzdd3xV9fnA8c+5M8nN3jshEAIJe29EFMRtcYA4UMFVqx3+tGotUKy21ba2tdQ6igNxVBy1iqDVgMjeEEgIIXvvfff5/RFz4ZKwAmQ+79crL+Ws+73n5j55zvd8z/NVVFVVEUIIIYQQvZ6mqxsghBBCCCE6hyR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QgghhBB9hCR+QpylhQsXoigKb7zxRlc3RQjRR73xxhsoisLChQu7uimih5LET/Q58fHxKIrS5sfb25thw4bxxBNPUFlZ2dXNFEJcACd+3z/55JNTbnfZZZd12oVd60XkyT8eHh7079+fu+++m7S0tIveDtE36bq6AUJ0lcTEREJDQwFwOp0UFxdz4MABDhw4wNtvv82mTZuIj493bR8REUFSUhJ+fn5d1GIhxPlYunQp1113HYqidHVTAAgNDSUxMdH174qKCrKzs1m5ciWrVq3i448/5qqrrnLbx8/Pj6SkJCIiIjq7uaKXkB4/0Wc9+eSTbNq0iU2bNrF582ays7PZvXs3kZGRFBYW8thjj7lt/9xzz5Gens4NN9zQRS0WQnSUVqtl3759rFmzpqub4jJnzhxXDNq0aRPp6enk5ORw6aWXYrPZWLx4MQ6Hw22fG264gfT0dJ577rkuarXo6STxE+IEI0eO5KmnngLg66+/7uLWCCEulPnz5wOwbNkyVFXt4tacWkREBH/7298AKC4ullu+4oKTxE+Ik8TFxQFgtVrdlp/q4Y7m5mbeffdd5s2bR1JSEt7e3nh7ezNixAieeeYZGhsb232dyspKHn30UQYNGoSHhwcmk4n4+HiuuOIKVqxYcVHemxB91d133018fDwHDx7kgw8+OOf9P//8c6644gqCg4MxGo3069ePBx98kPz8/Ave1tYYBG3j0Oke7vjqq6946KGHGD58OIGBga4xgw888AB5eXntvpbdbucvf/kL48aNw8fHB6PRSGRkJJMmTWLJkiXU1NRcyLcmugFJ/IQ4yc6dOwEYNGjQWW2/a9cubr31VtasWUNTUxODBw8mMjKStLQ0nn76aaZNm0Zzc7PbPrW1tYwfP54//vGPZGdn079/fwYNGkRzczPr16/nySefvODvS4i+TK/Xu3rzly1bhtPpPOt9n3jiCa6++mrWrVuHp6cnQ4cOpaysjH/84x8MHz7cFTMulNbj6XQ6+vfvf9b7zZkzhxUrVlBSUkJcXByJiYmUlpby8ssvM2rUKA4dOtRmn3nz5vHTn/6UHTt2EBYWxvDhw9HpdGzfvp3f/OY35OTkXKi3JboJSfyEoOXhjqKiIv7xj3/w+9//HkVReOKJJ85q35iYGD744AOqq6vJz89nx44dHDlyhPz8fG688UZ2797NH/7wB7d9XnvtNbKyspg1a5brds6uXbsoLS0lJyeHpUuXXoR3KUTftnDhQhISEjh8+DDvvffeWe3z3//+l9/97nfodDpWrVpFfn4+O3fupLi4mBtuuIHq6mpuuummNhd3HVFZWcl///tf7r77bgAeeOABAgICznr/FStWUFBQQGlpKXv27OHAgQOUl5fz29/+lsrKSn784x+7bb9r1y7WrFlDTEwMhw4d4ujRo2zfvp28vDyqqqp49dVXCQoKOu/3JboZVYg+Ji4uTgVO+TN27Fh13bp1bfa78847VUBduXLlWb9WU1OTajAY1MTERLfl9913nwqon3766fm+HSHEabR+37/77jtVVVV15cqVKqAmJSWpdrvdtd3MmTPb/X5PnjxZBdRHHnmkzbEbGxvV4OBgFVBff/31s25Tayw51U9kZKS6YsUK1el0ttm3tf133nnnWb+eqqrqlClTVEAtKChwLXv33XdVQP3Zz352TscSPZuUcxF91onlXKCllEJOTg67du1ixYoVjB079qyvtp1OJ5999hnr16/n2LFjNDQ0uAaQK4pCZmYmTU1NeHl5AS29hAAff/wxV155JTqdfBWF6Ay33347zz77LBkZGbzzzjvccccdp9y2oaGBLVu2APCTn/ykzXovLy8WL17Mc889x/r16109dWfr5HIuDQ0NZGdnU1RUxD//+U8mT57MsGHDzumYO3fu5MMPP+TQoUPU1ta6ngrOzMwEYP/+/URFRQHH49D//vc/qqqqCAwMPKfXEj2T/LURfdaTTz7ZZoB0TU0NjzzyCG+99RazZs1i+/btZ6z5VVNTw5VXXun6A3Eq1dXVrsTvrrvu4vnnn+eNN95g7dq1XHHFFUydOpUZM2aQkJBwXu9LCHFqWq2Wp59+mjvuuIPly5dz6623nvLC6+jRozidToxG4ym/lykpKQAcOXLknNsyZ86cNg+L2e12VqxYwSOPPMK0adM4ePAg0dHRZzyWqqo89NBDZ3wwrKqqyvX/EydOZPz48Wzbto2YmBguv/xypk2bxvTp0xk1alS3qXcoLiwZ4yfECfz9/XnllVeIiopi586dfPrpp2fc5+c//zlbtmwhKSmJNWvWUFhYiMViQVVVVFV1XV3bbDbXPpGRkWzZsoW5c+dSW1vLm2++yaJFi+jfvz8TJ048YxIphOi4W2+9laSkJI4ePcrbb799yu0aGhoACAkJOWUSFBYWBkB9ff0FaZtOp+Phhx92xYYXXnjhrPZ7++23WbFiBSaTiRUrVrjuMrTGoQULFgDucUij0bB27VoeeeQRPD09+fTTT/nFL37BmDFj6Nevn0xP2UtJ4ifESYxGI6NGjQJg+/btp93Wbre7SkN8+umn/OhHPyIyMhKDweBaX1JS0u6+gwcP5sMPP6SmpoZvv/2WpUuXMmjQILZu3cqsWbPkaTohLhKtVsuvf/1rAJYvX47dbm93O29vbwDKy8tPWfuvtLQUAB8fnwvaxkmTJgFnjkGt3nnnHQD++Mc/8sADDzBgwAA8PT1d609VdiYgIIAXX3yR8vJy9uzZw1/+8hdmzJhBbm4ud911Fx9++OF5vhPR3UjiJ0Q7Wks9nHhbpD3l5eU0NjYSGBhIUlJSm/UHDx5sU3n/ZEajkUsuuYQlS5Zw8OBBJk+eTENDA++++27H34AQ4rTmzZtHcnIy2dnZp+zZGjBgABqNBovFwrFjx9rdprXA8sCBAy9o+842BrVqvVBsTRhPZLPZOHz48Gn3VxSFESNG8PDDD/PNN9/wy1/+EoBXX331HFotegJJ/IQ4idlsZs+ePQBnHG/XekVdV1fXbjmHk8u4nIlWq2Xs2LEAFBUVndO+Qoizp9FoWLJkCQDPPPOM2y3QVt7e3q5EqnU2jRM1Nzfz2muvATB79uwL2r7NmzcDZ45BrVpjUWsP5IlWrlxJeXn5Ob3+hAkTAIlDvZEkfkKcoLq6msWLF1NUVITBYODmm28+7fb+/v6kpKRgt9v52c9+5qqy73A4+P3vf8/777/vuu17oqeeeorXX3+9TVX8E2cVaL3dLIS4OG666SaGDh1Kbm4u33//fbvbPP7440BLjbzVq1e7ltfX13PHHXdQXl5OfHw88+bNuyBtstvt/PnPf+bjjz8GWp5CPhtTpkwB4Fe/+pVbkvfll1/yf//3f3h4eLTZ55133mH58uVthpVUVlby17/+FZA41Ct1YSkZIbpEa12vxMREdfLkya6fQYMGqUajUQVUnU7Xpp7Xqer4/ec//1EVRVEBNTAwUB0zZoyrttfTTz/ter3s7GzXPtddd50KqBqNRh0wYIA6btw4dcCAAa46XjNmzFBtNtvFPxlC9HIn1/E72YcffuhWQ6+9Op2//OUvXetjYmLUMWPGqCaTSQXUgIAAdfv27efUptZYEhoa6haDhg8frvr6+rpea/HixW1q+Z2qjl9ubq4aGBioAqqnp6c6YsQINT4+3hVPFixY0Ob9/fnPf3a9VlRUlDp27Fh1yJAhqsFgcC3Lzc09p/cmuj/p8RN9VmZmJt9//73rJzs7m6ioKO666y527tzZ7lyY7bnmmmtYu3YtkyZNorm5mYyMDAYMGMCqVav4zW9+0+4+v/rVr/jlL3/J2LFjaWhoYO/evTQ3NzN9+nTeeust1q9fL7X9hOgEP/rRjxgxYsRpt3nuuef47LPPuPzyy2loaGD//v0EBwdz//33s2/fPtfwjHNVVlbmFoPS0tIwmUxcc801fPrpp7zyyitnXVIlNjaWLVu28KMf/QiDwUB6ejoeHh4sW7aML7/8st14MnfuXH7/+99z+eWXo9VqOXDgAMXFxQwZMoRnnnmGgwcPEhsb26H3JrovRVVP8aiSEEIIIYToVaTHTwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij9B1dQP6ivj4eMrKygDw8PAgPj6+axskhDijnJwczGYzAKGhoeTk5HTq60vcEKLn6eq4cSaKqqpqVzeiL/Dy8qK5ubmrmyGE6CBPT0+ampo69TUlbgjRs3VF3DgTudUrhBBCCNFHyK3eTuLh4eG6cvf09CQuLs61XFGUrmxaj6Gqqqv7XM7b2ZPz1nHp6emu762Hh0env/7JcSMpKUk+yw6Q70DHyHnrmK6OG2ciiV8niY+Pp7q6GoCkpCRWrlwJQHJyMgaDoSub1mNYrVYOHToEyHk7F3LeOm7kyJHs3bsXoEvG150YNwYNGsTWrVvls+wA+Q50jJy3junquHEmcqtXCCGEEKKPkMRPCCGEEKKPkMRPCCGEEKKPkDF+QnQzTqeT8vJympqasNvtF+R4DocDgOzsbDQaud47kU6nw8vLi5CQEDk3okeT2NF5enLckMRPiG6kqamJoqIibDbbBTumqqrodC1fdYfDgdPpvGDH7g3sdjtms5n6+noiIyPx8vLq6iYJcc4kdnSunhw3JPETohupqKhwC9xarfaClFBovSLVarXnfazeRFVVV4+GzWajsrKyRwVwIVpJ7Og8PT1uSOInRDditVpd/9+/f/8LUj7B6XS61eLqabclLjar1UpWVhYAFouli1sjRMdI7OhcPTluyKcoRDfSOoOiTqeTmlmdxGAwuG5nyQyWoqeS2NG5enLckMRPCCGEEKKPkMRPCCGEEKKPkMRPCCGEEKKPkMRPCHFBLFy4EEVRUBQFnU5HbGwsDzzwgGuu2bOhKAqffPJJm+U5OTkoiuKa//JE119/PQsXLux4w4UQXUpiR+fqtYnfjh07uPLKKwkICMBkMjFu3DhWr1591vunpqa6fhHb+9m6detFbL0QPdMVV1xBcXExOTk5vPbaa3z22Wc8+OCDXd0sIUQ3J7Gj8/TKci6pqanMnj0bg8HAvHnz8PPz46OPPmLBggXk5OTw5JNPnvWxpk+fziWXXNJmeXR09AVssRCnNv7Zr2m0OM7jCCqtD521lPU6+9peJqOWbU9edtbbG41GwsPDgZbvyC233MIbb7zhWr9y5Ur+8Ic/kJ2dTXx8PA8//LAEdyEugvOPG9DR2HGucQMkdnSmXpf42e12Fi1ahKIobNy4kZEjRwKwZMkSJk6cyJIlS7jppptITEw8q+NdcsklLF269CK2WIjTa7Q4aLCc//RLne3YsWN8+eWX6PV6AF599VWWLFnCSy+9xMiRI9mzZw+LFy/GZDJx5513dnFrhehdemrcAIkdF1uvS/y++eYbsrKyuOuuu1xJH4CPjw9PP/008+bNY+XKlTz77LNd1sa6Zht/31KGXqclMi8DL6MOT70Wk4eOhCAvBoR6E2iSOkwns9lsbtXSeyOn0+mqCXV8eqSurBGlnvU0Taqq8t///hdvb28cDoer8Osf//hHnE4ny5cv5/nnn+f6668HIC4ujrS0NP75z39y++23u47jdDrbvGbrv9tbp6oqqnr27Txd+51Op1sh3O5Un0tVVZaveAOr3Q4aLaZth9DpDWh0ejw9vfAPDCI4MJAAb0/6h5gI8JIY0qpvxo6eETegZ8eO7h432tPrEr/U1FQAZs2a1WZd67INGzac9fEyMzP561//SlNTE3FxcVx++eUEBwefVxsbzFbCyjZhwE5zkZ4aVYdZ1dGkGljlCCDXEYhWb6Cfv55bhvgyLMx4Xq/XWzidTmpqagDIyMjolVXkHQ4HOp0OjUbjCn5eBi1dFUe8DFpXO87E4XAwbdo0/vKXv9DU1MSbb75JZmYmixYtIj8/n/z8fBYvXsx9993n2sdut+Pr6+v2Gjabrc1rtlbGt1gsbda1TiR/tu08VdttNhvNzc0cOnTItfx8jnmhNTU3Y6zLwRUNGsBJy0/9Dz95KjSoRoqdvpQZ40iODmJUhAeDgg3oNOc/fVdP1RdjR0+JG9BzY0dPiBvt6XWJX2ZmJkC7t3IDAgIIDg52bXM2Vq9e7fZQiKenJ8uWLeP//u//OtxGVVUxYkdRwBMbnsrxK9AEXSVOFYqdfmRVhbDk21BuGOzDgqG+aPtw4O7LUn82+bz2P3FeyQs1f+epmEwm+vfvD8ALL7zAnDlzePbZZ10B+6WXXmLs2LFu+5zNHKC+vr4A1NXVtVlXW1tLTEzM+Ta92zubXgRFAR/Fgo+mnER7OVlZwTyfHoPB04dfTQsizl/fCS0V3cH5xg2Q2NFb9brEr7a2FgA/P7921/v6+lJQUHDG44SEhPD8889z9dVXExsbS01NDd9++y2PP/44jz32GL6+vm5XH+dC0WgpcvphVOwYsWNUbBiU413NGgWitLVEaWsJs9fx0eEBHKvX8vf5wwnx6bu9fzabjfT0dACSkpJc4z96k+zsbBwOB1qtFg8PjwtyTFVV3ebbvFjBW6vVotFo3Nq9ZMkSrrrqKh566CGioqIoKCg4Y/kEvV7f5r1HREQQEhLC/v37ufzyy13Lm5ubOXz4MLfccst5nS+tVut63X79+rmWX6jP4EI412m4FAUG6CpI0FaQbgvnyf8NYOXCMYyI8b84DezGJHZ0jMSOM7e7u8eN9vS6xO9CSUlJISUlxfVvLy8vFixYwPDhwxk9ejRLlixh8eLFHbplEORtZPT46VgdKkFhEdhVhYYmM/l52VQWZOFnr8RbafmyJenKqHB6s7dAYc7fNvPW3eMYERtwwd5nT9N6hafX63vlfJQajcY13uRC3Y5yOp2ugK0oykW7zdVa6ujE41966aWkpKTwu9/9jqVLl/Lwww/j5+fHnDlzsFgs7Ny5k+rqan7+85+79snNzWX//v1uxx4wYACPPvoozz33HOHh4UyaNInq6mp+//vfo9PpuP3228/7fbW2/cTfq4vZw3GudFodgyZfQ3FxMXaHA18f7x9uNVlprKvGXF+NamlA67S67adRIFlfgsOmsOBf8OodY7gkKbSL3kXXkdhx7iR2nF3bu3PcaE+vS/xae/pae/5OVldXd8rewLMxZMgQxo8fz3fffcfRo0cZOHDgOR/DqNMwJrLliiA5OfKEX5gkoOXL9s6aj8g9vBuAifpsqpwmSs2+3LlyB1ufmImn4cxd3EJ0Bz//+c+56667OHr0KK+99hrPP/88jz32GCaTiaFDh/LTn/60zfYn+/bbb3n00Ufx9vbmhRdeICsrC39/fyZMmMB3333nup3Tm2k0CtdOHe0aS5ScnNxuAlNUVMDXX31JXu4xt+VD9cXkmwO5+40dvHjLCK4dEdUp7RaioyR2XBy9LvFrHduXmZnJ6NGj3dZVV1dTUVHBpEmTzus1Wh/uaGpqOq/jnIpGo+G2G+fy+uvllBTlo1FUZhrT+cQ8nNpmeHd7HndP6XfmAwnRiU6suXWiW2+9lVtvvbXN/7fnTOPYHnzwQanddQaRkdHcceciCgvy+fSTf1NVVeFaN92QyRrzSB55fy+xQaY+edtXdD8SOzpXr3u0afr06QCsX7++zbrWZa3bdITdbmf37t0oikJsbGyHj3MmiqJw55334OfnD4CXYmOmIQMNTl769ihW+/mVrhBC9G5R0THMu/VOtwHwJo2VSYYsVBWWf5bWha0TQnSVXpf4zZw5k4SEBFavXu02N199fT3Lly9Hp9O5DRCtqKggPT2diooKt+Ns2bKlzRWE3W7n//7v/8jNzWX27NkEBgZezLeCXm/glvl3YjC0PNARpq0nRVdMVaOVT/YUXtTXFkL0fIGBQcyafbXbspYHPsrZlVfDtmOVXdQyIURX6XWJn06n47XXXsPpdDJ16lTuvfdeHn30UYYPH05aWhpLly51G5f30ksvMXjwYF566SW348yfP5+EhAQWLFjAY489xr333suQIUN48cUXiY2N5eWXX+6U9xMaGuYWuJN1xSiovPj1ERzO7l0kUgjR9UaNHkd8v/5uyyYbsvBSLDy39nAXtUoI0VV6XeIHMGPGDDZt2sSUKVP44IMPWLFiBUFBQaxatYqnnnrqrI7xwAMPEB8fT2pqKn/5y1945513MBqNPPXUU+zdu5e4uLiL/C6OGzFyNL7+Lb2LPhoLMdpqimrNrEsr7rQ2CCF6JkVRuP6GmzEaj5eCMioOhusK2Jtfy+asitPsLYTobXrdwx2txo0bx9q1a8+43dKlS9udi/fxxx/n8ccfvwgt65jhw0bw3cZvgJZevzxHIH9cf4Q5QyK6/aPjQoiu5e3tw9XXzmXNv48Xox+kK2WfPZrnvjjMfx6aInFEiD6iV/b49UZTpk7HYGwpAROtrcFPaSKrvJGNR8q7uGVCiJ5g0KAUQsPCXf/WKirDdIUcKKxj01Hp9ROir5DEr4fQavXExcW7/p2sKwHgD+syuv2E0EKIrqcoCpdeOttt2SBdKZ5YefaLdIkjQvQRkvj1IJfPugrlhwrjiboy9NhJK6pjXVpJF7dMCNET9B8wkJCQ47N26BQnQ/WFHC6u48NdZ57KUgjR80ni14MEBgYRFtpyq8agOBiga7nNu/SzQ1LXTwhxRoqiMOOkXr/BuhI8sPLUJwfJrWzsopYJITqLJH49zKQp01z/n6IrBlRKas28tSWny9okxJkoisInn3zS1c0QQOLAQQQFBbv+rVecDNUXYbU7ue/tXdgcchEpug+JHReeJH49zODBQ12zefhrmknSlgLwp6+OUNtk68KWib5u4cKFXH/99e2uKy4uZs6cOZ3bINGu9nr9knXFRGpqSC+p54V1GV3UMtFXSezoXJL49TCKopA8ZJjr35MNWfTTVtBkdfDnr490YcuEOLXw8HC3OnJdQVVV7HZ7l7ahu0gaNJiAgCDXv/WKkznGNEbp83hlYxabMqVagOgeJHZceL22jl9vdskll5GbfYyiogI0CswwHMFu0fD2FoVpA4OZkBCEl0E+WtF9KIrCxx9/zPXXX09OTg79+vVjzZo1/O1vf2Pbtm0kJiby8ssvM3HiRNc+mzdv5pe//CU7duwgODiYG264geeeew6TyQTAqlWrePHFF8nIyMBkMnHppZfy4osvEhra8vBCamoqM2bM4Msvv+Spp55i//79rFu3jhkzZnTJOehOFEXDrCuu4v133zphGYzS5xOuqeOBf5kJCgzi6mERXDEkgn7BJkxGiSk9yV/+/DssFssFOFLr095nX+fRaDTyyM9+eQFeW2LHxSDf5B5Iq9Vxx8JF/Ov1f1JWWoxGUZlpTOdry2DufmMHGkUhMcyHMXEBDA73ZUCYN/1DvAn2NkiR1h7q9Vf/TkNDfYf3by3Vca6fv7e3D/cs/nGHX/d0nnrqKV544QUSExN56qmnmD9/PkePHkWn03HgwAFmz57N8uXLef311ykvL+ehhx7ioYceYuXKlQBYrVaWL19OUlISZWVl/OxnP2PhwoV88cUXbq/z2GOP8cILL5CQkIC/v/9FeS89UWLiIK65di6ff/4JTofDtTxSW8stnrspb/Bm43dBvJUaRJ3qgYdeS5DJSEygJ5P6BzGpfzDDov0x6OTGUXdksViwWi9E4tf9SOw4P5L49VA6nYG77r6PF1eswFJbhk5RucLjEFZVS5XTRGWlF7srvNjg9KBeNdKgeqDRavH3MhDqYyTCz4OEEG8GhfswINSbhBBvvOWKvttqaKinvr6uq5txQT366KNcddVVACxbtoyUlBSOHj3KoEGDeP7557n11lv56U9/CkBiYiJ//etfmT59Ov/4xz/w8PDg7rvvdh0rISGBv/71r4wbN46Ghga8vb1d637zm99w+eWXd+p76ymGjxhNVFQM7737JjU11W7rQrQNhGgbGEcuFlVLjdOL6iYvKhtMvJbtz5++8kSnURgY5kP/UBOJoT4khnozJMqPmECvLnpHoi+Q2HF+5C99D6bXG3j4/gdY8qe/4W2rAlrKvIRr6wjXuicJqgr1qpFqixfVZi+yS73YnO5Hk3p87ES/YBNXDAnnmmGRDI7wkd7BbsTb2+e89j+fHr+LZdiw42NVIyIiACgrK2PQoEHs2rWLo0eP8s4777i2UVUVp9NJdnY2gwcPZs+ePSxdupS9e/dSVVWF09nyNGpeXh7Jycmu/caMGXPR3kNvEBwSyn0PPMLnn33MwYP72t3GqDgI09YTxvFe51qnB3mOAPJKg/is2JcTbwVO7B/E47OTGBEbcLGbL07hwo2L69it3otJYsf5kcSvhzMajSz56YO8/u6/KS0vR7U04IG1zXaKAr6KBV+NhTharuxVFYqdvhxzhJBtDyK7opF/pGbxj9Qsgr0N3DwmhnunJeDvZejstyVOcj63W51OJ2azGQAPDw80mu5xa06v17v+vzUhbQ3ATqeT++67j4cffrjNfrGxsTQ2NjJr1ixmzZrFqlWrCAkJIS8vj9mzZ2O1uv/+t47rEaem1xu4/ke3MGz4KHbu3EpWViaOMwxm99OYGaopZqi+mDKHNztscRQ7/QHYklXJ9Ss2MzLGn0dnJzGpf5BcSHayCzHGTmJH74wdkvj1Ap6eXjx0951Ay5VNaXkFqbsOkFNYQlVNLVZLM1q7GW+a0CvHa3QpCkRq64jU1jFJf4w8RwDp9nAKnf5UNFhZkZrFa5uyuXVcLD+eMYAQn659skr0HaNGjSItLY0BAwa0u/7AgQNUVFTwu9/9jpiYGAB27tzZmU3slRL6J5LQPxG73caxrKMcOLCXwoI86uvrTjulW6i2gau0aRQ4/Nlpi6XC2dJTvCe/hgWvbSPS34NbxsRy56Q4uZAUF5XEjjOTxK+XURSF8NAQ5s251G25qqqYzWay8/I5lHmM7LxcmmvK0NibAdAoKvG6KuJ1VdQ7jWTYwzhkj8Bq1/HG5hxWbc1lwYRYfjErCV8PfXsvLQS1tbXs3bvXbVlgYOA5H+fxxx9nwoQJ/PjHP2bx4sWYTCYOHz7MV199xd/+9jdiY2MxGAz87W9/4/777+fgwYMsX778Ar0LodPpGZg0mIFJgwGw2+1UVVZQWlpM5pF0srIysVjMbfaL1tYQra0hxx7IblsMVWrLeKmiGjN//voIf/smk1nJYfz+xmH4SBwRJ5DY0Xkk8esjFEXB09OT5KSBJCcNBMBut3Eo7SC7d22jtKwE2w/d3D4aC2MMeQzWlbDBmkiR0x+7U+XNzbl8tLuQX14xiPnjYtFo5NaNcJeamsrIkSPdlt15553nfJxhw4axYcMGnnrqKaZOnYqqqvTv359bbrkFgJCQEN544w2efPJJ/vrXvzJq1CheeOEFrr322gvyPoQ7nU5HaFg4oWHhDB02ElV1UlxUxN69O9mze0eb3sDWi8iTE0C7U+WLgyUcKKrlg3snEuHv2RVvR3RDEjs6j6Kerv9eXDCjRo1iz549AIwYMcL1WHlycjIGQ9ff+mhubmLr5u84dPgg1VWVbusO2CLZaYvDcUK97/4hJl68ZQRDo/07rY1Wq5VDhw4B3ee8XWiZmZnY7XZ0Oh2JiYkX5JjddZxOd3Kq8z5y5EhXL8TIkSPZvXt3p7brxLgxcuRItm7d2u2+A7W1NXzz9Zekpe1vd71Thc22BNLtEW7L/b30vHPPeFKi/C56GyV2dIzEjtPrrnHjTORTFEDLOMEZM2fz4I9/zoLb7sbf//jTeEP1RVznsQ8/pcm1LKu8kR/9YzObj1Z0RXOFEN2En58/N8ydx30PPMKAxKQ26zUKTDEcY4q/e7mYmiYbc1/ezDfpZZ3VVCEEkviJkyiKQr+EAdz/4E9JSkpGUVp+RQI1TVzrcYAQzfFyDjaHyh3/2k5qhgRuIfq6kJAw5s2/k3vve5gBA9omgIOsh5if4D6fuNnm5N63drL2QHFnNVOIPk8SP9EunU7PTbfcxg1zb8Hrh0fajYqdazwOEqmpcW1nd6rc8+ZO1qeVdFFLhRDdSWhYOPNuvZO77nkAvd79lqqpZDv3DXEfG2x3qjz83h42yAWkEJ1CEj9xWsnJQ7nr7gfx8/MHQIOTKz0P0U97/Bavw6ly/6pdfLFfrtqFEC2iomK4/c5F6HTuT+86jn3PLyf5cOKzYTaHyuK3d7E9u6qTWylE3yOJnzijgIAA7lh4L4FBwS0LVJWZxgy35M+pwsPv7WFXbvUpjiLOhTxz1bk6OrOJOL3IyGhuu+NutNoTC0io1B9O5blrEt2SP6vdyZ3/2s7+gprObmavIrGj8/TUuCGJnzgrfn7+3Hb7PYSGhbuWzfTMwkc5Pgm43amycOV28qua2juEOAutFekdDgc1NTVd25g+oqamBofDAbSULREXVnR0HLcuWIhGo3Uts1jMmDO+Zfn1KW4TgTXbHMx/ZSs7c6Tn71xJ7OhcPTlu9KzWii7l6+vHvPl3snrVSioqysBpZ0HwUV6pSMaptoTverOdW1/dyhePTJUCrR1gMplobm4pql1cXExZWdkFuZpsDVBarfYMW/Ytqqq6zg303imaulpcfAJXzLmGLz7/xLUsPz+XSwZk8/TVyfzmv4dcyxutDua/upUXbhrOdSOiuqC1PZPEjs7T0+OGJH7inPj6+nHFnGv44P1VWK0W7I01LIwq5V8Fx3sC86ubufuNHby7eAI6rXQqn4vg4GAcDgfV1S23zE8MLh2lqio2W8vTlHq9vsfdlugsAQEBBAcHd3Uzeq2Ro8aSnp7GsaxM17KNG/7Hwrvuxzw7iT+sy3AttzlUfvr+XnIrm3h45oWpSdfbSezoGj0xbkjiJ85ZXHwCo8aMY+vm7wDQVh/jurhgPs09/uu0I6eaX350gBduGt5VzeyRFEUhLCwMrVZLY2Mjdrv9vMfsOJ1OV0+AFGF1pygKOp0Ok8lEcHCw/GG7iBRF4fobbuEff/8Tzc0tw0GcTicf/vsdHvjxz9BpFJ5bm07rb7uqwp++OkJxbTPP/WhY1zW8h5DY0Xl6etyQxE+cM0VRmDz5EvJycygqzEdVVeKbDjI2chw7iqyu7T7cVUD/EBMPXNL+ZNmifYqiEBISQkhIyAU53omzFvTr169XzlogegYvLy+uu/5G3nv3Ldeyurpa/vPpGu69cT4hvkYe+3A/NsfxhOXd7fkMifRjwYS4rmhyjyKxQ5yNbpm+O53O8z7Gjh07uPLKKwkICMBkMjFu3DhWr17d4ePZbDZGjBiBoigMGjTovNvX03l6enLpzNl4ebWMbWhsbGSWZyZxAUa37Z5fl8E6qfEnhPjBgMRBDB8+ym3Z4UMHOLB/LzeMjOb1O8fiZXAfT/bbLw5TXNPcmc0Uotfqdomf2Wzm6quvpqGhocPHSE1NZcqUKXz33XfceOONPPDAA1RUVLBgwQKeffbZDh1z+fLlHD16tMNt6o3i4uIZPWa8q5u7tLiARfEV+HocD9pOFR55bw8HCmu6qJVCiO5mzlXXu00LCfDl2k+pq61l2sAQ3rt3Ap7643GkyergodV7pFSJEBfARU38nE4nhw4d4vDhw2e9j4eHB0888QQ33XRTh17TbrezaNEiFEVh48aNvPrqq7zwwgvs27ePlJQUlixZQmZm5pkPdILdu3fz3HPP8dxzz3WoTb2VomgYO24i/QcMdC0rOJrGz4aD7oQCXWabk7tW7pArdiEE0FL+Yu5NC9yeFLVYLPz736tQVZVh0f48doX7tG+78qp5bVN2ZzdViF7noiV+O3fuJDExkaFDhzJkyBCuv/76s9536tSpxMbG8vLLL5/z637zzTdkZWVx6623MnLkSNdyHx8fnn76aex2OytXrjzr41mtVhYuXMiECRN46KGHzrk9vZ2Xl4kpU2cQHNwypsThcFCbvYcHRnu7bVfRYGX+q1upbLC0dxghRB8TERHJ1GmXui0rLipkw7dfAbBwUjxj4tx7Bf+4PoPcysZOa6MQvdFFe7jjvvvuIzv7+NXZZ599xrfffsuMGTPOav+HH36YadOmMX/+fPz8/M76dVNTUwGYNWtWm3WtyzZs2HDWx1u6dCmZmZns27fvgj25c2INoNZH5XuykJAwRo+ZQOq3X2GxmGloqCei+gDXJw/nk0O1ru1yKpuY/8pWVt09Gn+vcx8kbLPZetV56yxy3jquO91abC2t0Zs+y7HjJpGZmUFhQZ5r2ebNG4mN60d0TBx/vHEIV/x1M822lvdstjl5cNUu1tw37pyeMO1t562zyHnrmO4UN9pz0RK/w4cP8/LLLxMYGMjNN98MnFuRw5SUFFRV5d///jeLFi066/1ab+MmJrat/dRab+dsb/Xu2LGDP/zhDzz77LMMHDjwzDucJbPZ7KqsnpGR0SsekVc0eiIio8nJbhkHWVxUyLBILRlB8RyuPF5P6khZA7e+splllwRhMpxbQVCn09nrzltnkPPWcWazuaub4GI2m8nIyOh1n2VyynDKSotdiYXT6WTNh+8yfcYVGAwGbhvqzau7j19AphXX8/QH21gw7Ow7BOQ70DFy3jqmO8WN9ly0TzE0NJRZs2Zx4403smHDBr777jvGjRt3TsfQ6/X8+9//Pqd9amtbAsSpegl9fX1d25yOxWJh4cKFjBw5kl/84hfn1Ia+SKfT0S9hICGhxws5l5YWckdsDTG+7tcXR6tsPPtdFVb7+T+9LYTo2YxGT4aPGOu2zGIxs3PH96iqylUDvRkc7H6H4OP0BjIqZNiIEB1x0Xr8pk+fTm5uLvHx8UydOvWc98/IyKC8vJyMjIwzb3wRPP3002RmZrJr164LPlWNh4cH/v7+ACQlJbnmWOwNgoIC+PqrtdRUV7XMGVlRxAtzkvnFunIKao5fBaWVW3knE56fm3zWx7bZbKSnpwO977xdTHLeOs7Dw6Orm+Di4eFBUlJSr/wsk5OTsdut7N2z07WsqrKcmupyJk+5hFeizcz522YaLC13D+xO+OvOBj5/aChehjP/GZPvQMfIeeuY7hQ32nPREr9FixaxZMkS1q9f36EJjH/7298CUFJybjXgWnv6TtWrV1dXd8Yxg7t37+ZPf/oTTz/9NEOHDj2n1z8biqK4kkm9Xt+rimIOHDiYyopyvtv4DXa7ncrKCvKPHuAfN8/g7ncPUV5//Cr9P/uKmTQgmFvGxp718XvrebvY5Lx1THeqyK8oCnq9vtd+lldedR3FRYWUlha7lm3+fiMJ/ROJi+vHkmtS+L8P97vWFdaY+fVnGfx1/sj2DtdGbz1vF5uct3PXneJGey7ard6pU6fi6enJhAkT2Lp16zntW1VVxXvvvQec++THrWP72hvHV11dTUVFRbvj/060f/9+HA4HS5cuRVEUtx9o6Y1UFMXVayeO02g0DBs+isTE40WuM49kUJV3mL/fnIKf5/ErRhVY9tkhsso6XrNRCNE7aDRabpl/B0bj8d4SVXXy4QfvUFpazE1jYrhscJjbPp/tL+LDXfmd3VQherSLOlLzlVdeoaioiMmTJ5OcnMzjjz/Op59+Snl5+Wn3y8zMxG63oyjKOT9UMX36dADWr1/fZl3rstZtTmXgwIHcc8897f5AS6/iPffcwx133HFObesrfHx8GT12AsEhoQA4HHYO7N+NtSSdX82Mcqvx12R1sPjtnVht5z+huBCiZ/P19eO6628CjseI5uYm3lz5CkczM/jTzcMI8Tk+O5CqwpJP0/j3Tkn+hDhbF3Wu3qioKNatW8fVV19Nenq623i9hIQEpkyZwuTJk5k9ezYxMTGudSc+Nn6ut1pnzpxJQkICq1ev5uGHH2bEiBEA1NfXs3z5cnQ6HQsXLnRtX1FRQUVFBcHBwQQHBwMwadIkJk2a1O7xX3/9dcLDw3nttdfOqV19TWxsPMOHj2bjhv9hs1mpqalm546tJKcM4+YUH1YfqHdte6y8kUfX7Oev887ulo0QovcamDSYceMmsn37Ztcyq9XCB++/zawrruYPc4ex6M2dOH4omdFodfD4mv0cKW3gySsHdfvbbEJ0tYv+bPbQoUPZvXs3CxYsQFEUVFVFVVWOHTvGW2+9xX333Ud8fDwjR47kxRdfpKqqiqioKNf+w4YNO6fX0+l0vPbaazidTqZOncq9997Lo48+yvDhw0lLS2Pp0qVuvYgvvfQSgwcP5qWXXrpg71m03PIdOmwEgwanuJY1NNSza+dWxhgLGRniHpz/s7eId7bldnYzhRDd0OWzr2Lw4CFuy5xOJ19+8R/Uwj3MGxfjvk6FV787xp3/2k6T1d6ZTRWix+mUojxBQUG8/fbb7Nu3j1/84hf069fPlQC2/uzfv59f/OIXxMbG8u6777p6AE9MAs/WjBkz2LRpE1OmTOGDDz5gxYoVBAUFsWrVKp566qkL/fbEKXh7+zBi5BiGDR+J7oenwRwOB4cOHeBK31xCvdyTv2WfHWJXbnVXNFUI0Y0oisKPbpzPpMnTOPG2L8Dm7zdwQ4yZuaOi0J7Uubcxs4KbXt6CzSGlooQ4lU6txpiSksLzzz9PVlYW2dnZvPnmm9xzzz0kJia6EsCmpiaefvppCgoKgI4/HTNu3DjWrl1LTU0NTU1N7NixgwULFrTZbunSpaiqytKlS8/quKqquh5vF2cWGxvP0KEjGTt2otuk7KXF+dwRWYThhMhttTu5962dlNd37+KXQoiLT1EULp15Bddc+yO0WvdRSV+t+4xfTAnl9zcOw9fDfV1aUR1L/5PWmU0VokfpsjLccXFx3H777bz66qtkZGRQXFzM+++/z49//GOSk5NdU54cO3asq5ooLgBFUeiXMICRo8YyavQ44uP7u9bVFB3jroR6t+0rG60sXLkDuxR3FkIAw0eMZsFtd7uVBXM47Pz7/be4OiWYLx+ZRnKEr9s+72zL47N9RZ3dVCF6hG4z/0pYWBg33XQTf/vb3zhw4ABpaWnMmDGDw4cPd3XTxAUQGBjE6DETGDp8JDExca7lmrJDXB3v3qubVlTHLz7c19lNFEJ0U7Fx8Vx59fVuy+rr6/j3B+8Q7mfkowcnERfk5bb+8TX7yamQUlFCnKzbJH4nGzx4MP/5z38oKpKrtt7CaDQybNgIRo8Z57rta7PZSDTvZ2io0W3bT/cWsfL77K5ophCiGxo2bBTDho9yW5abc4z16z7HqFN4/c6xGLTH/6Q1WR3c/eZOzFIqSgg33TbxA/Dy8nIVcha9g6JoGJw8jLHjJmEwtiR79XV1XOl1mJCTHvZ49ovD7Miu6opmCiG6oauuvoGQEPcizjt3bOGz/6yhX5AHv7p6sNu6Y+WNPPjObnnYQ4gTdOvED8DHx6ermyAuMK1Wy6jRYxk1apzr4Z3KsmJu8txLqK7RtZ3NoXLv2zspq5OHPYQQLbHjlvm3YzS63yHYv28P77/3FjePDGNGUojbum/Sy3jso4PYnWpnNlWIbqvbJ36id9LrDUyZegmDTqjVZW1u4FrDPobr8lFoCdLVTTbuXLkdu1yxCyEAf/9Arr72Rtccsq2OZR1l1Vuv8+w1/Qn1cU8MPz9Qyood1dgckvwJIYmf6DIeHp5cMecaxo2fjKdn68BslbGGPK40HkRPSyHWw8X1/OLf8rCHEKLF4MEpXHvdTRgM7gleSUkR//lwFSvmD8fb6F7m5ZvsZl7dVSO3fUWfJ4mf6FImkzczL5vNlVddT3R0rGt5hLaOK4yHXMnfp3uLeOLjNJyqXLELISBlyDBuumUBXl4mt+XlZaXk7fkfL94yAk+9e6/gV8ea+Mv/slzlwoToiyTxE11Oq9UxOHkI11w7l9FjxrvqdYVp692SvzV7ivjD91U02+SKXQgB/foN4Nbb7sbvhOLwAIfS9uPXcIzl16dg0B3/M6cCr32fwxubczq3oUJ0I5L4iW4jKDiEmZddwfgJU9ySvznGNAw/JH9bC8z84fsqCmuau7KpQohuIjw8gttuvxtvb/cHAb9a/zkTwlQen52EXnO8YoBThd9+fpjP90upMNE3SeInuhWDwcjUaTOYNHk6Ol3L/L6h2gZmGw+hpaWnb0+JhV9+lMaR0rqubKoQopsICAji5nm3o/9hTnAAp9PJ++++xc0jgrl3Wjwn5H7YnSo//2AfW49VdkFrhehakviJbken0zN5yiVMnTbDFcjDtPVMMRyFH5723ZZTzT1v7uSb9NIubKkQoruIjIzm+htudpvfvbm5iX++/BcuC2vm+kHenFgp1GJ3ctfKHXywI1/G/Ik+RRI/0S1ptVomTprG1GmXotG0/Jom6soZpit0bZNf1cwDq3bzp/VHJHALIUgalMIll85yW2Zububzz9YwsHEPNw7UuyV/zTYHj63Zz2V/2khqRlnnNlaILiKJn+i2NBoN4ydMYfgJ0zSN1ecSqz1+e8Zid/LXbzKZ+ccNPL8undI6GfsnRF82adK0NlO7AVRUlBFUsol7UpQ267LKG1i4cgc/WvE9mzLL5UJS9GqS+IluTavVctmsK4mLTwBAUeBSwxEClUa37Y5VNPL3b7OY9Ltvue6lTXx1qFSCtxB9kKIoXHPtXC6fdRVarXstP7vdjpLzPYsTGzBo2yaAu/NquO317Vz9t038Z1+hFI4XvVK3TPzy8vLIy8ujpqamq5siugGj0YNrrp1LcHDLVEw6xcl1XgcJ0zW02dbhVNlXUMt9b+/k4Xf3cKBACrYK0dcoisL4CZO5/8FHCAuPcFunqipq4T5+ObCEGQP8UNrmf6QV1fHwu3u5/u/fU1IrdxFE79ItE7/4+Hj69etHeHg49913Hzk5OV3dJNHF/P0DmHXFNRg9PADQqnau80xjjH+D29N6rZwqfLa/mMfW7OefG7IoluAtRJ8TEBDEosUPMXHSNLeHPgCKco8y0b6L56YYGBZhanf/g0V13PjyFoqlfJToRbpl4gctV2VWq5XXXnuNpKQk7rnnHrKysrq6WaILRUfHkjJkhCv5czrsjHam8dx4G3eMCqJfkGebfQ4X1/Ov73N4a3MOtc22zm6yEKKLKYrC1GmXMnzEWDQnze9bVlbK0V3fMsW8gZ/GFzAx2Nxm/4LqZm765xYKqyX5E71Dt0z8pk2bxvTp0xk3bhx6vR6bzcbKlStJTk7u6qaJLhYREUNKygh8fHwBcNjtHEvbRf/GvTycUMZjozV46933qWq08vbWPFZvz8Nql9u+QvRF0THxjB49EQ+PtheIVouFhrJcUpp28UhsLklB7kGkoLqZW17ZQn5VU2c1V4iLRnfmTTpfamqq6/8tFgtbt24lNTWV7777rusaJboFRVGIiIwhKiqKjRv+R21tDQ6Hg/z8PCAPgNt9THxrHkB6k7drvwaLnbc35xDmY+SGkVFtbvsIIXq/sPBI+g8YwNrPP6G2tqbdbRorCrjMWEFg0GC2VHq5lhdUNzP/1a28f+8EogK82t1XiJ6gW/b4nchoNDJ9+nSWLFnC119/3dXNEd2AoigMGpzCjJmzCfrhgY8T2cyNTNcdYmyg1W15Ua2Zf23K5jsp1yBEnxUbG8+NNy9g6LCRREREYTR6tNnGYjGT0ryH2T65KByPFS3J3zZKpGyU6MG6ZY+fEGeiKBpSUobi6eFJdnYWNTXV1NXVUFlZgcVsxmG3MVZ/mMbAERyqOh64DxbV8a9NORwpbWBgmA8Dw3wI8zVKD6AQfUhERBRXXX0DFosZu91OeXkZG779iuLiQrftYhwFXG9q4LPGQdhpGR+YV9XE/Fe28uH9kwjyNnZF84U4L5L4iR5LUTT0HzCQfgkDaGxsoKG+noKCPFK/XY/FYsHa3MAM33SqTIMpaTw+tm/DkXIKa5tJCDIRHehFfJAXlySFEhMot2+E6Ct0Oh06XctwED8/fxISBvC/r79kx/bNOJ3H40WQWsNcr/181pxMk9qS6GVXNHHLP7fw4f2T8DcZuqT9QnRUt7rVa7FYKC0tdfvSCXEmGo0GHx9fIiKjGDV6HKPHjHdN82apq+Ba/xxMuuO9fiqQWdrAukOlvL4pmxfWZ/Dbzw+z9kAxTVZ7F70LIURX0mg0XD7rSm68eQEmk7fbOh+amOu5j0hNDTocABwtb+SWV7fSZJGYIXqWTkn8Ghoa+OKLL/jiiy9oaGhbdLeiooK5c+fi6+tLZGQkAQEBPProo1it1naOJsSptc7xO2hQimuZszqfG037GaorxF9pAtzH99U22/kyrYTl/z3E8+sySCuq7eRWCyG6i4EDB3P7nYsIDg51W27ExpUeaSz02srNHru4zHCYurJ8nvj4AE6njBkWPUenJH5r1qzh6quv5sEHH8TLy/12mtPpZM6cOXzyySfYbDZUVaW+vp4///nP3HbbbZ3RPNHLeHp6Me2SmURHx7qW6W0NjDfkcKPnHm7y2E2Ipr7NfkW1Zt74PocnPzrA1qyKzmyyEKIbCQ4O5bY7FhEX16/d9b4aM/G6Kq7ySCMzbTfv7ciXB8ZEj9Epid+6desAmDt3rusWXKv333+fXbt2ATBq1Ch+9rOfMWrUKFRVZc2aNXz55Zed0UTRywQHhzJl6gxiYuLQ6dyHsvppzFzjcYBxXsXoNe7BWgX2FdTyfx/uZ19+Tec1WAjRrXh7e3PL/DtJGTL8tNtN1GXxyVepbMmq7KSWCXF+OiXxO3jwIIqiMHHixDbr3n77bQBGjx7N1q1b+eMf/8iWLVsYN24cAG+99VaHXnPHjh1ceeWVBAQEYDKZGDduHKtXrz7r/VNTU7n11lsZPHgw/v7+eHl5kZSUxN13301GRkaH2iQ6V/8BiUyZOoMpU2cwavQ44uITMPxQvFWDyjCOcXtQJim+FreSDQD51c38/IO9HCmp64qmCyG6AYPBwLXXzeXSy64gMioGP/8A9Hr34s6KAkMc6bz3xdd8caCYvMomufUrurVOeaq3vLwcgLi4OLflNpuNDRs2oCgKDz74oKtnRq/Xc//997N9+3a2bdt2zq+XmprK7NmzMRgMzJs3Dz8/Pz766CMWLFhATk4OTz755BmP8fXXX7Np0ybGjx/vOtbhw4d56623WL16NWvXrmXGjBnn3DbReU586re2toaqygpKSoo4eGAf5eWlAGgay5lmbGB4gImdjaEctfrh/OF6KKu8kUfe28srd44hRgq2CtEnabU6Jk2axsiRY7FaLdjtdgoL8vjo049dD3poFAiuPsC2jWYOxQ3D38+f5Ahfhkb74aVXqK6uAhWCgkOkdJTocp2S+FVVVQG0uVLauXMnzc3NKIrCnDlz3NYNHDgQgJKSknN6LbvdzqJFi1AUhY0bNzJy5EgAlixZwsSJE1myZAk33XQTiYmJpz3Or371K5555pk2y//3v/9x2WWX8dhjj7Fjx45zapvoGhqNhoCAQAICAomKjkWn05ORcYi83GwAbJZmvGhmmq6CKVqFIqcf+2xRFDv9OFxSz09W7eTNRRPw85SyDUL0VZ6ennh6ttwxCAoKJr/WzvZvP0OvtCZ/KprKI1RXZLPDEcK/1FBCPRWS/a2kBCr4ehlJSRlGQv/T/+0R4mLrlMTP09OT+vp6ysrK3JZv2LABgP79+xMWFtZmn4745ptvyMrK4q677nIlfQA+Pj48/fTTzJs3j5UrV/Lss8+e9jgeHm2ruQPMnDmTgIAAjh492qH2AaiqisPREixsNluHj9PX2Gy28z5vGo2G5JShOJ1OjEYjWUePuJUP0igq0doaorU1lDm82WuPZm+hymPv7+Iv80ah0fS8q/ULcd76qu40YF9VVfksO+hinLfLxg8nNaMUr6Jt6JXjMcRTsTFUV8RQisAOVED2D8+KHcvJ5dZ5C/DzD7ggbbjY5PetY7pT3GhPpyR+/fv3Z+/evaSmpjJr1izX8o8//hhFUZg+fXqbfVpvD4eGhrZZdzqt8/ye+DqtWpe1JpwdsWXLFqqrq5kyZUqHj2E2m6mpqQEgIyOjzQMvon1Op/OCnTe9wQOj0ZO4+AHU19diMTdjsViw222uRDBU28AsbTrFDl/WpQ/mT//ZzpUDfS7EW+lUF/K89TVms7mrm+BiNpvJyMiQz7IDLtZ3YGpiGK8VD2aEmo7hh56/06mvqeCDD99n4oQpPeKzk9jRMd0pbrSnUxK/yy+/nD179rBixQqmTp3K1KlTWblyJTt27EBRFK655po2++zfvx+AyMjIc3qtzMxMgHZv5QYEBBAcHOza5mykpqaSmpqKxWIhMzOT//73vwQHB/PnP//5nNoluhedTk90TD/Ky0owGo0/XNW29KjU1tZQVVOD4mwpzBqhrWOS4Rir9mtIDvUg3l9/+oMLIfqEGD89wwfE8HWGJyGOMgbqyvDTnP6PfnVFCUczDzMwKeW02wlxsXRK4vfII4/w8ssvU19fz9VXX+22bvDgwe0mfp9//vkpnwQ+ndraluK7fn5+7a739fWloKDgrI+XmprKsmXLXP8eMGAA7733HqNHjz6ndp3Iw8MDf39/AJKSktqMfRTts9lspKenAxfyvA1DVVWamhqpq6ultraG6qpKbDYbWzMKsVXmoFecDNSVU2b14aWdXnz8wCSMeu0FeO3OcXHOW99wqiEfXcHDw4OkpCT5LDvgYn4HDCEN+AWWklcVi4feia6xAKrzcFibaLBrqLHp8KERX43FtU9mZgZjxowjOibuNEfuehI7OqY7xY32dEriFxERwWeffca8efMoLi52LU9ISODDDz9s85RTVlYW3333HdDSW9iVli5dytKlS2lsbOTQoUP85je/YfLkyfzrX//i1ltv7dAxFUVBq21JHPR6PQaDPDRwti7WeTMajQQEBALgcNipqCgnLCyc17/SENzYMp5zoj6b/1Z588gHB5iZHEaAlwGTUUdKpC/B3Xyydvl965ju9ASmoijo9Xr5LDvoYp235KgAjlY0o9VqifL3ZHjMYAaEeoPqoKGhgcqaGn7yzi5G2/a6bgerTjuffrqGhXfd64o73ZX8vp277hQ32tMpiR/A1KlTyc7O5vvvv6ekpISIiAimTJnSprguQHFxMU8//TRAu+P/Tqe1p6+15+9kdXV1p+wNPB2TycTYsWP5+OOPGTNmDPfeey+XX345ISEh53ws0b1ptTrCwiIIC4vgAU9v/vReAzFqCVpFZaYhnU8yjHyTUY5Bo+Kth4EBGhaND2VAeAAenp6EhISi1XbaV0sI0YUUReHa4ZE4nCo67Ylj4HT4+fnj5+fPH+/y54GXGplpTHetbWyo41+vrWDAgIGMHjuB8PAItFpdt08aRM/XqX+dDAbDWdW+mzJlSocfnmgd25eZmdnmdmx1dTUVFRVMmjSpQ8cG0Ol0zJgxg3379rFz5842ZWhE7zJwwABuumwyn61bT4imHm+NlVs9d2JBh1nVYVb11FR68Y91hVzSz4ehsQHk5/kwdNiobt/dL4S4MBRFQac9dcI2KMKfyyaOZu+2eobrC13Lm5ubOHBgL4cPpxEREUlISJirSHRgYBD9Ega4etyEuFC61SM6FouF0tJSt/Ia56q1h3D9+vVt1rUuO9dexJMVFRUBtNtbKXoXRVGYOWEkiUNG06S2jG/RKCqeio0ATTMR2joG60sYqcmmNnc/G7/7joz0w+zds5OmpkbXcZxOJ6WlxeTmZlNTU42qdvx3XAjR8zw2ZzClpoEUOtrecbLbbeTn57J793a+2/gNO3ds5eDBvaSl7cfpPPPTwkKci05J/BoaGvjiiy/44osvaGhoaLO+oqKCuXPn4uvrS2RkJAEBATz66KNYrdZzfq2ZM2eSkJDA6tWr2bt3r2t5fX09y5cvR6fTsXDhQrfXTk9Pp6Kiwu04GzdubLcWz/r16/n444/x8/M7r55D0XMoiob7r5+BKXY4lfhTq3rRqBqwqW2/Phqc5ORkse/gAfbu2UV1dRX5+bls37aZ/fv2sGf3Dvbs3sHWLZs4knGYmprqLnhHQojOptdq+PP8MXxlSWaPLRqz2n7Hgd1uo6qqgoMH9rF96/cc2L9Xkj9xQXVKl9WaNWu46667iI2N5dixY27rnE4nc+bMYffu3a5Eq76+nj//+c/k5eXxwQcfnNNr6XQ6XnvtNWbPns3UqVOZP38+vr6+fPTRR2RnZ/PMM8+4ZgUBeOmll1i2bBlLlixh6dKlruXXXnstwcHBjB07lpiYGJqbm9m/fz8bN25Er9fz2muvYTKZOn5SRI+i0+l5/PZrOJCZQ2llDdV19dTWN/BVjpWiWivBmnrCNPXE61pmqSkvzie10UZVfRManOTnZFFRXoKqqmg0Gvz8AggLjyAoKJh+/foT369/F79DIcTFNjougHsvSeQfqRr22aJJ1JUxRFd0yhIwJSVFfL9pA05VZfjwkWg0cttXnL9OSfzWrVsHwNy5c9sUgHz//ffZtWsXiqIwatQopk+fzoYNG9i9ezdr1qzhyy+/5Iorrjin15sxYwabNm1iyZIlfPDBB1itVlJSUli+fDkLFiw4q2MsW7aML7/8kk2bNlFeXo6iKMTExLBo0SJ++tOfkpIiNZj6Gp1Oz8jBx+tDqqrK3Jo6VnyVxup91RywwlBnIeMNOQA460rYvLsZT0c9ygm3dp1OJ9XVlVRXV6LV6airq/2hrmBsZ78lIUQne+yKQQyN8uPd7XnszTeSbg4nUlNLrLaKGG2VW9kXgKqqCjamfo3VYiYuPoHg4FAZZiTOS6f89hw8ePCUNfnefvttAEaPHs3mzZvR6XTYbDamTp3Kjh07eOutt8458QMYN24ca9euPeN2reVaTvbII4/wyCOPnPPrir5DURRCAvxYcvMk5oyt5Kfv7eFAbRQqMOGH5M/LfvzpcqfaMg9wmKbONcWTw24n7eA+NBoNOp2O8IhzK1guhOh55gyNYM7QCErrmvnvvmJe3nCMLQ3+bLH1w19pZpohk1Dt8WFR9fV1bEj9msDAYHx9/YiOjSMiIhIvTxN6gwGDwYDJZEJRutWwfdFNdUri1zr9Wlyce7FKm83Ghg0bUBSFBx980HUVo9fruf/++9m+fTvbtm3rjCYKcV7G9Qti3c+mc++b29mSDSoKEw3ZrvW59gC22+KpVb3Q4mC4VyWTvYpobmrE6XRy8MBedFodo0aPw8tkwuFw4HA40Ov1+Pj4nFVAt9vtaLVaKQchRA8R5uvJPVMTGBETwE/e3U1RrZka1YsvLEOYacwgRnt8DLDVaqWkpIiSkiKOHDkMtJSeMhgMGI1GgoNDGDtuEv0S+rvdErbZrDgcDoxGD4kNAuikxK+qqmXc08lVv3fu3ElzczOKorQpi9I6Dq+kpKQzmijEefPx0LPy7gn8+qO9fLxPpcliIFpbTZY9hCKnv2s7B1p2N4ViNwQw0yeD+vpaHA4H+/btRtEoeHh44nDYsdls6HR6PD29CAgIICAgiMCgYIxG92LRVquVrKwjlJeV4uPrR0rKMCm0KkQPMjo+gN/+aAhL/3OI3Mom7GhZbxnEVEMWA3Vlp9zP4bDT3GynubmJmppqsrIyCQuPZMSI0Wi1OmqqK6mvrwNFISoymqTBKXh797z5xsWF1SmJn6enJ/X19ZSVuf8Cb9iwAYD+/fsTFhbWZh8hehoPvZZlN4wg1FvHmp1Ovm8OwkOrEuatQ1W0lNUfH7+zv0ZPSGQSyV5pNDc1Yrfb2LVzW5unyX39/H+o8RWKRqMlODiEyKgY/Pz8KS8r5ejRI9TV1ZCfn0dISCgOu42hw0a1SRCFEN3XJQND+flldv6eepQjpQ2oaNhoHUCN05Ph+gKMypmf7FVVlZLiQr4sLmyzLu3gPg4c3MfIkWNIThlKc3MzdbW11NbVoKoqCQkD8PKSBxb7gk5J/Pr378/evXtJTU1l1qxZruUff/wxiqK0W1ev9fZwaGhoZzRRiAvG06DlgctSCPb1orKqGr2XLxEBJoJMRn716QGKao4/wfe/Ij0VfoMYoUlD7zS3W0KorraGutoaso4eISgomKbYeMrLyzAYjFitFgoK8sjNOdZSK7CkiOrqSux2OyNGjsHDQy6ghOgJFEXhymERNFjsfJNeysbMCmwO2G+P5oA9Cn+liWBNAyGaBoI0jZgUK14aKxraxoz2OBwOCvJzKcjPZfP3G/Hy8kKr1aKi4unhRU11NcOGj8TX99xnthI9S6ckfpdffjl79uxhxYoVTJ06lalTp7Jy5Up27NiBoihcc801bfbZv38/AJGRMthd9Dwmo47bJvWnuslGgJfeNZXTCtMo7li5g7pmm2vbfbUeHGEolxoz8Nc0o9Fo8NRrMRr0WJsbcTjsQMsYvtLSEsrKSgkICCQiMoqC/Dxqa2vcXruwIJ+6ulosZgspQ4ah1elwOBwoikJNTTUN9XVUV1dhsZiJje1HVHSMjP0RohvQazVcPzIKbw8dCSHefJNeRlZ5IyoK1aqJaoeJTMeJd8dUggwOpgbWE6cW0ljf/lSlJ6usLKey0n1ZdnYWlZXlTJk6g6Cg4Av3pkS30ymJ3yOPPMLLL79MfX09V199tdu6wYMHt5v4ff7556d8EliInkCn1RDi4367dURsAH+YO4yH39uD1X68xEszBj63DHX9O9DgYLIvRPk1oWmsRm0sR7W19BSqqkpVVSVVVe6R29PLi+amJgDq6+rYsuU7yspLCAgIorKysiXxqy6nsbGB3JxjNDY2EhOTxdhxkxiQmCTJnxDdgMmo47oRUVwyMJTpA0P5aE8B245VUlxrxtmmc0+h0qrjk5IAQrzDuD7BTmhzNg31NWiUlkoBWq2WhsYGzM3Np31di8XMgf17KCoq4LLL5pA4cNBFe4+ia3VK4hcREcFnn33GvHnzKC4udi1PSEjgww8/bPMHJysri++++w5o6S0Uoje5Ykg4v75qMM+vP0LtCT1/J6qyavksD3yNfuhUE6oaiZfazHB9AZFKldu2iqIQF9eP6Jg46upqOXzoADabDbvdRkb6IbRaLZ6eJowenhQW5NLYeLxMxLFjR6mrq6WpuYmhQ4d3qEBsU1MTlZXleHp4EhwiQzOEuBD8vPRMSQxmQkIg6SX1bMuuJK2wjmMVDaSX1GO2uU/7WN5g5dWDMDRqKPPHhxNi0mC1WLDZLNjNTWgbSigqyKH6pAvGk1VWlPPvD1YxfuIUpkyZ4bauvr6OnJxjNDU20NjYQH19HU1NTYSEhDF12gyMRpmfvCfotCqQU6dOJTs7m++//56SkhIiIiKYMmVKu4Uoi4uLefrpp4Hzn1dXiO5owYQ4hkT5sf5QKfsLaimsaaagugmbw/2Svs7ipGVmRQ3V+FBoH0y8RxM/Csihob4Wo9FI0qAUAgICSRw4CHNzM76+vqQd3E91dUuC6HA4aGioo6Ghrt22VFSU8/X6L6itqSY8PBK73YbNbsdgMBAbG4/J5N1mH5vNRnl5KaWlJdTV1qCqThRFw8CBg4mIjLrQp0uIPkun1TAkyo+USF+yKxrZmVtNbkUje/Nr2JFb7XbnAOBAYR1HyxqICzJh0GrQaxW8PXSMihnKrQsuo7KkgOycLOpra7Hb7TQ2NlBeXorT6V5kfsv3GzE3m4mIjEFRNBTk57J37y5yc47R1NToNh456+gRjh7N4PobbiE8PAJouTNRWJBPdvZRBiQmEREhcaG76NTy3waDgRkzZpxxuylTpjBlypROaJEQXUNRFEbEBjAiNoDaZhtHyxrYk1fN2oPF7MmraeeWznE5Zi+yPZK4IknBaPTAx8eX5JSheHp6ARAeEUVUVCyHDh0gPz+Xmmr3HkKtVkt0dCxeXiaOHDmMw+GgubmJ7zZ+g16vR9Fo0CgaPD09GZCYxOgxE1xjflRVpaiwgOzsLBwOG/X19RQXF1JbU42XyRun04mnlxf+/gEX7dwJ0RcpikJCiDcJId5UNlg4VtFIWmEt/91fzO68areY0Wxzkl5S77b/tuwqnMBDlw5m0OAUzGYz5WWllJWVUFlZwbGsTCoq3Ctv7Nm9nYqKcvz9AykvK6akpOiU7asoL+PtN1/l0pmzMBg92Ll9C0VFBaiqyncbv2Xm5Vcwfvzks36/quqkuqoKu8NOSEiYDEW5gGTeFyG6mJ+nntFxAYyM8WdYtD/r00rYcKSco2UNp3xeb12BjiuHBBITHkR8fAJa7fFbtAaDgcSBgwgJDSP9cBqVleUcyTiMxWImICCQAYmD8Pf3JyY2nuCQEHbv2kFjYwOqqmK1Wl3HaW5uYueOrTQ2NjJmzASCgoPJyDhMbU01xcWFlBQXud02NpvNpKXtx2g0Mmr0eDw8Wm77qKqKzWZFp9Od861ki8VCTk4WjQ0NxMX1Iyg45Jz2F6I3CvI2EuRtZGx8IDeNiWHNrgJe2XiMgppTj+Mz25z8c2MWngYt905NwMPDg5jYOGJi4zCbm0lJGcbhwwfZsX2L64EygPy8bEqKC7HZrKc8diuLxczaLz6DkyKX0+ng6/Vf0NzUxPRLZp62IL3FYqGkuJDi4iIslpZxzfXRdfQfMPCMry/OTpclfqWlpRw8eNBV3DkwMJAhQ4a0qecnRF+h0SiM6xdIfLAXccEmCquaqDPb8NBrcarw/o58mm0ttbyabCqrMjS8MWnAKa+E/f0DGD1mPIcOHaChoRG73U5ERATR0bH0HzAQrVZLUFAI4RHRbN6USmVlBQ6HA6fTgdPpRFVVnE4naQf30djYQHR0LMXFheTn5WK1Wtp9zZrqKtLSDmAwGhk8eAgVFeUcy8okLzebgMAgBg8eQnhEJD4+vqc9F6rqpLCwgNycY1gsFqxWKw0N9fRLGEB0dKxc/QvxA5NRxx2T4pnYP4i//C+T/x0uc8WJk5ltTl78+gjeRi23TYh3Lffw8CQqOoao6BjCwyP47D9rcDiOH+PkpE9RNJhMJrxMJmw220njBtu/XFVVlU3fpWK2mJk0aRoGg8E1qUNdXR21tTXU1tZQ80PFgdqaGmrrajDoDaiqSnBIKH5+/qc9F6rqBJQLEh+KigooLMgnZchwvLy8zvt43UmnJn6qqvLKK6/w0ksvcejQoXa3SU5O5ic/+QmLFy+W4C76pFAfD+aPjSG9pJ4Gix1fDz2+njocTpW3t+a6ttuYWc7ag8UMifSnttlGo9VOlL8nMYHHg5Rer2fQoBRqamppaKhn0KAUIqOiXeu1Wi1JSYOJioqmsrICc3Mzzc1N1NfXkXZwHxUVLfU0c7KzyMvNdhsHBKDRaPDx8cXH15eC/DwASkuKSD90kOqqKnJzjrluD+Xn51JaWsKAAYn4+voTF9ev3YdB6upqyTxymIaGBurqaiksyMdiNRMREY2qqjQ3NTEgMQmHw0FVVQVVlRWoqkpcfEK74xGF6AsSw3z4/dxhfHmwmG3ZVTTbHFjtTkrrzOzNP17mxWxz8tvP08mtbGJS/2BiAr2IDvDEQ9/SGz9k6AjqG+r59n/r2nzfAXx9fRk2fDTR0bEEBgXj6enFui8/I+3gvnbrkILC8WRQZef2LRTk5aDV6dEoCioqVosFs8WMxWzGarW2OU5VVSUeHh6MHTfJ7e6GqqrU19eRn5dLYUFey0NmniaSU4YSExvvNhGE0+nEZrNiMBhPm1uUFBfx1VdfkJeb/UOy+g233bGYkF704FqnJX7V1dVcc801bNmyBeAUvyBw6NAhHnjgAd5++20+++wz/P39O6uJQnQbrQO6T/TY7CS+PlxKcW1rWRdY/t/DDAzzoclqx2p3EuXvyayUcGYkheLn1XI1rSgKfn4B+PkFnPKpW29vH7epnBwOO4FBwezauY283JY5h0/8I2AwGgkNCSM8IgpPT08UpWWquaOZGQDk5Bwj94fAeaLSkiJqqitJTBxEQ0M9ERFRrt5Hp9NJbm42+Xk5mM3N5OflUlFRhs3W8uRzfd0hKn/4d3V1JRaLBafTSV1dHTqdjsrKCmJj44mJjUejkcnqRd9jMuqYOzqGK4ZEUN1kpabJRmWjlTc35/BN+vHxe802B69+l82ne4sYFu1HcoQvUxJDGBMXgEajMGHCZBobG9i2ZZPbdzgmJo4x4yYyaFAyWu3x9OG6628iNi6eb75eh9nccrs5JCSMseMmoqoq6778zC1+lJQcr+5xNhoa6tm7ZxchoeH0758ItMxEkpr6NbU11W0S1IyMNKKjY0lOGYaXyURDQz31dXVYLRb8/P0ZNHhIm97DysoKvlr3OVlZR9zec2NjI++8/TqL7v0x3t6nv1PRU3RK4qeqKtdddx2bN28GICgoiJtvvpnx48cTHh6OqqqUlpayfft2PvjgAyoqKti8eTPXXXeda1o3Ifo6H089/zcriZ//e59rWXGt2ZUIAuwrqGVnbjW7c6u5Ykg4Y+IDO/RaWq2O5OSheJu82blzKxnph3A6nfj6+rmu9DUaDYGBQUREROHj68uB/XuwWizk5eUAxy/uNBoNoaFhlJaWoKoqFouFtLT9hIaFY7fbqaurIb5ff3Jzs6mrraWoqICiwgLX+J4TVVZWULN9C6FhYTQ2tJSUaL0l5R8QSHNzE+XlZURERtHU2EhDQz2NjQ0YjUYio2IID4906zEQojcyGXWYjDqif3jGakCoN9r/pPHVoVK37crqLXx9uIzUjHI2Ha1gdko4N42JIdBkYPr0yzA3mzmU1jKZwoDEJMaPn0xkVHSbHjNFURg1ahzx8f05eGAvISGhJA4c7Fa1Y/26/7rdPj5XFRVlbP5+A/5+/mzZ8h379u46ZQeSzWYjOzuLvLwcPL28MJvN2H+4gNRqdRw5ks74cZMYMHAQjY0NfL3+Cw4fPthuDye0JJ5vvfka9yx6sFeUrOmUxG/16tVs2rQJRVG49dZbWbFiBT4+bSeKvuOOO/jd737Hj3/8Y95++202bdrEu+++y/z58zujmUJ0ezeMiuK9nflsz6465TZl9Rbe3ppLWnEt0weGMjzKB4PNiaf+3HrBFEUhLj4BL5OJwMAQ7HYbvr6++PsH4u8fQEBgIAbD8QLVQ4eNwul0YrVaXFf0YeGRJCYOol9Cfw6l7Sft4D7M5pap6UpLiikvKyU8Iory8jLKy0spLip09fC1MhiMGI1G6uvrARWHw05xUdu5SGuqq9i5YyvRMXHU19fS2NhIQ309TU2NmLy9aWxsIC83m6ioGLx9fLGYzZgtZqwWCwEBgYSGhZ/T+RGip4jy9+T5G4fx5McH+OJASZv1dqfK7rwa9uXX8sWBYu6Z0o/hMf4MHT0Jq9WORqMwZcq0M9bpDAwMYtr0mW2Wjx4zHqfTyf/+96UrATsVjUaDTqdHq9Vit9vdxhfm5hzjvXffdJWqOhOHw0FDff1Jy+zk5hyjsCCPiMjoHx5cOX2bAKoqK3hn1b9YeNe9aDQ9+7nYTkv8oKUm39tvv33abb29vXnzzTfJy8tjw4YNrFq1ShI/IX6gKAq/vX4I1/39e5qsp756VoFduTUcLq5neLQfUUYriUEGYhJsBBkM5/SaISFhTJl6CQ6HHaPR45TjYwwGA8NHjEZVVUJDizB6eBIRGcWgQckYDEY8jB4YjR4cPnzQNRjc6XRSVJhPUWF+m+PpdDoCA4OJiIzCy8uL6upq8vJyaDrhSWJFUfD09MJsbsbpdOJ0OsnLzXbdnj5RXl4OsTHxWCwWFEWhvr6W/Pw8qqsq8fcP4Mqrrie+X/9zOjdC9BT+Xgb+dPMIBkdksfZAKUdK67GfVDfKoarsK6jl4ff2EupjJDrAEz8lkJQwD6Z7nN/42TFjJ2AyeXMk4xDOHx7CAFAUMBg88PAwYjQYQVFcPYMWi4V9e3disRx/mOzkpE9RFLxMJry8TBiNRsrLytq9W3Ayu91O/g93J04WGBjEpMnT2b9vt+sOBkBRYQErX/8nMy+fQ1xcv3ZjocNhd6t20B11SuK3e/duFEXhoYceOut9fvKTn7Bhwwb27NlzEVsmRM+TGObDM9cP4d3tedgcKp4GLV56LZWNFvbl17o9U9dkdbDlWBVaBRIC9NRocrljcj8i/DxPefz26PV61xN4p2MwGBkxcgwFwXl4eZkIC49wBcew8AisNitarZaS4kJKSoqpr29bVNpo9MDP35/IyCh8fHzR640EBgXh5eVNSEgoVVWVNNTX4+vni5+fP4qiwWq1kHkkvc00dieymM1kZqZTWJiHw+F0++NQVVXJF59/wpyrrqefJH+il/LQa3loRiJXD4vif4dL+f5oBXvya6hpatvjVVZvoay+JeHaXGChmkyWXjcUvbZj42cVRSE5ZSiDk4ec9uEKVXXS3GymqbGBmppqnE4He3bvaPc2sdFo5Jprb6T/gEQ0Gi2q6iQvL5fdu7aTm3OM5uYm17Y6vR4FTtu75+vrx4yZsxkyZDiKopAyZBivv7rCrb5hcXEh77z9OlHRsVwy4zLi4hJc78dms5Ga+jWNDZL4uUq29OvX76z3ad22dV8hxHE3jIxiVGwAVocTrUZBp1GobLTy8e4C1h4soaLBvfyCQ4XMKhs53+dQXGfhoUsHMCD0+HALp1NFUbggT9IbDEYSfhiAfbKYmDicTieKohAeEYXZ3ExBQR4N9fWYTCbCI6J+GAaiYDQaiY6JIyIiEq1Wh6o6qampoaK85Yre08uEyWTCZPKmsrICT08vqiorOHbsKFarFYPBgMFoxKDXU1lZ4Qr4TU1N7batqqqSr9d/wczL5xAf34/m5mbsdnu72wrRUymKQr9gE/dM6ceUxGA2H61gb34t27OrKKlrv6fM4lB5d0cBfl5G/m/2+c3rfaZ9FUWDl5cXXl5eBIeE4uvnh9VqZf++3W7b+fr6M/em+URFxZywVEvCDyWf8nKzyc7Owm634e3ti6enByqQfSyLvNxjmM3H36vRaGT8hClMmXqJW61Rvd7A7Xfew2uv/N3tIlVVVQryc1n11uuEhIYxdOgIkpKS+f77VA7s34t6ygqs3UOnJH5+fn5UVlZSVFTEyJEjz2qfoqKWEhC+vr3jKRohLiRFUYgPNrktiwsykRBsIjnCjy/TitmeXd2mnpfNofLJ3iKKa8387PKBGHUa8qtbpouzO1QGhvkwMSHI9UTwxRAX14+oqGgaGxtpbGygf/+BNJubMehbEjWjwYiHhwf+AQFuQVhRNAQEBBIQ0PaBFR8fXyIiosjNOYZ/QKDboG9FUXA47ORkt5SWae05MBqNxMTG42H0IC1t/w8PmRXz3cZvKMjvj6qqricUhehtFEVhULgvSWE+lNdbyKls5NuMcr46VEpuZWOb6SOdKvxz4zFCvI3cNeXsO3HOV2hoONOmz8RmtZKenoaqqkRGRnP9DTcT+MOMQiczGAwMSEyi/4CWC9ATC0aPGDGaivIy9uzZSVFhAWHhEVw6c/YpS0GZTD7cdvsi3nv3jXbHFpaXlfLN/9ax+fuNPSZedEriN2TIEDZs2MDKlSu56qqrzmqff/3rX659hRBnx9/LwC1jYxgY7s3mrEr259ewI6eKmmb3nqtt2VU88dEBIv09KK+3UNXY0kM4INSbA4U1jI4LYGiUP40WO5WNFqoabei1ChMSglz1vs6HTqfHz8//jAVZz4XRaGRg0mDi4hOwWMw/FIg1ACq5uTlotToio2LIz8/B29uH8PBIIiOjiY6JRaWlPARAfl4OZaXF2O2Obj9WR4jzpSgKob4ehPp6MK5fED+9LJG0wlq+OFjCvrxqdufV0JoDOpwqz61Nx6DXkBTmQ5PVQbPNQZS/JymRvhet9q6/fwBXXHkt0TFx2GwWhg4bdVaxo70ZQvR6AxGR0URERrezR/uCgoNZfN/D7N29g507t7Y7pKSnJH3QSYnfjTfeSGpqKh9//DFLly5lyZIlp/wFUVWVZcuW8fHHH6MoCjfddFNnNFGIXkOjURgdF8iQKD/SiuoYk1XOxkP5bCs0c+J87tkVjWRXNLrtW9FQxa7caoZH+5Mc6Utlg5XCmmaKa5vRahRmJ4fx81lJ+HhcvB7B82U0tjwFfKKEhAGEhYVzNDMDDw8PtFotiYmDCPthQvlLZlyOubmZrKwjAG6DyYXoS4w6LaPiAhkZG0B+ZT3P/2c3/z3S6Lp5aXU4+c1nh4gJ9MLXQ4evh55+ISYqG0OZlhh80ZI/k8mb8RMmo6pql0zuYDAYGDdhMmPGTeRQ2gG2bN5IaWn79QgVuvfkE52S+C1evJiXXnqJ9PR0li9fzpo1a1i4cCHjx48nLKxl8uWSkhK2bdvGm2++SVpaGgCDBg1i8eLFndFEIXodo07LqNgAkkO9iNDUEuat5dtcK9XtDOQ+kc2hsjO3mp251W3WvbE5l6IaM7+9YQjBPj2rnpXJ5M2w4aOor6/Dw8PDrRRNQEAgU6dfis1ucz0RrNXqZPYg0WcpikK4rwd3jvDD7oS1R49fJFrsTo6WHe8NTz1Szq7cairqLVw/Mgqtpv3vjcOpUttsI8BL3+HvVld/JzUaDUOGDidlyDCyjx3l+02pFBTkuYaQeHp64ePrC8Vty+Z0F52S+On1etauXcull15KdnY2hw4d4rHHHjvl9qqqkpCQwNq1a90KQAohzp1GoxDrp+fmFF9GJfqzckseWeWNZ96xHSqw7lAppfUW/jpvBLFBpjPu050oioKvr1+766KiYhg/YTIxMXEoSst8n/96Y3Unt1CI7kWnUVg0yg9vP3/+vatt/cxW+wtqeeqTA2zPqWLZtSluQ0JUVeVQUS0vfJXJsbIGpiQG89sbhnZG8y8aRVFI6J9IfL/+5OVms3v3Dux2OxMnTmHV6jVd3bzT6rSsKi4ujv3797N06VJef/11ampq2t3O39+fRYsW8etf/xpvb5l3U4gLxUOn4aahUQyO8ueVjccoqmnG26gjwMuAv5eBsnoz27KrqDef+UnWvfk1LHhtG7+5LoVLkkK7/Cr8QlAUhYEDBxMdHYuqqmg0WkxePSuxFeJi0GoUfnPNYDz0OtbsLjhlDVGzzcn7O/L5Nr2Mq4ZFcOOoaIK8jaz8Ppv3duRT29xytyF3Wx4JISbumZLQmW/jotBoNMT3609cfD+cTrVHzAzUqd1pJpOJ559/nt/+9rfs2rWLgwcPusq1BAYGMmTIEEaPHo3hHAvMCiHOjqK0jP/73Y+8yalsRKMo6LQKeq2G8noLI2MDOFBQw978GhosDoK8DcQGeuLnaSA1o5wGy/GkML+6mftX7ebqYRH86upk/D31lNSZSSusI7uikVBfI1cNjUDXwbpfXUFRFLen+xSZ81cIoCX5W3ZtCjeOjmbT0QqOlNZT0WAho6S+TfmosnoLK7/P4b3t+YT6GsmtbFtC6cWvMpk7Khp/r1P/vXc6VRyq2uHagZ1JUTT0gJwP6OTEr5XBYGDixIlMnDjxlNtkZWXx/fffAy1TuQkhLpwAk4EAk3vAHRjmw7h+gaQX17OvoIYGi50of0/6BZuIDfJiQ0Y5z35x2G1uYIvdyZrdhXx/tJLLBoditjmxOZ3Um20MCPUmwMvAtIEhnf32hBAXgUajMDzGn+Ex/pTVm0krquNwUR37CmrYlFlB40k9gc02R7tJH0C9xc6vPjnIS7eOand9bbONT/YUUttsY0xcAOMTgk45dlCcm247gG7Tpk3cddddaDSaDiV+O3bsYMmSJWzZsgWr1UpKSgo//elPufXWW8/69T/++GNSU1PJycmhsbGR+Ph4rrvuOp544gn8/f3PuU1CdHd6rYah0X4MjW47Du6a4ZH0DzHxfx/uJ63IfcaNkjozq7bluS3bkFFBZYOVfsEmYgK9Lmq7hRCdK9THg9AkD6YnhlBWb+FIWT1vfJ/Dd5nlbWoAtlIUOKHEJp8fKObuvCpGxbrX5jTbHHy8u4DdudWU1Jmpa7aSV9XEnCERF7XGaF/R7ftPTyzEerZSU1OZMmUK3333HTfeeCMPPPAAFRUVLFiwgGefffasjnHjjTfyl7/8BR8fH+644w4efPBBvLy8+MMf/sCYMWMoKys780GE6GWSI/1Ydc847pgQh7fx9NeNDlVl7cESPt1biNl26nmFhRA9l0ajEO7nwbTEEP61cCzf/GI6c0dF4efpnqDFB3nxxxuHEx90/CJQVeGxf+/HecKcwTaHk492F/Dejnz+s7+Y7TnVvL4ph5c3ZLHsszQOFtZ22nvrrbptj19H2e12Fi1ahKIobNy40TVTyJIlS5g4cSJLlizhpptuIjGx/SmlWv3sZz/jjjvuICIiwrVMVVV+/OMf849//INly5bx97///aK+FyG6owCTkWXXpXDLuBh+tzad749W4DzF9VmT1cEXB4oZEOrDFUPCabDYOVJaz9GyekZE+zMwXGbmEaI3iQk08cebR5Bb2cjrm7I5XFxHYqg3P54xgKgAL6IDPbnln1tddQGPljfy128yuXtKP7wNOtbsKuClb49SVHN8SIkK5FQ2kVPZxLpDJTx4yQB+PGNAl7y/3qDXJX7ffPMNWVlZ3HXXXW7Tw/n4+PD0008zb948Vq5cecaev8cff7zNMkVRePrpp/nHP/7Bhg0bOtxGVVVdNX9ON2G0cGez2eS8dcDFOm+JwZ68dtsI/pdeztvb8qhosOJwqjSY7ZSdMNj7UHE9Xx4ooqyuiayyBr5OL6ewxkyQycDvbkhmejceA9iROw4Xi6qq8h3oIDlvHXM+5y3CR8+TsxOpabbh56lHq1GwWq2MiPJhzpAwvjhY6tr2xa8zeXdbHv1DTKQV11HbfOrKAo0WBy+sy8Bms/PgJcefCrbYHBwuqUev1dA/xHRBZhjqqO4UN9rT6xK/1NRUAGbNmtVmXeuy80na9PqW7uvzqS9oNptd5WwyMjLQyJODZ8XpdMp564CLfd4igcfGelLeZCCrykZerZX/ZTsoazx+e3ddWgm5pVXsL7W4pn+qbLTy+Jr9PD45kKTg48WUnU4ntRYnAZ5dH55OnMi9q5nNZjIyMuQ70AESOzrmQp23k0sZ35qokJqh0GQ7niCV1lsorW87Y45BA1an+zIV+Ou3WVRVlnNdkjdZ1TYOllkw25yggFZRiPLV0c9fT7i3rtMfCulOcaM9XR9ZL7DMzEyAdm/lBgQEEBwc7NqmI1rnEG4vsRSir1IUhVCTjlCTjpERRqwO+CS9wZXkNdtV9pS0DepVzU7+uauWh8b542vUsjG3iY8P11NvVYn00fGTcf4MDjG22U8I0XN5G7UsHOHHih01p90u2lfHhCgPLA6V7Gob6ZVW17STThVW7a8jv9aGzalSWGenoqnlYtPXqCHQU0uAh5b4AD2XxHsR6NlDaq10gl6X+NXWtgz89PNrvzq/r68vBQUFHTr23r17WbZsGaGhoaedeeRMPDw8XE8FJyUluXoRxenZbDbS09MBOW/noivOm1doPaXWTDZltZ3M/GTHqm38J1vFbLOwLbvONfanqN7Or7+t5MbRUfzkkgSCfTo/AfTw6D7T0nl4eJCUlCTfgQ6Q2NExF/O8JSdDZEQB72zP52hZI7aTBgpP6BfAtcPCGdcvEJ1GweZQ+fZIOb9fl4njh22dKnyb09zm2PVWB4X1LUnglkIzRRYj902LZViUb6cUm+9OcaM9vS7xu1iys7O5+uqrcTgcvPfeewQHB3f4WIqiuKp76/V6KVh9DuS8dUxnn7ehMYFcMyKSI2UNlJ10+8ag1eDrqXMr+pp6pKLd49icKu/uKGBXXg0PzRjA5cnheBo678q9O81IoigKer1evgMdJOetYy7mebttUgILJvYjo6Sef+8qYNuxSpptDsb3C+KuyfEMCPV2+w4mRvij1+l45r+HcZzlODqbQ+Xr9HIqm2zcNSmeWSnhF338X3eKG+3pdYlfa09fa8/fyerq6k7ZG3gqubm5zJgxg/LyctasWcOMGTPOu51C9GaKonDZ4DAOFtbxzrZc11O/QSYD14+MYnC4D0s/S6PBcnZlXo6UNvDUJwfZnl3NTWOiGRrlh0aKuQrR4ymKwqAIX56+OpnKBgs1zTbiAr1OOePPXZP7YbE7+cOX6aesJtCePXk1VDZkkFXewIjYAIZG+RHs3TeHkVzwxO83v/nNBTnO3r17O7Rf69i+zMxMRo8e7bauurqaiooKJk2adNbHy8nJYcaMGRQVFfHvf/+bq6++ukPtEqKvCfI2MjslHLPNwXeZFYT5GpmaGMKVQyMYHOFDbmUTf0892iZ4B3jpuX5kFB/syHebCaDebOedbbkcq6hndko4/UN8CPczEubrgY+H3LoToqcL8jYSdBbJ2P3T+6OqKq9sPIbNoRLkbSDIZMDXU49GgWarg0arg8zSepptx58Myatq5h8bjhHqYyTYZCQhxMSkAUFMSAgi3NejR00veT4ueOK3dOnSLu3mnD59Os899xzr169n3rx5buvWr1/v2uZs5OTkcMkll1BUVMT777/Pddddd8HbK0RvNq5fIOkldQSYDHjqtUzsH0RyZEvtvnum9iOjtI71h44XQx8Y5s2TcwZzyaBQfjQqikfe28ux8kbXehXYnFXFsfJGUiJ9CTQZ8fPU4++ld4s73kYdA0K9SQzzJsTb2KGY5HSqp5yMXgjRte6f3p+rh0VSUN1Mg8VOvdlGg8WOAnjotXgatORWNvLG97mUNxwfbmK1Oymobqagupm9BTV8tKcQT72W2EAvhkT5MjY+kDA/D7z0WkxG3Q9JpRGDriUprGiw/FCLtIFmq4O4IBNJ4T7EBnr1mCnlLsqt3q6sYTNz5kwSEhJYvXo1Dz/8MCNGjACgvr6e5cuXo9PpWLhwoWv7iooKKioqCA4Odhu315r0FRYW8v7773PDDTd08jsRoucz6DRcNSyC745UEBvkxfh+x6dm8vcycP8lA9BqFNKK6kiO8OW6EVFMT2qp6zc0yp93F43nqU8O8k16mVvPYEmdhZK6crfX0igtt400SsvrBnga8PfSE+7nweyUMOaOimlze9hqd5JZVo+fp54of09XgthsdfBlWjENllPXExNCdB1FUYgJ9DrtdJA2h5NQXw/+ueEYR8saTrlds81BRmk9GaX1fLS7kNhAL5IjfekfYkKr0aAo4O/ZcnFZWmemoLqJY+WNNNscRPh5EhPgSXSgF8kRvgxrZ7rL7uaCJ37ffvvthT7kOdHpdLz22mvMnj2bqVOnMn/+fHx9ffnoo4/Izs7mmWeeYeDAga7tX3rpJZYtW8aSJUtYunSpa/kll1xCbm4uEyZMYP/+/ezfv7/Na524vRCifRF+ntw8NqbddSNj/LlscDgDw3yJDvDk8uQwt965MD9P/njTCP6x4Sjvbc+npvnURWSdKqCqOACbw0GjpZmCmmYOFtXx9eEyPj9Qwj9vG43xh4HdNU1WPtlbyOGiOow6LQmhJoZH+xPsbWTtwRL25VdT0yTFfoXoqfRaDXNHRhPgqeetLbnszK0+Yy++CuRWNZFb1YROo+Bl0GLQaTDoNFjtTiobrW7zDWf9cEdCo0Cwt5GEYJNbD2N3dMETv7O9jXoxzZgxg02bNrFkyRI++OADrFYrKSkpLF++nAULFpzVMXJzcwHYunUrW7dubXcbSfyEOD+KonD9yCgqGiyEeBvbfWDDz0vPTy8bSEyAF+9sy+VQcX2HXis1o5x7397F3xeMorLBwqqteazZXUBVY8vTxXqtQqiPB74eOrIrGzHbnNjPZfS4EKLb0WgUZg4Ow8dDz87caurNNurNdurNdoprmzla1kD1KS7w7E6VOvPZ9fo7VSirt1BWb6G83nrmHbpQr3uqt9W4ceNYu3btGbdbunRpuwlcd59yRYjeQqtRCPM9fd0rD72WW8bGEORtYMORco6WNVD3QwBvsNix2pw4VXCq6g8/7R9nw5FyfvzObryNWtYfKsXmOL6hzaFSWNNM4YV8c0KILqcoCuMTghgdFwDg9hBHbZONbTmVfH2olO3ZVeRWNtHb//r32sRPCNG76LQaZqeEEx3gRU5lIzaHE5tdxepwtvy/w4nNoWJzOLHYnJhtDhqtdr46VOp2Rb/hSPlpXkUI0Vu199Sun5eeWcnhzEoOJ7uikY92F7Ajp4oDBbVuVQVaaRQINBmI8PPEx0NHVaOFigYr1U02V2Hp7k4SPyFEj6EoCkOi/BgSdeoB1K299a1jBffl13Db69uoP80tG18PHfVmu9uVvrdRh1GnoXvftBFCXCj9gk38eMYAUjPKOVxcR22TFbtTRQVXUhdkMmDy0LX816jDanditTtptNo5XFTHkdIGSrv5w72S+AkhepWTS7cMj/HnzzeP4OH39rQZ2G3UabgiJZxxCYHY7Coldc1UN9nw89ARaDLwzGodHRtRKIToiTz0Wq4YEs6gcB+yKxrRazV4GbV4GbSYDDoCTAZMBm27JaKcTpXaZhuTX/HicEkXNP4sSeInhOj1LksO48krB/HM54cx/1DQNdTHyE1jorl5TAxxQaZ29/unt1HG/AnRB8UHm4gPbj8unIpGoxBgMmDUdd60kh0hiZ8Qok+YPy6OJouDL9NK8PXUc82wCOYMjcDLIGFQCNF3SMQTQvQJWo3CnZPjGRkXgK+HnoFh3t1+MnUhhLjQJPETQvQZRp2WsfGBZ95QCCF6qb4xI7EQQgghhJDETwghhBCir5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij5DETwghhBCij+i1id+OHTu48sorCQgIwGQyMW7cOFavXn3W+5eVlfHcc89x44030q9fPxRFQVGUi9hiIYQQQoiLS9fVDbgYUlNTmT17NgaDgXnz5uHn58dHH33EggULyMnJ4cknnzzjMQ4dOsSTTz6JoigkJibi5eVFU1NTJ7ReCCGEEOLi6HU9fna7nUWLFqEoChs3buTVV1/lhRdeYN++faSkpLBkyRIyMzPPeJzBgwezYcMGamtrycjIICYmphNaL4QQQghx8fS6xO+bb74hKyuLW2+9lZEjR7qW+/j48PTTT2O321m5cuUZjxMWFsa0adPw8fG5mM0VQgghhOg0ve5Wb2pqKgCzZs1qs6512YYNGzqzSW2oqorD4QDAZrN1aVt6EpvNJuetA+S8dZyqql3dBBdVVeWz7CA5bx0j561julPcaE+vS/xab+MmJia2WRcQEEBwcPBZ3eq9mMxmMzU1NQBkZGSg0fS6jteLwul0ynnrADlvHWc2m7u6CS5ms5mMjAz5LDtAvgMdI+etY7pT3GhPr/sUa2trAfDz82t3va+vr2sbIYQQQoi+pNf1+PUEHh4e+Pv7A5CUlIRer+/aBvUQNpuN9PR0QM7buZDz1nEeHh5d3QQXDw8PkpKS5LPsAPkOdIyct47pTnGjPb0u8Wvt6TtVr15dXd0pewM7i6IoaLVaAPR6PQaDoUvb05PIeesYOW8d051qdyqKgl6vl8+yg+S8dYyct3PXneJGe3rd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",
      "text/plain": [
       "<Figure size 640x360 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "color_list = matplotlib.colormaps['cividis_r'](np.linspace(.09, .85,3))\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(3.2, 1.8), dpi=200)\n",
    "# plot the dataset\n",
    "# make a symbol list with plus and minus for the scatterplot\n",
    "y_tick_fontsize = 7\n",
    "x_tick_fontsize = 7\n",
    "\n",
    "plot_single_metric_axis(ax1, \n",
    "                        metric_array=losses_relu_bias_standardized_plot, \n",
    "                        se_array=se_losses_relu_bias_standardized_plot,\n",
    "                        y_label=\"Loss, $\\mathcal{L}$\",\n",
    "                        fig_title = \"\",\n",
    "                        log_interval=buckets, \n",
    "                        legend_str=\"ReLU\",\n",
    "                        chance_level=None, \n",
    "                        line_width=1.4, \n",
    "                        x_tick_fontsize=y_tick_fontsize,\n",
    "                        y_tick_fontsize=y_tick_fontsize, \n",
    "                        x_label_fontsize=9,\n",
    "                        y_label_fontsize=10)\n",
    "ax1.plot(np.arange(0, num_epochs * len(train_loader),buckets), losses_linear_bias_standardized_plot, color=color_list[1], label=\"Linear\", linewidth=1)\n",
    "# # add shading for the se\n",
    "ax1.fill_between(np.arange(0, num_epochs * len(train_loader),buckets), \n",
    "                 losses_linear_bias_standardized_plot - se_losses_linear_bias_standardized_plot, \n",
    "                 losses_linear_bias_standardized_plot + se_losses_linear_bias_standardized_plot, \n",
    "                 color=color_list[1], alpha=0.5)\n",
    "# ax1.plot(np.arange(0, num_epoch * len(train_loader),buckets), losses_linear_bias_scaled_plot, color=color_list[1], label=\"Linear scaled\", linewidth=1)\n",
    "\n",
    "# ax1.fill_between(np.arange(0, num_epoch * len(train_loader),buckets), \n",
    "#                  losses_linear_bias_scaled_plot - se_losses_linear_bias_scaled_plot, \n",
    "#                  losses_linear_bias_scaled_plot + se_losses_linear_bias_scaled_plot, \n",
    "#                  color=color_list[1], alpha=0.5)\n",
    "\n",
    "ax1.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax1.set_xlim([-5, 300])\n",
    "# ax1.set_ylim([0.05, 0.55])\n",
    "# set title \n",
    "ax1.set_title(\"Bias\", fontsize=8)\n",
    "# ax1.xaxis.get_offset_text().set_fontsize(10)\n",
    "\n",
    "# set x and y limits\n",
    "plot_single_metric_axis(ax2, \n",
    "                        metric_array=losses_relu_no_bias_standardized_plot, \n",
    "                        se_array=se_losses_relu_no_bias_standardized_plot,\n",
    "                        y_label=\"Loss, $\\mathcal{L}$\",\n",
    "                        fig_title = \"\",\n",
    "                        log_interval=buckets, \n",
    "                        legend_str=\"ReLU\",\n",
    "                        chance_level=None, \n",
    "                        line_width=1.4, \n",
    "                        x_tick_fontsize=y_tick_fontsize,\n",
    "                        y_tick_fontsize=y_tick_fontsize, \n",
    "                        x_label_fontsize=9,\n",
    "                        y_label_fontsize=10)\n",
    "ax2.plot(np.arange(0, num_epochs * len(train_loader),buckets), losses_linear_no_bias_standardized_plot, color=color_list[1], label=\"Linear\", linewidth=1.4)\n",
    "# add shading for the se\n",
    "ax2.fill_between(np.arange(0, num_epochs * len(train_loader),buckets), \n",
    "                 losses_linear_no_bias_standardized_plot - se_losses_linear_no_bias_standardized_plot, \n",
    "                 losses_linear_no_bias_standardized_plot + se_losses_linear_no_bias_standardized_plot, \n",
    "                 color=color_list[1], alpha=0.5)\n",
    "# remove teh y_label from the second plot\n",
    "ax2.set_ylabel(\"\")\n",
    "# remove the tick labels from the y axis\n",
    "ax2.yaxis.set_ticklabels([])\n",
    "\n",
    "# ax2.plot(np.arange(0, num_epoch * len(train_loader),buckets), losses_linear_no_bias_scaled_plot, color=color_list[1], label=\"Linear scaled\", linewidth=1)\n",
    "# # add shading for the se\n",
    "# ax2.fill_between(np.arange(0, num_epoch * len(train_loader),buckets), \n",
    "#                  losses_linear_no_bias_scaled_plot - se_losses_linear_no_bias_scaled_plot, \n",
    "#                  losses_linear_no_bias_scaled_plot + se_losses_linear_no_bias_scaled_plot, \n",
    "#                  color=color_list[1], alpha=0.5)  \n",
    "ax2.legend(prop={'size': 5})\n",
    "# only plot part of the x range\n",
    "ax2.set_xlim([-5, 300])\n",
    "# ax2.set_ylim([0.05, 0.55])\n",
    "# set title \n",
    "ax2.set_title(\"No Bias\", fontsize=8)\n",
    "# ax2.xaxis.get_offset_text().set_fontsize(10)\n",
    "# fix y axis to be the same for both plots\n",
    "ax1.set_ylim([0.05, 0.55])\n",
    "ax2.set_ylim([0.05, 0.55])\n",
    "\n",
    "# make title for both subplots with less space below\n",
    "# fig.suptitle(\"MNIST, pixel-wise norm.\", fontsize=10, y=.9)\n",
    "plt.tight_layout()\n",
    "save_figure('/relu_nets_bias/', 'MNIST_bias_vs_no_bias_standardized_v2', fig)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "behav-analysis-fmri",
   "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.10.17"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
