{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "472c6e79",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import cvxpy as cp\n",
    "from tqdm import tqdm\n",
    "from scipy.sparse.linalg import LinearOperator, lsqr, lsmr\n",
    "from sklearn.kernel_ridge import KernelRidge\n",
    "\n",
    "from functools import partial"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "960db0fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "0655e5bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.rcParams[\"figure.figsize\"] = 12, 9\n",
    "plt.rcParams[\"font.size\"] = 18\n",
    "plt.rcParams[\"axes.grid\"] = True"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "d76861bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "mkdir: figs: File exists\r\n"
     ]
    }
   ],
   "source": [
    "!mkdir figs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "f004e9d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_unique_masks(\n",
    "    X,\n",
    "    G=None,\n",
    "    max_neurons=1000,\n",
    "    bias=True,\n",
    "    kink_eps=None,\n",
    "):\n",
    "    \"\"\"get_unique_masks.\n",
    "\n",
    "    :param X: data matrix, shape (n, d)\n",
    "    :param G: gates to generate masks, shape (num_gates, d)\n",
    "        if this is None, random gates will be sampled\n",
    "    :param max_neurons: number of random gates to generate\n",
    "    :param bias: whether the last dimension of the data is all 1s (aka bias)\n",
    "\n",
    "    Returns:\n",
    "        D: unique masks, shape (p, n)\n",
    "        G: gate vectors that generate the masks in D, shape (p, d)\n",
    "    \"\"\"\n",
    "    n, d = X.shape\n",
    "    if G is None:\n",
    "        if d == 2 and bias:\n",
    "            # data is effecitively 1-d, so we can enumerate all 2*n gates\n",
    "            assert (X == X[np.argsort(X[:, 0])]).all()\n",
    "            if kink_eps is not None:\n",
    "                # sample gates exactly at data points\n",
    "                G = np.random.rand(1, n - 1) * (kink_eps) + X[:-1, 0]\n",
    "                G = np.append(X[-1, 0] - kink_eps * np.ones((1, 1)), G, axis=1)\n",
    "                # G2 = np.random.rand(1, n - 1) * (-kink_eps) + X[:-1, 0]\n",
    "                # G2 = np.append(X[-1, 0] + kink_eps * np.ones((1, 1)), G2, axis=1)\n",
    "                # G = np.append(G, -G2, axis=1)\n",
    "                # G = np.append(np.ones((1, 2 * n)), G, axis=0)\n",
    "                G = np.append(np.ones((1, n)), -G, axis=0)\n",
    "                G = np.append(G, -G, axis=1)\n",
    "                G += np.random.rand(2 * n)\n",
    "            else:\n",
    "                # sample gates uniformly randomly between data points\n",
    "                G = np.random.rand(1, n - 1) * (X[1:, 0] - X[:-1, 0]) + X[:-1, 0]\n",
    "                G = np.append(np.random.rand(1, 1) + X[0, 0] - 1, G, axis=1)\n",
    "                G = np.append(np.ones((1, n)), -G, axis=0)\n",
    "                G = np.append(G, -G, axis=1)\n",
    "        else:\n",
    "            G = np.random.randn(d, max_neurons)\n",
    "    else:\n",
    "        G = G.T\n",
    "    D = (X @ G >= 0).astype(np.int32)\n",
    "    # plt.imshow(D)\n",
    "    # plt.show()\n",
    "    D, ii = np.unique(D, return_index=True, axis=1)\n",
    "    G = G[:, ii]\n",
    "    return D.T, G.T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "f3dfe7a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_data(n, d, max_neurons=1000, bias=True):\n",
    "    \"\"\"Generate gaussian data with masks.\n",
    "\n",
    "    :param n: num samples\n",
    "    :param d: data dim\n",
    "    :param max_neurons: max number of gates (masks)\n",
    "    :param bias: whether one of the data dims is a bias (aka all ones)\n",
    "\n",
    "    Returns:\n",
    "        X: data matrix, shape (n, d)\n",
    "        D: binary masks, shape (p, n)\n",
    "        G: gates that generate D, shape (p, d)\n",
    "\n",
    "    \"\"\"\n",
    "    X = np.random.randn(n, d - 1 if bias else d)\n",
    "    if bias:\n",
    "        X = np.append(X, np.ones((n, 1)), axis=1)\n",
    "    if d == 2 and bias:\n",
    "        # sort data\n",
    "        X = X[np.argsort(X[:, 0], axis=0)]\n",
    "    D, G = get_unique_masks(X, max_neurons=max_neurons, bias=bias)\n",
    "    return X, D, G"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "f8d25422",
   "metadata": {},
   "outputs": [],
   "source": [
    "class MaskedDataOp(LinearOperator):\n",
    "    def __init__(self, X, D):\n",
    "        self.X = X\n",
    "        self.D = D\n",
    "        self.n, self.d = self.X.shape\n",
    "        self.p = self.D.shape[0]\n",
    "        self.shape = (self.n, self.p * self.d)\n",
    "        self.dtype = np.float64\n",
    "\n",
    "    def _matvec(self, v):\n",
    "        v = v.reshape(self.p, self.d)\n",
    "        return np.einsum(\n",
    "            \"nd, pd, pn -> n\",\n",
    "            self.X,\n",
    "            v,\n",
    "            self.D,\n",
    "        )\n",
    "\n",
    "    def _rmatvec(self, v):\n",
    "        return np.einsum(\n",
    "            \"pn, n, nd -> pd\",\n",
    "            self.D,\n",
    "            v,\n",
    "            self.X,\n",
    "        ).reshape(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "ecfbba8f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_l2_grelu(\n",
    "    X,\n",
    "    D,\n",
    "    y,\n",
    "    weights,\n",
    "    L=0.02,\n",
    "    solver=lsqr,\n",
    "):\n",
    "    \"\"\"\n",
    "    X: data matrix of shape (n, d)\n",
    "    D: masks of shape (p, n)\n",
    "    y: targets\n",
    "    weights: regularization weights for each mask of shape (p, 1)\n",
    "    L: scalar which is global l2-regularization weight\n",
    "\n",
    "    Therefore, each mask is effecitively regularized with weight L*weights[i]\n",
    "    \"\"\"\n",
    "    A = MaskedDataOp(X, D / np.sqrt(weights).reshape(-1, 1))\n",
    "    p = D.shape[0]\n",
    "    d = X.shape[1]\n",
    "    w_opt, istop, itn = solver(\n",
    "        A=A,\n",
    "        b=y,\n",
    "        damp=np.sqrt(L),\n",
    "        # maxiter=max_iters,\n",
    "        # atol=tol,\n",
    "        # btol=tol,\n",
    "    )[0:3]\n",
    "    sol = w_opt.reshape(p, d) / np.sqrt(weights).reshape(-1, 1)\n",
    "    return sol  # .reshape(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "42385871",
   "metadata": {},
   "outputs": [],
   "source": [
    "def solve_l2_grelu_cvxpy(\n",
    "    X,\n",
    "    D,\n",
    "    y,\n",
    "    weights,\n",
    "    L=0.02,\n",
    "):\n",
    "    \"\"\"\n",
    "    X: data matrix of shape (n, d)\n",
    "    D: masks of shape (p, n)\n",
    "    y: targets\n",
    "    weights: regularization weights for each mask of shape (p, 1)\n",
    "    L: scalar which is global l2-regularization weight\n",
    "\n",
    "    Therefore, each mask is effecitively regularized with weight L*weights[i]\n",
    "    \"\"\"\n",
    "    p = D.shape[0]\n",
    "    d = X.shape[1]\n",
    "    w = cp.Variable((p, d))\n",
    "    pred = sum(cp.multiply(di, (X @ wi)) for di, wi in zip(D, w))\n",
    "    objective = cp.norm2(pred - y) ** 2 + L * cp.sum(\n",
    "        cp.multiply(cp.norm2(w, axis=1) ** 2, weights.reshape(-1))\n",
    "    )\n",
    "    prob = cp.Problem(cp.Minimize(objective))\n",
    "    prob.solve()\n",
    "    return w.value"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "8917517e",
   "metadata": {},
   "outputs": [],
   "source": [
    "def gated_relu_model(x, G, W):\n",
    "    return ((G @ x.T >= 0) * (W @ x.T)).sum(axis=0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "id": "38033997",
   "metadata": {},
   "outputs": [],
   "source": [
    "def lasso_objective(X, D, w, y, L):\n",
    "    pred = sum(di * (X @ wi) for di, wi in zip(D, w))\n",
    "    objective = np.linalg.norm(pred - y) ** 2 + L * np.linalg.norm(w, axis=1).sum()\n",
    "    return objective"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "b6926bc1",
   "metadata": {},
   "outputs": [],
   "source": [
    "def model_loss(model, X, y):\n",
    "    return ((model(X) - y) ** 2).mean()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aa101489",
   "metadata": {},
   "source": [
    "Solve unconstrained Group-Lasso problem corresponding to gated relu"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "f5c1728d",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_l1_gated_relu(X, G, y, L=0.02):\n",
    "    D, G = get_unique_masks(X, G)\n",
    "    n, d = X.shape\n",
    "    p, d = G.shape\n",
    "    w = cp.Variable((p, d))\n",
    "    pred = sum(cp.multiply(di, (X @ wi)) for di, wi in zip(D, w))\n",
    "    objective = cp.norm2(pred - y) ** 2 + L * cp.mixed_norm(w, 2, 1)\n",
    "    prob = cp.Problem(cp.Minimize(objective))\n",
    "    print(prob.solve())\n",
    "    w_opt = w.value.copy()\n",
    "    model = partial(gated_relu_model, G=G, W=w_opt)\n",
    "    return model, w_opt"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "354e8d3b",
   "metadata": {},
   "source": [
    "Solve it using reweighted least squares"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "48445d76",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_l2_gated_relu(X, G, y, weights, L=0.02):\n",
    "    D, G = get_unique_masks(X, G)\n",
    "    w_opt = solve_l2_grelu_cvxpy(X, D, y, weights, L=L)\n",
    "    # w_opt = solve_l2_grelu(X, D, y, weights, L=L)\n",
    "    model = partial(gated_relu_model, G=G, W=w_opt)\n",
    "    return model, w_opt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "28182902",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_l1_gated_relu_reweighted(\n",
    "    X,\n",
    "    G,\n",
    "    y,\n",
    "    L=0.02,\n",
    "    maxiters=100,\n",
    "    eps=1e-10,\n",
    "    init_weights=None,\n",
    "):\n",
    "    sols = []\n",
    "    D, G = get_unique_masks(X, G)\n",
    "    t = tqdm(range(maxiters), desc=\"Iteratively reweighted least squares\")\n",
    "    n, d = X.shape\n",
    "    p, d = G.shape\n",
    "    # weights = np.random.rand(p, 1)  # * eps\n",
    "    weights = np.ones((p, 1)) if init_weights is None else init_weights.copy()\n",
    "    for i in t:\n",
    "        modelk, Wk = train_l2_gated_relu(X, G, y, weights, L=L)  # .reshape(p, d)\n",
    "        sols.append(Wk.copy())\n",
    "        weights = 1 / np.sqrt(np.linalg.norm(Wk, axis=1, keepdims=True) ** 2 + eps)\n",
    "        loss = model_loss(modelk, X, y)\n",
    "        t.set_postfix(train_loss=loss)\n",
    "    model = partial(gated_relu_model, G=G, W=Wk)\n",
    "    return model, sols"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "bbc27a36",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_l1_squared_gated_relu(X, G, y, L=0.02):\n",
    "    D, G = get_unique_masks(X, G)\n",
    "    n, d = X.shape\n",
    "    p, d = G.shape\n",
    "    w = cp.Variable((p, d))\n",
    "    pred = sum(cp.multiply(di, (X @ wi)) for di, wi in zip(D, w))\n",
    "    objective = cp.norm2(pred - y) ** 2 + L * cp.mixed_norm(w, 2, 1) ** 2\n",
    "    prob = cp.Problem(cp.Minimize(objective))\n",
    "    prob.solve()\n",
    "    w_opt = w.value.copy()\n",
    "    model = partial(gated_relu_model, G=G, W=w_opt)\n",
    "    return model, w_opt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "1544d6f4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def ntk(x1, x2):\n",
    "    \"\"\"ntk.\n",
    "\n",
    "    :param x1: shape (n1, d)\n",
    "    :param x2: shape (n2, d)\n",
    "\n",
    "    Returns:\n",
    "        K: All pairwise ntk evaluations, shape (n1, n2)\n",
    "    \"\"\"\n",
    "    normed_x1 = x1 / np.linalg.norm(x1, axis=1, keepdims=True)\n",
    "    normed_x2 = x2 / np.linalg.norm(x2, axis=1, keepdims=True)\n",
    "    pairwise_angles = np.arccos(\n",
    "        np.clip(\n",
    "            normed_x1 @ normed_x2.T,\n",
    "            a_min=-1,\n",
    "            a_max=1,\n",
    "        )\n",
    "    )\n",
    "    K = (np.pi - pairwise_angles) * (x1 @ x2.T) / (2 * np.pi)\n",
    "    return K"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "a9bc6732",
   "metadata": {},
   "outputs": [],
   "source": [
    "def predict_with_ntk(test_X, krr, train_X):\n",
    "    test_K = ntk(test_X, train_X)\n",
    "    return krr.predict(test_K)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "ec4033cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_ntk_with_ridge(X, y, L=0.02):\n",
    "    K = ntk(X, X)\n",
    "    krr = KernelRidge(alpha=L, kernel=\"precomputed\")\n",
    "    krr.fit(K, y)\n",
    "    model = partial(predict_with_ntk, krr=krr, train_X=X)\n",
    "    return model"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ae9c5673",
   "metadata": {},
   "source": [
    "Computing weights induced by NTK"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "8b6db093",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_cone_probabilities(\n",
    "    X,\n",
    "    D,\n",
    "    mc_samples=int(1e5),\n",
    "    mc_repeats=10,\n",
    "):\n",
    "    n, d = X.shape\n",
    "    p = D.shape[0]\n",
    "\n",
    "    probs = np.zeros(p)\n",
    "    stds = np.zeros(p)\n",
    "    desc = \"Calculating cone probabilities\"\n",
    "    if d == 2:\n",
    "        for i in tqdm(range(p), desc=desc):\n",
    "            mat = (2 * D[i] - 1).reshape(n, 1) * X\n",
    "            mat /= np.linalg.norm(mat, axis=1, keepdims=True)\n",
    "            pairwise_angles = np.arccos(np.clip(mat @ mat.T, a_min=-1, a_max=1))\n",
    "            probs[i] = (np.pi - pairwise_angles.max()) / (2 * np.pi)\n",
    "\n",
    "        return probs, stds\n",
    "\n",
    "    h = np.random.randn(d, mc_samples, mc_repeats)\n",
    "    for i in tqdm(range(p), desc=desc):\n",
    "        mat = (2 * D[i] - 1).reshape(n, 1) * X\n",
    "        ps = (np.einsum(\"ij, jkl->ikl\", mat, h) > 0).all(axis=0).sum(\n",
    "            axis=0\n",
    "        ) / mc_samples\n",
    "        probs[i] = ps.mean()\n",
    "        stds[i] = ps.std()\n",
    "        # print(i, ps.mean(), ps.std())\n",
    "\n",
    "    return probs, stds"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3a447f52",
   "metadata": {},
   "source": [
    "---"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "612d1c5a",
   "metadata": {},
   "outputs": [],
   "source": [
    "las_color = \"blue\"\n",
    "rew_color = \"red\"\n",
    "ntk_color = \"green\"\n",
    "krr_color = \"purple\"\n",
    "\n",
    "lw = 5\n",
    "irlslw = 3\n",
    "ls = \"-o\"\n",
    "\n",
    "SAVE = True\n",
    "# SAVE = False"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "56d04f4d",
   "metadata": {},
   "source": [
    "# 1-D example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "b05b98df",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "def relu(x):\n",
    "    return np.maximum(0, x)\n",
    "\n",
    "\n",
    "def drelu(x):\n",
    "    return x >= 0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "0357eb40",
   "metadata": {},
   "outputs": [],
   "source": [
    "X = np.array(\n",
    "    [\n",
    "        [-2, 1],\n",
    "        [-1, 1],\n",
    "        [0, 1],\n",
    "        [1, 1],\n",
    "        [2, 1.0],\n",
    "    ]\n",
    ")\n",
    "y = np.array([-1, 1, 1, 1, -1])\n",
    "n, d = X.shape\n",
    "oned_xlims = (-2.5, 2.5)\n",
    "oned_ylims = (-1.5, 1.5)\n",
    "eps = 1e-8\n",
    "repeats = 10\n",
    "L = 1e-4\n",
    "\n",
    "xlims = oned_xlims\n",
    "ylims = oned_ylims\n",
    "rew_iters = 10\n",
    "\n",
    "G1 = np.concatenate((X[:, 0], -X[:, 0]), axis=0).reshape(1, -1)\n",
    "G2 = np.concatenate((-np.ones((n, 1)), np.ones((n, 1))), axis=0).reshape(1, -1)\n",
    "G = np.concatenate((G1, G2), axis=0)\n",
    "dmat = (X @ G >= 0) * 1.0\n",
    "test = np.linspace(-2, 2, 100).reshape(-1, 1)\n",
    "test = np.sort(np.append(test, np.array([-1]).reshape(-1, 1))).reshape(-1, 1)\n",
    "Xtest = np.concatenate((test, np.ones_like(test)), axis=1)\n",
    "dmat_test = (Xtest @ G >= 0) * 1.0"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cf32f5bd",
   "metadata": {},
   "source": [
    "## Gated ReLU with cone decomp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "5d3cd237",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Gated objective:  0.00018027958684020427\n"
     ]
    }
   ],
   "source": [
    "m1 = dmat.shape[1]\n",
    "Uopt1 = cp.Variable((d, m1))\n",
    "Uopt2 = cp.Variable((d, m1))\n",
    "\n",
    "yopt1 = cp.Parameter((n, 1))\n",
    "yopt2 = cp.Parameter((n, 1))\n",
    "\n",
    "yopt1 = cp.sum(cp.multiply(dmat, X @ Uopt1), axis=1)\n",
    "yopt2 = cp.sum(cp.multiply(dmat, X @ Uopt2), axis=1)\n",
    "\n",
    "cost = cp.sum_squares(y - yopt1 + yopt2) / n + L * (\n",
    "    cp.mixed_norm(Uopt1.T, 2, 1) + cp.mixed_norm(Uopt2.T, 2, 1)\n",
    ")\n",
    "constraints = []\n",
    "prob = cp.Problem(cp.Minimize(cost), constraints)\n",
    "prob.solve(verbose=False)\n",
    "\n",
    "cvx_opt = prob.value\n",
    "print(\"Gated objective: \", cvx_opt)\n",
    "W1 = Uopt1.value\n",
    "W2 = Uopt2.value\n",
    "\n",
    "\n",
    "############## Cone decomposition ##############\n",
    "W1c = np.zeros_like(W1)\n",
    "W2c = np.zeros_like(W2)\n",
    "\n",
    "for i in range(dmat.shape[1]):\n",
    "    wc1 = cp.Variable((d, 1))\n",
    "    wc2 = cp.Variable((d, 1))\n",
    "\n",
    "    cost = 0\n",
    "\n",
    "    dmatre = dmat[:, i].reshape(\n",
    "        n,\n",
    "    )\n",
    "    ycone = (dmatre * (X @ W1[:, i]) - dmatre * (X @ W2[:, i])).reshape(-1, 1)\n",
    "\n",
    "    constraints = []\n",
    "    constraints += [np.diag(2 * dmatre - np.ones((n,))) @ (X @ wc1) >= 0]\n",
    "    constraints += [np.diag(2 * dmatre - np.ones((n,))) @ (X @ wc2) >= 0]\n",
    "    constraints += [np.diag(dmatre) @ ((X @ wc1) - (X @ wc2)) == ycone]\n",
    "    prob = cp.Problem(cp.Minimize(cost), constraints)\n",
    "    prob.solve(solver=cp.MOSEK, verbose=False)\n",
    "\n",
    "    W1c[:, i] = wc1.value.reshape(-1)\n",
    "    W2c[:, i] = wc2.value.reshape(-1)\n",
    "\n",
    "ytest_cone = np.sum(relu(Xtest @ W1c) - relu(Xtest @ W2c), axis=1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "da24adda",
   "metadata": {},
   "source": [
    "## GD on two layer ReLU net"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "ebec19eb",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Final objbbective for seed : 0.0006657649942653781\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 864x648 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "######### GD Non-convex #########\n",
    "\n",
    "sigma = 0.01\n",
    "mu = 0.01\n",
    "mbp = 200\n",
    "epoch = 200000\n",
    "\n",
    "beta_bp = L\n",
    "obj_bp = []\n",
    "\n",
    "seed = 42\n",
    "np.random.seed(seed=seed)\n",
    "W1bp = sigma * np.random.randn(d, mbp)\n",
    "W2bp = sigma * np.random.randn(mbp, 1)\n",
    "yall = y.copy()\n",
    "for i_epoch in range(epoch):\n",
    "    Xgd = X\n",
    "    ygd = y.reshape(-1, 1)\n",
    "    yest = relu(Xgd @ W1bp) @ W2bp\n",
    "    obj_bp.append(\n",
    "        np.linalg.norm(yest - ygd, \"fro\") ** 2 / (2 * n)\n",
    "        + (beta_bp / 2)\n",
    "        * (np.linalg.norm(W1bp, \"fro\") ** 2 + np.linalg.norm(W2bp, \"fro\") ** 2)\n",
    "    )\n",
    "    gradW2 = relu(Xgd @ W1bp).T @ (yest - ygd).reshape(-1, 1) / n\n",
    "    gradW1 = (\n",
    "        Xgd.T\n",
    "        @ (drelu(Xgd @ W1bp) * ((yest - ygd).reshape(-1, 1) @ W2bp.reshape(1, -1)))\n",
    "        / n\n",
    "    )\n",
    "\n",
    "    W1bp = (1 - mu * beta_bp) * W1bp - mu * gradW1\n",
    "    W2bp = (1 - mu * beta_bp) * W2bp - mu * gradW2\n",
    "\n",
    "\n",
    "print(\"Final objbbective for seed :\", obj_bp[-1])\n",
    "ytest_sgd = relu(Xtest @ W1bp) @ W2bp\n",
    "\n",
    "plt.semilogy()\n",
    "plt.plot(obj_bp)\n",
    "plt.title(\"Train loss for sgd\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7ba192c5",
   "metadata": {},
   "source": [
    "## Kernel Ridge Regression with NTK"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "ec121815",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = train_ntk_with_ridge(X, y, L=L)\n",
    "ytest_ntk = model(Xtest)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f4f80503",
   "metadata": {},
   "source": [
    "## IRLS, Group Lasso, and NTK weighted program"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "id": "e461ac3e",
   "metadata": {},
   "outputs": [],
   "source": [
    "G1 = np.concatenate((X[:, 0], -X[:, 0]), axis=0).reshape(1, -1)\n",
    "G2 = np.concatenate((-np.ones((n, 1)), np.ones((n, 1))), axis=0).reshape(1, -1)\n",
    "G = np.concatenate((G1, G2), axis=0)\n",
    "G = G.T"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "id": "2cbf9510",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "8 2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Calculating cone probabilities: 100%|██████████| 8/8 [00:00<00:00, 17895.70it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sum of cone probabilities = 0.8975836176504335\n",
      "0.00018028779923629838\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 79.43it/s, train_loss=1.78e-9]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error between KRR and NTK on train data: 0.0002627277919425779\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 79.12it/s, train_loss=1.78e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 83.20it/s, train_loss=1.78e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 82.63it/s, train_loss=1.78e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 82.87it/s, train_loss=1.8e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 82.58it/s, train_loss=1.83e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 83.17it/s, train_loss=1.78e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 82.24it/s, train_loss=1.78e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 81.69it/s, train_loss=1.78e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 81.28it/s, train_loss=1.81e-9]\n",
      "Iteratively reweighted least squares: 100%|██████████| 10/10 [00:00<00:00, 83.13it/s, train_loss=1.79e-9]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABTQAAAGbCAYAAAD6Eh8mAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjUuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8qNh9FAAAACXBIWXMAAAsTAAALEwEAmpwYAAEAAElEQVR4nOzdd3hT1RsH8O9Jutt0bzqhpaxSCgVBQMpUfjJFRWSIooAsEXEgDkBlKgqIoigiyBAVEJC9l6IgUlahkzJaunebNsn5/XGTkNU2nWnK+3mePG3OPffc996k7e2bMxjnHIQQQgghhBBCCCGEEGIORKYOgBBCCCGEEEIIIYQQQoxFCU1CCCGEEEIIIYQQQojZoIQmIYQQQgghhBBCCCHEbFBCkxBCCCGEEEIIIYQQYjYooUkIIYQQQgghhBBCCDEblNAkhBBCCCGEEEIIIYSYDUpoEkIIIYQQQgghhBBCzAYlNAkhhBBCCCGEEEIIIWaDEpqk2phgCGPsJ8ZYAmOsgDEmZYylMcaOMsY+YIy1NHWcpsAY44wxbuo4zEFNr1VjvsaNObaqMMZ8lPGXMMb+Zow9YuqYVBhjFoyx2YyxGMZYMWMsizG2lzH2WEO32VD7McY6MsbeYoxtY4wlqd5bjLF2NT1nQgjRxRhLVv5uiTZ1LOaKMRakvIbJ1dxPpLxnvskYK1O2cbx+omxYjLH1yvMZb+pYCCGENF0Wpg6AmBfGWDMAvwLoqiyKBXAYQAkATwBRAHoD+JAxNodzvtQkgRJSD1TJSs45M3Us9cAJwAYAPQF0BrAOQFuTRgSAMWYJYC+AfgCyAPwBwA3A4wAeZ4y9yDnf0BBtNvB+HwAYWp3zIoQQYlZmAJgPIAfA7wCKINxXN2qMsSAASQBucc6DTBsNIYSQhxklNInRGGMeAM4CCABwAsA0zvkVnTpiAE8AeB/AQ9lLk9S71qYOoBKNObZKcc5jAbyg/NAiBUAbxpgr5zzbxKG9CSEReBFAX855DgAwxvoB2AfgW8bYcc55SgO02ZD7/QngMoALAM4DOA0gsBrnSAghpHF7Svn1ac75UZNGUvfmAFgMINXUgRBCCGm6aMg5qY6vISQzTwLor5vMBADOuZxz/geARwF81cDxkYcA5zxWmXxrdBpzbMbinN8FcEP5tIMJQwFjzALALOXTKapEIABwzg8D+B6ANYDX6rvNht6Pc76Ec/4+53wn5/yOsedHCCHEbPgpvyaaNIp6wDlPVd4T5Zk6FkIIIU0XJTSJURhjYXjwSfIUznl5ZfU55wrO+b86bajmgGOMsVcZYxcYY4WMsVydesGMsW+V8zpJlXPNHWCMDTIQV6XzFjHGoiuak8hAPJeUc9tlMMa2MMZaVHpRqoEx1p8x9pVy/rxsxlgpYyyRMbaGMWaw1xVjLIQx9g1j7AZjrIgxls+EOUt/Zoz1rWldZX2jr3E1zrFGbVb3+rNK5qlkjDkwxt5ljP3LhLldixlj/zFh7kKrCvaRMMbmMMb+YYzlKfeJZ4xtYIw9qqwzXvOYGu8dbqhc43m4suwWY8zgMHUmzF0pY4zlMsZsans+deQ/5deIejyGMR6FMDQ7mXP+l4HtW5VfqzM0u6ZtNvR+hBDSKDHG2jFhjsQUjb/3f7AK5uGs4T3QceXfz2jGWD/G2EHlvpwx1oFp3P8xYS7KmYyxq8q27zPG1jHGPOvqHJT7dGSM7VH+vS5kjP3FGHumelfvwbkBCFYWac6THK17/hW0oZr7NKiicsbY/xhjp5T3D/mMsf2MsY6VxOXJGFuofJ0KlfvFKl+ndso68yAMNweAQJ37oWSNtiqcQ5MxZqV8vc5r3NvEMMbeZ4w5GKg/XtnWesaYE2NsBWPstvJ1S2CMfciEDw9197NljE1nwv1dhvK9cY8xdpIx9m5F14EQQoj5oCHnxFj/A8AA/Mc5v1rLtlYDeAXAKQC7IfT6BAAwIYG0D4AjgDgA2wF4A+gLYABjbDHnfE4tj6/rcwDTIPQ8vQagC4DnIMxt95ihnqg18DWAZgCuAjgGwBJCsmgSgGcYY49yzlW94sAYaw/gDAAHZUz7IFx/fwDDIcy3dKS6dZX16/wa17LNOrn+jDF/AIcAhAFIU7bHIcz3ugzAk4yxxznnZRr7BAM4CCAEQB6E92QRhKG9IwEoIEyzEA/gRwAvKHf90ZiYOOeXGWMXAUQCiIbw2usaA0AM4GfOeWltzqcuMMYkEJJwgOkTmpHKrxcq2K4qb8EYk3DOC+qxzYbejxBCGh3G2BgIcyxbArgE4BwAXwhzAg9kjE3hnK/R2a1a90A6ngMwUXms/RDubRQ6dTYCGAbgOIR7kO4AXgTQmTEWxTmX1vYcmPDh8B8QetRfUT6CAGwDsKKC2CuyH0AygKcB2AP4DUChcltaNduqyCQAb0G4h9kHoCOE8+vBGOvIOb+pWZkx1gnCXM+eANIhzI9fDqA5hHv2NAjn/J8y3hEQ7pd+1Wgms6qgGGO2AA5AmK+7AMBR5XGiASyA8H7owzk31JYzhOlYXCHcrzkr25kH4f01UeM4IuX5RAPIhXCfnA/AB0AbCPeaC6uKlxBCSCPHOacHPap8QLhZ5AC+q0UbXPnIBhBpYLsNgNvKOp8AYBrbHoVw48MBDNQoD1KWJVdwzGjl9uOVxFMI4FGNcjGANcpt/9bkHA2UDwXgpFMmhjAZPAewX2fbD8rytw205QqgYw3rVvsaG3HONWqzptff0DWGkMD9S7ntUwDWGtucIfzzwAEs0CgXQbgx5wA2A5DotOkOoIcxr28Vsb2mLP+hgn1ilNu71+Z86uoB4BuN1+ZiNfY7rrGfsQ+9n0udNpcr631eSZ08ZZ12RsZZozYbej8DdZKrc570oAc96GHMQ+N3S7QRdTsAKIOQIOqrs60rhA9QywCE6Wyr1j2Qcrvm35TxBrYHaWy/CcBfY5snhGHcHMC42p4DADsA95TtvauzzzMA5KjkXtSIax9UyfkbfF0q2lejvARAL41ySwA7lNvW6ewjAXBXue0zAFY62/0BdDJw7Ss8XwDrDb12EO5pOIT7L0+NckcIyU0O4QNezX3Ga7zW2wHYaGx7BIAMQpI7SKO8l7L+eQD2Bt57fUz9s0cPetCDHvSo/YOGnBNjuSu/ZhjayBgbqRwKovWooK2lnPOLBsqfhTCf0A0A73POuWoD5/wshJssAHijRmdQsa+U7auOJVceIwtAJGOsZ20PwDn/nevMI8SF+UY/hHAT2V/ZM05FNUzqgIG2srn2cP7q1K2Pa1zbNuvi+g+EcFN7AsCbXKM3Buc8F0JPjTIAUxhTD/0eCqGHyA0AL3CdnnGc80zO+Wkjjl2VzRButkcwxuw0NzDGOgAIBxDPOT9Ty/OpNcZYfwg9HG4ri9owYYVuY+yH0HO1Oo/9VbSpGnpWVEkdVa8WSSV16qLNht6PEEIam3chJMZe55wf0dzAhSk1PlJun6Szrbr3QJoOcM7XVxHXDM656u8WOOfpeDCPe+86OIenIfTsuwpgkc4+vwDYWUV8prCCc35C9YQLU0V9onyqe01ehtBD9Sjn/A2uM/KDc36bc17RKAOjKXtnTlY+nap8nVTHyIdw/yEH8DRjLMBAEwUAJnGN0Syc83MQ7iUYhCSmiure+DTnXOvvr/K919QWYSKEkIcSDTkndaUzHgzH1TTeQNnOCtp4TPn1J8657nAiQBge9CGA7owxsTLxVRc26RZwzosYYzsg3OQ9BmFoS60wYZ6oJyGs/i6B8AkxINw4iyAMe1Yles9DGOb/FWPsfQCndG8wNVSnbn1c49q2WRfXf6Dy66+aCVWN9lIZY3EA2gIIhdCb4wnl5o28ijlha4NznsEY2wdgMIQpADTPd5zy6wad3WpyPrXCGHME8B2EfyaeAbAHwgcZrSCstl0pzvni2sZACCGkcVIO4X0cwt+I7RVUO6n82tXA/tW5B9K0s4rQyiEMj9alGsLuqxFDTc9BlSjbYuhvMoRRTE8ZKDelfQbK9K6Jkup+aF39hQMA6ARhiH2Czoe4AADOeTxj7CSEhGtP6N8fXuCcG+pYcQPCe0vzvC5CeJ1fYozFAtiumUAlhBDSNFBCkxhLNZeNu6GNnPPZAGYDwkImED5FrcitCsqbKb8mVbD9DoReaTYQFtmoqxuT5CrK/SrYbjTG2McA3sGDG3hDHDW+Xwphfp8nINyoSxljFyAMx9nAOY+rYd36uMa1bTO5gv1U5cZc/+bKr6sYY6uqqOsBIQGo+vS/onm76tKPEBKa46C8QWeMiQE8D2FI1Ead+jU5n9r6DMI1Wcg5P8cY+w9APwjD86pMaNYTVc9F+0rqqHpAGjv3ZE3bbOj9CCGkMXHDg/uU3CoGB3hoPqnBPZCmiu4ZVdI45zID5arfp9YaZTU9B9V9TnIFdSsqN6XbugWc8wLlOesuKthQ90NV3S8CwlQBvTXqatI7JyW911qZHH0NwhD3rwF8zRiLh/AB+W8A9laQnCaEEGJGKKFJjHURwuIlnWrbEOe8pPbhGM3k0yowxp4GMBfCZOQzIUyIn6oaRswYOwugG4ThMgCEHooQJqaPgvCpcy8IvQUeBTCHMfYq53xtdes2Yap/ko6i4htelSzl14a8kd0NYV6uvowxH855KoABALwAnOCcJ+vUr8n51BhjbACE3rAxEOY0A4Sf+X4QhuXrJlwNtfEOhN6c1RFbRc9O1T+y/hUcU4IH/5xW9U9vbdts6P0IIaQxUf1dKgOwpYq66gVdanIPpKOqe0ZDI0MqUqNzaKSqur+tznUxl8Redc4JnPPVjLHfAAyCsEhlTwhT9rwI4Ahj7IkKkuGEEELMBCU0ibH2QviUM5Ix1ppzfr0ejnFX+bV5Bdv9IHyqXAphYSFAuCkFHvRw0mUwiaAjEEIiR1eQTlw19bTy61zO+Q8GtodUtCPn/DyEIeVgjNlAmF/oCwArGWPbNOekMrJuTa5xVWrbZl1cf1XSbzPn/Hsj6gNAivJrSyPr1xjnvIwxthXAqxA+GFiGB8PNDa2YXpPzqRGNoeblEBZPUP1M/af8GmFkU09Ae/4qY5wAUFlCUzX8sKIPUlTlibpzoNZDmw29HyGENCaZEP6OW0KYx1BaRX2VGt8D1YOanoPqPiSwgu1BtYzLkArvbxljFhDm9KwrKQBaQ7gfOl+H7eqq6n5Rc1tt770BAJzzNAj3ON8BAGPsEQjJ7L4AJkBYCJEQQoiZMnnvNWIeOOexeDCP0WrlzVRdU81bNFo5z5GuF5Vfz2h8opoJIRHjxhgzNBx+gBHHfV63QLl4y1CduGrKVflVr6cdY6wvdIZmVYRzXso5XwkgHsLw7QoTcZXUrck1rkpt26yL669aXObpSmtpO6j8OrYaC9+UA+p/JqpLlbgcq0wiDgVQDOBXA3Vrcj419TmExP8CzvkljfL/lF+NSmhyzqM556yaj+gqmj0LoQdqEGNMb042AM8pv+40JsZattnQ+xFCSKOh/Pt9GEIvx2HV2LVO7oHqQi3OQXUf8lwFC/GNrmVohtxTfg0zsK036rZTiup+6CUj66uSrdWN4QKEBfKaM8a6625kjLWA0ItSgTqYu94Q5SJC3ymftq+PYxBCCGk4lNAk1TEZwnyIvQEcZIy1raCe3k2KkX6B8IlsGID5mjeNyk9UVatkL1eVK3uTqSYW/0CzMcbYOACjjDjuVM1Eg3Juw2UQbrIvofY3VbHKr69oJs4YY0EQ5vXRwxibwhgLNVAeDqGHgALCa1GtuqjBNTZCbdusi+u/A0JPuCcYY58rE4ZaGGNBjLExGkW/Q+gZ2grAOuXcr5r13RljPXSaUfUYaG1ETFqUN9E3IKxq/gkAWwA7KuiVV5PzAWNsHmOMM8aOGxMTY+wJCP/A/AOdlVuVsZYA8GCM1WVPEKMp//lUvW9WM8acVdsYY/0g9K6QAlihuy9jbANjLJYxNq0u2mzo/QghpBFaAEAGYRHCYbobGWNixlhvnQ9vqn0PVM9qcg6/AkiD8Pf7LZ36T6F+FgQ6pvw6hTGmWrEbjLEQAFXNrV1d3wFIhTAtzhLGmNYcm4wxf8aY5iiDDAhJTS/GmIuxB1FOOaXqEfklY0ydzFZOv/INhCTpr5zzFANNGI0x1ocxNlD3A2jlufVXPq3VMQghhDQCnHN60MPoB4SJw/+GMN8OB3ANQvJlMx7M98chJNE26OzLhbdcpe13B5CnrBurbPcIhJtPDmCRgX16Qeg5xyEkqH5Rfi2HkBjjAI4b2E91DiuU7R+BMAwlXlmeA6B9Na+P3jlCGE6lOqdkANsg9MArgTDk9oxyW7TGPv8py+KU13cTgOMa57m0JnVreo2NOO+avG41uv4VvY+U782ryu25ymu7CULi8qay/C+dfVpAmIBedbzdALYC+AtCkmm9Tv3lyrrpynrfAfjO2Pc4gHc1zpsD6F/Fz1p1z2eBsvyQEa+ZE4Sf1xIArSqoc07Z3hMN8fulghgsARxSxpEJ4ef7CITVSxUAXqhgv+PKfebVYZsNth+E+XD/0nhIlftf0ij7ylSvCz3oQY+m8YBwX6K6n/urgschjfqjIQzb5hD+Xu/Bg7/52cryyRr1q30PpNzvuKFyje1BqjYr2B6Niu//qnUOyn36a+wTo6x/Fg/uYyqMxYhrH2RgmzWEBfk4hATiTghJzmLlsQ3uW1mbyu0V3UN1UR6HQ0jeblf+rbqg/Fs1T6f+do3XdBOE+6HFGtvXK7eP19nPFkKPV658X+xUHkd17MsA3HX2Ga/ctr6Cc5oHnb/3EOZrVd3bHcaD+6d0ZfkNAM6m/vmjBz3oQQ961O5h8gDoYX4PCBO3D1PeUCVCGD4iVd4AHYeQVAk1sF+VCU1lveYA1kJYIKNMeXN5EMCQSvbpC6EnXxGEiecPQ0iyRaPqhCYDME15E1UCIeGwFUBIDa5NRTeKIXjQk7EEQtJvHoQb1uPQT2gOgvBJ9X94MOdTMoSE20Cdto2uW5trXNevW02vf2XvIwg3yq8BOK28iS1TXvM/AXwEwwlSJwAfQkgUFSkfcRBuxrsaaP8zCO/7Mt1YqnqPQxjaLVfWuwNAVMU1rdb5KF9zDuA5I16vdcq6syqps0ZZ552avi/q4gEhIfgmgCvK90gOgH0AHqtkH9XP1by6arMh98ODf+Aqexw35etCD3rQw/wfeJAAq+yRq7NPKIDVEJJCxQAKlX83dwF4BYCrTv1q3QMp9zFYrrE9CDVMaNbkHJT7RAH4A0IirhDCB/yjqorFiGsfVMF2Twh/q+9DuM+OBTAbwgg7g/sa0WZl91A+EObLj1W+TvkAriuvUxudum4Qkpi38eAD9GSN7ethIKGp3GYF4HUIydJC5bGuQBhp5WCg/nhUP6EZAmGRw2PKGEshJDP/UV5DR1P/7NGDHvSgBz1q/2CccxDyMGKMCXd2nFe0siZpZBhjthD+8SjmnNubOp7GRDmsKhtC783OnH65E9JoMMbmAOgIYRGoYAC3OOdB1WwjGRUvSuLBOW/sqzITQgghhBBSZ2iVc0KIOemi/HrTpFE0Tl0ASCD0pqRkJiGNy0IIHzj8C8C5Fu3EQpiDV5ehuXgJIYQQQghpsiihSQhp9BhjAyAsStVPWfRjJdUfSpzzsxCG7xNCGp8WnPNEAGCMXQHgUEX9itznnP9Ud2ERQgghhBBinmiVc0KIOWgDYAiE+TXfA7DStOEQQojxVMnMusAYs2CMOdZVe4QQQgghhJgjmkOTEEIIIaSBqHpo1nAOTS8AYgiLTOVBWLV3Duf8Xh2HSQghhBBCSKNGQ84JIYQQQhq/qxBWFb4OIaEZDeBlAH0ZY10oqUkIIYQQQh4m1EOzAbi7u/OgoKA6bbOoqAj29rTIc0Oh692w6Ho3LLreDY+u+QMXLlzI5Jx7mDqOhlLTHpoVtPU8gE0AvuOcv1JBnYkAJgKAra1tJ39//9oetsEpFAqIRDRLUkOga91w6Fo3HLrWDcscr/fNmzcfqnsRQpoKSmg2gKioKH7+/Pk6bfP48eOIjo6u0zZJxeh6Nyy63g2LrnfDo2v+AGPsAuc8ytRxNJS6TGgq20sCYM05962qbn3cjzQE+nlpOHStGw5d64ZD17phmeP1ftjuRQhpKszroxNCCCGEEKIpGYC7qYMghBBCCCGkIVFCkxBCCCHEfIUAuG/qIAghhBBCCGlIlNAkhBBCCGkkGGMBjLFWjDFLjTLXCupOBeAHYHdDxUcIIYQQQkhjQKucE0IIIYTUI8bYWACByqceAKwYY+8pn9/inG/UqL4BQC8AwRCGkwPAOMbYBAD7lWUWEFY5HwYgAcCH9Rc9IYQQQgghjQ8lNAkhhBBC6tcECElKTR8pv54AsBGV+wdAHwAjISREGYAkAEsALOac59ZZpIQQQgghhJgBSmgSQgghhNQjznl0bepyzs8AGFKHIRFCCCGEEGLWaA5NQgghhBBCCCGEEEKI2aAemoQQQgghhBBCCCGVuHDhQqiFhcW7jLEIzrkzqIMYIfVFwRhLk8lk8zt27HigokqU0CSEEEIIIYQQQgipwIULFwZaW1uv9Pb2hqOjY5GlpWU2Y8zUYRHSJCkUClZSUuKUnJz85b///jutoqQmfaJACCGEEEIIIYQQUgFLS8u3goKCyt3d3fOsrKxklMwkpP6IRCJub29fEhQUVGZhYfFhhfUaMihSN8rKypCWlmbqMAghhBBCCCGEkCaPcx5kb29fbOo4CHmY2NralnLOvSvaTkPOzQjnHFu2bEFCQgISEhIwaNAgODg4mDosQgghhBBCCCGkKWPUK5OQhiUSiTgq6YhJPTTNCGMMZWVlkMvlAID4+HgTR0QIIYQQQgghhBBCSMOihKaZCQkJUX8fFxdnwkgIIYQQQgghhBBCCGl4lNA0M6GhoervExISoFAoTBgNIYQQQgghhBBCCCENixKaZsbT0xOOjo4AgNLSUty5c8fEERFCCCGEEEIIIaQpKS4uZosXL/bo2rVrSxcXlwgLC4uOEomkQ7t27Vq/+uqrzS5evGhj6hjryogRI4IYY51SU1NpnRkzQi+WmWGMISQkBDExMQCEeTQDAgJMHBUhhBBCCCGEEEKagmvXrlkNHjw4NDEx0aZz586FkyZNuu/j41NeWFgovnTpku3WrVvdv/32W+/4+PiY4ODgclPHSx5OlNA0Q5rDzuPi4tCnTx8TRkMIIYQQQgghhJCmoLCwkA0aNCj09u3b1j/++GPCuHHjcnXrFBcXp3z00UdeVa38LpVKmVwuh52dHa+veMnDi4acm6HmzZtD9YsjNTUVhYWFJo6IEEIIIYQQQggh5m7FihUeSUlJNpMnT75vKJkJAHZ2dnzRokVpQUFB6t6Zs2bN8mWMdTp//rzNyy+/7Ofl5dXezs6u49GjRx0AIDU11WLs2LEB3t7e7S0tLTt6e3u3Hzt2bEBaWppYs21VOzdu3LDSPW6zZs3Cu3TpEqZZxhjrNGLEiKCdO3dKIiIiWtna2ka6u7tHvPjii/55eXl1mvM6duyY3YgRI4KCgoLa2draRtrb20d27Nix1YYNG5x168bHx1s+88wzQb6+vuFWVlYdXV1dIyIjI1utWrXKTVVHLpdjwYIFni1btmxjb28f6eDgEBkUFNTu2WefDZRKpVrZ4o0bNzp37Nixla2tbaSdnV1kx44dW/300096x32YUA9NM2RtbQ0vLy/18/j4eHTo0MF0ARFCCCGEEEIIIcTs7dy50wUApk6dmlGT/ceMGdPcxsZGMWXKlDTGGPz9/cuysrLE3bp1a5WSkmL9zDPPZEZGRhb/999/dps2bfI4c+aM5MKFC9ddXFxqvOLx5cuX7Z5//nmXUaNGZY4aNSrrxIkTkvXr13vGxsbanj59+qZYLK66ESP8+uuvLvHx8TZDhgzJDgwMLMvKyrLYunWr2wsvvNCiuLg4afLkydkAUF5ejv79+7dMT0+3GjduXHrLli2leXl54suXL9uePn3aYfr06VkA8M477/h8+umnvr1798576aWXMsRiMU9KSrI+cOCAc2lpKbO2tuYAsHjxYo85c+YEBAcHl86aNSsVALZs2eI2duzYFmlpabdmz56dWScnaGYooWmmmjVrhqysLADCsHNKaBJCCCGEEEIIIQ2nTx+EmDqGqhw9ivjq1I+Li7N1cHCQt2rVqkyzXCaTISMjQyuHJJFI5A4ODlrDyR0dHeVnzpy5YWlpqS6bPn16s1u3blkvWrQo5Z133lEnSiMiIorffffdgHnz5nmvWLHiXrVOTCfmDRs2JIwdOzYXAN55552MF1980X/9+vWe33//vcvEiRNzatq2pkWLFqU6Ojre1SybM2dOenh4eJtly5b5qBKa//77r21ycrLN3Llz73z88cf3K2rvjz/+cG7evHnp0aNHdV8j9TEyMjLECxYs8PP395eeP3/+uqurqwIA3njjjfSIiIg2H374of/48eNz3N3d5XVxjuaEhpybqWbNmqm/T0hIgEJR4w8zCCGEEEIIIYQQQlBYWCiyt7fXSzBcvHjRxtfXN0LzsXTpUk/detOnT7+vmcwEgL179zq7uLjI3njjDa1en7Nnz85wcXGR7d2716U2MQcFBZWqkpkq8+bNSwOA33//vVZta3J0dFRfl4KCAlFaWpq4sLBQ1L179/zExESb7OxsEQC4uLjIAeDkyZOOd+/erbAjoUQikaenp1seOHDAoaI6v//+u2NJSYlo4sSJ6apkJgC4uroqJk6cmF5cXCzavXu3Y92coXmhhKaZcnFxgaOj8J4tLS3FnTt3TBwRIYQQQgghhBBCzJmDg4OiqKhIL1cUFhZWtmPHjps7duy4+cEHH1SYgGjTpk2pbtndu3etg4ODS3UTnZaWlggODi69c+eO3nyZ1RESEqJ3zMDAwHKJRCK/deuWdW3a1nT37l2LUaNGBbq5uUU4OjpG+vj4dPD19Y3YvHmzBwBkZWVZAEDLli3Lpk+fnnrmzBnHgICAiLZt27aePHmy34kTJ+w02/vkk0/uWllZ8SeeeCLM09Oz/ZAhQ4LXrFnjWlpaqp4/MykpyRoAwsPDS3TjUZUlJCTU6vqZK0pominGGEJCHvRuj4uLM2E0hBBCCCGEEEIIMXehoaElhYWF4tjYWK0kmaOjo2LYsGEFw4YNK+jcuXNxRfs7ODjUavgoY6zCFdFlMlnly6rXI4VCgb59+7b87bff3J555pmstWvXJv76669xO3bsuDl48OBsVR2VlStX3rt8+fLlBQsW3A4MDJRu2bLFPTo6uvWrr76qHm7br1+/osTExMs//PBDwhNPPJF77do1u1dffTW4bdu2be7fv183E382YZTQNGOhoaHq7+PjqzUtBiGEEEIIIYQQQoiWYcOG5QDA6tWrPeqqTT8/P2lSUpJNeXm5Vnl5eTmSkpJs/Pz81PN1urq6ygHozddZXFzMMjMztbt4KsXHx9volt26dcuyoKBAHBgYKK2Lczh37pztjRs3bKdOnZq2Zs2aOy+//HLOiBEj8ocNG1agUCgMJlrbtGlTNnfu3PS9e/cmpqamXoqKiipcs2aNt+YwdCcnJ8X48eNzN2zYkBIfH3910aJFKYmJiTZffvmlOwC0aNFCCgCXL1+21W3/ypUrtso6ZbrbHga0KJAZa968OUQiERQKBVJTU1FQUACJRGLqsAghhBBCCCGEkCavugvumIPXXnst4/vvv/dYs2aNV+fOnYvGjRuXq1uH8wo7URo0cODA3C+//NL7888/93jrrbfU82guX77cIycnx2Ls2LHqslatWpUCwP79+yU9evRQ9wT96KOPvCpaOyQ5Odlm48aNzprzaM6fP98bAIYMGaIXf01YWFhwQP/c//nnH5uDBw86a5ZlZWWJHRwcFKpVygHAzs6Oh4aGlpw/f94hMzNT3KxZM1lqaqqFj4+PTHNfVe/X7OxsC2X8+ba2toq1a9d6Tp06NVO1GnxOTo5o7dq1nnZ2doohQ4bk18U5mhtKaJoxa2trBAQEIDk5GYDQSzMyMtK0QRFCCCGEEEIIIcQsOTg48D179sQNHjw49IUXXmixevXqgj59+uR7e3uX5+fni2NjY2327NnjKhaL4e/vb1TPwHnz5qXt3r3bZc6cOQEXL16069ChQ/F///1nt23bNvegoKBS1QI+ADB06ND8oKCg0mXLljXLysqyCA4OLjtz5ozDxYsX7Z2dnWWG2g8NDS2ZNGlS8PHjxzNDQ0NLT5w4Idm/f79L586dC19++eVsY8/9k08+8bKzs9PLmvbv3z+/d+/eRSEhIaVff/21d3FxsSgsLKz05s2bNps2bfJo2bJlydWrV9XzY+7du1fy2muvBQ4cODAnLCys1MHBQXHhwgW7bdu2ebRv374oIiJCCgBt2rRpGxkZWRQVFVXk6+tblpqaarlx40YPS0tLPmbMmGwAcHd3l3/wwQd35syZExAVFdV61KhRmQCwZcsW95SUFOtly5bdcnNze+hWOAcooWn2QkNDKaFJCCGEEEIIIYSQOtGmTZuyS5cuXVu1apX7zp07XdasWeNVUFAgtrW1VQQGBkpHjRqV+eqrr2aoEnNVcXNzk589ezb2rbfe8j106JDzL7/84ubm5iZ7/vnnM5YuXXpP1esQACwsLPD777/HT506NWD9+vWeFhYWvGfPnvknTpy40aNHj1aG2g8PDy9eunTp7Q8++KDZpk2bPOzt7eXjxo1L/+KLL+6KxcZPRbl69WpvQ+UWFha8f//+RX/88Ufca6+95vfLL7+4lZaWikJCQkq/+uqrpP/++89OM6HZuXPn4ieeeCLnzz//lPz+++9ucrkcPj4+ZdOmTUt9//3376vqvfrqq/cPHjzo9N1333kWFhaKXV1dZZGRkYVz585N69atm3oRoHfeeSfD19e3/PPPP/f+7LPPfAGgVatWJRs2bEjQXd39YUIJTTMXGhqKQ4cOAQASEhKgUCggEtHUqIQQQgghhBBCCKkZBwcHPmfOnIw5c+ZkVF0bWL58+b3ly5ffq2i7r6+v7KeffkoBkFJVW+3bt5eeOnVKb+Xju3fvXq5oH+WCRbHGxKrrt99+SwaQXFW9li1blu3bty9Rt3zcuHG5mufeqlWrss2bN1d5ngsXLkxbuHBhWlX1VMcwNPz/YUaZLzPn4eEBR0dHAEBpaSnu3Llj4ogIIYQQQgghhBBCCKk/lNA0c4wxrdXO4+L0PsQghBBCCCGEEEIIIaTJoIRmExASEqL+nhKahBBCCCGEEEIIIaQpozk0m4DmzZtDJBJBoVAgLS0NBQUFkEgkpg6LEEIIIYQQQgghpN5wzi+YOgZiGtRDswmwtrZGYGCg+nl8fLwJoyGEEEIIIYQQQgghpP5QQrOJ0Bx2TglNQgghhBBCCCGEENJUUUKzidBcGCghIQEKhcKE0RBCCCGEEEIIIYQQUj8oodlEeHh4wNHREQBQWlqK27dvmzgiQgghhBBCCCGEEELqHiU0mwjGmFYvTRp2TgghhBBCCCGEEEKaIkpoNiGaCc24uDgTRkIIIYQQQgghhBBCSP2ghGYTEhwcDLFYDABIS0tDQUGBiSMihBBCCCGEEEIIIaRuUUKzCbG2tkZAQID6OQ07J4QQQgghhBBCCCFNjYWpAyB1KzQ0FElJSQCEYeeRkZEmjogQQgghhJC6IVPIUFhWiMKyQpSUl0Aql6JUVooyeRnkCjnkXA4FVwAALEQWEDERxEwMGwsb2FjYwNbSFrYWtpBYS2BrYQvGmInPyLQ45yiRlaBAWoASWQlKyktQKitFqaxUfS3lCjk4uPpaikViWIosta6pg5UDHKwcYCGify8JIfVn5cqVbq+99lrQ7t27bw4aNKigojLycKC/OE1MSEgIDh48CABITEyEQqGASEQdcQkhhBBCSOPFOUduaS7Si9Jxv+g+0ovSkVmciZySHGSXZCOnNAf50nyUyErq7JgWIgs4WjvC2doZ7nbu6oeXgxd8Jb7wlfjCztKuzo5nCsXlxbhXcA/3Cu7hfuF9ZBZnqh+50lzkS/MhU8jq7Hg2FjZwtHKEq60rXG1d4WLrAnc7d3jae8LL3gue9p5wtnF+6BPJhJiD4uJitnLlSvedO3e63Lhxw7agoEBsa2urCAwMlPbs2TN/4sSJWZGRkaWmjrOhLViwwNPZ2Vk+Y8aMLGP3YYx10vgetra2ChcXF1nr1q2LBw0alDthwoRsBwcHXj8RNx5nz561/fXXX10mTZqUGRYWVlbb9iih2cR4eHjAyckJeXl5KC0txe3btxEYGGjqsAghhBBCCIFMIcO9gnu4lXsLKXkpuJN/R0i4Fd5Dqaxh/y+WKWTILslGdkk2EnMTDdZxtnFGgGMAgl2CEeQchGDnYAQ6Bza6nogyhQy3cm8hKTcJybnJSM5Nxq28W8gtzW3QOFS9O9OL0yusY2NhA18HIWHs5+iHAKcABDgFoJljs0Z3XQl5WF27ds1q8ODBoYmJiTadO3cunDRp0n0fH5/ywsJC8aVLl2y3bt3q/u2333rHx8fHBAcHl5sy1ilTpmS9/PLL2dbW1g2SEPzmm2+8mjVrVladhCYAtGrVqmT69OlpAFBcXCxKSUmxOnbsmNPMmTODPvvsM5+ff/45oVu3bnX3qV0jdP78ebvPP//cp0+fPgWU0CR6GGMICQnBhQsXAAjDzimhSQghhBBCGlpJeQkSchKQkJ2AxJxEJOYk4nb+bci53NShGS23NBe5pbmISY9Rl1mKLNHCpQVaurVEK/dWaOvZFq62rg0aV05JDq6kX0FsZixuZt1EQk4CyhUmzSkYrVRWisTcRL0kspiJ4e/oj+YuzdHcpTlauLZAC5cWsLW0NVGkhDycCgsL2aBBg0Jv375t/eOPPyaMGzcuV7dOcXFxykcffeRVVW9rqVTK5HI57Ozs6i3ZaGFhAQsLi0bfu9Hb27tsypQp2TrF99atW+cyadKk4KFDh4ZevXr1qoeHh/n8kTQxGovcBIWGhqq/p4WBCCGEEEJIfeOcIyUvBfvj92PluZWYtncaRv46EnOOzMF3F7/D0eSjSM5LNqtkZkXKFeWIzYrFrpu7sPTsUryw8wVM2j0Jq86twumU0yiQ1v0UbgXSApxOOY1V51Zh8p7JGLdzHJaeXYpdN3chNivWbJKZlZFzOZLzknE0+Si+u/gd5hyZg5G/jsTUP6Zi5bmV2B+/H7dyb4HzRp+3IMSsrVixwiMpKclm8uTJ9w0lMwHAzs6OL1q0KC0oKEj9y2fWrFm+jLFO58+ft3n55Zf9vLy82tvZ2XU8evSoAwCsXbvWpU+fPiE+Pj7hVlZWHV1cXCL69evX4ty5cwY/tfjss8/cg4OD21pZWXUMCAhot2DBAk9DP/8rV650Y4x12rNnj0SzvKSkhL3zzjveISEhba2trTtKJJIOffr0CTlz5ozW8fbs2SNhjHVauXKl24oVK9xCQkLaWllZdfT19Q1/7733vDTrMsY63bt3z+qff/5xYIx1Uj1u3LhhZez11fXSSy/lvPrqq2kZGRmWy5Yt89TcplAosGTJEo+2bdu2trW1jbSzs4t85JFHWu7evVui286XX37pFh4e3loikXSwtbWN9PPzCx8yZEjwvXv3tDoyXrlyxfrpp58O8vLyam9padnR09Ozfd++fVucOnVKa46VkydP2vXv37+Fi4tLhJWVVcegoKB2b7/9tnd5ufbfmy5duoQ1a9YsPDk52XLw4MHBjo6OHWxtbSN79OgRGhMTY62qN2vWLN/XXnstCAAGDx7cUnXtRowYEVTTa0c9NJug4OBgiMViyOVypKWloaCgABKJ3vudEEIIIYSQGpEpZEjITsDl9Mu4mn4V1zOvo6i8qN6Py8DUC9DYWtiqF6axtrCGmImFhWtEYgBQLxIkU8gglUlRIhMWvCkqL0K+NB9l8lqPdlO7VygMmz+YeBAMDC3dWqKjT0d09euKYOfgas8ZyTlHUm4Szt05hwupF3Az6yY46ieRZyW2gqO1I+wt7YVFfixsYW1hDQuRhXoRIEC4ngqugJzLIZVJ1cPLS2Ql6oWa6jpGDo6U/BSk5KfgUOIhAIC9pT1au7dGW8+2CPcMRwvXFjRUnZA6tHPnThcAmDp1akZN9h8zZkxzGxsbxZQpU9IYY/D39y8DgDVr1ni6uLjIxo4dm+nt7V2ekJBgvWnTJo8+ffq0+uuvv66Fh4dLVW0sWLDA88MPP/QPCwsrmTNnzt3i4mLR6tWrvd3c3Iz69EYqlbLo6OjQixcvOgwfPjzrlVdeSc/LyxNv3LjRvV+/fq0OHDhw47HHHivW3Of777/3yMzMtBw9enSms7Oz7Oeff3b75JNP/Pz8/MonT56cDQCrV69Omjt3rr+Li4ts9uzZqap9fXx8ajUZ8dSpUzNXrVrlc/DgQaelS5eq2x0+fHjwnj17XJ944omc0aNHZ0qlUtEvv/ziOnz48JY//vhj/OjRo/OUcblOnz49qFOnToVvv/32PVtbW8Xt27etDh8+7HTv3j0LX19fGSAkKZ988smWMpmMPfvss5nt2rUryc7Otjh9+rTk5MmTDj179iwGgK1btzqNGzeuRUBAgHTy5Mn3XV1dZX/99ZfDp59+2iwmJsZu3759Wl3si4uLRY899lhYZGRk0dy5c+8mJSVZr1u3znPYsGEhN2/evGphYYGRI0fmpKWlWW7ZssV92rRpaa1bty4BgJYtW0pRQ/SbvwmytrZGQECAerXz+Ph4Wu2cEEIIMSHG2BwAHQF0AhAM4BbnPKgG7YwD8DqAVgDyAewGMIdzXqN/OghBUhKwciWwaRN65uUBTk7A6NHAjBlAcLC6mirB9l/af7iUdgnXMq/V+ZyXNhY28Lb3hqe9JzztPeFh7wE3Wze42LrAxcYFzjbOcLByqLMFZUplpciX5iOrOEu9UE5GccaDRXSK7qtXTK8ODo4bWTdwI+sGtlzZAg87D3T164qecj+02nIQbNNmg9dawRW4mn4Vf975E3/d+QsZxbX/sRYxEbzshUWOfBx84GnvqV78yM3ODY7WjrCxsKn1cQDhPVJYVog8aZ6wkFNJDrJKspBRlIH0onSkF6UjrSit1u+bovIinE89j/Op5wEI75s27m0Q4R2BDt4dhARycrJR72tC6srs2bN9vvjiC9+6aEsmk12obLuFhUWnyrYDwMyZM+99+umnqVXVMyQuLs7WwcFB3qpVK61PfWQyGTIyMrRySBKJRK67mI2jo6P8zJkzNywtLbXaPXbsWJyjo6PWL9UJEyZkde3atc2SJUu8fvrppxQAyMzMFC9atKhZ8+bNS//5559YiUSiAIDJkydnhoeHtzPmHBYvXuzx999/S3799de4ESNG5KvKZ8+end62bdu2s2fP9v/7779vaO6Tmppqdf369atubm5yAJg+fXpWQEBA+Jo1azxVCc0pU6Zkf/LJJ83c3d1lBoaP11hYWFiZvb29Ijk5Wf0LecOGDc67du1yXbZs2a3Zs2dnqsrfe++9+5GRka3feuutgFGjRl0WiUT4/fffXezt7RV//vmn7nW/p/pGoVBgwoQJwWVlZaKTJ09ef+SRRzTn60yTy4URFMXFxWzatGlB7du3L9JpL3P+/PnF8+bN89+zZ49Ec0X53Nxci6lTp6Z9/PHH91VlHh4e5R9//LHf77//7jhixIj8Rx55pKRr166FW7ZscX/88cfz62JFekpoNlGhoaHqhGZcXBwlNAkhhBDTWgggG8C/AJxr0gBj7HUAywGcAPAaAD8AswB0Y4x14ZzXf/c40rQcOgSMHAmUCf+zcrEYKC4G1q4FfvwRBRu+w99tnHAh9QIu3b+EfGl+FQ0ax9nGGYFOgQh0CoS/kz/8HP3gK/GFi41Lg65+rerd6WnvaXC7agEj1SI7iTmJiM+OR540r1rHySjOwO3f1sFv5b8olXOImQgQMbCiIvC134KvX4cDH7+In32F1dxrytHaEaGuoWju0hxBzkEIcg6Cr8S3wXovMsYgsZZAYi2Bn6OfwTqcc+SU5uBewT3cyb+D23m3cStPWCCqpudeKivFv2n/4t+0fwEAj8YWYebnf8FSea1139f4+Wegf/8anychTV1hYaHI3d1dr8fhxYsXbbp06dJWs+z999+/s2DBgvuaZdOnT7+vm8wEAFUyU6FQIDc3VySVSkU+Pj6yoKCg0osXL9qr6u3cudOxtLRU9PLLL6erkpkA0KJFi/Jhw4Zlb9myxb2qc9i2bZtbcHBw6aOPPlqcmpqq9UuwZ8+e+du3b3cvLCxkmsnYkSNHZqmSmQAgkUgUkZGRRZqx1Sd7e3t5VlaWOtZNmza52dvbK0aNGpWrew6PP/547vLly32vXLli3b59e6mjo6O8tLRU9PPPPzs///zzuSKR/uySf/75p218fLzN888/n6GTzAQAiMVCb/ydO3c6ZmVlWbz//vuZmZmZWscdNmxY3rx58/z379/vqJmQFIlEePfdd7VWgxswYEDBxx9/jBs3blijnlBCs4kKCQnBwYMHAQAJCQmQy+XqNyghhBBCGlwLznkiADDGrgBwqM7OjDF3AB8D+AdAX86FiQgZY/8A2AUhwbmwTiMmTVtSkpDMlEqhEIlRLpdDLlegnHNwrgCkJZA/8yw+eCEEt52tAM2hxBWMKuYGvgtyj4S/XTt4WbWAp2ULeFk2h53UCUgHkA7sOrkBhYWxWvup5kjTnytN4wg623x8whAVNcRwXBy4e/c6zp/faWBf448JiMARisd6P4NCm2zclV7DnbIryChP1hpqnZGRBFn5g45N/nnlmLUpBSI5h0zEIIMC4BxS5b/pIinHo2+swvzR/khxepAEsLGRwNW1mcFzYmCwKXVAQUIWJKVusCtxhkJmh/MoxHnEAIjRO5fKzm3w4Lfh7OytfQyN3PL27R8jL+++3n6a7QpfKz9mcHBH9O07EYArgHaQAGinfBQr8nAhaQ9OxPyAEtt8lNjmocyqxNAhKxzYHpAvw+Sf06CQcZRaiAEwMA4omCUsxRZgUqnwvr9wgXpqElIBBwcHRVFRkV5GLCwsrGzHjh03AeDixYt2CxYsMPjJRZs2bQx2wz5z5ozte++91+zcuXOSkpISrfabNWum/qWZmJhoXVE7qmHKVUlMTLQpLS0V+fr6RlRUJy0tzSIkJEQ9hL158+Z6Q59dXFxkubm5DZI3KyoqEjs4OKgTuPHx8TZFRUUiPz+/Cs/h3r17lu3bt5d++OGHqefOnXMYO3Zsi+nTp8u6dOlS+Pjjj+e9+OKL2S4uLgoAuH79ug0AREZGFlfUHgBcu3bNBgBmzpwZNHPmTIN10tPTta6Jh4dHue7CT56enjIA0EzS1jVKaDZRHh4ecHJyQl5eHqRSKe7cuUOrnRNCCCEmokpm1sIwAHYAVqmSmcp2dzPGEgGMASU0SXWsXAmUlUEuEqGkrFRIyHEOKJiQ0IQCFuXAU8dvYHZHI9uUAchiQCaATAZkAS26bkOBpA0KABhaqvLEiWUoLLxe69Px8XkaN24YTmgCwL17V3Dx4vu1Pg4AZGY8A4mkB4AesATgKSpEge1V5NtdRJ7dv0jNPwG57MFIujf/BSzkgBwAFPqJYTkAS5kCI8/c0rrW1ja+KCl5kNC0KfeBU3FHOBZHQlLSFul39uHKxVF1ck7Fxa9AIvGucPuJEz/X2euUljaxgq1OuHfPCtcuHleXcCsOuAFw54A7ADde6X+wc1XXmgFMAYAJSVWprBwKBYeNpaXQI/nLL4HPPqv1+RDSFIWGhpacP3/eITY21kpz2Lmjo6Ni2LBhBYCwsnhFNJNyKnFxcVYDBgxoZW9vL3/99ddTW7VqVerg4KBgjPE333wzoLi4uE4XrOacs9DQ0JKlS5ferqiOal5JFbFYbLIVx27cuGFVVFQk6tChg3q0DeccLi4usnXr1lV4D9mpU6cSAAgPD5fevHnz6q5duxwPHz4s+fPPPyVvvPFG4OLFi32PHTt2o23btkbPU8k5Z4DQ+7Zjx44Gk5/+/v5ac5lWdu1U7dUHSmg2UYwxhIaG4vx5YW6ZuLg4SmgSQggh5quz8uufBrb9BWAUY8yBc17YgDERc7ZpEwCgtKy8woVcOIAxyag4oVnGgAwA95VfcwFWf/+3NFoWCge4FD0Cl6JHAABZ50+iyCkOaMYBT47RyRAuZiWXxtC1ZhxwLI6AS9EjcCqOgk25T/2dRCPFyhiQCiBVuHiccWHSDg8AXlz4avXg/VvZtS5XyGDJLSAGgJ9+ooQmIRUYNmxYzvnz5x1Wr17tsWrVqrt10ebWrVudi4uLRVu3bo0fPHiw1tyJr7zyitjK6sEPsqqn5LVr12yGDh2qVff69esGV0TXFRAQUJqTk2MxePDgAnMYqbp69Wp3ABgwYECuqiwoKEh64sQJm969exc5OTlVOaGzra0tHzlyZN7IkSPzAODnn392eu6550IWL17stXHjxhRVj9f//vvPrrJ2WrZsWQoA9vb26gR2XanraWUoodmEhYSEaCU0+/XrZ+KICCGEEFJDqoUGDP1jcRfCv+++AG5qbmCMTQQwEQC8vLxw/PjxegyxfhQWFppl3I1dz7w8yJgICv6ggwoHwDSGCHMAEs3+K3IAGUxILt0HkAPoZo50U6O5uTkoK8tERWQyOfRGQteAVCpFVlbFxykszK+T4wBVn5MiTwSkMeAGA6w4HMsVKGeoMqEpkQFQQLi+KQx2pR3hETwTAFAEoAjax2zIc2o0rxNnwmzE2RCuLzjgwgAvAN4cjuVcuNZ48H7WfF+XlElhI7YAy83FKfq9Ui8e1t/Zn376aWpNF+GprqoWDaqt1157LeP777/3WLNmjVfnzp2Lxo0bl6tbR38Ki8qpevDp7vfZZ5+5Z2ZmWvr6+qp7gg4dOjR/+vTpiu+++85z2rRpWap5NBMSEix///13V2OO99xzz2V99NFHfvPnz/fSneMTAG7fvm3h7+9fo5XJ7e3t5bm5uXWWJV23bp3L119/7e3h4VH+5ptvqleDGzt2bNaxY8ecZsyY0ezHH3/U62mqeQ6pqakWuiutd+vWrQgAVLF27dq1JCQkpPSXX35xnzlzZnpUVJTWkH6FQgGRSIThw4fnz5o1S7ZixQrv8ePHZ3t5eck16xUWFrLy8nKmGspeHRKJRA4AWVlZdXL9KKHZhAUHB0MsFkMul+P+/fvIz8+Ho6OjqcMihBBCSPWpPk03NGSoVKeOGuf8WwDfAkBUVBSPjo6ul+Dq0/Hjx2GOcTd23MkJstwcrYkSGefCc+U/nAxAgRhArDKJmQEwhUZWzoiOFs7OLpBIKl6/wcJCjLrosGFtbQ03t4qPI5U61slxgGqeUzlDAQdsOcCVQ6BhYGAl40ABAOwQgSkzcjY+9o3znGqh7l8nBuRCeNxgyOdy2AHgIoCJGcA03teAujey2NmZfq/UE/qdbf4cHBz4nj174gYPHhz6wgsvtFi9enVBnz598r29vcvz8/PFsbGxNnv27HEVi8Xw9/cvq7pFIUn50UcfKV5++eXgCRMmpLu4uMjPnj3rcPz4cSd/f3+pXC5X/+R7eHjI33rrrXsLFizw69y5c6vnnnsuq7i4WPTjjz96BAYGll6/fr3SHoYAMHfu3PSjR486fvTRR34nTpyQ9OrVq8DR0VGekpJidfLkSUdra2vFuXPnblbVjiEdO3Ys2rZtm/trr73m27p161KRSMSfe+65PN0V3HWlpaVZffXVV64AUFJSIkpJSbE6duyY4+XLl+0DAgKkv/zyS4K7u7s6efjiiy/m7N27N2vDhg2ely9ftn/88cdz3d3dZXfu3LH6+++/7W/dumVz586dywDQt2/fUEdHR3m3bt0K/f39y3Jzc8VbtmxxZ4xhzJgx2YCwcM93332X9OSTT4b17Nmz9ciRIzPbtWtXkpubKz59+rSkf//++XPnzk13dHRUfPvtt0mjR48OadWqVbvnnnsuMyQkRJqbmyu+ceOGzf79+102b96cUJNVyrt3714sEomwdOlSn+zsbAt7e3t5SEhIWZ8+fWq0sCUlNJswa2trBAQEqFc7j4+PR8eOxk6CRAghhJBGRDWHkTUA3QnxbXTqEFKl8116oPXBXdDNSoqZBRgD5HIZRBw46dUWfV27A67aQ8X0h40xrXLV10GDXODiUnEc9vZjkJ//YGHUB+0yneeGjvvge3//cHTvXvFxbt9uDX//dwzuqxuz7jXRjaFvX3c4OVV8LA+PqSgoyFTv9/d/e9E38Ty4Rjucc612RVDgnxaP4LmOg9RlPj6tEBWFCnss3rsXjrCwxZVes4peJ93tjz7qBYmk4nMKCHgXRUUPViGv+HVhlb5mHh7N0a5dxcdJT++ETp2+BSCcd0Wvt6EYAODy2c3oEXsCnDGIxRaQKqTQ7TdcJiuHePRoY/LxhDy02rRpU3bp0qVrq1atct+5c6fLmjVrvAoKCsS2traKwMBA6ahRozJfffXVjIiICKPmZmzbtq10+/btce+9916zlStX+ohEIt6pU6fCQ4cOxU6dOjXw7t27Vpr158+ff9/BwUG+evVq74ULFzbz9vYumzp1apqTk5N85syZQVUdz9ramh87dixuyZIlnlu3bnVbtmyZLwB4enqWR0REFI0fPz6rRhcGwGeffXY3JyfHYv369Z4FBQVizjl69ep12dHRsdLkbmxsrO3UqVODAcDW1lbh4uIia926dfHnn3+e/PLLL2drrriu8ssvvySvXr06f926dR6rVq3yKS8vZ+7u7uVt27Yt/vDDD++o6k2YMCHjt99+c9m4caNHXl6e2NnZWdamTZvi5cuXp2gO8e/Vq1fxmTNnrn3wwQe+e/bscd20aZPYxcVF1r59+6JevXqppy0aMWJEfkBAwLWPP/7Y57fffnPLycmxcHR0lAcEBEgnTZp0v3PnzjW65wwNDS374osvkr/44gvvt956K0Amk7Gnnnoqq6YJTVbdrsKk+qKiorhq6HddMfaTr7Nnz6pXO2/Tpg2effbZOo3jYUGfNDYsut4Ni653w6Nr/gBj7ALnPMrUcTQk1SrnnPOgauzzDYSh46Gc83idbZsAjALgWNkcmvVxP9IQ6Oel7mXk5OPJaf1w4Lf/YCVXQCFSJsI4g72NjZDokcsBa2taDbouJCUBnToBUimgnMtNJpfDQjWvG13ruqNzraXlcpTJpeoemiIFR5lYhO3LV2PClFdMHGzTZI6/s425F7l06VJyRERExfMlEELqxaVLl9wjIiKCDG2r05WkSOMTGhqq/j4hIQFyubyS2oQQQghppP5Rfu1mYFtXADdoQSBirBEfTMM//B+M6mmJMrGQ5GGcw1IkBlMoAIVCSLD9/DMl2OpCcLBwLa2thWurUChXlKdrXed0rrWVmAGcgXGuTGYCo3paYvqJuZCWl1fdHiGEkEaLEppNnLu7O5yUY2KkUilu39abS5YQQgghjQhjLIAx1ooxZqlR/DuEoebTGGNijbqDATQHsKmBwyRm6nrSbZzJ3AYAOOBRjI4D5Fjb0gplltaw4ArA3h6YNEnoLdi/v4mjbUL69xeu6aRJgL09mFxO17q+aFxrZm8PG8ZQbCHC2paW6DhAjgMexSgRZ+ClT+abOlJCCCG1QHNoNnGMMYSGhqpXO4+Pj0dQUJBpgyKEEEIeMoyxsQAClU89AFgxxt5TPr/FOd+oUX0DgF4AggEkAwDnPIMx9j6ATwEcZoxtAdAMwBsAYgF8Ud/nQJqGaV/Mg4I9mPIs2QF4PbwU3ksOwtvBwuyGipqV4GDgs8+Azz7DKTMclmtWNK/10WMY8vkYFEnuaVXZeX0dFIqPIBLRbJqEEGKOqIfmQ0Bz2HlcXJwJIyGEEEIeWhMAfKR8eAJw1ng+wZgGOOefAXgRgCuAlQBeBbANQC8abk6MUSYrx+m07XrlzWXd8NygfiaIiJD6JxIxvDdokV55sTgVq7b9ZoKICCGE1AVKaJozhcKoasHBwRArJx2/f/8+8vPz6zMqQgghhOjgnEdzzlkFj+gK6iYbaGc95zyCc27DOffknL/EOU/XrUeIIe+t+QZl4lztQg58NnGxSeIhpKG8PXEs7Ao89cqX71lmgmgIIYTUBUpomhOFAvjkE8DZGb169wYkEmBT1VNmWVlZITAwUP08Pj6+ktqEEEIIIaQp+uHMV3plzoXBGDagpwmiIaThMMYwKOwFvfLb/F/8e4P+NyKEEHNEc2g2gHsF98Dm183cLHye8JUBQHExMHGiUDB6tFBe2XGUm+bvng/srvw4H/b6EPOi51W4fd7xeZh/om4m0uYf8kq319W1q/U5nTD+WGZzTtXQkOcUjegKt5vrOTX616ka72/ATM6pmhrynI71OlbpdnM8p4Z6nQghNbPvz7+RKboB6Pyoju36qmkCIqSBffnOXPwycQW4TZm6jHMZZq6ej5MrN1ayJyGEkMaIemiau+JiYO5cU0dBCCGEEEIasTnrFgBce7oii2I7LJk1w0QREdKwPNyd0M66j175Xxm7UVImNbAHIYSQxowSmk1BSoqpIyCEEEIIIY1Uek4urhQd1Svv6joMtrbWJoiIENNYMnE+oLMMQTnLw5yvvzRNQIQQQmqMEppNQUCAqSMghBBCCCGN1GsrF0OOEu1CmQgrX6+bKScIMRcDe3eBa2GoXvnGc9+YIBpCCCG1QQnNpmDWLFNHQAghhBBCGiHOOXbf0J8fsJm0AyLDQ0wQESGm9VLP6Xpl2Swev52o5oTihBBCTIpxXvkk/qT2oqKi+Pnz5+umscBA/SHma9YAkyZVuWtZWRmWLFkCuVwOAJg1axYcHR3rJq4m7vjx44iOjjZ1GA8Nut4Ni653w6Nr/gBj7ALnPMrUcTwM6vR+pAHRz0vtfPnbr5j+2zN65Z/33YqZE0ZqldG1bjh0rRuO7rWWSsvg8LQbZJJCrXpt7QfgytoDDRxd02OO721j7kUuXbqUHBERkdlQMRFCBJcuXXKPiIgIMrSNemiamzFj9Mv27TNqVysrKwQGBqqfx8fH11VUhBBCCCGkEfp016d6ZTZ57pjx4rMmiIYQ07O2tkIPzxF65deLT+JuVoYJIiKEmAJjrNOIESOC6qs+qX+U0DQzfOBA/cLDhwGpcSvzhYY+mDMmLi6ursIihBBCCCGNzOXERKTILuiVPxkyDiIRM0FEhDQOX745HyjT/ldYwUsxY8VCE0VESOOxZ88eCWOs0wcffOClu+2PP/5wkEgkHTw8PNqfO3fOFgBmzZrlyxjrpHqIRKJOTk5OHbp169Zy06ZNToaOoVmfMdbJysqqY0BAQLuXXnrJPy0tTVzf51iRWbNm+W7cuNG5vtrv0qVLGGOsk5+fX3hpaaneH2LVtTx58qQdoH+dKnvcuHHD6saNG1aMsU7jxo3TW2jl/PnzNp6enu3t7e0jf//9d0l9nWNDsjB1AMR4CoUCa/79Fy/a2MC2tPTBhqIi4NQpoF+/KtsICQnBgQPCUIrExETI5XKIxSb7fUEIIYQQQurJa1/OB+cyrTJWYokv333PRBER0ji0bRWIgPIopFj9rVW+P34r5IpPIRbR/0eE6NqyZYvTiy++2MLNza384MGDN9u2bavVq2r27Nn3goODpTKZjCUkJFhv3LjRY8yYMSEFBQVJkydPztZtr1WrViXTp09PA4CcnByLI0eOOP7www+ep06dcrx8+fI1Gxubep0fsaio6F/dXMjnn3/u89RTT2WNHTs2tz6PfffuXatly5Z5vP/+++mV1Vu9enWS5vPTp09LtmzZ4j5q1KjMHj16FGhu8/HxkaWmphrM8R07dsxu+PDhLRljfM+ePTd69+5dXPuzMD1KaJoRkUgEJzc3JLRogXZXr2pv3LfPqISmu7s7nJ2dkZubC6lUitu3byMoKKh+AiaEEEIIISZRWi7FmbRdeuWtLaLh7eVigogIaVzeGTEXU/YP1SorRho+37YVs58bbaKoCGmc1qxZ4zpt2rSg4OBg6aFDh24GBQWV69YZPHhw3mOPPaZOlD333HM5jz76aJvly5d7G0poent7l02ZMkVdPnfu3PT+/fu3OHz4sPPWrVudxo8fn1tvJwTAzs7OJAvK2NjYKJo1a1a2fPlyn2nTpmW6uLgoKqqreX0AQCaTsS1btrh37dq1UHcbAKSmpuq1sWvXLsmoUaNC7O3t5fv27bvZqVOnUr1KZoqGnJuZsLAwxGkMG1fbu9eo/RljNOycEEIIIaSJW7ZtG8qZ9qInUACfvDTPFOEQ0uhMHjsYdjmeeuUr933R8MEQ0ogtWbLEY8qUKcFt2rQpPn36dKyhZKYh3bp1K3F2dpbdunXLxthj9enTJx8Abt68WeU+Tz/9dJC1tXXH4uJi9dDtw4cP2zPGOjk5OXVQLYYMANu2bXNkjHVau3at+hM9zTkxVUO1AWD79u1umkO5dY97+PBh+86dO4fZ2tpGOjs7dxg5cmRgXl6e0bk1xhjmz59/Jzc312LevHnexu5XEz/99JPzM888E+ru7l5+6tSp2KaUzAQooWl2wsLCEN+ihf6G2FggKUm/3ICQkBD197QwECGEEEJI08I5x76EC3B37weJpB3EFsJUWc55zTFs4KMmjo6QxoExhqFtJqifi8S2sHdoBamLC67fvWPCyAhpPObMmeP9zjvvBDzyyCMFp06duunl5SWvei9BRkaGOD8/38LJyUlWdW1BQkKCNQC4urpWuU/v3r3zy8rK2KFDhxxUZQcPHnQUiUTIz88Xnz171k5VfuTIEUfGGP73v/8VGGrLx8dHphre3alTp8LVq1cnqR6a9a5evWr39NNPh0ZGRhYtWLDgds+ePfO2bdvmPnnyZH9jzxEARo8endexY8fCtWvXeqWkpNTLyOnVq1e7jh8/vnlQUFDpqVOnYsPCwsrq4zimREPOzYxEIoFzWBgS3dzQPCtLe+O+fcCUKVW2ERwcDLFYDLlcjvv37yMvLw9OTgbn6iWEEEIIIWbmr7ibSMxJABNZwNYuCLZ2QSgvy8LM7tNNHRohjcrKOe9g17QtsHD1gLW1JwCho9eKfXux5uWJpg2OmIU+P/YJqbqWaR194WiNejH98MMPHnfu3LHu169f7q5duxJtbW0rHaKdk5MjTk1NtSgvL0dsbKz1+++/30yhUOCpp57SGxoNAOXl5Uw152NWVpZ49+7djhs2bPC0s7NTjBo1Kreq+FTJycOHDzsOHTq0AABOnjwpiY6Ozj137pzjgQMHJD179iwGhLknQ0JCSpo1a2YwUero6KiYMmVK9tSpU4MDAwOlhoZzA8DNmzdtDx8+HNunT58iAHjzzTczo6Ojxb/88ovbmjVrbjs5OVU4fFzX4sWL7wwYMKDVO++847t58+YUY/czxpEjR5x++uknjw4dOhQdPHgwzt3d3ehEtDmhHppmKCwsDDF+fvobjBx2bmVlhcDAQPVz6qVJCCGEENJ0rDrwB3T/6/Sx7oq5k0eZJB5CGit3d0e82PMLWFt7QZXMBICDcUdQUt6kRmYSUm2ZmZmWABAcHCytKpkJAMOGDWvp6+sbERgYGPH444+3+u+//xxeffXVtFWrVhns8nzmzBlHX1/fCF9f34jw8PB27777bkBoaGjJ7t27b1aUeNQUHBxcHhgYKD116pQEAIqLi9l///3n0L9///wuXboUHD9+3FF5HuLY2Fi77t27G+ydWR0dOnQoUiUzVXr16lUgl8vZzZs3rarTVv/+/Yv69euXu23bNveYmBjr2samKTs724JzDh8fnzJnZ+cmmcwEKKFpllq1aoXLzZrpbzh6FCg17g+v5jyalNAkhBBCCGkaMgvycCrllF75U+FPQkwLNxOiZ+bgfhBz7VxCUVkxvj10zEQREdI4TJ06Na1r164Fa9eu9XrllVcM9KjStmjRopQdO3bc/Omnn+JfeumldJlMxnJzcy0sLS0N1m/fvn3Rjh07bm7fvj1u+fLlt1q0aFGalpZmZW1tbXQvx+7du+dfuXLFLicnR3T48GEHqVTKHn/88YJevXrlX7hwwaG0tJTt27dPolAo0Ldv31onNAMCAqS6ZW5ubjIASE9Pr/YI6KVLl94FwN58880qr291PPXUU1lDhgzJ3rt3r8vQoUObl5cbNe2p2aGEphny8PBAemAgim1ttTeUlAAnThjVhmZCMzExEZoT5hJCCCGEEPO0ev9BlMm0O7ZYcQmmD+lpoogIadxaBNijg3O0Xvnmf/4A5yZZBJmQRsHOzk5x6NChuG7duhV89913XhMmTKh0nshHH320aNiwYQWjR4/O+/7772+//fbbd7ds2eK+dOlSD0P1XV1dZcOGDSsYPnx4/uuvv5555syZWLFYzEeOHBlSWFjIDO2jq2/fvgVyuZwdOHBAcvjwYYmHh0d5ZGRk6YABAwpKS0tFx44dsz9y5IhELBbjiSeeqHVCUywWV/hLgXNuVMyaIiMjS59++unMgwcPOh89etS+dtE9IBaLsX379qShQ4dm792712XIkCFNMqlJCU0zxBiDf1AQ4kMMTNdh5LBzNzc3ODs7AwCkUilSUup0ygZCCCGEENLAFFyBXy/t0yt/1GsAPN2qNRKOkIfKxN5P6pXdyr2FE7FXTRANIY2Hg4MDP3jwYFy3bt3y161b5/nSSy8ZvfjNhx9+eD8gIEC6aNEi3+zs7CpzT15eXvK5c+fevXv3rtXHH3/sZcwxBg4cWMAYw+HDhyUnT550fPTRRwsA4JFHHilxdnaWHTx40PHs2bOSVq1aFTfWeSQXL158z8bGRvHOO+/UaS9NsViM3377LWnYsGFZ+/fvdxk8eHCTS2rSokBmKiAgAHEhIWh/+bL2hn37gBUrqtyfMYbQ0FD8888/AIRh58HBwfURKiGEEEIIaQA7//4H6UUZWmUMDFMfH2iiiAgxD0N6BuODXa1xX3FdXcYBrD74B6JbtzNdYKTRq+mCO+ZEmdSMf/zxx0N++OEHT845fvjhh9tV7Wdtbc1nzZqVOnPmzKDFixd7LV26NLWqfaZMmZL16aef+nz99dfeb731Vrqrq2ulw899fHxkoaGhJYcPH3a+c+eO1YsvvpgBACKRCN26dSvYtWuXS1JSks2kSZPSjDlXOzs7RU5OToPmyYKCgsonTJiQvnr1au+SkpI67XQoFovx66+/Jj/zzDPYsWOH26BBg1rs2rUr0draukl0P6cemmbK3d0dd9u105vwHXFxwsMIIRo9POOM3IcQQgghhDROb303GwUFVyCTPRhVF2gZhZ6RRnV0IeShJRIBT7cfpFUml5fg4LX1uJ1530RREdJ4ODg48EOHDsV37949f/369Z4vvPCCUT01p0yZkuXr61v2zTffeBnTS9PS0hKvv/56Wn5+vnjRokVG/fHq0aNHwa1bt6zlcjkbOHCg+g9gdHR0QWJiog3nHP369TNquHlEREThn3/+KZk7d673N9984/rtt9+6GLNfbc2fPz/N2dlZduXKFbu6blssFuOXX35Jfuqpp7IOHjzoPGjQoOZSqbTaw+MbI0pomhGFQoG4uDj88ssv2LlzJ5pFROCOodXO9+kPNTIkODgYYuXs8Onp6cjLy6vLcAkhhBBCSAP5L+EmEkvOoaQ4GdlZJ5CT8ydKS1PxXKfHwZrEvy2E1K+pQx6FlcIJZWUZyM39B1mZR5FfEIuZXy4ydWiENAp2dnb84MGD8T169MjfsGGD59ixYwMUisrX77G0tMTMmTNT8/PzxZ988olRCcqpU6dm+fj4lH3zzTdeWVlZVS5n17dv33wA8PPzk7Zs2bJMVT5w4MB8ALCwsOADBgwoNObY33zzTUrHjh0LV6xY4TN58uTgSZMmNTdmv9pyc3OTz5w5s8oerDUlFouxbdu25Keffjrr8OHDzk8++WTz0tJSs787YDTRcf2Liori58+fr3U7crkcy5cvR1FREZKTk/Hcc8/BeskS9D5+XLviE08YndTcuHEjEhISAACDBw9Gp06dah1nU3T8+HFER0ebOoyHBl3vhkXXu+HRNX+AMXaBcx5l6jgeBnV1P9LQ6OfFOL1nj8Pxexu1yliRJe6uuQ8fH+M6mNC1bjh0rRtOda512DMDcNPykFaZncgbeRtuw0JEs7UZwxzf28bci1y6dCk5IiIis6FiIoQILl265B4RERFkaBv10DQjYrEY7du3Vz/PyclBYqtW+hWPHQOKi41qk4adE0IIIYSYt+KyEpxN3a1X3tqit9HJTEIIMON/U6E7p1exIg1f/LrFNAERQgipECU0zUyHDh3U3yckJEDcuTMK7e21K0mlQlLTCKGhoervExMTIZc3yoW/CCGEEEJIBd7/fg3KeK52oRxY+PI8U4RDiNl69YUhsMvWHxW7cl/Vi64SQghpWJTQNDNeXl7w9vYGAMhkMlhYWSFeo5elmpFDzt3c3ODiInxyX1ZWhpSUlDqLlRBCCCGE1C/OOTb8+Y1euVNeMIYO7GaCiAgxXyIRw5DWL+mV3ym/hH/irpkgIkIIIRWhhKYZ0uylmZeXhzhDCc29ewEj5kdljGkNO4+Pj6+LEAkhhBBCSAPYc+40MuX60wa90HWGCaIhxPytePdtiAqttMq4QoY3vv7IRBERQggxhBKaZig8PBxMuVxlRkYGMiMjodBdvjIpCbh506j2NIed0zyahBBCCCHm470fFwJce5VZi1w7LHrrVRNFRIh58/R0Qlur/nrl59L3oUhq3DoFhBBC6h8lNM2Qvb09/Pz81M+l9va4o/Fcbe9eo9oLCgqCWCwGAKSnpyMvL69O4iSEEEIIIfUnLTcTVwtO6pU/4vYU7OysTRARIU3DksnzAJl2WZkiD++u/dIk8RBCCNFHCU0zpTlMvKCgADcrGnZuBCsrKwQFBamf07BzQgghhJDG7/Uvl0Cu0OkxJmX4YtaHpgmIkCZiYL8ouOaF6pX/dG4tuBHTehFCCKl/lNCsIcaYLWMsnjFWaIrj+/n5wc7ODoCwOJDBeTRPngQKjQuPhp0TQgghhJgPuUKOPTc265X7lkQiKtLAfSEhpFpe7PmaXlm2IhHbzxwzQTSEEEJ0UUKz5hYAuGWqg4vFYrRr1w6AsLBPmrc3ChwctCuVlQFHjxrVnmaPz8TERMjl8jqLlRBCCCGE1K2vd/2GQvk9vfJZg98xQTSEND0fz34FFjk6/19xBT7cuMg0ARFCCNFCCc0aYIx1AvAEgCUNfWzOOZKTkxETE6O12nlRcTFutmihv4ORw87d3Nzg4uICACgrK0NKSkpdhEsIIYQQQurBZ7uW65XZZLlj5sQRJoiGkKbHxsYKPTyf0SuPLTqDO1n3TRARIYQQTUYlNBljYYyxTYyx64yxPMZYMWMsljG2nDHmU99BasQxhzH2C2MskTHGGWPJVdQXMcZeV8Zayhi7zRj7jDFmX4sYLACsBTAVQFlN26kJuVyOVatWYf369fj3339hY2MDT09PAMJCQTHNmunvtG8fYMQ8L4wxrV6aNOycEEIIIaRxikmKw62yf/XKB4a8ALGY+isQUldWvPkBUKr9MyVXlGDml4tNFBEhhBAVY+94/AD4ANgBYA6AmQAOAZgI4AJjzLNeotO3EEAfAAkAcoyo/zmA5QCuAZgO4BcAMwDsZoypz50xtlWZIK3oEa3R5psALnLO9ZeUrGdisRju7u7q55cvX0ZERAQAISF53c8PCsa0d0pJAa5dM6p9zXk0aWEgQgghhJDGaeZXH4MryrXKWJEFVr37rokiIqRpat8uCP5lUXrl++O2QqaQGdiDEEJIQzEqock5P8I578M5f5dz/hXn/FvO+XQAL0JIdI6vaF9lL8kJjDFxJXVeYoxZGRFKC865G+e8PwD9SYO022wLIYm5nXP+FOd8Led8FoBZAHoDeE6j+isAPCp5nFG2GQJgMoSkpkm0b99e/f3ly5cRHh4OpkxiFltaIsnPT38nI4edBwcHw8LCAgCQnp6OvLy82gdMCCGEEELqTHFZCc7c261XHibqjWbNXE0QESFN21vD5wA6A96KFGlYtf1n0wRESBNy48YNK8ZYp1mzZvnWtI0RI0YEKacFbJQae3zmrLZjUlSL4rhUUqcfgO8AbDSU1GSMrQDwPYCRVR2Mc55YjdhGAWAAvtApXwugGMAYjXYLOOeZlTxUH4H3AOAF4CZjLBPA7wDsGWOZjLHHqhFbjYWFhcHKSsj9ZmZmorCwUD1U3MXFBRe9vPR32rfPqLYtLS0RGBiofk7DzgkhhBBCGpf5679FGdcZqCQHPn7pQ9MEREgTN+XFobDN1h+Q+MUfXzR8MITUM8ZYJ2MfN27cMKZTGqmljRs3Otcm4duUWVSnMmPMBoADABsAbfBgUZwKuwByzg8yxl6HMPybMcbGcM7lyvZWAZgGYBHnfGMN4q9MZwAKAH/rxFPKGPtPub26tgE4rPG8G4D1ADoAyKhJkNVlaWmJNm3a4ObNmwCgXhwoLi4OYrEY/3p742ndnU6dAvLzAUfHKtsPDQ1FQkICAGHYeVSU/hALQgghhBDS8DjnOHL7EuzsWqCkNEU97NwpNxgjBnc3cXSENE0iEcPgsJewLfPBvJmMiZFlmYMbqbcR5uNvwugIqVurV69O0nx++vRpyZYtW9xHjRqV2aNHjwLNbT4+PrWedyE0NLSsqKjoX0tLy6oX/qjA5s2bb8nl8ltV1zRPO3fudN6+fbvb8uXLKx2l/DCqVkITwMsAVmk8TwYwhnN+qrKdOOdfMMY4hN6SIsbYGOX3UwAs5JzPrWYcxvAFkMk5lxrYdhfAo4wxK8650Qv7cM6LIfTuBAAwxjKEYn6n1tFWQ/v27bFz504AwrDzPn36wMbGBqWlpcjy8UGugwOcCwsf7CCTAUeOAMOHV9l2aGgo9u/fDwBITEyEXC6HWFzhbAGEEEIIIaSBnEu4gTtFGXCQtIa9Q0tIS++huCQZYx6ZZurQCGnSVrz7Nn6d+BmYszVsbQNha+MHJrLEin178dVLk0wdHjF3sbFWWLbMEzt2uKGoSAx7ezmGD8/Cm2+mo1WrBl2IeMqUKdmaz2UyGduyZYt7165dC3W36crJyRG5uLgoqnM8kUgEOzu7GiczAcDa2rpW+xPzVd0h5zsB9AcwHMACALkA3Cupr8Y5XwHgNQDPArgBIZn5ST0lMwHADoChZCYAlGrUqTHO+XHOuUNF2xljgxlj39b1XJRBQUGwsxNCLyoqQkpKCtq1awcAcHN3xwVPA2s0GTmPpqurK1xchBkEysrKkJKSUjdBE0IIIYSQWll14A9w5b9tjIlhY+uPlq4TsPy9mSaNi5CmztvbGc91WgE3t2jY2QWDiSwBAAduHkFJeWkVexNSiR07HPHII22wZYsHSktFsLDgKC0VYcsWDzzySBvs2FH1MEsTaNasWXiXLl3Czpw5Y9ujR49QiUTSoV27dm0BIbE5Y8YM3/bt27dycXGJsLKy6hgQENBuypQpzQoKCrRyUIbm0NQs27Jli1O7du1aW1tbd/Tw8Gg/adIkv/Jy7UXxDM1RqSrLysoSjx49OsDV1TXC2tq6Y8eOHVsdPXrUXvd80tLSxM8880yQs7NzBzs7u8iuXbu2PHPmjG2XLl3CmjVrFm7MNSkuLmaTJk3y8/T0bG9jY9MxPDy89fbt2w2+fseOHbMbMWJEUFBQUDtbW9tIe3v7yI4dO7basGGDs2a9Ll26hG3fvt0N0J4OYOXKlW4AcPHiRZsxY8YEhISEtLW3t4+0tbWNbNu2bevly5cblaczd9XqoansiajqjbiTMfYbgH8YY3ac80VGNLEKwlyZj0JIas6vzvGrqRhARauv22jUqTec890AdkdFRb1Sl+2KRCIEBwejqKgIgDDsvEuXLjh//jysrKxw3tMTfRN1phvdtw/gHNBdBV0HYwyhoaH4+29hpH5cXByCg4PrMnxCCCGEEFJNWYV5OHXrtF75sLaDYGVV22nxCSFV+XDcOBz74ijkogcJzEJpCb4/egzTHh9owsiI2YqNtcL48c1RVsagOSpS9T97WRnD+PHN0br1tYbuqWmMe/fuWQ0cODDsySefzBk2bFhOYWGhGACSk5OtNm/e7DFw4MCcZ555JtvCwoKfOnVKsmbNGu+YmBi706dPG7VYx6FDh5zWr1/vMW7cuIyxY8dm7tmzx/nbb7/1cnFxkS1evDjNmDb69OkT6ubmJps9e/a9rKwsi2+//dZrxIgRIYmJiZdVvUlLSkpY7969w2JjY21HjBiR1blz56KYmBjbJ598MszJycnoYfVDhw5tfvjwYefevXvn9e/fPy8hIcF6zJgxLfz8/PQ62v36668u8fHxNkOGDMkODAwsy8rKsti6davbCy+80KK4uDhp8uTJ2QAwZ86c1E8++cTnwoULDprTAURHRxcqr5Hk3Llzkv79++cGBweXFRUViXbu3OnyxhtvBGZkZFgsWrTIqOtkrqo75FwL5zyGMXYRQm/LShOaTFiKey2EZOYfAP4HYBtj7FmNRXfq0j0AbRhj1gaGnTeDMBy90f1SMFaLFi0QExMDALh+/TqefPJJuLm5ISsrC7dCQiD7+29YKDR6e9+9C1y+DGiskl6RkJAQrYTmgAED6uUcCCGEkIcFY0wEYaTKJABBEObe3gbgA855kRH7VzScqqiy0SKk6fjqwCFIy7X/r7JUOGLaEJo7k5CG0DLYHu2donGxYL9W+U9//4GpA54Aq6LjCCF6li3zRHm5djJTk1gMlJczfPqpJ777rkGnuTPG3bt3rT777LNbs2bNytQsb926tfTu3bsxmkPB58yZk/Haa6/5rly50ufYsWN2vXv3rrJzWXx8vM1///13NSwsrAwA3nzzzYywsLC233//vaexCc3w8PDin376ST3stG3btqUTJkxo/t1337m++eabmQCwYsUK99jYWNu33nrr7pIlS9TtLl68uGTOnDkBvr6+VeaNtm/f7nj48GHnp556Kuu3335LVpX36tWrcNy4cS106y9atCjV0dHxrmbZnDlz0sPDw9ssW7bMR5XQHD58eP5PP/3keuHCBQdDQ/4nT56c9dZbb2mt5/LBBx/c79atW9iXX37pPW/evPtNeUh+XXycawvAtbIKypv47wFMgHDjPgjAqwCGAviVMVYfq2P9A+H8uujEYgNhEZ/z9XDMBuPi4gJP5dDy8vJy3LhxAx06dAAAOPj44JqrgZfEyGHnwcHBsLAQct0ZGRmo6yHzhBBCyEPocwDLAVwDMB3ALwBmANitvE8yxikAY3UeE+o+VNLYKLgCv17ap1fezXMAfDxpkVlCGsorvZ7UK0vOvoWzcddNEA0xezt2uNVpvQbm5OQknzFjRqZuuY2NDVcl0crLy5GRkSFOTU21GDBgQD4AnD171qgPYvv375+rSmYCwkjVRx99ND8zM9MyLy/PqHunt99++77m8//973/5ABAXF6catYu9e/c6i8VivPvuu+madWfOnJnp4OAgN+Y427dvdwaAOXPmaCVax44dmxsUFKQ3L4Wjo6O691lBQYEoLS1NXFhYKOrevXt+YmKiTXZ2tlHnp9lOcXExS0tLE6enp1v06dMnr7CwUHzp0iWbyvY3d0ZdJMaYdwXlvQG0A/BXJfuKAKwD8CKA9zjnHwEA5/wbCL0UBgP4rR6Smj8D4ABm6pS/AmHuzE11fLwGxRhDePiDqRxiYmIQEREBxhjs7Oxwzt3AlAlGJjQtLS0RFBSkfh4XZ1SPcEIIIYQYwBhrCyGJuZ1z/hTnfC3nfBaAWQB6A3jOyKYSOec/6Tx+rq+4SeOx59/zSCvQ+j8LDAxTBtAwV0Ia0rDoIHiijVYZB/DlgT9MExAxb0VF4qqmhANjQr1GyN/fX6rqCKVr8eLFHi1btmxjY2PTydPTs4Ovr2/EoEGDwgAgJyfHqPMJDg7WG6rt5uYmB4D79+8bNdq4devWWm14e3vLASA7O1u9/+3bt608PDzKnJyctBY0srGx4X5+fkaN6r1165a1SCRCeHi4XswhISF6Cc27d+9ajBo1KtDNzS3C0dEx0sfHp4Ovr2/E5s2bPQAgKyvLqPPLy8sTTZw40c/Hxyfc3t6+o6qdJUuWNFO20yjfO3XF2CHnXzPGfAAcBXALwhyUnSDcgBcAeKOSffsBeAHAu7rzbHLO1yqHUH0LYW7NjZUFwRgbCyBQ+dQDgBVj7D3l81ucc/X+nPPLjLHVAKYxxrYD2AugNYTeECcAbK7yrBu58PBwHDlyBACQkJCgnlszMTER8SEhQGys9g5nzwK5uYCzc5Vth4SEID4+HgAQHx+PqKioOo6emDOpVIrs7GwUFBRALjfqQ6tqcXJywvXr9El3Q6Hr3fCa8jUXi8WQSCRwdXWFtbW1qcNpLEYBYAC+0ClfC2AxgDEw8r5E+QGwFee8sC4DJI3bol+/gkJRBpHowef/ARZRiI6qaLp4Qkh9EIuBp8KfxJrL17TKT906idTc8fBx9jBRZMQs2dvLUVoqqjSpyblQrxGytbU1uKL5vHnzvObPn+/XvXv3/MmTJ6c3a9as3NraWnH79m2rGTNmBCkUCqPmZxBXNBQfAOfGjaKuKOFq7P71QaFQoG/fvi0TExNtXnrppfSoqKgiFxcXuVgs5uvWrXPfvXu3q0Jh3GLxw4cPb378+HGn5557LuOxxx4r9PDwkInFYr5nzx6n77//3ksulzfpuTCMTWhuATAOwtAmDwgfRN0C8A2AZZzzCpfC5pwfZIx15pwbHOLNOf+OMfZfRdt1TADQS6fsI+XXE9BPiM4EkAxgIoAnAWRCWJjoA865ce+QRszZ2RmBgYG4desWOOe4cuUKOnTogMTERJS1aIH7NjbwKtX4MEAuBw4dAp55psq2Q0NDsX+/MD9MYmIiZDJZhb8MyMNFKpUiJSUFLi4uCAoKgqWlZZ3PGVRQUACJRFKnbZKK0fVueE31mnPOUV5ejvz8fKSkpCAgIICSmoLOABQA/tYs5JyXMsb+U243xtMQkp9ixlgGhNEo73HOaW6YJuxqSgLO3d4MzhWwsfGFrW0gLC2d8XzUk1V27CGE1L0pg7th3SUnlInyIJcVorjkFkpL72DmyiX4+YNPTR0eMSfDh2dhy5aqs+DDh2c1QDR15ueff3bz9fUtO3HiRJxmUvLXX39tlCu2+/n5lf3555+OeXl5Is1emlKplN25c8fK0dGxyoRyYGCg9PTp07h8+bJ1VFSUVo/M+Ph4rWHf586ds71x44btzJkzUz///PN7mtu+++47vfdDRf9rZ2Zmio8fP+40bNiwrM2bN2vl5A4ePNgor3VdMypDxTnfBmHi+hqpKllpZDITnPPoah5XDuAz5aNJat++PW7dugVAGHb+4osvwtraGo5OTjjn7o4hd3TmDt6716iEpqurK1xcXJCTk4OysjKkpKSgefPm9XEKxMxkZ2fDxcUF7oamNSCEPNQYY7CyslL/fsjOzoaPj4+Jo2oUfCEsRqg3DAnAXQCPMsasqlis8G8I827GA3CEsLjiNAC9GGOPVtRjkzE2EcIHu/Dy8sLx48drfhYmUlhYaJZx15XZm74AVwjrZ5aW3EZpyW1YlnkipG9+nV+Xh/1aNyS61g2nPq61Z74LYhT7ICt/sEbHrusbceTYQIhZkx7hWSV6b1fDm2+m49df3fVWOVeRywErK47Zs9P1NzZeYrGYM8a0ekGWl5dj6dKljfKm8H//+1/u6dOnHRcuXOipuSjQ559/7l5YWCg2JqE5fPjw3E2bNnksWrTIW3NRoI0bNzonJydrJTQtLCw4oN9L9J9//rE5ePCgs27b9soeuvfv3xd7eXmpYxGLxQbbuXXrluWWLVsein/WqcudmWvTpg327t0LuVyOe/fuIS8vD23btsW///6L2KAg/YTm/v2AQgGIKp8+lTGG0NBQ9Wrn8fHxlNAkAISeZZpzrBJCiCGOjo5ITk6mhKbADoChZCYAlGrUqTChyTl/RKdoA2MsBsAnEFZP/6SC/b6FMLUPoqKieHR0tPFRNxLHjx+HOcZdF0rLpbiydoReeXN5OAYN6l3nx3uYr3VDo2vdcOrjWo+5kYVZJ77UKitl6biWm4Hpw42dFrlpovd2NbRqVYb16xMxfnxzlJcL3fAYE4aZA0Iyc/36RLRqZdQ8jo3FkCFDchYtWtSsV69eoUOHDs3Nz88X/frrr26qRF5jM3PmzMwffvjBY+nSpc0SEhJsOnfuXBQTE2P7xx9/uAYEBEhlMlmV4yFGjBiR37t377zt27e79enTx2LAgAF5CQkJ1ps2bfIIDQ0tiYuLs1XVjYyMLA0JCSn9+uuvvYuLi0VhYWGlN2/etNm0aZNHy5YtS65evWqn2XbXrl2LNmzYgAkTJgQOHDgw19LSkj/22GNFrVq1KuvevXv+77//7vb888/zqKioolu3bllt3LjRo1mzZmW5ublNPt9XF6ucExOytbVFy5Yt1c9ViwMBQFqbNijT7Z6clgb8959RbYeGhqq/p4WBiIpcLoelpaWpwyCENHKWlpb1MseumSoGUNHYexuNOtW1DEISVH/ZXdIkfLThO0h5tnahApj/wgemCYgQAgB47ZWnYJOlP1L4s92fmyAaYtaGD8/HuXPX8PzzGbC1VUAuZ7C1VeD55zNw7tw1DB+eb+oQq2vBggVp77zzzt3bt29bv/fee/7r1q3zjI6Ozt+wYUOSqWMzxNbWlh8/fvzmU089lXXo0CHnefPm+SUkJNjs3bv3hkQikdvY2Bg1XeGuXbsSXn755fsxMTH28+bN8//rr78kP/30U0J4eLjWPZ6FhQX++OOPuD59+uT+8ssvbu+9957/2bNnJV999VXSgAED9KYRmjhxYvYrr7xy/59//nGYMWNG8KRJk5ofPHhQAgDbtm1LeuaZZzIPHz7sNGfOnIB9+/Y5z5079+7EiRPNqldvTTFTTob6sIiKiuLnzxs1qt5omp98Xb9+HT//LCxy6uzsjBkzZmDVqlXIzMzEkNWr0TknR3vnjz8G5s6t8hjl5eVYsmQJZDIZAGDmzJlwNmJBoaaIPml84Pr162jdunW9HqOpzi/YWNH1bngPyzU35vcFY+wC57xJrzzHGDsAYZFEO91h54yxMwBacs5rtJIEYywJQDnnvGVVdevjfqQhPMx/g73GtUW6THvxEcesQOQdSK6X4z3M17qh0bVuOPV1rZ+e9hZ+y16mVcZElvh3/hV0aFHlr+Qmyxzf28bci1y6dCk5IiIis6FiIqYnk8ng6uraISIioujUqVPUw8tELl265B4RERFkaBv10GwCQkNDYWMjdPDIzc3FnTt30KFDB4jFYlz299ffYe9eo9q1tLTUGlqsWvWcEEIIIdXyD4R7ri6ahYwxGwAdANQoy6jc3w/A/VrGRxqhQxfOIV0eq1c+KmqKCaIhhOha+e4csCLtUUtcUY5ZX39soogIITVVWFioN6x82bJlHgUFBeI+ffqYXS/ZhwUlNJsACwsLtG3bVv1cc9h5UqtW+jv89ReQna1fbkBISIj6exp2TgghhNTIzwA4gJk65a9AmDtzk6qAMdaCMab1x5sx5lZBux9BmA99d51FShqNd77/BODao9zE+bb4dM4ME0VECNHk6+uCVmL9uWzPpO5GSVmpgT0IIY3V6NGjg5544onm8+bN81q0aJHH0KFDg+fOnRsQEBAgnTlzZoap4yOGUUKziWjfvr36+6tXr0IikSAoKAjy5s1x18ZGu7JCARw8aFS7mvNoJiUlqYefE0KanvHjx4Ppzrtbh/XNBWMM48ePN3UYBkVHR9dqUa7jx4+DMYb169fXWUykapzzywBWA3iKMbadMfYyY+wzAMsBnACwWaP6EQDXdZp4jzH2J2NsIWNsMmNsNmPsKIDZAM4BWNUAp0EaUFZBLmLyjuqVRzkOhYODjYE9CCGm8MnLHwI600WX8Vx8sG6NaQIihNRI//798+/du2e1fPlyn/fff9//r7/+kowcOTLz9OnTsS4uLkbNoUkaHiU0zVBJSQnu6KxeHhAQoJ7fsqSkBHFxcejQoQOsrK1x0dAKs0YOO3dzc4OrqysAoKysDCkpKbWKnRBzokr+fPrpp1rljDGth7W1NUJCQjBz5kxkZWXptTNv3jwwxmDM3HUnT57EkCFDEBQUBGtra3h6eiIqKgozZsxAYmJinZ2bsXbu3Il58+Y1+HFJw0lOTsa8efPwn5ELxpEamwkhAdkWQnLzOQiJyEGc86pulI8DyAfwAoAvAMwH4ApgLoBoznlJvURMTOaN1Z9Cxou0C8sYlr9GiwER0pgM/9+jcMoL1itff3YNaK0KQszHtGnTsmJiYmLz8/P/k8lk/96/fz9my5Ytt/z9/alHVyNGCU0zolAosGnTJixbtgxHjhxBUdGDG13GGMLDw9XPY2Ji0Lp1a1haWiJOY9i42v79Qk9NI9Cwc0L0dejQARs3bsTGjRvx6aefonXr1lixYgV69eqFsrKyGrX59ddfo1evXrh69SpeeOEFrF69Gq+//jratGmDLVu24N9//63js9C2du1alJRo50V27tyJ+fPn1+txifEOHjyIGzdu1Hj/xx57DCUlJRg7dqy6LDk5GfPnz6eEZj3jnMs5559xzsM459ac82ac81mc80KdekGcc6ZT9jvn/HHlPjacc3vOeQfO+ULOOY1rbGI459hxZYNeuXdJezz6SP0uykcIqb6xXafplWXK47D/nz9NEA0hhDw8LEwdADGeSCRCWVkZFAoFOOeIjY1Fp06d1Nvbt2+PU6dOAQBu3rwJzjnatGmDfzIzIT1yBNaaCcyMDODCBaBz5yqPGxoair///huAsDDQ448/XrcnRogZatasGcaMGaN+Pn36dAwfPhw7d+7E7t27MWLEiGq1J5PJ8O677yIgIAAXL16Eo6Oj1vaysjIUFhZWsHfdsLS0hKWlZdUV61l5eTnkcrl6sTPygJWVVa32F4lEdF0JaeTW7duNfMUdvfJpj882QTSEkKosfnMqvh75PuSOxQ8KuQJz1n2CgV3+MF1ghBDSxFEPTTPTpk0b9ffXrl3T2ubh4QEf5fBymUyGa9euCcPOnZwQ42ZgPQEjh50HBQXBwkLIfWdkZCA3N7dmwRPSxPXr1w9AzXoyZ2ZmIjc3F507d9ZLZgJCIks1/UNFTpw4AcYYfvjhB63ysLAwMMawY8cOrXJvb28MHDhQ/Vx3Tszo6Gj8+OOPALSH2evOv5iXl4dXX30Vnp6esLGxQffu3XHu3Dmjzls1HP/q1auYNWsW/Pz8YGNjg7/++gsA8PPPP2PIkCEICAiAtbU13N3dMWzYMMTExOi1FRQUhOjoaMTGxuLJJ5+ERCKBk5MTnn76aaSlpenVv3r1Kp544gnY29vD1dUVo0ePRnp6usE4ZTIZlixZgjZt2sDGxgZubm4YPnw4Ll++rFUvOTkZjDHMmzcP27ZtQ4cOHWBra4uQkBD165KSkoKxY8fC1dUVEokEY8aMQUFBgVHXy9Acmqqye/fuYdSoUXBxcYGdnR0ef/xx3Lx5U6uu7hya69evR+/ewoIGL774ovo1jo6OBiCMDPjiiy/Qvn17SCQSODo6IiwsDBMmTEB5eblRMRNCqmfxb8sgrCH1gFWOC96Z+rxpAiKEVMre3hpdXYbrlV8pOI6MvJyGD4jUG5pGgJCGpfyZq3BoMSU0zUzr1g+GGiUlJaG4uFhru+biQDExMQgKCoKTkxOuGVpEwsiEpqWlpdY/0PHx8dWKmZCHRUJCAgBUmXg0xMvLCw4ODjh58mSNhxR369YNtra2OHr0wUISd+7cwc2bNyESibTKr169ivv376NPnz4Vtjd37lz07NkTANTD6zdu3IjHHntMq97jjz+OO3fu4IMPPsCcOXNw5coVPPnkk0Yn6QBg9OjR+PPPP/HGG2/gs88+U3848+WXX0IkEmHixIlYvXo1XnnlFZw6dQrdu3c3mDi+e/cuoqOjERAQgGXLluH555/H9u3bMW7cOK16SUlJ6NmzJ06dOoVp06ZhwYIFyMzMxBNPPFFhfO+88w78/PywbNkyTJ48GceOHUO3bt1w8eJFvfp79uzBjBkz8NRTT2HZsmWQSCR46aWXsGnTJvTs2RMODg5YuHAhnn32WWzatAmvv/660dfKkKKiIjz22GMQi8VYuHAhpk2bhuPHj2Po0KGQy+UV7vfYY4/h3XffBQBMnDhR/RrPnTsXAPDJJ5/g9ddfR1BQEJYsWYJly5Zh+PDh+PPPPyGVSmsVMyFEX9zdFCRK/9Yr7x8wBmIx3bYT0liteGMeUKa9UKKcF+P1L5eaJiBS5xhjOWVlZaYfykTIQ6S8vNyCMVbhJ0M05NzMODo6wt/fH8nJyVAoFLhx4wYiIyPV29u1a4eDBw+Cc47k5GTk5+cjIiICZ2NigH/+0W7sn3+EoeceHlUeNzQ0VJ3IjIuLQ1RUVJ2eFzF/dblwjFQqhbW1dZ21Vx+L2pSXlyMzMxMAkJubiwMHDmD16tVwcHDAsGHDqt2eqlff7Nmz0bZtW3Ts2BHdunVDly5d0LdvX3h7e1fZhpWVFbp3745jx46py44ePQqxWIxnn30WR44c0SoHUGlCs3///ti0aRNOnTqlNbxeV8eOHfHVV1+pn7dp0wbPPvssNm/ejEmTJlUZNwA4Ozvj8OHD6t7gKvv374e9vb1W2bhx49ChQwd8/vnnWscFhA9cfv75Zzz77LPqMpFIhK+++go3btxAWFgYACFZm5OTg6NHj6p7KE6dOhVPPfWUXoLy0KFD2LZtG5599lls3bpV3Yv12WefRadOnTBjxgz1dB8q169fx7Vr1xAYGAgAGDlyJPz9/TF27Fh8+umneOWVVyCRSDB58mTk5ORgw4YN+OKLL+Dg4GDU9dKVmZmJN998E2+99Za6zMPDA2+99RYOHz5c4VQhzZs3R//+/bFw4UJ069ZN73XesWMHWrdujV27dmmVL168uEZxEkIqN2PVx1AotOdhZiUWWLXwPRNFRAgxRqcOIfAt7YB7Vtr3EL9f2wjOF2qNgCHmSaFQ7MvNzX3Oy8sr29SxEPKwyM/Pd+Ccn6xoO33Ua4YqG3YukUjQvHlz9fPLly8jIiIC5QEBuG1np90Q58CBA0YdU3NhoKSkJMhktNgXebgdPHgQHh4e8PDwQGhoKKZNm4Z27drh8OHD8PT0rFGbb7zxBnbt2oUBAwbg2rVrWLlyJcaMGQM/Pz9MmDBBr0e2IX369MHdu3fVvTyPHj2Kjh07YsSIEbh+/TpSU1MBAMeOHYOLi4vWByI1pdu7UJUkrc7Q+5kzZ+olMwGok5mcc+Tn5yMzMxMeHh4ICwszOKzd19dXK5lpKB6FQoHdu3cjKipKncwEhKSyZkJQRTVUf+7cuVr/kERERGDw4ME4ffo0MjIytPYZNmyYOpkJQB2zSCTC1KlTter27NkT5eXlSE5O1r8wRhKJRJgxY4ZWWU1eB11OTk64e/cuTp8+XeM2CCHGKZfLcPz2dr3yFuiB4KCa/V0hhDScmU/q30MU8rv4Zpf+zzUxP3K5/Nv79+/n3r9/31UqlVrS8HNC6g/nHIWFhXZpaWkKmUy2qKJ61EPTDGkmNBMTE1FSUgJbW1t1Wfv27dVDXy9fvowePXogMDAQl/384K8znxr27QMq6Xml4ubmBldXV2RnZ6OsrAwpKSlaiVNCHjaPPPIIPv74Y3DOkZKSguXLl+POnTu1XrRl8ODBGDx4MORyOa5du4YjR45gxYoVWLduHSwsLPDNN99Uur8qiXX06FGEhYXh2LFjGDVqFHr37g3GGI4ePYpRo0bhxIkT6NWrF0Si2n+upfu7wE05Z29WVpbRbbRs2dJg+cWLF/H+++/j+PHjKCoq0toWHBxcZSyG4klPT0dhYSFatWqlV1fz96tKUlISRCKR1pQfKm3btsXOnTuRlJQED43e7obicHFxgY+PD6ytrVFWVqZVrhlfTfj6+uot9lOT10HXwoULMWzYMPTs2RO+vr6Ijo7Gk08+iaeffrrW73VCiLZPNn6PUq7z88qBD0e/b5qACCHVMmvis3h/1zRIXbR/jpfu/AyTh1ZvsUjS+HTq1Cn5woULT6Wmpk68f//+QM65u6ljIqQJ44yxpPLy8qWdOnWqsHcGJTTNkJOTE9zdhd+fcrkcN2/eREREhHp7q1atYGlpifLycty/fx/3799HREQE/gwLA3QTmvv3A3I5IBZXedzQ0FB1j6i4uDhKaBItdTmsu6CgABKJpM7aqw/u7u7qRYAAYPjw4QgPD8eIESNw9epVrQ8ZakIsFiM8PBzh4eEYM2YMQkJC8OOPP+Krr76CuJKf16ioKDg6OuLo0aPo378/UlJS0KdPH7i6uiIiIgJHjhxB69atkZ2dXelw8+rGakh1Prm20+1BDmHxnMceewyOjo54//33ERYWBnt7ezDGMHPmTIOrvld2bRryk/SK4qiv+Oqr3W7duiEhIQEHDhzAsWPHcOzYMWzevBkff/wxTp8+XaP5Ygkhhm3++zeAMWEEjZIk1x9jnq6b39WEkPolFovwRPOx+D3nC63y5LLziLt3G6G+/qYJjNSZTp06JQN4V/kghJgYDTk3U5pDGXWHnVtbW2v1PIqJiUHbtm2R2749SnR7Y2VnA3/rTz5viOaw89oMYSSkKXJ1dcXHH3+MpKQkfP7553Xatru7O1q0aAGpVKqet7MiYrEYjz32GI4dO4bDhw/DysoKPXr0AAD07dsXR48eVc+xaUxC05RzPu3YsQOFhYX46aef8Pbbb2PYsGHo378/+vXrV6tehx4eHnBwcEBsbKzeNt3fp4DQ21KhUOD69esV1jfUW9RcVPUaOzg4YMSIEfjyyy9x9epVrF69GtevX8f333/fQBES0vTFpCQj38Ya7m59Ye/QEiKx0OP62Ujj5iEmhDQOq+a8B1Yi9BliIkvY2TWHq2sPrDl8rIo9CSGEVBclNM2U7qrjuqvNaq52fvnyZVhZWaF1ZCSueHnpN7Zvn9HHVM1xl5mZidzc3GrHTUhTNnbsWDRv3hyffvop8vPzq7VvcXExTpw4YXBbXFwcrl27Bnd3d61hzRXp06cPsrKysHLlSnTt2lXd+7FPnz64desW1q1bBy8vL7Rt27bKtlSL1GRnN/z856peh7o9DNeuXYu0tLRatTto0CCcP39eawElzjmWLtVfjVS1yNOiRYu0Yrly5Qp27dqFHj16GPW6NFaVvcaGEugdO3assD4hpGZW7tsHzgGR2Ab29i3h7tYHPnYD8Nnbr1e9MyGk0fD3c0Mnp2cgcWwPd/d+cJC0gdjCHruvH0SZrNzU4RFCSJNCQ87NlEQigY+PD1JTU9XDzsPDw9XbmzdvDnt7exQVFSE/Px+3bt1CREQE/m7RAp2Vi4Ko7d0LLFhQ5TEtLS0RFBSktdp5586d6/S8CDFnFhYWmDNnDl555RWsWLEC77+vPe/ZunXrsH//fr39OnXqhM6dOyM6Ohrt2rXDE088gdDQUHDOERsbiw0bNqC0tBSrV682as5LVc/L69evY+TIkeryxx57DBYWFrh27Rqee+45o86pa9eu+PLLLzFlyhQ8+eSTsLS0xCOPPNIgPRIHDhwIOzs7jB07FtOmTYOLiwvOnDmDvXv3okWLFrVanOzjjz/Gvn37MGjQIEyfPh1+fn7YvXu33uI+gLDau2qF85ycHAwaNAhpaWlYvXo1bGxssHLlytqcpsm1adMGEokEX331Fezs7ODs7AxPT0/06dMHrVu3RteuXfHII4/A19cXqamp+Pbbb2FlZWX0e4gQUrmC0mIcTjiqXchEGBX1Gpyc9KfjIIQ0bt+/+xUGfPUiOHtwn5JXmodNp87ixd69TBgZIYQ0LZTQNGNt2rRRr1h87do1rYSmWCxGu3bt1HNexsTEYPDgwTjYrRugu1rthQtAWhrg7V3lMUNDQ9UJzfj4eEpoEqLjhRdewEcffYTly5djxowZcHJyUm/7+uuvDe4zadIk9O/fH+vWrcPBgwexa9cupKamorS0FB4eHujVqxemT5+utSJ3Zdq3bw93d3dkZmZqDSt3cHBAly5dcPbsWaPnzxw1ahQuXryIrVu34pdffoFCocAPP/zQIAnNFi1aYN++fXj33XexcOFCiMVidO/eHSdOnMC0adNqtSp4ixYtcOrUKbzxxhtYtWoVrK2tMXDgQGzcuBFeBnqyb9q0CR07dsT69evxxhtvwN7eHr169cJHH32k9bvXHNna2mLr1q147733MHPmTEilUvTq1Qt9+vTBG2+8gb1792LlypXIy8uDp6cnunbtijlz5mjN3UwIqbm1h46jpLxUq0zMbTB9cLRpAiKE1Er7ls5o4/Aorhad1Cpff+YPSmgSQkgdYg25SMLDKioqip8/f75O2zx+/DjCw8OxatUqAELPsLfeektr1dm7d+9i7dq1AIR5NWfPno0TJ04gbPhw+OsuprF+PfDCC1UeNzs7W90bydLSEm+//bZ6GHpTdvz4cURHR5s6jEbh+vXrBld7rkvmsChQU0LXu+E9LNfcmN8XjLELnPOoBgrpoVYf9yMNoSn/Deaco/O8abidn6JV/ojL/7Drg1cbPJ6mfK0bG7rWDccU13rj/muYfeBtrTLGgH3TVyLSjOfdNoY5vrfpXoQQ80RzaJoxNzc3dU8imUyGmzormPv6+sLNzQ0AIJVK1auhX9OYf1Nt716jjunq6qpe1ba8vBy3bt2q+QkQQgghhDzEjl65qpfMBIBJfQeaIBpCSF15rm9ruCBIq4xzYNV+4/7nIoQQUjVKaJoZzjmSk5MRExMDQBh2rqK7Oi9jTGtxoJiYGHh4eKCgZ0/9hg8eBIycjy40NFT9vWr4OSGEEEIIqZ6vDv2hV+Yjbov/PRrU8MEQQuqMpSXDkNb/0ys/mngcecVFJoiIEEKaHkpomhG5XI6VK1di/fr1+Pfff5Gdna2V0IyLi0NZWZnWPppzu8XFxaG4uBhBY8agWLl6sFpuLvDXX0bFoZnQjIuLq/6JEEIIIYQ85JJS72HXfwtRVHQTCsWDOTSf6fA/MGbCwAghdWL6kGhYcFv1c4WiHFn51/DW1ytMGBUhhDQdlNA0I2KxGB4eHurnV65cgYeHh7qsvLxcr8ekq6sr/P39AQAKhQJXr15F28hIXPf11T+AkcPOAwMD1fNmZmZmIicnpyanQwghhBDy0Hpt5SeQyfJRVHgTmZlHkZf3L1AqxdQhj5o6NEJIHfD3tkWUWx/IyvOQn38JmZmHUVhwDVsvfANax4IQQmqPEppmRrPH5ZUrVwBUPuxcd5+YmBjY2toaHnZuZELT0tJSa4VjGnZOCCGEEGI8mVyOw8m/PCjgCkhL78EhrRTOjk1/sUVCHha9fD2RnX0KpSW3AS4HAOQjBT/uo7k0CSGktiihaWbCwsJgaWkJAEhPT0d6erpWQvPmzZsoLy/X2qdt27YQiYSX+vbt28jJyYH/xIn6jV+6BNy9a1QcISEh6u9p2DkhhBBCiPGWbf4JJSxDr/y9UXNNEA0hpL68Nn4YrPNd9co/+WWJCaIhhJCmhRKaZsbKygotW7ZUP798+TI8PT3Vq5mXlZUhISFBax97e3utBGRMTAyCevTAbRcX/QPs329UHJrzaCYlJUFm5IJChBBCCCEPuy8PfKFX5pDXDOOfGdDwwRBC6o1YLEK/gOf1yhOkfyHh3h0TREQIIU0HJTTNUE2Gneuudi4SiZD9yCP6je/bZ1QMrq6u6iRqeXk5bt26ZdR+hBBCCCEPs7+uXsE9flmv/Knwl8FoNSBCmpxVb78PJtVekJWjHNO/+MhEERFCSNNACU0zFBISoh52npOTg3v37mklNG/cuKHXYzIsLAzW1tYAgKysLNy7dw++EyboN37wIKAzZL2yOFRo2DkhhBBCSNVmfb1APZeeiqjYGl+8/aaJIiKE1KfgQE+EsB565UdTfkM5jXIjhJAao4SmGbKwsEBgYKD6+eXLl+Ht7Q0X5RByqVT6f/buPC6qen3g+OfMsO8IiAgqihuKG6Lijri0mtYtzbQys+222n7vbbHl3urXZquVVpZZpraYS+WCuGvuioAoAgouyL6vc35/jJwYh2VQdASe9+vFK88z55x5ZlLEZ77P9+H48eMm19ja2hIcHKwdHzx4EJ8JEyg6XxjV5OfD1q0W5VG97VwGAwkhhBBC1K2wpJhdmebdMH2crsXT09kKGQkhroSXp75oFivVZfLGwq+tkI0QQjQPUtBsoqpPGT98+DCqqjao7TwmJoZKnY5zffua39zCtvMOHTpgY2OcxJmRkUF2draF2QshhBBCtDzPfjKHCqXANFgJb/9ztlXyEUJcGVNvHo1rXjuz+Nx1H1shGyGEaB6koNlE+fn54exs/CQ/Pz+fEydOmBQ04+Pjqaw0bWcKDAzE1dUVgMLCQo4fP06rqVPNb756tUU52NramhRWZZWmEEIIIUTtftg93yzmXdSd0cP6XvlkhBBX1KS+95vFzhDDloMHrZCNEEI0fVLQbKJ0Op1JAfPQoUO0bdsWd3d3AEpKSkhKSjK7pvpAoYMHD+J6223mN4+JgZMnLcqjetu57KMpRNM2ffr0Bg2kaOj5TVl0dDSKorBgwYKLvkdERASBgYGNlpMQomlZGhVFtpJkFp858okrn4wQ4op779mn0Bc5mAZVA0/NfcU6CQkhRBMnBc0mLCQkRPt1bGwsBoOhQW3n8fHxlHp5kVXTP7AtbDuvPhgoKSnJbBiREE1ZVRHrnXfeMYkrimLyZW9vT+fOnXniiSfIzMw0u8/s2bNRFIXdu3fX+5ybNm3ipptuIjAwEHt7e1q3bk1YWBiPPfaY2d64V8Kvv/7K7NmzL9v9FyxYoL2Pa9euNXs8OTkZRVF45JFHgL+LqJZ8VeUdERGBi4uL2b3LysqYNGmSdn9VVS/b66zNggULmDNnzhV/XiHElffyd28Apt9nbPPdee2JmdZJSAhxRbm5OdLP9Xqz+N6cP8kvKrJCRkII0bRJQbMJa9++PW5ubgAUFxdz/Phxs7Zzg8Fgco2vry+tW7cGoLy8nPj4eOwnTjS/uYVt561atcLLy0u7X0pKykW8EiGanr59+7Jw4UIWLlzIO++8Q3BwMB988AEjR46krKzsou45d+5cRo4cyeHDh7n77rv55JNPmDVrFj169OCHH35g7969jfwqTM2bN4/i4mKT2K+//sorr1yZlQPPP/98vUXFBx54QHvfq74Aunfvbha/5ZZbar1PUVERN910E0uXLuWFF17g448/rnO16YgRIyguLubOO++8uBcHrFmzhiNHjpjEpKApRMuQlnGOI8WbzeIj/G7FxkZvhYyEENbw7sOvQKXpzxsVSiFPffSulTISQoimy8baCYiLpygKISEhbNu2DTC2nd988824ubmRl5dHUVERycnJdOrUyeSa3r17s27dOsDYdt7n1lvhwn9Qr1sHpaVgb19vHl26dNFWpR09epSgoKDGeYFCXMX8/f2ZNm2advzoo49y88038+uvv7JixQr+8Y9/NOh+FRUV/Pvf/6Z9+/bs27dP+7CiSllZGQUFBbVc3ThsbW2xtbW9rM9Rm7CwMHbv3s3ixYuZMmVKrecNHjyYwYMHm8TuvPNOfH19Tf5/1CUnJ4cbbriB7du38/777/PEE0/Ue41Op8PBwaHe8+piZ2d3SdcLIZquR9/7Lwal1CSmlOv5+NnZ1klICGEVI8JDaF3cg3SXwybxJfu+4nP1hRazlY8QQjQGWaHZxFVvO4+Pj6eioqLetvPq+2geP36c/B49KDs/YEhTWAhbtliUQ/W2cxkMJC7JokUQGIiLuzsEBhqPm5AxY8YAF7efbEZGBjk5OQwYMMCsmAnGYlirVq3qvMfGjRtRFIWvv/7aJN6tWzcUReGXX34xibdp04brrrtOO75wT8yIiAi++eYbwLTN/sJ9JHNzc3nooYdo3bo1Dg4ODB06lJ07d1r0uqs89thj+Pv788ILL1z0CldLnD17loiICHbu3MlXX31lUTETat5Ds3rs66+/pmfPntjb29OhQwf+7//+z+weF+6hGRgYyMaNG0lJSTF5f6Ojoy/tRQohriqqqvLH8R/M4u0rB9K9c4AVMhJCWNODY2aZxXJ1yfywdp0VshFCiKZLCppNnJ+fn9byXVZWxtGjR00KmnFxcWZt5+7u7to/qlVVJSY+norISPObW9h2HhgYqK3qysjIIDs7+yJeiWjSFKVxvqZNg5QUFFWFlBTjcWPd+wpITEwEqLfwWBNfX19cXFzYtGmTWVuypQYPHoyjoyNRUVFaLDU1lYSEBHQ6nUn88OHDnD17lsia/uyf95///Ifhw4cDmLRyjxgxwuS8a665htTUVF566SX+9a9/ERMTww033EB+fr7FuTs6OjJ79myOHz/OZ599ZvF1DZGSksLw4cOJj49n6dKlTJ8+vVHu+9lnn/Hqq68yZcoU3n33Xfz8/Hjuuef4/vvv67xuzpw5dO/eHW9vb5P3Nzg4uFHyEkJcHd7/4QeKdelm8X/d+rwVshFCWNtLD9+DXYGHWfzV79+48skIIUQTJgXNJq6q7bxKTEwM7dq1w9XVFYDCwkJOnDhhdl314UCHDh3Csab2WAsHA9nY2JisOpJp56IlKC8vJyMjg4yMDI4dO8Ynn3zCJ598gouLCxNr2pe2HlVDbM6dO0fPnj0ZOHAgjz/+OIsWLeLMmTMW3cPOzo6hQ4eyYcMGLRYVFYVer2fy5MmsX7/eJA7UWdAcO3astmXFtGnTtK/q21gAhIaGsmLFCh555BFefvll5s+fT2ZmZr0FvQvdc889BAcH8/rrrzeoGGqJsrIyhg0bxunTp1m1ahU333xzo937xIkT7N+/nxdeeIFHHnmEqKgovL29+eijj+q8buLEifj6+uLs7Gzy/vr6+jZabkII63t/1XtmMaf8Ntw/ZbwVshFCWJteryPCf7JZ/GjZVlLOnLVCRkII0TRJQbMJysrKMpl2XL2gmZCQQFlZmckKn5raznv06IFeb9yE/tSpU2SGhZk/UVwcJCVZlFOXLl20X0vbuWgJ1qxZg4+PDz4+PnTp0oVHHnmEkJAQ1q1bpw3eaqinnnqK3377jXHjxhEbG8uHH37ItGnTCAgI4N5776XIggmYkZGRpKWlaas8o6KiCA0N5R//+AdxcXGcPn0agA0bNuDp6Um/fv0uKtfqZs0ybZ2qKpI29MMNvV7PG2+8wblz53j77bcvOa/qKisrSU9Px9XVlXbt2jXqve+55x7c3d21YycnJ8LDw+XDHSEEyekZFLdywsExAJS/f+y+Kfge2StPiBbs42deRimvPhBMwda+Fe8vX2G1nIQQoqmRgmYTUlZWxuLFi/noo4/YunUrhYWFAPj4+NCmTRvAOFgkPj7erO38wsnBDg4OdOvWTTs+ePYsJdUKoxoLV2lWL2gmJSVRUVFh8esSoikaNGgQa9euZc2aNcyfP58ePXqQmpp6yYNfxo8fz+rVq8nNzeXgwYO8//77tGvXjq+++sqscFiTqmJi1QrMDRs2EBkZyahRo1AUhaioKAwGAxs3bmTkyJHodJf+18CFKzartsGoGhbWEBMmTGDo0KG89957Fq9MtYSjoyNLly4lMzOTiIiIi27rr8mFrx+M78HFvH4hRPPy/oo/0Nu44+bWF2/vMTi7BGNX6cXHz//L2qkJIayoSyc/AtXB6HT2ODt3wds7EnePMNYl/4XBoNZ/AyGEEFLQbEpsbW3Jz89HVVUqKyvZvXu39tiFbeft27fH+fygn/z8fE6ePGl2v+pt5wcPHsR2wgSzc1QLC5qenp5aEaO8vJzk5GSLrhOiqfL29mbMmDGMHTuWe++9l82bN2NjY8M//vEPiouLL/n+er2eXr168cQTT7Br1y7c3d355ptvqKysrPO6sLAw3NzciIqK4tixY5w4cYLIyEhatWpFnz59WL9+Pfv37ycrK6vOdvOG5lqTCz9IsdRbb71FYWEhr7zyyqWkZeamm25i2bJlWlEzPj6+Ue5b2+sXQrRs5ZUVrDryp3as09nh7BzEPcM/wauVqxUzE0JcDT55fC7e3qNxdumGTu8IwLmS0/yyY5+VMxNCiKZBCppNiKIohIeHa8e7du3SVkJWL2gmJiZSUlJSb9t5586dcXQ0/uWZk5PDuRraztV166CkxKL8pO28BVPVxvn67jvo0AFVUaBDB+NxY937MmvVqhWvv/46SUlJvP/++416b29vb4KCgigtLSUjI6POc/V6PSNGjGDDhg2sW7cOOzs7hg0bBsDo0aOJiorS9ti0pKBpjZbIoUOHMmHCBObPn9/obdvjx4/np59+Iisri1GjRhEXF9eo928oaTkVovlasH47+eU5JjFF1fP4jeOsk5AQ4qpy3fAQOjn1N4vP32jZYFYhhGjppKDZxPTo0UMb+FNQUMDhw4cB8PDw0PaFMxgMxMbGmrSdx8bGmq2WsrGxoWfPntrxbkWhwsPD5BxdSQls3GhRbp07d9Z+LXvHiYsydSokJ1OQmwvJycbjJuTOO++kU6dOvPPOO+Tl5TXo2qKiIjbW8mft6NGjxMbG4u3tjY+PT733ioyMJDMzkw8//JDw8HCcnJy0eEpKCl999RW+vr4mf/5r4+LiAhj37r2S3njjDVRV5T//+U+j3/vGG2/k559/Jjs7m1GjRtX4gc+V4uLiQnZ29kWvZhVCXL2+3W5elAjxGExwoKcVshFCXI3uHHSDWWz/ub9IPH3OCtkIIUTTIgXNJkav1zNw4EDteMeOHdo/hC9sO+/QoYNWyMjLyyMtLc3sftXbzg/Hx6OOM181ULlypUW5BQYGYmtrCxj3zrvSBRAhrM3GxoZ//etfZGdn88EHH5g9/tVXX/H666+bff3+++8UFRURERFBr169eOaZZ/jiiy/4/PPPmTVrFuHh4ZSUlPDWW29ZtOdl1crLuLg4k1WYI0aMwMbGhtjYWEaNGmXRa6paFf7Pf/6ThQsXsnjxYpIsHBZ2KYKDg5k+fTq7du26LPe/4YYb+Pnnn8nJyWHUqFHah0NXWnh4OHl5eTzyyCMsWrSIxYsXk56ebpVchBCNZ8+xExzNiTGL3zvcvHghhGi57rkmDBfF2yRmUFXmrPzDShkJIUTTIQXNJqh///7anm2nT5/mxIkTAPTs2VNrX0xJSaGwsJDu3btr19W0Cqldu3Z4nF+VWVxcXGPbecVvv1mUl42NDR07dtSOpe1ctER333037du357333iM3N9fksblz5/Liiy+afS1fvhwPDw+++uorQkJC+O2333j66ad59NFHWbJkCSNHjiQqKooZM2ZYlEPv3r3x9jb+cFy9oOni4qJ9IGLp/plTpkzhqaeeYsuWLUyfPp0pU6bUupK0sb3yyivathiXw/XXX88vv/xCbm4uo0aNIibGvPhwuc2aNYsZM2awbNky7rrrLqZMmWLVFaNCiMbx4e+ruXDddSt9OyZF1L8yXgjRcjg66Lm283Vm8dUJf1ImQ1aFEKJOirS5XX5hYWFq9QE+jeF///sfZWVlgHEl0+TJkwH49ttvOX78OADXXHMNPj4+fPfdd4CxLf3xxx8327MtKiqKTZs2AdA3IIAJ99+PcuHvi6NHoVpLeW3++usvVq82tlh16dKFqU2sZbg20dHRREREWDuNq0JcXJzJ/qyXQ35+vra1grj85P2+8lrKe27J9wtFUfaoqmr+aZpodJfj55Eroan9HZyelUOP/1yDzt4bRfl77cCM3g/yxj1X9wrNpvZeN2XyXl85V/t7nXAym5HvzsCgVCtgqipPDZ7Js5MnWi2vi3W1v981kZ9FhGiaZIVmE1V9f8z4+Hiys7MB87bzjh074uDgABgH/5w+fdrsXr169dJ+fej0acpDQ83OKf75Z4vyqj4YKDk5WRtaJIQQQgjREjz23v/IzP2LjIx1FBTEUVlZhA0OPDbesq0+hBAtS9d2nvTyHAKAwVBKYeFRMjKjePOnp6ycmRBCXN2koNlEeXh4EBQUBICqqvz111+AcbVmVTt6Wloaubm59bad+/j40LZtWwAqKyvJqKHtvPinnyzKy9PTU2t1LS8vJzk52fIXJYQQQjRTiqLoFEWZpShKvKIoJYqinFQU5V1FUZyvxPXiylBVlZVHjJ0xqqGMosJEMjM20CqvEj9vJytnJ4S4Wt3efwi5uXvJyFhPYcERDJXFZNsk8dP6K7PNjxBCNEVS0GzCqoZ1AOzdu5fS0lIcHR1Npo3HxMTUO+0cTIcD7fH1NXvcbd8+1MJCi/Kq/vyyj6YQQggBwPvAe0As8CiwFHgMWKFU70u+fNeLK+CTJT9TaHthN4zKzJF3WCUfIUTTcOc1gzBkF4JqqBZVeWnhf62WkxBCXO3kB+AmrHPnztpqyNLSUvbv3w+Yt5136tQJe3t7ALKysjh79qzZvUJCQrS9NfcCFV5eJo/blJeTsWyZRXlVbzs/evSoxa9HCCGEaI4URemJsQj5s6qqt6iqOk9V1SeBJ4FRwO2X83px5byz/G2zmGNhax6d9g8rZCOEaCpsbW0Y7nuLWTy+ZCOnM7KskJEQQlz9pKDZhCmKwqBBg7TjnTt3oqoq3bp1w9bWFoD09HQyMzPp1q2bdl5NbecuLi5/t7ArCpk1tJ0XLFliUV4dOnTQnj8zM5OsLPlLWAghRIs2BVCAORfE5wFFwLTLfL24AmKOpXBCNR+6dGPXu9DplBquEEKIv3389Gyo1JvEDLoyHnnndeskJIQQVzkpaDZxffr0wdHRETCuvkxISMDOzs6kgHlh2/nhw4drbDuvPhzogL+/2eMeO3ZQfn6yel1sbGzo2LGjdixt50IIIVq4AYAB+Kt6UFXVEmD/+ccv5/XiCnhszmxUpdIkpiu346Nn/2OljIQQTUlw5/Z0MJh/O/8j8XsMBvN/uwkhREsnBc0mzs7Ojv79+2vHO3bsAGpuO7ezswOMqybPnTtndq/g4GBtZeU+b29UnelvD8+sLJL+/NOivKTtXAghhNC0BTJUVS2t4bE0wFtRFLvLeL24zMorKtia/otZvLvdKHx9PK58QkKIJum5W543ixXZnuWD7y3rlBNCiJbExtoJiEs3YMAAtm3bhsFgICkpibNnz9K5c2ccHBwoKSkhOzub9PR0unbtSkxMDGBsO2/durXJfezs7OjevTuHDh2i2NGR7O7daXVBe3re4sUwfny9OVUfDJSUlER5eblWLBVCCCFaGCegpmIkQEm1c2prg7jo6xVFuR+4H8DX15fo6GgL0r26FBQUXPV5f75yFWU2uWbxKWETr/rcq2sK73VzIe/1ldOU3uvubdywz/eh1NV08ckbP71OvwDzwa1Xo6b0fgshmjYpaDYD7u7u9OjRQytW7tixgwkTJhAcHMy+ffuAv9vOqxc0IyIizO7Vu3dvDh06BMDhDh0YfkFB03PHDvLz83F1da0zJ09PT7y9vcnIyKCiooKUlBSTIqcQQgjRghQBrWt5zKHaOY1+vaqqXwBfAISFhak1/d1/tYuOjq7xZ5aryW2fPAQXfG7rWRzEC7MetE5CF6kpvNfNhbzXV05Te69v/vNeFp940yR2ziEOT7929OkWZKWsLNfU3m8hRNMlLefNRHh4uPbrQ4cOUVhYaNJ2fvjwYTp16mQyLKimtvOgoCCcnZ2N17RrZ/Z4h5QUYs63tdenegFT2s6FEEK0YKcwtoXb1/CYP8Z28ro2qb7U68Vl9Oe2XWTYHjGLTxv0kBWyEUI0dR8+8zy68gu+3SuVPPrBbKvkI4QQVyspaDYTAQEBBAQEAFBRUcHu3bvp2LGjVpzMz8/nzJkzJntbxsXFmd1Hp9NphdAzbdpQ7Olp8rhNZSVZy5bVOFToQtWfSwYDCSGEaMF2YfyZa2D1oKIoDkBfwHw0duNeLy6j5+e/Cpj+XGRT6sLbsx6zTkJCiCbNx8udng6jzeI7zi2nrLzCChkJIcTVSQqazUj1VZq7du3CYDCYTDc/dOiQyXHsBe3kVXr37m38haKQ0KmT2eOt9+zh9OnT9ebToUMHbUVoZmYmWVlZFr0OIYQQopn5EWPF64kL4vdh3PtyUVVAUZQgRVG6X+z14srKys3nYME6s/igVuOxt5e9w4UQF+eNe18yi5Xb5vP8Rx9bIRshhLg6SUGzGQkODsbNzQ0wbsZ8+PBhevXqpT0eGxtLp06dsLExbp165swZMjMzze7Ttm1bvLy8ADhSQ0Gzy7Fj7D+/N2ddbGxs6Nixo3YsbedCNNz06dNRFMXaaRAYGCj7IQlxkVRVPQR8AtyiKMrPiqLMVBTlXeA9YCPwfbXT1wNxl3C9uIIee/ctDDYlpkGDjg8ef8U6CQkhmoUbIgbhVdLVLP7NtrlWyEYIIa5OUtBsRvR6PQMH/t2NtmPHDgICAnB3dweguLiYtLQ0k70ta2o7VxRFW6WZ2KkTBp3pbxOP3FxOrV9PRUX9LQ/Sdi6ag7y8PF577TVCQ0NxdXXFycmJHj168Mwzz3D27NlLvv+CBQuYM2fOpScqhLiaPQE8DfTEWJy8HfgIuFFVVcMVuF5cBssPLzCL+Vf0pX9IF/OThRCiAe4abL4Pb5bdUVZv2mmFbIQQ4uojBc1mJjQ0VGvzPn36NCdPnqRnz57a4xe2nR8+fLjG+1QVNEsdHDjRvr3Z4+1jYkhISKg3n+rF06SkJMrLyy17IUJcJRISEujTpw8vv/wynTp14s0332TOnDmEh4fzwQcf0LNnT7Zv335Jz1FXQXPevHkUFxdf0v2FENanqmqlqqrvqqraTVVVe1VV/VVVfVJV1YILzgtUVdVsWbal14srZ95PKyiwTzOLP37D01bIRgjR3Lz5+CPYlrpeEFV5/ktZAS6EECAFzWbHycmJPn36aMc7duwwaTuPj4+nY8eO6PV6wFj0zM7ONruPp6cn7c5POT8aFGT2eJejRzlw4EC9+Xh6euLt7Q0YhxWlpKQ07AUJYUVFRUWMHz+etLQ0VqxYwbJly3j44Ye5//77+eqrr9i2bRsVFRVMmDChUVZq1sTW1hYHB4fLcm8hhBAX741lb5rFHIq9efKuyVbIRgjR3NjZ2TDYe4JZ/HBJFBnZeVbISAghri5S0GyGBg0apP06Pj4ee3t7bU/MsrIyTp48SVC1ImV9w4GOdjFvm2p34gQphw5RUFD/wpDqbeeyj6ZoSr788ksSEhJ44oknuOGGG8weDwsL43//+x/nzp3j7bff1uLR0dEoisKCBQv46KOP6Nq1Kw4ODnTt2pWPPvrI5B6BgYFs3LiRlJQUFEXRvqKjo4Ga99CsimVmZjJ9+nS8vb1xdXVl4sSJnDlzBoAvvviC4OBgHBwc6N69O8uXLzfL/9NPP2XcuHF069YNOzs7/Pz8mDZtGsnJyZf4zgkhRPN2JiufU3bHzeLXdJqKXi8/XgshGsdHT74Kqun3FIO+lKc/nGOdhIQQ4ioiP3E1Qz4+Plqrt6qq7Nq1i5CQEO1xS6ed9+zZE51OR3rr1uS6mrY72BgMBCYmcujQoXrzqd52LgXN5m32bFCUS/9yc7uwvcacJfeZPfvSXs+yZcsAuP/++2s9Z/r06dja2vLTTz+ZPfbRRx/x5ptvMm3aNN544w08PDx47LHHeOWVv1uF5syZQ/fu3fH29mbhwoXaV3BwcL35XXvtteTm5vLqq69y3333sXLlSm6++Wbefvtt3n77be6++27efPNNysrKuPXWW0lKSjK5/p133sHb25sHH3yQTz75hEmTJvHLL78wZMiQGgeGCSGEMPpoZRTurcJo5TUSR8dAFMUGXaUtHz/zgrVTE0I0I727daRdZajxQNHh4OCPZ6uhHCwx77ATQoiWxsbaCYjLIzw8XBvCs3fvXu666y42btwIGIuK48aNQ6fTYTAYSEtLIycnBw8PD5N7ODk50aVLF44cOcKxLl3ov3evyeNdjh5l14EDDB48uM5cOnTogK2tLeXl5WRlZZGVlUWrVq0a78UKcZnExMTg6upqUpS/kJOTE927d+fQ+RXLLi4u2mMJCQnExcUREBAAwMMPP8ywYcN4/fXXuffeewkICGDixInMmTOH4uJipk2b1qD8Bg4cyCeffGISe//990lLSyMmJgY3NzcAIiMj6dOnD1988QVvvPGGdu6hQ4dwdnYmPz8f1/MfWtx0002MGTOGL7/8kmeffbZB+QghREtgMKj8ErMaABsbV1zdQnBx6U4/p14EtPG2cnZCiObm2Zv/zfMb/o2jYzt0OnsA0kqOsXbPUcb2lwFkQoiWS1ZoNlNBQUHa3pWlpaWkpqbSpk0bwLiX5YkTJ+jUqZN2fk3TzqHutvPOx45x5vRprcW1NjY2NibPtW/fvoa9GCGsJC8vD3d393rPqyoc5ubmmsSnTp2qFTMB7OzsmDVrFhUVFaxYseKS83viiSdMjocPHw7AXXfdpeUExj/Hbm5uZiuknZ2dATAYDOTm5pKRkUGfPn1wd3dn506ZoCmEEDVZuvkAmeWnTGKKzobXpz9mpYyEEM3ZPydPpKvXtVoxs8rc9autlJEQQlwdpKDZTCmKQnh4uHa8c+dOkzZzS9vOu3btir29Pcc7dqRCZ/rbxT0/H9/0dPbv319vPtUHE+3cuZPCwkJLX4oQVuPm5kZeXv2brledc2Hxs6a28ao/d8ePm++91lDVPygA4xAugI4dO5qd6+npadZGHhUVRUREBG3atMHDwwMfHx98fHzIzc2tcViYEEIImL/JvIjQ2bUPA7oF1HC2EEJcGp1OYVLo9WbxnWc2cSoz3woZCSHE1UEKms1Y7969cXR0BCArK0v7NRiLKe3bt0d3vkh58uTJGgs3tra29OjRgzJ7e0506GD2eJejRzl06BCVlZV15tKzZ09at24NGAcTbdmy5aJflxBXSkhICHl5edr2DTUpKioiPj6ewMBAk3bzK0Gv1zcorqqq9utdu3Yxbtw4zpw5w+zZs1m+fDlr1qxh7dq1eHl5YTAYLkvOQgjRlB05mcGhrB1m8bvCzYsNQgjRWP55/QgcdM4msQq1jA9XrLdSRkIIYX1S0GzG7Ozs6N+/v3YcGxtLu3btAGOLaXJyMoGBgdrj9bad17CPYOdjxygsLKyz4APGFaOjRo3Sjnft2mXRyjfRtMyeDap66V95efV/2mzJfS51KNAtt9wCwPz582s959tvv6W8vFw7t7qa/kxVrYauvrrywinmV8L3339PZWUlv//+O//85z+56aabGDt2LIMHD5bVmUIIUYs5K/5ERTWJuepbcc/YQVbKSAjRErg52xPRYYxZfHnsagwGtYYrhBCi+ZOCZjM3YMAAbRVmUlISfn5+2mOWtp136NABNzc3jtWwj2a7EydwKCmxqO28e/futG3bFjDu47l58+aGvBQhrriZM2fSuXNn3nvvPf744w+zx/fu3cu//vUvfHx8eOaZZ8weX7RoEampqdpxWVkZ77//Pnq9nhtvvFGLu7i4kJ2dbbKC8nKrWsV54XP+73//k9WZQghRg6KSMv5I/NMsfn3X67CzrXllvBBCNJbHrrvOLJZVfpofovdf+WSEEOIqIAXNZs7d3d2kaJmXl6etBjtx4gRt27Y1OS4oKDC7h06no1evXpzz9ibngj0C9apKp8REEhISKCoqqjMXRVGIjIzUjvfu3SsrwcRVzdnZmd9++w0/Pz9uuOEGJk2axKeffsoXX3zBzJkzGTx4MDqdjl9//VUbulVd165dGTRoEK+99hpz5sxh2LBh7Nq1i3//+9/aammA8PBw8vLyeOSRR1i0aBGLFy8mPT39sr62m2++GZ1Ox/XXX8/HH3/Mxx9/zIQJE/j++++1gWJCCCH+9sibb3Dy3K8UFyWjqhUA6NDzxPhxVs5MCNES9O/iTzf3vtqxqhooKUnjP9/Msl5SQghhRVLQbAGqDwc6evSotkpSVVVSUlLocH5vTFVV6247V5Qap513OXaMyspKYmJi6s0lKCiI9u3bA1BZWcnGjRsb/HqEuJKCg4M5ePAgL7/8MgkJCTz77LM8/vjjbNmyhUcffZTDhw8zZMiQGq999NFHee655/j222957rnnyM7OZs6cObz66qsm582aNYsZM2awbNky7rrrLqZMmVLriunGMnToUH766SecnZ15/fXXmT17No6OjmzcuFGbfi6EEOJvyw58SWVFPvn5MWScW0d+fgzdnLrRya+VtVMTQrQQdw++gcrKIgoK4snMWEde7j5Syjexbttea6cmhBBXnI21ExCXX0BAAAEBAaSmppoN7zl06BB9+/YlOTkZMLadDxgwwOwevr6++Pr6crRzZwbs3m3yWOejR1FUlf379zNw4MA6c1EUhdGjR/P1118DcODAAYYNGyYrwsRVzd3dnZdeeomXXnqpwdc+9thjPPbYY3We4+TkxJdfflnjYwsWLGDBggX1xgAiIiJqbVuv+jNe3cSJE5k4cSL5+fm4urrWeW5NMSGEaCm+Xb6GfMeT2rGqVlBclMzYjsFWzEoI0dLcGRnGg/N3UWFbfb95lWe+eIV9Q5ZbLS8hhLAGWaHZQlRfpZmRkaH9+tSpU/j6+mpt58nJyRQWFtZ4j969e5PUsSMVF0xQdi0sxPfMGU6dOmVRm2yHDh0ICgoCjKtCo6OjG/pyhBBCCCGumNcW/9csZl/qxfP33GWFbIQQLZWdrQ2DWt1oFj9YuIacvJr/DSeEEM2VFDRbiODgYNzc3AAoLS3FwcFBeywlJUXbz09VVeLj42u8R0hICBX29iRXm4xepcvRo4BxxaUlqu+lGRMTw5kzZyy6TgghhBDiSko8cYZEwzaz+OgOk9Dr5UdpIcSV9cFjs7nwn/EG2xIee/tNq+QjhBDWIj+FtRB6vd6kHbyoqEhrTY2JibFo2rm7uzuBgYEc69zZ7LGqgubBgwctmpDs7+9P9+7dteMNGzZY9kKEEEIIIa6gR999BVVfYRJTDLZ8/FTDtyERQohL1b9nV/wr+5rFf4n5+sonI4QQViQFzRYkNDQUW1tbwLgSs6q1PD09HS8vL+28pKSkWieW9+7du8bBQAFpaTgWF5Ofn09iYqJF+YwaNUprdT9y5AipqakNej1CXK2q9rKcPn26tVMRQghxCSorDUSdWGIW72wzhI7+bayQkRBCwGPXmU82L3BM48ufVlshGyGEsA4paLYgTk5O9OnTBzCu2Kw+IOjEiRMEBAQAYDAYOHLkSI33CA4OJrd1a7I8PU3iOlUl6Hwh09K2c19fX3r27KkdyypNIYQQQlxN/vvFN5Q6ZpnFX5rybytkI4QQRk/deQcOZeZDVf+35A0rZCOEENYhBc0WZtCgQdqvKyoqKC4uBoxt58HBf0/qrK3t3MHBgW7du3O0hrbzzufbzuPj47X71iciIkJbpZmYmCiTlIUQQghx1fh03ftmMbey9ky7YZwVshFCCCO9Xse4wDvM4kls52jyKStkJIQQV54UNFsYHx8fOp8vRnp6enLu3DkAsrOz8fDw0M47fvw4JSUlNd6jV69eNbadd0lMRFFVKioqOHz4sEX5eHt707dvX+04KipK29tTCCGEEMJatu45zFm7GLP4bX3vtUI2Qghh6uOnX0Ax2JrEVH0lj7zzipUyEkKIK0sKmi1QeHg4ADqdjvLycioqjBvdnzx5krZt2wJQWVlZa9t5ly5dOBscTLmNjUncubAQv1PGTwQtbTsHGDlyJHq9HjC2vlu6B6cQQgghxOXy5CezQTH9kFVf4cR7TzxtnYSEEKKadm186GY73CwefWoJFRWVNVwhhBDNixQ0W6CgoCC8vY17rnh6enLmzBkADh8+bDJ5vLa2c71eT7e+fUkODDR7rNv5YuTJkyfJyMiwKB8PDw9CQ0O1Y1mlKYQQQghrKigsYU+u+XCNfm7X4ObiZIWMhBDC3Oxp5vv5ljnk8MpnX1khGyGEuLKkoNkCKYqirdKsajtXVZX8/HxcXV218xITEyktLa3xHrVNOw9OSdF+3ZBVmiNGjMDm/IrPU6dOER8fb/G1QgghhBCN6cl336PSvuiCqI53H5ptjXSEEKJGk68ZjXt5oFn8i6gPrnwyQghxhUlBswk6fvw4cXFxl3SP3r174+joiKIouLi4kJmZCUBqaipt2rQBjEODEhISary+Xbt2nK22qrKKT1ISToWFgLGgaTAYLMrH1dWVgQMHascbNmyw+FohhBBCiMb0494vzGKtK4IZ0b+3FbIRQoja3R56n1ks3T6WjTsPWSEbIYS4cqSg2YSUlJSwcOFCvv32W3bv3k1ubu5F38vOzo7+/fsD0Lp1a1JTUwFjm3m3bt2082prO1cUhQ6RkWR4eZnGVZUe5++Vl5fXoKnlQ4cOxc7ODoD09HSLBwsJIYQQQjSWH1dHk+eUYhZ/MPJxK2QjhBB1e/eJJ7GpdDYNKipPzX3ZOgkJIcQVIgXNJsTe3l6bPF5ZWUlUVNQl3W/AgAHodDrc3NwoLi6moKCA4uJinJz+3hvq6NGjlJWV1Xh97969OXp+Ynp1fc4PBgLYv3+/xfk4OztrrfBgXKVZWSkbWgtxtYiOjkZRFBYsWHDR9wgMDCQiIqLRchJCiMb20revmsXsyz156T6Zbi6EuPo4OzrQ3+M6s/j+gj/Izbtw6wwhhGg+pKDZhCiKwtixY7XjgwcPagN9Loa7uzs9evRAURSTVZppaWm0bt0aMLadHz16tMbrvb29yapWgKzSZv9+lPPt4nFxcbXuw1mTIUOG4ODgAEBWVlaD9uEUorFVFfAURWHevHk1nqMoCjfeeCMAs2fP1s6v72v69OkATJ8+HUVRzIZoqarKE088gaIo3HLLLQ36c9RcREdHM3v2bHJycqydihCihTiRlsFRwxazeETArej18mOzEOLq9N5DL3PhP+0r7YqZ9c471klICCGuAPnJrIkJDAyka9eugLHgsW7duku6X9WKyNatW3P27FnKysqIj4/XngNqbzsH8L75ZspsbU1itnl59Dq/krS8vLzO6y/k4ODA0KFDteONGzdSUVFh8fVCXC6zZ8+muLi4znNuueUWFi5caPLl7e2Nt7e3WfyBBx6o9T6VlZXcc889fPDBB9xzzz0sXboUe3v7xn5JDTZixAiKi4u58847r8jzRUdH88orr0hBUwhxxXwTvQc3777Y2bfWYopqw8ezpHVTCHH1GtI3hDaVISYxW7tW7MiqeR6CEEI0B1LQbILGjBmDoigAHDt2jOPHj1/0vQICAggICMDFxQUHBwdOnTpFWVmZtpclQEJCAuXl5TVe37N/f5I6dTKLh6Wna79uSNs5wKBBg3B2Nu4Dk5uby549exp0vRCNLSwsjFOnTjFnzpw6z+vduzfTpk0z+XJ2dsbZ2dksPnjw4BrvUVpaym233cY333zDrFmz+PLLL9Hr9ZfhVTWcTqfDwcHhqslHCCEak6rCsgN/Ym/vi4fHQLy8R+HkFEQ3h1F0bu9v7fSEEKJOD497AkXR4+jYgVZeI/D0HEKmbS7bD6dZOzUhhLgspKDZBLVu3ZqgoCDteO3ataiqetH3Cw8PR1EUfH19OXXqFAaDgVOnTuHt7Q0YV1keO3asxmtdXFzIqaHt3HvXLnQ642+vlJQUsrOzLc7Hzs6O4cOHa8ebN2+utaAqxJUwadIk+vfvz1tvvUVmZuZle57CwkJuvPFGfvnlF1599VXee+897cOL2pSWluLo6Mjdd99tEn/ggQdQFIXHHzcdYjF58mTc3NxMVj7n5uby3HPP0blzZ+zt7fHx8WHKlClmH5bUtodmZmYmM2bMwMvLCxcXFyIjI9m3bx8REREEBgbWmHd8fDw33HADrq6uuLu7c+utt5psoTF9+nReeeUVADp27Ki16s+ePRswbkkxa9YsgoKCcHBwwMvLi/79+/P222/X+X4JIURtVu84ypnyv7fZ0eudcXEN5tNZn1gxKyGEsMy/pt9NN/9puLr1wsbGTYt//MfvVsxKCCEuHxtrJyAuTr9+/di/fz/l5eWcPn2amJgYevXqdVH3Cg4Oxs3NjdatW5OcnEx6ejp2dnYMGDBA29cvNjaW4ODgGq93mzwZvvnGJOYUG0uIjw8Hz54F4MCBAw0aBBIWFsa2bdvIy8ujoKCAv/76y6QVXVydZkfP5pWNrzTKvdSX6y7SK6/UXegDeHnky8yOmH3JuSiKwptvvsnYsWP573//y3vvvXfJ97xQdnY248ePZ+fOnXz88cc8/PDDFl1nb2/PkCFD2LBhg0l8/fr16HQ6k+FhqqoSHR3N8OHDsbExfvvPzc1l7NixpKamMmPGDHr27Mnp06f59NNPGTRoELt376ZDhw61Pn9paSljxoxh//79TJ8+nYEDB3Lw4EHGjBlDq1atarwmLS2NiIgIbr75Zt5++20OHDjA559/Tl5eHmvWrAGMBdm8vDx++eUX3n//fe0Dlt69ewNw2223sWnTJh588EF69+5NcXExcXFxREdH88wzz1j03gkhRHWfRa0yi7V36cKo3l2skI0QQjSMXq/jtr4T+XzXlybxTanryMydhpe7g5UyE0KIy0MKmk1U1UTwzZs3AxAVFUVwcLBWpGgIvV7PwIEDWbduHS4uLqSmpuLr62tyryNHjlBRUVHj/YNGj+Zc69b4VGszBxiYnc3B87/ev38/I0eOrHe1WRUbGxtGjBjBypUrAdiyZQthYWFXxT6ComUaM2YMY8eO5dNPP+Xxxx+vs8h3Ma699lpOnDjBwoULmTp1aoOujYyMJCoqiqNHj9KlSxdOnDhBYmIi06ZN47vvvuPs2bP4+voSExNDeno6kZGR2rUvvfQSycnJ7Nixgz59+mjx6dOn06tXL15++eU6p5p/+eWX7N+/n9dff53//Oc/WrxXr148/PDDNb5Px44d48cff2TSpElaTKfT8emnn3LkyBG6devG4MGD6d27N7/88gsTJ040WemZm5tLVFQUDz30EB999FGD3ishhKhJypl89mRsNovfEXa9FbIRQoiL8+gNo/lqz0LKDWVarIxCPlm5mZemjq3jSiGEaHqk5bwJGzp0KE5OToBxddfu3bsv+l79+/fH1taW1q1bU1BQQG5uLqdOncLLywuAsrIyEhMTa7zWzs6O7Brazltt346joyMAOTk5pKSkNCinfv364enpCUBxcTHbt29v0PVCNLa33nqLsrIyXnzxxUa/9+nTp3FwcKBjx44NvraqQFm1GjMqKgq9Xq9NXa+KV63irDpfVVUWLVrEkCFD8Pf3JyMjQ/uq+tCkasVkbVasWIFerzdrbZ85cybu7u41XtO2bVuTYmb1nI4ePVrTJSYcHR2xt7dn586dJCcn13u+EELU58MV66ikzCTmqHfhgWtHWCkjIYRoOB93V4b6jzSLLz2wEoPh4rcoE0KIq5EUNJswBwcHRoz4+wftTZs2UXJ+unhDOTo60qdPH1q3Nk71TE1NJSkpyaS4Ute0cudbbzWL2UZH06tam/qBAwcalJNerzdpU9++fTtFRUUNuocQjalfv35MmTKFRYsWcfDgwfovaIClS5ei1+u59tpr2bp1a4OuHTBgAK6uriYFzbCwMIKCgujVq5dJvFWrVvTt2xeAc+fOkZmZSVRUFD4+PmZfa9eu5ez5bSNqk5SURNu2bXFxcTGJ29nZ1Vqc7VTDILGqD08s2aPUzs6OOXPmEBMTQ8eOHenZsyePPvoo69evr/daIYS4UHm5yop48z3mxgWNxcneroYrhBDi6vXINeYry9PLj7Nim0w8F0I0L1LQbOLCwsK0VYxFRUUNLoRUN2jQIBwcHHBzcyMjI4PCwkKTacZVbec18bvtNsrsTH/oty0oYEBlpXZ8+PBhysrKLry0Tr169dL2zistLWXbtm0Nul6Ixvb6669jY2PDc88916j3HTRoEGvWrEGn03HttdeyZcsWi6+1sbFh+PDhbNiwAVVViYqK0lY8RkZGsn79egwGAxs3biQiIkLb+qFqmNioUaNYu3ZtjV9//vlno75OoM4p6ZYOOHvwwQdJTk5m3rx5hIaGsmzZMsaMGcPtt9/eWGkKIVqIlz77inPFB4C/v/8oCjx2/XXWS0oIIS7S8J6dCXTtahZ/b+VXVshGCCEuH9lDs4mzsbEhMjKSn376CTCuYhwwYABubm71XGnOx8eHzp07k5aWRl5eHmlpaZw+fRpPT0+ys7MpKSkhKSmJLl3MN8fXOTiQ3b8/vhe0hbts2YJ3x45kZGRQVlZGXFycyT599dHpdIwaNYqlS5cCsHPnTsLDw81Wg4mrw+yI2Y0yhCc/P7/ec+obGnS5dOzYkYceeogPPviA6OjoRr33wIEDWbt2LePGjeO6665j9erVDB8+3KJrIyMjWb16NcuWLSMtLY3Ro0cDMHr0aObMmcPPP/9MTk6Oyf6ZPj4+eHh4kJeXx5gxYy4q58DAQNatW0dBQYHJn8vy8nKSkpLw8PC4qPsC9e656+fnx8yZM5k5cyaVlZXceeed/PDDDzz11FMMGDDgop9XCNGyzF33X3Kdk9DrnXF0bI+DYzt6e4cT0sHP2qkJIcRFmTbwBl5fn4CqVlBSkkZxUQqbylaxdffdDA3rYe30hBCiUcgKzWYgJCSEtm3bAlBRUWE27bghwsPD8fHxAYx7+iUlJZkM9air7dz+5pvNYoaVK7X2VjAOB2qoHj160KZNG8BYJKkahCSEtbzwwgu4ubnx7LPPNvq9BwwYwNq1a7GxseG6665j06ZNFl1XVah8+eWXsbe3Z+jQoQCMGDECvV7Pyy+/bHIeGD8wmDp1Knv27GHZsmU13jf9gmFfFxo/fjyVlZV88MEHJvF58+aRm5trUe61qSqQZmVlmcSLiorMtp/Q6/XaBPQLzxdCiNos+30zuc5JAFRWFlJQEEdGxjqu6ST/4BdCNF33jh1GWf4JMjLWk593iIqKPNCpzPr4ZWunJoQQjUYKms2AoiiMHfv31Lr9+/fXW4SoTVBQEP7+/nh6elJZWcnp06fR6f7+bRIfH09ltTby6txraPV0Tkigj4+PttIqOTmZnJycBuWkKIpJEWb37t2XXCgR4lJ4e3vzzDPPsGvXrsty/7CwMNatW4ednR3XX389GzdurPeavn370qpVK+Li4hg8eDAODg4AuLm5ERYWRmxsLH5+fgRX29cW4L///S+9e/dm0qRJ3H777cyZM4dPP/2U5557jl69etVbtJ05cya9evXihRde4J577mHu3Lk89NBDvPjii3Tu3LneVZZ1CT8/bOy5555jwYIFLF68mJiYGBISEvDz82P69Om88847fPnllzz99NO89tprdOzY0eJVrUII8dK3r5rF7MrdePJ2873BhRCiqXCyt6OzLgjVUG4S35u3moLCi5u5IIQQVxspaDYTHTt2pHPnzoBxD7p169Zd1H0URWHQoEEmw4HS0tK0acXFxcW1ThVW2rWjoIZhHw7R0doQEFVVWbt2bYPz6tKlCwEBAQBUVlZavGpNiMvlySefxM/v8rUj9u/f36SoWd/Ka0VRtCFa1T8AALT281GjRpld5+7uzpo1a3jllVc4fPgw//rXv3juuef47bffCA8P56GHHqrzee3t7Vm/fj133303y5cv5+mnn+bIkSOsX78ed3d3HB0dG/CqTQ0dOpS33nqLxMRE7rvvPqZMmcKyZcto164dM2bMYP/+/bz++us88sgj/Prrr9x3331s3boVJyeni35OIUTLcepMFvHl5h8YjWh7CzZ17PUrhBBNwTsPvsyF/9yvdChi1tvvWSchIYRoZLKHZjMyduxYEhMTUVWVhIQEkpOTCQwMbPB9+vTpQ7t27UhISKCkpITDhw8zcuRIbVVkbGwsQUFBNV5rM348XNB6WrRsGUM++4zExETAOByoZ8+e9OhheTuXoiiMHj2ab775BoB9+/YxdOhQWrVq1eDXJ4SlIiIiah1S4+TkxKlTp+q9R20fAFRZsGABCxYsqPGx0NDQBrVPV+2le6H//ve//Pe//631OicnJ1588UVefPHFOu9f2/vh4+Nj9hoqKytJTExk0KBBJvHa3o/a7v3ss8/WuEr0/fffrzNXIYSoz8NvvYZqZ7p6SVFt+OgJackUQjR9I0P74GvowVldjEl8yb7Pmce/rZSVEEI0Hlmh2Yz4+vpqe8gBrF271uKJwdXZ2toSHh6uFQtTU1NN2kbj4uIwGAw1XutQwz6aTlu3EtS+Pf369dNiq1atorCwsEF5dezYkY4dOwJgMBgafSCLEOLiFBcXm8U+++wzcnJyTLbDEEKIq4XBoPJH4ndm8UD9ALoHtrdCRkII0fgeiHzULJbnfILvf7v4mQtCCHG1kIJmMxMZGYmNjXHhbVpaWp1DfOoycOBAbRBPTk4OCQkJ2oCOoqIiUlJSar5wyBAqnJ1NQrbFxVRs3sw111yjTV8vLCxk9erVDc6reivtoUOHLnqvUCFE47nvvvu49dZbee+99/jkk0+YNm0ajz76KJ07d+b++++3dnpCCGHm/QVLKHHJMIs/d8vzVshGCCEujxfvvRf7Ck+z+OxFr1khGyGEaFxS0Gxm3N3dTVo8169fX+sQn7q4ubkxfPhwbSDQwYMHtUnqUMe0c1tbGDfOLJy/eDEODg7cdNNNWuzw4cMcPny4QXm1a9eOLl26AMb9OC9lorsQonGMGzeOkydP8tprr/HEE08QHR3NzJkz2bJlC66urtZOT4irgqIodymKsk9RlGJFUc4qijJfURSfBlyfrCiKWsuX9+XMvTl6f+X/mcVcKvy5/+bxVshGCCEuDxu9nlHtbjOLHzNsJiX1nBUyEkKIxiMFzWZo2LBh2iCOrKws9uzZc9H38fY2/hvp7NmzlJT8PRGvrrZzmxtvNIvp16wBoHPnzoSGhmrxi2k9r75KMy4uzqJ9DIUQl89dd93Fzp07yc7Opry8nNTUVL744gt8fX2tnZoQVwVFUWYB3wC5wOPA58DtQLSiKM51XXuBeODOGr7yGzXhZm7PoUTSbPebxSf0uMtkix0hhGgOPnriJRTV1iSm2lbwyP+9aqWMhBCicUhBsxlydHRk+PDh2vHGjRspLS1t8H0CAgK0PTlVVWXv3r04n28nLygo4MSJEzVfeO21ZiG3lBTU8+ePGzdOm5peVFTEqlWrGrTXp5+fn8lAIVmlKYQQ4mp1fvXk68AuYLSqql+oqvoSMAXogbHAaamzqqp+V8NXw/+Sb8Een/MS6E0/lNUbHPhglrSbCyGan87t/OlkE24WX5vyAwZDw+ctCCHE1UIKms3UwIEDtaJhYWEh27Ztu6j73HjjjdqenEeOHMHLy0t7rNa287ZtUfv2NQvnLl4MYNZ6Hhsb2+DW81GjRmmrKI4ePVp7cVUIIYSwromAE/CRqqraHjCqqq4AjgPTGnIzRVFsFEVxa9QMW5Di4jJ2Zi03i/dyGYOXu7ytQojm6T+3PWcWK3XO5M0vFlohGyGEaBxS0GymbGxsTFqzt23bRn5+wzvSevXqRfv2xmmfVa2kVeLi4mpdWalcf71ZrPy337RfBwUF0b9/f+149erVFBQUWJyXj4+PyUT3qKioi5roLi6OvNdCiPrI9wnNgPP/3V7DYzuA7oqiuFh4r0FAEZCrKEqOoijfKIrStr6LxN+ef/9jKhwv2OpGUXhr5kvWSUgIIa6A6eOvx7WinVn84z/fs0I2QgjROGysnYC4fHr37s327ds5c+YM5eXlREdHM358wza71+v1XHPNNcydOxeA/fv3M2DAAEpLS8nPz+fkyZNawdPE9dfD//5nEnLfvRtKS8HeHjC2nh87dozc3Fyt9XzSpEkW7181cuRIDh06hMFgIDk5maSkJDp16tSg1ycazs7OjuLiYpycnKydihDiKlZcXIz9+e/3LVxVwTGthsfSAOX8OQn13OcwMB+IA2yBCGAmMFpRlIGqqta4obSiKPcD9wP4+voSHR3dwPStr6CgoNHy/mrLB+BhGnMv7oRdSWGTfG8aW2O+16Ju8l5fOfJeGw3xuZY/s+eZxE7bHeST+Yvo2dm/0Z5H3m8hxJUiBc1mTFEUxo4dy8KFxlaCffv2ER4ejo+PxUNVAWPb+ddff01JSQlZWVkmj8XGxtZc0Bw0CNXDAyUnRwvZlZaS//vvuE6cCIC9vT0TJkzg22+/BYwrPmNiYujVq5dFebVq1Yp+/fppQ4+ioqLo2LGjbOh/mXl7e5Oamoq3tzeurq7Y2NjIey6EAIyrMisqKsjPzycjI6NZDYZSFMUDeKIBl3yoqmoWxnZzgJr2uayatlfvJ0Sqqt5wQWixoiibgEXAK8B9tVz3BfAFQFhYmBoREVF/5leZ6OhoGiPv5Wu3UeBhvkXN/aMeb5T7NweN9V6L+sl7feXIe23Ut38Y3vd9R6Wu+O+gXuW7rSvYPnNxoz2PvN9CiCtFCprNXFBQEJ06deL48eMYDAbWr1/P7bff3qB7ODs7Ex4ern3Sdvz4cfz9jZ/ixcbGcs0115gXtGxsUK65Bn780SScv2SJVtAE6NSpE2FhYezevRswtp537NgRFxfLuu9GjBjB/v37qaysJDU1lYSEBLp169ag1ycaxt3dHXt7e86dO0dmZiYVFRWN/hwlJSU4ODg0+n1FzeT9vvKa83tuY2ODg4MD7du3b26v0QN4uQHnfwdkYWwRB7AHii84p+oNKuIiqKr6vaIo/wUuLHaKGvznq1eN62Grsat0578PPWSdhIQQ4grycHWhj+s49haa7iO8K3cFhYWlODtLV4UQommRgmYLMHbsWD7//HMA4uPjOXHiRM2rKuswYcIEraCZlJSEn58fOp2OvLw80tLSCAgIML/o+uvNCpqONbQfjB07lmPHjpGTk0NxcTErV65k8uTJFq36c3d3Z8CAAezYsQMwTjzv2rWrrBi8zBwcHGjXznwfnsYSHR1Nv379Ltv9hSl5v688ec+bHlVVkzErh1mkqhXcHzh2wWP+gFrtnIuRDAy9hOtbhDPpOcSVbwA70/hQ34nY2siPw0KIluGdB14m8v0VoBq0WKVDEU+/O4e5L5kPDhJCiKuZDAVqAfz8/EwG6Kxdu7bBwxr69u2rrcqsqKggMzNTe6zWaefXXGMW8jx9mpL4eJOYvb29ydTz+Ph4Dh06ZHFuw4YNw9bWFoAzZ87Uno8QQghx5e06/9/BNTwWDhxRVdXyqXjmOgNnL+H6FuG9JStQnExXHynY8OHjs62TkBBCWMGosH60rgw2i/908DsrZCOEEJdGCpotRGRkJHq9HoCTJ08Sf0FRsT5V+3FWOXnypNZqHBsbW3OB1NcXwsLMwie/+MIs1qlTJwYMGKAd//777xZPZXdxcWHQoEHa8YYNGzAYDHVcIYQQQlwxyzG2mj+iKIq+KqgoynigE8Y9MKkWb68oSndFUWyrxVrVdGNFUR4GAoAVlyPx5kJVISr1MF5eI/HwHIy9gx8oCu11/QkJCrR2ekIIcUXdF/GI9ms7Ox/cPQagBASyLyHdilkJIUTDSUGzhfDw8GDgwIHa8bp166isrGzQPcaNG6dNti4oKCAjIwOAnJwcTp8+XfNF119vFgr86CMyP/rILD527Fg8PDwAtNZzS1eSDh06VJumm5GRwcGDBy26TgghhLicVFU9B7wIDATWKYpyv6IorwA/APHAnAsu+RbjJPPqI2fvUhTlkKIobyuK8rCiKI8rivIL8DGQSMP29mxxovYmc7L0MAB2dl64u/fH22s0r0573cqZCSHElffyzJl4O4fi5TUKD89B2Nv7ggIfrv7D2qkJIUSDSEGzBRk+fLg2oCEzM5N9+/Y16Ho/Pz9CQkIAMBgMpKenawXHWtu8r7vOLGRbUYHbU09RtmCBSdzOzo4JEyZox0eOHLG4MOno6MiQIUO04+jo6AYXbIUQQojLQVXVd4F7gFbAh8BDwBJgpIXt5ruAJGAy8A7wFtD9/H/DzhdNRS0+WbvaLObv2pU7rxlthWyEEMK6bG1smDH8OfQ2zibxqJQ15BWUWykrIYRoOClotiBOTk4MGzZMO46OjqasrMzi6xVFYdy4cdic3zy/sLBQ20uz1rbzAQNAZ/7bzLa8nPJnnjG7pmPHjiYrSRvSeh4eHq6tIM3JyWlwwVYIIYS4XFRVXaCqah9VVR1UVW2tquoMVVXN+vtUVY1QVVU5P4SoKrZVVdWbVFVtr6qq4/l7BKuq+ryqqjlX8nU0Naczith5doNZfHLoDTJAUAjRYj12wzhsdKYD0UrI5dOVW62UkRBCNJwUNFuYQYMG4ebmBhjbxrdt29ag6/v27Uvbtm0BKCsrIy0tDYCsrCzOnq1hJoFeD7XsZ+mUkcGBAwfM4mPGjMHT0xOAkpISVqxYYVHrub29PUOH/j3odePGjZSXy6eMQgghREv14W8bqKDEJGavd+Cf146yUkZCCGF9/l4eDGwz1Cz+475VNHB2rBBCWI0UNJsYVVXZtGkTcXFxF3W9ra0to0b9/UP8tm3bKCiwfLiqt7c3oaGhKIqCqqoUFhZq19fadt66dY3hSmD1okXaXpxVLmw9T0hIqLHwWZOBAwfi4uICQH5+Prt377boOiGEEEI0L5WVKr/GrjKLj+oQibuzoxUyEkKIq8fDY28wi50qi+fPv45bIRshhGg4KWg2IcXFxXz33XdERUWxa9cuTp06dVH36dOnD63PFxnLysrYuHFjg64fMGAAPj4+gHEvzdTUVKCOtvP33gMbG7OwDRC5cCFLfvxRm5heJTAw0GRy+R9//EFeXl69udna2jJixAjteMuWLQ1qqxdCCCFE8/Dtn7vJqjxpElOAx2oYWCiEEC3N6D7dCXAONIt/tt5832EhhLgaSUGzCbG1taWoqIj09HRycnJYunQpJSUl9V94AZ1Ox9ixY7XjPXv2aHthWiIkJISAgAAAysvLOXv2LGVlZWRkZHDuXA1zCaZOhXnzwNbW7KHws2dxmz+f9evXmz02evRoWrVqBTSs9Tw0NBR3d3fAuM/nzp07LX5tQgghhGgenv58KtnZ2yktOQ2qcfubLh4h9A/qYOXMhBDC+hRF4fb+1VdpqpSVnePPI2+w68BRq+UlhBCWkoJmE6LT6fDy8uLIkSOkpKRw6tQpfvvtN4uKfBfq3LkzgYGBgHGVZU0Fxdq4u7sTEhKCm5sbiqKg0+m01aK1tp1Pnw7x8XC+0FjdlP37OfDppxw9avoX54Wt50ePHmX//v315mdjY0NERIR2vHXr1osq/AohhBCiaVqxfgdZTkcpL8skN3cPGZlRFBYmcEfYGGunJoQQV40Hr43ATrGhqOg4mRnR5GTvpKT8FLM+fNnaqQkhRL2koNmEFBcXk5KSQrdu3aisrOTw4cMcOnToovaJVBTFZJVmbGys1jpuieqrNFVVJS0tDYPBUHtBE6BTJ/j6a7OwHrjnzz9ZNneu2UTzDh06XFTreZ8+ffDy8gKMqzsbOvxICCGEEE3Xv798xdhffp6hsoSy3DPMGDfcekkJIcRVxtXRAZ/8SgryY6msLNTiO7N+o7hYtu0SQlzdpKDZhDg7OzNp0iT8/Pzw8vKioKCAhIQE/vjjD86cOdPg+/n7+xMSEqIdr1271uLVnj169MDHxwd7e3sqKiooLS0lPT2d9PR0syE/Jm6+GWbNMgv7lJYy9ttvWfz992Y5VG89Ly0ttWhVqk6nM1mluWPHDgoLC2u/QAghhBDNQnpGLrGlUWbxIa0nYG9rZ4WMhBDi6vXWzJdAUUxiFY6FPPPuB1bKSAghLCMFzSamXbt2XHfddfj7++Pi4sLZs2dJSUlh6dKllJaWNvh+kZGR6PV6AFJSUkhISLDoOhcXFzp37oy/vz86nQ69Xk9qaiqqqta9ShPgrbdg8GCzcFhmJs5z5rBlyxaTuJ2dHRMnTkQ5/xftsWPH2LdvX705hoSEmAw/uvC+QgghhGh+HnnzvxjsTVcWKej54FFpoRRCiAuNHRSGT2V3s/iiv+ZaIRshhLCcFDSboP79+9OtWzd69OiBXq8nMTGRxMREVq5c2eD9NFu1akVYWJh2vG7dOgwGg0XXhoSE4Ofnh06nw2AwUFBQQG5ubv0FTVtb+PFHON8SXt3t8fFse/11s/b39u3bm7Se//nnn+Tm5tb5NIqiEBkZqR3v2rXLonZ1IYQQQjRNBoPKyoRvzOLtlP706RpkhYyEEOLqd+/wh81iOS5J/PLnVitkI4QQlpGCZhOkKArh4eF06dKFrl27oqoqhw8fZvfu3ezdu7fB9xsxYgT29vYAnDt3zqLBOwDBwcE4ODjQpk0bVFWlsrKS1NRUzpw5U//U9Hbt4LvvzMI64L4NG1j4f/9nNshn9OjR2r6Ylraed+vWjbZt2wJQUVHB5s2bLXptQgghhGh6PvnuF4pd0s3iT930tBWyEUKIpuHVBx7ArtLDLP7vr2df8VyEEMJSUtBsovR6PZMmTaJTp074+flRXl5OTEwMq1at4uzZsw26l7OzM0OHDtWON2zYQFlZ/ZtAOzg40KVLF63tXKfTkZGRQXFxMXFxcfU/8bXXwn/+YxZuVV7O9QsX8uOiRSYFS1tbWyZMmKC1nicmJtZbwL1wlebevXvJzs6uPzchhBBCNDnvLH/LLOZU0YZHJ91qhWyEEKJpsLWxYXibm83iRyo2cvqs/NtJCHF1koJmE+bu7s5tt91G165dcXZ2Jj8/n7i4OJYuXWpRQbK68PBwXF1dAcjPz2fHjh0WXRcSEoKzszOtWrWisrJSm3heb9t5ldmzodrwnip9cnJweOMNswnu7du3Jzw8XDtes2ZNva3nQUFBdOjQAYDKyko2btxoWW5CCCGEaDIOxSdxwma3Wfz6rlO1D0OFEELU7KNZL6OoNiYx1a6ch998zUoZCSFE3aSg2cQFBgZy3XXX0aNHD3Q6HadPn+bgwYOsWrWqQfexs7MzmQq+detWi6aCd+3aFVtbWwICAtDpdFRUVHD69GlOnDhh2UpIGxv44Qfw9TV7aHJiIhueftpsanpkZKRJ6/ny5cvrbD2/cJXmgQMH6p7ELoQQQogm59H3ZoPedB9wnWrPx0+ad4MIIYQwFRzYgQ76AWbx3xMXYjA0bE6DEEJcCVLQbAYGDRrE4MGD6dq1KwBHjx5l8+bNFu+FWaVfv354e3sDxkLhpk2b6r3Gzs6O7t274+npiYuLC4qiUFlZyZkzZyxrOwdo08ZY1NSZ/3Z8cNs25r3wAhUVFVrM1tbWZOr58ePH2bNnT51P0aFDB4KCjMMAVFUlOjrastyEEEIIcdUrLS1n67lfzOI9HEbh28rTChkJIUTT8/wtz5vFSlwymLNgiRWyEUKIuklBsxlQFIXx48fTt29fbUBPTEwMv/zyC+fOnbP4PjqdjrFjx2rHu3fvJisrq97rQkJCUBSFgIAADAYDqqqSmppKTEyM5S9i1Ch49VWzsFtFBRO+/57F335rEm/Xrh2DBw/WjtesWUNOTk6dT1F9lWZMTAxnzpyxPD8hhBBCXLX+88FcKhzzL4gq/PeeF6ySjxBCNEX33zwe54q2ZvH3VvyfFbIRQoi6SUGzmbC1tWXy5Mn06tULJycnysrK2L9/Pz/++CPl5eUW36dr1660b98eMO43GRUVVe81QUFBODg44Ovri4ODA2VlZZSUlHDw4MF697c08a9/GQcFXaBHfj5Or7zCvn37TOKjRo3SVpSWlZXVO/Xc39+f7t27a8cbNmywPDchhBBCXLW+3vqxWaxVZWduGjG0hrOFEELURFEUJgTfbRZPs9vP3phjVshICCFqJwXNZsTT05Pbb7+dnj17otPpyM3NZfv27axevdrieyiKYrJKMyYmhrS0tDqvsbGxITg4GL1eT0BAgNYKnpqaannbORhbzhcuhIAAs4duOXGC9f/8p0mB9GJaz0eNGqWdf+TIEVJTUy3PTwghhBBXnd+j/yLL6ahZ/M5BD1ghGyGEaNo+fPJ59AYH06DewGPvvWydhIQQohZS0GxmgoKCmDBhAl26dAEgLS2N33//nYMHD1p8j3bt2tGjRw/teO3atXWufATo1asXYFwFqaoqqqqSk5PDtm3bGvYCvL1hyRLjsKALPLhrF58++aRJLgEBAQwZMkQ7XrNmTZ3DiHx9fenZs6d2LKs0hRBCiKbtuXmz4YIh5raVbrz5yKNWyUcIIZoyL3c3QpzHmMV3Zi+npKTMChkJIUTNpKDZDA0dOpTIyEhat24NQEJCAj/88EODJnuPHj0a3fkhPcnJyRw7VneLQWBgIC4uLtjb2+Pn50dpaSkAf/31F3l5eQ17AYMHw/+Z79PiUlnJrUuWsGj+fJP4qFGj8PHxASxrPa++SjMxMZHk5OSG5SeEEEKIq8K5zFwOl6w3i4d7j8fBzs4KGQkhRNP31syXQDH9pKjCsZBn3v3QShkJIYQ5KWg2Q4qiMHHiRIYMGYKjoyMGg4G9e/eyaNEii/fT9PLyon///trx2rVrMRgMtZ6v0+m0VZ2BgYFa/OzZs+zdu7fhL+KJJ+Dmm83CXQoK8Jg922Q/TRsbG5PW86SkJHbv3l3rrb28vOjbt692HBUVVe8KVCGEEEJcfR79vzcx2F+4YkjPh4+9YpV8hBCiObhm8AC8K7uZxRf9NdcK2QghRM2koNlM2dvbc+edd9KvXz90Oh2lpaVER0fz+++/W3yPkSNHYnd+dUN6enq9betVbedubm44OTlpred//PFHw1+AosBXX0GnTmYP3XjqFBvvu89kqrm/vz9Dh/698X99recjR45Er9cDcOLECRITExueoxBCCCGs6phSjptbH2xs3bVYAP3o2y3IilkJIUTTN33IP02O9TYuVLRx4lDiOStlJIQQpqSg2Yx5eXkxffp0OnfuDEB2djZLly4lJibGoutdXFxM9qeMioqqc4VnQEAAHh4egHEvz+LiYgD27t1rUny0mIcHLF0K9vZmDz2wbx9zH33UZNVoRESE1npeXl7O8uXLa1156eHhYbICVVZpCiGEEE1L9P4UTpYewcGxHa1aDcez1TAcHAN48sanrZ2aEEI0ef/750PYVXpib98GD89wvLwicHQKZM6qi1isIoQQl4EUNJu5rl27MmXKFK3Qd/LkSebPn09WVpZF1w8ZMgQXFxcA8vLy2LlzZ63nKoqiDdxp27attrqzrKyMVatWXdwLCA2FDz4wCzsaDEz5+WcWfvaZFqtqPa++9+euXbtqvfXw4cOxOT986NSpU8THx19cjkIIIYS44j5Zs9rk2NbWg66+43n89klWykgIIZoPWxsb/jn2Q9w9wrCz89bi65P/pKDIsm3MhBDicpKCZgsQERHBjTfeiKOjIwAHDx7kyy+/pKKiot5r7ezsGDlypHa8ZcsWioqKaj2/qu1cURS8vb21FZSWTEqv1f33wx13mIUDi4po++qr/FWtyHph6/natWtrLd66uroycOBA7XjDhg117hMqhBBCiKvD2awitp+OMovf2ud6dDqlhiuEEEI01KwJN6BXbExixWoun6/eZqWMhBDib1LQbAEURWHy5MkMHToURVEwGAxERUWxYsUKi64PDQ3Fy8sLgJKSEjZv3lzrub6+vnh7Gz/B69y5szbtPCUlhbi4uIt9AfD559C9u9lDY8+eZfeDD5pMcB85cqQ24b2+1vNhw4aZ7BN6+PDhi8tRCCGEEFfMhys2UE6JScxe58AjN0RaKSMhhGh+2vt4MsB3iFn8+92rkN26hBDWJgXNFsLBwYH777+f7ueLgsXFxSxcuNCiAp5er2fMmDHa8V9//VXrnpiKohASEgIY9+Bs1aoVAKqqsnz58ot/AS4usGwZnF9lWt3MAwf46tFHtf09L2w9T0lJ4a+//qrxtk5OTgwePFg73rBhA5WVlRefpxBCCCEuK4NB5ZcY861sRrSPxNPFyQoZCSFE8/XgmBvMYqmlcazfe9wK2QghxN+koNmCtG7dmkceeURbQZmVlcWcOXPqnAZepXv37rRr1w6AyspKoqLM27yqVBU0AXx8fLQ27l27dlm8d2eNevaEantmVrFTVab++ivffvSRthKzbdu2DBs2TDtn3bp1tT734MGDtXb8rKwsDhw4cPE5CiGEEOKyWroxhsyKk2bxx68z/0e3EEKIS3NtaDBtnQLN4p+uXW1+shBCXEFS0GxhevbsyYwZM3BwcADg6NGjfPTRR/WuSlQUhbFjx2rHBw8e5PTp0zWe6+3tjZ+fH2AsLNra2gLGKet1tatb5K67YOZMs7B/SQld3nqLTRs3arERI0bg6+sLGFvPf/311xpbzx0cHEymuW/cuNGi/UWFEEIIceW99N2/KC/PNYl1cQ9hQNf2VspICCGaL0VRmNzP/AOjLWkriDmSYoWMhBDCSAqaLdC1117Lddddh6IYN83fuHEjy5Ytq/e69u3bay3rYFz1WJuqVZoODg7a/puqqrJu3TqKi4svJX348EPo3dssPCI9ncTHH+fkSeOqjQtbz0+cOFHrlPZBgwbh7OwMQG5uLnv27Lm0HIUQQgjR6NZs3kVC0SqyszaTlbWFkpJUVLWSO8NldaYQQlwu/7w+AgedM6gqpSVnyM7ewbnMNTz0zn+snZoQogWTgmYLpNPpuO++++jTpw9gbCH/5ptvOHjwYL3Xjh49WiuEJiYmkpiYWON51dvOXV1dsbe3ByAtLY0FCxaQm5tb43UWcXQ07qfp6mr20F2HDrHkyScpKCgAwM/Pj+HDh2uPr1+/nszMTLPr7OzsTM7bvHmztienEEIIIa4Oz3w+G84PMa8ozyEvdz95Z3dxz5hwq+YlhBDNmZuTA8EOAWRkRpGbu5vyMuNA1h2ZyyktlX8zCSGsQwqaLZSTkxPPPvusNg28qKiIN998s979NH18fAgNDdWO165dW2Mbt7u7O+3bG1u/vL29cT1ffMzOziYtLY158+aRlpZ28S+gSxf48kuzsI2qMm3FChbOmaPt3Xlh6/ny5cu1x6oLCwvDzc0NgIKCgloHCQkhhBDiysvMziOmZL1ZfIDnNdjZ2FghIyGEaDkev24yhsoSk1iFQwHPzfnIShkJIVo6KWi2YG3btuXpp5/WVk+eOnWKN998s979NCMiIrR9Mc+cOcOhQ4dqPK9qlaajoyPOzs5069YNgLi4OHJzc1mwYAGxsbEX/wJuuw0efdQs7FtaSv8PP2T1ypWAcUq7Ja3nNjY2jBgxQjvesmULpaWlF5+fEEIIIRrNo2+9gcHuwr+X9Xz0+CtWyUcIIVqS64YNwKuiq1n82+2fWiEbIYSQgmaLN3DgQKZNm6a1ke/cuZOFCxfWeY2rqyuDBw/WjtevX1/jEJ2ePXtq97W3t8fT05M+ffqQm5vLvn37KCgoYMmSJWzZsqXGVZ4WefttGDDA/HWdO0feCy9w+PBhwNh6Xr1YuX79ejIyMsyu69evH56engAUFxezffv2i8tLCCGEEI1GVVWWxy0wiweo/ejbLejKJySEEC3QPUMfNotlOyWyfN1WK2QjhGjppKApuOOOO0ymfH/33Xfs2rWrzmuGDh2Kk5MTYByiU1N7trOzM506dQKMBUU/Pz88PDwIDQ2lsrKSvXv3UlBQwLp16/jtt9/qXRlaI3t7WLIEzhchq5t86BDrXnyRc+fOATB8+HDatGkDQEVFRY2t53q9noiICO14+/btFBUVNTwvIYQQQjSaL5Ysp8j5jFn8yRufsUI2QgjRMr3+0IPYVbibxf/z9atWyEYI0dJJQfMiKYriqCjKMUVRCqydy6XS6/U8//zz+Pv7A8Zi3//+978aVzBWsbe3Z+TIkdrx5s2ba5xeXtV2rigKjo6OjB8/HhcXF0JDQ3F0dGTfvn1kZWWxb98+Fi5ceHHFw8BA+PZb89cFTFu1isUffEBpaalZ6/nJkyfZsWOH2XW9evXCx8cHgNLSUrZt29bwnIQQQgjRaN746U2zmFO5L49Puc0K2QghRMtkb2fLEN+bzeJxZdGczah7FoMQQjQ2KWhevFeBFGsn0VhcXV155ZVXcHBwAIzDe1566aU6V02GhYXRqlUrwNievWXLFrNzgoOD0ev1gHGPzsDAQKZOnYqLiwu9e/fGx8eHQ4cOcerUKZKTk/nyyy9rnEJerxtvhOeeMwt7lZUx4rPP+GXZMlRVpU2bNiaF2KioKLPCrU6nY9SoUdrxzp07ayzWCiGEEOLySz51jhTFvHPk2qCp6HSKFTISQoiW66PHZ6OopoPYDLZlPPLW61bKSAjRUklB8yIoitIfuBZ4y9q5NKbOnTvz6KOPavtexsbG8umntW/yrNfrGT16tHa8c+dOcnNzTc5xcHCgS5cu2nFMTAxBQUHce++9eHp60q1bNzp27EhCQgKJiYlkZGQwf/58kpOTG/4CXn8dhg83C/fJzMT+rbe0lZbDhg3Dz88PMK5G/fXXX81az4ODg7X29PLycg4ePNjwfIQQQghxyT747TvQm/49rTPY8/HTL1gpIyGEaLlCOnegPWFm8VVHF178XAQhhLgIFhU0FUXpqijKq4qi7FAU5ZyiKPmKouxXFOU/iqI4X+4kq+XxL0VRliqKclxRFFVRlOR6ztcpijJLUZR4RVFKFEU5qSjKu5eSs6IoNsA84GGg7GLvc7W64YYbuOaaa7Tjn3/+mejo6FrP79Gjh0mr+oYNG8zOqWo7B2NBU1VVWrduzcyZM/H396d9+/b07NmTtLQ0Dh8+TEFBAQsXLmTfvn0NS97GBn74Ac63i1c34dAhDvzf/5GUlKS1nletHE1NTTUb/qMoCpGRkdrxkSNH6mzBF0IIIUTjKy+vIKY0yize3X4kft7m+2cLIYS4/J65+VmzWLHTOT78bqkVshFCtFSWrtCcAcwCEjG2Wj8DHAFeB7YpiuJ4edIz8z8g8nwelmzS8T7wHhALPAosBR4DViiKor12RVEWny+Q1vYVUe2ezwD7VFXd1Dgv6erz1FNPERRknBiqqipvv/02qampNZ6rKApjx47Vjg8cOMDZs2dNzunatSu2trYAnDt3joSEBMDY5j59+nS6d++Oj48Pffv2JS8vj/3791NcXMzy5ctZt25dwz7p8/eH778HxbQFTQfc8fvvLP/kE3Jzc/H19TVpPd+wYYM2PKhKly5daNeuHQAGg4EvvviCffv2ySePQgghxBXywsdzqXC8cLtyhdfvftEq+QghhICHbp2Ic5mfWfyd3/7PCtkIIVoqSwuay4AAVVWnqqr6kaqqn6mqOhn4L9AbuLe2C8+vkrxXURR9HefMUBTFzoI8glRV9VJVdSxwqq4TFUXpibGI+bOqqreoqjpPVdUngSeBUcDt1U6/D/Cp42vr+Xt2Bh7EWNRstmxtbXnttddwcXEBoLCwkBdeeIGyspoXpAYGBtK1a1fAWABdu3atyeN2dnZ0795dO168eDEbNmzAYDBgZ2fHpEmTCA8Px83NjdDQUFRVZe/evRQWFrJlyxaWLFlCeXm55S9gzBh4+WWzsEd5Odd8/TVLvv+eiooKhg4dWmfruaIojBs3TlvJWVZWxvLly1myZIlMPhdCCCGugC83f2wW8ywP4ubIYVbIRgghBIBOp3Bjt7vN4qn6fRw7ecYKGQkhWiKLCpqqqu5WVTW3hod+PP/fkBoeqzIGmA8srKmoqSjKB8CXwGQL8jhuQbpVpgAKMOeC+DygCJhW7b75qqpm1PFVVU0bBvgCCYqiZADLAWdFUTIURRnRgNyuem3btuX555/X9tNMTk7mrbfeqnV14pgxY7Rzjx07RlJSksnjkZGRWoFUVVU2btzIt99+S35+PjqdjmuvvZbrr78eR0dH+vbti7OzM/v27SM7O5u4uDi+/vpr8vPzLX8BL7wA1VaOVgnOyqLdp5/yxx9/mLWep6WlmU00b9euHTNmzMDNzU2LxcXF8emnn3L06FHL8xFCCNFiKYrygKIoi85vgVOpKMpFLfVXFOV6RVG2KYpSqChK1vlteDo2dr5XhaQkkidN4fDqBIp+hDM/w7t7IbAApg180NrZCSFEi/fRU/9CV2kcKBtYYPwefeZXA9OmT4XWrWHWLLjg34RCCNGYLnUoUMD5/56t7QRVVddgbFefAnxXvaipKMpHGFvA31BVdeEl5nKhAYAB+OuCfEqA/ecfb6glQGeg7/mvmRiLo32BnReb6NVq2LBhTJo0STtev349y5cvr/Hc1q1b07dvX+147dq1JsVPT09PHnzwQTp16qTFkpOT+fzzzzl+3FinHjhwIFOmTMHJyYmQkBDatGnDwYMHOX36NKdOnWLevHmcOWPhJ356PXz3HbRta/bQtTExnJ03j3379tXYep6enm5yvr+/P+PHj2fAgL9/yxQUFLBo0SJWrVrVsNWjQgghWqJ/ATcB6dTTYVIbRVFuAVYCjhg7Rd4GRgBbFUUx/8uuKVu7Fvr3x+eXpThVQLkCThVwXyLs+QPe7hFs7QyFEKLF82nlRk/H0Yw5DXv+NH6PdqqAMsWAWlQE8+ZB//7G7+lCCHEZXHRB83xh8kWgAvi+rnNVVZ0DPIGxzft7RVFsFUX5BHgE+J+qqv++2Dzq0BbIUFW1tIbH0gBvC9vcNaqqFqmqmlr1BZwzhtXUmp5HUZTxiqJ8ceHk76bk/vvvp3fv3trx3LlziYuLq/HcUaNGYWNjA8CpU6c4fPiwyeMuLi5MmzaNUaNGaas5qwYARUdHYzAY6Nq1K/fccw9ubm507tyZLl26kJCQwPHjx8nNzeWrr77iyJEjliXfujX8+KOxuHmByatXs2nBAk6fPs2wYcNoe77wWVlZWePUc1tbW2644QamTp2qrTQF2LVrF59//jmnTl3Uv0+FEEK0DBGAu6qqI4ADDb1YURRb4CPgJDBcVdVPVVV9A7gGY+fI7MZL1cqSkmDyZAwlpVRSiaoACqgKqICjQY/9ndNk1Y8QQlwFPrxuJj9uA7tK4/foqu/ZpRUVoNNBaSlMnizfs4UQl8WlrNCcAwwGXlJVtd4Kk6qqHwCPA5MwDhT6J/BfVVX/cwk51MUJqKmYCVBS7ZyLpqpqtKqqLnU8vkJV1fvd3d0v5WmsSq/X88orr+Dl5QVAaWkpr7zyCjUVad3c3AgPD9eO169fT0VFhck5Op2OkSNHctddd5m0oEdHR7Nw4UIKCgrw8/Pjvvvuo02bNrRt25ZevXqRlpZGXFwcJSUlLF68mB07dlg2nGfYMHjjDbOwS0UFNy5cyLLvvqOkpMSk9fzUqVNs3bq1xtt16dKFhx56yGRP0IyMDObPn8+mTZvMCqFCCCGEqqrJqqpeyl8QIzF+UDtfVVVtQo6qqvuBaGDy+aJn0/fhh1BWRkllRY0P2zk4QFkZfGy+t6YQQogrK2LHRuwqFQym81gprzw/e0Gvl+/ZQojL5qIKmoqivIZxdeUX51cIWOojYBvQEWNR85WLeX4LFQH2tTzmUO0cUQ9PT09efPFFbVL5mTNn+N///kdlZaXZucOGDcPR0Tj0Pjs7m927d9d4z44dO/Lggw/SsePfW38lJSXx2WefkZSUhJubG/fccw9dunShVatWhIaGahPQy8rK+OOPP1i1alWNOZh56ikYP94sHJSdTa8FC/jpp5/w9vYmIiJCeyw6Otqs9byKs7MzkydP5qabbsLOzrjI12AwEBUVxddff012dnb9OQkhhBCWq9rzZHsNj+0A3ICuVy6dy2jRIgAqVfO/3xV06HXnf3T97rsrmZUQQoiaLFqErd788zRVgUpDtcUn8j1bCHEZ2DT0AkVRZgMvAF9jnPht6XUKxoE8Q4BVwPXAEkVRJlUbutOYTgE9FEWxr6Ed3B9jO3rNY7uFmb59+3L33Xczf/58AHbu3Mk333zDjBkzTM5zcHBgxIgR/PnnnwBs2rSJvn374uDgYHZPFxcX7rzzTjZt2sTGjRtRVZWCggK+/fZbIiIiGD58OFOmTOH3339n165dhIaGEhMTw969e+nVqxe7d+8mOzub2267rcb7a3Q6WLAAQkMhJcXkoYjYWL5fupRof38iIiKIj48nLS1Naz2/9957tZWb1SmKQmhoKIGBgfzyyy+cPHkSgJMnTzJ37lyuu+46+vbtq7XWCyGEEJegao/MtBoeq4r5A4cvfFBRlPuB+wF8fX2Jjo6+HPk1muG5uVQo54uWih5jE6MBVLDR2VJRWQmqipKTw+ar/LU0RQUFBVf975HmQt7rK0fe68tneG6u8d9KVT0IigLoUIDS8nLsbPTyPVsIcdk0qKB5vpj5MvANMFO1qOcXFEXRYZx0fg/GFvXXFEV5AJgLLFMU5bbLUFzcBYwDBgKbq+XigHGIz6ZGfr5m74477iAuLk5rx168eDHdu3dnyJAhJucNGDCAnTt3kpOTQ1FREVu3bmX06NE13lOn0xEREUH79u356aefKCwsRFVVNmzYQEpKCrfccgvXX389rVq1Ys2aNfTt25f4+Hj27t1LSEgIiYmJfPnll9xxxx14enrWnnyrVrB0KQwdChcM8Zm4ejXzAgLw9/dn4sSJfPbZZ1RWVmqt5yNG1D7AvlWrVtxzzz1s2bJF2we0rKyM5cuXc+TIEcaPH4+zs7OF77AQQoirlaIoHhj3A7fUh6qqZjXS01dtkVPTVjp1bqOjquoXwBcAYWFhavVuhKuSuzvlubmgKBg/EjRuoKnodDjY2xljBgO4unLVv5YmKDo6Wt7XK0Te6ytH3uvLyN0dioqw1TtQoZ7fKkRVQVEwYECvt0OR79lCiMvE4pZzRVFewljMXAjMsHQvqPPFzK8wFjNfUFX1NQBVVT8HHgDGAz81dECPBX7E+LH+ExfE78P4Q/+iRn6+Zk+n0/Hss8/Srl07AMrKynjvvfdITU01Oc/GxsakgLljxw7y8vLqvHenTp148MEHCQwM1GLHjx/ns88+IyUlhcGDBzNp0iTs7e0JDg4mICCAAwcOcPbsWc6dO8f8+fO1VZK1GjAA3nvPLOxUWcktP/zAb4sXo9PpGDVqlPbYxo0bOXv2bJ231el0jBgxgpkzZ+Lt7a3F4+PjmTt3LkePHq07LyGEEE2BB8afgyz9atWIz121RU5NW+k0r210pk7F3tYWBxt7dMrfHRK2eltMeh6mTbviqQkhhLjA1KkA2NtWbzvXYaezxcne4e/v2/I9WwhxGVhU0FQU5WGM+12eANYBdyiKMq3a19g6Lh8D3A38W1XV/1Z/QFXVeRjboG4AJluQx52KorygKMoLgA/gXnWsKMqdF9z7EPAJcIuiKD8rijJTUZR3gfeAjdQzmV3UzN3dnX/961/aqsOMjAzefPNNCgsLTc4LCQnBz88PgPLycovaPFxdXbnrrrsYOXKkyRT0b775hk2bNtG9e3emT5+Oq6srgYGBdO/enfj4eJKTk7XzDh06VPeTPPwwTJpkFm6Xk8PwH3/kxx9/JCwsDH9/f+DvqeeW7NXZtm1bHnjgAQYMGKDFCgoKWLRoEatWraK8/HLsrCCEEOJKOD/YR2nA17FGfPpT5//rX8NjVbGa2tGbnsceQ7GzwxYVZzs7nOwc0Cs2xrZFgMpKsLODRx6xbp5CCCHgscfAzg6doRI7nfHDKEdbW+xtbYyFBvmeLYS4jCxdoVlVoWmPsd184QVftU4qV1V1DTCgtuFBqqrOBwaqqrrQgjzuBV47/9Ua42qJquN7azj/CeBpoCfG4ubtGAcT3XiJ00ZbtB49enDvvfdiY2PcseDw4cN89tlnJhO+FUVh7Ni/69z79u2rdchOdVUrJKdNm6YVTVVVJSoqiu+++w4PDw9mzpxJ69at8fX1pW/fvqSlpREfH09ZWRk//fQT0dHRtU9AVxSYNw+6dDF7KDwujtarV7Nq1SomTJigvb7Tp0/XXyg9z9bWlhtuuIGpU6dqU9wBdu3axeeff86pU6fquFoIIYSo0a7z/x1cw2PhQB6QcOXSuYw6doQffwR7ezAY0KsqdnqdsWXRYDDGf/zReJ4QQgjrqvY9216vw1bB2HIu37OFEFeARQVNVVWn17MKIaKe62sedW3h49XOi2hIDqqqVqqq+q6qqt1UVbVXVdVfVdUnVVUtsOT5RO0mTJhAZGQkYCw4rlmzhhUrVpic06lTJzp37qyds27dOovvHxQUxIMPPkiHDh20WGJiIp999hk5OTnMmDGDTp064e7uTmhoKPn5+Rw8eFBbDfrzzz9TUVFR883d3GDZMqhhkND433/n7Nq1JCUlmbSeHzx4kL/++suyqepAly5d+Oc//0lwcLAWy8jIYP78+WzatMmk+CuEEEJUURTFT1GU7oqiVN8TcyNwGpipKIpLtXP7ABHA0ss0YNE6xo6FPXvggQfA2RmlshKcnY3He/YYHxdCCHF1kO/ZQggrsXgPTSGq0+v1PPzww3Tr1g2A0tJSvv32Ww4ePGhy3pgxY7T28YSEBFIumDJeF1dXV+6++26ToTz5+fl888037Nq1izvuuIPQ0FAcHR0JDQ1FURT27dtHcXExhw4d4ptvvjFrhdf07g2ffGIWtjcYuOWHH9iwfDn+/v4EBAQAYDAYWL16NR999BH79u2zqCDp5OTEpEmTmDBhAnZ2dtp9oqKi+Prrr8nKaqxZEUIIIa5miqKMr7ZlTufzsaotcy7sw3sDiMM41BCA88XKx4F2wGZFUf6pKMrzwBrgHMY9O5uXjh3h3Xfh7Fk2//knnD1rPJZVPkIIcfWR79lCCCuQgqa4aO7u7syaNQsvLy8AMjMz+eSTTzhz5ox2Tps2bejdu7d2vGbNmgatTtTpdERGRjJt2jScnIyLVVRVZf369SxevJjIyEjGjBmDjY0NvXr1wsPDg71795Kbm8vJkyeZN28e586dq/nm99wDd99tFm6Tl8c1P//MsqVLGTt2LB4eHtpjOTk5LF++nE8++YRDhw7V3tp+nqIo9OvXj4ceeoj27dtr8ZMnT/LZZ5+xd+/eeu8hhBCiyfsHf2+R0+18rOr4aUtuoKrqUuAmjJPO3wGeAzYDQ1VVbR77ZwohhBBCCGEhKWiKS1I1qKeq2JiQkMDnn39OcXGxds6oUaPQ642b+aelpTF37lxiYmIaVNjs3LmzWQv6sWPH+Pzzz2nXrh233XYbdnZ2dOnShfbt23PgwAHS09PJyclh/vz5JCYmmt9UUeDTTyEkxOyhfkeO0HX9etavX8+DDz5IWFiY9hrBWLz96aefmDt3LnFxcfUWJT09PZk+fTqjR49GpzP+sSsrK+O3337jxx9/rH0lqRBCiCavnq17Ams5N7qG+6xUVTVcVVUnVVU9VVW9VVXVGv6CE0IIIYQQonmTgqa4ZNdffz1jxoxBr9ejqirbt2/n+++/1wqWHh4eDB789xyDc+fOsWzZMq2waekKRTc3N+6++26GDx+uxapa0LOysrjrrrtwdnamXbt29OjRgyNHjnDixAlKSkpYtGgRu3fXsFWrkxMsXWrc5+UC161dS8WOHURHRxMSEsLjjz9OZGQkDtX23kxPT+fHH39k3rx5HDt2rM7XotPpGD58ODNnzsTb21uLx8fHM3fuXI4ePWrR+yCEEEIIIYQQQgjRkklBU1wyvV7PjBkz6NOnDwAlJSX8/vvvREVFaedERkYSERGBvb29FqsqbH766accPnzYosKmTqdj9OjRTJ06VVsxaTAYWL9+PZs2beKOO+7A29sbb29v+vXrR1paGgkJCVRUVLBy5Ur++OMP85Wh3bsbJ59fwNZg4JbFi9m/YQPHjx/H3t6eESNG8PjjjzNixAht2EkslgAALOhJREFUX0yAU6dO8d133/H111+TnJxc52to27YtDzzwAAMHatujUVBQwKJFi1i5ciVlZWX1vg9CCCGEEEIIIYQQLZUUNEWj8PDw4P7779f2iczIyGDx4sXExcUBxkJkREREjcXAc+fOsXTpUubOnWtxYbNLly48+OCDJvtSHjt2jCVLljBu3DgCAwNxcXEhNDSUgoICDh06REVFBTt27GDx4sWUlpaa3nDKFHjoIbPn8c7PZ/zPP7Nt61Y2bdpEQUEBjo6OREZG8vjjjzNkyBBsbGy080+cOMGCBQv49ttvSU1NrTV/W1tbrr/+eqZNm4aLizawlt27d/P555+TlibboQkhhBBCCCGEEELURAqaotF0796dyZMn06pVKwASExP55ptvTIbyODk5ERkZyRNPPGFW2ExPT29QYbOqBX3YsGFaLC8vj8WLF9OpUyd69+6Nvb09ffv2Ra/Xs2/fPkpKSkhISODrr78mNzfX9IbvvQehoWbP0/PYMUbv309UVBTvv/8+P//8M6mpqTg5OTFu3Dgef/xxBg4cqO0TCnD8+HHmz5/P999/z+nTp2t9DZ07d+af//wnwcHBWiwzM5Mvv/ySjRs3NmifUSGEEEIIIYQQQoiWQAqaolFdc8012j6Tqqqyf/9+Fi5cSElJicl51Qubw4cPv+jCpl6vZ8yYMUydOhVHR0fA2IIeFRVFUVER4eHh6PV6evbsiZeXF3v37iUvL48zZ84wb94805WQDg7G/TTd3c2e5/a9e3n6nXfosX8/Bw8eZP78+cybN4/9+/fj4ODA9ddfz6OPPkq/fv20oT/w95CkJUuW1Dpt3cnJiUmTJjFx4kTtfTAYDGzYsIGvvvqKrKys+t94IYQQQgghhBBCiBZCCpqiUdnY2HDHHXcQGhqKTqejpKSE7du38/PPP9dYmHRycmL06NH1FjZjY2PrLGxWtaC3a9dOix07dozY2FitLbxTp0507NiRAwcOkJGRQUFBAQsWLCA2NvbvG3XqBAsWmN1fAVwKC5n4yy+MXrMGxWDg1KlT/Prrr7z//vusW7cOgAkTJvDwww/Tq1cvFEXRro+NjeXTTz/l559/rrFAqSgKffv25aGHHjJpo09NTeWzzz5j7969Fg9PEkIIIYQQQgghhGjOpKApGl2rVq2YOnUq3bp1A4x7ZG7YsIFNmzbVek19hc0lS5bUW9h0d3dn+vTpDB06VIvl5eWxY8cOevTogYODA35+fvTq1YsjR45w8uRJysrKWLJkCVu2bPn7vhMnwpNP1vgcelVl+PbtPPbuu0T88QdeGRkUFRWxZcsWPvjgA3744QdycnK45ZZbeOihh0xayVVV5eDBg3z88cesWLHCvOUd8PT0ZPr06YwePVpb6VlWVsZvv/3Gjz/+SGFhYa3voRBCCCGEEEIIIURLYFP/KUI0XM+ePbnxxhvJz88nNTWVY8eOsWLFCvz8/OjatWut11UVNgcPHsz27dvZuXOnNvW7qrDp6+vLyJEjCQ4ONlkFCcYW9LFjx9KhQwd++eUXiouLMRgMHDp0CD8/P/Lz8wHo168fhw4dori4mC5durBu3ToyMzO58cYbjXthvvmmcU/NWngWFRGxcycRO3dy3NeXQ2FhxIaEcOTIEY4cOYK3tzcDBgxg4sSJDB8+nA0bNnD06FHA2E6+Z88e9u/fT1hYGMOHDzcZDKTT6Rg+fDhBQUH8/PPPZGRkABAfH09qaio33XRTne+hEEIIIYQQQgghRHMmKzTFZXPNNdcwZMgQPDw8UFWVw4cPs3jxYlauXElycnKdA2+qr9gcNmyYyYrNs2fPsmTJEj777LNaV2x27dqVBx98kICAAC12+vRpKisrcXZ2xsnJidDQUAoLC7UJ6Pv27WPhwoUUFRWBrS34+1v0OjudPcuEVat48p13uGnJEjoeP07muXP8/vvvvPvuu+zbt49x48YxY8YMAgMDtesqKyvZuXMnH3zwAWvXrjU+bzVt27blgQceYODAgVqsoKCA77//npUrV2qFXiGEEEIIIYQQQoiWRFZoisvGxsaGyZMnk56ezvbt2ykuLubQoUOUlZWxe/duXF1d6dmzJyEhIfj7+5uttgRjYXPMmDEMGTKEbdu28ddff2mFvKrCpq+vLxEREXTv3t3kHu7u7txzzz2sX7+ebdu2AVBcXAyAra0tqqrSp08fEhIS2L9/P7169SI5OZkvv/ySO+64A6+33oL77oPz19THvrKS0Lg4QuPiyHRx4VC/fhzo149du3axa9cuOnbsyMCBAxk2bBjR0dGkpqYCUF5eztatW9m9ezfh4eEMHjwYBwcHLc/rr7+erl27snz5cm2F6e7du0lKSuKWW27B38LCqxBCCCGEEEIIIURzIAVNcVl5eXnxj3/8g4KCAg4fPsy5c+fIyMigVatW+Pj4kJWVxY4dO/Dw8CAkJISQkBB8fX3NiptVhc2qVvQLC5s//vhjjYVNvV7PuHHjtBb0qmnrZWVlVFRUANCtWzdOnjzJnj176N27NwDz589n8uTJBM6bB//5D+qJEyje3tCuHRw8COevrfV1FxQQsXkzEZs3kxgQwKH+/YktKyMpKQk3NzfCwsIICwtjx44dnDlzBoDS0lI2btzIX3/9xdChQxk4cKC2MrVz58489NBDrFy5UhtilJmZyZdffsnIkSMZPny4yXR1IYQQQgghhBBCiOZKCprisuvVqxcjR47E2dmZ3Nxc0tPTOXfuHJmZmSiKgqenJz4+Ppw7d44tW7bg7e2tFTe9vb1N7uXs7FxvYbNNmzaMHDnSpLDZrVs3HnzwQZYuXUpaWhqKomBra0tBQQElJSW0b98eR0dHDhw4QPfu3fHy8mLhwoXceOON9EtOZmN0NBEREcYk0tNh0SL4+ms4dKje1x+UmkpQairXrlpFbI8eHAgNJSo3F72NDT179qRbt27ExsZy7tw5wLiKdN26dWzfvp3hw4cTFhaGjY0NTk5O3HbbbRw4cIDff/+d0tJSDAaDtj/nLbfcQqtWrRrvf5wQQgghhBBCCCHEVUgKmuKKuOGGG2jdujUHDhzAw8ODLl26kJ2dTXp6OhkZGWRlZZGQkICHhwc+Pj6cOnWK6Oho2rRpoxU3PTw8tPtVL2xWtaKXl5cDcObMmRoLmx4eHsyYMUMrFgK4uLiQm5vL2bNnad26Nfb29sTExNChQwf8/f1Zvnw5mZmZxkFBVVq3hlmz4IknYN8+Y2Hz++8hK6vO98ChooLQgwcJPXiQDHd3Dvbrx4GsLA66u9OmTRt69OhBWlqaNv28sLCQP/74g23btjFixAj69euHXq+nb9++2orTEydOAJCamspnn33GNddcQ2hoaI3t+0IIIYQQQgghhBDNgRQ0xRWh0+kYNGgQgwYNIicnh9jYWGJjY0lNTcVgMJCVlUV6ejqZmZlkZ2ebFDdTUlJYt24dAQEBhISE0LNnT1xdXQFjYXPs2LEme2zWVNiMiIigW7du6PV6rrnmGjp06MCvv/5KSUkJ7u7u2NjYkJSURLt27QgNDdUmoAcFBbFlyxYqKysJCAigffv22NvbG1+UokBoqPHrnXdgxQpjcfOPP6COgUcA3rm5REZHExEdzfGOHTnQty/xwcHoXV3x9fUlOztbW3mal5fHypUr2bp1KyNHjqR37954enoyffp0tm3bxoYNG6isrKSsrIwVK1aQkJDATTfdhLOz8+X7HyqEEEIIIYQQQghhJVLQFFech4cHQ4YMYciQIeTm5hIXF0dsbCwnTpygsrKSzMxM0tPTycrKIicnh6NHj+Lu7k5qairHjh3jzz//JDAwkJCQEIKDg3Fycqq3sLl48WKTwmb37t154IEHWLZsGWlpaTg7OxMQEMCxY8fw9/enX79+xMXFcfjwYYKDgzl58iSLFi1Cp9Ph5+dHYGAgHTt2pF27dsYCp7093Hqr8evUKfjuO2NxMz6+zvdCB3ROSqJzUhLFq1ZxOCSE/X37UtK2LXb29hQWFmJnZ4eiKGRnZ/Prr7+yZcsWIiIi6NmzJ8OGDSMoKIiff/5Za1k/cuQIn376KRMmTKBr166X+3+nEEIIIYQQQgghxBUlBU1hVe7u7oSHhxMeHk5eXh7x8fHExsaSkpJCeXk5GRkZpKenk52dTW5uLseOHcPNzY0TJ04QFxeHk5MTQUFBhISE0K1btwYXNmfMmMHatWvZsWMHdnZ2dO3alSNHjuDm5kbPnj05fvw4+/fvx83NDQCDwUBaWhppaWls3boVnU5H27ZtCQwMJDAwkPbt22PXti08+yw88wzs3AkLFsAPP0BeXp3vhWNZGWF79xK2dy/pXl4c6NuXfSEhnCktpaysDA8PD2xsbMjIyGDZsmVs3ryZyMhIunbtyv3338+6devYuXMnYGxX//777wkNDaVXr160bdv275WlQgghhBBCCCGEEE2YFDTFVcPNzY2BAwcycOBACgoKtOJmUlISZWVlnDt3jvT0dHJycsjLyyMxMRFXV1eSk5M5ePAgrq6udOnShZCQELp27VpvYdPPz4+RI0dqLejLly+npKSE4OBgjh8/TmxsLN27d6egoIBjx45x9uxZDAYDrq6uODs7oygKBoOB1NRUUlNT2bJlCzqdDn9/f63A2S40FLvwcHj/ffjlF2Nxc906UNU634vWmZmMXb+e0VFRHAsKYk/v3mwqKqLYYMDHxwdnZ2fOnj3LDz/8gL+/P5GRkVx77bV07dqVX3/9lfz8fAD27t3L3r17URQFHx8f/P39CQgIwN/fn9atW8tkdCGEEEIIIYQQQjQ5UtAUVyUXFxfCwsIICwujsLCQI0eOEBsby/HjxykuLtaKm3l5eeTn53P8+HFcXFxITExkz549eHh40K1bN0JCQhg1ahRDhgxh69at7Nq1Sytsnj59WitsRkREcP/997Ns2TJOnTpFUFAQp06dYs+ePfTo0QNvb298fX0pLy8nNzdXa+82GAy4ubnh5uaGvb09BoOBkydPcvLkSTZv3mxS4OwYHk67227D9vRp+PZbY3EzMbHO90GnqnQ9doyux44xwcGBgz17strXlxgHB9r4+eHl5UVaWhoLFy6kQ4cOREZG8tBDD7Fy5UpiY2O1+6iqSnp6Ounp6ezbtw8AOzs7/Pz8tAJnQECAthJVCCGEEEIIIYQQ4molBU1x1XN2diY0NJTQ0FCKi4u1lZvHjx+nsLBQK9QVFBRQUFBAUlISzs7OJCQksGPHDry8vAgODiYkJITw8HB27NhhVtj84Ycf8PPzY9iwYaSkpPDXX3/Rtm1bHBwcOHToEDY2Nvj4+ODk5IS3tzfe3t4AlJeXk5OTw4kTJygtLUVRFFxdXXFzc9MGF1UvcOr1emOBc8gQAqdMof2JE9gsXAhLlkBhYZ3vg1NJCeF79hAOnPbxIapdO1Z6eODQvj1+fn6kpKTw9ddfExQUxKhRo+jbty9HjhwhNTWV9PR01AtWhZaVlZGSkkJKSooWc3V1NSlwtm3bFjs7u0b8vymEEEIIIYQQQghxaaSgKZoUR0dH+vXrR79+/SgpKdFWbiYmJpKXl6cVNwsLCyksLCQ5ORknJyfi4uLYvHkzrVu3pmfPntx8882cPHmS3bt3mxQ2ly5dip+fHwMGDODAgQO0atWKQYMGERcXR1ZWFidOnMBgMKDT6XBxccHZ2Rl3d3e8vb1RFEUrcJ47d45jx44BaCs4XV1dcXJy4sSJE5w4cYJNYCxwDhtG51tvJTg2Fq8VK9Bt2lTv++B37hxTz53jdp2OfX5+LPf0JKF7d9q0a0diYiKJiYl069aNkSNHcsMNN1BRUcHp06dJTU0lLS2N1NRU8mrY0zM/P5+4uDji4uIAUBSF1q1b4+/vrxU5fXx8pFVdCCGEEEIIIYQQViMFTdFkOTg4/H97dx4lZ13ne/z9raW7qzvdHbqzkMRIJ5DBGDGg6IgRjYjeGRaX69V75gZHrhdxQeaKl8NVGCWMinNEHFFw494ZHUVn1AsedGZUGIwLok5YDoSGrISmE0i6k/RaXdW1fO8fz1NFpdPd6ZDqqlT153XOc556lvo93/r19jzf/i2sXbuWtWvXkk6n2bZtG93d3Wzbto3BwcFicjOZTBZbIiYSCbZs2cLChQtZunQpa9asIZlMsmvXLrLZLBAkNp999lna2trIZDLF5OXy5cuL106n0wwNDXHo0CF6enpIpVIkEglaWlpoaWnh5JNPZuXKleRyOQYHBxkYGOCZZ54hnU4XW3AWlkKC8z4gev75rL7gAl7Z3c3ye+8ltnfvtHUQzec5e88ezt6zh8Ht2/n5ggX85tRTyaxeTT6fZ+vWrUSjUTo6Oujs7GTBggWsWrWK17zmNTQ0NHDw4EH27t1Lb28ve/fuZXx8/LDy3Z19+/axb98+HnroISDoqr506dLDxuNUV3URERERERERqRQlNKUuNDY2csYZZ3DGGWcwPj7O9u3b6e7uZuvWrRw8eLCY3BwbGysmEB9//HEeeeQRFi5cyOLFi4nFYgwODtLQ0ICZMTQ0RD6fJ51OE4/HAchms8RiMRobG1m4cCELFy4EgsTf6OgoQ0NDDA4O8swzzzA2NnZYknPFihXE43HS6TQDAwPs3LmTZDJJU1PTYQnOR+fNY8uKFdhll3FqTw/nbN1K10MPEU2np62D9nSad+/Zw7v37GHvH/7AvFyO1myWg/Pm8S/r1vHw2rU0NjYe1roykUjQ2dlJZ2cnXV1dRCIR0uk0w8PD7Nu3b8qu6rt372b37t3FfW1tbYclONVVXURERERERERmixKaUncaGhpYs2YNa9asIZPJsGPHDrq7u3nyySeLkwn19fWRSqWK41sWEpTt7e0ApFIpOjs7aW5uJpFIFLuluzupVAoIJgQaHx8nnU4TjUZJJBIsWrSIpUuXAkHyc3h4mKGhIYaGhtizZw+ZTIZoNEpLSwvz589n0aJF5HI5xsfH2bt3Lzt27CiOw9na2spzbW08du65tJ97Li/r7uasRx9leU/PUetgaUnys3NkhEt+/nOevP9+nmxrY6C5maF58xhpa+NQezt7TzoJb2ujKZGgqampmPBsb29n+fLlmBnj4+OkUimGhobIZrOY2WHXK3zGiV3VCwnOZcuWqau6iIiIiIiIiJSFEppS1+LxOKtXr2b16tVks1l27txJd3c33d3dxRaIfX19pNNpent76e3tpaGhgfnz53Pw4EFyuRwLFixgbGys2Dqz0FoToLm5uZjkHB0dpa+vj0wmQy6XI5fL0dTURFNTE0uXLmXFihUAJJPJYgJweHi42AKysbGR9vZ28vk82WyW5557jt7eXsyMeDzOg21t3HXeeZyazXLurl2c9dhjtA0Pz6geIsBLR0Z46cjIpMdTkQgHGhrob2zkUFMTAy0txaRncv58xk46iVRHB5FwoiMzKyZix8bGiMfjNDc3F+umtKv6gw8+CDzfVb100qHCxEkiIiIiIiIiIjOlhKbMGbFYjNNPP53TTz+diy++mKeeeqqY3NyzZw/79++nv7+f8fFx9u/fD0AkEmFkZIShoSH6+vrIZrM0NjYWl3g8TkNDQ3Fpb28vvo5EIiSTSUZGRjh06BAjIyOMhjOZFxKdbW1t5PN5MpkMmUyGsbEx0iWtKwsTEKVSKYaHh+nt7WV7PM49sRit69axLpnk/N5eznr6aWK53Auum6Z8nmWpFMtSKRgcnPK8kWiUg01NHEoknk96trZyKJGgv6GBQ4kEh5qaSLmTSCRobm4utnKdqqt6aYJzyZIl6qouIiIiIiIiItNSQlPmpFgsxqpVq1i1ahUXXXRRMbm5ZcsWent72b9/PwcOHCCfzwNB9/F8Po+ZkUqlGClp6eju5PN58vk8uVwOMyMSiRCNRouJy0QiQWNjI62trYe1bhwZGSGVSpFOp4stNaPR6GFlptNpzIxYLPhxTaVSZLPZYEIi4Efz57Ogo4M/Hxzkwr4+Vg0MzFq9zcvlmDc6yotHR6G/f8rzBuNxDjY10d/QQF9DA/ujUQaamxltbyfV0UGqo4NMRwepVIrBwUG6u7uBIIG8aNEi+vv7yWQyxfqbaonFYkd0fxcRERERERGR+qaEpsx50WiU0047jdNOO42LLrqI3bt3093dzaOPPkpPTw99fX0kk0mi0Si5XI5oNEo0Gp20LHcnl8uRzWbJZrMMDg5y4MCBYkK00OKykPCcuC4k50oTmtFolHw+X0xk5vN53L14fjKZ5KlcjlsyGb7S0cGHYjE+2t9f1R/u9kyG9kyGFdOckwMOxGLFlp1DLS105POs6eujJZ1mpLmZB9au5dFVq/CGBvLxOPmGBrLRKLlYjGw0ijc00NjSQiIc//NYl0KSWERERERERERqh57mRUpEIhFWrlzJypUrueCCC+jp6eGJJ57gt7/9LV1dXcVZzIeHh8lkMoyPjxeXidu5SbqAT0x4TrZM9p7SBGehpaiZFY8VWneaGTfHYuxsa+PakRGW5fPsi0T4p6YmtsfjLM7nOTmfZ0k+z+J8nsW5HCfncjRNmMm8EqLAomyWRdksJJNw4MBhx1uTSd7ywAO85YEHpi0nB2QiEcYjEbKRCJlolGxhiUTIxuNko1GSsRgjsRi5WIxcPE4+FiPf2Ig1NRFJJIgmEkTCJdrcTKSlhVhzM7GWFmItLcTnzQuW1lYa29poaG0l2twMjY1w993wmc9Aby8sXw433ggbNsxe5YmIiIiIiIjMYUpoikwhEonQ1dVFV1cXiUSC9evXF49ls1nGxsZIJpNTLkNDQwwMDDAwMMDg4CDJZHLKJGghkTmThGchgZnL5Yrd3AtLofXmP7rz7cZG3D1IfObzUDI2JwBmEItBNMp8YIn7kQuwLHx9MhDnxBMFovk8TeHwAFXX04NfckmwRKO4GZjh4UIkEmxHIke+nmSxSASi0edfF5bSfRNeH7EuvJ649PbCli28IZmE5mZ4+cshnLyKQlf+MP4j9k21PpZzj6f8rVvh/vtheBhaW2HdOli9+sivx3RDEhxtuILZON7dDb/+NW8YGoK2Nnj962HNmunLORE8/jj8+tdQiPvjH4dPfKLaUYmIiIiIyBylhGYF7N179OfemTpaQ7pyXef662HjxqmPb9wIN9xQnmvVxmdaP2E7BrSGy5Em+0yZTKaY7Fy6dMlRop2ZRYu+xuLFt5HNZovJ0dIE58jI1aRSHz9qOc+Fy8PTnNMQi7MAWAqcnM+zFA5LeF5MeVp5Xs9GNjL1N9dGrucGNpblWs7031x2vJ8pbKRbE58pCfw+XGbghPpMw0PwM4LlOFT8Mw0NwU9/GiwTHPf3XmhWPtMQcG24lKjU73IRERERERElNEUqJB6P097eTnt7e9nKPPPMMznnnP9S7AZfaAlaWJ5+ej779pXnWq3t7Yzl8+xwZ3tJV/dil/fR8lxHRERERERERGQ6SmiK1LBzzjmHjRvPKW4XJg8qJDRvuqmFW28tz7WuvPJK0ul0sSVoJpM57PX3v1+e65TKAU8Do2Y0AY3ujBzlPSIiIiIiIiJS35TQFKkjkUiE5uZmmpubAejsLF/Z119//bTHy5XQzLe24SNGdskSDl59NfmLL6YpnBRpNJ8n+ZVO+Fp5rrV5wwYsk8HSaSKZDKRSRDIZIpkMlsnAg+W5joiIiIiIiIiUjxKaInJCiXzsY/xq/StYv349i4HFE44vWlS+a5393e9Of0K5xvy79jr4xNWQzx+5uMPnm+GLZbrWpk2TX6ewvLVM13nb2+HtXc8PnOh++Ou7XwE/KdO1brnl8PI3b4Yf/AAymTJdIPTmt8Bb5gWvJxsQ8hevhXvLe0nicXjHO+Cssw7fX675dt50PpzfNPXxe18H/16ma4mIiIiIiFSI+dFG8ZfjdvbZZ/vmzZvLWuamTZsOm3VbZpfqu7JU3xVyxx1w3XV4Tw/24hfDZz8LGzZUO6qZCWOnpwdqKfZarfNZrG8ze9Ddzy5LYTKt2bgfqQT9Tagc1XXlqK4rR3VdWbVY37oXEalNaqEpIjJXbdgAGzbwqxq88SzEXnNqtc5rtb5FRERERKQuRaodgIiIiIiIiIiIiMhMKaEpIiIiIiIiIiIiNUMJTREREREREREREakZSmiKiIiIiIiIiIhIzVBCU0RERGQWmdkHzOwOM3vSzHJm5i+gjE1m5lMsmplVREREROYUzXIuIiIiMrs+AXQCDwMtwIteYDn9wFWT7N/1AssTEREREalJSmiKiIiIzK71QI+7583sp7zwhOaou3+3fGGJiIiIiNQmdTkXERERmUXuvtvd8+Uoy8wiZtZmZlaO8kREREREapESmiIiIiK1YRkwAgwCI2Z2p5m9pMoxiYiIiIhUnLqci4iIiJz4ngLuBx4FcsCfAh8B3mRmr3P3x6oZnIiIiIhIJZn7MU+0KcfIzPqAp8tc7AKCyQGkMlTflaX6rizVd+Wpzp93irsvrHYQR2Nm84GPHsNbvuzuBycp56fAhe5+3F3GzexcYBNwn7u/eYpzLgcuDzdPB7Ye73WrQD8vlaO6rhzVdeWoriurFuu7Ju5FRORwSmjWKDPb7O5nVzuOuUL1XVmq78pSfVee6rz2mFkXQSvJmVrl7jsmKadsCc2wvF8C5wKt7j5WjjJPNPp5qRzVdeWoritHdV1Zqm8RqRR1ORcRERE5CnffDZyIE/HsJphF/SSgLhOaIiIiIiITaVIgERERkdq1CsgCR3RvFxERERGpV0po1q5vVjuAOUb1XVmq78pSfVee6lwmZWZLzOwlZtZcsq/dzKKTnHshsA64x91TlYyzwvTzUjmq68pRXVeO6rqyVN8iUhEaQ1NERERkFpnZxcDacPMSgsl5PhluD7j7rSXnfgt4L/BGd98U7ns78EXgJ8AughaZrw7LOgisc/dts/05REREREROFBpDU0RERGR2vZMgSVnq0+H6aeBWprcV2AxcBCwG4kAv8HXgRnffU75QRUREREROfGqhKSIiIiIiIiIiIjVDY2jWCDOLmNlVZvakmaXM7Bkzu9nMWqodWz0ysz8xs78xs9+bWZ+ZDZvZI2Z2nep89plZs5ntMjM3s6O1XJIXyMw6zOwLZrYj/L3SZ2a/NLNzqx1bvTGzeWZ2rZk9Fv4+6Tez35nZpWZ2Is6cLXLCMbNlZvYJM/uVmT1rZqNm9riZ3WRmndWOr96Y2QfM7I7w3jNnZmoFcZx0P1854e+KH5bcT+6udkz1SM9MIlJNaqFZI8zsFuCvgLuAfwNWA1cCvwHOd/d8FcOrO2b2t8AVwN3A74EM8Ebg3cCjwGvcfax6EdY3M/sC8AFgHnCbu3+kyiHVHTM7BdhEUMf/F9gGtAMvB37u7v9Uvejqi5lFgF8BrwW+TfA7pRn4C4JxED/v7v+7ehGK1AYz+yBwC/AvwG+BYYKfoUuB54BXuftzVQuwzoQJoE7gYWAF8CJ31z9gjoPu5ysnTMAfBB4CXgkMuXtXVYOqQ3pmEpFqUkKzBpjZGuAx4C53f2fJ/iuBLwMb3P171YqvHpnZ2cB2dx+csP8zwHXAlaWTOEj5mNkrgD8C1wA3o4TmrDCz3wBdwKvd/dkqh1PXzOwc4HfAl9z9qpL9DcCTQIe7z69SeCI1I7wfOjAxaWlmlwG3Aze7+9VVCa4OmVkX0OPueTP7KXChEpovnO7nK8vMVrr7rvD1FmCeEprlp2cmEakmdTmvDX8BGPClCftvB5IEs5xKGbn75ol/mEP/HK5fVsl45gozixJ8X/8MuLPK4dQtM3s98DqCloHPmlnczJqrHVcdawvXe0t3uvs40A+MVjwikRrk7o9P0QJTf5tngbvvVovBstL9fAUVkpkyu/TMJCLVpIRmbXgVkCdotVbk7ingkfC4VMaLwvW+qkZRv64CXgKoRebsuiBc95jZT4AxYNTMtpmZHqjK74/AAHCNmb3LzF5sZi8xs88RdIPbWM3gROqA/jZLLdD9vMwl+r0sIrNOCc3asBTod/f0JMf2AAvCrosyi8LWg58EsoC6BJWZma0AbgD+xt13Vzmcend6uL4d6ADeC7wPGAe+Y2b/vVqB1SN3PwS8lWAsrx8ATwNPEIw59U53v72K4YnUgxvC9berGoXI9HQ/L3OCnplEpFJi1Q5AZqQZmOzmByBVcs54ZcKZs74EnANc6+5bqxxLPfo6sAv4YrUDmQNaw/Uw8Maw6zNm9mOCr8GNZvZtdTUsqxFgC8Gg+b8jSCRfAXzPzN7m7vdUMziRSjKz+cBHj+EtX3b3g1OU9b+AdwHfdPf7jj+6+lLOupbjpvt5mSu+hJ6ZRKQClNCsDUlg0RTHmkrOkVliZp8m6Ab9TXf/XLXjqTdhN+c3A69390y145kDCrNNfr+QzISgJaGZ3Q38JUErzieqEVy9MbMzCJKYV7n710v2f58gyXm7mZ3q7rlqxShSYfOB64/h/O8StHA+TDgZ0E0Es55rqJLJzacMdS1loft5qXt6ZhKRSlJCszbsBV5qZo2TdFNZRtB9Rf/NnSVmthH4a+AfgA9WN5r6Y2aNBK0y/xV4zsxOCw8tC9ft4b5+dx+oQoj1qDdcTza5RmHG85MqFMtccBXBw+oPS3e6e9LMComYLmBn5UMTqbxwWJHjmi3bzN4HfBP4BcHQDfpn2CTKUddSNrqfl7qmZyYRqTSNoVkb/oPga/Xq0p1m1gScCWyuQkxzQviH+XqCcbkuc3evbkR1KQEsBC4Etpcsm8Ljl4Tbl1UjuDpVmJDgRZMcK+zbX6FY5oJCcj46ybHYhLWIHEWYzPw/wL3A26cYk1DkRKP7ealbemYSkWpQQrM2/DPgHDkG0vsJxtq5o9IBzQVm9imCP8zfAd6n8QRnzSjB+GcTlw+Hx38Wbt9dlejq048Jxs+8xMzmFXaa2RLg7cA2d99RndDqUne4vrR0Zzi23duAQ4DqW2QGzOxSggnN7gPeFs4QLVILdD8vdUnPTCJSLaZ/ntQGM/sKQbfEuwi65q4G/gq4HzhPfzjKy8yuAG4Feghm6ZtYv/s0icfsMrMu4CngNnfX2GhlZmaXA98AHgf+HmgAPgQsAS5y919UMby6YmanAA8RdOO/g+D3dgfBQ2wXcIW7f7VqAYrUCDN7K8F90BBwDc+PB1ww4u4/rnRc9crMLgbWhpuXEIyt/Mlwe8Ddb61KYDVM9/OVY2bvAU4JN68kuM+5Odx+2t2/U5XA6oyemUSkmpTQrBFmFiX4j+7lBA/A/QT/6f2Uu49UL7L6ZGbfAt47zSm/cvf1lYlmblJCc/aZ2X8mSAqcQXAD+gBwg7vfX9XA6pCZnQp8CngTsJggEfMI8CV3v7OKoYnUjJIujVN52t27KhNN/TvKvZDq+gXQ/XzlmNkm4A1THNZ9fJnomUlEqkkJTREREREREREREakZGkNTREREREREREREaoYSmiIiIiIiIiIiIlIzlNAUERERERERERGRmqGEpoiIiIiIiIiIiNQMJTRFRERERERERESkZiihKSIiIiIiIiIiIjVDCU0RERERERERERGpGUpoisicZWbrzczN7NJqxwJgZpvN7LFqxyEiIiIiIiJyIlNCU0ResJKE4NUl+840s41m1lXF0IpOtHimYmYx4GXAI1UORUREREREROSEpoSmiJTbmcD1QFd1wyg6k6nj+TWQAL5TwXim8lKgESU0RURERERERKYVq3YAIiIzZWZRoNHdk+Uoz93zQKocZZXBmeH64WoGISIiIiIiInKiUwtNESkbM9sI/EO4+cuwO7qb2bdKzmk0s2vN7HEzS5nZgJn9xMzOmlDWpeF7zzezT5rZToLk47vNrNXMPmNmfzCzfjNLm9kOM/tbM2ueaTxTjaFpZgvM7DYze8bMxsP1bWbWOUWM55nZ1Wa2M4xlm5m99xirr/D5Hykpf76Z3RXW0+XHWJ6IiIiIiIhIXVILTREppzuBJcDlwI3AE+H+nQBmFgd+BryWoJv3rUA78H7gfjN7vbtvnlDmF4A4cDswBGwFlgGXAf8P+B6QBd4AXEOQGPxPM4lnMmbWDvwOOA34e+ChsMwPAeeZ2avdfXjC224k6Lr+DSAdnvstM9vh7vdPWVuHOxN4xt0PhnG8EvghYMA6d39whuWIiIiIiIiI1DUlNEWkbNz9UTN7gCCBeI+7b5pwykeA9cCfufvPCzvN7KvAFoLk5foJ70kAZ5V2MzezBmC5u2dKzrvNzD4N/HWYdPzjDOKZzDXAKuAKd/9qyTUfIUjAXgN8csJ7GoFXuft4eO6PgF3h5z2WhOZvwvd/CPg74N+B9xSSnCIiIiIiIiKiLuciUlmXAE8CD4bduheY2QKgAbgHeJ2ZJSa852sTx8x09/FCMtPMYmZ2UljOveEpf3ocMb4D6AO+OWH/N8L975jkPV8tJDPD+PYA2wgSo0cVzsA+H9huZt8jSJx+FrhIyUwRERERERGRw6mFpohU0mqCFpd905yzAHimZHvbZCeZ2YeBDwJrOPKfMycdR4wrgM3uni3d6e5ZM9sGvGKS9+yaZN8B4JQZXrMwfuaVQJ6gBes9M3yviIiIiIiIyJyihKaIVJIBjwEfm+acicnOI2Y0N7OPATcDvwC+DOwFxgnG1vwWlW99nptiv83w/YWE5u3Ah4EzCFqsioiIiIiIiMgESmiKSLn5NMe2AwuB+9w9fxzXeA+wG/jz0nLM7M+OMZ7J7AJON7NYaStNM4sBf8LkrTGP15lAv7tfEXa5v8nMdrv7nbNwLREREREREZGapjE0RaTcRsJ1xyTH/hE4mSlaaJrZ4hleI0eQqCy2gAwTjh8/xngm82OCpOtlE/a/P9x/1wzLORZnAQ+Hrz8AbAK+a2avnoVriYiIiIiIiNQ0tdAUkXL7D4JxIK8zs5OAUeApd/8DcAvwZoIWiOcB9wFDwIuBNwEp4I0zuMaPgM8B/2ZmdwJtwH8DMpOcO108k/k88C6CWdNfQZBoPAv4H8DW8HjZmFkn8CLgewDunjGzdwK/A35iZq9x96fKeU0RERERERGRWqYWmiJSVu7eA7yPYPKfrwHfBz4UHssAFwL/k6C14w3A3wH/laAr9+dmeJmbgGuBlQRJ0isIxtP8y2OJZ4r4B4F1BLOaX0AwRucFwNeB17n78AxjnKnC+JmFFpq4+wBBPQH8a5iIFRERERERERHA3I91eDkRERERERERERGR6lALTREREREREREREakZSmiKiIiIiIiIiIhIzVBCU0RERERERERERGqGEpoiIiIiIiIiIiJSM5TQFBERERERERERkZqhhKaIiIiIiIiIiIjUDCU0RUREREREREREpGYooSkiIiIiIiIiIiI1QwlNERERERERERERqRlKaIqIiIiIiIiIiEjN+P8A7loRQ/p9wgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 1296x432 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Lasso objectives:\n",
      "Group lasso=\t0.00018028779923629838\n",
      "Reweighted=\t0.00018028813854689533\n",
      "NTK weights=\t0.00032610176363451475\n"
     ]
    }
   ],
   "source": [
    "n, d = X.shape\n",
    "D, G = get_unique_masks(X, G)\n",
    "# G = G.T\n",
    "p, d = G.shape\n",
    "print(p, d)\n",
    "probs = get_cone_probabilities(X, D)[0]\n",
    "print(f\"Sum of cone probabilities = {probs.sum()}\")\n",
    "ntk_weights = 1 / probs\n",
    "\n",
    "las_model, las_sol = train_l1_gated_relu(\n",
    "    X, G, y, L=L  # * 2 * np.linalg.norm(ntk_sol, axis=1).sum()\n",
    ")\n",
    "# ntk_model, ntk_sol = train_l1_squared_gated_relu(\n",
    "#     X, G, y, L=L / (2 * np.linalg.norm(las_sol, axis=1).sum())\n",
    "# )\n",
    "rew_model, rew_sols = train_l1_gated_relu_reweighted(\n",
    "    X,\n",
    "    G,\n",
    "    y,\n",
    "    L=L,\n",
    "    eps=eps,\n",
    "    init_weights=ntk_weights,\n",
    "    maxiters=rew_iters,\n",
    ")\n",
    "ntk_model, ntk_sol = train_l2_gated_relu(X, G, y, weights=ntk_weights, L=L)\n",
    "krr_model = train_ntk_with_ridge(X, y, L=L)\n",
    "ntk_krr_err = np.linalg.norm(ntk_model(X) - krr_model(X)) / np.linalg.norm(krr_model(X))\n",
    "print(f\"Error between KRR and NTK on train data: {ntk_krr_err}\")\n",
    "\n",
    "rand_rew_sols = [\n",
    "    train_l1_gated_relu_reweighted(\n",
    "        X,\n",
    "        G,\n",
    "        y,\n",
    "        L=L,\n",
    "        eps=eps,\n",
    "        maxiters=rew_iters,\n",
    "        init_weights=np.random.rand(*ntk_weights.shape) + eps,\n",
    "    )[1]\n",
    "    for _ in range(repeats)\n",
    "]\n",
    "\n",
    "all_models = [las_model, rew_model, ntk_model, krr_model]\n",
    "all_sols = [las_sol, rew_sols[-1], ntk_sol]\n",
    "model_names = [\"Group lasso\", \"Reweighted\", \"NTK weights\", \"KRR with NTK\"]\n",
    "colors = [las_color, rew_color, ntk_color, krr_color]\n",
    "\n",
    "sample_n = 1000\n",
    "x = np.linspace(*xlims, sample_n).reshape(-1, 1)\n",
    "sample_X = np.append(x, np.ones((sample_n, 1)), axis=1)\n",
    "plt.subplots(1, 2, figsize=(18, 6))\n",
    "plt.subplot(1, 2, 1)\n",
    "plt.semilogy()\n",
    "plt.title(f\"Group lasso objective, $\\\\lambda={L}$\")\n",
    "rew_lobjs = [lasso_objective(X, D, rew_sol, y, L) for rew_sol in rew_sols]\n",
    "rand_rew_lobjs = [\n",
    "    [lasso_objective(X, D, rew_sol, y, L) for rew_sol in rew_sols]\n",
    "    for rew_sols in rand_rew_sols\n",
    "]\n",
    "rand_rew_lobjs = np.array(rand_rew_lobjs)\n",
    "plt.plot(\n",
    "    rand_rew_lobjs[1:].T,\n",
    "    color=\"black\",\n",
    "    alpha=0.5,\n",
    "    linewidth=irlslw,\n",
    ")\n",
    "plt.plot(\n",
    "    rand_rew_lobjs[0],\n",
    "    color=\"black\",\n",
    "    alpha=0.5,\n",
    "    label=\"IRLS with random inits\",\n",
    "    linewidth=irlslw,\n",
    ")\n",
    "plt.plot(\n",
    "    rew_lobjs,\n",
    "    # label=model_names[1],\n",
    "    ls,\n",
    "    label=\"IRLS with NTK init\",\n",
    "    color=rew_color,\n",
    "    linewidth=lw,\n",
    ")\n",
    "las_lobj = lasso_objective(X, D, las_sol, y, L)\n",
    "plt.axhline(\n",
    "    las_lobj,\n",
    "    # label=model_names[0],\n",
    "    linestyle=\"--\",\n",
    "    label=\"Optimal\",\n",
    "    color=las_color,\n",
    "    linewidth=lw,\n",
    ")\n",
    "ntk_lobj = lasso_objective(X, D, ntk_sol, y, L)\n",
    "plt.axhline(\n",
    "    ntk_lobj,\n",
    "    # label=model_names[2],\n",
    "    linestyle=\"--\",\n",
    "    label=r\"NTK weights\",\n",
    "    color=ntk_color,\n",
    "    linewidth=lw,\n",
    ")\n",
    "plt.legend()\n",
    "plt.xlabel(\"Iteration $k$\")\n",
    "\n",
    "ax = plt.subplot(1, 2, 2)\n",
    "plt.title(f\"Learned functions\")\n",
    "# plt.title(f\"$\\\\lambda = {L}$\")\n",
    "ytest_c, ytest_s, ytest_n = ytest_cone, ytest_sgd, ytest_ntk\n",
    "xtest = np.linspace(-2, 2, 101)\n",
    "plt.plot(\n",
    "    xtest,\n",
    "    ytest_c,\n",
    "    label=\"Group Lasso\",\n",
    "    color=las_color,\n",
    "    lw=lw,\n",
    "    alpha=0.7,\n",
    ")\n",
    "plt.plot(\n",
    "    xtest,\n",
    "    ytest_s,\n",
    "    \"--\",\n",
    "    label=\"Gradient Descent\",\n",
    "    color=\"black\",\n",
    "    lw=lw,\n",
    "    alpha=0.99,\n",
    ")\n",
    "plt.plot(\n",
    "    xtest,\n",
    "    ytest_n,\n",
    "    label=\"KRR with NTK\",\n",
    "    color=\"green\",\n",
    "    lw=lw,\n",
    "    alpha=0.7,\n",
    ")\n",
    "plt.plot(\n",
    "    X[:, 0],\n",
    "    y,\n",
    "    marker=\"o\",\n",
    "    markersize=10,\n",
    "    linewidth=0,\n",
    "    alpha=0.95,\n",
    "    label=\"Training data\",\n",
    "    color=\"red\",\n",
    ")\n",
    "l = plt.legend(bbox_to_anchor=[1.0, 1.0])\n",
    "plt.ylim(ylims)\n",
    "plt.xlim(xlims)\n",
    "prefix = \"one_d_example\"\n",
    "if SAVE:\n",
    "    plt.savefig(\n",
    "        f\"figs/{prefix}_L={L}.png\",\n",
    "        bbox_inches=\"tight\",\n",
    "        bbox_extra_artists=[l],\n",
    "    )\n",
    "plt.show()\n",
    "print(f\"Lasso objectives:\")\n",
    "print(f\"{model_names[0]}=\\t{las_lobj}\")\n",
    "print(f\"{model_names[1]}=\\t{rew_lobjs[-1]}\")\n",
    "print(f\"{model_names[2]}=\\t{ntk_lobj}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "857e619c",
   "metadata": {},
   "source": [
    "# Student teacher"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "ba348575",
   "metadata": {},
   "outputs": [],
   "source": [
    "def run_st_models_and_plot(\n",
    "    X,\n",
    "    y,\n",
    "    Ls=[0.02],\n",
    "    rew_iters=30,\n",
    "    eps=1e-10,\n",
    "    repeats=2,\n",
    "    prefix=\"\",\n",
    "):\n",
    "    D, G = get_unique_masks(X)\n",
    "    n, d = X.shape\n",
    "    p, d = G.shape\n",
    "    probs = get_cone_probabilities(X, D)[0]\n",
    "    print(f\"Sum of cone probabilities = {probs.sum()}\")\n",
    "    ntk_weights = 1 / probs\n",
    "    model_names = [\"Group lasso\", \"Reweighted\", \"NTK weights\", \"KRR with NTK\"]\n",
    "    colors = [las_color, rew_color, ntk_color, krr_color]\n",
    "\n",
    "    plt.subplots(1, len(Ls), figsize=(18, 6))\n",
    "    plt.suptitle(\"Group Lasso objective for Student-Teacher setting\")\n",
    "    for i, L in enumerate(Ls):\n",
    "        las_model, las_sol = train_l1_gated_relu(\n",
    "            X, G, y, L=L  # * 2 * np.linalg.norm(ntk_sol, axis=1).sum()\n",
    "        )\n",
    "        # ntk_model, ntk_sol = train_l1_squared_gated_relu(\n",
    "        #     X, G, y, L=L / (2 * np.linalg.norm(las_sol, axis=1).sum())\n",
    "        # )\n",
    "        rew_model, rew_sols = train_l1_gated_relu_reweighted(\n",
    "            X,\n",
    "            G,\n",
    "            y,\n",
    "            L=L,\n",
    "            eps=eps,\n",
    "            init_weights=ntk_weights,\n",
    "            maxiters=rew_iters,\n",
    "        )\n",
    "        ntk_model, ntk_sol = train_l2_gated_relu(X, G, y, weights=ntk_weights, L=L)\n",
    "        krr_model = train_ntk_with_ridge(X, y, L=L)\n",
    "        ntk_krr_err = np.linalg.norm(ntk_model(X) - krr_model(X)) / np.linalg.norm(\n",
    "            krr_model(X)\n",
    "        )\n",
    "        print(f\"Error between KRR and NTK on train data: {ntk_krr_err}\")\n",
    "\n",
    "        rand_rew_sols = [\n",
    "            train_l1_gated_relu_reweighted(\n",
    "                X,\n",
    "                G,\n",
    "                y,\n",
    "                L=L,\n",
    "                eps=eps,\n",
    "                maxiters=rew_iters,\n",
    "                init_weights=np.random.rand(*ntk_weights.shape) + eps,\n",
    "            )[1]\n",
    "            for _ in range(repeats)\n",
    "        ]\n",
    "\n",
    "        all_models = [las_model, rew_model, ntk_model, krr_model]\n",
    "        all_sols = [las_sol, rew_sols[-1], ntk_sol]\n",
    "        plt.subplot(1, len(Ls), i + 1)\n",
    "        plt.semilogy()\n",
    "        plt.title(f\"$\\\\lambda={L}$\")\n",
    "        rew_lobjs = [lasso_objective(X, D, rew_sol, y, L) for rew_sol in rew_sols]\n",
    "        rand_rew_lobjs = [\n",
    "            [lasso_objective(X, D, rew_sol, y, L) for rew_sol in rew_sols]\n",
    "            for rew_sols in rand_rew_sols\n",
    "        ]\n",
    "        rand_rew_lobjs = np.array(rand_rew_lobjs)\n",
    "        plt.plot(\n",
    "            rand_rew_lobjs[1:].T,\n",
    "            color=\"black\",\n",
    "            alpha=0.5,\n",
    "            linewidth=irlslw,\n",
    "        )\n",
    "        plt.plot(\n",
    "            rand_rew_lobjs[0],\n",
    "            color=\"black\",\n",
    "            alpha=0.5,\n",
    "            label=\"IRLS with random inits\",\n",
    "            linewidth=irlslw,\n",
    "        )\n",
    "        plt.plot(\n",
    "            rew_lobjs,\n",
    "            # label=model_names[1],\n",
    "            # ls,\n",
    "            \"-\",\n",
    "            label=\"IRLS with NTK init\",\n",
    "            color=rew_color,\n",
    "            linewidth=lw,\n",
    "        )\n",
    "        las_lobj = lasso_objective(X, D, las_sol, y, L)\n",
    "        plt.axhline(\n",
    "            las_lobj,\n",
    "            # label=model_names[0],\n",
    "            label=\"Optimal\",\n",
    "            linestyle=\"--\",\n",
    "            color=las_color,\n",
    "            linewidth=lw,\n",
    "        )\n",
    "        ntk_lobj = lasso_objective(X, D, ntk_sol, y, L)\n",
    "        plt.axhline(\n",
    "            ntk_lobj,\n",
    "            # label=model_names[2],\n",
    "            label=r\"NTK weights\",\n",
    "            linestyle=\"--\",\n",
    "            color=ntk_color,\n",
    "            linewidth=lw,\n",
    "        )\n",
    "        if i == len(Ls) - 1:\n",
    "            plt.legend()\n",
    "        plt.xlabel(\"Iteration $k$\")\n",
    "    if SAVE:\n",
    "        plt.savefig(f\"figs/{prefix}.png\")\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "id": "0388a95e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(211, 5)\n"
     ]
    }
   ],
   "source": [
    "n = 10\n",
    "d = 5\n",
    "max_neurons = int(1e3)\n",
    "p_teacher = 10\n",
    "X, D, G = get_data(n, d, max_neurons)\n",
    "Gteacher = np.random.randn(p_teacher, d)\n",
    "Wteacher = np.random.randn(p_teacher, d)\n",
    "y = gated_relu_model(X, Gteacher, Wteacher)\n",
    "\n",
    "st_prefix = f\"st_pteacher{p_teacher}_d{d}_n{n}\"\n",
    "st_repeats = 5\n",
    "st_rew_iters = 100\n",
    "print(G.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "3a63a6c1",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Calculating cone probabilities: 100%|██████████| 191/191 [00:06<00:00, 29.84it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sum of cone probabilities = 0.910914\n",
      "0.0039803772550093255\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.61it/s, train_loss=5.82e-8]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error between KRR and NTK on train data: 0.0005615305861675805\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.52it/s, train_loss=5.78e-8]\n",
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.72it/s, train_loss=5.83e-8]\n",
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.73it/s, train_loss=5.81e-8]\n",
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.58it/s, train_loss=5.83e-8]\n",
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.54it/s, train_loss=5.77e-8]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.03979077044367366\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:07<00:00, 14.19it/s, train_loss=5.81e-6]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Error between KRR and NTK on train data: 0.005248120688710063\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.34it/s, train_loss=5.78e-6]\n",
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.53it/s, train_loss=5.79e-6]\n",
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.47it/s, train_loss=5.79e-6]\n",
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.58it/s, train_loss=5.86e-6]\n",
      "Iteratively reweighted least squares: 100%|██████████| 100/100 [00:06<00:00, 14.61it/s, train_loss=5.77e-6]\n"
     ]
    },
    {
     "data": {
      "image/png": "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iJB/lzbmOYiIiHQAulbRNYdIzJlzrq37ICIiIiIiIiKyR1ENExERERERERGRMAqYiIiIiIiIiIiEUcBERERERERERCSMAiYiIiIiIiIiImEUMBERERERERERCaNphVtB165d3YABA2LW3u7du8nMzIxZex2djmds6XjGlo5nbOl4xlZzj+dnn322xTmXH8MuST10PbJn0/GMLR3P2NLxjC0dz9hqyesRBUxawYABA/j0009j1t6cOXMoKCiIWXsdnY5nbOl4xpaOZ2zpeMZWc4+nma2MXW+kIboe2bPpeMaWjmds6XjGlo5nbLXk9YiG5IiIiIiIiIiIhFHAREREREREREQkjAImIiIiIiIiIiJhFDAREREREREREQmjgImIiIiIiIiISBgFTEREREREREREwihgIiIiIiIiIiISRgETEREREREREZEwCpiIiIiIiIiIiIRRwCTeOEdCaSls3AirVrV1b0RERKQjqqwkoaQEtm2DrVvbujciIiItIqmtO9ARrCtch91sMWnL3WyMcc6707MnrFtXY32sHuemY25iSsGUOtdPmTOFm+feHJPHcje5etfrOdVtj31Oc5v+OHvsc2qGZj+nRhzPuHlOjRDz51TH8Yzr51SHVnlO/vFsreckTRfT65EpMCZw59BD4eOPa6yPq3PY167el74O/5x0PVKDrkeaR9cjTRfP1yPKMIk3LuQEKCpqu36IiIiIAJSWtnUPREREWoQCJvGsqKhmAEVERESktZWVtXUPREREWoQCJvHMOSgubuteiIiISEemgImIiLRTCpjEu8LCtu6BiIiIdGQakiMiIu2UOQ3paHGjRo1yn376afMbGjgQli+vuey772Dw4Oa33YHNmTOHgoKCtu5Gu6HjGVs6nrGl4xlbzT2eZvaZc25U7Hok9YnJ9ci2bZCXV3NZ587ecmkWfT7Flo5nbOl4xpaOZ2y15PWIMkziSVZW7WXKMBEREZHWkppae5kyTEREpJ1SwCSeZGfXXqaZckRERKS1RAqYqIaJiIi0UwqYxJNIGSYKmIiIiEhrSUqCxMSay6qrobKybfojIiLSghQwiScakiMiIiJtTcNyRESkg1DAJJ5oSI6IiIi0tbS02ss0LEdERNohBUziiTJMREREpK0pw0RERDoIBUziiTJMREREpK2p8KuIiHQQCpjEE2WYiIiISFvTkBwR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6CEuu+wyunTpwmOPPcZPfvITUlJSuPbaaxk7diy33XYbn3zyCY8//jhpaWk8+uijUR2rSHbv3s2YMWMYPXo0t912G8uXL+fee+/ltNNO45tvviExMTHifmPGjOHaa6/ltttu42c/+xlHH3004J2PAL///e+58cYbOeWUU/j5z39OYmIiy5cv55VXXqGsrKzFM5IaFTCRPUNqairJyclUVVV56WLdu5MUXtxp3ToFTERERKTFaEiO7IkCxUHLyspITY00WWbbiXXh0oqKCrZs2QLAjh07eOONN3jggQfIyspiwoQJjW4vkJXw61//mv3224+RI0dy+OGHc+ihh3LYYYdFFXhISUnhyCOPZPbs2cFls2bNIjExkbPOOou33367xnKg3oDJ+PHjeeaZZ3j33XdrDD8KN3LkSB588MHg/X333ZezzjqLZ599lksuuaTBfgN06tSJt956i6SwSTVef/31GpNuAJx//vkceOCB3HPPPTUeF2DJkiX84x//4KyzzgouS0hI4MEHH6wRiLruuuvYvn07s2bNCmZY/OIXv+CMM85g3rx5Ndp88803ef755znrrLN47rnnglk4Z511FgcffDBXXnkl7777bo19Fi5cyIIFC+jf36tocfbZZ9O3b1/OO+887rrrLn71q18B8POf/5zt27fzt7/9jalTp9Yo/9AYW7Zs4Te/+Q2//e1vg8vy8/P57W9/y1tvvcXxxx8fcb+BAwcyfvx4brvtNg4//PBar/PLL7/MsGHDeOWVV2osv+OOO5rUz8aKekiO7DkCARPwUrMq8vNrb6Q6JiIiItKCVPRVpG3NnDmT/Px88vPzGTJkCJdffjn7778/b731Ft26dWtSm1dffTWvvPIKxx13HAsWLOC+++5j4sSJ7LPPPlx00UUUFxc32MbYsWNZu3ZtsDDorFmzGDlyJGeeeSYLFy5k/fr1AMyePZvOnTvXyoxoiquuuqpWH6BxQ5MmT55cK1gC389Q6pxj165dbNmyhfz8fIYOHRpx2E+vXr1qBEsi9ae6upoZM2YwatSoYLAEvKBVaMAhIDCU6brrrqsxZOmAAw7glFNO4b333mPz5s019pkwYUIwWAIE+5yQkMAvfvGLGtseffTRVFRUsGLFitoHJkoJCQlceeWVNZY15XUIl5uby9q1a3nvvfea3EZzKGAShxISEoLFdpxzlHTuXHsjBUxERESkBSnDRKRtHXbYYbz55pvMnDmTRx99lH333Zc1a9Y0uyjnKaecwmuvvcbOnTv56quvuOeee+jTpw+PP/54rcBEJIEvyYEMktmzZzN27FiOPfZYzIxZs2ZRXV3N3LlzOeaYY0iINOtnIw0cOLDG/by8PICIUyzXZe+99464fN68eZx88snBeiSBINXXX3/N9u3bG+xLpP5s3ryZoqIi9tlnn1rb7rvvvrWWLV++nISEBIYNG1Zr3X777RfcpqF+dO7cmZ49e9bKvursf59szPEK16tXr1rFXJvyOoS77bbbSEtL4+ijj6Z3796ce+65PPvss02eCaqxNCQnjuzevZu//vWvfPPNN6xatSoY7SzMyqLWKEUFTERERKQF1Zlh4hyE/AIq0poCw14KCwujrl0Rr7p27Ros8gpw+umnM3z4cM4880zmz59Penp6s9pPTExk+PDhDB8+nAkTJnDggQfy5JNP8uCDD9ZZjwJg1KhR5OTkMGvWLMaPH8+qVasYO3YsXbp04YADDuDtt99m2LBhbNu2rd7hOI3tayTOuajbyMjIqLVs1apVjBkzhpycHG644QaGDh1KZmYmZsbkyZMjzhpU37FpTH+aq65+tFT/Wqrdww8/nKVLl/LGG28we/ZsZs+ezbPPPsutt97Ke++916R6PY2hDJM4kpaWxq5du6iuriYxMTF44u2I8OZWwERERERaVGKidwvlnGbqE2kjXbp04dZbb2X58uXcc889MW07Ly+PQYMGUVZWFqybUpfExETGjBnD7Nmzeeutt0hJSeGoo44C4Ac/+AGzZs0K1jiJJmBibRiAffnllykqKuLpp5/md7/7HRMmTGD8+PGMGzeuWVkTXbt2JSsri0WLFtVat2DBglrLBg4cSHV1NQsXLqxz+7322qvJ/WlrDb3GWVlZnHnmmfz5z39m/vz5PPDAAyxcuJDHHnusxfumgEkcSUxMDEaKk5OTqfanFN4aqaCVAiYiIiLS0sLSrwENyxFpQ+eddx4DBw7krrvuYteuXY3at7i4mLlz50Zct2TJEhYsWEDXrl3Jj1Q/MczYsWPZunUr9913H6NHjw5mb4wdO5aVK1fy+OOP07179+BwkvoEipBu27atEc8mNgJZE+EZEo888kjEaYIb0+7JJ5/Mp59+WqNArnOOP/7xj7W2DxTxvf3222v05ZtvvuGVV17hqKOOiup12VPV9xpHCtCNHDmyzu1jTUNy4kxgGE5qairFxcUkJiayJdI4RQVMREREpAVs2LCBV199lS+++ILDzaj1s01pKTRxlgURaZ6kpCSuueYaLr74Yu69915uuOGGGusff/xxXn/99Vr7HXzwwRxyyCEUFBSw//77c8IJJzBkyBCccyxatIgnn3yS0tJSHnjggahqjgQyRxYuXMjZZ58dXD5mzBiSkpJYsGABP/7xj6N6TqNHj+bPf/4zl112GSeddBLJyckcdthhrZJRceKJJ5KRkcF5553H5ZdfTufOnXn//fd57bXXGDRoEJXNyKi79dZb+c9//sPJJ5/MFVdcQZ8+fZgxY0at4q3gzRYUmCFn+/btnHzyycFphdPS0rjvvvua8zTb3L777kt2djYPPvggGRkZdOrUiW7dujF27FiGDRvG6NGjOeyww+jVqxfr16/n4YcfJiUlJepzqDkUMIkzgehbamoqhYWFAKyPlMKkgImIiIi0ADNj9erVFBYWUpmQUDtgogwTkTZ1wQUXcMstt3D33Xdz5ZVXkpubG1z3l7/8JeI+l1xyCePHj+fxxx9n5syZvPLKK6xfv57S0lLy8/M56qijuOqqq2rM6FKfESNG0LVrV7Zs2VJj2E1WVhaHHnooH3zwQdT1S8455xzmzZvHc889xwsvvEB1dTVPPPFEqwRMBg0axH/+8x+uvfZabrvtNhITEznyyCOZO3cul19+ebNmlRk0aBDvvvsuV199Nffffz+pqamceOKJPPXUU3Tv3r3W9s888wwjR45k2rRpXH311WRmZnLMMcdwyy23MHz48GY8y7aXnp7Oc889x/XXX8/kyZMpKyvjmGOOYezYsVx99dW89tpr3HfffezcuZNu3boxevRorrnmGg444IAW75u1ZuGZjmrUqFHu008/jUlbL7zwAq+++iq7du1i1apVZGVlcfioUdx+993euOFQZWXQzCrZHcGcOXMoKCho6260GzqesaXjGVs6nrHV3ONpZp8550bFrkdSn1hdjxQVFXHXXXexYsUKps6YQafwlOglS2DQoGY/Tkejz6fGWbhwYcQZQwI6QtHX1qTjGVs6nrFV3/Fs6LMC6r8eUQ2TOBPIMElPT6eqqgqAncXFEGmu9WaMqxMRERGJJCMjI1igryJSar4yTEREpJ1QwCTOhNYwCRR93b17N/TqVXtjDcsRERGRGEtISAgWcKxMijC6WwETERFpJxQwiTORMkyKiooUMBEREZFWE7geqQqfVhi8oq8iIiLtgAImcSaQYZKWlhbMMCkrK6O6R4/aGytgIiIiIi0gcD2iDBMREWnPFDCJM4FfdJKTk4PLKioqKO/atfbGCpiIiIhIC1DAREREOgIFTOJM4AIlOTmZwAxHFRUVlObl1d5YARMRERFpARqSIyIiHYECJnEmcIGSkJCAmeGco7q6mqJI0ygpYCIiIiItQBkmIiLSEShgEmeSkpJITk7GzEhKSgrWMdmWllZ7YwVMREREpAUEfsCJGDBRhomIiLQTCpjEofT0dABSUlKCM+VsCalpEqSAiYiIiLSAQIZJxCE5yjAREZF2QgGTOJTmZ5OkpqYGM0w2ASSEvZzbt0NJSet2TkRERNo9DckREZGOQAGTOBQpw2RHYSFEmlp4/frW7JqIiIh0AMEhOSr6KiIi7ZgCJnGkoqKCRYsWsXXrVtauXUtaWlowYLJr1y7o1av2ThqWIyIiIjGmDBMREekIFDCJIxUVFTz33HMsWbKEZcuWkZqa2nDAZO3aVu6liIiItHeJiYnedYiKvopIDE2aNAkza7Ht49mcOXMwM6ZNm9bkNgoKChgwYEDM+tQRKGASR9LT00lISCApKYmqqqoaQ3IKCwuhb9/aOy1f3sq9FBERkY4gLS0t8pAcZZiIxEzgS/Jdd91VY7mZ1bilpqYyePBgJk+ezNatW2u1M2XKFMyMTz/9tMHHfOeddzj11FMZMGAAqampdOvWjWOOOYYrr7ySZcuWxey5RWv69OlMmTKlxdqfNm1a8Di++eabtdavWLECM+Pyyy8Hvg/SRHML9LugoCA4lDFUeXk5Z511VrB951yLPc+6TJs2jalTp7b648aLCD8LyJ7KzMjMzCTZnxEnMTExGDApKiqC4cNr7/Tdd63ZRREREekg0tLSNCRHpA0deOCBXH311QBs376dmTNncu+99/LWW2/x+eefk5KS0ug2//KXv3DZZZcxcOBALrjgAvr27cvmzZv56quv+Pvf/86YMWMYOHBgrJ9K0COPPMJDDz1UY9n06dN58sknWzRoEvC///u/jBs3rt6slUsuuYRx48bVWHbeeeexzz77cN1119VYPmLEiDrbKS4u5owzzuCNN97g+uuv55Zbbqm3b2PGjKGkpCT4XbApZs6cWSsoM23aNFasWMHkyZOb3G57poBJnMnKyiLJvzhJSkoKzpJTVFQEgwfX3mHJktbsnoiIiLRzu3fv5rvvvmPLli1s27279gYakiPSKnr37s3EiROD96+44gpOP/10pk+fzowZMzjzzDMb1V5lZSXXXnst/fr1Y968eeTk5ATXFRYWkpqa6n3naEHJycnNCgg0x6hRo/j000957rnnOOecc+rc7vDDD+fwww+vsey8886je/fuNV6P+uzYsYMf//jHfPjhh9xzzz1RBSsSEhKCs6U2VVOCaB2dhuTEmczMzGDAJCEhIZhhUlxcTHWkaK8CJiIiIhJDO3bsYPr06axcuZLNu3bV3kAZJiJtJpD58F0Tssy3bNnCjh07OOSQQ2oESwJSUlLo0qVLvW3MnTsXM+OJJ56osXzo0KGYGS+//HKN5T169ODEE08M3g+vSVJQUMCTTz4J1ByGFF7HY+fOnVx66aV069aNtLQ0jjzySD7++OOonnfAlVdeSe/evbn++uspLy9v1L6NsXHjRk466SQ+/vhjHn/88agzOyLVMAld9sQTT7DffvuRmppK//79+eMf/1irjfAaJgMGDGDu3LmsXLmyxvGdM2dO855kO6IMkzgTmmEC4JzDOUdFRQUlPXqQmZAAftYJ4M2Ss3s3+NXsRURERJojIyMD8DJdSyKNt1eGibSVkC/a2W3YjXq1cI2KpUuXAjQY2Iike/fuZGVl8c4777B48WKGDh3a6DYOP/xw0tPTmTVrFhdeeCEAa9as4dtvvyUhIYFZs2Zx+umnAzB//nw2btzI2LFj62zvuuuuo7q6mnfffZennnoquPyII46osd3xxx9Pfn4+N954I1u3buXuu+/mpJNOYvny5WRnR3c2pKenM2XKFC6++GIeeughrrzyysY+/QatXLmS8ePHs2rVKl544YXgsWiuhx56iI0bN3LRRRfRqVMnnn76aX73u9/Rp08f/t//+3917jd16lSuueYatmzZwj333BNcPmzYsJj0qz1QwCTOZGZmkpiYSGJiItXV1ZhZMGBSXFVFZr9+sGJFzZ2WLYtc30RERESkkUIDJqWRvvwpw0SkVVRUVLBlyxbAy/x64403eOCBB8jKymLChAmNbi9QpPTXv/41++23HyNHjuTwww/n0EMP5bDDDosq8JCSksKRRx7J7Nmz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9ddQ3m7q7ou0mV/96lf0jPQei5GDDz6Yt956i5SUFH70ox8FZ7ipi5lRUFAA1MwiAYLDc4499tha++Xm5vL+++9z8803M3/+fK655hp+97vf8corrzB69GguvfTSeh83NTWVt99+mwsuuIB//etf/PrXv2bx4sW8/fbb5Obmkp6e3ohnXdORRx7JH/7wB5YuXcrFF1/MOeecw4svvkjfvn35yU9+EpzO+PLLL2f69OlcfPHFvP/++8Fp1yX+RZthInEgP6T+yN57780nn3wCQFFREV999RWHH344X375JQALcnLYO7yB//4XqqqgniJIIiIiIuB9OerUqRNbtmyhU6dOwV+Ty8rKWLp0Kfvssw9fbd5MUWYmWbt3f79jeTksWAD+LBkiUreCgoI6i5BmZGSwbt26BttoaNrbadOm1ZnBMXLkSLZt20ZhYWFUNWH++c9/Rlz++9//nt///vcR14H3XG644YYGM2bqOh75+fm1nkNVVRVLly7lsMMOq7G8ruNRV9u//e1vIw59uueee+rtq7QPzZolR/YsoQGT6upqhg4diplRVVXFokWL6Ny5c3D91xUVuPB5yYuKvAsYERERkSgEri2ysrKCv6gGZsrp0qULmEXOMvnvf1uzmyLSzpWUlNRa9tBDD7Fjxw7Gjx/fBj2S9kIZJu1IaMBk69atHHLIIbz77rvs3r2boqIi3n//ffLz872Zc5yjZPhwMsKnC/vwQxg+vJV7LiIiIvEoEDBJSEigS5cuwTomW7duDQ7XWderF0OWLKm54zvvwM9+1trdFZF26uKLL6a0tJQjjjiC1NRUPvzwQ5599lkGDx7Mz/RZI82gDJN2JCsrq0Y6bF5eHr169Qref++99+jatWtw+/X9+9duRHVMREREJEqh2audO3cO1jHZtm1bsPDrykjXG3PnQh3DDEREGuu4445j9erV3HLLLUyePJk5c+bw05/+lPfee69VppeW9ksZJu2ImZGfn8/q1asBglMMr1q1ivLycoqKili5ciXOOcyMhbm5DApv5IMPWr3fIiIiEp9CAyahhV937NjB1q1bycvLY3VZGVUJCSRWh0xQuGYNLFsGg2pdiYiINNr555/P+eef39bdkHZIGSbtTPfu3YP/rqioIDMzk7y8PMrKyigqKqKwsDA4L/j8kOkAgxYvhrVrW6u7IiIiEsdCAyaBqYXB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qafWqGny5Zdf8sILL1BZWdnyT0hERET2OGlpaYwePTp4f/r06TWG8r733nv07NkTgHkhP7wEvfwybNvW0t0UERGpRQGTDqxXr14k+QGQ7du3c8ABB9C9e3f22msv1q5dS1VVFcuWLWPDhg1UVlZSmJPDlyEXOEF33AHffQd8HzQJHZ+8cOFCnnvuOSoqKlrleYmIiMieZeLEicFirxs3bqSqqio4FPi7774jPT0dgG/33pvi8ELz5eXwzDOt2l8RERFQwKRDS0pKok+fPsH76enpdOrUif79+9O3b182bNgAQGFhIevWraOyspJ3jzyydpZJeTn84hfg1ysxM04++WQOD5mOeMmSJTz11FOUlpa2/BMTERGRPUqvXr0YN24cAM451q5dS05ODgAVFRV8+eWXJCcnU5WYyBf771+7gYcfBg3xFRGRVqaASQcXOixn9erVwSBH//79yczMDNYfyc7O5osvvmB9VhYfhARCgt58E154IXjXzDjuuOMoKCgILlu1ahVPPvkku3fvbpknIyIiInuscePGBa87Nm7c6M3E5w/ZXbBgAd27dwdgXqSaad98A6+80mp9FRERAQVMOrzQgMnKlSs56KCDgmmxnTp1YuDAgcF/JyQk8Pnnn/PvAw+kpFu32o1Nngy7dgXvmhkFBQUcf/zxwWXr168PTlssIiIiHce+++7LkCFDyM7Opri4mOzsbKqqqqiurqakpITVq1eTmJjI5m7dWNW3b+0G/u//gtmsIiIirUEBkw6uT58+JCYmArBp0yZ2797NkUceGVy/adMmjj/+eBITE+nfvz9lZWX895tveOrQQ2s3tn493HRTrcWHH344p556anBKwW3btvHYY48Fh/yIiIhI+5eSksKIESMYNmwYCQkJbN68mf79+7N161acc8ybNy9Y/PWdMWNqNzBvHsyY0cq9FhGRjkwBkw4uJSUlOAsOwPz58xk9ejSdOnUCvOn/du3axbnnnkuvXr3IysqiurqaZwsLWbLffrUbvO8++OyzWotHjhzJ2WefHSwyW1RUxBNPPMGKFSta4mmJiIjIHuiggw4iIyODIUOGsGnTJvr374+ZsW3bNnbu3MmWLVswM5YMGsSa3r1rN3DzzcoyERGRVqOAibBfSOBjwYIFJCUlcdxxxwWXffzxx3Tq1ImLL76YAw44ILj8xpwcKlNSajZWXQ1nneVNNxxmn3324bzzzgtWyS8rK+Ppp59mwYIFMX5GIiIisifq06cPXbt2pUePHvTo0YOdO3cyZMgQCgsL2bFjB5988gm9e/cGM+Yec0ztBj7/HF57rfU7LiIiHZICJsLQoUODw3LWrVvH9u3bGTZsWLC+SXV1NTNnzqRr165cd9119OvXz9s2JYWXImWZLFsG554bsZp9//79ufDCC8nypwysrKzkhRde4KOPPmqhZyciIiJ7CjPjoIMOwswYPHgwiYmJDBkyhPT0dHbu3Mny5cuDxeG/GzyYtb161W5EWSYiItJKFDAR0tLSag3LMTOOP/74YN2RxYsXs2zZMjIyMvjVr35FX78Y2yPZ2azLz6/d6H/+413QRNC9e3cuuugi8vLyAG96wddff5033ngDpwsgERGRdu2AAw4gISEBMyMvL4+99tqLAQMGAF6ds9dee40uXbrUnWXyySfw+uut22kREemQFDARwKtcHxAYItOrV68aQ3DeeOMNqqurOeCAAxgzZgzDhw/HJSdz28iRlKam1m70//6vzuJsnTt35qKLLgoGXgA+/PBDXnzxxeAUgyIiItL+ZGVlMWTIEAASEhLo06cPxx57bHCWvsWLF/PZZ5/hnOPbIUNYHynLZMqUiJmsIiIisaSAiQBefZHwYTkAP/jBD0jx65Rs3LiRDz/8EDPjxBNPJC8vj0MOOYTVqak8GVLzpIaJE2Hx4oirMjIyOP/88xk2bFhw2fz583nyySeD6bgiIiLS/hx88MHBf3/xxRdMnDiRgw46KLjsgw8+YOXKlThgztFH127gv/+FRx5phZ6KiEhHpoCJAN6wnIEDB/7/9u47Tqr6Xvz/6zOzM9v7Llsou/SutFVAaYolEWxYIvZCvMaYX5J7k3uTaGJyk5hvcm+KJQZFrxE7RkRsqCiC9CIISFlYFrb3Oruz0z6/P87MOLvMVobdBd7Px+M8ZuacM+d8zod19+370/yffb1MYmNjmRUQqHz66aeUlZUxaNAgzj//fMLDw5k0aRIHhg1jXbBus/X1MH8+HD0a9L4Wi4Ubb7yRCy+80L+voKCA5557jsrKyhA9nRBCCCH6k5EjRzJo0CAA3G43mzdv5i9/+QuZ3t4kTqeTPXv2cPjwYQ6OGkVJevrJF/nJT6CwsDeLLYQQ4hwjCRPhF7hazv79+/3vZ86cacxYjxHUvPXWW7hcLubPn4/VakUpRUJCArZ//3fyg00CW1iInjcPjh0Lel+TycSVV17Zas6U6upqnnvuOY4fPx7CJxRCCCFEf6CUarUi3969e3G73fz6178mOjoagNraWgoLCzlw8CAfXnrpyRdpaIB/+zeZAFYIIcRpIwkT4dfesByz2cx1111HWFgYYAzNWbduHbGxscyePdv//X1ff03Se+/RFGSssSoowDV7NuTnB723UooZM2Zw8803Y7FYAGhububFF19kz549oXxMIYQQQvQDQ4YMaTUs96OPPuKSSy5hwYIFREVFobWmoqKC0tJS3qqrY/t55518kffeg1df7cVSCyGEOJdIwkT4tTcsByAlJYXLLrvM/3njxo2cOHGC6dOnk5iYCBgJjnV79hD12We4Bww46fphhYU0TZ9Oy+HD7ZZhzJgxrZYddrvdrFy5krVr18oKOkIIIcRZZv78+ZhMRjian5/PkSNHePDBB8nOziY2Nha73U5LSwsNDQ08lpxMvTc+aOUHP4CKil4uuRBCiHOBJExEK4HDcgITJgAXXHCBP6GitWblypW43W6uuOIK/zm7du3ikNaYP/8cnZZ20vWjyspwTptG7ssvt5sAyczM5L777mNAQNJlw4YNvPHGGzgcjlN6PiGEEEL0H8nJyUybNs3/+eOPP2bQoEEsWrSIpKQkkpKSqKiowG63U+3x8Cfv8sOtVFUZSRMhhBAixCRhIloZPXq0f1hOUVER5eXl/mNKKa655hoiIiIAqKmpYdWqVYwaNarVssTvvPMOtsGDUZ99BkF6msQ0NJB91118/sADlJWVBS1HQkIC9957r3/ZQYADBw7wf//3f9TX14fkWYUQQgjR9+bMmUN4eDgAlZWV7Nq1i1tvvZWsrCzi4uJITU2lsrISh8PBhuRk1qWmnnyR116DJ57o5ZILIYQ420nCRLQSGRnJqFGj/J83bdrU6nh8fDxXXXWV//PXX3/N+vXrWbBgAbGxsQDYbDbeeecd9Jgx8OmnECSwsbhczF26lIM338zqVauCLiMcHh7OLbfcwvTp0/37SkpKeOaZZygoKDjlZxVCCCFE34uOjubiiy/2f/74449pamriF7/4BZGRkURGRjJgwAAqKyvxeDz8bcQI6r3znbXywx8ac5oIIYQQISIJE3GSmTNn+t9/9dVX1NXVtTo+ceLEVssAr1u3jvz8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\n",
      "text/plain": [
       "<Figure size 1296x432 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "run_st_models_and_plot(\n",
    "    X,\n",
    "    y,\n",
    "    Ls=[0.001, 0.01],\n",
    "    eps=eps,\n",
    "    prefix=st_prefix,\n",
    "    repeats=st_repeats,\n",
    "    rew_iters=st_rew_iters,\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6e891c47",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "jupytext": {
   "formats": "ipynb,py:hydrogen"
  },
  "kernelspec": {
   "display_name": "Python (convex_nn_1.1.15)",
   "language": "python",
   "name": "convex_nn_1.1.15"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
