{
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "id": "sopHPgEhu4Jo",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "d0eb3033-9d14-41f8-bc01-77383b0e6b79"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-1-bbec0cc7a895>:8: DeprecationWarning: Please use `gaussian_filter` from the `scipy.ndimage` namespace, the `scipy.ndimage.filters` namespace is deprecated.\n",
            "  from scipy.ndimage.filters import gaussian_filter\n"
          ]
        }
      ],
      "source": [
        "import os\n",
        "\n",
        "import numpy as np\n",
        "from PIL import Image\n",
        "\n",
        "import matplotlib.pyplot as plt\n",
        "import matplotlib\n",
        "from scipy.ndimage.filters import gaussian_filter\n",
        "\n",
        "import torch\n",
        "import torch.nn as nn\n",
        "import torch.nn.functional as F\n",
        "import torch.optim as optim\n",
        "from torch.autograd import grad\n",
        "from torchvision import transforms\n",
        "from torchvision import datasets\n",
        "import torchvision.datasets.utils as dataset_utils\n",
        "\n",
        "from sklearn.datasets import make_classification\n",
        "from sklearn import tree\n",
        "from sklearn.model_selection import train_test_split\n",
        "from torch.utils.data import TensorDataset, DataLoader\n",
        "\n",
        "import random"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "kkTMK-oJveGg"
      },
      "source": [
        "## Generate Slab Data\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "seed=60\n",
        "torch.manual_seed(seed)\n",
        "np.random.seed(seed)\n",
        "random.seed(seed)"
      ],
      "metadata": {
        "id": "P_LfJAsB-vPI"
      },
      "execution_count": 2,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": 3,
      "metadata": {
        "id": "knP-xNzavgAb"
      },
      "outputs": [],
      "source": [
        "# Base code from https://github.com/harshays/simplicitybiaspitfalls\n",
        "\n",
        "def get_orthonormal_matrix(n):\n",
        "    H = np.random.randn(n, n)\n",
        "    s = np.linalg.svd(H)[1]\n",
        "    s = s[s>1e-7]\n",
        "    if len(s) != n: return get_orthonormal_matrix(n)\n",
        "    Q, R = qr(H)\n",
        "    return Q\n",
        "\n",
        "def _prep_data(X, Y, N_tr, N_te, bs, nw, pm, w, orth_matrix=None):\n",
        "    X_te, Y_te = torch.Tensor(X[:N_te,:]), torch.Tensor(Y[:N_te])\n",
        "    X_tr, Y_tr = torch.Tensor(X[N_te:,:]), torch.Tensor(Y[N_te:])\n",
        "    Y_te, Y_tr = map(lambda Z: Z.long(), [Y_te, Y_tr])\n",
        "\n",
        "    tr_dl = DataLoader(TensorDataset(X_tr, Y_tr), batch_size=bs, num_workers=nw, pin_memory=pm, shuffle=True)\n",
        "    te_dl = DataLoader(TensorDataset(X_te, Y_te), batch_size=bs, num_workers=nw, pin_memory=pm, shuffle=False)\n",
        "\n",
        "    return {\n",
        "        'X': torch.tensor(X).float(),\n",
        "        'Y': torch.tensor(Y).long(),\n",
        "        'w': w,\n",
        "        'tr_dl': tr_dl,\n",
        "        'te_dl': te_dl,\n",
        "        'N': (N_tr, N_te),\n",
        "        'W': orth_matrix\n",
        "    }\n",
        "\n",
        "def _get_random_data(N, dim, scale):\n",
        "    X = np.random.uniform(size=(N, dim))\n",
        "    X *= scale\n",
        "    Y = np.random.choice([0,1], size=N)\n",
        "    return X, Y\n",
        "\n",
        "def generate_linsep_data_v2(N_tr, dim, eff_margin, width=10., bs=256, scale_noise=True, pm=True, nw=0, no_width=False, N_te=5000): # no unif_max.\n",
        "    assert eff_margin < 1, \"equal range constraint\"\n",
        "    margin = eff_margin if no_width else eff_margin*width\n",
        "\n",
        "    N = N_tr + N_te\n",
        "    w = np.zeros(shape=dim)\n",
        "    w[0] = 1\n",
        "\n",
        "    X, Y = _get_random_data(N, dim, width if scale_noise else 1.)\n",
        "\n",
        "    U = np.random.uniform(size=N)\n",
        "    if no_width: X[:,0] = (2*Y-1)*margin\n",
        "    else: X[:, 0] = (2*Y-1)*(margin + (width-margin)*U)\n",
        "\n",
        "    P = np.random.permutation(X.shape[0])\n",
        "    X, Y = X[P,:], Y[P]\n",
        "\n",
        "    return _prep_data(X, Y, N_tr, N_te, bs, nw, pm, w)\n",
        "\n",
        "def sample_from_unif_union_of_unifs(unifs, size):\n",
        "    x = []\n",
        "    choices = Counter(np.random.choice(list(range(len(unifs))), size=size))\n",
        "    for choice, sz in choices.items():\n",
        "        s = np.random.uniform(low=unifs[choice][0], high=unifs[choice][1], size=sz)\n",
        "        x.append(s)\n",
        "    x = np.concatenate(x)\n",
        "    return x\n",
        "\n",
        "def generate_ub_linslab_data_diffmargin_v2(N_tr, dim, eff_lin_margins, eff_slab_margins,\n",
        "                                           slabs_per_coord, slab_p_vals, corrupt_lin=0., corrupt_slab=0.,\n",
        "                                           corrupt_slab7=0., scale_noise=True, width=10., lin_coord=0, lin_shift=0.,\n",
        "                                           slab_shift=0., indep_slabs=True, bs=256, pm=True, nw=0, N_te=10000,\n",
        "                                           random_transform=False, corrupt_lin_margin=False, corrupt_5slab_margin=False):\n",
        "    get_unif = lambda a: np.random.uniform(size=a)\n",
        "    get_bool = lambda a: np.random.choice([0,1], size=a)\n",
        "    get_sign = lambda a: 2*get_bool(a)-1.\n",
        "\n",
        "    def get_slab_width(NS, B, SM):\n",
        "        if NS==3: return (2.*B-4.*SM)/3.\n",
        "        if NS==5: return (2.*B-8.*SM)/5.\n",
        "        if NS==7: return (2.*B-12.*SM)/7.\n",
        "        return None\n",
        "\n",
        "    num_lin, num_slabs = map(len, [eff_lin_margins, eff_slab_margins])\n",
        "    assert 0 <= corrupt_lin <= 1, \"input is probability\"\n",
        "    assert num_lin + num_slabs <= dim, \"dim constraint, num_lin: {}, num_slabs: {}, dim: {}\".format(num_lin, num_slabs, dim)\n",
        "    for elm in eff_lin_margins: assert 0 < elm < 1, \"equal range constraint (0 < eff_lin_margin={} < 1)\".format(elm)\n",
        "    for esm in eff_slab_margins: assert 0 < esm < 1, \"equal range constraint (0 < eff_slab_margin={} < 0.25)\".format(esm)\n",
        "\n",
        "    lin_margins = list(map(lambda x: x*width, eff_lin_margins))\n",
        "    slab_margins = list(map(lambda x: x*width, eff_slab_margins))\n",
        "\n",
        "    # hyperplane\n",
        "    N = N_tr + N_te\n",
        "    half_N = N//2\n",
        "    w = np.zeros(shape=dim); w[0] = 1\n",
        "\n",
        "    X, Y = _get_random_data(N, dim, width if scale_noise else 1.)\n",
        "    nrange = list(range(N))\n",
        "    # linear\n",
        "    total_corrupt = int(round(N*corrupt_lin))\n",
        "    no_linear = num_lin == 0\n",
        "    if not no_linear:\n",
        "        for coord, lin_margin in enumerate(lin_margins):\n",
        "            if indep_slabs:\n",
        "                P = np.random.permutation(N)\n",
        "                X, Y = X[P, :], Y[P]\n",
        "            X[:, coord] = (2*Y-1)*(lin_margin+(width-lin_margin)*get_unif(N)) + lin_shift*width\n",
        "\n",
        "            # corrupt linear coordinate\n",
        "            if total_corrupt > 0:\n",
        "                corrupt_sample = np.random.choice(nrange, size=total_corrupt, replace=False)\n",
        "                if corrupt_lin_margin:\n",
        "                    X[corrupt_sample, 0] = np.random.uniform(low=-lin_margin, high=lin_margin, size=total_corrupt)\n",
        "                else:\n",
        "                    X[corrupt_sample, 0] *= -1\n",
        "\n",
        "    # slabs\n",
        "    i = (num_lin)*int(not no_linear)\n",
        "    for idx, coord in enumerate(range(i, i+num_slabs)):\n",
        "        slab_per = slabs_per_coord[idx]\n",
        "        assert slab_per in [3, 5, 7], \"Invalid slabs_per_coord\"\n",
        "\n",
        "        slab_pval = slab_p_vals[idx]\n",
        "        slab_margin = slab_margins[idx]\n",
        "        slab_width = get_slab_width(slab_per, width, slab_margin)\n",
        "\n",
        "        if indep_slabs:\n",
        "            P = np.random.permutation(N)\n",
        "            X, Y = X[P, :], Y[P]\n",
        "\n",
        "        if slab_per == 3:\n",
        "            # positive slabs\n",
        "            idx_p = (Y==1).nonzero()[0]\n",
        "            offset = 0.5*slab_width + 2*slab_margin\n",
        "            X[idx_p, coord] = get_sign(len(idx_p))*(offset+slab_width*get_unif(len(idx_p)))\n",
        "\n",
        "            # negative center\n",
        "            idx_n = (Y==0).nonzero()[0]\n",
        "            X[idx_n, coord] = 0.5*get_sign(len(idx_n))*slab_width*get_unif(len(idx_n))\n",
        "\n",
        "        if slab_per == 5:\n",
        "            # positive slabs\n",
        "            idx_p = (Y==1).nonzero()[0]\n",
        "            offset = (width+6*slab_margin)/5.\n",
        "            X[idx_p, coord] = get_sign(len(idx_p))*(offset+slab_width*get_unif(len(idx_p)))\n",
        "\n",
        "            # negative slabs partitioned using p val\n",
        "            idx_n = (Y==0).nonzero()[0]\n",
        "            in_ctr = np.random.choice([0,1], p=[1-slab_pval, slab_pval], size=len(idx_n))\n",
        "            idx_nc, idx_ns = idx_n[(in_ctr==1)], idx_n[(in_ctr==0)]\n",
        "\n",
        "            # negative center\n",
        "            X[idx_nc, coord] = 0.5*get_sign(len(idx_nc))*slab_width*get_unif(len(idx_nc))\n",
        "\n",
        "            # negative sides\n",
        "            offset = (8*slab_margin+3*width)/5.\n",
        "            X[idx_ns, coord] = get_sign(len(idx_ns))*(offset+slab_width*get_unif(len(idx_ns)))\n",
        "\n",
        "            # corrupt slab 5\n",
        "            total_corrupt = int(round(N*corrupt_slab))\n",
        "            if total_corrupt > 0:\n",
        "                if corrupt_5slab_margin:\n",
        "                    offset1 = (width+6*slab_margin)/5.\n",
        "                    offset2 = (8*slab_margin+3*width)/5.\n",
        "                    unifs = [\n",
        "                        (0.5*slab_width, offset1),\n",
        "                        (offset1+slab_width, offset2),\n",
        "                        (-offset1, -0.5*slab_width),\n",
        "                        (-offset2, -(offset1+slab_width))\n",
        "                    ]\n",
        "\n",
        "                    idx = np.random.choice(range(N), size=total_corrupt, replace=False)\n",
        "                    X[idx, coord] = sample_from_unif_union_of_unifs(unifs, total_corrupt)\n",
        "                else:\n",
        "                    # get corrupt sample\n",
        "                    idx = np.random.choice(range(N), size=total_corrupt, replace=False)\n",
        "                    idx_p = idx[np.argwhere((Y[idx]==1))].reshape(-1)\n",
        "                    idx_n = idx[np.argwhere((Y[idx]==0))].reshape(-1)\n",
        "\n",
        "                    # move negative points to random positive slabs\n",
        "                    offset = (0.5*slab_width+2*slab_margin)\n",
        "                    X[idx_n, coord] = torch.Tensor(get_sign(len(idx_n))*(offset+slab_width*get_unif(len(idx_n))))\n",
        "\n",
        "                    # pick negative slab for each positve point\n",
        "                    mv_to_ctr = np.random.choice([0, 1], size=len(idx_p))\n",
        "                    idx_p_ctr = idx_p[np.argwhere(mv_to_ctr==1)].reshape(-1)\n",
        "                    idx_p_sid = idx_p[np.argwhere(mv_to_ctr==0)].reshape(-1)\n",
        "\n",
        "                    # move positive points to negative slabs\n",
        "                    X[idx_p_ctr, coord] = torch.Tensor(0.5*get_sign(len(idx_p_ctr))*slab_width*get_unif(len(idx_p_ctr)))\n",
        "\n",
        "                    # move negative points to positve slabs\n",
        "                    offset = 1.5*slab_width + 4*slab_margin\n",
        "                    X[idx_p_sid, coord] = torch.Tensor(get_sign(len(idx_p_sid))*(offset+slab_width*get_unif(len(idx_p_sid))))\n",
        "\n",
        "        if slab_per == 7:\n",
        "            # positive slabs\n",
        "            idx_p = (Y==1).nonzero()[0]\n",
        "            in_s0 = np.random.choice([0,1], p=[1-slab_pval, slab_pval], size=len(idx_p))\n",
        "            idx_p0, idx_p1 = idx_p[(in_s0==1)], idx_p[(in_s0==0)]\n",
        "\n",
        "            # positive slab 0 (inner)\n",
        "            offset = 0.5*slab_width+2*slab_margin\n",
        "            X[idx_p0, coord] = get_sign(len(idx_p0))*(offset+slab_width*get_unif(len(idx_p0)))\n",
        "\n",
        "            # positive slab 1 (outer)\n",
        "            offset = 2.5*slab_width+6*slab_margin\n",
        "            X[idx_p1, coord] = get_sign(len(idx_p1))*(offset+slab_width*get_unif(len(idx_p1)))\n",
        "\n",
        "            # negative slabs\n",
        "            idx_n = (Y==0).nonzero()[0]\n",
        "            in_s0 = get_bool(len(idx_n))\n",
        "            idx_n0, idx_n1 = idx_n[(in_s0==1)], idx_n[(in_s0==0)]\n",
        "\n",
        "            # negative slab 0 (center)\n",
        "            X[idx_n0, coord] = 0.5*get_sign(len(idx_n0))*slab_width*get_unif(len(idx_n0))\n",
        "\n",
        "            # negative slab 1 (outer)\n",
        "            offset = 1.5*slab_width+4*slab_margin\n",
        "            X[idx_n1, coord] = get_sign(len(idx_n1))*(offset+slab_width*get_unif(len(idx_n1)))\n",
        "\n",
        "            # corrupt slab7\n",
        "            total_corrupt = int(round(N*corrupt_slab7))\n",
        "            if total_corrupt > 0:\n",
        "                # corrupt data\n",
        "                idx = np.random.choice(range(len(X)), size=total_corrupt, replace=False)\n",
        "                idx_p = idx[np.argwhere((Y[idx]==1))].reshape(-1)\n",
        "                idx_n = idx[np.argwhere((Y[idx]==0))].reshape(-1)\n",
        "\n",
        "                # pick positive slab for each negative slab\n",
        "                mv_to_inner = get_bool(len(idx_n))\n",
        "                idx_n_inner = idx_n[np.argwhere(mv_to_inner==1)].reshape(-1)\n",
        "                idx_n_outer = idx_n[np.argwhere(mv_to_inner==0)].reshape(-1)\n",
        "\n",
        "                # move to idx_n_inner and outer\n",
        "                offset = 0.5*slab_width+2*slab_margin\n",
        "                X[idx_n_inner, coord] = torch.Tensor(get_sign(len(idx_n_inner))*(offset+slab_width*get_unif(len(idx_n_inner))))\n",
        "                offset = 2.5*slab_width+6*slab_margin\n",
        "                X[idx_n_outer, coord] = torch.Tensor(get_sign(len(idx_n_outer))*(offset+slab_width*get_unif(len(idx_n_outer))))\n",
        "\n",
        "                # pick negative slab for each positive point\n",
        "                mv_to_ctr = get_bool(len(idx_p))\n",
        "                idx_p_ctr = idx_p[np.argwhere(mv_to_ctr==1)].reshape(-1)\n",
        "                idx_p_sid = idx_p[np.argwhere(mv_to_ctr==0)].reshape(-1)\n",
        "\n",
        "                # move to idx_n_inner and outer\n",
        "                X[idx_p_ctr, coord] = torch.Tensor(0.5*get_sign(len(idx_p_ctr))*(slab_width*get_unif(len(idx_p_ctr))))\n",
        "                offset = 1.5*slab_width+4*slab_margin\n",
        "                X[idx_p_sid, coord] = torch.Tensor(get_sign(len(idx_p_sid))*(offset+slab_width*get_unif(len(idx_p_sid))))\n",
        "\n",
        "        # shift\n",
        "        X[:, coord] += slab_shift*width\n",
        "\n",
        "    # reshuffle\n",
        "    P = np.random.permutation(N)\n",
        "    X, Y = X[P,:], Y[P]\n",
        "\n",
        "    # lin coord position\n",
        "    if not random_transform and lin_coord != 0:\n",
        "        X[:, [0, lin_coord]] = X[:, [lin_coord, 0]]\n",
        "\n",
        "    # transform\n",
        "    W = np.eye(dim)\n",
        "    if random_transform: W = get_orthonormal_matrix(dim)\n",
        "    X  = X.dot(W)\n",
        "\n",
        "    return _prep_data(X, Y, N_tr, N_te, bs, nw, pm, w, orth_matrix=W)\n",
        "\n",
        "\n",
        "def generate_ub_linslab_data_v2(N_tr, dim, eff_lin_margin, eff_slab_margin=None, lin_coord=0,\n",
        "                                corrupt_lin=0., corrupt_slab=0., corrupt_slab3=0., corrupt_slab7=0.,\n",
        "                                scale_noise=True, num_lin=1, lin_shift=0., slab_shift=0., random_transform=False,\n",
        "                                num_slabs=1, slabs_per_coord=5, width=10., indep_slabs=True, no_linear=False,\n",
        "                                bs=256, pm=True, nw=0, N_te=10000, corrupt_lin_margin=False, slab5_pval=3/4.,\n",
        "                                slab3_pval=1/2., slab7_pval=7/8., corrupt_5slab_margin=False):\n",
        "    slab_p_map = {5: slab5_pval, 7: slab7_pval, 3: slab3_pval}\n",
        "    slabs_per_coord = [slabs_per_coord]*num_slabs if type(slabs_per_coord) is int else slabs_per_coord[:]\n",
        "    for x in slabs_per_coord: assert x in slab_p_map\n",
        "    slab_p_vals = [slab_p_map[x] for x in slabs_per_coord]\n",
        "    lms = [eff_lin_margin]*num_lin\n",
        "    sms = eff_slab_margin if type(eff_slab_margin) is list else [eff_slab_margin]*num_slabs\n",
        "    return generate_ub_linslab_data_diffmargin_v2(N_tr, dim, lms, sms, slabs_per_coord, slab_p_vals, lin_coord=lin_coord, corrupt_slab=corrupt_slab,\n",
        "                                                  corrupt_slab7=corrupt_slab7, corrupt_lin=corrupt_lin, scale_noise=scale_noise, width=width,\n",
        "                                                  lin_shift=lin_shift, slab_shift=slab_shift, random_transform=random_transform, indep_slabs=indep_slabs,\n",
        "                                                  pm=pm, bs=bs, corrupt_lin_margin=corrupt_lin_margin, nw=nw, N_te=N_te, corrupt_5slab_margin=corrupt_5slab_margin)\n",
        "\n",
        "\n",
        "def get_lms_data(**kw):\n",
        "    \n",
        "    c = config =  {\n",
        "        'num_train': 10_000,\n",
        "        'dim': 2,\n",
        "        'lin_margin': 0.05,\n",
        "        'slab_margin': 0.1,\n",
        "        'same_margin': False,\n",
        "        'random_transform': False,\n",
        "        'width': 1, # data width\n",
        "        'bs': 1000,\n",
        "        'corrupt_lin': 0.0,\n",
        "        'corrupt_lin_margin': False,\n",
        "        'corrupt_slab': 0.0,\n",
        "        'num_test': 50_000,\n",
        "        'hdim': 100, # model width\n",
        "        'hl': 1, # model depth\n",
        "        'device': gu.get_device(0),\n",
        "        'input_dropout': 0,\n",
        "        'num_lin': 1,\n",
        "        'num_slabs': 0,\n",
        "        'num_slabs7': 0,\n",
        "        'num_slabs3': 1,\n",
        "    }\n",
        "    \n",
        "    c.update(kw)\n",
        "\n",
        "    smargin = c['lin_margin'] if c['same_margin'] else c['slab_margin']\n",
        "    data_func = generate_ub_linslab_data_v2\n",
        "    spc = [3]*c['num_slabs3']+[5]*c['num_slabs'] + [7]*c['num_slabs7']\n",
        "    data = data_func(c['num_train'], c['dim'], c['lin_margin'], slabs_per_coord=spc, eff_slab_margin=smargin, random_transform=c['random_transform'], N_te=c['num_test'],\n",
        "                     corrupt_lin_margin=c['corrupt_lin_margin'], num_lin=c['num_lin'], num_slabs=c['num_slabs3']+c['num_slabs']+c['num_slabs7'], width=c['width'], bs=c['bs'], \n",
        "                     corrupt_lin=c['corrupt_lin'], corrupt_slab=c['corrupt_slab'])\n",
        "    return data, c\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "def get_data(**c):\n",
        "    smargin = c['lin_margin'] if c['same_margin'] else c['slab_margin']\n",
        "    spc = [3]*c['num_slabs3']+[5]*c['num_slabs'] + [7]*c['num_slabs7']\n",
        "    data = generate_ub_linslab_data_v2(c['num_train'], c['dim'], c['lin_margin'], slabs_per_coord=spc, eff_slab_margin=smargin, random_transform=c['random_transform'], N_te=c['num_test'],\n",
        "                     corrupt_lin_margin=c['corrupt_lin_margin'], num_lin=c['num_lin'], num_slabs=c['num_slabs3']+c['num_slabs']+c['num_slabs7'], width=c['width'], bs=c['bs'], \n",
        "                     corrupt_lin=c['corrupt_lin'], corrupt_slab=c['corrupt_slab'], corrupt_slab7=c['corrupt_slab7'])\n",
        "    return data"
      ],
      "metadata": {
        "id": "KiRjxqq9IBwe"
      },
      "execution_count": 4,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "XOnjIjK8q7UJ"
      },
      "source": [
        "## Plotting Functions"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 5,
      "metadata": {
        "id": "EwUoQZCyvs6T"
      },
      "outputs": [],
      "source": [
        "def plot_data(datas, datas1, use_w=False):\n",
        "  fig, (ax, ax_) = plt.subplots(1,2,figsize=(14, 4))\n",
        "  \n",
        "  X, Y = datas['X'], datas['Y']\n",
        "  if use_w:\n",
        "    W = datas['W']\n",
        "    X = X.numpy().dot(W.T)\n",
        "  else:\n",
        "    X = X.numpy()\n",
        "  ax.scatter(X[:,0], X[:,1], c=Y, cmap='coolwarm', s=4, alpha=0.8) # first coord is linear, second is slab\n",
        "  ax.set_xlabel('linear component', fontsize=15)\n",
        "  ax.set_ylabel('first slab component', fontsize=15)\n",
        "\n",
        "  X, Y = datas1['X'], datas1['Y']\n",
        "  if use_w:\n",
        "    W = datas1['W']\n",
        "    X = X.numpy().dot(W.T)\n",
        "  else:\n",
        "    X = X.numpy()\n",
        "  ax_.scatter(X[:,0], X[:,1], c=Y, cmap='coolwarm', s=4, alpha=0.8) # first coord is linear, second is slab\n",
        "  ax_.set_xlabel('linear component', fontsize=15)\n",
        "  ax_.set_ylabel('first slab component', fontsize=15)\n",
        "\n",
        "  fig.suptitle('LMS-3 data', fontsize=15)\n",
        "  plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "def plot_boundary_heatmap(model, test_loader, config, show=True, dim=0):\n",
        "    device = config['device']\n",
        "    model.eval()\n",
        "\n",
        "    matplotlib.rcParams['contour.negative_linestyle'] = 'solid'\n",
        "    plt.rcParams[\"figure.figsize\"] = (3, 3)\n",
        "    #cm = ListedColormap(['#0365C0', '#C82506'])\n",
        "    n = 100\n",
        "    d1_min = -1\n",
        "    d1_max = 1\n",
        "    d2_min = -1\n",
        "    d2_max = 1\n",
        "    d1, d2 = torch.meshgrid([\n",
        "        torch.linspace(d1_min, d1_max, n),\n",
        "        torch.linspace(d2_min, d2_max, n)])\n",
        "    heatmap_plane = torch.stack((d1.flatten(), d2.flatten()), dim=1)\n",
        "    if dim==0:\n",
        "        heatmap_plane_with_noise = torch.cat((heatmap_plane, torch.zeros(size=(n * n, config['dim'] - 2))), dim=1)\n",
        "    else:\n",
        "        heatmap_plane_with_noise = torch.cat((torch.zeros(size=(n * n, dim)), heatmap_plane, torch.zeros(size=(n * n, config['dim'] - 2 - dim))), dim=1)\n",
        "    hmap = model(heatmap_plane_with_noise).data.cpu().numpy()[:,1].reshape(n, n)\n",
        "    hmap = gaussian_filter(hmap, 2.0) # smoothing!\n",
        "    hmp_x = heatmap_plane[:, 0].data.numpy().reshape(n, n)\n",
        "    hmp_y = heatmap_plane[:, 1].data.numpy().reshape(n, n)\n",
        "    cont1 = plt.contourf(hmp_x, hmp_y, hmap, 10, cmap=plt.cm.RdBu_r, alpha=0.3)\n",
        "    contour = plt.contour(hmp_x, hmp_y, hmap, 10, antialiased=True, linewidths=0.2, colors='k')\n",
        "    cbar = plt.colorbar(cont1)\n",
        "    #plt.clabel(contour, colors = 'k', fmt = '%2.1f', fontsize=12)\n",
        "    cont2=plt.contour(hmp_x, hmp_y, hmap, [0.0], antialiased=True, linewidths=1, colors='k')\n",
        "    #cbar = plt.colorbar(cont2)\n",
        "    \n",
        "    plt.gca().set_aspect('equal', 'box')\n",
        "    plt.tick_params(left = False, bottom = False)\n",
        "    plt.xticks([])\n",
        "    plt.yticks([])\n",
        "    \n",
        "    with torch.no_grad():\n",
        "        for data, target in test_loader:\n",
        "            data, target = data.to(device), target.to(device)\n",
        "            data = data.cpu().numpy()\n",
        "            plt.scatter(data[:,dim], data[:,dim+1], c=target, cmap='coolwarm', s=4, alpha=0.8) \n",
        "            plt.xlim(-1,1)\n",
        "            plt.ylim(-1,1)\n",
        "\n",
        "    if show: plt.show()"
      ],
      "metadata": {
        "id": "NQwvbN7lo_sP"
      },
      "execution_count": 6,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def plot_boundary_heatmaps(model,model2,model3, test_loader, config, show=True, dim=0):\n",
        "    device = config['device']\n",
        "    model.eval()\n",
        "    model2.eval()\n",
        "    model3.eval()\n",
        "\n",
        "    matplotlib.rcParams['contour.negative_linestyle'] = 'solid'\n",
        "    plt.rcParams[\"figure.figsize\"] = (10, 3)\n",
        "    fig, axs = plt.subplots(1, 3)\n",
        "    #cm = ListedColormap(['#0365C0', '#C82506'])\n",
        "    n = 100\n",
        "    d1_min = -1\n",
        "    d1_max = 1\n",
        "    d2_min = -1\n",
        "    d2_max = 1\n",
        "    d1, d2 = torch.meshgrid([\n",
        "        torch.linspace(d1_min, d1_max, n),\n",
        "        torch.linspace(d2_min, d2_max, n)])\n",
        "    heatmap_plane = torch.stack((d1.flatten(), d2.flatten()), dim=1)\n",
        "    if dim==0:\n",
        "        heatmap_plane_with_noise = torch.cat((heatmap_plane, torch.zeros(size=(n * n, config['dim'] - 2))), dim=1)\n",
        "    else:\n",
        "        heatmap_plane_with_noise = torch.cat((torch.zeros(size=(n * n, dim)), heatmap_plane, torch.zeros(size=(n * n, config['dim'] - 2 - dim))), dim=1)\n",
        "    hmp_x = heatmap_plane[:, 0].data.numpy().reshape(n, n)\n",
        "    hmp_y = heatmap_plane[:, 1].data.numpy().reshape(n, n)\n",
        "\n",
        "    hmap = model3(heatmap_plane_with_noise).data.cpu().numpy()[:,1].reshape(n, n)\n",
        "    hmap = gaussian_filter(hmap, 2.0) # smoothing! \n",
        "    vmin = -3.2 #np.min(hmap)\n",
        "    vmax = 3.2 #np.max(hmap) \n",
        "    hmap = np.clip(hmap,vmin,vmax)  \n",
        "    cont1 = axs[2].contourf(hmp_x, hmp_y, hmap, 10, cmap=plt.cm.RdBu_r, alpha=0.2, vmin=vmin,vmax=vmax)\n",
        "    contour = axs[2].contour(hmp_x, hmp_y, hmap, 10, antialiased=True, linewidths=0.2, colors='k')\n",
        "    axs[2].contour(hmp_x, hmp_y, hmap, [0.0], antialiased=True, linewidths=1.5, colors='k')\n",
        "\n",
        "    hmap = model(heatmap_plane_with_noise).data.cpu().numpy()[:,1].reshape(n, n)\n",
        "    hmap = gaussian_filter(hmap, 2.0) # smoothing!    \n",
        "    hmap = np.clip(hmap,vmin,vmax)\n",
        "    axs[0].contourf(hmp_x, hmp_y, hmap, 10, cmap=plt.cm.RdBu_r, alpha=0.2, vmin=vmin,vmax=vmax)\n",
        "    contour = axs[0].contour(hmp_x, hmp_y, hmap, 10, antialiased=True, linewidths=0.2, colors='k')\n",
        "    axs[0].contour(hmp_x, hmp_y, hmap, [0.0], antialiased=True, linewidths=1.5, colors='k')\n",
        "    \n",
        "    hmap = model2(heatmap_plane_with_noise).data.cpu().numpy()[:,1].reshape(n, n)\n",
        "    hmap = gaussian_filter(hmap, 2.0) # smoothing! \n",
        "    hmap = np.clip(hmap,vmin,vmax)   \n",
        "    axs[1].contourf(hmp_x, hmp_y, hmap, 10, cmap=plt.cm.RdBu_r, alpha=0.2, vmin=vmin,vmax=vmax)\n",
        "    contour = axs[1].contour(hmp_x, hmp_y, hmap, 10, antialiased=True, linewidths=0.2, colors='k')\n",
        "    axs[1].contour(hmp_x, hmp_y, hmap, [0.0], antialiased=True, linewidths=1.5, colors='k')\n",
        "  \n",
        "    fig.subplots_adjust(right=0.8,wspace=0.1)\n",
        "    cbar_ax = fig.add_axes([0.82, 0.15, 0.01, 0.7])\n",
        "    fig.colorbar(cont1, cax=cbar_ax)\n",
        "    \n",
        "\n",
        "    #cbar = fig.colorbar(cont1)\n",
        "    #plt.clabel(contour, colors = 'k', fmt = '%2.1f', fontsize=12)\n",
        "    for i in range(3):\n",
        "      axs[i].set_aspect(1)\n",
        "      axs[i].tick_params(left = False, bottom = False)\n",
        "      axs[i].set_xticks([])\n",
        "      axs[i].set_yticks([])\n",
        "    \n",
        "    with torch.no_grad():\n",
        "        for data, target in test_loader:\n",
        "            data, target = data.to(device), target.to(device)\n",
        "            data = data.cpu().numpy()\n",
        "            for i in range(3):\n",
        "              axs[i].scatter(data[:,dim], data[:,dim+1], c=target, cmap='coolwarm', s=4, alpha=0.8) \n",
        "              axs[i].set_xlim(-1,1)\n",
        "              axs[i].set_ylim(-1,1)\n",
        "\n",
        "    if show: plt.show()"
      ],
      "metadata": {
        "id": "_78Lr5y-MX-S"
      },
      "execution_count": 7,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "jleIZ9vNv5rV"
      },
      "source": [
        "## Define models\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 8,
      "metadata": {
        "id": "9hYJRewnv80x"
      },
      "outputs": [],
      "source": [
        "class LinearReg(nn.Module):\n",
        "  def __init__(self, inputSize=10, outputSize=2):\n",
        "        super(LinearReg, self).__init__()\n",
        "        self.in_size = inputSize\n",
        "        self.linear = torch.nn.Linear(inputSize, outputSize, bias = False)\n",
        "        #self.apply(self._init_weights)\n",
        "        \n",
        "  def forward(self, x):\n",
        "        x = x.view(-1, self.in_size)\n",
        "        out = self.linear(x)\n",
        "        return out\n",
        "\n",
        "class FCN(nn.Module):\n",
        "  def __init__(self, inputSize=10, hdim=100, outputSize=2):\n",
        "        super(FCN, self).__init__()\n",
        "        self.in_size = inputSize\n",
        "        self.linear1 = torch.nn.Linear(inputSize, hdim)\n",
        "        self.linear2 = torch.nn.Linear(hdim, outputSize)\n",
        "        #self.apply(self._init_weights)\n",
        "        \n",
        "  def forward(self, x):\n",
        "        x = x.view(-1, self.in_size)\n",
        "        x1 = F.leaky_relu(self.linear1(x))\n",
        "        out = self.linear2(x1) #.flatten()\n",
        "        return out\n",
        "\n",
        "def kaiming_init(m):\n",
        "    if isinstance(m, nn.Linear):\n",
        "        nn.init.kaiming_uniform_(m.weight.data)\n",
        "        nn.init.kaiming_uniform_(m.bias.data)\n",
        "\n",
        "def get_fcn(idim=2, hdim=100, odim=1, hl=1, init=False, activation=nn.ReLU, use_activation=True, use_bn=False, input_dropout=0, dropout=0):\n",
        "    #use_dropout = dropout > 0\n",
        "    layers = []\n",
        "    #if input_dropout > 0: layers.append(nn.Dropout(input_dropout))\n",
        "    layers.append(nn.Linear(idim, hdim))\n",
        "    if use_activation: layers.append(activation())\n",
        "    #if use_dropout: layers.append(nn.Dropout(dropout))\n",
        "    #if use_bn: layers.append(nn.BatchNorm1d(hdim))\n",
        "    '''\n",
        "    for _ in range(hl-1):\n",
        "        l = [nn.Linear(hdim, hdim)]\n",
        "        if use_activation: l.append(activation())\n",
        "        #if use_dropout: l.append(nn.Dropout(dropout))\n",
        "        #if use_bn: l.append(nn.BatchNorm1d(hdim))\n",
        "        layers.extend(l)\n",
        "    '''\n",
        "    layers.append(nn.Linear(hdim, odim))\n",
        "    model = nn.Sequential(*layers)\n",
        "\n",
        "    if init: model.apply(kaiming_init)\n",
        "    return model\n",
        "\n",
        "class FCN2(nn.Module):\n",
        "    def __init__(self, idim=2, hdim=100, odim=2, init=False, \\\n",
        "                    activation=nn.ReLU, \\\n",
        "                    use_bn=False, input_dropout=0, dropout=0):\n",
        "        super().__init__()\n",
        "        self.idim = idim\n",
        "        self.hdim = hdim \n",
        "        self.odim = odim \n",
        "\n",
        "        self.fc1 = nn.Linear(idim, hdim)\n",
        "        #if input_dropout > 0: layers.append(nn.Dropout(input_dropout))\n",
        "        self.activation = activation()\n",
        "        self.fc2 = nn.Linear(hdim, odim)\n",
        "        #if use_dropout: layers.append(nn.Dropout(dropout))\n",
        "        #if use_bn: layers.append(nn.BatchNorm1d(hdim))\n",
        "        \n",
        "        if init: \n",
        "            self.apply(self._kaiming_init)\n",
        "    \n",
        "    def _kaiming_init(self):\n",
        "        if isinstance(self, nn.Linear):\n",
        "            nn.init.kaiming_uniform_(self.weight.data)\n",
        "            nn.init.kaiming_uniform_(self.bias.data)\n",
        "    \n",
        "    def forward(self, x):\n",
        "        x = self.fc1(x)\n",
        "        x = self.activation(x)\n",
        "        x = self.fc2(x)\n",
        "        return x"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "il3cATYxwIyP"
      },
      "source": [
        "## Test ERM"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "use_cuda = torch.cuda.is_available()\n",
        "DEVICE = torch.device(\"cpu\")\n",
        "\n",
        "c = config =  {\n",
        "    'num_train': 10000, # training dataset size\n",
        "    'dim': 10, # input dimension\n",
        "    'lin_margin': 0.05, # linear margin\n",
        "    'slab_margin': 0.075, # slab margin,\n",
        "    'same_margin': False, # keep same margin\n",
        "    'random_transform': False, # apply random transform\n",
        "    'width': 1, # data width\n",
        "    'num_lin': 1, # number of linear components\n",
        "    'num_slabs': 0, #. number of 5-slabs\n",
        "    'num_slabs7': 0, # number of 7-slabs\n",
        "    'num_slabs3': 1, # number of 3-slabs\n",
        "    'bs': 500, # batch size\n",
        "    'corrupt_lin': 0.0, # p_noise\n",
        "    'corrupt_lin_margin': True, # noise model\n",
        "    'corrupt_slab': 0.0, # slab corruption\n",
        "    'corrupt_slab7': 0.0, # slab corruption\n",
        "    'num_test': 50_000, # test dataset size\n",
        "    'hdim': 100, # model width\n",
        "    'hl': 1, # model depth\n",
        "    'mtype': 'fcn', # model architecture\n",
        "    'device': DEVICE, # GPU device\n",
        "    'lr': 0.005, # step size\n",
        "    'weight_decay': 5e-4, # weight decay\n",
        "    'momentum': 0.99 \n",
        "}\n"
      ],
      "metadata": {
        "id": "v1VSDqoTIdwd"
      },
      "execution_count": 9,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": 10,
      "metadata": {
        "id": "L4qZtXx_weBb"
      },
      "outputs": [],
      "source": [
        "def test_model(model, device, test_loader, set_name=\"test set\"):\n",
        "  model.eval()\n",
        "  test_loss = 0\n",
        "  correct = 0\n",
        "  with torch.no_grad():\n",
        "    for data, target in test_loader:\n",
        "      data, target = data.to(device), target.to(device) #.float()\n",
        "      output = model(data)\n",
        "      test_loss += F.cross_entropy(output, target, reduction='sum').item()  # sum up batch loss\n",
        "      pred = torch.argmax(output, 1) #torch.where(torch.gt(output, torch.Tensor([0.0]).to(device)),\n",
        "      #                   torch.Tensor([1.0]).to(device),\n",
        "      #                   torch.Tensor([0.0]).to(device))  # get the index of the max log-probability\n",
        "      correct += pred.eq(target.view_as(pred)).sum().item()\n",
        "\n",
        "  test_loss /= len(test_loader.dataset)\n",
        "\n",
        "  print('\\nPerformance on {}: Average loss: {:.4f}, Accuracy: {}/{} ({:.2f}%)\\n'.format(\n",
        "    set_name, test_loss, correct, len(test_loader.dataset),\n",
        "    100. * correct / len(test_loader.dataset)))\n",
        "\n",
        "  return 100. * correct / len(test_loader.dataset)\n",
        "\n",
        "\n",
        "def erm_train(model, device, train_loader, optimizer, epoch):\n",
        "  model.train()\n",
        "  for batch_idx, (data, target) in enumerate(train_loader):\n",
        "    data, target = data.to(device), target.to(device) #.float()\n",
        "    optimizer.zero_grad()\n",
        "    output = model(data)\n",
        "    loss = F.cross_entropy(output, target)\n",
        "    loss.backward()\n",
        "    optimizer.step()\n",
        "    if epoch % 1000 == 0:\n",
        "      print('Train Epoch: {} [{}/{} ({:.0f}%)]\\tLoss: {:.6f}'.format(\n",
        "        epoch, batch_idx * len(data), len(train_loader.dataset),\n",
        "               100. * batch_idx / len(train_loader), loss.item()))\n",
        "\n",
        "\n",
        "def train_and_test_erm(all_train_loader, test_loader,idim=2,lr=c['lr'],epochs=10, nn=True):\n",
        "  use_cuda = False #torch.cuda.is_available()\n",
        "  device = torch.device(\"cuda\" if use_cuda else \"cpu\")\n",
        "\n",
        "  kwargs = {'num_workers': 1, 'pin_memory': True} if use_cuda else {}\n",
        "  \n",
        "  torch.manual_seed(seed)\n",
        "  np.random.seed(seed)\n",
        "  random.seed(seed)\n",
        "  if nn:\n",
        "    model = FCN(idim).to(device)\n",
        "  else:\n",
        "    model = LinearReg(idim).to(device)\n",
        "\n",
        "  optimizer = optim.SGD(model.parameters(), lr=lr, weight_decay=c['weight_decay'])\n",
        "\n",
        "  for epoch in range(1, epochs):\n",
        "    erm_train(model, device, all_train_loader, optimizer, epoch)\n",
        "    if epoch%200==0:\n",
        "      test_model(model, device, all_train_loader, set_name='train set')\n",
        "      test_model(model, device, test_loader)\n",
        "  return model\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "datas = get_data(**c) \n",
        "idim=c['dim']\n",
        "hdim=c['hdim']\n",
        "odim=2"
      ],
      "metadata": {
        "id": "cbArYswiIhiO"
      },
      "execution_count": 11,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Train FCN"
      ],
      "metadata": {
        "id": "07Gg_d3wQBKS"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "model = train_and_test_erm(datas['tr_dl'], datas['te_dl'], idim=idim, epochs=301)"
      ],
      "metadata": {
        "id": "JHClSjKbIo_7",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "04100211-e7d2-42de-fd56-1008961387ed"
      },
      "execution_count": 12,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "Performance on train set: Average loss: 0.0641, Accuracy: 10000/10000 (100.00%)\n",
            "\n",
            "\n",
            "Performance on test set: Average loss: 0.0642, Accuracy: 50000/50000 (100.00%)\n",
            "\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plot_boundary_heatmap(model, datas['te_dl'], c)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 336
        },
        "id": "_85F9amFpERf",
        "outputId": "55180427-1594-4552-cbd4-024db8ff9314"
      },
      "execution_count": 13,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.10/dist-packages/torch/functional.py:504: UserWarning: torch.meshgrid: in an upcoming release, it will be required to pass the indexing argument. (Triggered internally at ../aten/src/ATen/native/TensorShape.cpp:3483.)\n",
            "  return _VF.meshgrid(tensors, **kwargs)  # type: ignore[attr-defined]\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x300 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Train linear model (the simple model for CMID)"
      ],
      "metadata": {
        "id": "H4TyZfpXQEOI"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "model_lin = train_and_test_erm(datas['tr_dl'], datas['te_dl'], idim=idim,lr=10*c['lr'], epochs=301, nn = False)"
      ],
      "metadata": {
        "id": "SIVe61e7rqu6",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "outputId": "0a064cda-b984-463e-e88b-5762e702be29"
      },
      "execution_count": 14,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "Performance on train set: Average loss: 0.0613, Accuracy: 10000/10000 (100.00%)\n",
            "\n",
            "\n",
            "Performance on test set: Average loss: 0.0614, Accuracy: 50000/50000 (100.00%)\n",
            "\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "plot_boundary_heatmap(model_lin, datas['te_dl'], c)"
      ],
      "metadata": {
        "id": "qXjtxr15pSGw",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 282
        },
        "outputId": "1e782843-53c0-403e-a4df-3ddbcd230188"
      },
      "execution_count": 15,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x300 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "PRAXf7ozQYdJ"
      },
      "source": [
        "#Mutual Information Computations"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 16,
      "metadata": {
        "id": "gFz8fq5cQbl1"
      },
      "outputs": [],
      "source": [
        "## Information Computations\n",
        "# Base code from https://github.com/anoneurips2019/SGD-learns-functions-of-increasing-complexity\n",
        "\n",
        "# estimate I(M(x); y | L(x))\n",
        "\n",
        "def kernel_val(x, mu, sig):\n",
        "    a=torch.div(torch.exp(torch.div(-torch.square((x-mu)), 2*torch.square(torch.tensor(sig)))), torch.sqrt(torch.tensor(2*torch.pi)))\n",
        "    return a\n",
        "\n",
        "def getbinvals(M, cen_arr, Xv, Yv, device, sig=0.05):\n",
        "    X=torch.zeros((4)).to(device)\n",
        "    Y=torch.zeros((4)).to(device)\n",
        "    for i in range(4):\n",
        "    #for j in range(4):\n",
        "        X[i]=kernel_val(Xv, cen_arr[i], sig)\n",
        "        Y[i]=kernel_val(Yv, cen_arr[i], sig)\n",
        "    M = torch.outer(torch.div(X, torch.sum(X)), torch.div(Y, torch.sum(Y)))\n",
        "    return M\n",
        "    \n",
        "\n",
        "def est_IMYL(model, linModel, x, y, device, round=True, bin=False):\n",
        "    Mx, Lx, y = est_pred(model, linModel, x, y)\n",
        "    p = est_density(Mx, y, Lx, device, round, bin)\n",
        "    return I_XYZ(p)\n",
        "\n",
        "def est_IMLY(model, linModel, x, y, device, round=True, bin=False):\n",
        "    Mx, Lx, y = est_pred(model, linModel, x, y)\n",
        "    p = est_density(Mx, Lx, y, device, round, bin)\n",
        "    return I_XYZ(p)\n",
        "\n",
        "def est_pred(model, linModel, x, y):\n",
        "    o1 = model(x)\n",
        "    o1 = torch.nn.Softmax(dim=1)(o1) #sigmoid(o1)\n",
        "\n",
        "    o2 = linModel(x)\n",
        "    o2 = torch.squeeze(torch.nn.Softmax(dim=1)(o2)) #sigmoid(o2))\n",
        "    Mx = torch.flatten(o1[:,1])\n",
        "    Lx = torch.flatten(o2[:,1])\n",
        "    y = torch.flatten(y)\n",
        "    \n",
        "    #p = est_density(Mx, y, Lx)\n",
        "    return Mx, Lx, y\n",
        "    \n",
        "def est_density(X, Y, Z, device, round=True, bin=False): # estimate p[x,y,z] \\in R^{{0,1}^3} for samples from X, Y, Z \\in \\N\n",
        "    \n",
        "    if not bin: \n",
        "     if round: \n",
        "      X = torch.round(X).int()\n",
        "      Y = torch.round(Y).int()\n",
        "     else:\n",
        "      X = torch.sigmoid(12.5*(X-0.5))\n",
        "      Y = torch.sigmoid(12.5*(Y-0.5))\n",
        "    Z = torch.round(Z).int()\n",
        "    \n",
        "    n = X.size(dim=0)\n",
        "    #print(n)\n",
        "    if bin:\n",
        "      p = torch.zeros((4,4,2)).to(device)\n",
        "      cen_arr = torch.tensor([0.125, 0.375, 0.625, 0.875])\n",
        "    else:\n",
        "      p = torch.zeros((2, 2, 2)).to(device) # p[x,y,z] is the joint prob density\n",
        "    \n",
        "    flag=True\n",
        "    for i in range(n):\n",
        "      #if i==1:\n",
        "      #  flag=False\n",
        "      if bin:\n",
        "        if round:\n",
        "         #i1 = (torch.round(2*X[i])+torch.round(X[i])).int()\n",
        "         i1 = (1*(X[i]>0.25)+1*(X[i]>0.5)+1*(X[i]>0.75)).int()\n",
        "         i2 = (1*(Y[i]>0.25)+1*(Y[i]>0.5)+1*(Y[i]>0.75)).int()\n",
        "         #i2 = (torch.round(2*Y[i])+torch.round(Y[i])).int()\n",
        "         p[i1, i2, Z[i]]+=1\n",
        "        else:\n",
        "         M = torch.zeros((4,4,2)).to(device)\n",
        "         M = getbinvals(M, cen_arr, X[i], Y[i], device)\n",
        "         #if flag:\n",
        "         #  print(M)\n",
        "         p[:,:,Z[i]] += M #/torch.sum(M, axis=(0,1))\n",
        "      else:\n",
        "        p[0, 0, Z[i]] += (1.0-X[i])*(1.0-Y[i])\n",
        "        p[0, 1, Z[i]] += (1.0-X[i])*(Y[i])\n",
        "        p[1, 0, Z[i]] += (X[i])*(1.0-Y[i])\n",
        "        p[1, 1, Z[i]] += X[i]*Y[i]\n",
        "    \n",
        "    p /= n\n",
        "    if bin and flag:\n",
        "      print(p)\n",
        "    return p\n",
        "\n",
        "def I_XYZ(p): # compute I(X, Y | Z) for joint density p[x, y, z]\n",
        "    pz = torch.sum(p, axis=(0,1), keepdims=True) # the density of z. pz[x,y,z] = p(z)\n",
        "    \n",
        "    p_xy_z = p / pz  # q[x, y, z] = p(x, y | z)\n",
        "    p_x_z =  torch.sum(p, axis=1, keepdims=True) / pz  # p(x | z)\n",
        "    p_y_z =  torch.sum(p, axis=0, keepdims=True) / pz  # p(y | z)\n",
        "    \n",
        "    I = torch.sum(p * torch.nan_to_num(torch.log2( p_xy_z / (p_x_z * p_y_z) )))\n",
        "    return I\n",
        "\n",
        "\n",
        "# returns I(A; B) where A, B \\in {X, Y, Z} spefice by idx\n",
        "# eg, I(X; Y) = I_ab(p, idx=[0, 1])\n",
        "#     I(X; Z) = I_ab(p, idx=[0, 2])\n",
        "def I_ab(p, idx=(0,1)): \n",
        "    exlude = (0+1+2) - np.sum(idx)\n",
        "    p_ab = torch.sum(p, axis=exlude)\n",
        "    p_a = torch.sum(p_ab, axis=1, keepdims=True)\n",
        "    p_b = torch.sum(p_ab, axis=0, keepdims=True)\n",
        "    \n",
        "    I = torch.sum(p_ab * torch.nan_to_num(torch.log2( p_ab / (p_a * p_b) )))\n",
        "    return I\n",
        "\n",
        "def H(q): # binary entropy\n",
        "    return -q*torch.log2(q) - (1-q)*torch.log2(1-q)"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ZMFqwKY7tjG_"
      },
      "source": [
        "# CMID"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 17,
      "metadata": {
        "id": "hGHo7x7PtieR"
      },
      "outputs": [],
      "source": [
        "def mi_reg(model, lin, x_train, y_train,device):\n",
        "  I_MLY = est_IMLY(model, lin, x_train, y_train,device,round=False)  # p[M, Y, L]\n",
        "  #I_MYL = I_XYZ(pMYL)\n",
        "  return torch.abs(I_MLY)\n",
        "\n",
        "\n",
        "def erm_train_reg(model, device, train_loader, optimizer, epoch,m1=None,lam=0.0):\n",
        "  model.train()\n",
        "  \n",
        "  for batch_idx, (data, target) in enumerate(train_loader):\n",
        "    data, target = data.to(device), target.to(device) #.float()\n",
        "    optimizer.zero_grad()\n",
        "    output = model(data)\n",
        "    \n",
        "    if lam!=0:\n",
        "      l1 = mi_reg(model,m1,data,target,device)\n",
        "    else: l1 = 0\n",
        "    if lam==-1:\n",
        "      lam=min(epoch**1.5/15,8)\n",
        "    loss = F.cross_entropy(torch.squeeze(output), target)+ (lam)*l1\n",
        "    loss.backward()\n",
        "    optimizer.step()\n",
        "    if epoch % 100 == 0:\n",
        "      print('Train Epoch: {} [{}/{} ({:.0f}%)]\\tLoss: {:.6f}'.format(\n",
        "        epoch, batch_idx * len(data), len(train_loader.dataset),\n",
        "               100. * batch_idx / len(train_loader), loss.item()))\n",
        "\n",
        "\n",
        "def train_and_test_erm_reg(all_train_loader, test_loader, idim, m1=None, lam=0, epochs=2, sched=False, model=None):\n",
        "  use_cuda = False #torch.cuda.is_available()\n",
        "  device = torch.device(\"cuda\" if use_cuda else \"cpu\")\n",
        "\n",
        "  kwargs = {'num_workers': 1, 'pin_memory': True} if use_cuda else {} \n",
        "  torch.manual_seed(seed)\n",
        "  np.random.seed(seed)\n",
        "  random.seed(seed)\n",
        "  if model is None:\n",
        "    model = FCN(idim).to(device)\n",
        "  \n",
        "  optimizer = optim.SGD(model.parameters(), lr=c['lr'], weight_decay=c['weight_decay'])\n",
        "  if sched:\n",
        "    sched1 = ExponentialLR(optimizer, gamma=0.9)\n",
        "\n",
        "  for epoch in range(1, epochs):\n",
        "    if epoch==1:\n",
        "      for params in model.parameters():\n",
        "        print(params.requires_grad)\n",
        "    erm_train_reg(model, device, all_train_loader, optimizer, epoch,m1,lam)\n",
        "    \n",
        "    if sched:\n",
        "      sched1.step()\n",
        "    if epoch%100==0:\n",
        "      test_model(model, device, all_train_loader, set_name='train set')\n",
        "      test_model(model, device, test_loader)\n",
        "      plot_boundary_heatmap(model, test_loader, c)\n",
        "  \n",
        "  return model\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "for lam in [150]:\n",
        "  print('Lam = ', lam)\n",
        "  wreg3=train_and_test_erm_reg(datas['tr_dl'], datas['te_dl'], idim=idim, m1=model_lin, lam=lam,epochs=301)\n",
        "  print('=================================================')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        },
        "id": "e4RdWzK4-sPm",
        "outputId": "1866710c-d628-4c33-8765-e728de1cb828"
      },
      "execution_count": 18,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Lam =  150\n",
            "True\n",
            "True\n",
            "True\n",
            "True\n",
            "Train Epoch: 100 [0/10000 (0%)]\tLoss: 0.553782\n",
            "Train Epoch: 100 [500/10000 (5%)]\tLoss: 0.568133\n",
            "Train Epoch: 100 [1000/10000 (10%)]\tLoss: 0.572328\n",
            "Train Epoch: 100 [1500/10000 (15%)]\tLoss: 0.551071\n",
            "Train Epoch: 100 [2000/10000 (20%)]\tLoss: 0.567356\n",
            "Train Epoch: 100 [2500/10000 (25%)]\tLoss: 0.566584\n",
            "Train Epoch: 100 [3000/10000 (30%)]\tLoss: 0.543337\n",
            "Train Epoch: 100 [3500/10000 (35%)]\tLoss: 0.564813\n",
            "Train Epoch: 100 [4000/10000 (40%)]\tLoss: 0.532503\n",
            "Train Epoch: 100 [4500/10000 (45%)]\tLoss: 0.555786\n",
            "Train Epoch: 100 [5000/10000 (50%)]\tLoss: 0.574710\n",
            "Train Epoch: 100 [5500/10000 (55%)]\tLoss: 0.559650\n",
            "Train Epoch: 100 [6000/10000 (60%)]\tLoss: 0.551506\n",
            "Train Epoch: 100 [6500/10000 (65%)]\tLoss: 0.558439\n",
            "Train Epoch: 100 [7000/10000 (70%)]\tLoss: 0.547156\n",
            "Train Epoch: 100 [7500/10000 (75%)]\tLoss: 0.580480\n",
            "Train Epoch: 100 [8000/10000 (80%)]\tLoss: 0.536891\n",
            "Train Epoch: 100 [8500/10000 (85%)]\tLoss: 0.561549\n",
            "Train Epoch: 100 [9000/10000 (90%)]\tLoss: 0.541982\n",
            "Train Epoch: 100 [9500/10000 (95%)]\tLoss: 0.544782\n",
            "\n",
            "Performance on train set: Average loss: 0.4752, Accuracy: 9257/10000 (92.57%)\n",
            "\n",
            "\n",
            "Performance on test set: Average loss: 0.4765, Accuracy: 46222/50000 (92.44%)\n",
            "\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x300 with 2 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAARkAAAEJCAYAAACgxlOMAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABJn0lEQVR4nO2dd3yUVfb/38/09EISUihJ6EoJRUIHBQ1FBay4WH+ILuquyqqrrm0Rxb6o68pXV1FsWFBWBUEEUZBeAtIhEAikkp5Mpj+/P2ICIXWS506B5/16zQvmmTvn3pnMnLn33HPPR5JlWUZFRUVFEBpvD0BFReX8RnUyKioqQlGdjIqKilBUJ6OioiIU1cmoqKgIRXUyKioqQlGdjIqKilBUJ6OioiIU1cmoqKgIRXUyKioqQlGdjIqKD/PWW2+RmJiIyWQiNTWVLVu2NNrWbrczZ84cunTpgslkol+/fqxYsaJNNhVBVlFR8UkWL14sGwwG+f3335f37t0rz5w5Uw4PD5fz8vIabP/II4/I8fHx8rJly+SMjAz5P//5j2wymeQdO3a02qYSqE5GRcVHGTx4sHzvvffW3nc6nXJ8fLw8b968BtvHxcXJ//73v+tcu+aaa+Tp06e32qYSqMslFRUfxGazsX37dsaNG1d7TaPRMG7cODZu3Njgc6xWKyaTqc61gIAA1q9f32qbSqATZllF5QLAYrFgs9la1FaWZSRJqnPNaDRiNBrrtT19+jROp5P27dvXud6+fXsOHDjQoP20tDRee+01Ro0aRZcuXVi9ejVff/01Tqez1TaVQJ3JqKi0EovFQqf4BMLCwlp069ChQ71r8+bNU2w8r7/+Ot26daNnz54YDAbuu+8+7rjjDjQa737N1ZmMikorsdlsFBQXsX7RYoIDA5tsW2E2M+LWaWRlZREaGlp7vaFZDEBUVBRarZa8vLw61/Py8oiNjW3wOdHR0SxduhSLxUJhYSHx8fE8+uijJCcnt9qmEqgzGRWVNhIcGEhIYFCTtxonFBoaWufWmJMxGAwMHDiQ1atX115zuVysXr2aoUOHNjkek8lEQkICDoeDJUuWMHny5DbbbAvqTEZFxUeZPXs2t912G4MGDWLw4MHMnz+fyspK7rjjDgBuvfVWEhISapdcmzdv5tSpU6SkpHDq1CmeeeYZXC4XjzzySIttikB1MioqPsqNN95IQUEBTz31FLm5uaSkpLBixYrawO2JEyfqxFssFgtPPPEER48eJTg4mIkTJ/LRRx8RHh7eYpsikGRZLSSuotIaysrKCAsLI/2rbwkJDGqybbm5kpTrrqa0tLROTOZCQI3JqKioCEV1MioqKkJRnYyKiopQVCejoqIiFNXJqKioCEV1MioqKkJRnYyKiopQVCejoqIiFNXJqKioCEV1MioqKkJRnYyKiopQVCejoqIiFNXJqKioCEV1MioqKkJRnYyKiopQWlS0yuVykZ2dTUhISL1q6yoq5wuyLFNeXk58fLzXi2/X8NZbb/Hyyy+Tm5tLv379ePPNNxk8eHCDbceMGcMvv/xS7/rEiRNZtmwZALfffjsffvhhncfT0tIaVJpUihY5mezsbDp27ChsECoqvkRWVhYdOnTw9jD4/PPPmT17NgsWLCA1NZX58+eTlpbGwYMHiYmJqdf+66+/riPPUlhYSL9+/bj++uvrtBs/fjwLFy6svd9YnWGlaJGTCQkJAWBt+gGC//i/LMtcM24koeERfL/sB5/w/Hk5J8nPL2DY4EHeHkot2Uf2kZuXx6D+/VttY+8Tr3Pqo+8VHBVsd1UyUNN0NTfR7HCZGaBpusq/CMplF7nY6CbVFUIzyy5udx2r/bx7m9dee42ZM2fW1t9dsGABy5Yt4/333+fRRx+t1z4yMrLO/cWLFxMYGFjPyRiNRqHqBOfSIidTs0QKDgkhOORM6cCnX/wXM6dN5bkXX+RlBfVjWkto6EUcO7qM8iobCe2jvD0cAEIHDOHwF58gSbT6wxs/oA/FH/+g6LhiNHrMuIiS9IradQejJBEoaT3eb6CkJctla7RvkSGBsrKyOvcbE3erUXt87LHHaq+5q/b43nvvMW3aNIKC6v6YrF27lpiYGCIiIrjsssuYO3cu7dq1a8WraRltmn6MuHQs9z/6JP994zUWf/qxUmNqE5ePn8hPP67Ebrd7eyi1TLruJr77YSWtLacce+UohUcEPaQADsoWxe26QztJR4Hsnb+TjHKlrcPDTURENH0LD6+eNXXs2LFF4m5NqT3m5uY2O6YtW7awZ88e7rzzzjrXx48fz6JFi1i9ejUvvvgiv/zyCxMmTKhVmRRBm9UK7n7gIY4cOsg9d92JVqvl+htvUmJcrUaSJK6eMpWPPvmMqddeR0SI56fj56LRaJiUdgWfL/mGG6+d6vYvpcZoEDKubpKJA3IVPaUAIfabI1kysdlVQbQXZlNGNFhkFybJs8v8loq7tZX33nuPPn361AsST5s2rfb/ffr0oW/fvnTp0oW1a9cyduxYIWNp8zssSRIvvfUO4ydfy90z7uDTjxcpMa42oTMYmXLdDSz9egkFxWXNP8EDhMR1Jm3sZXzx9VK3ZzQVR04IGVOMpMcsuyiXxf2KNYcRCYvs8ni/Pf9wsJ6mpeJubVF7rKysZPHixcyYMaPZ8SQnJxMVFcWRI0da/iLcRBE3rtFoeOXt/zL5hj9x790z+ffr85Uw2yb0ej3X3DCNlSt+IDMr29vDASAsIYm0sZfx+ZJvcLla/sUq3bFf2Jj6S4HskCtbvZRrK32kQHbLZo/3a5A02BVcMilNW9Qev/zyS6xWKzfffHOz/Zw8eZLCwkLi4uLaPObGUGyuqNVqmffG29z25/t48vG/M/vhh732wa1Bo9Ew+ZrrSN+5k937Dnp1LDWExidy1YQ0PvtyCRZLy2Iiwb2ShY1HkiQGSkHs8MIXHUArSUiA3QufFQkJlw/Ljs2ePZt3332XDz/8kP379zNr1qx6CpJnB4ZreO+995gyZUq9YG5FRQUPP/wwmzZtIjMzk9WrVzN58mS6du1KWlqasNehqIKkJEk8NmceMe1jefmfT5CXk8MHCxei13tvBwNgbNp4tm3eyK+/FTFquDjN35YSEN2B626+g68+XsiV49MIC2ta7Kt4y+9CxxMsaQlFS45sI04SE/9pin5/zGYGSp7dUk+WjBzFSldMzTf2Au4qSAIcPHiQ9evX8+OPP9azp9Vq2b17Nx9++CElJSXEx8dzxRVX8OyzzwrNlWmRgmSNUt62jFN1trCb4ruvPufRv9zNoKEjWPL1N/W20bxBxqGDZB47xuSrJvpE5rIsy3zz6SKGDx1MXBPr7KzPf+D3WXOFj2eDq5zBUjA6L7w3m10VXCIFofFw31tdFVyiCQbALDu5wZnRYpXHmu9F5k8/EtrM57usspLEcVeoCpJKctV1N/LOZ1+Tvm0zl44eSUF+vqiuWkyX7j0YMHAgH326uE5mpLeQJIlrpt/Gjl2/czjjaKPtjFERHhnPJVIQ2+RKj/R1Lr2lAPZ4IRCrIh6h+3fDx1zGp9+vIj8nm1HDh3DsaIbI7lpERFQ0V06eyuIvl/hMQHjC1BvIzsklfXfDy6KSdHGB37PRSxraS3qyZM874CBJixnP7zLFSHryvJSrc6EgPEng4r4pLFn1K5IkMWbEMNJ37hDdZbPo9XqmXncDu3btYtvO3d4eDgAjr5iEw+Fkw+Yt9R4rSz/ksXEkSUZOyFacXgiIdpWMHPZwgmAnDJyQrR7t80LDI5lIHTonsmTVr8QmdGD8uEv5efVPnui2WS67/AqsVisrf1rj7aEAMGDEpYSHhbHq57V1rpvai0v5bojq3SbPL5uiJD1FssOjffpCbO58x2PpjpFR0Sxe9hMpg1K5burVfP7ZJ57qukn69h9A58REPvviK7dyV0TRc8AQuiYl8d0PK2uvdXviLo+OwSRpCJS0FHv4Cw8QK+nJ9vByzSRpqPJCQuCFgkdzqgODgvjv598wYfK1/PnO/8cb/3rVk903SkLHzowddzmLPv6UvMISbw+HzhelMDClH0u/q64BIld5fjp/sRTAPi8EYjtLRo/HhHpi8sprvVDweH0GvV7PK2//lzvuuZ+nn3ice//6V5+YQQQEBTP1+htZs/onDh3N9PZwiO3Si2FDBvPNt9+Dl8podJVMHo+RAARKGio9eNRBL2lwIuPw4cQ8f8Yrn15Jkvj7M3N5/LmX+Oz9d7jppmk+saWs0Wi4cvJUjhw+zNYdu7w9HKI6d2do6iV8/eXXXum/vaSnQLZ7PAh8EZ6fRaVIgexWZzNC8GqlqVtnzuLV/1vI6hXLmDhhPBUVFd4cTi0jx1yGzWZj9dpfvT0UYpJ6cnFsB9Jd3slf6S8Fke7hIwdaScIFHj2WYpA04MNnmfwZr5ezmzjlWt774n/s3bXDZ5L2oDogHNO+Pd/8T9mKdK2h13VTaSfpOOiFX9qAP0ohePqkdKJk5Diend32l7xfFuR8xOtOBmDIiFF8+v0qCnJzGDV8KMczj3l7SAAkJnetzRAWWdSnOXK+WEZHyYgLyPFColyKFMguD89m2kt68j2cJKduZ4vBJ5wMwEV9+vHVj9WV1kePGMbvu7wfEwGIjI5hwsRJfPzpYk6XlHtlDKU79gHQSwogU7Z5fLtVK0mY8GwwVuX8wWecDEDHxCSWrPqV6PaxXDF2NL+u/dnbQwLAGBDI5GuvZ8UPyzl+Msfz/cefqUyfKgWxRa7weBmNPlIAv3t4uRYr6cn1wsxNRVl8yskAtIuO5vPlq7m43wCuuXoSS778wttDAqqPyU++5jq2b9/GngOeS/MHCOycUPt/zR/1Xzx9kFHzx2zG7MHZTEcMXjlHpaIsPudkAIKCg1n41beMm3g1d95+C2+98bq3h1TL5eMnkn3qFJu2eu4MVtz1E+rcD5a0xEh6jnn4zI2nZzNqjKRa3C0xMRGTyURqaipbttQ/23Y2JSUl3HvvvcTFxWE0GunevTvLly9vk8224pNOBqrLD/7r3Q+49e77eOKxR/jLAw/4RNIewNARo3C5XPz0c321PhGU7TpQ71pnyUih7KDCgzMLrSShRcLuwZhQdd28C5Macbenn36aHTt20K9fP9LS0shvZAfWZrNx+eWXk5mZyVdffcXBgwd59913SUhIaLVNJfBZJwPVyXGPPzuPx559gU/+u4Bp03wjaQ+gT0p/2sfGsvTbZcL7Or2i4XydgVIg2z1cn7efFODRpLUQSUPZBRpwPlvc7aKLLmLBggUEBgby/vvvN9j+/fffp6ioiKVLlzJ8+HASExMZPXo0/fr1a7VNJfBpJ1PDbXffy7/e/ZA1K5eRdvk4SktLvT0koHqLu19KCp8s/kLoLCtixMAGr3ujPq9e0uBA9phjS8RI5gVYiqFG3G3cuHG115oTd/v2228ZOnQo9957L+3bt6d37948//zztekXrbGpBH7hZADGXz2VD5Z8x8F9e7h01HByczy/y9MQUe1jufyKND786BOKysQEY4P6dG/0sWBJS5ik5ZQHA6S9pAD245kzTUZJg+08ysQtKyurc7NaG3agrRF3O3r0KF999RVOp5Ply5fz5JNP8uqrrzJ37txW21QCv3EyAJcMHcHnP6yhpLiYkcNSOXSwfqzCGwQEBTPluhv4duk3ZOcXKm6/ZFN6k493lUxkylaPVfwPlbRe1WryNYJiwgiKDW/6FhMGtFxBsjW4XC5iYmJ45513GDhwIDfeeCP/+Mc/WLBggWJ9tAa/cjIA3XtdxNc/rSMgIJCxo0eyfdtWbw8JAJ1OxzU3TGPtz2s4evykora1wc2nuw+Wgj26ra3msLSOrKwsSktLa28NSZpA68Td4uLi6N69O1rtGY3vXr16kZubi81ma5NgXFvwOycDEJfQgS9/XEvHxEQmXjGW1avqyz94A0mSuGrKNexKT2fvwcOK2TWEhDTbRi9JxEp6Tnroi99ZMnLcQ32ZJOm8KSrVUgXJ1oi7DR8+nCNHjtSJDx46dIi4uDgMBkObBOPagl86GYDwiEg+/W4VAwYP5cZrp/hM0h7AuPETOJ6Zya49yhQAt1e2LLBbU5/XU0FZHZJHarB0xsgJLrzgr7vibrNmzaKoqIj777+fQ4cOsWzZMp5//nnuvffeFtsUgaLibp4mIDCQdxd/zUOz7mTmHbdSWlrC/7vTs6UqG2PkmMvY9Ns6tqc7GJjSp022ytP3tbhtzWHGFA8IpV30R/W8voJPL4dIWipcLi60lBl3xd06duzIypUrefDBB+nbty8JCQncf//9/P3vf2+xTREIE3fzJC6Xi2f+PpsvPnyPp+fM5YG/PeztIdWy6bd1REVF07/vxa22cfDp1zn24v+1uP02VyV9pACMkviJ6tniaCLZ7qpkoEas42ytuFvB7s2EhjT9HpSVVxDdN1UVd2uO71b96nV964bQaDT886V/MeMvs/nnU0/wyGOP+8w4hwwfSW5uTptiNFHjR7rVvr8U6LFCUxokr8inqPgPbjmZmLgOvPv+R2w7qOzuiRJIksTDT/6TBx9/mnffeJW/PfKIzziaEaMv5cD+/WRl5zXfuAEM7cLdaq+VJIxImD0QLO0qGTnioZwZFf/ELSeT3CGeyVOvY8+2jazdukfUmNrE3Q88xMNPz2Xhf95g9sMP+4yjuXz8RNasWY3D0QqZEaf7r6GPFMgeD8xmwiSdR9L+9UjYzpMdpgsNtxftkiQxceKV5JzIZM1m31BfPJcZ997PI888xwdvv8ljTz7l7eEA1e/blVddzRdLvnH7ua4W7i6djVaS0CB5JEHPE4cY20t68lDlZP2RVkcGx142lvxTWT47o/l/9/yV+x99kv/710u8Of81bw8HAIMpgJT+/fn51/XuPbGVJQ+qSzN4tmymKKLQUeAFsTmVttOm7YfLLr2MrIxD/LZLucQzJZk1+xFun/UXnvrHY3z68SJvDweAjp2TqKiocCs+U/77wVb1ZZQ02D1w7sckScILjWsl6Tw6wXRh0eY9zrS0CRxI3+qTwWCAvz/zHFdffxN/mXU3q1au8PZwABh92TjWulFaVHa2/gvcWRJ/ijkBA6c8oCygOhn/RJFEiiuvmsK2dT+xO/O0EuYURZIknn/9PwwZOYZbbrqRnTu2e3tISJLE8OEj+HF1yxxNcO/GT2E3R6ykJ09w1f9wtJSoByZVGkERJyNJEldffQ0bfvreZ3Zzzkan0/HWh5+R2KUrU6+axIkTx709JKJj46iqspBTUNRsW21QQJv6MgiuZuepMpkXWMLveYNiKaE6vZ5BI8ex8OPPlTKpKAGBgbz/5bcYTSaunDDeJwpfjRk7jp/XrG62nb2opE39XCQFsNcLmtYqKqDwAclOMe3o1juFz5Z4X3WxIdpFR/PBku8oLMjjmqlTsNu9uyWq0Wjo0aMn29N/b7qdXt+mfqoLP/l/jokG1OxiP0Txwy09EjvTLiaW/61cq7RpRUju1oP/LPqc9G2bufvPf/b68q57r4s4ePBAk+MIHXBRm/sJkDQeyQAWSZikpRQ19uNvCDlBl9L7YmRZ5sf13g+yNsSQkaP558uv883ij31CbmXkyFFNBoFlR9u/WD0J8IqWtpKEo1OdjB8i7JjusNQhnM49xfqdrcvxEM31N9/GLXfdy1P/eJQVP4hXHGiK8HZRlJWVNaq37bS2fXtYL0k4BG4Ce2IpE4L2glUu8GeE1gIYN/ZyDv2+g+2HTonsptU8Nud5hl86jttv/hN7fm86LiKaUaPH8MOPPzX4mKvC97N2gyUtFYLjPqIdpYoYhBccmXTlZLb+usrrQdaG0Gg0vPHeRyR07MzUqyaSn9e6U9JKEBgcQlVVVYPSKtogZYpCRUg6igSl5oeipQw17V9pWqv2uHjxYiRJYsqUKXWu33777UiSVOc2fvx4ASM/g3AnI0kSQ8dN4v0PP/V6kLUhAoOCeP/L/+FwOph81SQsFu9t9Q4dNpzVa+sLuVlzlFH3S6S6PKcIQtAIn8lcaLRW7TEzM5OHHnqIkSMbrkM0fvx4cnJyam+fffaZiOHX4pEav3FhwQwYcSkffvKlJ7pzm9j4BN797GsyDh3g1ltv9ZozDIuIbDB/JzC5oyL2dZIkbK5hwv93r3yN1qg9Op1Opk+fzj//+U+Sk5MbbGM0GomNja29RUREiHoJgAcLiXduH01yrz58/s3y5ht7gT79B/LiW++yatn/ePWlF7w2jpiYGI6dqBvD0gYGoIuLUsS+qKxZjYeyfi8UWqv2OGfOHGJiYpgxY0ajbdauXUtMTAw9evRg1qxZFBYqrxV2Nh4tJN4zOZGqygr+t3Itk9PGeLLrFjFxyrXs37uH5+Y8w0W9ezNx0lUeH0PKwEv4aeUPJHVKqHN9+G9fsv3KuzBnZRParxcXvz2Hg4+/QvnOfWhMJmRcSDodGq0OfUwEtpwCqrJywOlC0mmJGDWIjndcz8lPPiGqAlxVFjQmE4HJCQR2TyT7qx+x5hYS0DGGkF5dCe7WCVNcNAU/byF/xW84SsrQhYcQ0DEOSSthjG5H5ZETuBx2cLioKiyBCguS0UTowB4EdIhFq9dRlZmLvaScyEt6ETbwIo68vAhJryP++rGU7j5CyZa9uOx2AjvF0nnGFEyx7Tj1xSoCO8YS0qcLeT9uwpJTiC33NLrQIBI6BzHgxhsp35fB8f98gb2oDGPHWGKvql4aFP6yHUdZBbbTJTjNVjRGHdqgAFx2F7LNhkavIyC5A8HdE7GczMVeVIrTasdRVEpYt46wPkPo37esrKzOfaPR2KAsSlNqjwcONCxquH79et577z3S09Mb7X/8+PFcc801JCUlkZGRweOPP86ECRPYuHFjHb0mJfG4WkH/Pr3ZsHkTP67fzhWNaDx7kwcfe5IDe3Yx47Zb+HXDZrp17+HR/hs7BxQQ354RO/5X59qgL//ttv0OziIuuXxsvX6SZ1zTYPu4SaPglYdaZNu1+BPGXX55k23ajxvcrJ3wfmcOhEYNT6nz2MkPPsYUE4kpJpLoMZfUe278NePqXWspZZWVMO5rt5+nj4xGH9q0NpZeX33+rGPHukvfp59+mmeeecbtPs+lvLycW265hXfffZeoqMZnvdOmTav9f58+fejbty9dunRh7dq1jB07ts3jaAiv6C4NSx1CYV4O63b6hszs2Wg0Gv717oe0i47humumYDZ7fvs4IiKCLIWCvecSGRFOUVGxENueiWX53uaBO4hSkMzIyCAzM5OrrroKnU6HTqdj0aJFfPvtt+h0OjIyGp6hJScnExUVxZEjR9r+4hrBa+JuYy8by+Hfd7L1QJa3htAowcEhvP3RF+ScOsmf75nl8f77DRhE+s4dQmx37tiBY8dPCLHtmdPY/h37EaUg2bNnT37//XfS09Nrb1dffTWXXnop6enp9WZQNZw8eZLCwkLi4uKUeYEN4FUFyUlXTmbH+jXsyizw5jAapHuvi3hy3qt89+ViVq7wbLBar9fjVOAoQUPEJPWkQFCgT53JKIs7CpImk4nevXvXuYWHhxMSEkLv3r0xGAxUVFTw8MMPs2nTJjIzM1m9ejWTJ0+ma9eupKWlCXsdXnUykiRx1dVT2fTTcp/Mobn+5tu4ZPhIZs28k9KSEm8PRxEkSRL2XqszGWW58cYbeeWVV3jqqadISUkhPT29noJkTk5Oi+1ptVp2797N1VdfTffu3ZkxYwYDBw5k3bp1jc6olMDrMrU6vZ5Bo8ax8KPF/L9bb/L2cOogSRIvv/Uu44f056G//513/6/lKo5txWA0YLFYMJlMHuuzragzGeW57777uO+++xp8bO3atU0+94MPPqhzPyAggJUrVyo0spbj1ZlMDR2jI+nRbxCffPm/5ht7mNj4BO575HGWfPIh+/bu9Vi/vXpdxLZ0MZIzvjhrbAlOp7OO9rOKf+Azf7FunTrQPqETS5Y1fEjQm9x61z3ExMYxe/aDHuszqn0shafFxE48VS5TacxVFgIETutVxOAzTgagb6+eGE0BLFvTeEajNzAYDDzyzHNsXv8LG35zUzOpLfh17ER5KqvMBKpOxu9wKybz0cJMevWOJueknYBgDd26BXEsowpLlRMZmaBgPe1jDeTnW8jJttG1axAX9w1l2+Zijh0zExGmJ65DANmnzISF6eiUGExxkY3cHAvFxXYuvjgEp7Mjmzdt5Mh+O92TuvH7njJMRolrru1IcLCW3NwqQKK01E5QkJbsbAspKWFYLC6WL8/mZJaZ6JgA4uNNxMcFkJgUSGmpg8OHKoiLN3Jgfzk2m4uQUD2BAToGDgonJiaAbdsKOXCgnA4dTOTl2sjPt9CunRG9XktkpI7knmOJiUtk1p8fZtL17xIUqMUly0SG64mPDcBic5FxrILgQC2dOwfTOSGAo5lm9EaJiDADFouT/QfLGdAvjOTEYE7lWpBlOHSkjKJiO/37hjNscDt0Op/y+24h2nnl7kgnyKQ6GX/DLSeTcdjC8cwz1fU3rW+6GPeh/WaWf3dmezoTCzt3lJ/VoqSu/UM1ldu6cnjPZraFWTEYIwHYtWtfo/18vrjuWZ+cnHJ27ypvpHVdli5tKjpfUedeRNxtHNzxT35bv4WQiF5NPK9xBYJVaxuWjVn182k6xGfxn1f7o9GI/bKKismIjvWYrVZikjybga3Sdnz2ZzMiJpWywt04Hb5TMrJd3CgMpmiyjnwsxP7JbCuHj1Y037CNiJpxiJ7JmC1WggLaJg+j4nl81slA9Ze6KO83ZB8puShJWhK63ERx3gYs5lwhfWSeEH+MQavVCCkiJsuy0NmM2WIl0I+29FWq8WknI0kaImNHUphTv5CTt2jfcQIarZHc40uF2D91qvLMHUEzg6DAQKqqlC/OZTQYsNnEVUB0upzodF5P7VJxE592MgBarZHQdikU52/29lAA0OoCiOlwBbnHv8flUr4EVE7eWUXDBc0KAkwBmKuUnzEFmoxUCrBbg7/m91zo+LyTATAYIzAGxlJe4huntmM7X43TUUFx/ibFbV86sl3t/3V6nZBljcGgx25X3kGajEasAmcyKv6JXzgZgMDgzsguO5bKbG8PhaDQrgQEdyL3+LeK2y6rOBN/CggIoKpK+cC3wWCgSkAtY4NBj8Uqpoawiv/iN04GIDSyD5XlR3E4vC8R0r7jlZSe3o7D1rKt8pZy4NCZyml6gwGbre2aS+eiDWnXqMZTW9DrdDgqxGmM+2sS4YWOXzkZgMj2wynO24Ds5aLVUQmXIcsuivJ+U9Ruv95htf83GoxYBcwMdDodDoeA5VJCEg4BzkvFv/E7JyNJEpHth1OUq+yX212MpigCQ5IpOLW6+cZu0LP7mTKOBoNBSExGVLkHdaah0hB+52SgeocnKKwrZUViTim3lKj4yygtSsflVG5Jk19wxpZOr6O0QvmYjCgnI8uy6mhU6uGXTgbAFBiHJOmpqjjptTFExAxGdtkpK1auBMSe/WdiPFq9QciyRpQjqDp5FJ2givfVXHgOzB0Fya+//ppBgwYRHh5OUFAQKSkpfPTRR3XayLLMU089RVxcHAEBAYwbN47Dhw8LfQ1+62QAQiJ6Ya44jsNe2XxjAQSFdkGjDaCsaJdiNq3WMzENvU4vJPALYnJO7A4H+uBwxe2e4cLKk3FXQTIyMpJ//OMfbNy4kd27d3PHHXdwxx131ClU9dJLL/HGG2+wYMECNm/eTFBQEGlpaUKVU/3ayQBEth9Gcf4mryRqSZKG4LAelBRsV8ym2XyWk9HrsTvE5J2ImM1YrTZMRoPidi9U3FWQHDNmDFOnTqVXr1506dKF+++/n759+7J+fXV5ElmWmT9/Pk888QSTJ0+mb9++LFq0iOzsbJYuXSrsdfi9k5EkiYiYIRTne6cGTWhkH8wVxxSzd/mlZzRzdHo9DgGBX1FUWa0ECD1b5P/LpbKysjq3xnYPW6sgWYMsy6xevZqDBw8yatQoAI4dO0Zubm4dm2FhYaSmprbIZmvxeycDoNMHYQqMp6JU7NqyIYJCu+C0V2C3lShiL+vUmWmrXq8XdpBRBOYqC4EBIp2Mby6XXIHhuAIjmrmFA9XibmFhYbW3efPmNWizKQXJ3NzGD+eWlpYSHByMwWBg0qRJvPnmm1z+h+BezfPctdlWzpvTZoEhiRTlbcAZlIBWF+ixfk1B1XKylsoc9IbwNturNJ8J9IrKZwExyyWnyyXsAGO1Y/T/mUxWVhahoaG195VWCQgJCSE9PZ2KigpWr17N7NmzSU5OZsyYMYr24w7njZMBiIgZQmHOr0TFj/FYn8aA6l8Fa1VeM4WsWkZw0Jk/SbWT8Z/kNpFxsfKKSoKFzpI8Q42oW3O4qyBZg0ajoWvXrgCkpKSwf/9+5s2bx5gxY2qfl5eXV0fMLS8vj5SUlFa8mpZxXiyXapAkDUFhXT26bNLpQ5AkLTZr49Xw3GH/wTNb2P6WcyJyvMc3bSYypGm96fMJdxUkG8PlctXGfZKSkoiNja1js6ysjM2bN7tl013Oq5kMQEBQBwpz1hEU2tUjX1JJktDqg7HblNGXzjh2TmU8QUlzIhA5kympqKRTzz7C7Psis2fP5rbbbmPQoEEMHjyY+fPn11OQTEhIqI3rzJs3j0GDBtGlSxesVivLly/no48+4u233waqP6sPPPAAc+fOpVu3biQlJfHkk08SHx/PlClThL2O887JAIS260tZ0e+Etevrkf60ukDFDkrWq+/rp6Uylaa4vIK+F9BMBqoVJAsKCnjqqafIzc0lJSWlnoLk2TpUlZWV3HPPPZw8eZKAgAB69uzJxx9/zI033ljb5pFHHqGyspK77rqLkpISRowYwYoVK4SKCLrlZJzOKnT6IFFjUQy9IQyHvcxjae5aXZBiu0t9zzogCfjVTEYkF2pVPHcUJOfOncvcuXObtCdJEnPmzGHOnDlKDbFZ3IrJVBQfoLQwXdBQlCU4rAeVpYc80pdWG4BTofIT3bue82utzmRU/By3nExYVH9MgfEU5vzq87+GxoBobFYxCoznotMFKuZkcnPPSe9WZzIqfo7bu0vGgBjCogdxOudnn/+wajQGXE7xldokrRGXS5mkubPzZKqNKz/jcLlcQmYyYmdH6szLX2nVFrZOF0hEdCqFOb/4tKMJiexDWXHjonBKodUacbmUOcgYHn7O2R9BMxkRwvW+/FlQ8R6t/qTp9EGERaV47cxQS9BqjZ6ZyWgMyArNZLRa8btLLpcLrcIlGaqqqgQfjlQdmL/Spp8zvSGcwJAkvwkGi0Kj0SMrJI9yPOucshUCZgfO8kLF674UFZcQGdZ8JqvKhUeb58ymwDh0+mAqyzKUGI/iGIwRimXjNoak0SmmcnnqVN2Zl4gliMPhUHw7OP/AbiLaxytqU+X8QJGFeVBoV+y2MqxVBUqYU5TAkCTM5ZlC+9BIOsVmHAZj3eWRiGCq3e7AYNArarOotIzI8LDmG6pccCgW/QuP6k95yT6cTnEVtlqDRqtcvKRRJAkZZdQT2kUo++VvCJvdhl6nbD9VFtG1ZFT8FUW3GNrFjqAo97cLbpdBkjSKzWQ6JJxTpkJUBTuTsiUGQNwWtsPhELIbpuIZFP3LSZKWiJhUH9xxEp1joZx9w7mhEgEO22K1KF7HRCTllZWEBAR4exgqrUTxnwedPhhTUAef0a32NzIyz8kcFlFcyql8cSmRiXgnNm8lPNj3z8ypNIyQOWhgcCdcjiofCgT7z/LtkkERdS/4ybECkUvk0opK2iV2F2ZfRSzCFrphUf0pK/5dsfyRtiF6uSQrNuOoJ07gd+n/ylNSUUn4BVbm4XxCaDStXfvhFOVtENlFCxE7k1FSl7uk9JzjCX426xCByNrBvo474m579+7l2muvJTExEUmSmD9/fr02zzzzDJIk1bn17NlT4CsQ7GQ0WiOBock+EJ8R+8styy4khd7KouJznIyfzTrE4F9OUSncFXczm80kJyfzwgsvNFkH+OKLLyYnJ6f2VqPLJArh+4IBQR1w2Eq9pvJYjeiZjBMkZd7KiLBz8lf8bNahohzuirtdcsklvPzyy0ybNq3J3UOdTkdsbGztLSoqqtG2SuCR5IPw6MGUFGz1RFeNIHgm47IjScqcBTIYxB+Q9L8yD57h1/+tbL6Rh2iruFtTHD58mPj4eJKTk5k+fTonTpxo63CbxCNORpIkQiJ6UV683xPdeRyXy46kUcbJmC3nxHf8JCbjb3GehsgpUaYYfFO0VEGyteJuzZGamsoHH3zAihUrePvttzl27BgjR46kvFyZGtUN4bFomjGgPRWlh3G5HGg051cQz+W0otEok6ZfT8vtPJgh+AMOhwNtK7OKy61OJGvTB2TL/3i8Y8eOda4//fTTPPPMM63qtzVMmDCh9v99+/YlNTWVzp0788UXXzBjxgwhfXr02x4RPZiSgm1Eth/iyW4RHZNxOS1IGmVqqWikc8Z6HswQ2oKoKn7nsuzzpfTu1Fl4Py1VkGytuJu7hIeH0717d44cOaKYzXPx6IEQjdaAJGl87hBlW3E6LWi1yqS9BweLPyApAlHLpcO/rCM6PFyI7bOpsFiI7ddPeD81CpI1t8acjFLibs1RUVFBRkZGHUVJpfH4qbOwqAGUFe7ycK9ifwmdDjNavTL622fXkpJl5ZL8zsafAr9ZBadJukjsl1+WZZ+sIDx79mzeffddPvzwQ/bv38+sWbPqibs99thjte1tNhvp6emkp6djs9k4deoU6enpdWYpDz30EL/88guZmZls2LCBqVOnotVquemmm4S9Do8HRzQKFnhqOWKXHE5HJQHBnRSxFXrWTMbpdKLV+n4tXlHjBCg3mwkTnO27Zfka4iPbCe2jNbgr7padnU3//v1r77/yyiu88sorjB49ulaj6eTJk9x0000UFhYSHR3NiBEj2LRpE9HR0cJeh1cisAZjO2yWQgwm3/vDtgan3Yxer0zBpiMZ5QzqHwlU/zKJOC2t9KzDZrNhNIis7yuWrNMFjJp4JRab+HrQ7uKOuFtiYmKzPyCLFy9WamgtxitFOoLCulFZJi7Q5Gmczip0BmV+bddtPKMVZbNaMSj85bVarRj0ysZ9bDY7emFp/+IXMg6nU+D4VbziZCSFsmPd6FGYZVl24XSY0RuUmcmEhp5xAFWWKgIClIn11FBaWkp4mLJlMm12G0aFy3meQfzu2oW9fyeeC6TcmLiPkdNeCcjo9MpU6u/Y4cwulcVsxqRwsaaS7EzCwpSNcYidyaj4O150Mp6M54vry24rAUBvDFfEXkXFmWy8yooKYiKVnXUUl5TQLiJSUZs2m03xZZ0n8cWdpfMJdSbTRmqdjELLpZLSM06moqKcEIV3VsrKKwgNVdZmZVYG+mDllQosVisGhQuen0tlVRUmP3aQ/sAF4mQEzmSsJQDoDRFNN2whvXudcQBmcxWBgcrGZESoR9psNkwCdsEO/bqe2Ehl3tfG2LhsNR2jxG3fqnjVyXgy3CZyJlMMSOgMysRkgkPPim3IsuLbzSIycy1WMYHfvKJi4rtfrLjdsykoKyVpcKrQPi501JlMG7FZi9HqgxTbMQsJELs8EJGZW2UVo7lUUVVFSJD4AuLnQ5kKX+YCcTLiZjI2y2l0emViHCajxJiRYqfuomYyIpZLoDqA8wG39h0vuywYi9WEVuvC6ZQwGjV07Gjg0CE7gYEyBoOG3Fw7UVF6EhP1HDpkQ5JcFBdXp5337x+I0ajlwIFKNm7QMig1HKvVQWi4HpNJi93mIjxCT0iwlrIyJ1abi5xTFlyyjMXsomv3IGQZKipcdO9u4tjRKvLzLdjtMpHtDPRNiaB9rJH8PCvmSicBARqiYwws+eow4y5NRqfVoNVBUaGNvftKMVc60Ok1aDVaunUPJOuEheAQPfFxJk6ftlBR4SQ+IYCoKAPt2hnYv68Cm81Jv34hrF59msxMM7lHSjDFtWdSWgyBgVr0f6TXD09tR1CQjo3bigg0apEkCArSER9rYPuuEtJ/L0WjgcTOgQQG6IkMMzB6RJTffqnEjFv8e+Gf77Z/4ZaTGTQohKDg+r/aXbo03L5jx4aDlsdOn2DYFclMGNc2gfYu3Rve0ejUuW6/7eNN9OtXN4A4bLj7M4a4uDN2b74lGIApP5dycc8uzPp/Db8JV6XVP93asUMwUyZ1cLt/X0VcwSqxcTtVmdIzeOUdzj+ZyeVjPFNTxlJlxmgUp9FcXHiaDh06Nt9QxefYvHwNCT54MPJ8wytOxulyekziIuNkNmHtxMU5ykpLiDmnRKJS+EtJS1HjFP36swpP02PYcKF9qHjr7JIHV8LFBfkM7dtViG2b1UqV2UxMjPJOxmazoRd2HkhZRMWRRMenZFlWPGdIpT4edzKygNyPpjBXlhMSqnw2KsDpgmr9m+iYGMVt55zKIiFB+biNfwWW/WmsKo3hcSezbud+ohPE11L1BIV/OBkRM5mTWVn06JqkqE1/WX6B+LHKsuwX74c7CpIAX375JT179sRkMtGnTx+WL19e53FZlnnqqaeIi4sjICCAcePGcfjwYZEvwfNOpjD3JONGDvJ0t0IoyK8u8txewcLONVgtVgIUPoFtNpsJVNimKErKyggNUvZIxdlsXr6GhHZiRc3airsKkhs2bOCmm25ixowZ7Ny5kylTpjBlyhT27NlT2+all17ijTfeYMGCBWzevJmgoCDS0tKwWMTV3fZSPRkPToMF/lqdzs9DkjRECShdKOJXtrS0lDCFD0eKInPjZtoJHGtmXi69R44SZl8J3FWQfP311xk/fjwPP/wwvXr14tlnn2XAgAH8+9//Bqo/U/Pnz+eJJ55g8uTJ9O3bl0WLFpGdnc3SpUuFvQ41SaAN5OfmEhoW5jfBw9Kc44SFKnPGSjQFpWXEdr1ImH0ZfDpHpjUKkhs3bqzTHiAtLa22/bFjx8jNza3TJiwsjNTU1DarUjaFRysN7TiSTWCI5z7k5soKjApXljubU1kniGjnmTyL8r2HyXhhASVbd+OyO9AFmAi7pA/xd1xL2aZ0itZtBw1oAkzINjsVR7OwF5WiNRkISExArrKRESQz8p5byNl7nCMvL6T8UCYSYOoYS/ToSzC0C0MyGTj902bMR09i6hSLLiQYU3Q4tpJyLKfyMEa3I3L0IApXb0Iy6HGZqzhmLaKqzwBkh4PjC7+j4tAJDFFhBHaOwxgTSfGm37GXVhJycTKJM6ci2+1Ycgoxn8yjbNdhynYfxlFeiS4sGEmSiEjtw5Fff8X0zmr0ocFoAk3oAk0E9+6K1qDHVlSK7HBiPnIC6+kSbMVl4HQiA65yMwC6dmGE9euOxmTEFBuFLjQYS04+sktGtjko2baFzM3HsOUV4qysAknCmSxOFqSGsrKyOveNRmODdZybUpA8cOBAg7Zzc3ObVJys+VdpVcrm8KiTycrYz3VTr/RYf7v27qVjcndh9o8fyyAuQUwi3tlLSkdFJdum/hnriZzaazbAfOQ4OZ9936QdJ2D743lZrkr2/bwbzVm2ZaDq8AlOHK6vh2zNKah3rZzDnF696Yx9WaZcNrN+1MxmX1Pxxt2c+O/SZtuVbN1HmasSqyaIs0t7F63d1uxza3DkF1O4anODj1XJLrRYqJLqSrNa97Su7nSB2UaV1tZkmwpz9ePeVpD0Bh51Mk6nA70HCwSVlxQzOW2MMPu52acYP35C8w3dpKysjJCz4hFluw7UcTCtRYY6DkYJKnERKPnHcrGGDCwkIy4LvClEKkjGxsY22b7m37y8vDpibnl5eaSkpLj9WlqK7y5KlUBggFmWZU7n55GcnKy47eNHM0hMPLN9rTWJOeGsBJU4CfKzj5FFlgn0eDH7akQqSA4dOrROe4BVq1bVtk9KSiI2NrZOm7KyMjZv3qyoKuW5eGwms/v4aYwmcfERT3M6Px+b1UpikrK5LAAFBQUMHTyw9n5Iv56K96EUlbiI8o5813nP7Nmzue222xg0aBCDBw9m/vz59RQkExISmDdvHgD3338/o0eP5tVXX2XSpEksXryYbdu28c477wDVS/AHHniAuXPn0q1bN5KSknjyySeJj49nypQpwl6Hxz4dJw7vYfKVV3iqO+w2GzqB9WGPZVQnMHXpKibmc3ZMRqPTgUYDLpeQvtpCpeyis58tl/wFdxUkhw0bxqeffsoTTzzB448/Trdu3Vi6dCm9e/eubfPII49QWVnJXXfdRUlJCSNGjGDFihWYBBQdq8FjTsZus2E0eS4RbOvOHST1EFe68eihg2g0GpIELJfOze0pWrfVJx0MgAMZvcLLUpfA3KYS2UGYHzlFdxQkAa6//nquv/76Ru1JksScOXOYM2eOUkNsFo8tTGUPS2iVlxSTenGiMPv79+4mNj5BiIzsubEk87GTyvfhwxThoJ0k5vfvuGwjEVWdwJN4xMls2nuU8HbKHyJsCtEubde2rfTo3VeM8XN+ydtdfmGVI8jBTixilrp2ZPReCvpeqHjk3c4+fphJV4z2RFcAWK0WDAZxOzJOp5NjGYcZM0L5L7/FYsFgrPtLW7J1l+L9+DJWWcakOoLzBs/8JT1c3mHT5s107ztAmP2jhw9htVjoP2Bg841bYbtrt251rjnLKtts1yHLaNXSCeo74AWEO5ndJ05jEFj+siEsVWYGdBWXIp6+bTOSpCFFgJPJzcmha2KnOtckBaoIVsc5/CPgKcoRVMkujH5VT+f8QLiTyTywm8lXpYnuphZP1AjZuO5XOiUmKS4hW8O5sz5DeNv7ycdOtKA4h79wHCuJ+G5i4/mKcCfjsNuEFvI+l937DxDfWcC28lls3bCu3mlXpWjISYalprTZrr/EOSwCZxuVsotgP5nNnU8I/dQ5HHY0Hi6DkJOVydihKcLsZ5/MoiAvl1FjLhXWx7n4asnMctlJsMKO6zhWOqmzjfMKoU7mx3WbSerZT2QXHmfjurVIksQIAQWPTuflEhVTvwCWLsw3C01lYyNe4ZyTctlFqDrbOK8Q6mQs5gqGpnRrvqFCHD2VS0hYuNA+fvphGcndehApoI7M3r17SB3Yv+EHfXAyUyG7CPETh+CUZV98Cy8IhDkZp9OpmAh9SzmybxdXC8zHcTqdbFn/C1MmTxZi32F3oNfXD866HI42ZRdaZRd6AV8x3y/DfYaT2OggqZm+3kCYF/hx3SYSewrKiG0E2eUSWgpz17YtVFZUkDZxkrA+GqJ0y+42Pf84NjpLvh/ncAmcbRTIDqLV0+JeQZiTMVeUMXxAD1Hm62G32dA2MAtQktUrlxMcEsqAgcqrLdjtdrS6hh1k5YGjbbJdJjsVPxQowiHkY6e9JOZvKOPZhFCVMwhxMk6HA63Ws78aGzZvokcfcVm+AD8s/ZpR49KEzJb27E6nb9+Gg+T6BDEyuG3hFHYSFF5+ZMt24gTl8nhStVSlLkKczIpfNpDUy7O7SlXmSgZ2TxBm/1jGYbJPnuBPNzZ+jL4tFBacpnOHhrOUDRFtK74u4gR8nmynvcLLDxegFTDbsAmKSam0DCFOxlJV6dFdJU9k+a5a9h0Go5FLx14uxH5TU/mQ7q2vvlcluwgQFID3l+VHBla6+EFMqrUUFRUxffp0QkNDCQ8PZ8aMGVRUVDT5nHfeeYcxY8YQGhqKJEmUlJTUa5OYmIgkSXVuL7zwgtvjU/zTt/v4aaEyJA2xa99+OiR2EdrH/774jCEjxxAYqPxrczgcSE1oABVvTG+17QwsdBFQNNvT9YHawvme6Tt9+nT27t3LqlWr+P777/n111+56667mnyO2Wxm/PjxPP744022mzNnDjk5ObW3v/zlL26PT/HAydF9O7nhOjFbvI2Re/I4t067Rpj9U1knyDh0gEcfa/oP0lqq4zGN78QVrPyl1barZBcBCouYnZbtRCscoK2QnQQJmnH5k0N0l/3797NixQq2bt3KoEHVGxJvvvkmEydO5JVXXiE+Pr7B5z3wwANAw9X1ziYkJKRRdYSWovhf1em0oxO8y3MuoiftK79bik6v5woB8icAp/MLSOrUeDwpfJjyp73bwnHZRieFM30zsdJZwHECTyyl3aGsrKzOzWq1Nv+kJti4cSPh4eG1DgZg3LhxaDQaNm9uWHfKHV544QXatWtH//79efnll3E4HG7bUHQm88v2PcR0UL56f1MczysQrkr5zeJPuGTYiDp6OUrS3C+ts7zp9XVjmGWnkHiMCP0miywTKEA2Nhs78YKT8ApKLJgdTf+wVlZUC9orLe6Wm5tLTEzdqpM6nY7IyMg2q0L+9a9/ZcCAAURGRrJhwwYee+wxcnJyeO2119yyo6iTKcg+wa233KSkyWY59PtObpgyUZj9U1knOHxgHw89/IgQ+1WVFc3GeSr2ZbTK9iHZwsWSssXbRRb5FkGObGeg5DtSPC0Vd3v00Ud58cUXm7S1f/9+Rcd2LrNnz679f9++fTEYDNx9993MmzfPrdrWijmZXZn5mAKDlDLXYpxOZ4Op+Eqx4ttv0On1TJgkRl5329YtXDpqRJNtHJVVrbItop7tMawk+9FOja8l4dWIujXH3/72N26//fYm2yQnJxMbG0t+fn6d6w6Hg6KiojbHUs4lNTUVh8NBZmYmPXq0PNFWMSdzZM92pv/pBqXMtQibzSo8/rPk00UMHXWpsAJVFouFgICmZxvBfdzXdqrOyFX+y1UkO+iiUXa3yi7LwhL+/TUJLzo6mujo+ifyz2Xo0KGUlJSwfft2Bg6sjt2tWbMGl8tFamqqomNKT09Ho9HUW541hyI/c06HA0mS6ghNeYLfNm6gZz/lU/xrOH40g6OHD3HHbbcJse9yuVr0JQjp6X4RrqN+lBtyAiudBIw1T7YTI0haxVfo1asX48ePZ+bMmWzZsoXffvuN++67j2nTptXuLJ06dYqePXuyZcuW2ufl5uaSnp7OkSNHAPj9999JT0+nqKgIqA4oz58/n127dnH06FE++eQTHnzwQW6++WYiIiLcGqMiXuH71b/Qrc8lSphyC6vFIrSW73dLvsBoMpE2QUzMZ9fO7aT0b6S0w1k4W7FcKpYdRCj8BcuX7UQJOFtULDuJFOAMsmQbHS8AjaVPPvmEnj17MnbsWCZOnMiIESNqpWmh+lzcwYMHMZvNtdcWLFhA//79mTlzJgCjRo2if//+fPvtt0B1rGjx4sWMHj2aiy++mOeee44HH3ywjt2W0ua/rMvlwm6zktpXbMnLczlVVCpU9kSWZb7+7CPGXD5eSAIeQEF+PqOGDWm2XUhf97SwZVlMZshx2cogyfNxt7bgS/EYUURGRvLpp582+nhiYmK9rfxnnnmmyV2tAQMGsGnTJkXG1+aZzA8/r6fLxWIPJjbE/vStXDNJTJ1dgL2708k+mcXMGTOE2JfdkYlxOt2yfRwbiYKWSv7ypRVZNkLFPdrkZGRZpspc4dGSDjXYrVYMIiRi/2DJpx8RGhbO6EsvE2I/fcc2UlKaXyoB2IpL3bJdINuJUXhZky/baSdgqVS9BFN+qZSJjc5qkSqfoE1OZvnP60m+qGVfFCXZd+Qo0XHiTlzb7Xa+X/I5N02/GZ0CmkcNUZCfT3LnDi1qW3Uyp8V2RWW4ZspWkgTEN07INjoLsFsoKH6k4j6tdjJOpxNzeSkjBroXL1CC44f3M/HSocLs//rTSsrLyph+i5hdJZvNhk7X8i9A5d4jLW5bfeJYjASNiKWSr+WxqChPq53Mdz+uoUf/5oOWSpNdXCY8N+aT998lqWt3+jRxaLEtbFz/K8OGt1xHu93oluc7FMkOxXdqMmWrkPKd1bWHlU97sMouDB5SYFZpnlb9JXZlFiBJEkP6ii2v0BB7tm3k+qvHC7Ofn5fLpnVrmTXrHmF9WCwWot0oRBUxomUHJO2yC52AcGeeLKYs5n7ZQi8Bs65DWOguaDan4j6tcjL7d/zGjTdMVXoszeJyuXDY7YIDvovQ6nTcME3MGazjxzLo1KmzW88xHzneonZ75Sp6K3xWySnLQhwXgB0XRgEHOC0CC3WpuI/bf4nlP68nsUdfj2f3Aqxbv46LBgwWZt/pdPLJe+8wbuLVhIWHC+lj/759DB6Y4tZzLFktC/xakTEo/OXaRxW9FHZcUF3nxqguaS4I3Porb95bfRr4suGe31GSZZnK8jIG93JvFuAO63/+idP5ecx+4H4h9s0V5QQFuZ/MFtL/ombbnJJtxAtY0phlF4ECZgX75CouEuC8CgXEpFTahlufnrLi01w31bOaQzVs2LSJ7n3FJv3999/zSerWnYGDxByR+G39OtLGuZ93U7H3cLNtTso2OiocnC2TncIkY53I6ATsKh2TrSSpWto+hVtOZvKVV4gaR5PIskxJUQHD+nYV1sfxoxls3bCeh/72sJAtVavVikbStEpORWNoeoZilp0ECFh6HJSr6CGgPrDI2YaMrHhBLZW24ReL4g2bN9Gtt9gl2n/fep3gkFCuuV5MuYp1P69hQlrrjkEYY5s+8r9HrlK8OBWIqYAHkCFb6CJgtuGQZbTqYQKfw+edjCzLlBQWMCLF/ZoqLaW0pJj/ffEpd8+6B5NJ+V9um80GNF4FrTlMHWKhkRlQjZC80npFmbKY8gs1GckiZosHsdBD3br2OXzeyfy2cSM9+ootpP3ZB+/hcrm4689icmPW/byG0Zde2urnSxoNuBo+JLlbNtNHQHnJfNlOrIBA8jGsJAk6vGmWnQSdx9In/opPOxlZliktPi00FmOzWln49ptMnHIdMe2Vl4O1W6sLSEeGtr5EgsvhoKHaDbIsY0PGpPDuj8hlx2nZobicCvieKoEnaY242913302XLl0ICAggOjqayZMnc+DAgTptTpw4waRJkwgMDCQmJoaHH364VWoFPu1kNmzaRA+Ble8Avvv6C0qLi/jHY48Ksf/Lzz8zcXzbVCfNx081eP2AoOWBqO1lpyyjEeS8RJ7Z8nVaI+42cOBAFi5cyP79+1m5ciWyLHPFFVfg/KOsiNPpZNKkSdhsNjZs2MCHH37IBx98wFNPPeX2+HzayZQWFzKsj7ijC7Is83/zX2XIyNF076H8Qc8aTR2DoW2njEu3/t7g9TLZSbiAXRoLYjJmD2ChpyBHUHyB5sfUiLv997//JTU1lREjRvDmm2+yePFisrOzG33eXXfdxahRo0hMTGTAgAHMnTuXrKwsMjMzAfjxxx/Zt28fH3/8MSkpKUyYMIFnn32Wt956qzbG2FJ81sls3ZlOYvfmk9Daws4tmzhxLIOH/vaQEPu//bK2TbGYGqx5p+tdyxV0nsgsMCXfLDvPa7lYb6CEuFtlZSULFy4kKSmpVhdq48aN9OnTh/ZnhRDS0tIoKytj7969bo3RZ51MYV42Yy65WGgfixctJCqmPZeOVb7CnizL2B32NsViaogcWT85MEu2Cql+d0CuoicCtsMFxkxOCyqoJQKlFSTbIu72n//8h+DgYIKDg/nhhx9YtWpV7aw7Nze3joMBau+7Kxrnk07GarWgF1i/F6q1aVb/8B1/mn6zkHNY+37fTe8+fRSxZYqv+yES+YV1IqMXsL2ch4NYQZXqjss2Er1YMNxcUtqiG1QrSIaFhdXe5s2b16DNRx99FEmSmrydG6h1l+nTp7Nz505++eUXunfvzg033IDFYmmTzYbwyUXsps2bhR8hOLR/L5UVFcJE23KysxlyiTKv4dwDkgU4FC+vWYMonaJTso0BApUc/SXLt6UKkp4Qd6txdN26dWPIkCFERETwzTffcNNNNxEbG1tHQgUgLy8PwG3RuBY5mZpfzsqKcreMt5ay4iJ6xAZTUV4mrI+De/cAEp0TEykrU76fqqoqxey6EqKpMumRq6p/ZTJcFnpLAZhxr8B4czhkGYfswiwraxeqyy9USa4Gt+KVsK3EmM2yCxA7U2ypgqSnxd1kWUaW5drl29ChQ3nuuefIz8+vXY6tWrWK0NBQLrrIvVipJLfgHT158mQ9oXAVlfOVrKwsOnRovv5yWVkZYWFhLFm9g6DgphVGKyvKuXbsAEpLS1vkZNxhwoQJ5OXlsWDBAux2O3fccQeDBg2qlUk5deoUY8eOZdGiRQwePJijR4/y+eefc8UVVxAdHc3Jkyd54YUX+O2339i/fz8xMTE4nU5SUlKIj4/npZdeIjc3l1tuuYU777yT559/3q3xtWgmEx8fT1ZWFiEhIWo9VpXzFlmWKS8vr1Ve9Bc++eQT7rvvPsaOHYtGo+Haa6/ljTfeqH38XHE3k8nEunXrmD9/PsXFxbRv355Ro0axYcOG2lmLVqvl+++/Z9asWQwdOpSgoCBuu+025syZ4/b4WjSTUVFRqY+vzGR8HZ/cXVJRUTl/UJ2MioqKUFQno6KiIhTVyaioqAhFdTIqKipCUZ2MioqKUFQno6KiIhTVyaioqAhFdTIqKipCUZ2MioqKUFQno6KiIhTVyaioqAhFdTIqKipCUZ2MioqKUFQno6KiIhTVyaio+DmtUZCsQZZlJkyYgCRJLF26tM5jDRUvX7x4sdvj88lC4ioqKi1n+vTp5OTksGrVqtrym3fddVdt+c2mmD9/fpPVLhcuXMj48eNr74eHh7s9PtXJqKj4MTUKklu3bq0VeHvzzTeZOHEir7zySpOlRNPT03n11VfZtm0bcXFxDbYJDw93W53gXNTlkoqKH9NaBUmz2cyf/vQn3nrrrSadyL333ktUVBSDBw/m/fffb5WSgzqTUVFpI+bK5uMfNW3OlckxGo2Nai+1hNYqSD744IMMGzaMyZMnN9pmzpw5XHbZZQQGBvLjjz9yzz33UFFRwV//+le3xqg6GRWVVmIwGIiNjeWWq0e1qH1wcHA9aaGnn36aZ555pl7bRx99lBdffLFJe/v372/xWM/m22+/Zc2aNezcubPJdk8++WTt//v3709lZSUvv/yy6mRUVDyFyWTi2LFj2Gy2FrWXZblekNUbCpJr1qwhIyOjXhD32muvZeTIkaxdu7bB56WmpvLss89itVrdmn2pTkZFpQ2YTCZMJpPidkUqSD766KPceeedda716dOHf/3rX1x11VWN9pWenk5ERITbyzvVyaio+DG9evVi/PjxzJw5s1ZB8r777mPatGm1O0vnKkjGxsY2OMvp1KkTSUlJAHz33Xfk5eUxZMgQTCYTq1at4vnnn+ehhx5ye4yqk1FR8XPcVZBsCXq9nrfeeosHH3wQWZbp2rUrr732GjNnznR7fKqCpIqKilDUPBkVFRWhqE5GRUVFKKqTUVFREYrqZFRUVISiOhkVFRWhqE5GRUVFKKqTUVFREYrqZFRUVISiOhkVFRWhqE5GRUVFKKqTUVFREYrqZFRUVITy/wEvcbrVtvWqEQAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Train Epoch: 200 [0/10000 (0%)]\tLoss: 0.184562\n",
            "Train Epoch: 200 [500/10000 (5%)]\tLoss: 0.200990\n",
            "Train Epoch: 200 [1000/10000 (10%)]\tLoss: 0.270161\n",
            "Train Epoch: 200 [1500/10000 (15%)]\tLoss: 0.176680\n",
            "Train Epoch: 200 [2000/10000 (20%)]\tLoss: 0.214529\n",
            "Train Epoch: 200 [2500/10000 (25%)]\tLoss: 0.180994\n",
            "Train Epoch: 200 [3000/10000 (30%)]\tLoss: 0.183271\n",
            "Train Epoch: 200 [3500/10000 (35%)]\tLoss: 0.220755\n",
            "Train Epoch: 200 [4000/10000 (40%)]\tLoss: 0.202932\n",
            "Train Epoch: 200 [4500/10000 (45%)]\tLoss: 0.206962\n",
            "Train Epoch: 200 [5000/10000 (50%)]\tLoss: 0.185992\n",
            "Train Epoch: 200 [5500/10000 (55%)]\tLoss: 0.186917\n",
            "Train Epoch: 200 [6000/10000 (60%)]\tLoss: 0.194872\n",
            "Train Epoch: 200 [6500/10000 (65%)]\tLoss: 0.225963\n",
            "Train Epoch: 200 [7000/10000 (70%)]\tLoss: 0.193577\n",
            "Train Epoch: 200 [7500/10000 (75%)]\tLoss: 0.192951\n",
            "Train Epoch: 200 [8000/10000 (80%)]\tLoss: 0.201906\n",
            "Train Epoch: 200 [8500/10000 (85%)]\tLoss: 0.219477\n",
            "Train Epoch: 200 [9000/10000 (90%)]\tLoss: 0.166214\n",
            "Train Epoch: 200 [9500/10000 (95%)]\tLoss: 0.176346\n",
            "\n",
            "Performance on train set: Average loss: 0.1275, Accuracy: 9997/10000 (99.97%)\n",
            "\n",
            "\n",
            "Performance on test set: Average loss: 0.1269, Accuracy: 49990/50000 (99.98%)\n",
            "\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x300 with 2 Axes>"
            ],
            "image/png": "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RERExGpEBSIiImI1ogIRERGxGlGBiIiIWI2oQERERKxGVCAiIiJWIyoQEZH7nLfffhujRo2Co6Mj3NzcOn1dVlYW5syZA1dXVzg5OWHYsGHIz8/v0tiiAhERuc8xGAxYuHAhnnvuuU5fk5ubizFjxiA0NBRHjhzB+fPn8cYbb0Cl6lorD7GgkIjIfc6f/vQnAMD69es7fc1rr72GWbNm4d133711rG/fvl0eW1yBiIg8YFgsFuzZswchISGYPn06fHx8EBsbi+3bt3dZlqhAREQY0WoaOvUCgLq6ulYvvd72vWjKysrQ0NCAv//975gxYwYOHDiAefPmYf78+Th69GjXhFERERGraGxspH5+fhRNDSHu+VKr1XcdW716dZuyX3755XvKy8rKanXNunXrqKur6z3nXVhYSAHQpUuXtjoeFxdHlyxZ0qXvQLSBiIhYiUqlwvXr12EwGDp1PqX0rrYoSqWyzXN/97vf4cknn+xQXp8+fTo17p14eXlBJpNh4MCBrY6HhYXhxIkTXZIlKhAREQZUKlWXPRedwdvbG97e3tzlAoBCocCwYcOQnZ3d6nhOTg569erVJVmiAhERuc/Jz89HVVUV8vPzYTabkZ6eDgDo168f1OqmPsKhoaFYs2YN5s2bBwB46aWXsHjxYowbNw4TJ05EfHw8du3ahSNHjnRt8C5teEREROyOJ554ok0byeHDh2+dA4CuW7eu1XVr166l/fr1oyqVikZFRdHt27d3eWzSLFxERESky4huXBEREasRFYiIiIjViApERETEakQFIiIiYjWiAhEREbEaUYGIiIhYjahARERErEZUICIiIlYjKhARERGrERWIiIiI1YgKRERExGpEBSIiImI1/w92y3FNi9AqdwAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Train Epoch: 300 [0/10000 (0%)]\tLoss: 0.057015\n",
            "Train Epoch: 300 [500/10000 (5%)]\tLoss: 0.089123\n",
            "Train Epoch: 300 [1000/10000 (10%)]\tLoss: 0.054982\n",
            "Train Epoch: 300 [1500/10000 (15%)]\tLoss: 0.053006\n",
            "Train Epoch: 300 [2000/10000 (20%)]\tLoss: 0.068735\n",
            "Train Epoch: 300 [2500/10000 (25%)]\tLoss: 0.060120\n",
            "Train Epoch: 300 [3000/10000 (30%)]\tLoss: 0.053629\n",
            "Train Epoch: 300 [3500/10000 (35%)]\tLoss: 0.064969\n",
            "Train Epoch: 300 [4000/10000 (40%)]\tLoss: 0.060251\n",
            "Train Epoch: 300 [4500/10000 (45%)]\tLoss: 0.056402\n",
            "Train Epoch: 300 [5000/10000 (50%)]\tLoss: 0.055077\n",
            "Train Epoch: 300 [5500/10000 (55%)]\tLoss: 0.055971\n",
            "Train Epoch: 300 [6000/10000 (60%)]\tLoss: 0.058359\n",
            "Train Epoch: 300 [6500/10000 (65%)]\tLoss: 0.071380\n",
            "Train Epoch: 300 [7000/10000 (70%)]\tLoss: 0.067514\n",
            "Train Epoch: 300 [7500/10000 (75%)]\tLoss: 0.057521\n",
            "Train Epoch: 300 [8000/10000 (80%)]\tLoss: 0.067586\n",
            "Train Epoch: 300 [8500/10000 (85%)]\tLoss: 0.055695\n",
            "Train Epoch: 300 [9000/10000 (90%)]\tLoss: 0.043420\n",
            "Train Epoch: 300 [9500/10000 (95%)]\tLoss: 0.069256\n",
            "\n",
            "Performance on train set: Average loss: 0.0407, Accuracy: 10000/10000 (100.00%)\n",
            "\n",
            "\n",
            "Performance on test set: Average loss: 0.0406, Accuracy: 50000/50000 (100.00%)\n",
            "\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 300x300 with 2 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAARAAAAEJCAYAAABc03hGAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAABN20lEQVR4nO2dd3hUVd7Hv3daJpOZTHojCaEmQAhJCAkJLfReraCiouuqu+qru67Lrqurvr5gWddd3VXXsqCgKAhIhxA6CSSkEEIqKaSTXiYzmUw57x8hkZIyMzl3ZpDzeZ55Hpjc+Z2Tcr/3nN/5FY4QQsBgMBgWILD1BBgMxp0LExAGg2ExTEAYDIbFMAFhMBgWwwSEwWBYDBMQBoNhMUxAGAyGxTABYTAYFsMEhMFgWAwTEAaDYTFMQBiMO4CNGzeC4zj8z//8T7/XffjhhwgODoajoyMCAgLw4osvoqOjg7d5iXizzGAwqJCamorPPvsMYWFh/V737bff4o9//CO++uorxMXFoaCgAI899hg4jsMHH3zAy9zYCoTBsGNUKhUeeughfP7553B1de332qSkJEyZMgVr1qxBUFAQ5s2bh9WrVyMlJYW3+TEBYTDsmN/85jdYvHgx5syZM+C1cXFxSEtL6xGM4uJiHDhwAIsWLeJtfmwLw2AMgo6ODnR2dpp0LSEEHMfd9J6DgwMcHBx6vX7btm1IT09HamqqSfbXrFmD+vp6TJ06FYQQ6PV6PP300/jTn/5k0uctgjAYDIvQaDTE09WNADDpJZfLb3vv9ddf79V2WVkZ8fLyIhcvXux5b8aMGeSFF17ocz7Hjx8n3t7e5PPPPydZWVlk586dJCAggLz55puUv/Of4QhhBYUYDEtobW2FUqnEqc3bIJfJ+r1WpVZj+qMPory8HM7Ozj3v97UC2b17N1auXAmhUNjznsFgAMdxEAgE0Gq1N30NAKZNm4bJkyfjvffe63lvy5YteOqpp6BSqSAQ0PdYsC0MgzFI5DIZFDInk651dna+SUD6Yvbs2bh06dJN7z3++OMICQnBK6+8cpt4AIBarb5NJLqv42udwASEwbBDFAoFQkNDb3rPyckJ7u7uPe+vXbsWQ4YMwYYNGwAAS5cuxQcffICIiAjExMTgypUr+Mtf/oKlS5f2Kjg0YALCYNyhlJWV3bTiePXVV8FxHF599VVUVlbC09MTS5cuxdtvv83bHJgPhMGwkG4fSPr2PQNuYdrU7Yi8bxlaWlpM2sLcKbA4EAaDYTFMQBgMhsUwAWEwGBbDBITBYFgMExAGg2ExTEAYDIbFMAFhMBgWwwSEwWBYDBMQBoNhMUxAGAyGxTABYTAYFsMEhMFgWAwTEAaDYTFMQBgMhsUwAWEwGBZjUkEho9GIqqoqKBSK26pKMxi/FAghaGtrg5+fHy/1Q3+JmCQgVVVVCAgI4HsuDIZdUF5eDn9/f1tP447AJAFRKBQAgIQLOUg6cxox02diuJeS14l1QwjB7LhoDA0ahh937rTKmFqtFkknE7Fg7sDNfGixf8c2LFowv9ev5bz2b1R9d5C3sdON7ZjAySC0s9XleaMK0ZyT1Va9amLEY8aSnr93U3FVOMDZqffeLt2IhPrBTM1uMUlAun+BTnIFlqy4B3t378DYR9ZALBbzOrlu/vzG/+KZdWtxYP8+PLh6jVXGdFG6oFWlhr+fj1XGi44Mx+XLlxE7efJtX/ONDEXztiO8jR0jkOM8acdUzrwbh29iBHJcJBrEcnKrjsu26aZj9kZPLBZj9qLl2LRlG2+l4m9lxb33YdHS5fjts88iNzfHKmPOmLsAJ06ehF5vnSfHiPBotLWpUFdTfdvXfBfF8Tq2mBMghJPiolHN6zjmIuOEGMU5IMPYbuupMPrAIk+R0kmGKbPm4svNW2E0GmnPqVf+/u/P4OPriwXz5qKystIqYy5bugTf/bDDakI5b+V9OH42Ge0tzTe9z/XR+pAmHpwYbpwQl4mG97HMwYMTw5eTII2JiF1isavZ080NU2bPw1fffGeVG8xZqcSO/YcAAHNmzURtbS3vYzooXLFo4QJ8+/12q3yPHMfhvrXr8NOhBOh0up73VYVlvI8NAAGcAxQQIJvY10rEhxNjGOeAs8Y2q4k5wzQGdVbl4eKCuJlz8MWmLVZZifj6DcGug0fR2tqC+OnTrCIicjcvzJs7x2oiIhAIcN/ax/HDzl09ItJysYD3cbsJ5BzgBpHdPfHdOBEiOCecJG3oJNZZ9TIGZtCH3Z6urpg2dwG+2LwFBoOBxpz6ZcSoUfjpyDG0tDRjxvSpqK6+3WdAG2cPHyyYPw9bvvveKt+jRCLBvUsW9oiIIjiI9zFvxI+TYBjngCQ7e+LLOAGmcQqcI+1oIb/MU407DSrRMu5KJeLnL8EXm7fctPTmi1Gjg7En4ThUbW2YMW0qKioqeB9T7uaFpUsWY8u2763yPUp9hvaISE3SBd7HuxU3ToRwzgmnSBt0diQiQo7DdIECBaQDVaTT1tO566EWbueqkGP2ouX46ptvUVjdRMtsn4wcNRr7E0+hs7MT06fGobSkhPcxHZXuuGflSnz7w3a0tKl4H0/qMxQPPPoEjlWV2WTZLuMEmMIpkETa0Eb4X3mZwySBHE0woIRobT2Vuxqq8bpKJxmWrbwPxw/tRX5lPU3TvTJ02DDsP3YSAoEQ06bGoSA/n/cxxU5K3Lf6EezZuw8NTc38jycW475V9yKJqNBhAxERcRymcwrkEg1q7OyJP45zhAEEBaTD1lO5a6Ee8C8SibB81f04deQgcsqu0TZ/G/4BgThw/BQUCmdMnzYVWVkXeR9TKBTivjWP4PCRBNTU1vE+XltWPqZzCpwnKqhtsBLgOA7RAjnqoccVO7tZR3JSiAAU2tm87hZ4yRgSCARYfs/9SD6RiOwS/p2c3j6+2HfsJHx8fTE7Ph4pKed5H5PjOKx6YA1OnzmL8kp+v8e2zDwIrq8E0ojaZtuJUE4GETi7CzgbzklhBEEp285YHd5SDjmOw9IV9yD17ElkFfHv5HR398DehOMYPnIkFsydg9OnTvE+JsdxWHbP/UjPSEfxVf5iNRy83HvGm8rJcYmo0WyjU4ggzgFDODGSjG0w2pFzNZhzRCPR2+zncrfCa84yx3FYvGwlMlOSkZ5fyudQALqCzXYfOoqw8EgsWbQQhw8d4n1MAFiwdCVyc3NRWFTMi/1Rf/1tz785jkOcQIF80oEGG90sHpwYEddPaLR2FJMRKXDCRaKGwY6E7ZcO70UPOI7DwiXLkZuVgQu5RXwPB5mTE77fsx9xU6fh3lUrsPPHHbyPCQBzFi5FSUkpcvPpB30Rze37+xiBHCVEi1rC/5Fybzhej8lIJe1osqOn/mROjjRiX0Fwv2SsVjVl3oLFKMzJxvlL/EdVSqVSfLNjF+YvXoJHHlqDrzdv5n1MoCsBr6qqGpcu59I13EdxmyiBEypIJ6ptdDoi5DhMFShQQrQosxP/gwMngDsnQqWdnRj9UrFq2aU58xbialEhki9SvsF6QSwW4z+bt+L+NQ/j6aeexMcf/ZP3MQFg6qy5aGhsRGZWNjWb2uq+T3oiBU6oI3qb3jCRAidoQZBjJ4l4IzgpSojWrqJof6lYvW7bzNlzUVlWijPp9G6wvhAKhfj7vz/Dr559Dn/4/e/w57+8ZpU/qtjpM9GmasOFjEwq9vTNbf1+PUwgQxP0Nl0FjOKkcIUQKUaVXdy44ZwMF+0sKfCXiE0KP86In43a6iqcvpDF+1gcx+GNDe/gD39+DX9/dwN+89xzVkn8i54yA1qtFucvpA3aljJ6/IDXhHIytMNo08hMX06CMZwjTpE2mzsy5ZwQBnRVGbsT+eSTTxAWFgZnZ2c4OzsjNjYWBw/2XZXu888/x7Rp0+Dq6gpXV1fMmTMHKSkpvM/TZpVjp02PR0NdLU6kZPA+FsdxePGV9Xj7/b9j0+ef4ZG1a61SKCgqdhoAIOn84H6RVdsPm3TdGM4RnTDaNNhLwQkRx8lxmrTZJOjtRiI4GTLvUIeqv78/Nm7ciLS0NFy4cAGzZs3C8uXLcfny5V6vP3HiBFavXo3jx48jOTkZAQEBmDdvHu+1c2xaenrK1OlobW7GseTBP6VNYd1TT+PjL/6Ln37cjuXLl6Ojg/8bLXxSLMRiMU4nJVtsozXT9CpswZwjANg0vFvMCTCDUyCTqG121AwAAo6DFye2uxB8U1i6dCkWLVqEUaNGYfTo0Xj77bchl8tx7ty5Xq/funUrnn32WYSHhyMkJARffPEFjEYjEhMTeZ2nzWvXx8ZOgaZdhaNn+F9uAcA99z+ITd9tx5mTJzBv3ly0tfXvX6BB2MQYyJ3kOHH6rEWfd/D1NOv6rvBuDrk2dGp2x6uUES0qbHgDj+SkKLKTEyJLMRgM2LZtG9rb2xEbG2vSZ9RqNXQ6Hdzc3Hidm80FBACiY2Kh03XiyKne1ZU2cxcuwvd79uPypSzEz5iO+nr+E//Ghk+Em6srjp0wP0JWNtTP7M8M5xwgs4PqYhECJ7TBgCIbroiCOSny7eSEqLW19aaXVtu3uF26dAlyuRwODg54+umnsWvXLowdO9akcV555RX4+flhzhx+OwvYhYAAQFRUNAgx4tAJy57S5hI7ZSp+OpyIyooKTJ0SZ5WaIsHjw+Ht7YWExONmfc73nt7bPQzEUM4BLhAhy8a5K2M4R3CAzY55PTgxGomBN8euo4cTHD3l/b88nAAAAQEBUCqVPa8NGzb0aTc4OBiZmZk4f/48nnnmGTz66KPIyRl4O7tx40Zs27YNu3btglQqpfZ99obdCAgAREZGQSgUYX8i/3ksADB+QjgOHDsFjVqNqXGxKCzgP8ht5Ngw+PsPweEE0/emrVmWlynw5yTw4kQ2r2w+nJNCAYHNEvG6HKq2P9YtLy9HS0tLz2v9+vV9XiuRSDBy5EhMnDgRGzZswIQJE/CPf/yjX/vvv/8+Nm7ciCNHjiAsLIz29G/DrgQEAMLDIyB1lGFfwkmrjDdi1CgcOnkGUqkU06dNwcWLmbyPOTwkFMOGBWH/IdNOV+qODG5V5sNJMISTINXIfxGk/gjgHODNiZBpAzGTcgIIAJufDHUfy3a/HMyouG80Gvvd8rz77rt46623cOjQIURFRdGY7oDYnYAAQNj4MDgpFPjp8DGrjOc3xB8HTpyGr98QzJ4Zj+Qk/rdRQ0eNQXBwMPYeGLjjnGtsxKDH8+LEGMlJkWzjQC8fTgJvTmyTbdUEO1mFmML69etx6tQplJaW4tKlS1i/fj1OnDiBhx56CACwdu3am1Yv77zzDv7yl7/gq6++QlBQEGpqalBTUwOVit+Hhl0KCACEjguFi6sbdh88apXx3N09sOfIMYSMGYuF8+fhyGHTVgeDIWD4aISGhuKnffv7vU4+fiSV8Vw5EUI5R5whthURX04CN05kdcemgOPgzolQb6MERHOora3F2rVrERwcjNmzZyM1NRWHDx/G3LlzAQBlZWU3FRT/5JNP0NnZiXvvvRe+vr49r/fff5/XeXLEhL+k1tZWKJVKJOWVQ65w5nVCt5JXkI/a6krcs2SBVcbTaDR47MF7cfbUSWz+ZgtW3XMv72NeqyhFauoF3LNiWa9frzlwEhn3/w+18TTEiPNEhWmcwqb9cPOJBk4Qwp+TWHXcJGMb4gS3t/FUEwPuNxShpaUFzs4D/5133xc1F87AWd5/+81WlQo+UVNNtn2nYNYKZNvOPUgv4r/C2I2EjA6Gr38gtu85YJXxHB0dsWXHbixYshSPPLQGmzdt4n1Mb/8gTI6JwQ8/7up1ZSCUy6iO58gJMIWT45SNe6wEc46oJJ3QWHkOQzgJy9alhFkCMnfWHGSnnsW+Y2f4mk+vjBoxEv5Dh2Pbzr1WGU8sFuOzTVvwwEOP4Jlf/wr/+vgj3sf08AvAtKlT8P2OnbeJiNiZfnNpMSfAdE6BJKJCuw0di5M4J6RaOdx8KOeAq3d4cJm9YJaACIVCLF20BA5SR2z5YSdfc+qVkcOHY/joEHz3409WGU8oFOKDf32KJ57+DV7+3Ut4Z2Pf5/W0cPPxx6yZ8di2/cebRETfzo/jT8hxPSHntioFKOA4jOMcrR4jwkSEDhY5UaNCx2HE2AlWa2nZzbChQzFqbKjVxIvjOLz1znt4/nd/wBuvv4ZX1v+Jd+ej0tMXc+fMvqmVZltmHm/jcRyHKQIFCkmHzaqbuXMiqInRqluZIZwEVXeAM9XesfgUJiRwCCKnzcYX//3aKpmt3Qz1D8DYCZH4+rvtVhmP4zisf/0NrH/9DXz0wXt44cWXeBcRhbs3Fsyfh63bfoDRaERnPf+NuiYJ5KgiOpvlrURyMmRYeSszhBMzX8ggGdQx7jBPV0TPWogvN39jlXaP3QT4+WHCpMn479ZtVjuOfP53f8AbG9/FF598jKefeYb3lZfczQuLFy3Elm3fw3VOHK9jdRMukKHVRt3eBBwHXys7NwPZNmbQDDoOZKi7EqtW3Iuvvt6Ci6W1NOZkEn7e3oiKm47/brGeiDz17HN458OPsGXTV1i37gneRUTm4oHlS5fip/NnrFagZyznCD2ITRo1DbPBDe3LSe7IdH97gUogmUgsxqoV9+Jc4n6rioiPhwdips3El5u3Ws0Xs3bdk/j7vz/D9m1b8fDDj8Bg4PcEQ+rshkUzZlm1yteo6+UAbJH8NoZztGoZgi7RYgJiKdQiUW8UEWtuZ7zc3TBl9jx8sdl6Dt0HHnoEH3/xX+zZtQP3P/AA7z4gCSfG1OtxG3oricgwzgEKCKwecu7KidDMY+Zsb4jBQWcHdVzvRKiGsneLyFdfb7GqiHi4uGDGvEX4fNM3VnPorrrvAXy2aQuOHNiHe1atQmcnn08xDmJOgKmcAqdJm9X+2AM4B7hzImRaWUSsnTk7lnO0ed2UOxX6zbXFYkyevRhffb3Fqqczbs7OmLVwGb7YvIXnm/lnlqxYiS+3bsPxxAQsX7as30zJwaDK7krnF3McpnEKnCFt0FnpyHMIJ4GPlUVEyglAAKtFyUo5AbQgdtWq806Bl2S6QDdnxMxahC83f8O7j+BGXOROWLbyPvx3y3coqGq0ypjzFy3B5u9/xNkzp7Bk8WJe6qwSw883kuh6k+0zRGW1G8znuohYs5aHtdsyhHKOyIPtqqbdqfCWjTvUXYnomQvxxaavrSoiYrEYy1fdjxOH9yGvou+GTDSZNXcetu7YjdTzyVi4YAHUarp/+E7jR9/0f+F1ETlrZRFx50RWc3CKOA4CcFb7/uSc0Oo5Ob8EeE3nD/JwQXT8Qny56RurRqwKhUIsX3U/zhw9jJyrNVYZc/rMWfhu9z5kZqRh/rx5aG+nFxQldHS8/b3rIpJkRRHx5yQQg0OplY5awzgZsqx4IiOC7TKT71R4rwcS5OmCiTPm4YtN31i1BoVAIMCyVffh3KnjyCrmtzdGN3FTp+H7n/bh8qUszJ0zm1rFd11jc6/vC6/7RKy5EhnJSdFM9FZpqC3mOBhArPZ3M467XagZ/WOVgkLDvdwQMWUWvvr6W6uKCMdxWLJ8FTLPJyE9v9QqY8bETsH2vQeQn5eLObNnobW1ddA2BWJxn1+7cTtjLcdquMAJl4jGKketIVb0TYhsWBvlTsVqFclG+noiNHoqNm3dZq0hAXSJyMIly5GblYGU7EKrjBkVMxk79x9G8ZVCzJoZj+bm5kHZU0T2X8pfeINj1VpxItGcEy5YIXdFyQnRauM6poy+sWpJw9FDvBE8YRK+3rbDmsMCAOYtWIySwnwkX8y1ynjhE6Pw44EjKCstwayZ8WhqsjwhjugHvoGEHNcTJ2KNlYGUE8CLE1sl+c4BApsWPhoIiZsbJO7u/b94bvBkK6xeE3XMUH8MCw7FtzusU9fjRmbNmYeq8qtWaeoNABMiIrHzYAIqysswM34GGhstO1o2ak27ScUchynX+9JaI6ahO3eF77FCOCnybNiYitE3NimqHDoiCD6Bw7B9z8AVyWkzfcYsNNTV4vi5dKuMN35COHYfOorqqkrEz5iOhoYGs20YVKYfC0s4AWI4udUKJ0dwTrxHjUo5ATrBgrzsEZtVZY8IGQ1nV3f8dNi8Lm00mDJ1Otrb2nD0bKpVxhs3Pgw/HU5EbU0NZlrQSlPoZF5NVEdOgAhOhmTCfx8YGScAB/77rRAmIHaJTds6RE8IAycQ4uBJ6/TEvZGYybHo1HZYrR/vmHGh+OlIImprazErfoZZItJZbX6Gs4ITIoRzxAUrNHGawMlwked4DRE4qybYMUzD5n1hpsVEQ9XajOMp1vFL3MikSTFW7ccbMnYcfjp8FLW1tWatRByHB1g0nhsngj8n4T2jVsBxcOGEvMaG+HISVIGVILQ3bC4gADBnRjwqiguRfLnY6mNHRkZBIBDi4HHrVJoPGTsOe44kor6+zmQREcocIfTxsGg8H04MZ07Ie4GgEPDr6PSECA2shqndIbL1BLpZvHARdu7aAamjDBHDfaw6dkREJDIzM3Dw+BksnDmV9/GCx4zFT4cTsXz+bMycMR3HT56Ch0f/AhFz+gdcXP5rqMuqoAgfg+B/v4Hi9e+jLTMXQkcpCIyAUAiBUASxlyu01fXoqKgGZzBiuFCG8rFDoFi9FJ7VzWi5mAejWguBoxSyEf5wGj0MVdsPQVtVB2mgLxRjR0I+OghSP0/UJyaj9sBp6JtbIHJVwDFwCDiBABJvN7QXXgXRGQC9AZqGRihUOqjEIgRMngDHQD+IRCKoSyvR2dgGt8njoYwehyv/+wU4sQh+axaiNSMfTckXYejUwynID8N+cz+kPh4o37IfsiA/KCcEo/rAaXRU1kJbXQ+ppgHjX/o1FCFBaMkuxJV3v4GusQXSYX4YsmoWQAhqj6ZA19IGbW0TDOoOCKQSiJwcQfQGGDt0EIiFcBodCMXY4dCUVqOzvhkGbSd0Dc2QjhkKHCvi/ff/S8KsznQHUq/ASX57Ry9aGAwG7Ny5Hb9a9yg4G0QFZmZmQK/XWUVEACA/NwfL5s2Gl5cXjp88BXd3d17HO7hnJ+JiY+Hlwc84RqMR+7d/hyWLFvJif++3WzB/Pj+2AfO7x3XfF43FOXBW9H9ftLa1wW342Lu7Mx3fCIVCRE6bg81bv7fJ+OHhERCJxFbziXStRI6i9tq1QQebmcKCpStx+EgCb4mNAkHXn5M1EycZtsWuBAQARvh4ICgk1CYxIkCXiAgEQhw+mWSV8ULGjsPOg0dQXVWJuXNmU8md6QuO47Bo4QLs2c9fm9DoyAlISbXO8TjD9tidgADAhNEj4egkx6FT520yfkREJABY7Yh33Pgw7Nh3CKUlxVgwfx71eiI3InfzQkBAALKyc3ix7z0qFA2N/PexYdgHdikgADBl0iQ01V3D2SzrJMDdSmRkFHS6TqsFm02IiMQPP+1Hbs5lLFm8mLfyiAAQGjEJefn5vJWc5Mt/xbF6HXaH3QoIACyYOw+56eet2iriRqKjJ0OjbseJlAyrjDcxOgZbd+zGhdTzuP+++3it5DZ/3lwcOHyEF9v+fr4oKy2hbpdFo9ofdi0gALB86XKknjhss/EnT45DU309zqRnW2W8KdNn4ItvvkViwmGsW/cEb/ksUmc3SB2kqKmlX/YxdPI05BZeoW6XYX/YvYCIxGKMnRiLbbv22WwOU6fNQHVFmdXqicxftAQffvIfbN+2FS+/8kfexpk+Zz7OJiVTtysUCq1aOIphO+xeQICuEgDOru42yZnpJn7mHBTmZiOzsMwq4923+iG8+ubb+Pc/PsC/P/6YlzE4joOLUolrdeYl95kC04+7A7MiUb/ZdBVjQj1RU6mDo0yAUaOcUFKsQYfGAAICmZMY3r5i1NZqUVPViZGjZBgb6oy0lGaUlKjh4iKGn78UVeUaKF1ECBjqhKZGHa5Va9DUrMfYcXIYDQR1tTq4e0pgNBIU5LVDIuEwf9EYJKcew48HshE6YijaWnWQOgpxraYDYROcodEQJByuQkWlBp6eUvj6SOHj64jAoY5oa9OjqFAFH18H5Oe3o7PTCLlcBJlMhPAIJby9HZF2oRH5BW3wH+KAa9f0qKvVwM3dARKJAEoXMYYFOcJJHoPPP9oFqVMUvD2VIARwcRHD11eKjg4jSq62w0nKITBQjoAhMpSWqSERAy4uDujoMCCvUIXw8QoEDZWj5loHiJFDYXEbmho7MSFMiZhJ7hCJftb03/zPS6iurMTLv38JAYGBWLpsGfU/gLj42Ti0dzdWLltC1S4fflTmRLU/zBKQ4isdKLv6c1Gcc0kt/V5fkKfGgb03Pt06kJl+Y6Hh5puuLyrsO6MzP68EhAShvuoQPPziwXHCnq/t2F5107U11SpcyjItlX3vnv6qtt+eyUpIJOovHoWHbzw4QV8/vuY+LR4/0fvT/tjJBvj5VuLD9yZAIPj5RnnznfdQVlqCtQ+vwYnTZzBhQng/8zUfgUAAjgMIIVRPT/g4ibmbnKinTp3Ce++9h7S0NFRXV2PXrl1YsWJFv5/RarV48803sWXLFtTU1MDX1xevvfYa1q1bx9s874gtTDccx8HNZyoaaqyT+Nb7HARw95mO+ppT1Pf5VdVaFBXfLHwCgQCfbt6CocOGY/nSpWbXEjGFiZETkXQ+hbpd2txNK5D29nZMmDAB//rXv0z+zP3334/ExER8+eWXyM/Px3fffYfg4GAeZ2lHyXSmIhQ6QK4MRmtjFpzdwmwyB4FQAhePKDTVJsPNO46q7bJyNUaNvDmvQiaTYeuPuzE7NhqrVz+II0cSqD7hvfyHIj2DboU2qYMD1GoNZDJ6rRLuphXIwoULsXCh6Xk/hw4dwsmTJ1FcXAy36/VXg4KCeJrdz9xRK5BupDIfAAJ0qKttNgexxBmO8kC0NV2mareyqvcoVP+AQPz7y004e+ok/vPZp1THBOhvOVxdXNDU0kzV5t20AjGXPXv2ICoqCu+++y6GDBmC0aNH4/e//z00Gn4LPd2RAgIAzm6haG8phNFgnS5pveHo5A8CQNNOr3FVTW3f38/s+Quw+uFH8cc/vIyyq1epjQkAAf4BuFJSSs2eq9IZjZS3WwIBZ9U2qXzQ2tp604tWxHFxcTHOnDmD7Oxs7Nq1Cx9++CF27NiBZ599lor9vrhjBQQA3Lzj0HjNOklvfeHsOg7qtmIYDHSK6UyP678uyJvvvAeZkxOee/55KuN1ExIWgfz8fGr2XIeOQksrnc583UgdHKDpsN0Doy84uSs4hVv/L7krACAgIABKpbLntWHDBipzMBqN4DgOW7duRXR0NBYtWoQPPvgAmzdv5nUVckcLCCcQwdktDM311gk17ws37ynUhKxN3f8TVq5Q4I0N7yLh0AGkpNBLNhQIBFSdwnK5HO1quvVYZVIHtPO8JOeb8vJytLS09LzWr19Pxa6vry+GDBkCpVLZ896YMWNACEFFRQWVMXrDLAFpb7W/8GSJ1B1CoZTqNsJcOE4ApdsEKkJWUDDwU3vV/Q8icGgQ/rT+T4Mejy84jqN+SiVzdER7ne38XjRwdna+6eXg4EDF7pQpU1BVVQWV6udTvIKCAggEAvj7+1MZozfMEhCRWI766pMgdtYlTOE6BurWYhgN/HdJ6wuJ1B0CgRBazeByS0LHDVytSigU4g+vvoakM6eQm8tPWr494jZ6LNo77o4GUyqVCpmZmcjMzAQAlJSUIDMzE2VlXZHQ69evx9q1a3uuX7NmDdzd3fH4448jJycHp06dwssvv4x169bB0ZG/puFmCYiDow9cPaNRV5kIo5H/7uzm4OYda3t/iFsY2pqyB/XkDR4tN+m6JStWQeHsjC8+/4/FY90Kx3FUq4nRPtlxkjlCrbk7BOTChQuIiIhAREQEAOCll15CREQEXnvtNQBAdXV1j5gAXVvGhIQENDc3IyoqCg899BCWLl2Kf/7zn7zO0+w4EKHIER5+8WioPgEPv1ngOPtwo3ACERSuY9DamA1nt1CbzcPFIwot9Wlw8Yyy6PN1dTr4eA18nYODA+55YDV+2PY93v/b36ncrF5eXqitrYWPD52i1rS3ME4yGdrvEgGJj4/v9+e3adOm294LCQlBQkICj7O6HYvufoFADDfvODRUn6I9n0Hh4OgNo1GHzg7z20fSQiRRAJwAus7+w/z7IjfP9JKGi5etQENDPS5ezLRorFvx8vJCRXV/of3mQXsFIpFIeCuCxLAMi5cPQpEMzm7j0VyfRnM+g8bFIwItjRdtmk6udI9Aa8NFiz6r1Zoe5xATNwVisRhnT5+2aKxbcffxpxoqz8fv4G6KRr0TGNT+QyJ1h0jsjPZW6zeE6g9Xj0lorrNdYV+O4yBTDEN7q/k9RtRq030QYrEYw0eOwskzdHKDxGIxe8IzzGLQDgy5chQ6O+qg19ENGhoMIokCQpEjtBrblEIEAEd5ADraK81+Cs+KN68D3djQ8SikGABGEz4yclk4u31BxQPq4hmNptoUu6pC5ew2Hm1NOTadU9epzCWzPlNRZZ6TcOiwYai9ds2sz1gLtoX55UNFQDiOg6tXNJrr7CslXOkRjtaGTJuNL3Zwga6z1awbSa02bwuhVCrR0UEvOtPea4KwFYh9Qe0MViRWQOzgCo2qnJbJQSOWuMBo1EGvoxtSbQ7ObqFoazK9ILOTTDjwRTcgkThAr6PXdJrmqoGtQH75UA3ikCtHQ91WYldBZi6eUWipp1vrwhzEEhez/EN5+eb5kvR6PYRC80SnP9gKhGEO1KPAXL0mo6nWdsWPb4XjBJA6+UHTzl9C0UBIHNyh7TDteLS41LzVkkajgVgisWRavWJPfqzeYCsQ+4K6gAiEEjg4ekOjst0NeytOziOgtuFRs5NyNNpbTEtEFAjNe8I2NTbAycm08HdT4KurHC3YCsS+4CUOXa4chfa2Irt6msldxqCtyTaJZ+bclGFjlQNfdAM11dVwcXU1d0p9wnwgDHPgLZFF6T4BrY2WRWPygYOjJzo7GmwmagKBCEbjwM7OESPNW01UlpfBbwi9dG1794Ew7AveBEQscYFBr7Yrh6rSIxwtDbYpPiRzHg5128D9Yq9dM6/iVk1NDUYMH2bptG7D3lcgDPuC11RapcdEtNhRroxIrIBBrwEh1q+rKZa4QqdtGvA6c+NAGurrMDRwqKXTugnaJzp8wHwg9gWvAiIUOoAQo12tQlw8ItBigxKIpi7nlS6mn6i0trRAo1bDP4DOFqahoaGnJYA9wlY09gfvxTyUHpE2jcO4FaFIBoNBa5NViCmIzPiNVJR3FZQZOpTOCqSuqoxaLRA+ULW3w4linxnG4OFdQIRCBxiNOrsqg6j0iECLDUPc+6OsvPe+ML1RXtbV2iFwaBCVsWtra+Hva78CUp5xAR4u5p1SMfjFKuXElG5haG00L6mMT0QiGQz6DrtcEldWm+5EvVpSArFYQm3VYDAYqPlAVCoVnGQyKra6qa6rx5Dho6napIGWk5j0+iViFQERSRTQ60xrdm0tnN3GUe8qNzAD+0EcxKY7CYuvFMLL29suj0uLLl5AECXfTDfqjg7IneiKEmNwWK2gqUwRZNIxprUQS1wsLjvIJ65uppepzcvJwfCRI3mcjeVUX7uGIQGBtp4Gg2esJiCOTkOgaa+y1nAm4ejkb7UcGWLUm1SA2s/X9CdsSXERIsLDBzEr/iCEQCCg++dlj1vOux2rllQXS5zt6qkvUwyFRlU28IUU6NDUwMFxYF+FxMQtTEdHB+pqryE4OHiwUwMAdHZ2QiwSU7HFF3xv1c78tJ9X+79ErCogCtdQG/gdBoJ+B7Xe6FBXQ+rkO+B1pVdNO4UpKiwAIQRjxowZ7NQAAIWXszBq9CgqtvhAr9dDwHMLkcY2+ynLeadgVQHpeoJwdhWDIVeORntLAe/jEKMBHDfwCUfURBeT7OVe7hLikDFjBzOtHiqrKjEsMICKre5GzzTJPnUcIwKGULV5K2yHZD5W7wrl7Dbero50JVJ3dJoQYm4tTC0uduliBjy9vODi4kJtbFo3fWH6eQwfSteBWl5zDcNCxlG1eSOXj56At5sLb/Z/qVhdQERiuU1LDPYG33tro4kOVABobjFNQVKSkxAaNmEw07oJmj+D4qtXMWIk3e0QIYTX39Plq1cxIXoqb/Z/qdikL6WDo6dNWy5Ym/aWAshdTAuAamoeOJDMYDAgL+cy4mfMGOzUeqCbhQvqJzB8QgjpStKzw3gae8cmv2Un51FobzWtQtcvAV1nC8QSF5OudXEeOGKxIC8XHR0diI6OGeTMumioroC7uzsVW3zAt5P7woHDGO3Pr3/ll4pNBKR7KWo/5/p8P3lMty+RDHzt+aSzEApFmBQdPZhJ9ZCTk4PICWFUbBkMBggEdH+ehclnEODjTdXmjZTV1mF0JB0xvtuw2TpT7jIGquY8Ww1/C/wJmb6zDSKx6VXG1B0DJx0eP3oEo0NCIKOUa6Lp0EAqlVKxlX3uNMaMohsdW1BahpDx4VRt3ojdPMfuQGwmIBIHV+g6m201vNVoa86FwiXE5OsHKp1iNBqRdOY0li5ZMsiZ8UNVTQ0Cg+hVSAMAIzHyVuhI09EBB7F9B9DZMzb1dHGcwK7S/PmAEAM4gen5LeD6fxxmZaRD1daGOXPnDXJm/MDH05zPFULijt2YONo+84nuBGwqIE7K0VBZIYirP/j0wxiNOggE5j3dFPL+naiJRw5DJpMhZvLkwUyth/qqcruuQtbR0QEHin1vbkWj7YTrcNNXiIybsamASBxcodM223IK6GivhFTGjwe+reky5K7mRYoOtFj5aecOTJ0xE2JKy+7s7GxERYRTsdVYkg+FnF6PGgBIOrgfkWP4qQGi1+shsvMasPbOnXNYzxOa9gpInfgREINeA5HIPEenQt63glRXVaIwPw+rH3xgsFProVPXCQcHByq2Ll7OwcTICCq2umlrV8PFj5+yAKd27UUYxYr2dyM2FxChSAqDnl53efOhn7cBmJ6+fyvFV/pO6Dq4dw+EQiHmzV8wmKndBM0tnKZDC0dHujVL+dxiNqlU8BtD5/j6bsXmAtLlBym0ydi6zhaIJPzU2GxrzoHCzO0LAJw939jn17Zv+xYTo2PgSqkTnbq5Hk4yJyq2+KAkJQm+nvYb4GYN/vWvfyEoKAhSqRQxMTFISUnp9/rt27cjJCQEUqkU48ePx4EDB3idn80FRCSSwWiwzQqkrSkHChc66fC3otepIBIrzP6cQt67b6P2Wg0upqfj0bVrBzu1HlJTL2BKLJ0AKj78CVkFRQiP4ifAK/fYSXhRTETkg++//x4vvfQSXn/9daSnp2PChAmYP38+amt7TwNJSkrC6tWr8cQTTyAjIwMrVqzAihUrkJ2dzdscbS4gtoVYtM0YCKNBC4HAspODgIDetwB7d++EQMBh2fIVg5jZzdAMIEs7lYiwcXTFmM8EusulZZg4JZ4X27T44IMP8Ktf/QqPP/44xo4di08//RQymQxfffVVr9f/4x//wIIFC/Dyyy9jzJgxeOuttxAZGYmPP/6YtznetQKibrsKRyd+nHOtjZfg7Dbeos+q2nrPxt266b+InTqdWs4K7Zod9Q2N8Pb1o2avPD0F7jy2cOA7u7cvWltbb3pptb0nT3Z2diItLQ1z5szpeU8gEGDOnDlITk7u9TPJyck3XQ8A8+fP7/N6Gty1AtKhroSjnG7V8G6Mxk4IhJadbLS03h6KWnzlCnIvZ+NXTz4x2Kn1cCH5NKImRlGzR9vZmZ6Tj0mT46ja7Kb4dBJcFfSOm1u1erQM8GrVdv1eAwICoFQqe14bNmzo1WZ9fT0MBgO8vW/OAfL29kZNTU2vn6mpqTHrehqYESL5y8GgV0MgpLN0vxWNqmJQcSVjxjrf9t63X2+CTCbDkqXLBjO1m2hoaMC0uFgqthpL8uGsMN/f0x9Go5G3kgAZV4qwYNFyXmwPRHl5OZydf/4d0zpCtxV3pYC0NFyEq+ckXmyrVVfh7jPF4s8r5DffNDqdDt9u/i9W3PsAtSNSdXM9HKX0jltTMjIxKz6emr38s6cQ4Mtf9q0t65U4OzvfJCB94eHhAaFQiGvXrt30/rVr1/psJObj42PW9TS467Yw5Hq2mln5KSai62yGWDK4J7Hc8Wbn65GD+9HU1Ijnn/vNoOzeyJmzZzErfjo1e3q9gVpkLADkFJUgLJIfgc84dBRDvT15sU0TiUSCiRMnIjExsec9o9GIxMRExMb2vnKMjY296XoASEhI6PN6GtiFgFizLkhLQyaU7uG82G5tvASFq2XOUwCQOnCYNtXjpvf+9fcPMG58GMIolS8khECn01O74RuK86A04YlqKkYjv8mVBRWVCL1DShe+9NJL+Pzzz7F582bk5ubimWeeQXt7Ox5//HEAwNq1a7F+/fqe61944QUcOnQIf/vb35CXl4e//vWvuHDhAn7729/yNkezHsMzZzlBq5VCKCQwGDhIJAIEBopRUKCDo2NXMZxr1/RwdxciKEiCwsJOcBxBU5MeQiGH8HAZHByEKCjQoKHBAKlUgJLyMnj4+mBihDt0nQRKVxEUTiK0thnQqTWiqkoDYgQ0GgNGjnICAYd2lQGjRktRUqxBba0Wej2Bm5sY4ye4wtvHAbXXtFCrDXCUCuDpJUFlZQf0egIBBySdu4y46FHIyWmFWm2ARCyAQCDAiJEyVFR0wNlZBB8fR9TVd6C9zQjfIQ5wd5fA3U2CvHwVdFoDQsMUOHGiAVdLNQgMlMLbS4qSklo0NQ5BVGSX/2PyJDc4OYmQktYEqVQAjgOcZGL4+IiRebEZly63QgBg6FAZZI5iKF3EmBbncdPJwOVLWchIS8U3W7+l9gvPSElCJMVw8+QL6Vg4n15m8Mk9uxE9nk6l+VupTkm7o1L3H3jgAdTV1eG1115DTU0NwsPDcejQoR5HaVlZ2U1bsbi4OHz77bd49dVX8ac//QmjRo3C7t27ERoaytscOWLC47+1tRVKpRI7EtPg5EQ3WerH/Yfx0IP3WWVPeuRYIoaPCcOkYDrtC27k4L6f8MiD91I9Gnxq7UNIPnsGRSWl1FYM+3btwD0r6DhjCSHYs20Lli1ZTMUeAOz8ehOWLF5Kzd6N7Nq0FbPmLYKkj59la3s7hi2Yj5aWFpP8FN33RUHFNSgGuL6ttRWj/b1Ntn2nYAdOVPotEHvDYDCgQ93Oi3iUV1bCzcOLqniUlZZi/57deOe996mJR2lBDoYFBVGxBQAXTh5FZBi9p1tFRirclfzEfhBCoDPo+xQPhmXY1AdyOjMPbl70go/6I+H4MYyL4ieuICs9BYvn0HNKAsB7b78FhcIZjz2+jprNS9mXERlOL3mssqoa/oFDqdlLuXQZk6dMo2bvRg59tx3RlNqAMn7GpgJSU1ZM/cbrDb1OB12nFlGj6QeO5eXnIXDYSKqrj5KiIuzcvg1/XL8eTk50kt1qK67Cy4ve6UP55Qz4+dI7HjQajeDA8ZMZTQha1Gp4B/PnC7hbsZmApBZWQCanG3zUF4cTEzCeJ897UUEuZsVOpGrzjT//ES6urvjVr5+mZjMlNZVa4BgApF28hElR9CJZj+/eickT+LnBj+3YjciRI3ixfbdjMwEpzb2Ie1fwXxi4pK4JnECAiOH0g2nOn0tGaAS9mwgA0lNTcPjAPrz9fxupVV1vrq2Ci1JJ7eneVFoApTNd8W9uU8HdP4iqzW7qWloQMI5uoSNGFzYRkPN5VyFXulolmelSyhk8wINQ6fV6NDXUIWoMvSeb0WjE7557FiNHjcbDjzxCze7ZpGSqgWOnz6Vg+jR6voq8Mycx1I+faMnjO3ZjAqs6xhs2EZDSvCzcs2wR7+PklVVCrlBCJKJ/2HQ88Qhips+iavP7rd8gL+cy/v3Jp9TaGLQ1XIPcyYmaWLdXlsBBIqF6cnaZx8jTmqYmBI2nu8Vk/IzVBeR46iV487RUvZW8zBSsWjyXut2K6mo4yRUY7UevmnlTYyNeX/8HLF6+ElMpPt1PnjqNObPiqdk7fjYZM+Pp9eSty86EjFJNkls5vmM3IkYw3wefWDUOhBCCaxUlWPcYvapafXEh+zJ8A4fzsk3KTE3GY2voFTYGgL+ufwV6vR4f/fOfvX5ddbkQpe9+hpbULBC9HgJHKZRR4+Hz2D1oPZeJ5jMXwAk4cFIpiE4HdXE5GhrqUIZOnP9sD4waLZxGBCLgyXuhq2/GlY3/QVt+MTgOkAb4wWNWDCRuLhBIHVCfkAR1URmkgb4QOTtD6uWCzqY2qMorccWoQkhpKxqOp0IgFsOg0cDBxwOjX30KRK9H6X92QJVXAom7K2TD/eDg7YGms5nQNbfBOWwUhv3mQZBOHTqq6qAuq8aurdsQ1ibAuY8OQujiBAE4uESHQlvbhNaMPAiVcohkUohkjlCEj4bQQYLOhmYYdXq055Wio74ZnfXNIAYDIAAMze0Ax0Hi7oJMFyPcR41HeVYlRAo5tFV1MBICdOrQ2dgCXVMrOmsaoFOpQQQAN8I6IQW/JKwaibon4Tj8hgVj+kR+QpW7IYRg955dWPfIGuq20zPSoHBWIi6c3vdwPvksVsyfgw//+RGe6uXkRa9qx/mo5dCWV5tlN9mowmSO3vYlzdiO8ZwjJJSquBkIQTppxyQB3ehmAMgnGnhCDDfO9Gekmhhwv6GIRaKagdW2MBkl12A0GHgXDwA4euI4xk2kHzSm0+lwrbKCqnhotVo8/9STGDc+DE/+6qler1FdyjNbPOqJDm6ckJp4GAiBHoSaeADAJaLGeI7OSdOtNBGDWeLBsAyr/YTzM8/j8UfpnSz0xZXqWhgMBsSMDaJuOzHhEGLj5wx8oRl8+O5GVFaU41zqhT4dkwKJ+UVnCkgH4gT0jlovETXCKN7sRkKgBYGUh5q0BaQDozh+/CqMm7HKCiTxfAZ8h9KN1uyLrHOn8eBK+se2V4qL4Ontg1G+dFoqAEBezmV89MF7+M0LL2HcuL6DqOQTzGu9WEK0GMrRq3TVfbM7UrzZL0ODcRzdHjLdNBA93NnqwyrwLiB6vQ4NNZVYOJOfPJQbOXXuHIaPGU9dqAghyM3KxIJ4yyuN3YrBYMCzTzwGP39/vPHX1/u9ViASASYemxoJQTXpxBCOXj/ZbKJBKMWbnRACNTFCztFvK1lEOjCCongy+od3md51IAFjJtK78fqiqKYerU0NWD4vnrrt44kJiJk2k6rN//zrI+TlXEbi8RMD1sVsOpMKmFhoJ5OoEU5xq0EIgRpGOFG82bOhwVieVh91RI8RArZ9sRa8rkBOZebCxdMbMeP4jwTMTDqBh+5bSd1uadlVyORyjAuiFylZUlSEjW++jkeffAqTYwdemXWUVppkt40YIAIHGcWb/RIPqw8VMULBw+qjgvLKizEwvK1AjEYjqooLsO7xR/kaoofjZ05jdFgk9boihBBkpaXiibX0joONRiOefeJRuLm747133jHpMy6zTdv+ZRE14jh6R6KG66sPmluNbNAVpBspJ52I5eFIeCDqVZ3o4Dr7vUal6v/rdyq8CciugwkIieTf75F7tQK6zk5Mj6R/PMzH1uWrzz5BZnoaDh05anKqftuFrAGvuXJ970/T/5NF1JhAeTvUToxQCOivPuqJDh7McWp1eNnCnM0qhJNCibgJo/gw3wMhBDlpyXhgBb2Set0UlZRArlAgdJgvNZulxcV467U/46FHH8f0GaaHg+va2vv/OjGinujhQ3H5riVGGACqJy/ZPJ68XCFadnRrA6gLCCEEZVcuY9XSBbRN38aBwwcxITaeul2j0Yici+lYPIdezkfP1sXNDX//4AOzPjtQYt0FokYUR6fwUDeZRI0IyqsPvnwfrcQAOQ/xJIyBob7m23UwASER/G9dzmdmwd3bj5cap10BY7Op2vzik38hI+0CDh05CrncvH26SNl36HMF6YQ3J4KIZp9booMzJ4SQos1saDCep9VHDtEghrKAMkyDqmyfzSqETO6MKeGjaZq9jaKaetRVlWPhjMnUbefl58HDywdjAryo2SwqLMTbr7+KRx5/wqytSzfKmN57whgJQSnRYjjlpXs+6cAYije78brvg4+4DxUxQAaBTRplMygKiMFgQPmVHN63LoQQZJw9hocfWEXdtk6nQ1FBLuZNpydMBoMBTz/+CNw9PPHB3/5mmZE+bo400k5965JHNAimLEiXCH+rDz5tMwaG2hZm14HDGBPFf8DYwYTDCIuZzssTJ+HQfkydNZ+qzU8/+gcuX8pCQuIxiwski5S357TUXt9m0Mwl0RIjWokBIQJ6N6SBEHRQDkTrppno4UwxYZBhPlT++o6nZsHVyw+x40fSMNcn5zOz4OLuyUuiXHpGGoaPDsFIHxdqNvPzcrHxrb9i3a+fRdyUQRZ1vuEeIYSggHQgmPKTN420YyLlFU0G5aPgG8khGowFO3mxJYMWkMyr9aivrsBSHkLIb+RKdS3qqsuxeCb9VU5tQyMa62oxLYpezxS9Xo+nH30Yvr5+eHfjhkHZMur1wA1VWzIoh6sDXUFYfpyEquNUQ4zgAF4ybmtIJ7w5MVt92JhB/2ZzUk7hkYcepDGXPunyexzHw/fT93sAQPLJRDy4ik67x24+fG8jCvLzsOXbb+HoOLiVQmvqpZ5/1xMdHDgBVYekgRCUEy2CKCehZZB2qkfBN1JMtBjB4j5szqAEZPfhRIwMm8R7a8r9hw4gPC6el6fNqZPHMDF2Kt0IzswMfPjuRjzz/IuYNCl60PbaC4oAXM8KJh3Ug7HSSDsiKW9dqkknvDgxBDz8zrqibpl42AMW3/lHk9OhcHFHfPR4mvO5jaS0NHj5BSA6hF4LxW4KrhRC6ihDxGh6trVaLX796MMYNmIk3n7rTSo2Jb5d3dgv8rB1qSU6KCk7YwkhKCJajOThJjcSglqigzfHetzaAxb91ZzNKkSHRsW73yP3agVamxoxf9rgn+K30qxqR0HOJSyeTbe15v+9/hdUlJfh2+++g0RCJ7Rc7OKMRqKHiOOoRnLy5YzNIhqq1ctupKtcAQsasxfMFpCT6Tmoqy7D/Svp+gxuxWAwICctGatXLeXF/umjh/DIA/dStXk++Sw+/+Rj/OW11xEaSm9l5jQqCJeJBqGUb0o+VjRtxAACwJmnoDEhOMhY2LrdYNZv4tDxM1C1NGLN/ffwNZ8e9u7fg4nT6Pd0AYAzp09ifGQU1YZTqrY2PP3YIxg/IRwv/f5lanYB4MAn/6F+FNpM9BCAox4depGoMYGnwK5MokYYCxqzK8y6g7wCh2H+tBi+5tLD8TOnMSw4FBEj6Lc7vFJcBIlEgknj6GYK/+l3L6KpsQlHE49T6yoHADXlJdBczIU35Rs9m2gwhWLtEADIJRqEcFJenN18lCtgDB6zViBTI/hvyZCZVwCO4xA/ib5ztrGtDfmXs6hm2QLAkYP7sX3bVrz/tw8wnGInNEIIzp5Nwtx7VlCzCQDZRI0xnCPVm1FNDGgnRnjw4NzsJEY0ED18WbUxu8OuNpOldc0oLbiMlQvptk7o5nQCfb9HQ0M9Xnj6V5g6YybWPfkkVdsnEg5i1sx4GNpU1GyqiQFaQqhXLU8nakTy5Di9wEPOT28YBu6xxrgFuxEQQgjSTidg7er7ebF/8kQiIidPobq9IITg+aeehEFvwNdff031iV5ZegVSqSN8vDzRlldMzS4fN3oB6cBIzoGXmI8i0oFAzoFqhGxv5BIN0oma1zH44u2330ZcXBxkMhlcXFxM/lxubi6WLVsGpVIJJycnTJo0CWVlZWaNbTcCcijhCMZNonuDd5OblwuFsxKRwUFU7f7w7RYcSziMz774Aj4+9Pw1hBCcO3ce8dO6wvYNqg4qdguv3+g0ha6DGNFMuRpaNxpiRCPRw5/nrUuqUQUPiDBJcGceD3d2duK+++7DM888Y/JnioqKMHXqVISEhODEiRPIysrCX/7yF0jNbHRuF0Ukz2VkwtXTG7HjhlO3XdfUhLKSIuph8OVXr2L9Sy9g+ap7sWIF3WrwCQf2YO6cnwsaOY0fvMNXe/1mHEW56HA6aUcMZWdsNxdIO3VH762kGdsxjHOAByeGmhh4HYsv3njjDQDApk2bTP7Mn//8ZyxatAjvvvtuz3sjLPDf2XwFkldWieb6Wl6KAxFCkHQsgXq7B4PBgF8/9jDkCmd8+umnVG1fLcyFm5sbPN3det5zDh58Www+aocUkw4M5Wl7kWVUYxznyMu2qJt8ooEvJ+bF8dsXra2tN720Wq3Vxu7GaDRi//79GD16NObPnw8vLy/ExMRg9+7dZtuyqYAYDAZkp57FgzwFiyUmHMLkGbOpH/39+x8fIDM9DVu2fgulUknNrsFgQHpGJqZMvvmo3NA+uL15KdHCn3KmbScxopboeenDUkt0EHEcr82x64kOWkLgR2H+zW1aNLV29PtqbusSioCAACiVyp7Xhg2Dy9S2hNraWqhUKmzcuBELFizAkSNHsHLlSqxatQonT540y5ZNtzB79v2EqBnzeDnbv3gxE95+/lSrqgNAdtZFvPPWG3jymd9i2nS6YfCH9u7GgvnzbntfERZssU09IaginVQbbQNd2ws+ti6G6+H1UynP99YxckkHpvE4Rl+Ul5fD2fnnGrd9dSX84x//iHcG6BuUm5uLkBDz+iYDXSsQAFi+fDlefPFFAEB4eDiSkpLw6aefYoYZZTdtJiDHTp3C8DFhiBhOP1is6to1NNTV4gHKTbY1Gg2efHg1ho0YOegaH7eSl5WBoUMD4eLcyx+1wbS2lr1xgbRjEuWtCx8rmm5SSDuieT6yTbXCGH3h7Ox8k4D0xe9+9zs89thj/V4zfLhlPkMPDw+IRCKMHXtzXNeYMWNw5swZs2zZREDSc/IgEosRH9V3R3pLMRgMSD1zEk88+hB126/94feoqqxAckrqgP1szaFT1YyCwkLct2pF719vbLXIbhXphCcngphi7oiOpxUN0OVT8eckkPCY61JKtPDhxHCw83waT09PeHp68mJbIpFg0qRJyM/Pv+n9goICDB1qXma61X+KxdcaUFFcgOXz6XZ86+bwgb2YNncB9W3RkYP7sWXzV9j47nsYO3YcVdsHDh7CiqV9N8fSVFabbdNICEp4KLrTtaKhv3VRX482DeDxyFZLjKghOuqFk2xNWVkZMjMzUVZWBoPBgMzMTGRmZkKl+jkAMSQkBLt27er5/8svv4zvv/8en3/+Oa5cuYKPP/4Ye/fuxbPPPmvW2FZdgRBCkHYqAU8+vpYX++fOJWH0uPEIHuJB1W5NdRV+++Q6TI+fhaefMe8HPBCZqckIHTcWYnHfJwGqnCKz7fJRJKicdMKXE0PMw9YlzQpHtimknWrvYHvhtddew+bNm3v+HxERAQA4fvw44uPjAQD5+floaWnpuWblypX49NNPsWHDBjz//PMIDg7Gjz/+iKlTzavda1UB2XdwPyKmzuKlgtmV4iIQQhA7YQxVuwaDAU8+vAZiiRhbtm6lurJRNdaipqYGy5f035rTfcYkFP3fZybb7a7YTrMtpYEQlBEtpvCwdblMNBjDSXk9ss253q6C74hWW7Bp06YBY0BIL2H669atw7p16wY1ttW2MKfPn4dv4DBMCg6kbruxtRX5l7OwbB79bdHf392A9Asp2PrtNnh40F3ZHD6SgKWLFg54nVtcpMk2+SoSxFc+SgvRQ08Ir7EYDUQPAwi8WBUz6lhFQC5dKYa2Q4O5cROp2yaE4NSRg9ST5AAg6cxpfLDx//D87/6AGdeXgtRsnzyGyZNjTFqNqa+Ynp+QTrmnLdDljHXnRNQdj4SQ69XL+Kvx0XVkq8F4nhL97nZ4F5DS+mZcyc7AfTx1rEtMOISYGbOo59DU19fhV4+sQcTEKPzvm2/QtV1Vjk6tFsOHmrYa01TUmGaX6CDjBFSbOBkJQTFP9U27Sx/yWePjPFFRP8Zm/AzvAnLh5BGsXfMAL7bTM9Lg6x+AsOFDqNo1Go146pGHoNfr8MP2HdQzeE+eOoX5c01v3u0cPrBfhxCCPMo9bQF+mk0BQCPRQ8gBSh5KH3aTTzQI4hzs/sj2TobXn+yhhCMInTSFaunAbq5WlEPV2oL4GNP9A6byj/ffwbmkM9iy9Tv4+flRtX38yAHMmhlv1mdUOYUDXpPOU8V2BWVnLNAldtk81Hi9kUaipxaqzugb3gQkOT0DLh5eiA2lV6Grm5Z2NS6mnsc9S+hvi5LOnMZ7b7+FZ194CXPm0q3JWlaUD7lcDh8v8wKEOHH/N0E90cGRcrOpbmdsCA/+CT6LDwFdfo9sokGYgPk9+IYXAcm9WoGWhjpeMmwB4OSRA1i7+j7qduvravHkw6sRMTEKG97+X6q2DQYDLlxIw7S4WLM/K/Xt+/Sne+sylvKNzkf7TIAfsbuV80SFyczvYRWoC4her8flC0lYfQ8/bR9OnkhERHRsv4FXltAd72E0GrB9x4/Ut12H9u7GwgXzLfqsdIg3IOz9V8XHjd5I9JBw9Cu2d3fWoy12N5JLNBjOSXkNh2f8DHXnxN59P2FSvGU3ykBczsmGQumCyJDB18e4lQ/f3YiUc0nYu/8gfH3pZvDmX8pEYGBA74lyJsAJBL0m1PH1NL9MNLxkqmbwcMR8I/VEBwMIfFi8h9WgKtOJJ09iZGgEwod50zQLAKhtaERVeRnmTzd/CzAQyWfP4G8b38ZzL/4es2abfjpiCp2dncgvKEBURLjFNox6/W3v8XXqcomoMZ6HFUID0UPK49bFcP3nwadjlnE71AQkM68AQpEI0yPpt34ghCD5xFGsvmc5ddtNjY14au0ahEdOxNv/+xZ1+4f3/YTlSxYNyoa6rOq29y7y0D6ynRigIwQuPBTyySUaXrcu54nKZin6dzNUBESv06EkPxsrF9J9endz7OgRxMyYxUvA0e+fexYajQbf/7CdejBaXlYGRo4YMegeuS2p2Tf9X0UMICDU20de5GmLkU26yhPyRTHRIpBzYH4PG0DlJ77/4H5MnMZPL5crxcVQODtj/DC68RgAcPjAPhzY+xP+8c+P4O/vT9W20WhEXn4+wsMGX/NEe63hpv9n8eA4rSSd8OMk1EVaR4xQEyNceSpPqCNG1BId75XbGb0zaAFJzboE36HDMSHIi8Z8biP/8kXqneQAQKfT4Y8vvoAp02Zg9Rr6xYdOHT2M2bPoJPe5Tfs5h6iO6ODFianf6OWkk5c6GZlETb2swI1kELVVmk4xemfQAlJZegXzp0XTmMttpKWlYsz4CF5sb/tmM67VVOPvH/6d+s1oNBqham+Hh5srFXtSv5/FuYiHvJRaooMXDysEAyEgAEQ85bqoiREScLzZZwzMoATkfOZFBI2mW53rRhrr6xAzfjQvtv/7+WeYHj8LoaH0e/Cmnz+LyTH0mpB3lHcl0xFCIAL9m+Uq0WI4D8ly+eA/5oNl2doWkx473cVI1Kq2m96vKCnEg6uWQdVmWc3O/tDr9dDrdGhrpW9brVaj+EohnnzySbTyYL+8vBzjx46hZts4xBMaqRhX1a3whIh6AyQtIbw0VWo06hEkkPDWsElDjNByRoBSS1s16Yq16a34Tr+fa20BZ+j/e1S30+tvbE9wxISfVkVFBQICAqwxHwbD5pSXl5vkVG9tbYVSqcSOxDQ4OfVfKrG9XYV7Z09ES0uLSVXZ7xRMWoH4+fmhvLwcCoWC19oNDIYtIYSgra2Negb2LxmTBEQgEFA/5mQw7BGanQbvBljkDYPBsBgmIAwGw2KYgDAYDIthAsJgMCyGCQiDwbAYJiAMBsNimIAwGAyLYQLCYDAshgkIg8GwGCYgDAbDYpiAMBgMi2ECwmAwLIYJCIPBsBgmIAwGw2KYgDAYDIthAsJg3OEsW7YMgYGBkEql8PX1xSOPPIKqqtubkXXT2NiI5557DsHBwXB0dERgYCCef/55tLS0mD02ExAG4w5n5syZ+OGHH5Cfn48ff/wRRUVFuPfee/u8vqqqClVVVXj//feRnZ2NTZs24dChQ3jiiSfMHtukmqgMBuN27LUm6p49e7BixQpotVqIxaY1Gt++fTsefvhhtLe3QyQyvcUHW4EwGL8gGhsbsXXrVsTFxZksHgB6hM0c8QBMrInKYDD6xpSWDd3X3Nrqw8HBAQ4Og+8I+Morr+Djjz+GWq3G5MmTsW/fPpM/W19fj7feegtPPfWU+QMTBoNhERqNhvj4+BB0daYZ8CWXy2977/XXX+/V9iuvvDKgvdzc3J7r6+rqSH5+Pjly5AiZMmUKWbRoETEajQN+Dy0tLSQ6OposWLCAdHZ2mv0zYD4QBmMQdHR0oLOz06RrCSG3tUXpawVSV1eHhoaG296/keHDh0Miub2peHcfp6SkJMTGxvb5+ba2NsyfPx8ymQz79u2DVGp+d0K2hWEwBoFUKrXoxhsIT09PeHp6WvRZo7Grw55Wq+3zmtbWVsyfPx8ODg7Ys2ePxd8Dc6IyGHcw58+fx8cff4zMzExcvXoVx44dw+rVqzFixIie1UdlZSVCQkKQkpICoEs85s2bh/b2dnz55ZdobW1FTU0NampqYBigReetsBUIg3EHI5PJsHPnTrz++utob2+Hr68vFixYgFdffbVna6TT6ZCfnw+1Wg0ASE9Px/nz5wEAI0eOvMleSUkJgoKCTB6f+UAYDIbFsC0Mg8GwGCYgDAbDYpiAMBgMi2ECwmAwLIYJCIPBsBgmIAwGw2KYgDAYDIthAsJgMCyGCQiDwbAYJiAMBsNimIAwGAyLYQLCYDAs5v8B4ZjvqqcrqdMAAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "=================================================\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Final Result"
      ],
      "metadata": {
        "id": "yv86BgCXQLFL"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Left to right: Linear model (ERM), FCN (ERM), FCN (CMID)\n",
        "plot_boundary_heatmaps(model_lin, model, wreg3, datas['te_dl'], c)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 254
        },
        "id": "DNusrdmVNW8t",
        "outputId": "7a8ad041-57f9-4ce2-d679-7c6bb7dba1d9"
      },
      "execution_count": 19,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1000x300 with 4 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwAAAADtCAYAAAAIsxJPAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAACgp0lEQVR4nOyddXgc17m435nl1YrZtszM7BhjO3Ech5naUNP0/tqkTblJb5uUbnPLfAsppGkbBidxHDtmZltmJplkWSwtw/z+kGVLtmBnZ2a1Wp33efZJvHvmO2e1c86c73wkKYqiIBAIBAKBQCAQCLoEckcPQCAQCAQCgUAgEMQPoQAIBAKBQCAQCARdCKEACAQCgUAgEAgEXQihAAgEAoFAIBAIBF0IoQAIBAKBQCAQCARdCKEACAQCgUAgEAgEXQihAAgEAoFAIBAIBF0IoQAIBAKBQCAQCARdCKEACAQCgUAgEAgEXQihAAgEAoFAIBAIBF0IoQAIBAKBQCAQCAQ68Mc//pGRI0eSlpZGWloakydP5uOPP27zmurqap566ikKCwux2WwMHDiQhQsXGjpOs6HSBQKBQCAQCASCLkKPHj343//9XwYMGICiKPzzn//k9ttvZ8eOHQwbNuyq9oFAgDlz5pCXl8fbb79N9+7dOXnyJBkZGYaOU1IURTG0B4FAIBAIBAKBoIuSlZXFz372M5544omrPvvTn/7Ez372Mw4cOIDFYonbmIQCIBAIBAKBQCDocvh8PgKBQLvtFEVBkqRm79lsNmw2W5vXhcNh3nrrLR599FF27NjB0KFDr2pz0003kZWVhdPp5P333yc3N5eHHnqIb33rW5hMJnVfSAVRuQBFIhHOnj1LamrqVX8AgUAQPYqiUFdXR7du3ZBlfUJwxPwUCPRBzE+BIHHRe376fD569ijiQkV5u21dLhf19fXN3nvhhRf43ve+12L73bt3M3nyZHw+Hy6Xi/fee6/FzT/AsWPHWL58OZ/61KdYuHAhR44c4Qtf+ALBYJAXXnhB9feKlqgsAKdPn6aoqMiwQQgEXY1Tp07Ro0cPXWSJ+SkQ6IuYnwJB4qLX/KytrSU9PZ0NH32CK8XVart6dz2Tb76BU6dOkZaWdun9tiwAgUCAkpISampqePvtt/nrX//KqlWrWlQCBg4ciM/n4/jx45dO/H/5y1/ys5/9jHPnzmn8lq0TlQUgNTUVgIXL1pPiav2PlEis3bKbwf17UlDYPar25eXnOXDiLLOnTYyqvdfjZfP27dw8Z2bUY1q2bBm33TQ36vYrli3j5rlzomp7803z2LRpE6/84+/cdustnHnjI/Z+6UdtXrMj4mGM7Ix6PJ29fSLgUSI8Fjl+aU7pQbzn5/sLl3D3XXfGfP3y9RuZMn4kaWnpMV2/eMkS7r7tppiuVTsHG1EzFxt5+qmneP311/je89/ly1/6YrPPShesZNcTz7V4XSz39THFTxZmMiR15uKIorBL8TI6xnmkdQ4m2hw2cn7uPRKd3Lq6Onbu2MYNs2frNoZGvF4vw4YOoba2ljdfe5Ub5lyvex/nTx6l5NQZxk8Yp7vsRha88xbzbrzZMPmv/s8vKPj3KsPkN2V7xM0oyYmpA6xD55QgARR6Sda49x0LRsxPAFeKi9Qonp2NWX2iwWq10r9/fwDGjRvHli1b+M1vfsOf//znq9oWFhZisViaufsMGTKE0tJSAoEAVqsxv09UCkCj2TLF5cLl0vcPbxR2hxNnSgquKG8Ur9eN3ZmCKzW6H9dkMuNwOkmN8mYAcDidUd88AE4V7c3mhp/S4XCQlpaGJz8PZzubAbskt9smmdonEnq6AsR7ftpsjqjnVUvk5BVy9EwV07vHdipqd6ibd82vdaiag404YrguKysLaDgJuvLaQPf8Vu/dWO5rCxKpmFRfF0QhJYbrGtE6BxN1DhsxP1NTU6O6h9LS0ti+dQt2u133B39aWhqPPfYYv/3tb/nmc99m7g1zdN9MpY0YQ/HuPaSkpBjmvzy4X1/Olhxl8LDRhsjv2b07VUTIlYwPyBwru9ijeJgoxf9wtZ9kYm2kjr7YsEmdJyt8Z3Sli0Qi+P3+Fj+bOnUqr776KpFI5JJr06FDhygsLDRs8w9JXAegM94gepJ388yOHoIgWdE4tUYN6E1l+Xl9xqKSeK4LGZkZAFRVV1/1Wdb0Cbr2FQZMMfwwIRQsMf5NIoqi9VYQtMLceTfxzvsfGCL7u8+/QM+eRZw4cYKnv/QMRuQBufmG61nwkXE5zMfOmMWBw8fwVV8wRP5NX3ySA4qPcBxypDglmULJwhHFZ3hfLTFZcrFBqSci8sHoxnPPPcfq1as5ceIEu3fv5rnnnmPlypV86lOfAuCRRx7huecuW4A///nPU1lZyTPPPMOhQ4f46KOP+PGPf8xTTz1l6DiTVgGICZUTIJETKMkmE8ji8SwwAI23fYrLhc/r0dB97AOIdc7a7Ta8Xq+qa7IyGywAlRWVV30myzKY9TsdDSlKTEVdgiiYY9zGB1CwdvGDFqOwWq0MGz6CZavX6C47PT2dl//5CrIs86//vMqPfvyi7n04cwoZMnAAGzds1F12I7fd/wDzFy817Dk80ZrGBqW+/YY6UCTZ8BHhjNJ+Nhq9MUkSkyQXa5S6uCg8XYGysjIeeeQRBg0axHXXXceWLVtYvHgxc+Y0uJGWlJQ08+0vKipi8eLFbNmyhZEjR/KlL32JZ555hmeffdbQcQoF4CJqTwYTzcLQ4njEZBYYgMlsJtCKKTNatDy0JaS4K9+F3bpz5GSJqmtycnMBuFDeyimljt8h1o18gAjWGBUAPxHsGh4hYUUh8Zx/Eof+AwZgt9nZuHW77rKnTZvOL3/5KwBe+P4P+Ovf/657H4NGjcNms1K8Y4fusgEsFgs3XDuVDz6cb4h8GzLDJQebI/FRAoZLTsqVUIcoAQ5J5pqLSkBQicS9/2Tjb3/7GydOnMDv91NWVsbSpUsvbf4BVq5cycsvv9zsmsmTJ7Nx40Z8Ph9Hjx7l29/+tqEpQCHJFQC1mwSj28eDxjF5Sy9oPqkVCFoiOy+f9Zs1PtQ1zJ2MrGyKD6nbjDficDpxu92qr+veowdnz5xRdU1eXoMCcP582VWfBSqrIazfg1YB5BgOJYIoWGJUAHwo2DQ4AfmIdCq/445gzLhx1NXVsmPPPt1lf+Gpp/jmt74FwH99/ile+de/de9j7OTp+Hx+du/cpbtsgNz+QxgzbCiffPKxrnJDbg+EwmRIZnpLNooj6teMWBglO6lQQpxStB2wxIJNkpkupbJeqadOCce9f0H8SdrV1+gT+kS3APhOnu2gkQiSnWtGDeLCeeNSk7XHyCGDOH3yWEzXFvXuw/a9B1Vf53Q68fnUPZRzc/OAli0AvnPt551WQ6yrkR8lZguAjwgODY8Qr8bruwpTp8/gfOk5du47oLvsH/7wR/zXf/0/FEXh8c8+yb/+/R/d+5g88zo8Xq9hloA+o8bSv3dPli1drJvMQFXtpf/PkywUSFZ2xEkJGCk7qSfSITEBJklihpTKAcXbIZYIQXxJ6tXXeAuAquaqicXC0HhN6qhBeg9HIADAarURCgU7rP/UtHTcdXUxXdu7R3fKSuOjvOTn5wNw4UI54XDzE7WUwX107SvWpSiIgjXGx4BPowuQlwjO5H4E6caMmbM4e+Y0u/arV17bQpIkfvPb3/Lkk59DURQee+Kz/P0K1wQ9uOba2QSDQbZt3aq7bIABYyfSq0d33ZQAZ4+CZv8ukCx0k6xsi5MSMERyYEJijxJ7rFSsSJLEBNlFPWH2KeringSdi+RdfVUeakkqL0h0C0D9geMdNBJBV0DtfLkSs9WqOY4gFmRZjtl1T+11OTk5SFJDvEJFRUWzz7zHT8c0htaI3QIQidmNx6co2DQ8QjzCAqCKa2fN5tzZM7q7A8myzO9+/3s+97n/QlEUPvu5/8ef/vKSrn0ATJw+C5PJxIb1G3SXDTBo/CR69ejO0iWLNMvynbvaapcvWeglWdkSp5iAPpKNHCxsitR3iLvxIMlBFiY2RESGoGQluVdf1TetyvYJOCkaF4pQdW07LQWCjqOge0/WbjXGLzhRMJvNZGdnA1fHAQSrEmN+BpTYXYC0pBAF8CqKUABUMv3amVwoO8+2XXt0lduoBHzpS18C4AtPf5Ff/ea3uvYBMOaaaWSkp7Fy5UrdZUODEtC3VxFLNMYEBOtaPunPkSz0l+ysj9TFZVNeIFkYIjlY3UEZegokK6MlJ2uUOjwiODjpSNrVV/UJpdoHWYJbAFJHDOygkQi6BBpv/3FD+lPeQXEE8bTetZYJyDW4b9zG0BaxBg/rQRgFc4Kto52BaTOupaqqks07duoqV5IkfvbzX/CNb34TgK9945v86Mcv6r7RHTp2Ij179GDRIv189psyYOxEBvTtzccfL4hZhqOosNU1LlMyM0Jysk6Jz8l8mmRiysUMPR2xCXdIMjOkVHYqHkpFXEBSkbQKABjv068lH7lRNH5n96ETHTsQQXKjaMuCZTKZiERif5iZLRYCgdgeRlrGrfba3JwcoCEOoCmeE/q6AAm6FlOmTsPtrtc9RagkSfzoR//DC9/7HgDPf+/7PPff39V9o9tv2ChGDhvK/Pc/MGQT3W/0eIYPGsBHH30Y0/W+drLopUomxkopcTuZt0gy10qpFCtuypX4x19JksRk2UUFYQ6KuICkIWkVgN556sqbJ1sdgEBVTQeNRNAVSMvIZMuOvR3Wf/eevdmwIzZf6FiVh9zcXI6fVpddq9ECUH5FDECwJrYgZoGgkUnXTCYQDLBu0xZd5UqSxH//93f46U9/BsBPf/5zvvSVr2pS2Fuie//BzJhyDW++9bbusgF6jxzLmOFD+HDB+6qvDXnbz8DjvJg7f7VSRygOSoAkSUyRUzmjBDnRAWlCAYZJDlIwsTVOwdACY0laBQDgaMl5Ve2TqQ5AzVZ9fUQFgqZMHjOU0rMaT7E1zJ+h/ftyPsb+exT1ZMf+Q6qv69W7N6dOqas/kJ3VEANQXt7cAlBbvF91/wLBlYyfMBGA1QZU3P3yV77CH/7wf0iSxB/+74989nP/dVU2K61k9+jDzTfM4fU33iIUCukqG6Bo2CgmjhrB/Pnvqnpe1+85ElU7myQzTUpljVJHIE7uOaNkJ2GUDskQBNBDsjJAsrM6IioHd3aSVwEw+EQ/0S0ArqH9O2gkgq5AaloaHrfGU2wNc0iW5ZhPDfv16c3Z0+qVh8ysLKoqq1Rdk5WdBUBlVfPrXAP1TQMq6LqMGTcOq8XKirXrdJf95Oc+x9//8TImk4mXX/kXD336kZhd71ojNb8799x+C2++9Q6+ev0tY92GjGDaxHG8++7bUSsBzt7do5ZvuZg7f4NSjzdOSkA/yU5uB2YISpdMXHPRBcongoM7LcmrAHRxut9zY0cPQSBoE7PF0iGpQC0WC+EYThtjUfqzshoUgKrKymbv590wTbUsgaA1Ro4eTUqKi6WrVusu+1Of+hSvvf4GFouFt955h7vuvQ+vV18/cFtmHg88/CjvLfiY2ivmih7kDxzK7GnX8Nbbb0a1Yc6aOEKVfJMkMV1KZavipj5OVXTzJQvDJAerlDqCHbAJt16MS9gcx+8s0JekVgBUa8ZJ5AKkGOBTKRA0Q+Ptn9+tiHXbduszFpXEqxZAZkYmcLUFIBHXDkHnZviIEWRmZvHJ8hW6y77jjjt4b/587HY7Cz9exM233U5djMX4WsNkMvHgI4+xePkKys+X6iobIKffYG6cOZ033nzdkJgDWZKYJrnYpXioUvR3Z2oJl2RimpTKeqWemg7YhMuSxHTJRbHiEUpAJyRpFQCjXXoS3QUoEgyBxdJBoxEI2mfckP5c0FiVN9aNdKzzV+11GZkNCkBVVXXzDyIRJLs1pjEIOifvfrCADxYtMVT5GzJ0KHn5BXy8ZKnusm+4YS4fLVyIy+Vi5arVzLlxHpU6n9ZLksS9Dz3Muk1bOHvqlK6yATL7DOCW62fy5ltvtBvPIDtsquU3BuoeVnxciFO2HvNFF6RDipczHZCmU5IkpkoudiieuLlA6U2KSW73lYwk57e6iNo0nUZbDOLBpe+gKJhdjo4djCCp0ZoG12w2E4nEfmqUkZVN8SF1QbmNxOsEPjMzA4CqKy0A4QiWNHWZygSdm7lzb2TQ0GG88uob7Dx41LB+Bg4aRI+iIhYYkGd/+vQZLFmylMzMTDZv2cqs62+gtFTf03pJkrjj3gfYuWcvJ47p/3dK79Wf2+dexxtvvt5q4HEkFMaSkRZzHxNlF6eUAOfitCGXJIkJsovaDkrT2agEbFbqRWBwJyJpFYCubgGo33+UkFvk6xUYh0UHH34t82jU0MGcOhHbBkGSpLgoAenpGQDU1DZPy+s+cpJArUgF2tXonp/H3ffcw+mSkyxds96wfvr1H0Dffv34YKG2irgtMW78eJYtX0FBfj679+xh+qzrOHHihO793HTH3Rw9fpLDBw/qLtvVow93zbuBN996A39N+VWfe0+dI1CtrVr3WDmFckKUxDFl5xDJgRMT2zogTacsSVwjudio1Me9b0FsJK0CAKj2UTbaYhCPNKON19i750MwPn6Igq5JTn431m7apkmGlk24KzUNT31sD5ucvHz2HlVvPUhJcVKvos/09HQAqqubKwC2glwIxr+gjyAxuHbGDJwpKbzzwUeG9dG7T18GDh7Mex/q38fw4cNZsWo1vXr25OjRo0ybOYv9+w/o3s/1N93KudLz7Nujf1rrlB69eeCxx3ln4WK81WXNPrPlZKIEtD8/R0hOPEQ4orRfV0AviiQrfSUbazogTadNkhkg2dknioV1CpJWAUhEC4CRfVzZ1paXDWazqv4EAjVMGjnQkGA9NcRqQRjUvx+nS06ovq5HUREHj0V/XaMC4PV6CTbZ8Fuz0pHMIkanKzNy2DAGDxvBv16LLjNNLPTs2YthI4bzzvsf6C67X79+rFy9hiFDhnD27Dmmz5rN1m3aDgRa4tob5lFTW8eu4p26y7ZYLDz0mSeYv2gp7srLa5k5NQXJps/8HCw5kIH9cdwUZ0pmJkoprFHq4u6XnydZ8CsRakVQcMKTtAoAJOYJvdE0jqls0WpxwigwFIvFQkRjYSBZNmkqLhTrHExNS6M+hiwm3br3oPRc9NWA09Iu+xHX1l52KahYtRnFH/+APUFi0atHN6bOnMU//v2q7kW2GunRo4jRY8by5rvv6S67e/fuLFu+gvHjx1NZWcms629g5apVuvczZdb1+AN+thugYJhMJh76zBN8uGQFdeUNSQmqd+xH8eh3at9XsuPCxM5I/Ip32SSZGVIq2xQ3lXHKStTIaMnJzg4qVCaInqRVAFQfDCZZDICnJPpNikDQUeQWFLKxg6rixjKHLRYLoVD0GzWLxYLdbgdoljbRc0pb9qPOTiIennQUeVmZzJl3C//41384XWlMXEhht25MnHQNr70VfTGsaMnJyWHxJ0uYOXMmbrebG2++lQ8+XKBrHwATp89CkiQ2b9qku2xZlnnw8c/w8YrVVJ8/je9sWfsXqaRIslIoWdgciZ+PvCxJTJNTOa7445ohSJIkhkj2uFo9BOpJWgUAEq8OQDxjAFwDe6u+ViCIN+OHDeT8mdjT/UmSFHNO73jVAmi0AtQ2Cfp1De4XU9/Jgh8FW4IdonQkmakp3H3PvSz+cD4ny9RVm46WvPx8pk2fwatvvqW7EpCamsoHHy7g1ttuIxAIcPd99/Ovf/9H1z4Axk6ejsPuYP06/QOoZVnmgcceZ+na9QQyjHHPy5MsDJLsrI3UEYmjEjxOTqGWcFxjEXIkC7VKmEAnTQ3aFUhiBUDlib7K9pBYcQZXtpWkJP5pBUmDzWYnGIz9ZCq3oBub9xyO6dp4WfFSUxvSfdbVX1YAOvvWV+sG0kMEJyadRpMcWCwW7r3vfpYt+ohj5y4Y0kd2Tg4zZ83mX6+9rrsSYLfbeeONN3n44UcIh8M8+pkn+M3vfq9rHwAjJ04mIz2N1QZUPZYkifseeYw1xbsMK6yVLpkZJ6WwWqkjFEclYIjkQEZiTxxdc8ZJKWwXrkAJS5LvEju/T79aGr9D1rRxSDZRaEhgLFprAYC2eTdy8EDOnjwR937VkJLiAqCu7rLpP33sUCSHPS79G0EABasGBcpLBGenV4P0R5Zl7r3vflYvW8ohg9zEMrOymDP3Rl75z6u6V8Q1m8289Ne/8qUvfQmAr3zt6zz/ve/rPteGjZtEfl4uK1boX/VYkiQe/uZX2W8NGlbR1yHJTJNSWafU4YnjCXlfyUY25rilCTVLEpmSKW5F0QTqSFoFoLPn9VfLVeOXZRSRBlRgMHaHE49bm0+rlrlns9sJBGLLs2212fBrrGMQDS5XCgBud5OHriShdOIgfR8Kdg2PD7ewALSKJEncfc89bF6/lv3HTxvSR3p6OjfefAuv/Ef/4GNZlvnZz3/B977/fQB+9OMX+eKXv6K7sjF49Hh69ujB0qXLdJULDb/BNbg4pPioMEgJaKzgW6y4DVM0WqJQstJLsrIhUh+XQ5BBkoPDcXQ9EkRP0ioAkBxZfdTS+B1qdx8CnRdcgeBK8gq6s3Zjx9UC0EK37j3YeeCI4f24XA0WgKb1A9wnz4CKYOJEw08Eu4YTfI8SwZncjx9NSJLEHXfcyc7tW9h1+LghfaSmpnLzbbfzyn9ebbUibqxIksS3v/3f/Pa3v0OSJP7vj3/i0cc/0ywVrh70Hz6aAX37sHjxJ7rK9Z0vh2CISbKLY4rPsBNsSZKYIqdyVPFzNo5BujmShaGSg3VKfJSAvpI9rvEHguhI2hW4q1sAQrWiGp/AeMYP60tVhTH+ykbTt3cvzp5Rf8LqcqWoKgbmTLloAfBc9oUN13TuKsA+Itg0PD7CKJg7+ZobD2655VYO7dvLjv2xxbm0R0pKCrfecSf/evU13TfnAP/v85/n5X++gtls5j+vvc7d996P16tvZpjeQ0YwdNBAFupY9ThYc9laN0F2UaIEKDPQjWW8nEIVYY7FcZOcLpkYLTlZGwcloECyUKYE4xr4LGifpFUAkgEtSknayEE6jkQgaBmTyYQS0baoO5wp1NfVtt9QZ6xWK6EYNj0FhYUcLYlecXClXG0BcA3o3WrqYQkS/kHpR9GkAAii58Ybb+TEsaNs3W1Mulyn08ntd93Nv197nYo6/X3DH3zwQd5+5x1sNhsLFi5k3i23NquJoQc9Bw1j9IjhfPCBPulHnb0KQb58f4+TUzijBCg18JR+mOQAYG8cU2e6JBNjJCfrFeMPDEVtgMQjqVfwZHDpUUtjUKYlzdXBIxEIoiO/e0/Wb9ujSUa8UnoCFBR2U1UMLOWiBcDTxAJgcjpaTTtsRiKkQ3B1e0QUJWYnHp9GFyCBOuZcfz3nzp5hY/FuQ+Tb7Xbuvu9+PnjvXcoNsB7fdNPNfLxoEampqaxes5brbriR8vJyXfvo3n8w10wYy3wdqh6bbNarXGjHyCmUKiHOGagE9JXsZGFia5yCdKFBCRgmOQwPDHZKJsKAT6QFTRiSVgFQ7wJk0EDixFUuQHXCBUgQJzTOndEDemlyI8rIzqH4UElM18ZiZXM6nfh80QcPO50NJ3sez+WTvXCg9U2EWZKIR0hgCAVzjD9eQFGwCgUgrsyaOZOKCxdYt7XYEPlms5l77n+ABe/Pp6xaf4vctGnTWbp0GdnZ2Wzbvp1rZ1/PmTNndO0jv/cApl0zkXfefU/TAaDSSvzcaNnJBSVkaFGtQslKP8nGukhd3A4xMyQzBZKFAwZbH8ZIToq7gBXgxRdfZMKECaSmppKXl8cdd9zBwYMHo77+9ddfvxgHdIdxgySJFQBAbRbQpLAYNH6HSEBkABLECY3TRpZlTXNv2IB+nDsdmwIQjzlvd1xUALxNHnzh1k/BTDT4yBtNEAWLhpOPzh431Rm5dsYM6mprWL1JW+B9a5hMJu65/wE+XvAhpZXVussfM3YsK1auonu3buw/cIDpM2dz/Li+Qc65Pfsxe8Y03nr7HUMsgyNlJxVKiNMGKgGZkpkxca4V0F2yEgZDU3aaJIlUyUR1HLMedQSrVq3iqaeeYuPGjSxZsoRgMMgNN9zQPBNcK5w4cYKvf/3rTJ8+3fBxJq0CoPrh1MkfZld+X5PL2UEjEQjUo2UzmZ6RSW11bNVT47GJdTob5mLT4EfZ2nqlUUucXICCKFjEKX6nY9rUqfj9Plau32yIfFmWuef+B/hk0cecvVChu/zBgwezcvUa+vbty4mTJ5k2cxb79x/QtY+s7r2ZO3sWb771dkxKgGxqO0XtSNlJNSFOKcalEXZKMlOkVNYqdXFzmxkmOTio+AgbqHQMxc6+OMY5dASLFi3iscceY9iwYYwaNYqXX36ZkpIStm1rW3EPh8N86lOf4vvf/z59+/Y1fJxJqwCA+iJFyWQBQBYPdkF8sDud1Ndpy2qjZe5JkhRzQTKTyaR7CsQrcTouKgBNYgCaBhheNSYkgkIBELTB5EmTiCgRlq3dYIh8SZK4+977WL5sKadKy3SX36tXL1asXMXQoUM5d66UGbOvo7h4p659ZHTryc03zOGNN9/WvQYBwHDJSQ1hSgxUAiwXawVsVtzUGVSZ+EomSilsVYyLB5AkidyLWYE6G7W1tc1e0daRqampASArK6vNdj/4wQ/Iy8vjiSee0DzWaEheBaCLpQG98vuKGABBvMjN78b6zds7dAxSjBvZ3PwC9h2LzX0oWuz2hoq/TeMGwm08OMxI8XMBEgpAp2Xi+PGYTGaWrFpriHxJkrjz7ntYu2Y1J87oX5W4sLCQpcuWM2bMGCoqKpg15wY2b9miax+p+d25bd4NvP7GW6oKnkWrMAyXnNQRMVQJkCWJ6ZKLPYqXyji4zlglmRzJbGicw4AEqwtgT7HgaONlT2mw2BYVFZGenn7p9eKLL7YrOxKJ8OUvf5mpU6cyfPjwVtutXbuWv/3tb7z00ku6fa/2SF4FgBhOFZPIAlC761AHj0TQVdCrFkBHWOD69urJuRhqAagZa2MMgNd32exdv/9Yq+3jlQVISxCwIDEYP3YMNruDT1auMUS+JEncfuddbNm8iSMnT+kuPycnh0+WLGXy5MnU1NRw/dx5rF23Ttc+UnK7cect83j9jbeitvZ5j0W/JgyTHNQT4aSBSoAkSUyWXRxX/JTG4eS8n2TnuOI3dE3OlSyGxhsYwalTp6ipqbn0eu6559q95qmnnmLPnj28/vrrrbapq6vj4Ycf5qWXXiInJ0fPIbdJ0ioAak8EO7sFoLOPX9B50aMWQGpaBjUx+vFr6zeNuhhykquZb5ctAJdPvJQ2NiINCoDxhIQFICkYO3oUKa5UPl620rA+br71Nnbv3MmBY/pXJU5PT+ejhR8zc+ZM6uvrmXvTLSxbvlzXPpw5hdxz+y288ebbURU8C6t0CxwqOXAbbAmAhnoE55WgoQHIjYyWnOwy0Fd/gGTnqMF/L71JS0tr9rLZbG22f/rpp1mwYAErVqygR48erbY7evQoJ06c4NZbb8VsNmM2m3nllVf44IMPMJvNHD16VO+vAiSxAgCoPtFPphiArIkjO3gkAkH05HXrwYbte+Peb6yKs5q1wuFoUAC83ssKQPqoIa22j5cFICgsAEnDqBHDSc/M5KNPlhnWx9ybbuLg/gPsPaR/VWKXy8X7H3zI3Llz8Xq93HzbHXy8aLGufdiz8rn3jlt548238bvbdpF19e+pWv7Qi5YAo5WAUXJD7MEJg/txSSZCKHgNDEB2IuOJU2xDPFEUhaeffpr33nuP5cuX06dPnzbbDx48mN27d1NcXHzpddtttzFr1iyKi4spKioyZJxJqwCoTwLUuR+EV45ftretmQoEuqJx+ozsV0RNVewZRxxOJ+76+MW9SJIUtRLQkgVAsphbbW+BOLkAISwAScTIYcPIys1lwWLjlIA5c+dy4vhxdu7TN2sPgMPh4O133uWWW28lEAhwx9338MGH+lT2bcSWmceDjzzG2+8vwFffeuIC2dz6/GyLoZLD8JgAaHA78hHhmMH9GJ23f5jkYE8SZgR66qmn+Pe//82rr75KamoqpaWllJaWNssE98gjj1xyIbLb7QwfPrzZKyMjg9TUVIYPH47VajVknEmrAID6E/1YM4kkEpfqABic2UQg0BOtCnheYXe27NH/ZLI1XKku6qLMfNSoADRd/FsrNAQNFoBgHKyRIUXB1AEKQDJYWhOVEUOHkluQz4eLlxrWx6zrrud86Tm27tS/KrHNZuONN97krrvvJhgMcs/9D/D2O+/q2ofZbOaBhx/l3Q8X4q3Tv+DZsItKgJEpQgEGSw5CKBwzMJhWliRyJLNhGXtMkoRC8q0Jf/zjH6mpqWHmzJkUFhZeer3xxhuX2pSUlHDunP7B9WpIWgVAdSXgTn4SduX3DZRVdtBIBILY0KIEDOzdk/KyUh1H0zYZGZmcvVAeVVu7rUEB8AcubwiCFdWtto9vEHD8CaJg7eQW11hYvXlHXPoZNngwBYXd+GDREsP6mDbjWurqatm4Vf/sXxaLhX//+z88+OBDhEIhHvjUp3n1tdYDKGOhUQmY/9Ei3DXVV30erKnXVBtomOSghjCnDPbVHyjZCaIYGoBsdMaePpKNExgf0xBPFEVp8fXYY49darNy5UpefvnlVmW8/PLLzJ8/39BxJq0CAOoLlKq2GCRY+6bXmNNcYErqn1eQQEiSpDnXtpZTIKvVSiiK4D69yMzMpLqqOqq2thbSgJpSU6AVNyD54qlYPOgI10cvERzJ/ehpEZvdwd/++R+27jUmoK8pQwYNpFv3HsxfqK8ffVMmXTOZUDjE6g0bdZdtNpv5+z/+wSOPPEokEuHhxx7n5Vde0bUPk8nEAw8/yoeLllBX1TwBgeywgVWbetxQJ8DYisEAgy7GHhiZtrOPZOO4QUpGnmShvJNlA0oWknYVVm0BiOFBaHQfatpf2dZ98DgYUPxEIGiJ9MxsNm3T3yUgHsQy99PS06mtrYmqbWOmCL//8ima59AJCHfN+dlVFYBhA/px3733cfrkMT78ZIXh/Q0eOIAePXvx3keLDOtj7Ljx2Kw2lq3WPw2pyWTiLy+9xJNPfg5FUXjiyf/ipb/9Tdc+ZFnmgYcf5aNPllJbedlq7jl2GkLa5+dwyUmlEjJ0cw4NFodSJUiNQXUCCiVrXNKPCuJLcq/CXbgOQKjeo94EIhDEyPjh/am4ED8XHD0xmc1RpQZsisPhaJbVpy1aLATm83dZBd2Lgj3JHz1tcd3MmWRl5/La2/MN72vwgP4U9erNews+NqyPEaNGkZGRycdL9I87kGWZ3//hDzz11NMoisJ/ff4p/vDHP+nahyRJPPDwoyxatpzqiga3PiUYAhWFw9pipOykXAlxzmAlYJycwk7Fa1j80CDJzgGDAnZzhBWgQ0jeVVh9GiBjxhEnrjzFtOZnd9BIBF2R9PQM6mPIp9+UlNQ0alvwxzWazKxsKivUZSBSkwXosgXgcmEdS06mukEmEb4uagFoysghgxg0fBQv//t1wwMgBw/oT88+fQ21BAwZOpQeRUV8sFB/RUOSJH75q1/xla98BYAvPvNlfvWb3+rex32feoSlK1dTeaEMS2aarvJHyU5KlaBhwbSNTJFcbFKMyYaWJZmpUsKG3K+9sHIyDrUNBM3p2qtwEmMvzO3oIQi6EHr4kucXdkwtgKycHA6ePGOY/KbFYhotDV15fvqUCLZOnnRBDwb07MHYydP5+yuvGq4EDOrfj569+xhqCejXfwADBw/mnfc/0F22JEn8709+yje/9S0AvvaNb/LTn/9C9z7uefDTrFy7njpJf1eaMXIKp5SAoSfdZklioGRnv0En9YMlOwfRPyA4nnFPgssktQKgPujWaPnxCAJu+K8UYx5jgaCjGDWgF9WV0WXW0ZPu+XlUVhjXb1MFwO9vcAOSZFlz7YTOSoSG9H8C6FOYx8Tps+JiCRjUv5/hloCePXsxZuw4Xn/7Hd2/jyRJ/PCHP+I73/0uAM9++7/50Y9f1L2Pu+5/iLUbN1Ej6V+gapycwnHFT5VBvvrQEFTrUyLUG1BgK1MyU5OEhbu6KkmrAHT1IOBQTXQ5ygWCREGrFcFitV7aYKvB6AxCLSkAodr6ThujE1REBWE96V2Qy7jJ03nl1TcN7+uSJcBAJaCgsJCp06bz79ffMEQJeP75F/jBD38IwPPf+z7f+8EPde1HkiRum3c7+yJeQzbqE2QXBxWfoRvp0QYW8OohWQ1PbyqID0mrAEB8TtwTjcbvICwAgs6IljmYk1fA9v3HdByNPsiyjPnifLxkATCbO60FwE8EmzjB15U+3fIZOf4a/v2GvkWvWiIeSkB2Tg7X3zCXV/7zqub0wC3x7LPP8eL//i8AP/jR//Cd51/QVwkwm5gsp3JI8VFpgBJwjexij+LBbZASIF10BTpkQP7+7pLVkIBmKxIBpWsmRugoklYBUFvYqyPyYevJleO3F+QgpTg6aDQCQfwZ2LsorsXA1KwZTQOBAaxZ6chpLkPGZTT+Lp7Fxyj6F3Vj4NARvPneAsP7GtS/H0W9ehtaJyA9PZ15t9zKK/95lZABlem/9rWv87Of/RyAF3/yU5799nd0UwLMqSmYs9OZJLs4rPioMEAJmCK52Kq48Rm06c2TLFQpIUIGHGxakfDrPO5syUwFxrlGCa4myVdx1aXADBlFPGm6ACoh4asn6GRoeFi5UtPw1BuTAaMl1Gw2rFYrAH7/5ZMzRac0g/HGTwRrZzVfJDhD+vWme8/ezF9oXBXfRgYP6E+Pop68//EnhvXhcrm49Y47+derr6lOtRsNz3z5y/zqV78G4Ge/+AXfePY5/SwBF+t0TJJdHDVACZAkielSKhuUesNSd46VnOxQ3LrLHSY52KdzoHE2QgGIN0mrAMQjBiCRaHH8QTGZBPHDarfj9Wr0O+2geWh0DFCjBSAQaKIA+DqnH62wABjLyCGDcKWls2jlesP7GjxwAIXduvPhYv1z+DficDi46977+Nerr1FRp/9m9Kmnn+a3v/0dAL/81a/56je+qYsSEHZf3uBOvKgE6O0OJF9UAtYpdUQMUAIskowNWfeAYIskE9L5wNQuyfiTwA27M5HUq3hXjgEAumyhIUHHkJmVo7kasDPFRV2UFXY7mpgsAIEmQcqd1EInLADGM2nsGMKhEKs2FRve19DBg8jNz+ejT5YZ1ofFYuGe+x/gg/fe5YIBCSr+3+c/zx/+8H8A/Oa3v+OZr35N8/NcueIAbaLs4oji0z0w2CxJXCO5WG9Q/v4RkoPdBqQFlZEIJ8GeqSuTtAqAsADQ6YubCToX44b2pbrigiYZed2K2LBjX8zXx1OJV7NmWC9aAJq5Qcidc/n1K8ICEA9mTJlM2bkzbNlzxPC+hg8ZQmZODh8vW2lYH2azmXvuf4CPPnifsmptRQNb4snPfY4//enPSJLE7//wf3zxy1/Rth6Yrr7HJ17K4KOvEmCXZIZLDrZF9LeQSJJElmTS3YWpr2TjOOqzriUiVpcda6qj9ZfL3tFDNISkXsWNzuufiDR+h0go1OICJhAYhTMlBZ9X20nT6AG9NCsRsRBbzY3or7FYLMDlIGAlEkEym1T3mQiEUDCLw4W4cOMNN7Bv5zb2Hjc+uH3ksGGkZ2SyaPkqw/owmUzcc/8DfLzgQ0orq3WX/5knnuDPf/4LkiTxf3/8E08/8+WY57ZsaTmT3jWyi72Klzqd3WoyJDN5koXDBmTuGSQ5dM8IlCmZqRY1ATo1ybtDVPl8SjYLQLCqttO6GAg6MRqnkSzLHaKIGx0DYLU0uAAFL7oVhOo9KAHjag8Ikoc777iT9SuXGJJJ50pGDh+GM8XFktXrDOtDlmXuvu9+Fn+8kHMVVbrLf+zxx3nppb8iSRJ//NOfeepLz6hORRrxB4j4Wj/dniy52Kl48Oi8AS6SrLiVsCH1BzIkk+5yO/euSZC8CgCQDFl91NK4ebJmZ4Aspqcgzugw5TpCATDeAtBwmtjoAmROTWnTQtf18pcJWkOSJK694ea4VAsGGDt6FBazheXrNhrWhyzL3HPf/SxZvIizFyp0l//Io4/y0l//hiRJ/OnPf1GtBJjsNmijlo4kSUyVXGwxII3naDmFXYpH96DgwRhTF0DQeUlaBaCzn+ir5crvK8kyqeOHddBoOiFCWUoYtMxdk9kcU7pBWZYJG5iWs9EFqHFskiSROXVsq+3V/gWS/u7tYuv5lRRmpjJu8nRef/eDuPQ3ftxYIpEIqzZuNawPSZK4+977WLZ0CWfKynWX/8gjj/DXv/0dSZL4819eUq0E5F43pc3PJUli2sU0nnrn2p8gudimc/pOSZIwIxE0ou5AF5+fnZWkLhebDD79amn6nSe+/Qc2XPcInuOnMGekM+L3zyOZZPZ/46cEqmuxYMLqyEQJK5jsFsxOB6a0FOr2HyPi9QESSBKpIwfS/2uPcubfb5BHCvUHTyDbbZhTU3D07kbq4D6cm78Cz8kzWFKdpA7rhzkthYJANYOvmUb56q1UbSgmXOtGNpuwD+hFpKYea2EOAN5jp5FMJkz1QNgOoRCEQkhpLlKGDkBOcWB22PGfOU+ovBJrbjaFT97H7l/9H3JpPZaCXNLmTMW37yjurbuJBIKYnDYcwwbS/fmnqV+1mZplG7AP7I3rmrFULlhC8HwloQuVKB4fjqH9yXn4DiyZ6bgPHuPCn14lcKYMyWbBdc1o0mZdg//AcWrXbiEcCBKpqUPxB0CSkB12ImYzks/f4NdtMWMtKsQxpB+hqhoCx04juxwEzl2AQIjUScNh8dGOuTk6CVrmbVZOLsUHTzJheH9V16W4XNTV1ZGRkRH1NWrG2VgJuKlyMu71X7Nh9iO4j5zAnJbKsN9+B4srhb1f+TFy6Ums6dkgySiRCLLNitlpx5TaMD8V3+X5mTK0H32m9aevOZP6IyUX56cVs8uBo6iQ1OEDKJ2/HPeJM5hdDlKHD8CamsLpQBVDpkynYs02KtfvIFRTj2wy4RjUi1B1Hba8HDDLeI+eQjKZQIJAbT14vA0PfFcKrmEDMLmcmOxWAufKCJZVYc7JpMcT91D+8Wqq12zFmp9N5g3T8B4+Se3GYqj3Iael4xzan+7ffYr6jcXUfLIGe79epE4fT8X7SwmeryBUXolS78ExpD85n74dS24W7gPHuPDS6wRKziFZLTgnjiDjuin4j5RQu3oLYb+fcE09+P0Nfx67A6xm8PovxV1YezTMz3CdG/+Rk0gpDkLny1H8AVzjh8LSxJyf/Yu6UVdTzcJla7jpuumG93fNxImsW7+edVuLmTp+tCF9SJLEXffcy3vvvM3MWbPpkZ+rq/yHH34YSZJ44jOP8+e/vATA//3ut1EdMoz+50/YcN2j1B84gjnVxdBfPIu1MJe9T/+AQHk1JocNJJnZ4SzWBKuZk9sTS1oqdQePoXga7j8kCdegPgz4789RV3yA+oPHqdt3FNluw+JyYutZSPrYoZx7+xPqj5ZgdjlJG94fS1oakj1AercCHIfOU75yC6HqWiRJJmVoH0JVdVgLszFbbdQfPA6yCUmWCNTUowSDEAwhp6aQPmYwpjQXFrsd7+lSxp84zX5riHu/81UuLF5H+ZINWHIzKbh1JvVHTlG1ZgthXxCTw4ZrWD8G/89XqN26m9L5y3D26UH23Kmce3sx/rPl+C9U4jx/GtuwkfR5/G7s3fOp33eU0y+9ge/4aSSrGdf4EeTeMB3f8VNUrtxE0OsjUluPctG9yuRwELGawBeEcBgiAaz9+uAc3J+I24Pv8Alkp51gWSWK149r1EBYnZjzszOStApAV7cAANhyMpm588Or3i+4eRYAygfvcd3cG6Luo5vnPKPn3tTiZ72fuOuq9068/iYFN8+i4NZZUck//+obTLr9ajmtkX7LTIbee0+77TJvmU3mLbMv/ds1Zkirba3d88mcPfnqD+ZMo+CLD0c9ttaoq6+Hxf/SLEfQMv179uDA0eOAWgUgFXd9vSoFQM0a02gBaOrHbc1I49rt869qm7d3IX6Vc3PhO2/Rv5W5CdD7M3de9d7x198k/+aZ5N8yM+p+AKqinKcZE0e1+P7x199sNm8zb5xB5o0zLv07ZeTgVmVau+WROfuaqz+4AQq+8Kl2x9QedfX1sPRVzXKMYszwoaxYs4Z12/cydazxFt6pU6awavVqNu/cy8RRxvQnSRJ33n0P77/3LtNnXEtRQZ6u8j/96U8DXFICZFnm97/5dbvz15KawozNb1/1ft7uj656b3rZGT76ZCn33nN3q3ILbpzWal99nrz6OTYKeOuVf3LX//tmm+NUS92/XyV7yhiyp4yB7z/dbnv7jdPJu/Gywpk5+vLz07x0JRazmfRxwwGwFeSS3dL8BIo+/1C7fZ18/U0GtvFMr6uvh5lvtitHEB1J6wIEwgIgEHRGbHYHHk9s5u+MzCxqqipVX5ficnHyvP6+yI20ZAFoi3jUMIl1rdCcX12sUZqYNX06Rw/ui0tmIIBrZ8zg7JnT7Nh/2LA+JEni9jvvYs3qVZScO6+7/E9/+tOX3IH++Kc/61InoCmuvO5cd+10FixYqJtMgCnjx7B29QpdZWampVJ27JAusvqMG0VlnX4pXcXaEF+SVgGQkt8rthldzeIhSFAk7Yt4XmF3NmzfG9O1siyrzvgBkJORplrpUDPnzI0WgHB0WTjiUcck1jVD61oj1irt3HHb7axb8UlM93osXH/ddRw+sJ89R04a1kejErB2zWpOntVfuXn44Yf5y19eulQn4BvPPqfrhjOnqC8jhw1h5cqVusnsPnQkFdXVusYnzbj5JnbsP6iLrPTUVOrc+sUqiLUhviStAiAQCOKPKzVNcyXfMYP6UnmhTKcRRYczxYXX4zFMfqMFwMhA43ghTuk6HkmSmDZ7Lv9549249XnTTTdRvG0zh06dM6yPRiVgw/p1higBjz72GH/8458A+OWvfs13nn9BV/m9h4wgMz2DnTuKdZM5e8o1LFv2iW7yTCYTEZ0Cgc1mM+E4KaEC/UluBaALPqjEw1nQkaRnZrNlR2yn942YzWbCUZ6U64XVasXvU5ciT81cM5kain6FoqzNEY953FFrhVij9KEoL4u+Awez4JOVcevz9tvvYN3KFZws0z9/fyOSJHHbHXeyft1aTpzRX9n4zBNP8Jvf/BaAF3/yU178yU91lT/6mqmUV1ZSeuaMLvIyevfHHwgk7OGBnvNZrA3xJWkVgK5mSupqLk+CxGTskD7UVBnnSx8NsbrDGLlmqLUAqB1LLA/OjnABUhSly63NRjJyyCDCkTAbivfHpT9Jkrj7nntY+vGCmNLtqsFIS8Dnv/AF/vcnPwHgv7/7PL//vz/qKv/6m25l9foNuhVvu3bSBFavWq6LLACHzY5HY9X2RvScz2JtiC9JqwBADMVxDA68S7TAvkQbfzz+PgJjsdlsBAKtV9BMZIy8n0xyowUgug1Boq0VelwHEAyFMF+0hgj0YfaMGRzau4uDp/XPpd8Ssiwz99Y7+Ndrbxi+Bt9+512sX7fWkMDgr371a/z3d74DwJe+/BX+9e//6Cr/9ptu5MMFV2cMioXMPgOo19FFcVDvXuzbsUUXWcIC0HlJXgUgFk3S4MA7I9vHIwiws7cXxIfO+rsYef81ugAZZQHoLEHAgUAAq8Ua8/WClrn9tttZveTjuG2gMlIczJwzl/+8eXWaTL257Y47WbtmNadK9Y8Lev75F/jiF78EwGee/BwffLhAN9n2rHwGD+jPruKdusgb1LcP+/fs0EVWzzGjKa+s1kWWnnTWZ0dnJXkVALqmNtkVv7Mgsejoe7Cj0lu2hSw3LLXRKgBqxxLLg7Mj/k4+vx/rxYxIAv0wmUyMnzKDt+brc+IcDXlZmYweN5F3P9Q39eWVNAYGr1q5grMX9HUvlCSJn/3853z60w8TDoe5/6FPsXbdOt3kDx07keMlJQQCAc2yhkyczNETp3QYVeJutDv62dHVSFoFIFFvcKPoat9XkNzIsinmoLdYU4EaOYfUWgDiQYdYAIIBrOakrT/ZofQv6kZmdg7L12+LW5+9i7pT2KMHn6xcY2g/jcXCli75hFKdT65lWeYvL73ETTffjN/v59Y77mLPHm2JDJpy0+13sXjxEl1kSZKk2yZZr/VOxABczerVq7n11lvp1q0bkiQxf/78Ntu/++67zJkzh9zcXNLS0pg8eTKLFy82fJxJqwAA6rMAJZjPuogB0Le9IE7o8LNk5eSxeVdsxWrSMjKpjqEYmJH3n9EKQGeJASjZdwiLUAAM45rx4zh/9hS7juqTgSYaRgwdiiRJbNixy9B+JEnirnvuZdFHCyivrddVttls5tVXX2Py5MnU1NQw75ZbOaNTFh+r1UpGehrnz57VLGv4oAHs1sl3Xy9EDMDVuN1uRo0axR/+8Ieo2q9evZo5c+awcOFCtm3bxqxZs7j11lvZsUMfl6/WULUSv/JqGcOGhrGYJY6VBBg+1InDJnG8xE/QH0E2S4TDMKi/nZraIOfOh3C7w4wb5aKoyMaOnW4OHfUiS9Cnlx2LOcKJUyGGDbZht5uprArjD4Q4dMRPv942+vZxcPioD38gQmG+lWA4woEDPnz+CDOmpjFkoIPzZSEiikIoFKa2LkJOtpnjJwL06KYQiUTYtbuGteuq8PrC9OrpIDPLTEGenfw8Gw6Hif0H6pEkyM4ysWNrLSbpNC6XGbMZhgxOp0cPB3V1ITZvqcDrjdC9u53Sc16On/RSerYKp+0skYjC4EEuLBaJuvowp0952HewnowMC4oSwW41k59nZd/+Wt6RTnPqtIfcbDvZORYG9nNx4UKAC+V+irrbcTrNnDjl5dRpN2Gvm7q6IOWVAWrrg4TDsHtfNZIEE8ZkMXhA6iWNWcQACP75ahlDBodw2GWOHg8wbIgDp1PmZIkfrzeC1SYTCCgMGmCntjbE+QshaurDjB2RQp+eNor3uDlwyIsE9Oltx2ZVOH4yyJCBNlJSLJRXhggGwxw87KNvLxv9+jk4esyH1xOmoNBGONIwP3ft8jB0WA0jhqdRVhYgFFaIhMNU14TJzbVw7JiP3r0dDXPiQB1r1lbh8TTMz+xsMwUFDopye7D70D42h/JBUcjNtbBpUzUmk4Qr1YzFIjFoYDpFRQ7q3SG2bKnA4w7TrYedffsifPLxZkYOH0pWtrVhfg5IxWqTqK0NcfaMj70HaklLNyMBFotMfr6NA/tqmG86zfGTbnKzbWRn2xrmZ2WQCxd89Ophx2Y3cfqsj5MlboKehvlZUR2gpiZIBNi1txoJGDsyg2GD0y/do40KQLSWiUSOAdBCMBQib8jAuPebCPz5peMMH5aLy2Xl4OE6hg9LJy3VxLHjHtyeMDaLhD+gMGxYKrU1Qc6VeqmqDjN+bAb9+7vYUVzNnj01gETfvim4XDKHDtczbGg6aakWysr8hEIRjh8byOYN7/GFzz/C4cP11NaF6N7NCZJC8a5qamtDzJmdx8QJ2Zwr9REIhFEiChWVAbp1t3Fgv5t+/VLo3s3B7j01fLL8PHW1Qfr2TiEv30b3bk7y8+ykp1ko3l1DJByhIG8of/3r+6xY4WZA3x5YLBLDh6TTv28qdfUh1qwvo7o6RP++Tk6f87H/YB3ZmVZycqxEwgqDBqaRmmKiojrIuXNedu6pIS3VgkkCs0WmMN+KM8WC1xvmVMUYvvXcS9x8092MGJJJZVWQM6Ve+vR0YLeZOHvex6Gj9Uwak0H/fmlUVwepqgkSiUTYvb8GJQKjR2QwYkg6snx5DjidTt6b/z4zpk/j0KFD3HrHnaxesRyXy6X5t59+/Vzee/M17rzjdk1y+o4ex4dvvs5IzSPSD2EBuJp58+Yxb968qNv/+te/bvbvH//4x7z//vt8+OGHjBkzRufRXUaVArDngJ8DRy8X+dm8reWo9KUr65r9e+PWq9NNbdt5Oef2hi1Xy9m9zw+0XmJ638ELbY41EvZTV1VPes7pS+8dPdZ2nu+qMi8VVU3ltp2DuKqsjrOlp9ts07x9GZu2lahof4r5Sza1+Nk/Xj/NjbPz+NYXmz9Mk0WDFqhn7wE/B49enjObt7c8P5etaj4/N7cw/7bvUjs/L5/IVZWF+dNL0c+LRo4dbz4/q8qOkZmX08YVLc/PcChMfc1Zzpxt69qrqSorY9N2dfPzg6Wtz89Z03J4/muDgdgsAGpSZsbTAqCFYCjUZWMAdu+uY/+Bywrg+vXVLbZb/EnzZ9v69Vfn3N+y9fJzeM2aq+WEQsP5wuf/Tlb+lBb72LW7Djja/qCbcOhwe2kjB7Fl83Ky8qcgm2yqZKslEh7F89//BzndZrc6R958v43n9xunmToxix89N7TZ21lZWXy44COmTZ1M8c5dPPr4E7z1xmuXYnhiRZIkCvPzKT1zhoLu3TXJ0gu95n9XsgDU1jbfk9psNmw2/e/1SCRCXV0dWVlZustuShK7ACWHJtkWi5aXEYk0TJhk0ZwFyYBefqqxyZBNDiLhWHJc6zuHVqwtJxhs2PA1biCitQCYTOpiIDqLBSAUDmMxd00FIJ6YzU7szu7U18TmRhcr2QXTqShdY/hGTjZZycyfTGVp7LEH6zZX4vFenZa3T58+vPvufKwWC++9/z4//t+faBnqJa65djZbthdrlpNovvt6ryMdoQSYUpyYXCmtv1KcABQVFZGenn7p9eKLLxoynp///OfU19dz3333GSK/kSRWAHRxRU54vL7mm4RE16AFyY/J7CQc0i9ntVpifyDpP3caNxgmk7osQCaTrKqIUGexAITCIUxmUQcgHjhTexEK1BLwG1e190ok2Uxm7iSqyjYY3pfZ7CQ1cxhVF2L3ia+rb7mY2aRrruG3v/s9AC98/wesXLUq5j4akSQJs9mkuYBaYV4uZ04c1jyeRLQAmE1mgjoVTzOCU6dOUVNTc+n13HPP6d7Hq6++yve//33efPNN8vLydJfflORVALrIiXhFZUPRJWEBECQKFlsmwThuOhKZ8xca5mejBSDaZ6XZZDbUAqClIq+WtSYUCosg4DiSkTuemvLtKIr6rFixYram4kgpoq5qn+F9We3Z2Bx51FUfiOn60rLWixZ+5oknePzxz6AoCo8+/gQ1NTWtto2WaddMYp3GNKNDJ07m8PGTmseSiBYAq8WiS8pUo0hLS2v20tv95/XXX+ezn/0sb775Jtdff72uslsieRUAoCvYAMrKmy9gwgIg6GistkyCAfVZeK6m8yu1jRuMS3UAItFaAEyEQuriBdQQ0lCRV8saE46EkWVhAYgnWQVTqTyvX277aHC4ilCUED5P23F0euB09UKJBPG51WfZOVvatqXyF7/8JX379uXU6dN85evfiHWIl0gr6EF9vVuTDIfDgdfXdjxjNJhkdVbG1tBzz2G1WAgEE1cBMJLXXnuNxx9/nNdee42bb745Ln0msQLQ+TcP0dCrhwMQFgBB4tDgAqT9ARV/9J9DvXs2zE9ZZRYgo2MAAsEgVmtsvviaLADhSMyKhyA2TCY7TlefmE/JYyUtayTumiOEw8avBWlZI3DXHlXdV6+eKW1+7nK5+Mc/XkaSJF7+5yus36DdtclisWjeeOvxvE9NcVLn1qaM6I3VbNHsIpUI1NfXU1xcTHFxMQDHjx+nuLiYkpKGJBPPPfccjzzyyKX2r776Ko888gi/+MUvmDRpEqWlpZSWlupidWqLJFYAugZZmcZmWxAIYiPx/Es7gsK85gp69ApAbMXMoiUQ6JiCXIoS0ZxRRaAeh6sH4ZCbgF8Py1z0ZBVMobJ0XVzmcWNfaujXs/0Un5OnTOHRRx8D4Mtf/Zrm7zJ+zCi2btmqSYY+CkAKVadOaJaj5+GjxWwmkAQKwNatWxkzZsylFJ5f/epXGTNmDM8//zwA586du6QMAPzlL38hFArx1FNPUVhYeOn1zDPPGDrOJF+JO/fmIRoOHW1eEKWzb5gEgkbMlhTCIX0L/rSN/nNn9/6GtHGXXICiDgI2Re0uBOrnvT8QwBJjOk6ta4ywVnYMGTnjqKkojms8gCSZyMidQFVZy+lyde8rZxzV5dFXQt66szqqdj/80Y9wOp1s3badDxd8FOMIG8gp6ktVdXT9toYez/m8wYOo1cECoOeeo/vgflQeUpeeNhGZOXMmiqJc9Xr55ZcBePnll1m5cuWl9itXrmyzvVEkrQLQVR4xXm/DJkE8VAWJhfb70WLL0nBiGUv/+s8ht6cxC1CD20u0D0uTbLALUCCIrQNcgLryOlVZtoFQsK79hgaSlT+FyvPr49qnxZqGzZGHu/aI8X3ZMpBlGz5PaVTtW8sCdCX5+fl84amnAPjh//w4KQ7aUl0u6t3as7XpbQEIGlQtXXA1SasAANGn3OjE9O3d3IcxGRYmQTKg/T602LII+mJVAGLpX/+5M2RgKhCLBUAmHI7+pFbtvK85fgxrjPn4xRoTG5m511BbuQev+0yHjcFksuNw9Yx7fYCUtL4EfBUEA60X99SLtKzh1FcfiOo+HTEkLWq5X/nKV7Hb7Wzbvp0NGzdqGWJCkOJ04vbGUi+lOXquByaV2c8E2kheBaCLnDRlpFuBrn2yJkhOTCYbkUisGSESwwKQk9UQo9M4P6O2ABgcBOwPBHHmd1N1DWhLH9rVkSSJrPzJBP0V1Ndoz+MeK05XT4KBGoIBYwMMryQjdyLV5VvjokBm5I6nurx9P/uCPHvUMnNzc7n33obCTH/9299jHhtAWmrqVVVl1WAxmzWny5RlWZffQpb1i1eSZb2KSAqiIXkVgC6C3y8KgQkEVxMfC0B7862xEJj6IGB1CoDaeR8IBWOKAQgGg1hMIo+/FtKyRqJEQnjqTnTYGDJyxlN9IT6b8UYkSSIzdyLVFzYb3pfZ4kKWzO0qOW6PutPmxz/zOADvvDdf0wZ8YP++HDp4MObrc7IyqahKjFordqsVjw5pSQFkSSYi9jBxI4kVgK5xSnXsZEMQjziVEwiaIMkxBDuqnENRzLkDhxt8vi8XAovSApCSTkRFPmy18z8YDGGzWlVdAxfTh8YYPCy4TGrmEAL+qqh91fVGkiQy8ybFJTi3KWaLC4stE2/9KcP7SsseTW3Frjbb7D6g7hR+ypSp5ObmUldXx5q1a2MeW27PfpRXxJ6RKSsjnYpz2v+GeuwbUuwOPF59Kr8rKF1k55YYJLEC0HAzJTsWS/PpIiwAgkRAlq2Ew61X2TQak8lBOKTWv1X/uWO1NiyxRrsAqbYABIMxVeQNBIOYzSKPvx5k5IzBXXuEULBjcrGbLS6s9mw8ddqryqrBlT4QT91xlIj2IlRtIUkS9pTueN2nW21jManbbsqyzLx5NwGwZOlyTWPTQl7/wVRozCQE+uwXnHY7Vcf0CfAWLobxJYkVgK5xE3n9DaecYtIIEgmLLZNQoLrD+m8oRqb2VEr/OVRb39wFKNoHrlq/2lgsALGc5AeDwQ6pH5CsZOVPpapsQ1xTczbFlT4Ar/tU3JX1zLxJVMbB+pCS1rdNBaemTr0SMmXKFAC2buu4XP4OhwOfPzEq5hYOG4zHp8/9o6VCuUA9SawA0CWyADlszSeLsAAIEgGLLZOAv+N8VE1mB+GwWgVA/7iBFEfD/IwtBsC4TWE4ErmUmlQNwVAIs1AAdKMhMDj+qTmbkpU/marz2ivcqkE22bA58to8ndcLu7MQn/tsi581zk81jBk7FoDi4p2axqXlWS1JiRMs63Q68OoUA3B6/xHMIsYobiStAtBVTsT792moZNhVvq+gc2C2pHZoznOTORYXIHVIUVgMRg3LaGircn6aTCZDKwFDbGvGhQNHYk4fKmgZk9mJ09WbuuoDHdK/JJlwZQyirmpvXPt1pQ/AXXvU8I1sSlpfPPUnWvxsysRs1fL69esHQGVVFW4NhbSS5Zltt9nwq4hXagt/MEDO4P66yBK0T9IqAA0YrSGrla9/e38g9ixAahfezt5eED8kSYYOcmuAhhiASAwKgN73VP3FQkOXHvYqXICMrAQc6/cMhoK4inrFdK2WfpMdh6sH4ZBbQ+E7bdidhYSC7rgr7enZo6itKDa8H0m2EGnBzelCuXrXlbS0NFyuhoO306djr+mQLHPBZrXiD0ZXUK09AsEgNqtNF1mC9klyBcBoDVutfP3bl1c2aN6xnCaovaaztxd0RmIzdUuylUhE3UNJkkyAvkpLWXnz+akmBkDN947X3AmFwjGlD73cr345w5ONjJxx1JTv6LB4gIzcCVRf2BbXPi3WDMJhX4ubcz1JyxpBbdWeq94vi0EBAEhPTwfA7encFgA9xqDn9/D6faQ4HbrJE7RNkisAyU+qq7m/XLKcKgiSAe0PBpPZTiSs/iS/4aGkci5IJhQVp+4NtN1HWlps81OWZUMrYsa6TgRCoZiyBzViUmnZ6Gpk5k+Oe2rORiRJIjVzSNxdgTJyJ1BdbqziYTLZiYSvdlPJzIhNmbXZGk6p/f6Oy3SmB4m2X/D6A9ht0RdnE2hDKACdHOXiJiERThMEAr1piCWoj/FqtafiMorOFoBQKLb52WAB0HUozYjZAhCOLXtQI7IkdYXcDDFjNjux2nPikie/JWyOfIKBWsJhfYI6o0GWzcgmB6GAse5HkmRCUZornx5vbK4rjVasWALpE4nE2zcol2qmxBPJltLuKxlJcgUg+WMAtu5qXulQxAAIEgftv4/JkkooqK5YT6z9SzFZANpm7cbYfLrVWgDiNXcCGrMASbJExEDLRjLgSh+Au+4YEYPz5LdGZt5EqsuMr9bblPTs0dRUFhvahyt9IPXVh5q9t3pjRUyyvN4Gq6QWf3Xx/Loa8TeJL0muACR/DEDdFXnGVUlPMB99EQOQbGj/feJtAdA7cNnji21+SpJkaB2AWOdOOBzW7AIU6cDg8M5CVt5kqi/EdxPeiCSZsKf0wFNfEsc+JSzWDENTB1tsGVcdJng9sSmjNTUNB29paamaxxUryfj8S8bvlMgkuQKQ/NisndsEKRC0hclka9F31xAkGQV9T6edMeQZB/VBwPEiFA5rcnuQJNnQ+gbJgmyyYrFl4fOUdkj/KWl98dQei+s9mJo5nLrKqwN1jcSVot6dzePx4LuY9z47W30aUb1IxPVBK8n4nRIZoQA0o/Npn+NHZzT7t5hAgkRCn/sxVhlqXYBk9RlY2vl+14zLUifvIrLBJ+Wx/i6Komg6pTOprHDclUnNGIy75lD7DQ0iPWcMNXFI0dmIJEmYrekEAzXtN9aJaZPUb+DLysoAsFqtpKZ2nAVAj7VVr/2C2Hd0ToQC0MmRpYafUJjOBImG2eIiHIrVfacpsd7bsbgAqXiQRTHnTKbYlthEqvTZFK3rjNr6Bl0dV8YQ6qr2dUjfFms6kTik6GxKWtYIait3x60/s1n9/Cw9dw6AboWFmuaD1rmUKCk8Q6EQ5k4eDN1VEQpAJ6fe0zyLQSJuGgRdE4stUyef3vhYAEC+KkuIVurqGuSpnZeyLBOJGBfQHyta+zHJwgVIDTZHLgF/RYfWBqi6sDVu/UmShCxbjXP7k5rP8epa9f2cPtNQ/Ktbt0JNQ0mEZ7UeY/D4fNhF8a5OiVAAOjluj0gDKkhMLNYMQoHqDhxBDBYAnTOH1V2hoEc7T9VaAOIVBKyHBSAiLACqSM+OrytOU2TZjNniIhjHeZyePYrayl2GyDaZHISbWDRq69RnWjpz+jQART2KYh5HWGMsDSTOM9/tduNy6FO8K1G+U1dBKACdHJPcfMIkwqmCQABgMjsIh9QX8dIPtYXAYogBaAfLRRcgtfPSaBcgLTEAWjDJJkIiDagqGlzpvB1mBUjLGhlXtxzZZCMSMcYCIJuszVyabDb1m/BTpxqyI/Uo6hHzOMpOHiUnO7b4oEZ0iQHQ4cDj9O59uJxOzXJA7F/ijVAAOjndChqq5gnNWZCY6HFfxikGAJUxAFHQo1vzqpZGWQDU0lEWALNJFnUAYiA9ezQ1FTs7pG9JkrDac/F7y+LWp9WWTcAXW47+tlAiYSTp8qa/qJv6qrMnSxoUgN69esU8jtNnz1LUM/br9SASiVyKIdRCVW0dhUOG6TAisY+JN0IB6OScPtv8hFVo0ILEovNkAUJC91PWEyc9DSOJYV4mowVAlmUqjxzXJKMrYrakEA55Omx9T80YTH31wbj1l5I+kPqaw7rLjUSCyPLl1J9Hj7tVyzh54iQAvXr2jHkc5RWVZGuwAEQiEUwaK+Ye3bqVghztaUzrvR5ShAWgUyIUgE5OzcUgJqE5C5KXOFoAdI4BqLo4Py892FRYAIykoywA3Qf1F2lAYyQ1cwj11R2TEQjA5iyIW10Co+7/SNiHbLp86l9Zoz7D0fHjxwDo07u3prFo+Y7nDuwhV6ML0fHTZxkwcowmGY3o9XuJfUx8EQpAJ+dCRXNfSaFBCxILPRb0eFkAJBT03ZyWV16hAEQ9lCSNATDJhIULUExYbVkE/NUd1r8rfQDu2iMd1r9eNN1kllcE22h5NZWVlZeqAPfu3XEuPGfPl1HYs68mGT6/H6dOwbt6IfYv8UUoAJ2cnj0aJrDQnAXJS3wsAA0+QDF21QrdC5ubxtXEABhJR1kATCYzYWEBiBlHSg+89ac7rH+rLcsQ3/yWMFtTCQXrdJbafIIX5qtLX3ns6NGG6woKSElJ0W1UaimrqCQvJ6fD+jeCUCiErNGtSaAO8dfu5PgDzRc0oUELEouOjAFQR8PmVkVfUcy1UChysanSpI/Oi9b1xWwSWYC04Ezthaf+ZIf178oYQl31gbj05Ugpwlt/ytA+1N7NRy4qAP36aTt914rWitygTwYgPalzu3E59IklEESHUAA6OUXdGiZMZ99YCAStE697W6UCEAW9ihrmZ6IpALFu5LVbAGQRA6ARsyWFUFCPCtvqkSQJk8kWl/S+ZosRFoDm9O3lUtX+0KGGQOgBAwbE3KfX68VuT47CWXoeOB7YtpN0V6pu8gTtIxSATk56qrnZv4UFQJBISJIJJaK+2E4zGbLFuMqgV6D3/MnKsMQk1/D2MSo62i0AZkJhbfdDV6chL78xhbKioSElabHh/eitLEcioWYpQAHycqyqZBw6dAiAwYMGxTyOgzu3M7Bfv5iv1wO3x4PTrj4F6pUc2riF3IxMHUYENfV19BozUhdZicIf/vAHevfujd1uZ9KkSWzevLnN9m+99RaDBw/GbrczYsQIFi5caOj4hALQyTl1MQ1oopwsCgRNMVvTCQZrNckwmeyEwz6dRtQWMcyhdubdsZMNaQZjsQAY1RZAitGqot0CYBIxABqRpMbich3zd5RkM6B0usMmT+1RnGnNXXf27Fe3Nu3ftx/QpgCcLS2lsEfsRcT0+LvvXL2GQRqzGAEcPX2aYddM0SwHoM7jJi01eSwAb7zxBl/96ld54YUX2L59O6NGjWLu3LmUlbVcT2P9+vU8+OCDPPHEE+zYsYM77riDO+64gz179hg2RqEAdHK65TfX4jvboixIbizWDIIaM5eYzA4i4XhUFNZ/7vTo1hCkr1YBMHoex7qRFzEAiUFa1oi4Vue9ElfGYOqr93dY/7EQDFRjtTVPnVnULfosOKFQiIMHG+Ifhg8bqmksWhTpM/t3U5CrLQC4vKqagv6xKzGN+AIBHDpYEkCfuIZE4pe//CVPPvkkjz/+OEOHDuVPf/oTTqeTv//97y22/81vfsONN97IN77xDYYMGcIPf/hDxo4dy+9//3vDxigUgE6O3d5g0kyieSNIIiy2DIKBak0yZJMtThaAWB7MbbdPc1ma/duoU/14Kf6aKwGbzSIGQAfMllTCIfVFrPTCasvSPK/bo8HCod+DraU5kp8b/eb1wIEDBAIBUlNd9NJQBVgr+w8fZcjw0ZpkJFoAcGehtra22cvvb7mORCAQYNu2bVx//fWX3pNlmeuvv54NGza0eM2GDRuatQeYO3duq+31QCgAnZySM/E4GY0PwnqRfMiyRXMMgGyyEwmrL9iTCJw4FXsl4GQkmU74OhqbIx+f51yH9S8b7JoXCtZhtqbpIqu10+VjJZ6oZRQXFwMwetQoTekqtc4BfyCAXadT90SiI9eGkGRu9wVQVFREenr6pdeLL77Yorzy8nLC4TD5+fnN3s/Pz6e0tOVieqWlpara64G5/SadGbUP3c7XPs3VPKhJzUYj0QIT1SI2VZ0FrcWjbERi2mgYfP9FId/paJifRrsAxWsu6NGPmLf6kJLWj8rz67E7Czuk/7TM4dRW7iIjd7wh8v3eMmz2XF1ked2nsKd0v+p9hy36jfz2bdsAGD16dMzjqK+vT7jiW7ESCASwmPXbQnaGdeHUqVOkpV1WSm22zp3NKckVAH3N+YnY3udvMKfHoj2rDhw0uL1axGliZ0Hb7ySbbDFmAVLXb4PLgb5GUa83fFG2egXAyCDgWNGjHzFv9URGiYQuBubGuWeTlYhG615bBP1VpKT110WWz32GzLxrrnq/tj768W/Z0pDBZeL42BWePds2M3zo4JivB+3z5/i2beRmac/cs2nJCgb11McVSlE6R1B5WlpaMwWgNXJycjCZTJw/f77Z++fPn6egoKDFawoKClS11wPhAtTJcbmuTAPaQQMRCFpF200pSSYUJR6Bo4o6nSGKyZaW2jwNqFEKQLwQFoDEIi17ZIcGAxt7j+o7B1qSlZlhaaHl1fh8Pnbs2AHANZMmxjyGyqoqsnLzYr6+4uhB0lPV1S64kgPHTjBi/NXKkFouVFdRNHK0ZjkAuzduJTs9QxdZiYDVamXcuHEsW7bs0nuRSIRly5YxefLkFq+ZPHlys/YAS5YsabW9HggFoJNjkhsWtUTcLAgEDXTUvalyo6koSJjab9eMtr+bbGoU3TCWaH2HE1UBEBaAxMJsdhKOS4asljGZnYSCHReMHA2RsB9ZbnmjbzJFdy9u2bKZQCBAQX4+ffvGXgVY672/c/8BRo2JXQEBCISC2Kzq6h8YzbEzpxkzc0ZHD0NXvvrVr/LSSy/xz3/+k/379/P5z38et9vN448/DsAjjzzCc889d6n9M888w6JFi/jFL37BgQMH+N73vsfWrVt5+umnDRtjkrsAdbyPvtHtGxWAS1eIGACBICYUIip1lfbvv8b9fmwWADVjUUesc0dYABIPsyWVYKAWi04Bs2pwuHridZ8iNUObW8uV6FnjoK5qH6mZLaftjDaWd9WqVQBMnzZN0yZe673v9nhxOrXFECTi/PMH/EkX2Hz//fdz4cIFnn/+eUpLSxk9ejSLFi26FOhbUlLS7EBoypQpvPrqq3znO9/h29/+NgMGDGD+/PkMHz7csDEmuQLQ8T76RrevrAmQkmIWMQCCJMf431pRIq2eFLZGe/dgVXWInKzEiwGIde4IC0DikZo5lKqyLWTla3frUIvZ4iIcrNddrqfuBM7U3rrICof9mMzOFj+7UB6ge0HLnzVlxfLlAMyePTPmcYRCIcwag2a1zh29Nv8+vx+bRd1a2RV5+umnWz3BX7ly5VXv3Xvvvdx7770Gj+oywgWok2O64hdMRO1e0NXR456Mw32tRC5VWY2O9h/GJrlh3I2570UMgEBvJMkEdFBVYIPic/zeMmyO/PYbtkN796vV0v4cq6+vZ+PGjQBcN2t2zGPZu20zQwcNjPl6Pdi3bj19ul+dDUkt6z5ewpA+sbtCCRIDoQB0curqGxbfRNwsCASNaN84xscCoPeS2Dg/Y4oB6LDYidYR60xiYrakEQzUxr1fRQlfVEB0l6yLFHftYVzpA1r9vLa+feVl+fLlBINB+vXtS//+/WIey5lz5+jes2fM1587sIecTG3Ze46cOsXgMdrTtta46ykcqo9ryv4txbicKbrIEqhDKACdnCtLmYsKf4JEw2R2Eg5FX3CnZYy/rxs2M/ouib17Oi/KTqwsQCIGILlIzRxCffX+uPcbCtZjsmjLSnMlkUhQtSteawR8lVjt2a1+3r93+xvPjxcuBGDevBt1GVOs7D5wiJE6bN71WFf0nMMHTx5n0pzYLSuC2BEKQCfHbr94+iJO5gQJitmaRiio9XQyHhaAsO751J0O80XZiaUAiBiA5KLBFSf+bkBe92kcLRTY0kJd1V5crQTt6o2tnUJgkUiEBQs+BOCWm+Zp6kvrpjkQDCZE4alQKITJpJ/Vxxfw47AnR3G0zoZQADo5soYsQAJBPDBb0ghpdk+IgwUgEkKS9FUALj0nE0wBiBWxviQukiTHXQkIB+sxW1L1lRnyYG4laFcNnvqTOF1tu9zYrG1vgbZu2cL58+dxuVzMvPbamMdScnAvPbp1i/l6PTi7ezfpLu3WmtULFzOiX+yuUILEQSgAnRyvNwiIUzVB4mK2pBIKac0UEsv9rbYSsP4WgNq6hvl5KQg4yjFFIpGo4wXiiVhnEhdHShFe96mOHoYmGgKK9bnvfe4z2FPa3nSXV7RdYfzd994F4OZ587BqyJ2/e99+ho8cEfP1ehwI7DxwiHFTpmuSAVBVW0u3YSM1y4EGq4ZFY2YkQewk3hNGoIqtO6ub/Vuc0AkSDVk2o0RCGqXEcl+rrVsR0j2gceXa8xdlG2sBiFeNDrG+JC42ZyF+T2lHD0MTdVX7W83Zr57258+iFeda/UxRFOa/Nx+Au+68Q9NIFEXRpNDv27ye/r17aRqDXgXA9FwDli5cxJDeIptQRyEUgE6O19uwsRInc4LERuv9GQcLQET/jCbhSMMYLmcBUmMBSM4YAIExxPu38dSXYNfZ/z8U1Kegmae+BEdKUbvtIkrrf7PiHTs4duwodrudeTfOjXksgUAAi8ac+cdLTtNv0DBNMvRgz5r1dMvJ1U1erdtNr3GjdZMnUIdQADo5hQUieEYg0Au9N1E9ujVmAVInP1FjAASCRnzuMzhSeugmLxz2IZv0CXL1uU/jcLU/tj49W88C9OZbbwJw680349LgO79h5TImT+jY7D1nd+nj/3/gxAlGT489FkKQWAgFoJNjvyKISZjoBYmJ1vvSeBcgI9pbL87PRMsCFCtifRFcRt97obZiJ2lZ2n3L1dyjNmvLcywSifD6a68BcN+992gaT21dHaka8vcriqJ53m3fv5/xOvj/K+h3SLJ7wxYyU7VbewSxIxSATk5ldUMQUyJuFgQC/TDeBcgI+Y1BhmorAasNAo7X/BfrTKITn9/HXXsMZ2ofXWUqSliX/P/u2sOkpLVe/KspZRd8Lb6/Zs1qzpw5Q1paGjdrSP8ZCAQ0BQ8D7Fq3mqED+2uSEQqHNY9j/7pN5GksRNaUfcePMuXGG3STJ1CPUAA6OVU1zYMrxQmdQNCI0XOhfflVNQ0KQLJYAASJTnzWf7+3FLuzUDd57tojOFP1CQb1ey9gc0Tnp15d23Jygn+98i8A7rn7Lux2e8xjWbPsE6ZOmhDz9QAnz5yjd/8hMV8fiUR0WUv2HjvKhJnXaZbTSKJmOutKiPxLnZzxYxo0crFZEAiuRO2c0L/91IkNVUgbLQDRPvAikQiyzlWJBV0B458D4bAPWdaeTaYpPs95sgu0nXIDhENeTOboN+wzp16tKNTV1fHWRf//xx99RNN4PB4PKekZmmRoZf2ixYweNEizHD3df4rXbSI7Qz9rglY8oQjmUOs1NDxtfNaZEU+YTk4o2PzER1gABIJGOj4GIBRqaJNoFoCOXCfEGmUkxv9tayt2kpY9Wjd5fu/5qE/s26O2chdpWaOibh8OXf33euP11/F6vQwcMIApkyfHPJZzxw6Rl5sT8/UAh7dvpncPbQXEyiqrKBwwWJOMLUtX0K+7fhmf9gv3n4RAKACdnPS0BiOOsAAIEpuOuD873gKQmdHg09xoATCZokszGolEMJmMW547cr0Qa1XnRVEiF3319XMeqK85hCt9oGY5DcGy6saWlt485kBRFP7ylz8D8LknP6vpXt2yvZgJEyfGfD3A3kNHGDZqXMzX63WQcPzsWYZMmqJZDqiPhxIYh1AAOjE9ezhw2JsvduJ0TZCYdMR92bEWgG75VtJSG1wl1FoA1PrtinkviAcNJ+yxV7S9koCvAostSxdZdVW7Sc2MPld+braF/Jzm7kIbN2yguLgYm9XKow9/OuaxhMNhZFnStMkNh8Oa3QDXfbyIMUO0uf+Ew2FMOvrqL3x/ASMHaHdJEmhHlRo/77o0QoqDQCCEySTj9ytkZVro19fGpq1u7DaZwgIzR4/5iSgwfrSTYEjhyDEfVptERUWIQAAmjnORlWkmFIqwZkMdiqLgsJvw+cKkpMhkZ1uoro6QmiKRl28lEo5Q51YIBhROnvJjMilU10TIzDAxdlQKh476cdglBvW3s3e/h7KKEMFAmGOyxC235TJpQiahEJwv8+P1hrFYZQYNcHL0mBePJ4wsg9UisXzNQcaP6c7uvXV43SHsDjNeX5iiHnaysywcOOSmW6GD3FwbFeU+Nm90MnVGAX16peCwy2Rl2li/qRyrRWbC+HTWrqtmW3EVaS4Lo0ems2H9Ifr0zSU93YJJBr8/wrgxGYwYms6GzRWcO+8jN8eOzxciLdXK2VMXcKX2Ys+BGsorghTm2enZw0EoDD27O7j+2vxLv43QpgU3XpdGuHF+yjL+oEJWuoV+faxs3uHFaoHuhRaOHAsQiUQYOyqFiKJw+KgPq0WisjqM16swaVwK2dlWwuEwazfUEYpAikPG42mYnzk5VqprQricEvl5VsJhhXq3QiikcPyUH7PcMD8z0k2MG5PC4SN+9u6x8MhjPdmzr47S8wGC/jAms8zAASlMHJ9BRJEoLfXj9YUwm2UGDUjh+Akv9fUhzCaZdZsOMuva3lRVBdl/sI76+jBOhwmvN0xhNzu52VYOHqqnsNBGXp6dysoAm9a7mDq9gD69U7DZZHJzbKzbUI5JlphyTRbrNlWydUsVzhQLY0amsWljJr365JCRZkGWJYJBhdEj0hk1MoPNWys4ddZLbrYNvz9CWqqZsyUXSEvvxZ6DtZSVB8jPtdGzuwMFie4FDuZcm3fpt7lcCCy6B6nWyqGCxGPe3FwU7Pj8QcxmCwFfmPQMM/0HONm2tQ7ZBL162Dl0xEM4HGH0qFTMFhMH9tdjsTYkfPC4w0yckEF+rp0IEVatqiAYAleKCbcnxPFjNq6/oYDqqhDOFJnCfDtIUFMbIhJSOHbcjUmGyuoQGekWJk3M4uChOsxmiVEj09mzp4Zz5/34vGFMJolBg1K5ZlImIHPunIfFi/dx041jGDE8nSNH3dTWBZElMFsaNrsVFQH27KuhpiaI02nB6w3RvZudwgI7e/bW0a3QTmGBg4oqH5WVAY4f3sUD992Jw2GmIN/OyrXlyDJMm5zN+k2VrNtQQUqKiXGjM3G7w1TWBMhIs2AySfj9EUaOSGfsyEy27ajkvff2cdvN4/D5I6S6LAzs62DT9ir2HqjlXFmAvBwrvXs6QZHIy7Ux77qCq36j3/7utwA89NCDZGdnx/xbr/zkY2ZMid19CGDlwgVMmzBWk4yyyiomTp+pScbi9z5gwlD9ipDV1NfRe/wY3eQJYkeVAjDr2nRcrtQWPxvYz3np/6dd0/yzsaNavgZgQJPrYmXksMsFLvr3vSzv7fdTuH725YdwZmZzc9/gQc0LYxw4ZmfGjDxmzMijJebMaf5vqz2HB+7u2ey9+4su//uB+1J54L7L1Qgt5hzuub3l9GTXTru6z08W2bjjliLuva39ioaNqDkJVHtqaHR7tYhTz+bMbmt+Drhc8GbqFfNzzMjW52fT+RQrI4e6UBQ7/ful0r9f631lXGGOHzTw8vw8esrOqFENQWMzZ7Y8P2+4wqXUYs2+en7ec/nf996Zwr13Np2f2dx7R8uuCNMmX+2j/Eltw/y8+9YWL2lGLGlAEzEGQI8511Xn7ZzrcnCltnz/Dxl4OR/61KnNN56jR6a3KrNfn8tzZNOuAwwZNYzrpqnLzjNmTMal/x8woPX5uXPPHm6+61rGDm44sR86pOUc7tfPzm/x/ZtubP7vYyWnOD9iONOnXm7/6fsvr1M9e7iumr+tISuH+fIX59G/V/NN/V3dXNx1S1QiOH78OPPfew+AZ55+OrqLWqG+3q0p9z9AbX096Xmx+91XHjyIXWPqT4B6j4fcQbFnIWrKuqUr6VWoLaZBoB/JfcSk8vmp9oGbSO1j2Swk0vhjQVg9Og+ySSYcDsd8fWe/v422AMRrbuox58S8NYZTJw4ze6q2lJOtoSgKVRXljB2sX+7/Xdu3MufaaZrlKIrC+dJS+veK/qCsJX71y18SDoeZc/11jBwZu5vTzk3rGTFMW9Dt7vVrGNxPW1rU9cU7mX7dnPYbtkFD7n99XLQATpw7w5hZopJwopDcCkAXpKuergkSG5vdgdfjiWufiWSBUmsBCLtrkMzaiyIJugaKoqBEjMsctWrdOoaPHa+bvP0HD9Gztz55/9etWc3kKVM1yTh37hz/+MffAXj2m9/QJOt4SQl9+mlLaXrkZAkDh2qriuwPBLFptADsPnqEibP0yf2/fe1GchIo9adAKABJgzhVEyQyNrsDny++CkAiWQBiqgMgYgAEUbJs3Sb6DR5uiOzG0/8xg3rrJvPAvj3MmBR7dptGQqEQ1dXV9Op2tT+/Gn7205/i9/uZMvkaZl4b+wn1if276VXUQ9NYTuzaTvf8lt0co2X7ipUM7B2d+1RrNAQhawtkbsq+Y0eYdqUfmKBDSe4njMoDwETziY/lBFPEAAgSEZvNzp6DJ2K+3ui5YHR7tRaARK0DIGIAEpPKC+e5ZrQ2t5PWWLpiJaMn6pMCEmDL1m0MHRF9rv62WL50KTNnazuhLikpuZT68/svPK9p3hXv2cvoMdoCXLfv2cc4jX/vY6dPM2i0NovN4nffZ+IwfZTKvZu2kd5KfJqg40huBUDEAOh6jYgBEMTKwKIcAn5fRw+jTQy1ACix1AGIrm08EXMu8di4az953bSdOrdGKBTC465nZD99ikApisLpUycZN0x7Gsjq6mpMJpm8jJaDkaPl+9/7HoFAgJnXzmD2rFkxyzl/4jC5GjIHAZw/tI+s9NaDvqPh7K7dpKW42m/YDnU6Bv/uOLifWbdFGY0tiBvJrQB0QcTpmiARsdpsBPz+2AXEYgFQaQKMhwVAjQtQItYBEOtL4nHyyAFuuFZbysnWWLxkCROmztBN3oqVK7lmmj7y1qxayc1ztVWTLS4u5t///hcAP3nxx5oU3A1btjFZY+rPdVu3M21G7EoIwIadu5ihMfh3x4o19CpUl02qNfZvKcblTBGHBwmIUACSBDG5BImMzWojFAzELiAWC5dKE2BixQAoyLJxc1pkAUoONhTvpaBHL0NknyqrxGQyMahHji7yqus9eD0eBvTQ5q8PcOzoEYqKemqKk1EUha9+5csoisKD99/HhPGxu8xcKDlKZnq6pnu78tghUlO0bZQDgQAmk6w5fuhQyUlG6aT4bT+wl+tujyJXsiDuCAVAIBAYjsVqJRgMxnx9PFzc1GKkBcDoGABBcnDy6EHmzLim/YYxsGX9Ku6+bZ5u8tauXMZdt96ki6zdu3YxZaI2H/e33nqLtWvXYrfb+d8f/48mWes2bWH6jOmaZKzevJWZs67XJGPRO+8xY5y24mFnivfgtNvbbxgFR7bvxma1ioQGCYr4VZIMYaIXJCJms5lwOBTz9Z09CLixBkKiKAAiCLjzY2Tmn90HD1PQrYduG7dTZ0tJTUvHYtGe2nb92jVMnKRN6amtreXrX/sK0JD2s6go9hoCpccPk5OVpWm+1pYc1bxRjkQiBEJBXN20Zf/ZuGc3M2+8WZOMRrbs282cO27XRZZAf4QCkCSI00JBItMR92ciBbk3WgBMpihdgJTkDQIWa5V2IpEI5efPMnWcMQrAob27mDtTv8w/Wzeu56brtfm2A7jdbmpra+nXU1vQ8w9/8H1KS8/Tr29fvvn1r2mStX7zFqZM1fa3WrF+M7Nna/PbXzL/faaOGa1JRiQSIaIomM1mTXIA/IEAsizrIiuZ+Z//+R+mTJmC0+kkIyOj3fbBYJBvfetbjBgxgpSUFLp168YjjzzC2bNnVfctfpkko+npWv3hExz53z9TuXYbiiwhhRXM6S76ffNJnH2KKP1gBZv/shDZakW2WZDsVjwlZ/GfKyfi9iI7HaQN74+/tBxrZhp1owqp7XmU8uWbOfHXdwjV1CNbzdi655E9YzyOHvmE69xYMtI5+bd3OFh9noJFO1ECQeyFeSjBIO5DJ1AiCjnXTQIkqtYXY83JIFBVS2lVKd6RE7HkZOI+fprSf79P2OvDlp+LvVch9h4FVC3fQKC8GnN6KoF0E0okQqiq5uKrFve2vfiPluA/dRY5xYlkNiM7bKTPnY5n10E82/dgykxDttmRrGbsfXtiyc0Cu43w+XIigQDB8xX4jpUQCYYIl1eBxYyigFJdCxKYMtNxTR+PpICc4sDRvxeRQJBQeWVDQR5fgGB5FaHKagKl5YSq6yAURLZZkcfok1WhU6Ll4FflqbHaINqGLow7mY5ctAA03dR7jp/m8It/omLVlovzM4I5LYU+X/0MNd4KQku2cGLT/oa5aTVjSnHgOXkWX2k5kToPksNG+vABBMoqOeIupzylAFtuJuWrtnHiL28SrK5DNjfMz6xpY0npXUi41oMpI5VDv36ZtF+/T8rA3iihEI5uuURCYdwHj6NEImRdOwHZaqFqzXYsOZmEauow2W34B+USqnPjOX6a0v+8T7jei7UgB3tRIY4+3alYup5geTUml5O8268jY8pYgpU1BKvrCFbVULd1N9UrV3LonTXIKQ5kiwXJaiV97jR8B45Sv3kXcnoaJocNyWLG1rsIa0EO2KyEyyuJ+AIEL5TjPVKCcnF+KmYTIF2enxlppE4dDzLIDgf2Ab1QQhFCZeUogOL1EaqoIVhZTaD0AqHaOggEkW02GDXAsHtAT+YvXMSoidqr6LbE8lWrGDl+km7yinftZsCQIboofsuWfMI9Gk+Ud2zfzu9+9zsAfvebX2Nvxd3FW3KWQz/+ExUrN6NICoQVzKkp9PnSI6QOH0jVxh0Uv/0BHklh+zsbMbnseE6V4jt7gUh9w/zMGDEAX1kVlhQnvb/wAI4e+ZSv3MzR3/6bYGUtstkEeRmc6ZXJmbIQoVo35ux0Tv19PmGvD9eQvijhMI5uuSjhCHX7jqGEw+RcOx5zmosLyzZiy80iUFXHngsljHvxuw3z8+RZTv71bUJ1bmwFuaT0LMQ5oCfli9fhu1CJ2Wmn4M455MyaSLCqlkBlLYHKaha+/CpF7jA7X1+L7LAh2yzIFgtZN0zDe7SEmg07MKW5MDkdyBYz9t7dsRXkIdltBC9UoPgD+Msq8B4tYU1ZCaN8Jvb+YxHIMkp1DQByWiqpU8chm0xgt+Ec0JOIAsGycpAkIm4v4coaQpXV+EsvEK6pRwkEwGpBHtE55qcaAoEA9957L5MnT+Zvf/tbu+09Hg/bt2/nu9/9LqNGjaKqqopnnnmG2267ja1bt6rqWygAScKVi6sSibDj0W9RV7y/ecPTsPPRbwFwKuImT05pQ2oVF05e1ioPf+Im7RfvNWsRCYbwHirh9KGSq64ORtxULdvUomT3/mNXveeNuNl1/zNgkiEcufR+XSujq4m42fve2jbG36S/jcWX/9HkO9WvUTdhUCBcUU3N/KXqrgMiXj/1yzeovi5p0PL8V7l5CAWDmC3qqmAaaQFodAEyyQ0KgKIo7Hj0m9Rs3XNV292f/W8OKT4KsZAqtW0FuFBSCkBdxM32h7511eeRQAjv4RLOHG4+P4MRNwE5SOBsGQDVV1zn3n+8xf7OrHSz7e+Lm83P1qhe2fLcb+i7+brj3ryzyb+azM+129rtpxkKhCtrqP5wmbrraJifnpWbVV8Xb3YfO4PFamVkf31Sczbl1IVKPB43Ywf30UVeJBLh+NHDPPzAfZplHT50iF69ems6UQ6FQnz+8/+PSCTCA/fdy41tZBHa8cS3qV63vdl7fmDP51+49O/tkTqmyKmUcbBFGWUX5ydARQv3ViQQZMuxI4w+nsLBVfuv+tx/pqxFufV7jzb7937FSxEWtt/7lauen61Rsfzq8ZyO1NNDdnFlwubazbtaFtLK8zOiKIQUN2bZheJpnv0tUl1LzUcrLv27qt2RXsTrV/+87gR8//vfB+Dll1+Oqn16ejpLlixp9t7vf/97Jk6cSElJCT17Ru8CJlyAkozGU8xgVQ11u1pelBKeKBYvgaAtgsEAZou6jUI8YwDCXh81O/a1LhtFk75kKGJ+dii7t67nrlv1C85tyuY1K7j/Tv0ytixbtowpM2ZqlqMoCnt272LyBG3Vg3//u9+xfft20tLS+OXPf9Zqu0goRPWmna1+DnBY8dFf0hYsG7y4hlg0WkdqlDAZ0sX1Lsb5eUTx0VeyaRpHI3vxMkxy6CIrkaitrW328mtJba0jNTU1SJIUlQtRU4QCkCRcZQEIhkERD2pB1yQQCGJJQAtAYxBkxBdo061JQZvBRJCcLF+/iX6DRxgSR7Fx23b6DhyiW+DvuQvlSLJMv255mmUtW/IJszRW/D1+/DgvvPA8AD//6f9SUNB6OtKIPwCR1p+fYUWhXAmRJ2kLat6peBgtOTXJOKL46KfDxl2P79OIR4ngasd6mUi4/SHq23i5/Q0JLIqKikhPT7/0evHFFzt45ODz+fjWt77Fgw8+SFqauqJ4QgFIMhpPJa352eDQJ5WXQNDZCAYDql0FjLQAhEIND5DGGABrVjomV+vud0IBEFxJMBDgQuk5pk8cqbvs0up6Sk+fYsbEUbrJ3LhmNbfP01aoC+B8aSk2m41uubFX2VUUhae+8Hm8Xi8zr53BE48/3mZ7c4oTcxsVhrcrbsZo3LgHLh7QWSRt27ByJUSuxo37CcVPkaTuwKQ1jik++uhkSUg0Tp06RU1NzaXXc88912K7Z599FkmS2nwdOHBA83iCwSD33XcfiqLwxz/+UfX1IgYgSbjyREiSJFKH9KNu294OGpFAoB9qTzyDwQAWa/QPoVgCgNWMqVEBaJoGMXXUIKrXtOzj3qAACBVAcJl3Fyzk/nvuMET2hlVLeVBH2Vu2bmPIiJG6WCrWrV3Dpx+4X5OMf73yCkuXLsVms/GnP/whqnGljx1GxdL1V71fpYRwSDJ2jRv3YsXDWKmtGLz2OaH46aXDxv2cEmSy7NIsB+CCEqKvnJyHj2lpaVGdsn/ta1/jsccea7NN3759NY2lcfN/8uRJli9frvr0H4QCkHQ0bmQi4TB1uw518GgEgibEmGQnHA4jqXzYXqh1q8o5HggEsFjVPUi1WAAURaGmtcA6IJLIMQCCuLNh5z5yC7phVXmPRsOW4p306NVXlxz90FDx93zpWWZN1Z5JaN2a1VwzWVuKzXPnzvG1r30VgO+/8DwDB7afSUZRFKrWb2/xs72Kl2lyqqYxeZQwVmTMGhWkUiXINRo37iU6nv6XKUFyJLGtzM3NJTc31zD5jZv/w4cPs2LFCrKzY7OOCRegJOHKE43aHftAQ+VVgUB3YnzW+X1ebCorUwYDAfoUZKjow9dqOkA9CAabWwDq9x1F8Yv5KWifSCTC8YN7uXG2/mk/z1XVcfrkcWZP0RZc25SVSxdz9223aJZTWVGBz+ejf6/Yi3QpisKXvvRFampqGDd2LF/98jNRXectOUfEc2UuHDioeBmoMfAXYKfiZaTGINlTip8eOmzczypBXeQAHFf89NPh79OVKCkpobi4mJKSEsLhMMXFxRQXF1NfX3+pzeDBg3nvvYYMjMFgkHvuuYetW7fyn//8h3A4TGlpKaWlpQQCAVV9C1UtyWg8lWzLfzGZMLpiqkAftOTY9/l8WG3qHiqBQACbLXoXoEDAj1WFy5BagheVccvFzETm9LZP7dTGAIjausnLewsWMmbytYbI3rBqKQ/de6du8op37aZv/4G6WBNWrljOp+7Xlj707bff5v358zGbzfztL3+OOi7InHL15tyvRKhRwgyStW3cy5Qg2ZIZWeNz60yCnf7XK2Ec4kxZNc8//zz//Oc/L/17zJgxAKxYsYKZM2cCcPDgQWpqGuoonDlzhg8++ACA0aNHN5PV9JpoEApAknDlJjiln7Zy4J0Bse3vPITDYWQ5tqwQfp9PtQUg4Pdht0f/oPb7/NhUBs2rUTyDoQYFoNGFw949v832iqKu9IGYC8nJ1n1HcKWlM2qAtsq3LbFx6zb69B+kq+tPyYljPHTv3ZplrV+3lgmTJmk63CkrK+NLX3wagG8/+y1GjhwR9bXWnMyGCdjk4GKb4maSpN1P/ojiY4pGF6JTip/uOmzcz+jo+79X8TJBY0xDV+Tll19utwZA0wO03r1761a0UqhrSUbjjREoj7q8RqdGnHx2DkKhUMwFfI6dr1RvAfD7saqwAFS73aotAGoW4eBF0+ylNKDeq90LriQRN/UyDSkQBcajKAoH9+zg1hu1pb9sidPlVZSVntM168+KTxZx353aqvRCg+uPx+1mUJ/emuQ888yXqKioYOSIEXz72auL5LVFJBRqtvkvUfx0k6yYNJ7a6+VCdEoJaD65P6n46anT6b9fiWBG0mzVEMQXoQAkCVeelIRU+oJ1RsRS03loKMwV20mjz+tlaJ9CVdeEQyFVJ5t+n58e2elRt1fretbom9loAQj7O+f8tEsyfkR9kXjw/sefMHqi/n7/ABtWLuXBe7Rv1hvZtGULg4cN11Slt5EVy5dx67wbNcl4++23eefttzGZTPztpT+rDp5WApfjc8KKwmklQG+NqS2DikK1EiZHY8rO44pf81igwfdfDysCNNQzGKUxLaog/iS3AqDyoMrIPODxaN/smk4YYBjLuaI4i+wcBPx+zCoLczXi83pwONQ9XNTOHb/PqyoIOBAIYLWqyzIEYL34N4h0wvkJ4EDGo1EBkICIsCK0yY5Dx7HZ7YwZ3Et32SvWrGHY6PG6FfwqLa+gqqKCCSOHapa1dvUqJk+Zqtn154tPPwXAs9/8BuPGjlUto6mCvk1xM04H15btiltz2k+Ac0qAbho37nr6/geUCDKS5oxGgviT3AqAyvvRyEqgRre/sm3gQqWqvhIBtcuHWG46Dw0b5tgeOAG/D7vD2LLyfp9fVZyBT2VcwpUWAP+5MnVO/gmCAxmfRrXbIkkEhereKoqisG/HFm6/aY7usg+XnCYUCDJp5EBd5CmKwurlS7n7tps1yyo7f55QKKQ5688Xv/g0FRUVjBg+nO/+97djkuM/WwayRKkSIEsyY9OY879UCZIpmbFonPP7FC+DNWYPAjitBHTL/LNDnP53WpJbAejCpPTrCXLn22AIkpMjZyqxWGI3WxutbAcCflUWAL/Ph11FXILf7wfAZmt46Dr79ABT51t+7ch4NVoALAgFoC3e//gTRk+arrtcRVHYsWkdd906VzeZS5YsYdrM2ZozsSmKwprVq5g353pNct58803ee/ddzGYzL//trzEfOjh6diNiMnFE8dNfo8++oigcUXyaff/DikKNEiZLY579k4qfXjpV6vUqESxImhUbQcfQ+Z5AgjZpdH2w5mRCRDxkBYlBMBBgcP/YTvY0ucJFSSQSUbWJUWMBUBTlkgLQuCGxZKRBpPP50juR8CpCATCKrfuOGOb6s2DhR1wzQ9sGuyl79u8nMyubgUXq4nNaYsWypcy4dqYmRaK0tLRZ1p8xY0bHLMucmsK2YK0urj8NOf+1n5A3uBBpl3NGCQjffwEgFICkocWF05zsP684degsqD1hb0osmwKjLQZerxdHlGlDQ6HQJYWk2d/AHFta1I7ErMPm3SoUgBaJRCIc3L3dENefLcW7yCvszrA+BbrIK6+u5djhQ7pU+y0pOYnd4aBXt9jHpigKX/jC56mqqmLM6NH893PPahrT8f27SLfYcGh0/alVwgCkSdrmepUSwiHJml2Rjik++up0+l+jhHFJsubMSIKOI7l3iF0wCLhp6jJbz27qr+9ARBBw8hIIqEvL2ZR4WADUBw37yHRFdzro811O+dm0OFlK/7ZPeRPx3taj6J6wALTMuws+YuyUmbrLPXWhkrMlJ7h+2kRd5CmKwvJPPuaBu7UXEItEImzZtInrr52hSc6///1vFnz4IRaLhZf/9ldNtQ0ikQhbthczbvhwTWMC2KV4GKWDz/4+xctwHU7aS5UgBTqd/u9VPAzD2NgsgbEktwLQhYOAASJ1HlX9dTQiCDh5Cfh92FTm8m8kES0APr8PR5SByY3uP9DcAhCqrW+p+eUxqRqROmQ6LhOPHlaEZGPd9l1k5xYYUvBrw8olPHSfftV+lyxZwpQZM3XJIrRk0SLmzNWW8vP06dN85cvPAPDCd7/DiBHaNu4fv/8uN143m1B1rSY5By7m/NeqNB9UvAzQoXbAfsXLEB2UEYBSJUCBZNHlQEDQcSS3AtAFaXqSGays6cCRxAexjegkKMS8YUhEC4DPG33a0EYLgNlsbvY38JdVqOpTT0xIhDto9liQhQLQhENnKzl94ihzZ03VXfYny5YxZtJU3VJ+7ty9h6ycXAb36q5Z1qGDB8kvKKAgKyNmGYqi8F+fe5La2lomThjPN7/+NU1jOrZvJznZWaRmZuI7dyFmOT4lQp0SJk9jzv+AEqFaBzmNAcSZGgOIGzmm+Omrg1Ii6FiEApAkXJUGtLwKwuEOGk18EGcPXYN4nDKp7cPvDzRz52mLRgWgacxAsLYeAqH2RqVqTGqQJeio1UHEADRny5qlPHT/PbrL3bnvAM4UF2MH99FFXml5BadLTjBz8gTNsgKBAPv37WXKxPGa5Pz1pZdYsmQJNpuNl//2N02FyCKRCFt37GTipEmEPT4UX+zF+rbplPN/q+JmvA5ydigeRusUrHtI8elikRB0PEIBSDIaTzJDHm8HjyReiI1EshOTBUDlfRGLxSBapaFRAWiqMERCbW+/jb6rO9YCIBEQhcAA+GDxEoaOmYDJpG9A+NnKGo4e2s+82fpUElYUhdXLlnDfnfpUD/74owXMnXeTJhlHjx7lG9/4OgA//tEPGTx4kLYxvf8u866/ruEfGlJoH7uYZlNrcGyJ4qebZNUsp04JY0HCrjGAGBosCZVKiFyNFglBYqCPPUjQ4Vy5GbFkZ3TMQAQCnYkpBkDl6bmRMQP+SxaAy/63lnRXm9coGGvhMiN1mAXABB2mfCQSqzfvwJWaxqSR2jauLbF22SIe+/SDusn76KMFzJwzVxdr3I5t2xgydBhZrthPpMPhME9+9gk8Hg8zpk/jmYvpP2Pl6N6d5OZk48rIAMBkjy1hQVBROK8EmSy3Pb/bI6wonFICTJVTNcmBhlSdUyVt42lET0tCIlHvDYK59ers9d7OWbm9PYQFIMm4dJLZRWoAdI1v2bWJKRuWwX2oad+SBUAJtuf+oxiqAHTkJlwEDsL2g8epqrjAjbP1L/i1ZNlyRk2YrJtVYfPWrfTu15++hbmaZVVXV1N2/jyjhw3RJOc3v/k1a9euJSUlhX/89SVNMQ7hcJjtO3cxYeLlLEmRUHvzs2X0ctnZppOco4qPfpJNlzlXo4Sx6mRJECQG4pdMEq6c4EowlPRO8mIf0TWIRxYgI+X7/BctAPbLFgAlFG7TzcBoC4AJiZBQnzuE3cdOc2jPDu698xbdZRfv24/d6WT80H66yDtx6gx1tbVcM3qELvKWfrKYO269WZOMPXv28Px3vgPAL3/+U/r00RbjsHD+O8y7fnaz95RwBEzqZuBpJUC+ZNFcFfe8EiRdMmnO+R9UFC4oIQp1Svu5W/EwQqcsQoLEQCgAScalSsBZ6Zjzcjp4NMYjtjDJTyJmAdJqATC7nFi75bd6TQTjXYCEAhB/tu0/yv6d23j4oft1l32moppjhw5w03X6WBWCwSBbN67n9nk36CJv5fJlTJs+Q5NyHggEePyxRwkEg9x80zw++5nPaBrT4d07KCzIJyU9o9n7JpsVR+/oU7KGFYWTil9zkS1FUTis+Bikw0Z7q+LWpZIxwOGLgb/CepdcCAUgSbjS57m6eD+h8+UdNJr4IJai5CcSieiWwrAtjHyw+XwNdQCaZgGqO3ScwOnSDhtTgwIgiCcLly7jTMkxPv3gvYb8tmuXLebT99+tm7wP3n+f6+dpO61v5PixozicTvoWaUsf+qMf/ZCdO3eSlZXFX/74f5r+jqFQiJ179jJu/NWZiLxnzuM9eipqWdt12mwX6+Rjr5c1AsCvRKhUQuSLwN+kQygASUbjyWT1huKOHUicEGeYyY3H7cbuUPdADIVCumdV0UJLFoCazbs6ajiAthgAMedio9/gEdxzuz4b6iv5ePFixk2ertt9v3LlKkaPn0CP7DTNsoLBIMU7djBrmrY6B5s2buSnP/kJAH/6w+8pLCzUJO+j997hpjnXtfhZTfHBqOWUKUHSJJNm3/gqJYRFknBJ2n5DvawRjegVjyBIPIQCkCRceRKSfd3kDhqJQNACMR5EuevrSHGp24S46+tISdW+cdGLwMVKwE1jALJmXqN7P2rckiwaXICE5S02RvTXXjyrJbbu3E1mdg5jBvXSRd6+Awex2W2MGqRPHMFHH37AvJu1xTu43W4ee+xRIpEIn37oQe65+y5N8vZt30yvoh44WlknMieNjEqOoigc0sllZ6/iZbgOp//bdHT9Oab46KlDSlNBYiIUgCRFaxlzgSAROHS6jKF9u6m65lRZBSkudenzjEwD2mgBaFo5OFStb5VuCXUn8yIIODk4eb6cs6dOMmeGPgrlhaoaDh/cz5xr9akfsHHDekaPGaMp5SfAs9/6FkePHqV792789te/0iQrGAyy/9BhRo0Z3XqbmrqoZOmVFnOP4mGYDkpEqRIkQzLrkqnHr0S4oITooVMQsSDxEApAktF4ChgQCoAgkYhxr+mur8WVqm4zX19Xy6CeeaquMTQI2N/oAnT5QRqsc6vqrz3UKgBagoAlICIKeXU4iqKwfsUSHrr3Dt3krfjkYx68R9vpeiOnT58iGAgwdEB/TXIWLfqYP//5TwC8/Le/knExV3+sfPjuW9wyd06bbcIeX7tyKpUQVh1cduqVMAFFIVPSVpYpoigcUXwM1KlK7xbh+pP0CAUgSbjyRNJz/HQHjSR+qC32JOhAYvypfF6P6tN8T30daWnpsXUYJbFYAGxNLACek/rOT7V/XgsSoRg38TZJxi+sBx3OBwsWMHXWDboFFH/88cfMuG6OLkH3oVCITRs2MPe62e03boOKigo+99nPAvDFp5/iutna5O3ctJ7BA/pjdba9sfWdPd/m54qi6OayU6x4GKODnO2Kh7E6bdgPKl76C9efpEcoAElG48mks5cx/qaJhtiGdBJi/KFiyQLk83pxOI2tVqnGAuC/GAPQNAjY2V1bAKNWTFLslYAdSPiI6DoegTrWbd5CUe++DOtToIu8rdu206NXL/p3bz01rRoWfPA+N91yqyYZiqLw9NNPUXr+PIMHDeJ//+dHmuR5ys9xouQUQ4YNa7etvZ2iZ7sVry458Q8qXl3Sa5YpQVySjFMH1x+3EqZeiVAgXH+SHqEAJAlXLiBpowd30EjihzibSH5ifTCquS4UCmEyqzO/x2IBcDgubxhcwweo6i+KEcVNGbYhCwWgAzl4ogR3XS3XThqti7wTp85QXV3FlLGjdJG3Yf06Ro8ZQ3aqttPoV199lXfefhuz2cy//vmPZvMnFj76ZCk33zwvqrYp/Xq2+lmN0pA/K0Ojy45PiVCjhDWn12wMRB6sU5GuBkuCsQcogsRAKABJRuPJZLi6rkuUyhUWgMQnHA4jm2JbauJRBMxdX49TpcVAlQXgYh0Am/XyiZoR8zNec8GOjE/MvA4hGAyyc8tG7r71Rt3kbdmwjjtumquLvJKTJ4iEw5r9/k+ePMmXvvg0AM9/578ZN3asJnmbVi9n3OiRUadJDVbXQSuWx12Kh5E6bLb1ytajV+0AaAhGHio5RMGvLoJQAJKEKydsLBunzoZYojoHHrcbRzs+t60Ry4NI7TXu+npDswa1lAUICV1v4HjOBbtwAeow3v/gfWbMuUk3eR+8/z5zbtbmqtOIz+dj29atzJk1U5OcSCTCE595nLq6OiZfM4lnv/kNTfKqzp6ksqqaPv2iV0okueUZ1ZitR+sG+bji1yW9ZoVOtQMAapQQYQWyNVo2BJ2H5FYAVO6BjcwEEo/2Ddc0/NfZvye0sohdaqtaurGIskTJSX19XcwKQDwsAOXVNaS4XIb10VIhMEfPbkgJVKxMDXZk/IpQAOLN0hUrGD5mAgO6Zeoib8XKlYyZOIkeWeqU39ZYuOBD7rvrTs1yfvnLX7B69WpSUlJ45R9/x6zSPe9KFi9bwdy5N6i6xl6Yi2Rp3m+dEiakKGRp3CCHFIVzSoAijT72iqKwT6dAZEVR2Kl4dbFsCDoPya0AqFSujcwFbnT7K9vKsgzhth/SiXaCnmjjEejD/hOljBgcW1Gh+FgA6uhTkGNYH/7AxUJgV/gwK6FYw3BbGZOu0lpHSwCxIDZ27NmH3eFkwnBtrjWN7Nm/H2dKCiMH9NFF3ppVK5kwaRIWizZ/9h07dvDC888D8Otf/px+/bQVI1v5yUKunTpF9ZqgKApKMNTsvWLFwygdNttbFTcTdHD92aV4GamT689OxcsoySlcf+LMiRMneOKJJ+jTpw8Oh4N+/frxwgsvEAgEorpeURTmzZuHJEnMnz9fdf/C1pNkNJ5MRnTeXCQq4vw/8fF63KpdbBqJhwWgvr5eda2B2CwATU78FOWyuU4HxDxIXkrOV1By/Cifvl+f/PxllVWcOHqEB+7WfloPcPTIYSxWK4P69NYkx+Px8MjDnyYYDHLn7bfzmcce0yTv3LFDSEgUdI8xI17k8gGaXr7xZ5QAeZIZi8ZsPTVKCAlI18H1p1IJYZb0kSVQx4EDB4hEIvz5z3+mf//+7NmzhyeffBK3283Pf/7zdq//9a9/remeFApAknDlTRCsqO6YgcQRcVbROfB63DhTEjcGIBIOq3IzCIfDmFQENfsbswDZL1sAAgbMTzEfkg9FUVi34hOefPxh3eSt+GQRn3nk07rIc7vd7N2zhwfuuVuzrG98/escPHiQgoJ8/vzHP2ja2CiKwqp167n/vntjuj7UpBJwrRImpEC2rL1Q1wnFz1RZu8vVbsXLVEmd22JLNNYzmK7DmATqufHGG7nxxssB/X379uXgwYP88Y9/bFcBKC4u5he/+AVbt26lsDC2tNLJrQB0yRiAhmtqdx1sv61q6cajKIqqhT8Rv4PgChRiLi4Uj2B2tX14PB5VdQZaigGoP3RCVZ/tI2ZCMvLBhx8ybfZc3VwzFiz4kFlz5+lXPOyjBXzq/vs0y5k/fz4vvfQXJEnilX/8nZwcdS55V7Log/e4UUMRMveJM5f+f6fiYZoOm229sv7oFYgM+hUh6yrU1tY2+7fNZmu2rutBTU0NWVlZbbbxeDw89NBD/OEPf6CgIPZaICIGoGnzBPLpV9v+yrbm9PYXrM5+YtjZx99l0PBDxcMnVW0f9XV1pKpwafJ6vUDzGABLhr4nbmL7n3ys2bCRXv0HMLS3PsW5NmzaRL8Bg+irMt6lNZYvXcKMa2dGnVqzNUpKSnjys08A8PWvfpXrr7tOk7wje4rJyc4iPTs7ZhnWjDQAdkU8DNdhs12mBEmTTNg1uv7UKWGCikKmDpl6ypUgNknWJYNQZyfgCxLwBdp4BQEoKioiPT390uvFF1/UdRxHjhzhd7/7Hf/1X//VZruvfOUrTJkyhdtvv11Tf8mtAHRBGk8z08cPhxhzr3ckYiOThGj4UeMRA6C2fW1tLa7U6E8EfRfrANjtl0+KUof2B43ZTZqiIBTiZGLfkeME/D6mjx+pi7wjx08Q8PmYOKr9KrjRsG/vXrKysumtsaJ1KBTikYc/TU1NDRMnjOdHP/ieZnk7du1m/IQJmuQ4enWj6uL01LrZbizUNUiHDDs7dcr5rygK+xUfQ0XWH1WcOnWKmpqaS6/nnnuuxXbPPvsskiS1+Tpw4ECza86cOcONN97Ivffey5NPPtnqGD744AOWL1/Or3/9a83fJ7ldgLoQV55QmCwWJFcKShNfxkRHbGAETVHrDtZ4jVpUZw1y11NU0Dfq9j7f1RYASZaRM11ELlSr6rs1FEAWGTySgrNVtezftZ3HPv2ALvKq6tzs3rGdhx/U7qoDUFVZyckTx7n79ts0y/r+97/H+vXrSU1N5T+v/FNzFqEP332LW+bO0TwugL2OCNNC2jfbehXq2q94GSTZdbGKbheuPzGRlpZGWlpau+2+9rWv8Vg7Qex9+15+hpw9e5ZZs2YxZcoU/vKXv7R53fLlyzl69CgZGRnN3r/77ruZPn06K1eubHd8jQgFIMlo3AAFKms61ea/EbXbN2ExSF78fh9Wqzr/Sq9XnX8+xJA1qK4Ol4q6AS25AAVr63Xb/AuSB0VRWLPkY902/wBLPl7AIw/er4ssRVFY+sliHvnUQ5plLV26hJ/+5CcAvPSnP2pO+blr8wYG9uuLPcaMY035+I3XGVWraD6VqlRCWHVws/EoYTxKhFxZm4IEDa4/DuH6Yyi5ubnk5uZG1fbMmTPMmjWLcePG8Y9//KPdeLlnn32Wz372s83eGzFiBL/61a+49VZ1Rf2EApAkXHkq4DtzvoNGEjtq11pJ2Aw6BzH+THW1NaSktn/a0pST5y6Qmp6h6hq1J2p+f0BV4NclBaBJFiD/uQuq+hR0DRYuWsT4KTM0F79qZPHixUyZfq1u8hYu+JAb5t2k+RT63LlzPPLwwyiKwuee/Cz33XuPJnnuC2c5frKE2267RZMcgGPF27D4Q6Rq3CDrmWFnu+Jhik5Zf/YrPpH1J0E4c+YMM2fOpFevXvz85z/nwoXLz4XG4N4zZ85w3XXX8corrzBx4kQKCgpaDPzt2bMnffqoq+vR+ZzEBVGR0r8nCJcAQSfmQEkprrR0VdfU1lQxtE83g0Z0GTUbII/HA4DDYb/0nrNPj3YrdQu6Fhu3biOvsDujB/bURd724p3k5hcwuHcPXeRt2byJAQMHUZitrRJxOBzm0Ucepry8nJEjRvCrn/9M89gWLlnGzTfP0ywnEomwZecuZt5+O5i1KQC7dKqse1jx0V+y6eLiJ1x/EoslS5Zw5MgRli1bRo8ePSgsLLz0aiQYDHLw4MFLzxE9EQpAktHoziCZTLoWGkpUkv8bJgEx/kj1tTWMUrkZqqupJj1D3QbFyKBhRVEupQFtFgNgkiEi7l5BAwdPlFBbU83sKeN0kXfqbCnlZeeZMUkneadK8Hm9jB42RLOsH/7wB6xcuRKn08kbr/7nqgrZatmwchnjx4zSnI0IYMFbb3LDjGkN81NDMc3qS4W6tFlefEqEKiVEgWRtv3E7XFCCOIXrT0Lx2GOPNVSdbuHVSO/evVEUhZkzZ7YqR1EU7rjjDtX9CwUgSbiqEFhtfQeNJHbUuwAJkhmf14MzRZ3Z2+/zqd5QGJmet3HzD5DSpBha2OtX1acgeTlbVcuurZu4+9Yb228cBaFQiA1rV3HXrTfpIs/j8bB182bmasir38jSpUt48cc/BuDP//cHBg0aqElexenj1NbV0buvtvgBgP2bN1CYl0NabjeUYEiTrN2KlxE6nP7rVTtAURQOKj6GiKw/giYIBSDJaNQco6kDkIiIIGBBI7FkAYq1H6PaNzXbNlVMTE57S80FXQxFUVi1+CMeeUifDD0AH7z/PnPmafeFb2Thgg+5/+67NMs5e/bsJb//zz7xGT710IOa5CmKwpIVq5gz53rNYwuFQuw5cIixEyYDIFstMZ8w7f7/7d1fUFTXHQfw793/sECYqIgEiMEExEQxVluNRakmbQ1OM5nmT/+k1T40zWPrTB+at2ammSRtM9MX28z0rZ1kMpN2ptFBg1kZlWIyqFG0KP6BRAgiIMoue+/de3fv6cOyCX+W5d57zv5h9/d5hLtnzwCHPb9zfud3mJi7A/pZBA9KXjgp9YekCQUAeWLuPxuH0wmH4MuG0s/iSmyaekHEYYy/kka6pXMHIBEAeL3e2SkKkgTXitS3PZL89+GhQ9jW8qSwQ7onTpxA0zc2o2a5tbMzC/m4/SM07+A/RByNRvGzl36K8fFxNG1Yj7+8/Wf+vrUdwu6dzUIWCf7z/nvYs2vHrK+5bVyYFmQxxBj/3QE6MzDKdFQLSP0ZnU798VPqD5mDAoA889UZAIcDvgoxNz5mko1rn9LQCyJKODwFX1HurjxFo1E4LOYOW9kBCIfDAGYfAAbiQYRvlbkycfnKzp0N+eTY8Q6sWbsO6+vEHFrvvdIHj8+Hpgb+dBgAuNTTg4qKlXiomr9/r732e5w6dQp+vx/vv/sud97/wOUelPj9WL5yfjUUqy50nsDDD9aiqLxi1teLbIzPHiajSUCaTTcLYzOl/pA0owAgTyRbBdGX2D0AOb5QTGy4eP1LlJaV23ptJtJ/QsFJlN1nbbXUSr+U6R2Amfn/CdF7QUvvm0+cAIxsdyKLTp3+BOX3L8O2jfyHagFg7O4krvVdxlM7tgtpb3xsDLdu3cLWzZu422pv/whvvvEGAODv7/wN9fWPcLUXi8XQfe48tm7byt238NDnuP7FTTy2cfO87+n3rH1+/o8paBSQ+jPIIqiSPHAJSv3ZRKk/ZAEUAOSZmatq+sS97HXENov52GnqBREjHApi46P2PvAzsUJ8e3wCpRbvGrBzBiDZimfk9h1L7yuaA0AsS6vwLkmCXqCj92TXaTidTmEVfxhj6Gg/gh8/x5+nD8RLYXYcD+AHT/MfSh4ZGcH+ffvAGMMrv3oZL77wPHebh//9gbDbfo90nMTe1uQ3Glu5qyPMYlCZgWWcqT8xxnCTaVgtWbsAMZlxpsNHqT8kBQoA8sTcVQdmGABnJYNMoypA+WcqNIkyixdzZVIoGMRDaUzFCcvxFCB/8fwdABbR0va+ZnglByJZmoS7ICFWgAFAeyAAf0kpvtfyhLg229vx7e/sXvQGUbPaDh/Cnta93CvZhmHgF/v3fVXv/+0/vsXdt0tnPkHd6loUWQzak/nsZAcaHq5b8HyDYaFS12eCVtrPCar6AwBXmIpHKfWHpEABQJ5JrE6qw6NZ7ok9VAUov0T1KNwe/oNs6RIKBS2nAFkhy/FbgIuLZ08OIiPjaXtPszyQoGUpEceFwtsB+PDwYdSsXoOWrY8La/Niby+WrahAfc2qxR824dzZM6hvWIuKcv4J9l8PHkQgEIDP58N7//wHfD6+ylfqxG1c6x/AYxs2cPdN13X0Dw5h3frkvwvt7qTptm4wFXWSlztgmmBR+CUnfBL/tOwSk2nyTxZFAUCemPvPR74xmKWeZA7tABBeWiQCr9fadrulMwBKIgCY/WEs3xy29J7p4IUEzeYk3AmJK33IBQnRAgsAfvL8s/jmer7895k0TcONq31o2bZFSHuTk5MYuz0q5LKv/v5+vPrq7wAAf3rrTTQ2ruVu82igA61P89/2CwBt//oA39/ZvOD31VvmAnSDMYyyKKoEVOu5whSsEzBp15gBmRnclYhI/qMAYIZcq0phpz+J17jv51/BIYTMZ2VcqtMBwNzVT7eAFVZebo5VeLdkP3gApgMI268mAHD06BG88Owzwto7/vExPLNXzOVhB37zayiKgp07mvHKy7/kbu/6pfOorX4Abrebu60ve3tQXlYKX/nCqX/u+8yV0L4gqOrPF9M1/0WIpyOJSSMi+Y0CgDwxd1WypKEOkjd3Uy+Ssb6DSnsA5GuZujjMzk3APu/sAKC4rhpSli8D40nDcXOu4LuAgjwDIMrA4BCWr6iAR1B63eXeXqxtXCfkHMHpri60tbXB6XTinYMHhbR5sfcyHt/EX5EIAD4934PtzS0pn/GtWg5HaepJtMEYNDAUCzhkO8J0PCBgF0FjBtyQhFQQIvmP9og45NqOAfB1n2KyAqZl95ChHbn3EyXZYBiG5YmDqijwWswzTuctwAAQicQPEnrnBOOGqoEtcMgwxlhGVmbccEC3uQ7Pm8PvhIRIQRcC5XPhbDdeepG/ok7Ctat9+NFzPxTS1uuv/wEAsH/fz7lLfgJA34WzqF9Tx90OAEz0X0VZScmiQbyhRWGE5ZTP9EIRkmc/xnTu6kEJF5mCDVT207LwVOqSr4t9f6miAGCGTKweWsHTn1hYQXyFfOlMqXPrp0+EsPlLVVUFHq+1ybyqqpYvHbM6xmKxGJxO89NzPaoDwLyV2piixre8kgQUMTA4MzAanLC/Cs/zWiC+9UzTf3s0TUNxkqpSdo2NjmJlJf+FWgAQDAYRCAQAAL89cEBIm9du9KO1VUxq0qfne7Br1+IlRA1Nm96SXvhvXGUMJQ7+1f/PWQRbHCXc7QDx3rpzbB6TyzweDyorK/Hd7U2LPltZWSlsxy1XmAoAEqte4amptHZGtIiqYCpkPnJTZRlTIfOX86iKjFDQ/POKLCNo4XnZwvOJw4a6riMYDIKV+OB9ogl3O88u+BqVGZCZ+RXAjDwPw/TEQmEGvJDgXULZxDKLT3tE7h7l8vi0OgYTgpP3EItGLY3Hu3fGEY3qlsakqiiWxqSqKNA1zfRrEvcAxAxj9mu8LhTt2oI7x7rmvUZhDBrSO9YAIMIYZBiQbYwfjTEwGPDbHHsqYwjbfO90Suf4tDMOkvnv6S480tBo6e82ZXudndjz1G4h7Z3p7obL5UJtbS0qK1cKaVOxOEZTCYZCkKc/K1OSgOInv4Xxo50LPhKxMebS2U6MsekDwLk1pkQSPT59Ph8GBgagmciW8Hg83JWsco3ETPwkh4aGUFNTk4n+EFIQBgcHUV1dLaQtGp+EiEXjk5DcJXJ8FjJTAYBhGBgeHkZpaWnOpckQspQwxhAKhVBVVSXs4h4an4SIQeOTkNyVjvFZyEwFAIQQQgghhJD8QCEUIYQQQgghBYQCAEIIIYQQQgoIBQCEEEIIIYQUEAoACCGEEEIIKSAUABBCCCGEEFJAKAAghBBCCCGkgFAAQAghhBBCSAH5P5M3bzgBrWQWAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        }
      ]
    }
  ],
  "metadata": {
    "accelerator": "GPU",
    "colab": {
      "collapsed_sections": [
        "kkTMK-oJveGg",
        "jleIZ9vNv5rV"
      ],
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}