{
 "cells": [
  {
   "cell_type": "code",
   "id": "initial_id",
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.154718Z",
     "start_time": "2024-09-16T17:01:11.148770Z"
    }
   },
   "source": [
    "import numpy as np\n",
    "from learners import MetaLearner\n",
    "from utilities import *\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "from itertools import product"
   ],
   "outputs": [],
   "execution_count": 123
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.184061Z",
     "start_time": "2024-09-16T17:01:11.181393Z"
    }
   },
   "cell_type": "code",
   "source": "rng = np.random.default_rng()",
   "id": "8056635bf42dee63",
   "outputs": [],
   "execution_count": 124
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.193888Z",
     "start_time": "2024-09-16T17:01:11.191942Z"
    }
   },
   "cell_type": "code",
   "source": [
    "dims_list = [10]\n",
    "num_tasks_list = [3]\n",
    "num_samples_list = [5000]\n",
    "post_sample_num_list = [100]\n",
    "low_rank_dim_list = [1]\n",
    "sigma_list = [0.3]\n",
    "ptf = True"
   ],
   "id": "4734a589e0736d0",
   "outputs": [],
   "execution_count": 125
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.196771Z",
     "start_time": "2024-09-16T17:01:11.194841Z"
    }
   },
   "cell_type": "code",
   "source": [
    "max_dim = max(dims_list)\n",
    "max_num_tasks = max(num_tasks_list)\n",
    "max_num_samples = max(num_samples_list)\n",
    "max_low_rank_dim = max(low_rank_dim_list)"
   ],
   "id": "38daaf9a0bec61d1",
   "outputs": [],
   "execution_count": 126
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.199004Z",
     "start_time": "2024-09-16T17:01:11.197584Z"
    }
   },
   "cell_type": "code",
   "source": [
    "inner_step_size = 0.003\n",
    "outer_step_size = 0.03"
   ],
   "id": "14ea88ddf61f9e13",
   "outputs": [],
   "execution_count": 127
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.210185Z",
     "start_time": "2024-09-16T17:01:11.207663Z"
    }
   },
   "cell_type": "code",
   "source": [
    "A_star = rng.normal(0, 1, size=(1, max_dim, max_dim))\n",
    "A_star = (A_star + A_star.transpose((0, 2, 1))) / 2\n",
    "U_star = rng.normal(0, 1, size=(max_num_tasks, max_dim, max_low_rank_dim))\n",
    "test_U_star = rng.normal(0, 1, size=(1, max_dim, max_low_rank_dim))"
   ],
   "id": "715863456a9785bf",
   "outputs": [],
   "execution_count": 128
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.212685Z",
     "start_time": "2024-09-16T17:01:11.210994Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def compute_A_loss(A_star, A, dim):\n",
    "    return np.sum(np.square(A_star.reshape(dim, dim) - A))\n",
    "\n",
    "\n",
    "def compute_U_loss(U_star, U):\n",
    "    return np.sum(np.square(mat_stack_op(U_star, U_star) - mat_stack_op(U, U)))"
   ],
   "id": "4278cf0f4d84bc5",
   "outputs": [],
   "execution_count": 129
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.215099Z",
     "start_time": "2024-09-16T17:01:11.213447Z"
    }
   },
   "cell_type": "code",
   "source": [
    "num_inner_steps = 10\n",
    "num_outer_steps = 3000\n",
    "final_num_steps = 3000"
   ],
   "id": "5e7faa3b65846b9f",
   "outputs": [],
   "execution_count": 130
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.238670Z",
     "start_time": "2024-09-16T17:01:11.236715Z"
    }
   },
   "cell_type": "code",
   "source": [
    "prods = product(dims_list, num_tasks_list, num_samples_list, low_rank_dim_list,\n",
    "                sigma_list)\n",
    "enum = product(range(len(dims_list)), range(len(num_tasks_list)),\n",
    "               range(len(num_samples_list)),\n",
    "               range(len(low_rank_dim_list)), range(len(sigma_list)))"
   ],
   "id": "f0f2373b12846986",
   "outputs": [],
   "execution_count": 131
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:11.242391Z",
     "start_time": "2024-09-16T17:01:11.239846Z"
    }
   },
   "cell_type": "code",
   "source": [
    "losses = np.zeros(((len(dims_list)), (len(num_tasks_list)), (len(num_samples_list)), (len(low_rank_dim_list)),\n",
    "                   (len(sigma_list)), num_outer_steps + 1))\n",
    "A_losses = np.zeros_like(losses)\n",
    "A_losses_ptf = np.zeros_like(losses)\n",
    "U_losses = np.zeros_like(losses)\n",
    "post_loss = np.zeros(((len(dims_list)), (len(num_tasks_list)), (len(num_samples_list)), (len(low_rank_dim_list)),\n",
    "                      (len(sigma_list)), len(post_sample_num_list), final_num_steps + 1))\n",
    "losses_ptf = np.zeros_like(losses)\n",
    "post_ptf_loss = np.zeros_like(post_loss)"
   ],
   "id": "91413bf3bd8dbef2",
   "outputs": [],
   "execution_count": 132
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:20.245416Z",
     "start_time": "2024-09-16T17:01:11.243100Z"
    }
   },
   "cell_type": "code",
   "source": [
    "for prod, counts in zip(prods, enum):\n",
    "    dim, num_tasks, num_samples, low_rank_dim, sigma = prod\n",
    "    num_samples_per_task = num_samples // num_tasks\n",
    "    tasks = A_star[:, :dim, :dim] + mmt(U_star[:num_tasks, :dim, :low_rank_dim])\n",
    "    learner = MetaLearner(dim, num_samples_per_task, low_rank_dim, num_tasks, tasks, sigma, inner_step_size,\n",
    "                          outer_step_size)\n",
    "    losses[*counts, 0] = learner.true_loss()\n",
    "    A_losses[*counts, 0] = compute_A_loss(A_star[:, :dim, :dim], learner.A, dim)\n",
    "    U_losses[*counts, 0] = compute_U_loss(U_star[:num_tasks, :dim, :low_rank_dim], learner.U)\n",
    "    print(dim, num_tasks, num_samples, low_rank_dim, sigma)\n",
    "    for i in tqdm(range(num_outer_steps)):\n",
    "        for j in range(num_inner_steps):\n",
    "            learner.inner_gradient_step()\n",
    "        learner.outer_gradient_step()\n",
    "        losses[*counts, i + 1] = learner.true_loss()\n",
    "        A_losses[*counts, i + 1] = compute_A_loss(A_star[:, :dim, :dim], learner.A, dim)\n",
    "        U_losses[*counts, i + 1] = compute_U_loss(U_star[:num_tasks, :dim, :low_rank_dim], learner.U)\n",
    "\n",
    "    # PTF pretrain\n",
    "    if ptf:\n",
    "        data = (np.concatenate([learner.X[i] for i in range(num_tasks)], axis=-1),\n",
    "                np.concatenate([learner.Y[i] for i in range(num_tasks)], axis=-1))\n",
    "        data = (data[0].reshape(1, *data[0].shape), data[1].reshape(1, *data[1].shape))\n",
    "        ptf_base_learner = MetaLearner(dim, num_samples_per_task, low_rank_dim, num_tasks, tasks, sigma, inner_step_size,\n",
    "                                       outer_step_size, data=data)\n",
    "        for i in tqdm(range(num_outer_steps)):\n",
    "            ptf_base_learner.outer_gradient_step()\n",
    "            losses_ptf[*counts, i + 1] = ptf_base_learner.true_loss()\n",
    "\n",
    "    # Test run\n",
    "    test_tasks = A_star[:, :dim, :dim] + mmt(test_U_star[:, :dim, :low_rank_dim])\n",
    "\n",
    "    # print('T=',num_tasks)\n",
    "    for j in range(len(post_sample_num_list)):\n",
    "        new_learner = learner.detach(test_tasks, post_sample_num_list[j], new_learning_rate=0.005)\n",
    "        new_learner.symmetric = False\n",
    "        post_loss[*counts, j, 0] = new_learner.true_loss()\n",
    "        for i in tqdm(range(final_num_steps)):\n",
    "            new_learner.inner_gradient_step()\n",
    "            post_loss[*counts, j, i + 1] = new_learner.true_loss()\n",
    "        if ptf:\n",
    "            ft_data = (new_learner.X, new_learner.Y)\n",
    "            new_ptf_learner = ptf_base_learner.detach(test_tasks, post_sample_num_list[j], new_learning_rate=0.005,\n",
    "                                                      data=ft_data)\n",
    "            post_ptf_loss[*counts, j, 0] = new_ptf_learner.true_loss()\n",
    "            for i in tqdm(range(final_num_steps)):\n",
    "                new_ptf_learner.inner_gradient_step()\n",
    "                post_ptf_loss[*counts, j, i + 1] = new_ptf_learner.true_loss()"
   ],
   "id": "ec9cdb4999773dce",
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "10 3 5000 1 0.3\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3000/3000 [00:04<00:00, 624.03it/s]\n",
      "100%|██████████| 3000/3000 [00:04<00:00, 747.98it/s]\n",
      "100%|██████████| 3000/3000 [00:00<00:00, 38824.52it/s]\n",
      "100%|██████████| 3000/3000 [00:00<00:00, 33122.43it/s]\n"
     ]
    }
   ],
   "execution_count": 133
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:20.256369Z",
     "start_time": "2024-09-16T17:01:20.248837Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def string_producer(dim, num_tasks, num_samples, low_rank_dim, sigma):\n",
    "    return f'd={dim}'"
   ],
   "id": "7fee1f20d8ba216e",
   "outputs": [],
   "execution_count": 134
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:04:20.721071Z",
     "start_time": "2024-09-16T17:04:20.531943Z"
    }
   },
   "cell_type": "code",
   "source": [
    "end = 1000\n",
    "prods = product(dims_list, num_tasks_list, num_samples_list, low_rank_dim_list, sigma_list)\n",
    "enum = product(range(len(dims_list)), range(len(num_tasks_list)), range(len(num_samples_list)),\n",
    "               range(len(low_rank_dim_list)), range(len(sigma_list)))\n",
    "plt.figure('Losses')\n",
    "plt.title('Pretraining Loss')\n",
    "plt.xlabel('Iteration')\n",
    "plt.ylabel('Loss')\n",
    "for prod, counts in zip(prods, enum):\n",
    "    dim, num_tasks, num_samples, low_rank_dim, sigma = prod\n",
    "    plt.semilogy(losses[*counts, :end], label=string_producer(dim, num_tasks, num_samples, low_rank_dim, sigma))\n",
    "    plt.legend()\n",
    "    plt.savefig('./images/losses.png')\n",
    "plt.show()"
   ],
   "id": "ada97a44fac0a6",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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dDoMGDAAb7zxBgCgX79+OHHiBNasWYNZs2bpj+O9bpuNGzfiiy++wFdffYVevXohJSUFixYtgre3N2bPnq0/jvfZ8AxxT692vCHuO7vGOpirqyvkcnmTBFtQUNAkMdO1Pf744/jpp5+wc+dO+Pr66rd7enoCwDXvsaenJ2pqanDp0qVmj7F0SUlJKCgoQFhYGBQKBRQKBXbv3o333nsPCoVCf594n9vOy8sLwcHBjbb17NkTmZmZAPjPtKE888wzeP7553H33Xejd+/emDlzJp588klER0cD4H1uD4a6p56ensjPz29y/osXL7b5vjMIdTClUomwsDDEx8c32h4fH49hw4ZJVJVpEUURjz32GDZt2oTff/8dgYGBjfYHBgbC09Oz0T2uqanB7t279fc4LCwMVlZWjY7Jzc3F8ePH+fdwxdixY3Hs2DGkpKToXwMGDMB9992HlJQUdOnShffZQIYPH95kCYi0tDR07twZAP+ZNpSqqirIZI1/7cnlcv30ed5nwzPUPR06dChKS0tx6NAh/TF//PEHSktL237f2zTUmlqlYfr8xx9/LKampoqLFi0S7ezsxPPnz0tdmkmYP3++qFarxV27dom5ubn6V1VVlf6YN998U1Sr1eKmTZvEY8eOiffcc89Vp2v6+vqKv/32m3jkyBFxzJgxFj0FtiX+OWtMFHmfDeXQoUOiQqEQX3/9dfH06dPil19+Kdra2opffPGF/hje67abPXu26OPjo58+v2nTJtHV1VV89tln9cfwPt+48vJyMTk5WUxOThYBiCtWrBCTk5P1S8IY6p7ecsstYp8+fcQDBw6IBw4cEHv37s3p86YsJiZG7Ny5s6hUKsX+/fvrp37T9QG46uvTTz/VH6PT6cSXXnpJ9PT0FFUqlThq1Cjx2LFjjc5z+fJl8bHHHhOdnZ1FGxsbcfLkyWJmZmYHfxvT8u8gxPtsOP/73//EkJAQUaVSiUFBQeK6desa7ee9bruysjJx4cKFor+/v2htbS126dJFXLp0qajRaPTH8D7fuJ07d171v8mzZ88WRdFw97SoqEi87777RAcHB9HBwUG87777xEuXLrW5fkEURbFtbUpEREREpoljhIiIiMhiMQgRERGRxWIQIiIiIovFIEREREQWi0GIiIiILBaDEBEREVksBiEiIiKyWAxCRETXEBAQgFWrVkldBhG1EwYhIjIac+bMwbRp0wAAo0ePxqJFizrs2uvXr4eTk1OT7YmJiXjkkUc6rA4i6lgKqQsgImpPNTU1UCqVrf68m5ubAashImPDFiEiMjpz5szB7t278e6770IQBAiCgPPnzwMAUlNTMXHiRNjb28PDwwMzZ85EYWGh/rOjR4/GY489hsWLF8PV1RXjxo0DAKxYsQK9e/eGnZ0d/Pz8sGDBAlRUVAAAdu3ahQceeAClpaX667388ssAmnaNZWZmYurUqbC3t4ejoyPuvPNO5Ofn6/e//PLLCA0Nxeeff46AgACo1WrcfffdKC8vb9+bRkStwiBEREbn3XffxdChQ/Hwww8jNzcXubm58PPzQ25uLsLDwxEaGorDhw/j119/RX5+Pu68885Gn//ss8+gUCiwf/9+fPDBBwAAmUyG9957D8ePH8dnn32G33//Hc8++ywAYNiwYVi1ahUcHR3113v66aeb1CWKIqZNm4bi4mLs3r0b8fHxOHv2LO66665Gx509exZxcXHYsmULtmzZgt27d+PNN99sp7tFRG3BrjEiMjpqtRpKpRK2trbw9PTUb1+zZg369++PN954Q7/tk08+gZ+fH9LS0tC9e3cAQNeuXbF8+fJG5/zneKPAwEC8+uqrmD9/PmJjY6FUKqFWqyEIQqPr/dtvv/2Go0ePIj09HX5+fgCAzz//HL169UJiYiIGDhwIANDpdFi/fj0cHBwAADNnzsSOHTvw+uuvt+3GEJHBsUWIiExGUlISdu7cCXt7e/0rKCgIQH0rTIMBAwY0+ezOnTsxbtw4+Pj4wMHBAbNmzUJRUREqKytbfP2TJ0/Cz89PH4IAIDg4GE5OTjh58qR+W0BAgD4EAYCXlxcKCgpu6LsSUcdgixARmQydTocpU6bgrbfearLPy8tL/2c7O7tG+zIyMjBx4kTMmzcPr776KpydnbFv3z7MnTsXtbW1Lb6+KIoQBOG6262srBrtFwQBOp2uxdchoo7DIERERkmpVEKr1Tba1r9/f/zwww8ICAiAQtHy/3wdPnwYdXV1eOeddyCT1TeEf/vtt9e93r8FBwcjMzMTWVlZ+lah1NRUlJaWomfPni2uh4iMB7vGiMgoBQQE4I8//sD58+dRWFgInU6HqKgoFBcX45577sGhQ4dw7tw5bN++HQ8++OA1Q8xNN92Euro6vP/++zh37hw+//xzrF27tsn1KioqsGPHDhQWFqKqqqrJeW6++Wb06dMH9913H44cOYJDhw5h1qxZCA8Pv2p3HBEZPwYhIjJKTz/9NORyOYKDg+Hm5obMzEx4e3tj//790Gq1GD9+PEJCQrBw4UKo1Wp9S8/VhIaGYsWKFXjrrbcQEhKCL7/8EtHR0Y2OGTZsGObNm4e77roLbm5uTQZbA/VdXHFxcejUqRNGjRqFm2++GV26dMHGjRsN/v2JqGMIoiiKUhdBREREJAW2CBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgsFoMQERERWSwGISIiIrJYDEJERERksRiEiIiIyGIxCBEREZHFYhAiIiIii8UgRERERBaLQYiIiIgs1v8DY7Yrb7vsMmcAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 143
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:20.499248Z",
     "start_time": "2024-09-16T17:01:20.497624Z"
    }
   },
   "cell_type": "code",
   "source": [
    "def string_producer_post(dim, num_tasks, num_samples, low_rank_dim, sigma, post_sample_num):\n",
    "    return f'N\\'={post_sample_num}'"
   ],
   "id": "99aabcb00bcfba76",
   "outputs": [],
   "execution_count": 136
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:04:23.969932Z",
     "start_time": "2024-09-16T17:04:23.783878Z"
    }
   },
   "cell_type": "code",
   "source": [
    "end = 500\n",
    "prods = product(dims_list, num_tasks_list, num_samples_list, low_rank_dim_list, sigma_list)\n",
    "enum = product(range(len(dims_list)), range(len(num_tasks_list)), range(len(num_samples_list)),\n",
    "               range(len(low_rank_dim_list)), range(len(sigma_list)))\n",
    "plt.figure('Losses on New Task')\n",
    "plt.title('Loss on New Task')\n",
    "plt.xlabel('Iteration')\n",
    "plt.ylabel('Loss')\n",
    "for prod, counts in zip(prods, enum):\n",
    "    dim, num_tasks, num_samples, low_rank_dim, sigma = prod\n",
    "    for j in range(len(post_sample_num_list)):\n",
    "        plt.semilogy(post_loss[*counts, j, :end],\n",
    "                     label=string_producer_post(dim, num_tasks, num_samples, low_rank_dim, sigma,\n",
    "                                                post_sample_num_list[j]))\n",
    "plt.legend()\n",
    "plt.savefig('./images/losses_new_task.png')\n",
    "plt.show()"
   ],
   "id": "40f2a8586f5ec3d",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAHFCAYAAAAe+pb9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAABQNklEQVR4nO3deVxU5f4H8M+ZlX3YlF1BxQVBVFzSckFcMpfMMluuadliaabWbfN29ba59LtmJVpdLdN7LSvT2zVLMfesRJRUcBcFBERAdtlmnt8fwCQCgjBwZvm8X795MXPOmXO+c6af87nP85znSEIIASIiIiIbpJC7ACIiIiK5MAgRERGRzWIQIiIiIpvFIEREREQ2i0GIiIiIbBaDEBEREdksBiEiIiKyWQxCREREZLMYhIiIiMhmMQgRWbm1a9dCkiQcPnxY7lLMwrRp0yBJErp37w69Xl9rvSRJmDVrlgyVVaqur6HHtGnTTHY8Jycnk+yLyBKp5C6AiEgOiYmJWLt2LaZPny53KTW88cYbmDFjhvH1kSNHMHPmTLz77ruIjIw0Lm/Tpo0c5RFZHQYhIrI5jo6O6N27NxYsWIBHHnkE9vb2cpdk1LFjR3Ts2NH4uqSkBAAQHByMO+64Q66yiKwWu8aICABw4MABREVFwdnZGQ4ODhg4cCB++OGHGtsUFxfjpZdeQlBQEOzs7ODu7o4+ffrgyy+/NG5z4cIFPPTQQ/D19YVWq4WXlxeioqIQHx/fYA3ff/89BgwYAAcHBzg7O2PEiBH49ddfa2yzcOFCSJKEhIQEPPzww9DpdPDy8sITTzyBvLy8Rn/eJUuW4PLly/jggw8a3DY/P9/4uTUaDfz8/DBnzhwUFRUZt5k0aRK6d+9e433jxo2DJEn45ptvjMuOHDkCSZLwv//9r9G13uzw4cN46KGHEBgYCHt7ewQGBuLhhx/GpUuXamzXmO+rLr/88gs8PT0xduzYGp+RyBoxCBER9u7di2HDhiEvLw9r1qzBl19+CWdnZ4wbNw4bN240bjdv3jysWrUKs2fPxk8//YT169dj0qRJyM7ONm5zzz33IC4uDkuXLkVMTAxWrVqFXr16ITc395Y1bNiwAffeey9cXFzw5ZdfYs2aNbh27RqGDh2KAwcO1Nr+/vvvR+fOnbFp0ya8+uqr2LBhA+bOndvozzxgwADcd999WLJkCXJycurdrri4GEOGDMEXX3yB2bNn48cff8Qrr7yCtWvXYvz48RBCAACGDx+OxMREpKenAwAqKiqwd+9e2NvbIyYmxri/nTt3QqVSYejQoY2u9WYXL15Ely5dsHz5cmzfvh1LlixBeno6+vbti6ysLON2jfm+bvb1118jKioKDz74IP773//C0dGxyXUSWQRBRFbt888/FwBEbGxsvdvccccdom3btqKgoMC4rKKiQoSGhgp/f39hMBiEEEKEhoaKCRMm1LufrKwsAUAsX778tmrU6/XC19dXhIWFCb1eb1xeUFAg2rZtKwYOHGhctmDBAgFALF26tMY+nnvuOWFnZ2estT5Tp04Vjo6OQgghTp06JZRKpXjxxReN6wGImTNnGl8vWrRIKBSKWufv22+/FQDEtm3bhBBCnDt3TgAQ69atE0IIceDAAQFAvPzyyyIoKMj4vhEjRtT4PA3ZvXu3ACC++eaberepqKgQhYWFwtHRUXzwwQfG5Q19X0LUPB+LFy8WSqVSLFmypNH1EVk6tggR2biioiL8/vvveOCBB2pcPaRUKjFlyhSkpqbi9OnTAIB+/frhxx9/xKuvvoo9e/bg+vXrNfbl7u6Ojh074r333sOyZctw9OhRGAyGBms4ffo00tLSMGXKFCgUf/6z5OTkhPvvvx+//fYbiouLa7xn/PjxNV736NEDJSUlyMzMbPRn79KlC6ZPn44VK1YgOTm5zm22bt2K0NBQ9OzZExUVFcbHqFGjIEkS9uzZA6BybE9gYCB27twJAIiJiUFYWBj+8pe/ICkpCefPn0dpaSkOHDiA4cOHN7rGuhQWFuKVV15Bp06doFKpoFKp4OTkhKKiIpw8edK4XUPfVzUhBJ555hksWLAAGzZswMsvv9ys+ogsCYMQkY27du0ahBDw8fGptc7X1xcAjF0pH374IV555RVs2bIFkZGRcHd3x4QJE3D27FkAlZee//zzzxg1ahSWLl2K3r17o02bNpg9ezYKCgrqraF6//XVYDAYcO3atRrLPTw8arzWarUAUO+PfX0WLlwIpVKJN954o871V65cwbFjx6BWq2s8nJ2dIYSo0RUVFRWFn3/+GUBlF9iIESMQFhYGLy8v7Ny5E7/88guuX7/e7CD0yCOPYMWKFXjyySexfft2HDp0CLGxsWjTpk2Nz9/Q91WtrKwMGzduRPfu3TF69Ohm1UZkaRiEiGycm5sbFAqFcWzLjdLS0gAAnp6eACqvtvrHP/6BU6dOISMjA6tWrcJvv/2GcePGGd/Tvn17rFmzBhkZGTh9+jTmzp2LlStX4q9//Wu9NVSHmvpqUCgUcHNza9bnrI+Pjw/mzJmDf//73zh27Fit9Z6enggLC0NsbGydjxsDVFRUFC5fvoxDhw7h999/x4gRIwAAw4YNQ0xMDHbu3AknJ6dmXf2Vl5eHrVu34uWXX8arr76KqKgo9O3bF2FhYbXGOjXm+wIqQ+Tu3buRkpKC4cOH1wqdRNaMQYjIxjk6OqJ///747rvvarQmGAwG/Pvf/4a/vz86d+5c631eXl6YNm0aHn74YZw+fbpW1xUAdO7cGX/7298QFhaGI0eO1FtDly5d4Ofnhw0bNhgHHwOV3XabNm0yXknWUl555RW4u7vj1VdfrbVu7NixOH/+PDw8PNCnT59aj8DAQOO2UVFRkCQJb7zxBhQKBQYPHgygciD17t27ERMTg8GDB0OtVje5VkmSIIQwtoBVW716dZ0TRFZr6Pvq1asX9u7di9TUVAwdOvS2uhiJLBnnESKyEbt27cLFixdrLb/nnnuwaNEijBgxApGRkXjppZeg0WiwcuVKnDhxAl9++SUkSQIA9O/fH2PHjkWPHj3g5uaGkydPYv369cagcuzYMcyaNQuTJk1CcHAwNBoNdu3ahWPHjtUZMqopFAosXboUjz76KMaOHYtnnnkGpaWleO+995Cbm4vFixe31GkBALi4uGD+/Pl1XnU2Z84cbNq0CYMHD8bcuXPRo0cPGAwGJCcnY8eOHXjxxRfRv39/AEDbtm0RGhqKHTt2IDIy0hjehg8fjpycHOTk5GDZsmXNrnXw4MF477334OnpicDAQOzduxdr1qyBq6trjW0b+r5u1q1bN+zfvx/Dhw/H4MGDsXPnTvj7+zerXiKzJ+tQbSJqcdVXjdX3SEpKEkIIsX//fjFs2DDh6Ogo7O3txR133CH+97//1djXq6++Kvr06SPc3NyEVqsVHTp0EHPnzhVZWVlCCCGuXLkipk2bJrp27SocHR2Fk5OT6NGjh3j//fdFRUVFg7Vu2bJF9O/fX9jZ2QlHR0cRFRUlfvnllxrbVF81dvXq1To/Z/Xnqc+NV0ndqLS0VAQFBdW6akwIIQoLC8Xf/vY30aVLF6HRaIROpxNhYWFi7ty5IiMjo8a2c+fOFQDEO++8U2N5cHCwACCOHTvW0Gmooa6rxlJTU8X9998v3NzchLOzs7j77rvFiRMnRPv27cXUqVON2zX0fdV3PlJTU0XXrl1FYGCgOH/+/G3VS2RpJCFuaIcmIiIisiEcI0REREQ2i0GIiIiIbBaDEBEREdksBiEiIiKyWQxCREREZLMYhIiIiMhmcULFBhgMBqSlpcHZ2dk4qRwRERGZNyEECgoK4OvrW+NmzjdjEGpAWloaAgIC5C6DiIiImiAlJeWWM6QzCDXA2dkZQOWJdHFxkbkaIiIiaoz8/HwEBAQYf8frwyBUj+joaERHRxtvYuji4sIgREREZGEaGtbCW2w0ID8/HzqdDnl5eQxCREREFqKxv9+8aoyIiIhsFoMQERER2SyOESIiImokvV6P8vJyucsgAGq1Gkqlstn7YRAiIiJqgBACGRkZyM3NlbsUuoGrqyu8vb2bNc8fgxAREVEDqkNQ27Zt4eDgwAl2ZSaEQHFxMTIzMwEAPj4+Td4Xg1A9br58noiIbJNerzeGIA8PD7nLoSr29vYAgMzMTLRt27bJ3WQcLF2PmTNnIjExEbGxsXKXQkREMqoeE+Tg4CBzJXSz6u+kOeO2GISIiIgagd1h5scU3wmDEBEREdksBiEiIiKyWQxCREREVmratGmQJAmLFy+usXzLli3GbqU9e/YgMDCwycfYt28fxo0bB19fX0iShC1bttTaRgiBhQsXwtfXF/b29hg6dCgSEhJqbFNaWornn38enp6ecHR0xPjx45GamtrkuhqLQUgml3Ov43LudWTmlyCnqAz5JeW4XqZHud4A3v6NiIhMxc7ODkuWLMG1a9daZP9FRUUIDw/HihUr6t1m6dKlWLZsGVasWIHY2Fh4e3tjxIgRKCgoMG4zZ84cbN68GV999RUOHDiAwsJCjB07tsWv3ubl8zJ58ONfcTn3er3rVQoJKqUEtUIBlVKCSqmAWlH5t+7lEtRKRdX7FFArJaiqttGqFHDUqOCoVcHZTgUnrQpOdlWvtSp4OGnh6aSBk1bFwYBERFZm+PDhOHfuHBYtWoSlS5eafP+jR4/G6NGj610vhMDy5csxf/58TJw4EQDwxRdfwMvLCxs2bMAzzzyDvLw8rFmzBuvXr8fw4cMBAP/+978REBCAnTt3YtSoUSavuxqDkExUSgkapQLlBgPqagCqMAhUGARKYGi1mrQqBTydtPB01sLHxQ7tPRzQ3sOx6q8D/FztGZSIiFD54369vPXnmbNXK2/732GlUol3330XjzzyCGbPng1/f/9bbr9///5bBhsAeP311/H666836vhJSUnIyMjAyJEjjcu0Wi2GDBmCgwcP4plnnkFcXBzKy8trbOPr64vQ0FAcPHiQQUgOLT2h4t6/Rhqf6w0C5XpDZfjRG1CuF6gwGFChv3F55bJyfeU2FdXvuXG5cX3NbcsqDCgsq0BhSQWKSitQWFqBgpI//2YXlqKoTI/SCoOxy+6POmp2tlMhxMcF3X11CA/QYUAHD7R1sWuR80NEZM6ul+sR8vftrX7cxDdHwUFz+z/d9913H3r27IkFCxZgzZo1NdYNHToUFy9eNL7u06cP4uPjb7k/d3f3Rh87IyMDAODl5VVjuZeXFy5dumTcRqPRwM3NrdY21e9vKQxC9Zg5cyZmzpyJ/Px86HS6Fj2WUiFBqWj+jeOa43qZHlmFpbhaWIqrBaVIy72OS9nFuJRdhEs5xUjJKUZBSQV+T8rB70k5xvd1auuEOzt6YFg3Lwzs6AG1ksPOiIjM0ZIlSzBs2DC8+OKLt9zO3t4enTp1Mvnxb27JEkI02LrVmG2ai0GIAAD2GiUC3B0Q4F73zKnlegPOZRbixOU8JKTl4/ClHCSk5eNcZiHOZRbii18vwc1BjbtDvfFQ33YID3Bt3Q9ARNSK7NVKJL7Zct01tzpuUw0ePBijRo3C66+/jmnTptW7nam7xry9vQFUtvrceE+wzMxMYyuRt7c3ysrKcO3atRqtQpmZmRg4cGCjjtNUDELUKGqlAt18XNDNxwWTqpblFpfhtwvZ2Hc2CzsSMpBVWIYvD6Xgy0MpCPfXYdqdgRjXwxcqthIRkZWRJKlJXVRyW7x4MXr27InOnTvXu42pu8aCgoLg7e2NmJgY9OrVCwBQVlaGvXv3YsmSJQCAiIgIqNVqxMTE4MEHHwQApKen48SJEy0ywPtGlvctktlwddDg7lAf3B3qgzfHd8fvSTnYFJeKrcfS8UdqHuZu/AMf7TqHeSM6455QHygUHGhNRCSnsLAwPProo/joo4/q3eZ2u8YKCwtx7tw54+ukpCTEx8fD3d0d7dq1gyRJmDNnDt59910EBwcjODgY7777LhwcHPDII48AAHQ6HaZPn44XX3wRHh4ecHd3x0svvYSwsDDjVWQthUGITEKlVODOTp64s5MnXh/TDV8dSsaaA0m4cLUIszYcRbj/BSya2AMhvi5yl0pEZNPeeustfP311ybb3+HDhxEZ+ecFQPPmzQMATJ06FWvXrgUAvPzyy7h+/Tqee+45XLt2Df3798eOHTvg7OxsfN/7778PlUqFBx98ENevX0dUVBTWrl3b5LvKN5YkOHvfLVUPls7Ly4OLC3/Eb0dBSTk+O3AR/9p/AYWlFVApJDwzpAOeHxYMu2b0cxMRtaaSkhIkJSUhKCgIdna8Utac3Oq7aezvNwdvUItxtlPjheHB2PXiENzd3RsVBoHo3edx/6qDuJRdJHd5REREDELU8tq62OHjKRH4+C+94e6oQUJaPsZ+dAB7TmfKXRoREdk4BiFqNXeH+uCH2Xchor0bCkoqMP2Lw/jqULLcZRERkQ1jEKJW5aOzx5dP3YGJvfygNwi8+t1x/GvfBbnLIiIiG8UgRK1Oo1Lgnw+G47mhHQEA72w7yTBERGaP1xaZH1N8JwxCJAtJkvDy3V3xQlQwgMow9PXhFJmrIiKqTa1WAwCKi4tlroRuVv2dVH9HTcF5hEhWc0d0RmmFAR/vPY/XvjuOts5aDO3SVu6yiIiMlEolXF1dkZlZeYGHg4NDi9//im5NCIHi4mJkZmbC1dW1WXMNMQjVo6XvPk9/euXuLriSX4LNRy/j+Q1H8d9Zd6JDGye5yyIiMqq+X1Z1GCLz4OrqavxumooTKjaAEyq2jrIKAx5d/RtiL15DZy8nbH7uTjhqmdOJyLzo9XqUl5fLXQahsjvsVi1Bjf39ZhBqAINQ68nML8GYjw7gakEp7uvlh/cn95S7JCIislCcWZosTlsXO6x8tDcUErD56GVsPZYmd0lERGTlGITIrPQNdMfMyMq7Hs/ffAIZeSUyV0RERNaMQYjMzuyoYPTw1yHvejn+/t8TcpdDRERWjEGIzI5aqcD/TQqHSiFhR+IVbE/IkLskIiKyUgxCZJY6eznj6cEdAAALv09AYWmFzBUREZE1YhAis/X8sGC0c3dAel4JPt5zXu5yiIjICjEIkdmy1ygxf0w3AMC/9l9AWu51mSsiIiJrwyBEZm1kiBf6BbmjtMKA97aflrscIiKyMgxCZNYkScIbY0IAVM4tlJCWJ3NFRERkTRiEyOyF+eswLtwXAPDBzrMyV0NERNaEQYgswgtRwVBIwI7EKzhxma1CRERkGgxCZBE6tXXC+KpWoeU7z8hcDRERWQsGIbIYs6tahXaezMSpjHy5yyEiIitgE0Hovvvug5ubGx544AG5S6Fm6NDGCaNDfQAAn+67IHM1RERkDWwiCM2ePRvr1q2TuwwygerZpr+PT8NlzitERETNZBNBKDIyEs7OznKXQSYQHuCKAR08UGEQ+OxAktzlEBGRhTP7ILRv3z6MGzcOvr6+kCQJW7ZsqbXNypUrERQUBDs7O0RERGD//v2tXyi1mqeHVLYKfX04BcVlvAcZERE1ndkHoaKiIoSHh2PFihV1rt+4cSPmzJmD+fPn4+jRoxg0aBBGjx6N5OTkVq6UWsuQ4DZo7+GAgpIKfB+fJnc5RERkwcw+CI0ePRpvv/02Jk6cWOf6ZcuWYfr06XjyySfRrVs3LF++HAEBAVi1alWTjldaWor8/PwaDzIvCoWEv/RvDwBY9+slCCFkroiIiCyV2QehWykrK0NcXBxGjhxZY/nIkSNx8ODBJu1z0aJF0Ol0xkdAQIApSiUTm9THH1qVAonp+TiSnCt3OUREZKEsOghlZWVBr9fDy8urxnIvLy9kZGQYX48aNQqTJk3Ctm3b4O/vj9jY2Hr3+dprryEvL8/4SElJabH6qelcHTTGCRb//dslmashIiJLpZK7AFOQJKnGayFEjWXbt29v9L60Wi20Wq3JaqOWM2VAe3wTl4ofjqXjb2O6wcOJ3xsREd0ei24R8vT0hFKprNH6AwCZmZm1WoluV3R0NEJCQtC3b99m7YdaTg9/V4T761CmN+DbuFS5yyEiIgtk0UFIo9EgIiICMTExNZbHxMRg4MCBzdr3zJkzkZiYeMtuNJLf5L7tAACbjqRy0DQREd02sw9ChYWFiI+PR3x8PAAgKSkJ8fHxxsvj582bh9WrV+Ozzz7DyZMnMXfuXCQnJ2PGjBkyVk2tZUwPH2hUCpy5UoiENF7hR0REt8fsxwgdPnwYkZGRxtfz5s0DAEydOhVr167F5MmTkZ2djTfffBPp6ekIDQ3Ftm3b0L59e7lKplaks1djZIgXth5Lx7dxqQj108ldEhERWRBJsD+hTtHR0YiOjoZer8eZM2eQl5cHFxcXucuiOuw+nYnHP4+Fu6MGv70WBY3K7Bs6iYioheXn50On0zX4+81fjHpwjJDlGNTJE22ctcgpKsOe05lyl0NERBaEQYgsnkqpwISelXMKbTrCq8eIiKjxGITIKtwf4Q8A2HUqE9eKymSuhoiILAWDEFmFrt4u6ObjgnK9wPaEjIbfQEREBAahenFCRcsztocPAOCH4+kyV0JERJaCQageHCxtecaEVQahg+ezkV1YKnM1RERkCRiEyGoEejoi1M8FeoPA9oQrcpdDREQWgEGIrMqYsMqrx344niZzJUREZAkYhMiqVHeP/Xo+G1nsHiMiogYwCNWDg6UtUzsPB/Tw18EggJ9O8OoxIiK6NQahenCwtOWqbhXaeozdY0REdGsMQmR17qkKQoeScji5IhER3RKDEFmdAHcHdPV2hkEAP5/ivceIiKh+DEJklUZ29wYAxCRynBAREdWPQageHCxt2UaGeAEA9p3JQkm5XuZqiIjIXDEI1YODpS1bd18X+Lna43q5HgfOZsldDhERmSkGIbJKkiRhRFWr0A52jxERUT0YhMhqVXeP/XwyE3qDkLkaIiIyRwxCZLX6BrlDZ69GdlEZjiRfk7scIiIyQwxCZLXUSgWiurYFAMQk8iasRERUG4MQWbWobpXdY7s5nxAREdWBQYis2l3BnlAqJJzNLERKTrHc5RARkZlhEKoH5xGyDjp7NSLauwEA9pxmqxAREdXEIFQPziNkPYZVjRPaxe4xIiK6CYMQWb3ILpVB6OD5bM4yTURENTAIkdXr7OUEX50dSisM+PVCttzlEBGRGWEQIqsnSRIiq7rHePUYERHdiEGIbEJ199iuU5kQgrNMExFRJQYhsgkDO3lAo1Ig9dp1nL9aKHc5RERkJhiEyCY4aFS4o4MHAGD3qasyV0NEROaCQYhsRmSXNgB4GT0REf2JQagenFDR+lSPE4q9mIOCknKZqyEiInPAIFQPTqhofQI9HRHk6YgKg8DB87yMnoiIGITIxgwO9gQA7D/LcUJERMQgRDZmUHDlOKH9Z7NkroSIiMwBgxDZlAEdPaBWSriUXYxL2UVyl0NERDJjECKb4qhVoXe7yrvR72OrEBGRzWMQIpszuHNl99i+MxwnRERk6xiEyOYMrhon9Ov5bJTrDTJXQ0REcmIQIpvT3dcFbg5qFJZWID4lV+5yiIhIRgxCZHMUCgl3BbN7jIiIGITIRlXPJ8QB00REto1BiGxS9XxCx1JzkVtcJnM1REQkFwYhskneOjt08XKGEMCBc2wVIiKyVQxC9eBNV63foOrbbZxhECIislUMQvXgTVet36DO1bfbuAohhMzVEBGRHBiEyGb1D3KHRqVAWl4Jzl8tlLscIiKSAYMQ2Sw7tRL9g9wBAPvYPUZEZJMYhMimDTJeRs/5hIiIbBGDENm06vuO/XYhG6UVepmrISKi1sYgRDati5cz2jprUVJuQNzFa3KXQ0RErYxBiGyaJEnGyRX3snuMiMjmMAiRzRvcmfMJERHZKgYhsnl3dqoMQonp+bhaUCpzNURE1JoYhMjmeTpp0d3XBQBw4By7x4iIbAmDEBH+vHqM3WNERLaFQYgIN84nlMXbbRAR2RAGISIAEe3dYK9WIquwFCfTC+Quh4iIWgmDEBEArUqJAR09AFTehJWIiGwDgxBRlerusf1nOU6IiMhWMAgRVameWPHQxRxcL+PtNoiIbIFNBKGtW7eiS5cuCA4OxurVq+Uuh8xUxzaO8HO1R1mFAb8nZctdDhERtQKrD0IVFRWYN28edu3ahSNHjmDJkiXIycmRuywyQ5W322D3GBGRLbH6IHTo0CF0794dfn5+cHZ2xj333IPt27fLXRaZqerusX1nOGCaiMgWmH0Q2rdvH8aNGwdfX19IkoQtW7bU2mblypUICgqCnZ0dIiIisH//fuO6tLQ0+Pn5GV/7+/vj8uXLrVE6WaA7O3lAIQFnMwuRnndd7nKIiKiFmX0QKioqQnh4OFasWFHn+o0bN2LOnDmYP38+jh49ikGDBmH06NFITk4GgDonx5Mkqd7jlZaWIj8/v8aDbIergwY9/F0BsHuMiMgWmH0QGj16NN5++21MnDixzvXLli3D9OnT8eSTT6Jbt25Yvnw5AgICsGrVKgCAn59fjRag1NRU+Pj41Hu8RYsWQafTGR8BAQGm/UBk9gZXzzLN7jEiIqtn9kHoVsrKyhAXF4eRI0fWWD5y5EgcPHgQANCvXz+cOHECly9fRkFBAbZt24ZRo0bVu8/XXnsNeXl5xkdKSkqLfgYyP4Oq7jt24FwW9AbeboOIyJqp5C6gObKysqDX6+Hl5VVjuZeXFzIyMgAAKpUK//znPxEZGQmDwYCXX34ZHh4e9e5Tq9VCq9W2aN1k3noGuMJZq0JucTlOXM5DeICr3CUREVELseggVO3mMT9CiBrLxo8fj/Hjx7d2WWSh1EoFBnT0wI7EK9h/9iqDEBGRFbPorjFPT08olUpj60+1zMzMWq1Etys6OhohISHo27dvs/ZDlqm6e2wfB0wTEVk1iw5CGo0GERERiImJqbE8JiYGAwcObNa+Z86cicTERMTGxjZrP2SZhlTNJ3Tk0jUUlJTLXA0REbUUs+8aKywsxLlz54yvk5KSEB8fD3d3d7Rr1w7z5s3DlClT0KdPHwwYMACffvopkpOTMWPGDBmrJkvXzsMB7T0ccCm7GL9dyMGIkOa1MBIRkXky+yB0+PBhREZGGl/PmzcPADB16lSsXbsWkydPRnZ2Nt58802kp6cjNDQU27ZtQ/v27eUqmazEoGBPXMpOxv6zVxmEiIislCTqmnGQEB0djejoaOj1epw5cwZ5eXlwcXGRuyxqRTsSMvD0+jgEejhgz18jG34DERGZjfz8fOh0ugZ/vy16jFBL4hghGtDRA0qFhIvZxUjOLpa7HCIiagEMQkT1cLZTo3c7VwDA/nOcZZqIyBoxCBHdwmDejZ6IyKoxCNWD8wgR8Od8Qr+cy0a53iBzNUREZGoMQvXgGCECgB5+Ong4alBYWoHYizlyl0NERCbGIER0CwqFhCFdKluF9pxm9xgRkbVhECJqQGSXtgCA3acyZa6EiIhMjUGIqAGDg9tAqZBwNrMQKTm8jJ6IyJowCNWDg6Wpms5BjYh2bgCAPafZKkREZE0YhOrBwdJ0o6FdK8cJ7eY4ISIiq8IgRNQI1eOEDp7PQkm5XuZqiIjIVBiEiBqhq7czfHR2KCk34NcL2XKXQ0REJsIgRNQIkiRhaFWr0B5ePUZEZDUYhIgaKbLLn+OEhBAyV0NERKbAIFQPXjVGN7uzkyc0SgWSc4px/mqR3OUQEZEJMAjVg1eN0c0ctSr07+AOANh16orM1RARkSkwCBHdhqiuleOEdiZynBARkTVgECK6DcNDvAAAhy/lIKeoTOZqiIiouRiEiG6Dv5sDQnxcYBDAzyfZPUZEZOkYhIhu04iqVqGYRAYhIiJLxyBEdJuqg9D+s5xlmojI0jEI1YOXz1N9uvu6wM/VHtfL9ThwNkvucoiIqBkYhOrBy+epPpIkYXi3yqvH2D1GRGTZGISImmBEiDcA4OdTV6A3cJZpIiJLxSBE1AT9O7jD2U6FrMIyxKdck7scIiJqIgYhoiZQKxWIrLoJ644Edo8REVkqBiGiJuJl9ERElo9BiKiJhnZpA41SgQtZRThzpUDucoiIqAkYhIiayNlOjbuCPQEA246ny1wNERE1BYMQUTPcE+YDgEGIiMhSMQjVgxMqUmOMCPGCWinhzJVCnMtk9xgRkaVhEKoHJ1SkxtDZqzEouA0A4IdjGTJXQ0REt4tBiKiZ2D1GRGS5GISImqm6e+z0lQKcyyyUuxwiIroNDEJEzaSzV+OuTrx6jIjIEjEIEZkAu8eIiCxTk4JQSkoKUlNTja8PHTqEOXPm4NNPPzVZYUSWZGSIN9RKCacyCnD+KrvHiIgsRZOC0COPPILdu3cDADIyMjBixAgcOnQIr7/+Ot58802TFkhkCXQOatxZ1T32wzG2ChERWYomBaETJ06gX79+AICvv/4aoaGhOHjwIDZs2IC1a9easj4iizGmqnvs+z/SIISQuRoiImqMJgWh8vJyaLVaAMDOnTsxfvx4AEDXrl2Rns7/NUy2aVSoN7QqBc5lFiIhLV/ucoiIqBGaFIS6d++Ojz/+GPv370dMTAzuvvtuAEBaWho8PDxMWiCRpXCxU2N41R3ptxy9LHM1RETUGE0KQkuWLMEnn3yCoUOH4uGHH0Z4eDgA4Pvvvzd2mRHZovt6+gEA/vtHGvQGdo8REZk7VVPeNHToUGRlZSE/Px9ubm7G5U8//TQcHBxMVhyRpRncuQ3cHNS4WlCKg+ezjLffICIi89SkFqHr16+jtLTUGIIuXbqE5cuX4/Tp02jbtq1JCySyJBqVAmN6VA6a3szuMSIis9ekIHTvvfdi3bp1AIDc3Fz0798f//znPzFhwgSsWrXKpAXKhXefp6a6r1dl99j2ExkoLquQuRoiIrqVJgWhI0eOYNCgQQCAb7/9Fl5eXrh06RLWrVuHDz/80KQFyoV3n6em6t3ODQHu9igq0yMm8Yrc5RAR0S00KQgVFxfD2dkZALBjxw5MnDgRCoUCd9xxBy5dumTSAoksjSRJxkHTvHqMiMi8NSkIderUCVu2bEFKSgq2b9+OkSNHAgAyMzPh4uJi0gKJLNG9Vd1j+85m4WpBqczVEBFRfZoUhP7+97/jpZdeQmBgIPr164cBAwYAqGwd6tWrl0kLJLJEHds4IdxfB71B4L/xbBUiIjJXTQpCDzzwAJKTk3H48GFs377duDwqKgrvv/++yYojsmST+gQAAL6KTeEtN4iIzFSTghAAeHt7o1evXkhLS8Ply5X/i7dfv37o2rWryYojsmTje/rCTl15y40jyblyl0NERHVoUhAyGAx48803odPp0L59e7Rr1w6urq546623YDAYTF0jkUVysVPjnqobsW6MTZa5GiIiqkuTgtD8+fOxYsUKLF68GEePHsWRI0fw7rvv4qOPPsIbb7xh6hqJLNZDfdsBALYeS0dhKecUIiIyN026xcYXX3yB1atXG+86DwDh4eHw8/PDc889h3feecdkBRJZsr6Bbujg6YgLWUX44VgaJlcFIyIiMg9NahHKycmpcyxQ165dkZOT0+yiiKyFJEl4sO+fg6aJiMi8NCkIhYeHY8WKFbWWr1ixAj169Gh2UUTWZGJvPygVEo4m5+LMlQK5yyEiohs0qWts6dKlGDNmDHbu3IkBAwZAkiQcPHgQKSkp2LZtm6lrJLJobZ3tENW1LXYkXsHG2BS8MTZE7pKIiKhKk1qEhgwZgjNnzuC+++5Dbm4ucnJyMHHiRCQkJODzzz83dY1EFm9yVffYd0dSUVKul7kaIiKqJgkTzvT2xx9/oHfv3tDrrecf+vz8fOh0OuTl5fH2IdRkFXoDhry3B5dzr+P/JoXjgQh/uUsiIrJqjf39bvKEikTUeCqlAo/0r7xibP2vF+UthoiIjGwiCN13331wc3PDAw88IHcpZMMe6hsAjVKBP1LzEJ+SK3c5REQEGwlCs2fPxrp16+Qug2ych5MWY3pUzjS9jq1CRERm4bauGps4ceIt1+fm5janlhYTGRmJPXv2yF0GEaYMaI/NRy9j67F0/G1MCNwdNXKXRERk026rRUin093y0b59ezz22GO3VcC+ffswbtw4+Pr6QpIkbNmypdY2K1euRFBQEOzs7BAREYH9+/ff1jGIzEWvAFeE+rmgrMKAjZxgkYhIdrfVItQSl8YXFRUhPDwcjz/+OO6///5a6zdu3Ig5c+Zg5cqVuPPOO/HJJ59g9OjRSExMRLt2lYNPIyIiUFpaWuu9O3bsgK+vr8lrJmoqSZLw2IBAvPztMfz7t0t4enAHKBWS3GUREdmsJk2oaEqjR4/G6NGj612/bNkyTJ8+HU8++SQAYPny5di+fTtWrVqFRYsWAQDi4uJMVk9paWmNUJWfn2+yfRMBwPhwX7y77SQu517HrlOZGBHiJXdJREQ2y6wHS5eVlSEuLg4jR46ssXzkyJE4ePBgixxz0aJFNbr7AgICWuQ4ZLvs1EpM7lP539XnvyTJXA0RkW0z6yCUlZUFvV4PL6+a/4vZy8sLGRkZjd7PqFGjMGnSJGzbtg3+/v6IjY2td9vXXnsNeXl5xkdKCsdxkOk9NjAQSoWEg+ezkZCWJ3c5REQ2S/auscaQpJpjKIQQtZbdyvbt2xu9rVarhVarbfT2RE3h52qPe8J88L8/0rBmfxKWTe4pd0lERDbJrFuEPD09oVQqa7X+ZGZm1molMrXo6GiEhISgb9++LXocsl1PDQoCAHz/Rxoy8kpkroaIyDaZdRDSaDSIiIhATExMjeUxMTEYOHBgix575syZSExMvGU3GlFz9PB3Rb9Ad1QYBL7gBItERLKQPQgVFhYiPj4e8fHxAICkpCTEx8cjOTkZADBv3jysXr0an332GU6ePIm5c+ciOTkZM2bMkLFqItN4sqpV6D+/XUJRaYXM1RAR2R7ZxwgdPnwYkZGRxtfz5s0DAEydOhVr167F5MmTkZ2djTfffBPp6ekIDQ3Ftm3b0L59e7lKJjKZ4d28EOjhgIvZxfg2LhVTBwbKXRIRkU2RhBBC7iLMUXR0NKKjo6HX63HmzBnk5eXBxcVF7rLICq3/9SLe+G8C2rk7YPdLQznBIhGRCeTn50On0zX4+y1715i54hghai0PRATA1UGN5Jxi/HgiXe5yiIhsCoMQkczsNUpMq+oSW7n7PNhIS0TUehiEiMzAtIGBcNAokZiejz1nrspdDhGRzWAQIjIDrg4aPNq/8ibCK3efk7kaIiLbwSBUD06oSK3tyUEdoFEqEHvxGg4l5chdDhGRTWAQqgcHS1Nr83KxwwN9/AEA0WwVIiJqFQxCRGZkxuCOUEjA3jNXceIyb8ZKRNTSGISIzEg7DweMC/cFwFYhIqLWwCBUD44RIrk8N7QTJAn48UQGTqbny10OEZFVYxCqB8cIkVy6eDvjnjAfAMAHO8/KXA0RkXVjECIyQ3OigiFJwE8JGUhI41ghIqKWwiBEZIaCvZwxtkflWKHlbBUiImoxDEJEZuqFqMqxQjGJV3gFGRFRC2EQIjJTndo6Y3x4davQGZmrISKyTgxC9eBVY2QOZkcFQyEBO09m4lhqrtzlEBFZHQahevCqMTIHHds4YUJPPwAcK0RE1BIYhIjM3PNRwVAqJOw6lYkjydfkLoeIyKowCBGZuSBPR0zsVdkqtOTHUxBCyFwREZH1YBAisgBzRnSGRqXA70k52HvmqtzlEBFZDQYhIgvg52qPx+5oDwBY8tNpGAxsFSIiMgUGISILMTOyE5y1KpxMz8f/jqXJXQ4RkVVgECKyEG6OGjw9uAMA4J87zqCswiBzRURElo9BqB6cR4jM0fRBQfB00iI5pxhfHkqWuxwiIovHIFQPziNE5shBo8ILUZ0AAB/tOoui0gqZKyIismwMQkQW5qF+7dDewwFZhWVYvT9J7nKIiCwagxCRhVErFXhxZBcAwCf7ziOzoETmioiILBeDEJEFGhvmg/AAVxSX6fF+DG/ISkTUVAxCRBZIoZDwxphuAICNsSk4mZ4vc0VERJaJQYjIQvUJdMeYMB8YBPDODyd56w0ioiZgECKyYK/c3RUapQIHzmVhz2neeoOI6HYxCBFZsHYeDph2ZyAA4J1tJ1Gh5ySLRES3g0GoHpxQkSzFzMhOcHNQ41xmIb6MTZG7HCIiiyIJDiy4pfz8fOh0OuTl5cHFxUXucojqtO7Xi/j7fxPg7qjBnr8OhYudWu6SiIhk1djfb7YIEVmBh/u1Q8c2jsgpKsMHO8/KXQ4RkcVgECKyAmqlAgvGdQcArD14EWeuFMhcERGRZWAQIrISgzu3wcgQL+gNAgu/T+Dl9EREjcAgRGRF3hgbAq1KgYPns/HjiQy5yyEiMnsMQkRWJMDdATOGdAQAvL01EcVlvDs9EdGtMAgRWZlnh3aEn6s90vJKsGrPebnLISIyawxCRFbGTq3EG2Mr70P2yb4LuJRdJHNFRETmi0GIyAqN6u6NQcGeKKsw4K2tiXKXQ0RkthiEiKyQJElYMK47VAoJO09mYvepTLlLIiIySwxCRFaqU1snPF51H7IF3yegpFwvb0FERGaIQYjIir0wvDO8XeyQnFOMFbvOyV0OEZHZYRCqB2+6StbASavCwvGVM05/su88znLGaSKiGnjT1Qbwpqtk6YQQeGpdHHaevIK+gW7Y+PQAKBSS3GUREbUo3nSViABUDpz+x73d4aBRIvbiNXwTlyJ3SUREZoNBiMgG+LnaY96IzgCAd7edQlZhqcwVERGZBwYhIhsxbWAgQnxckHe9HO/+cFLucoiIzAKDEJGNUCkVeHdiGCQJ+O7oZRw8lyV3SUREsmMQIrIhPQNcMeWO9gCA+VtOcG4hIrJ5DEJENualUV3Q1lmLpKwifPDzWbnLISKSFYMQkY1xsVPjnfvCAACf7ruAY6m58hZERCQjBiEiGzQixAvjwn2hNwi8/O0xlFUY5C6JiEgWDEJENmrhuBC4O2pwKqMAq/acl7scIiJZMAgR2SgPJy3+UXX7jRW7z+JURr7MFRERtT4GISIbNraHD0aGeKFcX9lFVqFnFxkR2RYGISIbJkkS3p4QChc7FY6l5mH1gSS5SyIialUMQkQ2rq2LHd4YGwIAWBZzBuevFspcERFR62EQIiI8EOGPwZ3boKzCgBe//oNdZERkM6w+CKWkpGDo0KEICQlBjx498M0338hdEpHZkSQJiyeGwdlOhfiUXF5FRkQ2w+qDkEqlwvLly5GYmIidO3di7ty5KCoqkrssIrPj62qPN++tvIrsg5/P4nhqnswVERG1PKsPQj4+PujZsycAoG3btnB3d0dOTo68RRGZqQk9/XBPmDcqDAJzv47nvciIyOrJHoT27duHcePGwdfXF5IkYcuWLbW2WblyJYKCgmBnZ4eIiAjs37+/Scc6fPgwDAYDAgICmlk1kXWSJAnvTAhDG2ctzmUWYulPp+UuiYioRckehIqKihAeHo4VK1bUuX7jxo2YM2cO5s+fj6NHj2LQoEEYPXo0kpOTjdtEREQgNDS01iMtLc24TXZ2Nh577DF8+umnLf6ZiCyZm6MGSx/oAQD47JckHDyXJXNFREQtRxJCCLmLqCZJEjZv3owJEyYYl/Xv3x+9e/fGqlWrjMu6deuGCRMmYNGiRY3ab2lpKUaMGIGnnnoKU6ZMaXDb0tJS4+v8/HwEBAQgLy8PLi4ut/eBiCzY65uPY8PvyfDV2eHHOYOhs1fLXRIRUaPl5+dDp9M1+Pste4vQrZSVlSEuLg4jR46ssXzkyJE4ePBgo/YhhMC0adMwbNiwBkMQACxatAg6nc74YDca2ar593RDew8HpOWVYOH3CXKXQ0TUIsw6CGVlZUGv18PLy6vGci8vL2RkZDRqH7/88gs2btyILVu2oGfPnujZsyeOHz9e7/avvfYa8vLyjI+UlJRmfQYiS+WoVWHZgz2hkIDNRy9jy9HLcpdERGRyKrkLaAxJkmq8FkLUWlafu+66CwZD4yeH02q10Gq1t1UfkbWKaO+G54cF44Ofz2L+5uPoGeCKQE9HucsiIjIZs24R8vT0hFKprNX6k5mZWauViIhaxvPDOqFfoDuKyvSY/dVRlFVw1mkish5mHYQ0Gg0iIiIQExNTY3lMTAwGDhzYoseOjo5GSEgI+vbt26LHITJ3KqUCyx/qCZ29GsdS8/De9lNyl0REZDKyB6HCwkLEx8cjPj4eAJCUlIT4+Hjj5fHz5s3D6tWr8dlnn+HkyZOYO3cukpOTMWPGjBata+bMmUhMTERsbGyLHofIEvi62uO9qkvq/7U/CbtPZ8pcERGRach++fyePXsQGRlZa/nUqVOxdu1aAJUTKi5duhTp6ekIDQ3F+++/j8GDB7dKfY29/I7IFvz9vyew7tdL8HDU4Mc5g9DW2U7ukoiI6tTY32/Zg5C5YxAi+lNJuR4Ton/BqYwC3NXJE+ue6AeFonEXLhARtSarmEdIThwjRFSbnVqJFY/0gr1aiQPnshC9+5zcJRERNQtbhBrAFiGi2r4+nIKXvz0GSQLWPdEPg4LbyF0SEVENbBEiohbzYJ8APNQ3AEIAs788isu51+UuiYioSRiEiKhJFo7vjlA/F1wrLsdz/zmC0gq93CUREd02BqF6cIwQ0a3ZqZVY9WgEdPZq/JGSi7e2JspdEhHRbeMYoQZwjBDRre0+nYkn1sZCCGDZg+GY2Ntf7pKIiDhGiIhaR2SXtpg9LBgA8Prm4ziZni9zRUREjccgRETNNjsqGIM7t0FJuQHPrI/DtaIyuUsiImoUBiEiajalQsIHk3siwN0eyTnFeO4/R1Cu581Zicj8MQjVg4OliW6Pm6MGqx/rC0eNEr9eyMab/+PgaSIyfxws3QAOlia6PTGJV/D0+sMQAnh7Qij+ckd7uUsiIhvEwdJEJIsRIV7466guAICF3yfg1/PZMldERFQ/BiEiMrlnh3TEhJ6+qDAIPPufOFzMKpK7JCKiOjEIEZHJSZKExff3QHiAK3KLy/H42ljk8EoyIjJDDEJE1CLs1Er867EI+LnaIymrCE9+EYuSct6Gg4jMC4NQPXjVGFHztXW2wxdP9IXOXo0jybmY81U89AZen0FE5oNXjTWAV40RNd/vF7IxZc0hlOkNmH5XEN4YGyJ3SURk5XjVGBGZjf4dPPB/D4YDANYcSMKaA0kyV0REVIlBiIhaxfhwX7w6uisA4K2tidgUlypzRUREDEJE1IqeGdwBj98ZCAB4edMx7EjIkLcgIrJ5DEJE1GokScIbY0LwQIQ/9AaBWRuO4pdzWXKXRUQ2jEGIiFqVQiFh8cQw3N3dG2V6A55adxhHk6/JXRYR2SgGoXrw8nmilqNSKvDBwz1xVydPFJfpMe3zWCSm5ctdFhHZIF4+3wBePk/UcopKK/CXNb/jaHIu3BzU+M+TdyDEl/9/RkTNx8vnicjsOWpVWPt4P4QHuOJacTkeWf0bEtLy5C6LiGwIgxARyUpnr8b66f2M9yV7dPXvOHGZYYiIWgeDEBHJzsWuMgz1ZBgiolbGIEREZsHFTo110/uhVztX5F0vxyP/+g2HL+bIXRYRWTkGISIyGy52aqx7oh/6tHdDfknlQOrdpzLlLouIrBiDEBGZFWc7NdZP74/ILm1QUl45z9CWo5flLouIrBSDEBGZHXuNEp8+1gf39fJDhUFgzsZ4fP4Lb9RKRKbHIFQPTqhIJC+1UoF/TgrHtIGBAIB//C8Ri7adhMHAqc+IyHQ4oWIDOKEikbyEEIjefQ7/t+MMAGBkiBeWP9QTDhqVzJURkTnjhIpEZBUkScKsYcH44KGe0KgU2JF4BQ9+8isy8krkLo2IrACDEBFZhHt7+uHLp/rDw1GDE5fzcW/0Ac41RETNxiBERBYjor07tsy8E8FtnXAlvxT3rzqIb+NS5S6LiCwYgxARWZQAdwdsem4gIru0QWmFAS998wde++44Ssr1cpdGRBaIQYiILI6LnRprpvbFvBGdIUnAl4eSMenjX5GSUyx3aURkYRiEiMgiKRQSZkcFY+3j/eDqoMbxy3kY+9EB7EjIkLs0IrIgDEJEZNGGdG6Drc/fhXB/HfKul+Pp9XF4ddMxFJVWyF0aEVkABiEisnj+bg74esYAPDOkAyQJ+Co2BWM+3I+jydfkLo2IzByDEBFZBa1KiddGd8OGJ++Ar84OF7OL8cDHv2JZzBmUVnAgNRHVjUGIiKzKgI4e+HHOYIwP94XeIPDhz2cx9sMDOHwxR+7SiMgMMQgRkdXR2avx4cO9sOKRXvB00uBsZiEe+PhX/G3LceSXlMtdHhGZEQYhIrJaY3v4Yue8IXiwjz8A4N+/JWPEsr34b/xl8DaLRAQwCNWLd58nsg6uDhosfSAcG57qj0APB1zJL8ULX8Xj/lUHEZ+SK3d5RCQz3n2+Abz7PJH1KCnXY/X+C1i55zyKyyoHUE/s5YeX7+4Kb52dzNURkSk19vebQagBDEJE1udKfgmW/nQam45U3qdMq1Jgyh3tMWNoR3g6aWWujohMgUHIRBiEiKzXHym5ePuHRMRerJxvyEGjxNSBgXh6UAe4OWpkro6ImoNByEQYhIismxACe89cxbKYMziWmgcAcNKq8Ogd7fDEnUHwcmGXGZElYhAyEQYhItsghMDOk5lYFnMGJ9PzAQBqpYR7e/rh6cEd0NnLWeYKieh2MAiZCIMQkW0xGAR2ncrEp/su4NANkzAO7twGf+nfDsO6toVKyQtuicwdg5CJMAgR2a6jydfw6b4L+CkhA9X/Unq72GFy3wA81C8APjp7eQskonoxCJkIgxARXcouwoZDyfjmcCpyisoAAAoJuCu4De7r5YtR3b3hoFHJXCUR3YhByEQYhIioWmmFHj+dyMCG35Pxe9Kf3WYOGiVGhnjh3p5+GNjJA1qVUsYqiQhgEDIZBiEiqktSVhG2HL2MLfGXcSm72LjcSavCkC5tMKq7N4Z2aQMXO7WMVRLZLgYhE2EQIqJbEULgaEouthy9jJ9OZCCzoNS4Tq2UMKCjJ4Z0boNBwZ4IbusESZJkrJbIdjAImQiDEBE1lsEgcOxyHrYnZGBHQgbOXy2qsd7LRYs7O3liULAnBnb05BxFRC2IQchEGISIqKnOZRZi16kr2H82C4eSclBaYaix3s/VHn0C3dCnvRt6t3dDV28XKBVsMSIyBQYhE2EQIiJTKCnX4/DFa9h/7ioOnM3CyfR8GG7619dJq0J4gA6hvjqE+Lqgu68OQZ6ODEdETcAgZCIMQkTUEgpKyhGfkou4S9cQd+kajibnorC0otZ2Dholuno7o7uvDp29nNCxrRM6tXVCGyctxxsR3QKDUJWCggIMGzYM5eXl0Ov1mD17Np566qlGv59BiIhag94gcDqjAH+k5iIhLQ8Jafk4mZ6PknJDndu72KkqQ1GbynAU6OEAfzcHBLg7QGfPK9WIGISq6PV6lJaWwsHBAcXFxQgNDUVsbCw8PDwa9X4GISKSi94gcOFqIRLS8pGYno/zmYU4d7UQKTnFtbrVbuRip0KAuwMC3Bzg72aPAHcH+Lraw8tFCy8XO3g4anibELJ6jf39tvqpUJVKJRwcHAAAJSUl0Ov1sPLsR0RWQqmQEOzljGAvZ0zo5WdcXlKux8XsIpzLLMS5zEKcv1qE5JxipOYUI7uoDPklFUhIy0dCWn6d+1VIgIeTtjIYOduhrYsdvFy08HTSwt1RAzcHTeVfRzXcHDRQMzSRFZM9CO3btw/vvfce4uLikJ6ejs2bN2PChAk1tlm5ciXee+89pKeno3v37li+fDkGDRrU6GPk5uZiyJAhOHv2LN577z14enqa+FMQEbUeO7USXb1d0NW79v/KLSqtQOq160i9VoyUnGKkXLuOlJxiXMkvwZX8UlwtLIXeIHC1oBRXC0pxAnWHpRs526ng4aiBm6MG7g4auNir4Wynqnqoa/x1uWmZg1oJBQd7kxmTPQgVFRUhPDwcjz/+OO6///5a6zdu3Ig5c+Zg5cqVuPPOO/HJJ59g9OjRSExMRLt27QAAERERKC0trfXeHTt2wNfXF66urvjjjz9w5coVTJw4EQ888AC8vLxa/LMREbU2R60KXbyd0cXbuc71eoNAdlEpMvNLjeGo8m8JsovKcK2oDDnFlX9zr5dDCKCgpAIFJRW4eMMM2o0lSYCDWgl7jQr2GgUc1CrYa5Rw0Chhr1be9FwFh6rXWrUSWqUCWrUCGqUCGlXVo+q5VqWs+nvzcgW7/ei2mNUYIUmSarUI9e/fH71798aqVauMy7p164YJEyZg0aJFt32MZ599FsOGDcOkSZPqXF9aWlojVOXn5yMgIIBjhIjI5ugNAnnXy5FTVIZrxWWVf4vKkF9SbgxHfz6v/FtYWmF8Xa6X5+dFIcEYjlRKBVQKCSqFBKVSglqhgFIhGZcrFRLUysq/KoUCKqVUtb0CyhueqxSScZ1CIUEpVf6VJFQ+lyQopMrfMaXiz+cKSYJSASgkqXKdhKr3VW5T/V5JQtX7Kp8rbtqPsmp59YWCEiRU/R8kSar6W7lcqlqOG7aVbtzW+Lxq7Q3rqt92475w876rnv+5vO593bifajdf6Fj92tvFzuQB1irGCJWVlSEuLg6vvvpqjeUjR47EwYMHG7WPK1euwN7eHi4uLsjPz8e+ffvw7LPP1rv9okWL8I9//KNZdRMRWQOlQoK7Y+V4odslhEBphQH5JeW4XqZHcZke18v1xufFZRUoKa9+rr9pmwpcL9ejrMKAMr2h8m+FAaVVr0vLay4v0xugv2H0uEEAJeWGeq+4I/Pz22tR8NbJM9O6WQehrKws6PX6Wt1YXl5eyMjIaNQ+UlNTMX36dAghIITArFmz0KNHj3q3f+211zBv3jzj6+oWISIiajxJkmCnVsJOrWyV41Xo6w5NeoNAhV6gwmBAhUFAbxAor7FcQG8woFxfua7CIFChN9T4++fyym0rDAIGURn29FXPDVW/MXpR3zpUva58brhh/c3vq7XOIKAXAKo6cKqfClTuq/I5jBcCVa/783nlOlH15htf37gf/HmIOtf/WULd+xai7uNUq35mPAb+XCfnlFhmHYSq3TxpmBCi0ROJRUREID4+vtHH0mq10Gq1t1MeERHJTFXVDeZw+41XZOPMekSZp6cnlEplrdafzMzMFh/sHB0djZCQEPTt27dFj0NERETyMesgpNFoEBERgZiYmBrLY2JiMHDgwBY99syZM5GYmIjY2NgWPQ4RERHJR/auscLCQpw7d874OikpCfHx8XB3d0e7du0wb948TJkyBX369MGAAQPw6aefIjk5GTNmzJCxaiIiIrIGsgehw4cPIzIy0vi6eqDy1KlTsXbtWkyePBnZ2dl48803kZ6ejtDQUGzbtg3t27eXq2QiIiKyEmY1j5A5iY6ORnR0NPR6Pc6cOcN5hIiIiCwIb7pqIrzpKhERkeVp7O+3WQ+WJiIiImpJDEJERERksxiE6sF5hIiIiKwfxwg1gGOEiIiILA/HCBERERE1gEGIiIiIbBaDEBEREdksBqF6cLA0ERGR9eNg6Qbk5eXB1dUVKSkpHCxNRERkIfLz8xEQEIDc3FzodLp6t5P9XmPmrqCgAAAQEBAgcyVERER0uwoKCm4ZhNgi1ACDwYC0tDQ4OztDkiST7bc6qbKlqeXxXLcOnufWwfPceniuW0dLnWchBAoKCuDr6wuFov6RQGwRaoBCoYC/v3+L7d/FxYX/D9ZKeK5bB89z6+B5bj08162jJc7zrVqCqnGwNBEREdksBiEiIiKyWQxCMtFqtViwYAG0Wq3cpVg9nuvWwfPcOnieWw/PdeuQ+zxzsDQRERHZLLYIERERkc1iECIiIiKbxSBERERENotBiIiIiGwWg5BMVq5ciaCgINjZ2SEiIgL79++XuySLsm/fPowbNw6+vr6QJAlbtmypsV4IgYULF8LX1xf29vYYOnQoEhISamxTWlqK559/Hp6ennB0dMT48eORmpraip/C/C1atAh9+/aFs7Mz2rZtiwkTJuD06dM1tuG5br5Vq1ahR48exgnlBgwYgB9//NG4nue4ZSxatAiSJGHOnDnGZTzXprFw4UJIklTj4e3tbVxvVudZUKv76quvhFqtFv/6179EYmKieOGFF4Sjo6O4dOmS3KVZjG3bton58+eLTZs2CQBi8+bNNdYvXrxYODs7i02bNonjx4+LyZMnCx8fH5Gfn2/cZsaMGcLPz0/ExMSII0eOiMjISBEeHi4qKipa+dOYr1GjRonPP/9cnDhxQsTHx4sxY8aIdu3aicLCQuM2PNfN9/3334sffvhBnD59Wpw+fVq8/vrrQq1WixMnTggheI5bwqFDh0RgYKDo0aOHeOGFF4zLea5NY8GCBaJ79+4iPT3d+MjMzDSuN6fzzCAkg379+okZM2bUWNa1a1fx6quvylSRZbs5CBkMBuHt7S0WL15sXFZSUiJ0Op34+OOPhRBC5ObmCrVaLb766ivjNpcvXxYKhUL89NNPrVa7pcnMzBQAxN69e4UQPNctyc3NTaxevZrnuAUUFBSI4OBgERMTI4YMGWIMQjzXprNgwQIRHh5e5zpzO8/sGmtlZWVliIuLw8iRI2ssHzlyJA4ePChTVdYlKSkJGRkZNc6xVqvFkCFDjOc4Li4O5eXlNbbx9fVFaGgov4dbyMvLAwC4u7sD4LluCXq9Hl999RWKioowYMAAnuMWMHPmTIwZMwbDhw+vsZzn2rTOnj0LX19fBAUF4aGHHsKFCxcAmN955k1XW1lWVhb0ej28vLxqLPfy8kJGRoZMVVmX6vNY1zm+dOmScRuNRgM3N7da2/B7qJsQAvPmzcNdd92F0NBQADzXpnT8+HEMGDAAJSUlcHJywubNmxESEmL8R5/n2DS++uorHDlyBLGxsbXW8b9n0+nfvz/WrVuHzp0748qVK3j77bcxcOBAJCQkmN15ZhCSiSRJNV4LIWoto+Zpyjnm91C/WbNm4dixYzhw4ECtdTzXzdelSxfEx8cjNzcXmzZtwtSpU7F3717jep7j5ktJScELL7yAHTt2wM7Ort7teK6bb/To0cbnYWFhGDBgADp27IgvvvgCd9xxBwDzOc/sGmtlnp6eUCqVtRJtZmZmrXRMTVN9ZcKtzrG3tzfKyspw7dq1erehPz3//PP4/vvvsXv3bvj7+xuX81ybjkajQadOndCnTx8sWrQI4eHh+OCDD3iOTSguLg6ZmZmIiIiASqWCSqXC3r178eGHH0KlUhnPFc+16Tk6OiIsLAxnz541u/+mGYRamUajQUREBGJiYmosj4mJwcCBA2WqyroEBQXB29u7xjkuKyvD3r17jec4IiICarW6xjbp6ek4ceIEv4cbCCEwa9YsfPfdd9i1axeCgoJqrOe5bjlCCJSWlvIcm1BUVBSOHz+O+Ph446NPnz549NFHER8fjw4dOvBct5DS0lKcPHkSPj4+5vfftEmHXlOjVF8+v2bNGpGYmCjmzJkjHB0dxcWLF+UuzWIUFBSIo0ePiqNHjwoAYtmyZeLo0aPGKQgWL14sdDqd+O6778Tx48fFww8/XOelmf7+/mLnzp3iyJEjYtiwYbwE9ibPPvus0Ol0Ys+ePTUugy0uLjZuw3PdfK+99prYt2+fSEpKEseOHROvv/66UCgUYseOHUIInuOWdONVY0LwXJvKiy++KPbs2SMuXLggfvvtNzF27Fjh7Oxs/J0zp/PMICST6Oho0b59e6HRaETv3r2NlyNT4+zevVsAqPWYOnWqEKLy8swFCxYIb29vodVqxeDBg8Xx48dr7OP69eti1qxZwt3dXdjb24uxY8eK5ORkGT6N+arrHAMQn3/+uXEbnuvme+KJJ4z/HrRp00ZERUUZQ5AQPMct6eYgxHNtGtXzAqnVauHr6ysmTpwoEhISjOvN6TxLQghh2jYmIiIiIsvAMUJERERksxiEiIiIyGYxCBEREZHNYhAiIiIim8UgRERERDaLQYiIiIhsFoMQERER2SwGISKiWwgMDMTy5cvlLoOIWgiDEBGZjWnTpmHChAkAgKFDh2LOnDmtduy1a9fC1dW11vLY2Fg8/fTTrVYHEbUuldwFEBG1pLKyMmg0mia/v02bNiashojMDVuEiMjsTJs2DXv37sUHH3wASZIgSRIuXrwIAEhMTMQ999wDJycneHl5YcqUKcjKyjK+d+jQoZg1axbmzZsHT09PjBgxAgCwbNkyhIWFwdHREQEBAXjuuedQWFgIANizZw8ef/xx5OXlGY+3cOFCALW7xpKTk3HvvffCyckJLi4uePDBB3HlyhXj+oULF6Jnz55Yv349AgMDodPp8NBDD6GgoKBlTxoRNQmDEBGZnQ8++AADBgzAU089hfT0dKSnpyMgIADp6ekYMmQIevbsicOHD+Onn37ClStX8OCDD9Z4/xdffAGVSoVffvkFn3zyCQBAoVDgww8/xIkTJ/DFF19g165dePnllwEAAwcOxPLly+Hi4mI83ksvvVSrLiEEJkyYgJycHOzduxcxMTE4f/48Jk+eXGO78+fPY8uWLdi6dSu2bt2KvXv3YvHixS10toioOdg1RkRmR6fTQaPRwMHBAd7e3sblq1atQu/evfHuu+8al3322WcICAjAmTNn0LlzZwBAp06dsHTp0hr7vHG8UVBQEN566y08++yzWLlyJTQaDXQ6HSRJqnG8m+3cuRPHjh1DUlISAgICAADr169H9+7dERsbi759+wIADAYD1q5dC2dnZwDAlClT8PPPP+Odd95p3okhIpNjixARWYy4uDjs3r0bTk5OxkfXrl0BVLbCVOvTp0+t9+7evRsjRoyAn58fnJ2d8dhjjyE7OxtFRUWNPv7JkycREBBgDEEAEBISAldXV5w8edK4LDAw0BiCAMDHxweZmZm39VmJqHWwRYiILIbBYMC4ceOwZMmSWut8fHyMzx0dHWusu3TpEu655x7MmDEDb731Ftzd3XHgwAFMnz4d5eXljT6+EAKSJDW4XK1W11gvSRIMBkOjj0NErYdBiIjMkkajgV6vr7Gsd+/e2LRpEwIDA6FSNf6fr8OHD6OiogL//Oc/oVBUNoR//fXXDR7vZiEhIUhOTkZKSoqxVSgxMRF5eXno1q1bo+shIvPBrjEiMkuBgYH4/fffcfHiRWRlZcFgMGDmzJnIycnBww8/jEOHDuHChQvYsWMHnnjiiVuGmI4dO6KiogIfffQRLly4gPXr1+Pjjz+udbzCwkL8/PPPyMrKQnFxca39DB8+HD169MCjjz6KI0eO4NChQ3jssccwZMiQOrvjiMj8MQgRkVl66aWXoFQqERISgjZt2iA5ORm+vr745ZdfoNfrMWrUKISGhuKFF16ATqcztvTUpWfPnli2bBmWLFmC0NBQ/Oc//8GiRYtqbDNw4EDMmDEDkydPRps2bWoNtgYqu7i2bNkCNzc3DB48GMOHD0eHDh2wceNGk39+ImodkhBCyF0EERERkRzYIkREREQ2i0GIiIiIbBaDEBEREdksBiEiIiKyWQxCREREZLMYhIiIiMhmMQgRERGRzWIQIiIiIpvFIEREREQ2i0GIiIiIbBaDEBEREdksBiEiIiKyWf8PgznBqkAtE2sAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 144
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:57.154544Z",
     "start_time": "2024-09-16T17:01:56.953106Z"
    }
   },
   "cell_type": "code",
   "source": [
    "end = 500\n",
    "if ptf:\n",
    "    prods = product(dims_list, num_tasks_list, num_samples_list, low_rank_dim_list, sigma_list)\n",
    "    enum = product(range(len(dims_list)), range(len(num_tasks_list)), range(len(num_samples_list)),\n",
    "                   range(len(low_rank_dim_list)), range(len(sigma_list)))\n",
    "    plt.figure('Losses on New Task')\n",
    "    plt.title('Loss on New Task')\n",
    "    plt.xlabel('Iteration')\n",
    "    plt.ylabel('Loss')\n",
    "    for prod, counts in zip(prods, enum):\n",
    "        dim, num_tasks, num_samples, low_rank_dim, sigma = prod\n",
    "        for j in range(len(post_sample_num_list)):\n",
    "            plt.semilogy(post_loss[*counts, j, :end], label='Meta-LoRA')\n",
    "        for j in range(len(post_sample_num_list)):\n",
    "            plt.semilogy(post_ptf_loss[*counts, j, :end], label='PTF')\n",
    "    plt.legend()\n",
    "    plt.savefig('./images/losses_compare.png')\n",
    "    plt.show()"
   ],
   "id": "e45ed4c2f7b122fa",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAkIAAAHFCAYAAAAe+pb9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAABbVklEQVR4nO3deVxVdf4/8Ne5K/sFZBcQ3EVcccldXNO0zHJsMy2tsaxGac/pl+NMafbNsUa0Gk1bpnIm08osww23UkTJBXdRQEEEZN/v/fz+uHDlCgiynbu8no/H+V7u53zOue976CuvOZ/POUcSQggQERER2SGF3AUQERERyYVBiIiIiOwWgxARERHZLQYhIiIislsMQkRERGS3GISIiIjIbjEIERERkd1iECIiIiK7xSBEREREdotBiMjGrV+/HpIk4fDhw3KXYhFmzZoFSZLQvXt36PX6GuslScJzzz0nQ2VGVfXVt8yaNavZPs/FxaVZ9kVkjVRyF0BEJIfExESsX78es2fPlrsUM2+++Sbmzp1ren/kyBHMmzcP77zzDiIjI03t3t7ecpRHZHMYhIjI7jg7O6Nv375466238Mgjj8DR0VHukkw6dOiADh06mN6XlJQAADp16oS77rpLrrKIbBaHxogIALBv3z6MHj0arq6ucHJywuDBg/HTTz+Z9SkqKsJLL72E0NBQODg4wNPTE/369cPXX39t6nPx4kU89NBDCAgIgFarha+vL0aPHo2EhIR6a/jhhx8waNAgODk5wdXVFWPHjsVvv/1m1mfRokWQJAknT57Eww8/DJ1OB19fXzz55JPIzc1t8Pd99913ceXKFXzwwQf19s3LyzN9b41Gg7Zt22L+/PkoLCw09Zk2bRq6d+9utt3kyZMhSRL+97//mdqOHDkCSZLw448/NrjWWx0+fBgPPfQQQkJC4OjoiJCQEDz88MO4fPmyWb+G/L5qs3//fnh5eWHSpElm35HIFjEIERFiY2MxatQo5ObmYu3atfj666/h6uqKyZMnY8OGDaZ+UVFRWL16NV544QX88ssv+OKLLzBt2jRkZWWZ+kycOBHx8fFYtmwZYmJisHr1avTp0wc5OTm3reGrr77CfffdBzc3N3z99ddYu3Ytbty4gZEjR2Lfvn01+j/wwAPo3LkzNm7ciNdeew1fffUVFixY0ODvPGjQINx///149913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qLMfj3XTTZgwwfRzjx49MGjQIHTo0AGfffYZ7rrrLgCWc5w5NNbKvLy8oFQqayTajIyMGumYGqfqyoTbHWM/Pz+UlZXhxo0bdfahm55//nn88MMP2LVrFwIDA03tPNbNR6PRoGPHjujXrx+WLFmCXr164YMPPuAxbkbx8fHIyMhAREQEVCoVVCoVYmNj8eGHH0KlUpmOFY9183N2dkaPHj1w7tw5i/tvmkGolWk0GkRERCAmJsasPSYmBoMHD5apKtsSGhoKPz8/s2NcVlaG2NhY0zGOiIiAWq0265OWloYTJ07w91CNEALPPfccvvvuO+zcuROhoaFm63msW44QAqWlpTzGzWj06NE4fvw4EhISTEu/fv3w6KOPIiEhAe3bt+exbiGlpaU4deoU/P39Le+/6Wadek0NUnX5/Nq1a0ViYqKYP3++cHZ2FpcuXZK7NKuRn58vjh49Ko4ePSoAiOXLl4ujR4+abkGwdOlSodPpxHfffSeOHz8uHn744VovzQwMDBTbt28XR44cEaNGjeIlsLd45plnhE6nE7t37za7DLaoqMjUh8e66V5//XWxZ88ekZSUJI4dOybeeOMNoVAoxK+//iqE4DFuSdWvGhOCx7q5vPjii2L37t3i4sWL4vfffxeTJk0Srq6upr9zlnScGYRkEh0dLdq1ayc0Go3o27ev6XJkaphdu3YJADWWmTNnCiGMl2e+9dZbws/PT2i1WjF8+HBx/Phxs30UFxeL5557Tnh6egpHR0cxadIkkZycLMO3sVy1HWMAYt26daY+PNZN9+STT5r+PfD29hajR482hSAheIxb0q1BiMe6eVTdF0itVouAgAAxdepUcfLkSdN6SzrOkhBCNO85JiIiIiLrwDlCREREZLcYhIiIiMhuMQgRERGR3WIQIiIiIrvFIERERER2i0GIiIiI7BaDEBEREdktBiEiotsICQnBihUr5C6DiFoIgxARWYxZs2ZhypQpAICRI0di/vz5rfbZ69evh7u7e432uLg4PP30061WBxG1LpXcBRARtaSysjJoNJpGb+/t7d2M1RCRpeEZISKyOLNmzUJsbCw++OADSJIESZJw6dIlAEBiYiImTpwIFxcX+Pr6YsaMGcjMzDRtO3LkSDz33HOIioqCl5cXxo4dCwBYvnw5evToAWdnZwQFBeHZZ59FQUEBAGD37t144oknkJuba/q8RYsWAag5NJacnIz77rsPLi4ucHNzw5/+9Cdcu3bNtH7RokXo3bs3vvjiC4SEhECn0+Ghhx5Cfn5+yx40ImoUBiEisjgffPABBg0ahKeeegppaWlIS0tDUFAQ0tLSMGLECPTu3RuHDx/GL7/8gmvXruFPf/qT2fafffYZVCoV9u/fj48//hgAoFAo8OGHH+LEiRP47LPPsHPnTrzyyisAgMGDB2PFihVwc3Mzfd5LL71Uoy4hBKZMmYLs7GzExsYiJiYGFy5cwPTp0836XbhwAZs3b8aWLVuwZcsWxMbGYunSpS10tIioKTg0RkQWR6fTQaPRwMnJCX5+fqb21atXo2/fvnjnnXdMbZ9++imCgoJw9uxZdO7cGQDQsWNHLFu2zGyf1ecbhYaG4u9//zueeeYZrFq1ChqNBjqdDpIkmX3erbZv345jx44hKSkJQUFBAIAvvvgC3bt3R1xcHPr37w8AMBgMWL9+PVxdXQEAM2bMwI4dO/D222837cAQUbPjGSEishrx8fHYtWsXXFxcTEvXrl0BGM/CVOnXr1+NbXft2oWxY8eibdu2cHV1xeOPP46srCwUFhY2+PNPnTqFoKAgUwgCgLCwMLi7u+PUqVOmtpCQEFMIAgB/f39kZGTc0XclotbBM0JEZDUMBgMmT56Md999t8Y6f39/08/Ozs5m6y5fvoyJEydi7ty5+Pvf/w5PT0/s27cPs2fPRnl5eYM/XwgBSZLqbVer1WbrJUmCwWBo8OcQUethECIii6TRaKDX683a+vbti40bNyIkJAQqVcP/+Tp8+DAqKirw/vvvQ6Ewngj/73//W+/n3SosLAzJyclISUkxnRVKTExEbm4uunXr1uB6iMhycGiMiCxSSEgIDh48iEuXLiEzMxMGgwHz5s1DdnY2Hn74YRw6dAgXL17Er7/+iieffPK2IaZDhw6oqKjAv/71L1y8eBFffPEFPvrooxqfV1BQgB07diAzMxNFRUU19jNmzBj07NkTjz76KI4cOYJDhw7h8ccfx4gRI2odjiMiy8cgREQW6aWXXoJSqURYWBi8vb2RnJyMgIAA7N+/H3q9HuPHj0d4eDj+8pe/QKfTmc701KZ3795Yvnw53n33XYSHh+M///kPlixZYtZn8ODBmDt3LqZPnw5vb+8ak60B4xDX5s2b4eHhgeHDh2PMmDFo3749NmzY0Ozfn4hahySEEHIXQURERCQHnhEiIiIiu8UgRERERHaLQYiIiIjsFoMQERER2S0GISIiIrJbDEJERERktxiEiIiIyG4xCBEREZHdYhAiIiIiu8UgRERERHaLQYiIiIjsFoMQERER2a3/D0EEgorlHhMNAAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 141
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:21.211689Z",
     "start_time": "2024-09-16T17:01:21.031449Z"
    }
   },
   "cell_type": "code",
   "source": [
    "prods = product(dims_list, num_tasks_list, num_samples_list, low_rank_dim_list, sigma_list)\n",
    "enum = product(range(len(dims_list)), range(len(num_tasks_list)), range(len(num_samples_list)),\n",
    "               range(len(low_rank_dim_list)), range(len(sigma_list)))\n",
    "plt.figure('A_Losses')\n",
    "plt.title('A error')\n",
    "for prod, counts in zip(prods, enum):\n",
    "    dim, num_tasks, num_samples, low_rank_dim, sigma = prod\n",
    "    plt.semilogy(A_losses[*counts, :], label=f'Num Tasks={num_tasks}')\n",
    "plt.legend()\n",
    "plt.savefig('./images/A_losses.png')\n",
    "plt.show()"
   ],
   "id": "32de1d6df5cd2eaa",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "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F1+s6urqFs+1adMmxcXF6a9//ask6csvv9T48eMVERGhyMhIZWRkaOPGjadpvZaNGzdOU6dO1aBBg9S3b1/ddtttGjJkiD799NN2Ha+1/KbnpbP1jAiWJB2ssptcCQB4j2N1DqXds9zj581/YKLCgtr2J8xms+nBBx/Uz3/+c/3ud79TcnL7e9FXrFih5ORkrVq1Sp999pluuukmrV27VhdccIHWrVunnJwczZ49W5dccol69+7dpmMfP35cGRkZ+uMf/6jIyEi9++67mjFjhs4880yNGjVKxcXFuu666/Twww9r6tSpqqqq0urVq1sMdJ988ommTJmirKws/eY3v5EkXX/99frJT36iRYsWyWazKS8vT4GBgZKkwsJCpaWlnbK+X/ziF3ryySebrTcMQytWrNCOHTv00EMPtek7txXhpZV6djsRXo4SXgDAV02dOlXDhg3Tvffeq8WLF7f7ODExMfr73/8uq9WqAQMG6OGHH1ZNTY3uvvtuSdK8efO0YMECffbZZ7r22mvbdOxevXrp97//vWv51ltv1fvvv69XX33VFV7q6+t11VVXud4LOHjw4GbHeeuttzRjxgz985//1HXXXedaX1hYqLvuuksDBw6UJJ111lmubUlJScrLyztlfT9+dH9FRYV69eolu90um82mhQsX6pJLLmnTd24rvwkvnf2EXXpeAKC50ECb8h/ovLENpzpvez300EOaMGGC7rzzznYf4+yzz27ywLX4+Hilp6e7lm02m3r06KHS0tI2H9vhcGjBggXKycnRd999J7vdLrvdrvDwcEnS0KFDddFFF2nw4MGaOHGiMjMzNW3atCbjeNatW6d33nlHr776qqZOndrk+HPnztXNN9+sF198URdffLGuueYa9e3bV5IUEBCgfv36taneiIgI5eXl6ejRo/roo480d+5cnXnmmRo3blybv3tr+c2Yl85+wm7siZ6XimN1stfzCgIAkBpmzYQFBXj805EZQhdccIEmTpzo6iX5IavV2uz2S11dXbP9Gm+z/LAdWlrndDrbXN8jjzyixx57TH/4wx+0YsUK5eXlaeLEiaqtrZXUEIxyc3P13nvvKS0tTf/4xz80YMAAFRQUuI7Rt29fDRw4UEuWLHH9XqP77rtPX3/9tS6//HKtWLFCaWlpevPNNyU19Mp069btlJ/Zs2c3OZ7ValW/fv00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8e677xo7duwwduzYYdx9991GYGCgsXXrVsMwfOO6Iry0wjnnnGPMnj27ybqBAwcaf/rTn0yqyBz33nuvMXTo0Ba3OZ1OIyEhwViwYIFr3fHjx42oqCjjySefNAzDMI4cOWIEBgYaL7/8smuf7777zrBarcb777/fqbV70o//ILurbfLz8w1Jxueff+7aZ+3atYYkY/v27Z38rTrHycLLT3/605P+Tldtq9LSUkOSsXLlSsMwuK5O58ftZRhcW6fSvXt345lnnvGZ64rbRqdRW1urTZs2KTMzs8n6zMxMrVmzxqSqzLNr1y4lJSUpNTVV1157rfbs2SNJKigoUElJSZN2Cg4O1oUXXuhqp02bNqmurq7JPklJSUpPT/frtnRX26xdu1ZRUVEaNWqUa59zzz1XUVFRftd+n3zyieLi4tS/f3/96le/UmlpqWtbV22riooKSVJMTIwkrqvT+XF7NeLaasrhcOjll19WdXW1Ro8e7TPXFeHlNMrKyuRwOBQfH99kfXx8vEpKSkyqyhyjRo3SCy+8oOXLl+vpp59WSUmJxowZo/LycldbnKqdSkpKFBQUpO7du590H3/krrYpKSlRXFxcs+PHxcX5VftNmjRJ//73v7VixQo98sgj2rBhgyZMmCC73S6pa7aVYRiaO3euzj//fKWnp0viujqVltpL4tr6oS1btqhbt24KDg7W7Nmz9eabbyotLc1nrquADh+hi7BYLE2WDcNots7fTZo0yfXvwYMHa/To0erbt6+ef/5516C39rRTV2lLd7RNS/v7W/tNnz7d9e/09HSNGDFCKSkpevfdd3XVVVed9Pf8ua1uueUWffXVV/r000+bbeO6au5k7cW19b0BAwYoLy9PR44c0euvv66ZM2dq5cqVru3efl3R83IasbGxstlszZJiaWlps2Ta1YSHh2vw4MHatWuXa9bRqdopISFBtbW1Onz48En38UfuapuEhAQdOHCg2fEPHjzo1+2XmJiolJQU7dq1S1LXa6tbb71Vb7/9tj7++GMlJye71nNdtexk7dWSrnxtBQUFqV+/fhoxYoSysrI0dOhQ/e///q/PXFeEl9MICgpSRkaGcnNzm6zPzc3VmDFjTKrKO9jtdm3btk2JiYlKTU1VQkJCk3aqra3VypUrXe2UkZGhwMDAJvsUFxdr69atft2W7mqb0aNHq6KiQuvXr3fts27dOlVUVPh1+5WXl6uoqEiJiYmSuk5bGYahW265RW+88YZWrFih1NTUJtu5rpo6XXu1pKteWy0xDEN2u913rqsOD/ntAhqnSi9evNjIz883br/9diM8PNz49ttvzS7No+68807jk08+Mfbs2WN8/vnnxhVXXGFERES42mHBggVGVFSU8cYbbxhbtmwxrrvuuhan1yUnJxsffvih8cUXXxgTJkzwi6nSVVVVxubNm43NmzcbkoxHH33U2Lx5s2s6vbva5tJLLzWGDBlirF271li7dq0xePBgn5qiaRinbquqqirjzjvvNNasWWMUFBQYH3/8sTF69GijV69eXa6tfvOb3xhRUVHGJ5980mRqb01NjWsfrqvvna69uLa+N2/ePGPVqlVGQUGB8dVXXxl33323YbVajQ8++MAwDN+4rggvrZSdnW2kpKQYQUFBxvDhw5tMv+sqGuf6BwYGGklJScZVV11lfP31167tTqfTuPfee42EhAQjODjYuOCCC4wtW7Y0OcaxY8eMW265xYiJiTFCQ0ONK664wigsLPT0V3G7jz/+2JDU7DNz5kzDMNzXNuXl5cb1119vREREGBEREcb1119vHD582EPf0j1O1VY1NTVGZmam0bNnTyMwMNDo06ePMXPmzGbt0BXaqqU2kmQ8++yzrn24rr53uvbi2vrejTfe6Pp71rNnT+Oiiy5yBRfD8I3rymIYhtHx/hsAAADPYMwLAADwKYQXAADgUwgvAADApxBeAACATyG8AAAAn0J4AQAAPoXwAgAAfArhBQAA+BTCCwAA8CmEFwAA4FMILwAAwKf8f/GYOAlrxKLJAAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 139
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:21.448213Z",
     "start_time": "2024-09-16T17:01:21.212322Z"
    }
   },
   "cell_type": "code",
   "source": [
    "prods = product(dims_list, num_tasks_list, num_samples_list, low_rank_dim_list, sigma_list)\n",
    "enum = product(range(len(dims_list)), range(len(num_tasks_list)), range(len(num_samples_list)),\n",
    "               range(len(low_rank_dim_list)), range(len(sigma_list)))\n",
    "plt.figure('U_Losses')\n",
    "plt.title('U error')\n",
    "for prod, counts in zip(prods, enum):\n",
    "    dim, num_tasks, num_samples, low_rank_dim, sigma = prod\n",
    "    plt.semilogy(U_losses[*counts, :], label=f'Num Tasks={num_tasks}')\n",
    "plt.legend()\n",
    "plt.savefig('./images/U_losses.png')\n",
    "plt.show()"
   ],
   "id": "d6cae06ad3a6ffe0",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ],
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi8AAAGxCAYAAACqUFbqAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAABG4ElEQVR4nO3de1xUdf4/8NeZAYaLXEVugoh4RRByJJPShC0M01LTtZth22UprJR+1prtqu1umG1qrWgXM7ftW7nmZduyjFIExQwR8oJ5KQxUEEG56wzMnN8fyOQICgMzc5gzr+fjMY9lzjmc857zmJaXn/O5CKIoiiAiIiKyEQqpCyAiIiIyBcMLERER2RSGFyIiIrIpDC9ERERkUxheiIiIyKYwvBAREZFNYXghIiIim8LwQkRERDaF4YWIiIhsCsMLEXXL4sWLIQgCKisr290fGRmJ8ePHW7coIpI1hhciIiKyKQwvRGTzGhsb292u0+mg0Wgscm4ikg7DCxH1CKIoYvXq1YiJiYGLiwu8vb0xffp0/PLLL0bHjR8/HpGRkcjOzkZcXBxcXV3xhz/8AadOnYIgCFi2bBn+9re/ISwsDCqVCjt37gQAfP755xgzZgxcXV3h7u6OO++8E3v37jU6d+sjsAMHDmD69Onw9vZGeHi41e4BEXUOwwsR9Qh//OMfMXfuXNxxxx3YunUrVq9ejSNHjiAuLg7nzp0zOrasrAwPP/wwHnzwQWzbtg1PP/20Yd9bb72FHTt24B//+Ae++uorDB06FB9//DHuvfdeeHh44JNPPsH777+PixcvYvz48di9e3ebWqZNm4aBAwdi48aNePvtty3+2YnINA5SF0BE9P333+O9997DG2+8gbS0NMP2sWPHYvDgwVi+fDlee+01w/YLFy5g48aNSEhIMGw7deoUAMDZ2Rnbt2+Ho6MjAECv1+PWW29FVFQUvvrqKygULf9mmzhxIsLDw/Hiiy9iz549RvUkJydjyZIllvq4RNRNbHkhIsl98cUXEAQBDz/8MJqbmw2vgIAAREdHIysry+h4b29vo+BytXvuuccQXADg2LFjOHv2LGbNmmUILgDQq1cv3Hffffj+++/b9Gu57777zPfhiMjs2PJCRN3i4NDyfyM6na7d/c3NzUZhoj3nzp2DKIrw9/dvd/+AAQOM3gcGBl73XNfuq6qquu7vBAUFQa/X4+LFi3B1de3U+YlIegwvRNQtrYHjzJkzbcKHKIooKyvDqFGjbngOX19fCIKAnJwcqFSqNvuv3SYIwnXPde2+3r17A2jpJ3Ots2fPQqFQwNvbu9PnJyLp8bEREXVLQkICBEHAhg0b2uz7+uuvUVtbizvuuOOG55g0aRJEUcSZM2cwatSoNq+oqKgu1zdkyBD07dsXH3/8MURRNGxvaGjApk2bDCOQiMh2sOWFiLolPDwcc+bMweuvv47q6mpMnDgRLi4uyMvLw9KlSzFq1Cg8+OCDNzzHrbfeiieffBKPPvoo9u/fj3HjxsHNzQ1lZWXYvXs3oqKi8NRTT3WpPoVCgWXLluGhhx7CpEmT8Mc//hEajcZQ79KlS7t0XiKSDsMLEXXbm2++iYiICLz//vv46KOP0NzcjNDQUKSmpuLll1+Gk5NTh+d45513cMstt+Cdd97B6tWrodfrERQUhFtvvRU333xzt+p78MEH4ebmhvT0dMycORNKpRK33HILdu7cibi4uG6dm4isTxCvbkclIiIi6uHY54WIiIhsCsMLERER2RSGFyIiIrIpDC9ERERkUxheiIiIyKYwvBAREZFNkd08L3q9HmfPnoW7uzun+CYiIrIRoiiirq4OQUFBRouotqfHhZe6ujokJCSgqakJOp0Ozz77LJ544olO//7Zs2cREhJiwQqJiIjIUkpLSxEcHHzDY3rcJHU6nQ4ajQaurq5obGxEZGQk8vLyDIurdaSmpgZeXl4oLS2Fh4eHhaslIiIic6itrUVISAiqq6vh6el5w2N7XMuLUqk0LJJ2+fJl6HQ6mJKvWh8VeXh4MLwQERHZmM50+TB7h93s7GxMnjwZQUFBEAQBW7dubXPM6tWrERYWBmdnZ6jVauTk5Bjtr66uRnR0NIKDg/HCCy/A19fX3GUSERGRjTJ7eGloaEB0dDRWrVrV7v4NGzZg7ty5WLhwIQoKCjB27FgkJSWhpKTEcIyXlxd+/PFHFBcX4+OPP8a5c+fMXSYRERHZKIv2eREEAVu2bMGUKVMM20aPHo2RI0dizZo1hm3Dhg3DlClTkJ6e3uYcTz31FBISEjBjxox2r6HRaKDRaAzvW5+Z1dTU8LERERGRjaitrYWnp2en/n5btc+LVqtFfn4+/vSnPxltT0xMRG5uLgDg3LlzcHFxgYeHB2pra5GdnY2nnnrquudMT0/HkiVLLFo3ERH9RhRFNDc3Q6fTSV0K2RClUgkHBwezTGNi1fBSWVkJnU4Hf39/o+3+/v4oLy8HAJw+fRqPPfYYRFGEKIqYM2cORowYcd1zLliwAGlpaYb3rS0vRERkflqtFmVlZWhsbJS6FLJBrq6uCAwMhJOTU7fOI8loo2tTlyiKhm1qtRqFhYWdPpdKpYJKpUJGRgYyMjL4LwEiIgvR6/UoLi6GUqlEUFAQnJycOBkodYooitBqtTh//jyKi4sxaNCgDieiuxGrhhdfX18olUpDK0urioqKNq0xpkpNTUVqaqrhmRkREZmXVquFXq9HSEiIYUoLos5ycXGBo6Mjfv31V2i1Wjg7O3f5XFZd28jJyQlqtRqZmZlG2zMzMxEXF2fNUoiIqIu68y9msm/m+u6YveWlvr4eJ0+eNLwvLi5GYWEhfHx80K9fP6SlpWHWrFkYNWoUxowZg3fffRclJSVISUnp1nX52IiIiMg+mH2odFZWFuLj49tsT05Oxvr16wG0TFK3bNkylJWVITIyEitWrMC4cePMcn1ThloREVHnXb58GcXFxYZJRolMdaPvkKRDpcePH9/hdP5PP/00nn76aXNfmoiIyO7Nnj0b1dXV7c5wLxeyeXCZkZGBiIgIxMbGSl0KERH1MLNnz4YgCFi6dKnR9q1bt0oyYkoQhBu+Zs+ebfWaumLz5s0YNWoUvLy84ObmhpiYGPz73/+2+HVlE15SU1NRVFSEvLw8i5y/ql6DB9/7Hicr6ixyfiIisixnZ2e89tpruHjxotSloKyszPBauXIlPDw8jLa9+eabUpfYKT4+Pli4cCH27t2LgwcP4tFHH8Wjjz6K7du3W/S6sgkvlvb3bUeR+3MVXtpyWOpSiIh6DFEU0ahttvqrK90177jjDgQEBLS7FE2rxYsXIyYmxmjbypUr0b9/f8P72bNnY8qUKXj11Vfh7+8PLy8vLFmyBM3NzZg/fz58fHwQHByMdevWXfc6AQEBhpenpycEQTC8d3R0REpKCoKDg+Hq6oqoqCh88sknRr//2WefISoqCi4uLujduzfuuOMONDQ0tHut/Px8+Pn54e9//zsA4Mcff0R8fDzc3d3h4eEBtVqN/fv3d3D32jd+/HhMnToVw4YNQ3h4OJ577jmMGDECu3fv7tL5OkuSSeps0QM398PmA2fwU1mt1KUQEfUYl5p0iPiLZf+V3Z6iVybA1cm0P2FKpRKvvvoqHnzwQTz77LMIDg7u8vV37NiB4OBgZGdnY8+ePXjsscewd+9ejBs3Dvv27cOGDRuQkpKCO++80+RZ3y9fvgy1Wo0XX3wRHh4e+PLLLzFr1iwMGDAAo0ePRllZGR544AEsW7YMU6dORV1dHXJyctoNdFlZWYa1A1uX2nnooYdw0003Yc2aNVAqlSgsLISjoyMAoKSkBBERETes7+GHH8bbb7/dZrsoitixYweOHTuG1157zaTPbCrZhBdLD5UO9GzpFa1p1lvk/EREZHlTp05FTEwMFi1ahPfff7/L5/Hx8cFbb70FhUKBIUOGYNmyZWhsbMRLL70EoGXpmqVLl2LPnj24//77TTp337598f/+3/8zvH/mmWfw9ddfY+PGjYbw0tzcjGnTpiE0NBQAEBUV1eY8//3vfzFr1iy88847eOCBBwzbS0pKMH/+fAwdOhQAMGjQIMO+oKCgDme5v3YkUE1NDfr27QuNRgOlUonVq1fjzjvvNOkzm0o24cXSM+w6KVuesDXpGF6IiFq5OCpR9MoESa7bVa+99hoSEhLw/PPPd/kcw4cPN5pwzd/fH5GRkYb3SqUSvXv3RkVFhcnn1ul0WLp0KTZs2IAzZ85Ao9FAo9HAzc0NABAdHY3f/e53iIqKwoQJE5CYmIjp06fD29vbcI59+/bhiy++wMaNGzF16lSj86elpeHxxx/Hv//9b9xxxx2YMWMGwsPDAQAODg4YOHCgSfW6u7ujsLAQ9fX1+O6775CWloYBAwZg/PjxJn/2zmKfl05yvBJe9CKg05t1ahwiIpslCAJcnRys/urOCKFx48ZhwoQJhlaSqykUijaPX5qamtoc1/qY5er70N42vd70f/C+8cYbWLFiBV544QXs2LEDhYWFmDBhArRaLYCWYJSZmYmvvvoKERER+Oc//4khQ4aguLjYcI7w8HAMHToU69atM/xeq8WLF+PIkSO4++67sWPHDkRERGDLli0AWlplevXqdcPXtZPKKhQKDBw4EDExMXj++ecxffr0G/YrMgfZtLxYmoPyt/9QmnR6KBVdT/1ERCStpUuXIiYmBoMHDzba3qdPH5SXlxstGGzKYsHmkJOTg3vvvRcPP/wwgJYFMU+cOIFhw4YZjhEEAbfeeituvfVW/OUvf0FoaCi2bNmCtLQ0AC1rCW7evBnjx4/HzJkz8Z///McoXA0ePBiDBw/GvHnz8MADD+CDDz7A1KlTu/TY6FqiKEKj0XTx03eObMKLpfu8tLa8AC3hxbkbTZZERCStqKgoPPTQQ/jnP/9ptH38+PE4f/48li1bhunTp+Prr7/GV199ZdUZ2wcOHIhNmzYhNzcX3t7eWL58OcrLyw3hZd++ffjuu++QmJgIPz8/7Nu3D+fPnzcKNwDg5+eHHTt2ID4+Hg888AA+/fRTNDU1Yf78+Zg+fTrCwsJw+vRp5OXl4b777gNg+mOj9PR0jBo1CuHh4dBqtdi2bRs+/PBDrFmzxnw3pB2yeWxk6Xlerg4vzTo+NiIisnV//etf2zwiGjZsGFavXo2MjAxER0fjhx9+MOo8aw1//vOfMXLkSEyYMAHjx49HQEAApkyZYtjv4eGB7OxsTJw4EYMHD8bLL7+MN954A0lJSW3OFRAQgB07duDQoUN46KGHoFAoUFVVhUceeQSDBw/G73//eyQlJWHJkiVdqrWhoQFPP/00hg8fjri4OHz22Wf46KOP8Pjjj3f143eK2dc2kpol1zYasOBL6EXgh5d+Bz8PrutBRPaFaxtRd5lrbSPZtLxYg+LK80/21yUiIpIOw4sJFIrW8ML0QkREJBXZhBdrLMx4JbtwqDQREZGEZBNeLN1hFwCUVx4bseGFiIhIOrIJL9bQ2udFx/RCRHZMZuM8yIrM9d1heDEB+7wQkT1rneSssbFR4krIVrV+d66djdhUspmkzhpa+7zo2eeFiOyQUqmEl5eXYb0eV1fXbk3TT/ZDFEU0NjaioqICXl5eUCq7N9Erw4sJlAoOlSYi+xYQEAAAXVpwkMjLy8vwHeoO2YQXSy8PAMDwLwyONiIieyUIAgIDA+Hn59fugoVE1+Po6NjtFpdWsgkvqampSE1NNczQZwlKgX1eiIiAlkdI5vpDRGQqdtg1gaHPC8MLERGRZBheTNA62oiPjYiIiKTD8GICrm1EREQkPYYXEyg5zwsREZHkGF5MIHCeFyIiIskxvJhAyeUBiIiIJMfwYgIFF2YkIiKSHMOLCTjaiIiISHqyCS8ZGRmIiIhAbGysxa6hvHK32GGXiIhIOrIJL6mpqSgqKkJeXp7FrqHgDLtERESSk014sQZDeNFLXAgREZEdY3gxQevyABxtREREJB2GFxO0TlInMrwQERFJhuHFBELrPC98bERERCQZhhcTKNlhl4iISHIMLyZQcKg0ERGR5BheTMCh0kRERNJjeDGBgn1eiIiIJNfjwktpaSnGjx+PiIgIjBgxAhs3bpS6JIPW0UZseSEiIpKOg9QFXMvBwQErV65ETEwMKioqMHLkSEycOBFubm5Sl2aY50XPtY2IiIgk0+PCS2BgIAIDAwEAfn5+8PHxwYULF3pIeGlteZG4ECIiIjtm9sdG2dnZmDx5MoKCgiAIArZu3drmmNWrVyMsLAzOzs5Qq9XIyclp91z79++HXq9HSEiIucvsEkOfFz42IiIikozZw0tDQwOio6OxatWqdvdv2LABc+fOxcKFC1FQUICxY8ciKSkJJSUlRsdVVVXhkUcewbvvvmvuEruMM+wSERFJz+yPjZKSkpCUlHTd/cuXL8djjz2Gxx9/HACwcuVKbN++HWvWrEF6ejoAQKPRYOrUqViwYAHi4uJueD2NRgONRmN4X1tba4ZP0T6hdW0jPjciIiKSjFVHG2m1WuTn5yMxMdFoe2JiInJzcwG0tGrMnj0bCQkJmDVrVofnTE9Ph6enp+FlyUdMv402stgliIiIqANWDS+VlZXQ6XTw9/c32u7v74/y8nIAwJ49e7BhwwZs3boVMTExiImJwaFDh657zgULFqCmpsbwKi0ttVj9hg67TC9ERESSkWS0UesCh61EUTRsu+2226DXd34WOJVKBZVKhYyMDGRkZECn05m11quxwy4REZH0rNry4uvrC6VSaWhlaVVRUdGmNcZUqampKCoqQl5eXrfOcyOGeV4YXoiIiCRj1fDi5OQEtVqNzMxMo+2ZmZkddsztCQx9XvjYiIiISDJmf2xUX1+PkydPGt4XFxejsLAQPj4+6NevH9LS0jBr1iyMGjUKY8aMwbvvvouSkhKkpKR067rWeGwkcJI6IiIiyZk9vOzfvx/x8fGG92lpaQCA5ORkrF+/HjNnzkRVVRVeeeUVlJWVITIyEtu2bUNoaGi3rpuamorU1FTU1tbC09OzW+e6HuWVdioOlSYiIpKO2cPL+PHjO5zE7emnn8bTTz9t7ktbXGuHXU5SR0REJJ0et6p0V2VkZCAiIgKxsbEWuwZHGxEREUlPNuHFOqON2OeFiIhIarIJL9bQ2ueFo42IiIikI5vwYo3HRu7OjgCAd7J/wU/llltDiYiIiK5PNuHFGo+NYkK8DD8/vHYfmnSdnwmYiIiIzEM24cUaxg3ug48fHw0AqKzX4lh5ncQVERER2R+GFxPFDfTFLQN8AADHzzG8EBERWRvDSxcEeroAAM7XaSSuhIiIyP7IJrxYo8NuK99eTgCAynqGFyIiImuTTXixRofdVn3cVQDY8kJERCQF2YQXa/JybWl5qb7UJHElRERE9ofhpQu8XFrme6lheCEiIrI6hpcuaG15qWlkeCEiIrI22YQXa3bY9XJtaXnhYyMiIiLrk014sWaHXc8rj42qG7Vc54iIiMjKZBNerKk1vOhFoF7bLHE1RERE9oXhpQucHZVwdmy5dez3QkREZF0ML13k5XKl0y77vRAREVkVw0sX/dbvheGFiIjImmQTXqw52ggAPA0jjrRWuR4RERG1kE14seZoI+C3ierY8kJERGRdsgkv1tY61wv7vBAREVkXw0sXeXKJACIiIkkwvHSRYXHGRvZ5ISIisiaGly7iaCMiIiJpMLx0Edc3IiIikgbDSxe1TlJXy/BCRERkVQwvXcTHRkRERNJgeOmi1sdGF9lhl4iIyKpkE16sPcNu714tj400zXouzkhERGRFsgkv1p5h19XJAX3cVQCAXy80WOWaREREJKPwIoVQH1cAwK9VjRJXQkREZD8YXrqh35XwUnKB4YWIiMhaGF66IbS3GwDg5/P1EldCRERkPxheumFooDsAoOhsrcSVEBER2Q+Gl24YHuQBADhZUQ9Ns07iaoiIiOwDw0s39PVygZerI5r1Io6X89ERERGRNTC8dIMgCIbWlyNnaySuhoiIyD4wvHRTZF9PAMCPp6ulLYSIiMhO9MjwMnXqVHh7e2P69OlSl9IhdT9vAMD+UxclroSIiMg+9Mjw8uyzz+LDDz+UuoxOUYe2hJcTFfWo5jpHREREFtcjw0t8fDzc3d2lLqNTevdSYUCflvle8n9l6wsREZGlmT28ZGdnY/LkyQgKCoIgCNi6dWubY1avXo2wsDA4OztDrVYjJyfH3GVY1agrrS/7GV6IiIgszuzhpaGhAdHR0Vi1alW7+zds2IC5c+di4cKFKCgowNixY5GUlISSkhJzl2I1o0J9AAD57PdCRERkcQ7mPmFSUhKSkpKuu3/58uV47LHH8PjjjwMAVq5cie3bt2PNmjVIT083+XoajQYajcbwvrbW+rPdqvu3tLwUnq7G5SYdnB2VVq+BiIjIXli1z4tWq0V+fj4SExONticmJiI3N7dL50xPT4enp6fhFRISYo5STTLA1w193FXQNutRWFpt9esTERHZE6uGl8rKSuh0Ovj7+xtt9/f3R3l5ueH9hAkTMGPGDGzbtg3BwcHIy8u77jkXLFiAmpoaw6u0tNRi9V+PIAiIC+8NAMj9ucrq1yciIrInZn9s1BmCIBi9F0XRaNv27ds7fS6VSgWVSoWMjAxkZGRAp5NmjaG48N74b+FZ7P25ErhzsCQ1EBER2QOrtrz4+vpCqVQatbIAQEVFRZvWGFOlpqaiqKjohq00lhQX7gsAKCipRqO2WZIaiIiI7IFVw4uTkxPUajUyMzONtmdmZiIuLs6apZhdiI8rgr1d0KwXkcdRR0RERBZj9vBSX1+PwsJCFBYWAgCKi4tRWFhoGAqdlpaGtWvXYt26dTh69CjmzZuHkpISpKSkdOu6GRkZiIiIQGxsbHc/Qpf91u+lUrIaiIiI5E4QRVE05wmzsrIQHx/fZntycjLWr18PoGWSumXLlqGsrAyRkZFYsWIFxo0bZ5br19bWwtPTEzU1NfDw8DDLOTtra8EZzN1QiBHBnvh8zm1WvTYREZEtM+Xvt9nDi9SkDC/nai9j9KvfQSEABX9OhKero1WvT0REZKtM+fvdI9c26oqe8NjI38MZ4X3coBeBvb/w0REREZElyCa8SD3aqNXYQX0AALuOn5e0DiIiIrmSTXjpKcYPaQkvWcfOQ2ZP5IiIiHoE2YSXnvDYCABuGdAbKgcFymou40RFvaS1EBERyZFswktPeWzk7KjELQNahkxnHauQtBYiIiI5kk146UmufnRERERE5sXwYgG3D24JL3mnLqBBw6UCiIiIzInhxQLCfN3Qz8cVTTqRq0wTERGZmWzCS0/psAu0rJrd2vqy6zj7vRAREZmTbMJLT+mw26q138vOnzhkmoiIyJxkE156mlsH+sLFUYkz1Zdw5Gyt1OUQERHJBsOLhTg7KjF2kC8AILPonMTVEBERyQfDiwUlDg8AAHzD8EJERGQ2sgkvPanDbqvfDfWDQgCOltWi9EKj1OUQERHJgmzCS0/rsAsA3m5OiO3vA4CPjoiIiMxFNuGlp2p9dMTwQkREZB4MLxaWGOEPAPjh1AVUN2olroaIiMj2MbxYWIiPK4YGuEOnF/HdUU5YR0RE1F0ML1bQ+ujoq8NlEldCRERk+2QTXnriaKNWk0YEAgCyj1ei5lKTxNUQERHZNtmEl5442qjVYH93DPbvBa1Oz467RERE3SSb8NLT3R0VBAD44uBZiSshIiKybQwvVjIpuuXR0e4TlbjYwFFHREREXcXwYiXhfXphWKAHmvUivikql7ocIiIim8XwYkWtHXe/OMhRR0RERF3F8GJFreEl9+cqVNVrJK6GiIjINjG8WFFobzdE9fWETi9i2yG2vhAREXUFw4uV3RvTMupoc8EZiSshIiKyTQwvVnZPTBCUCgEFJdX4+Xy91OUQERHZHNmEl548w+7V/NydMW6QLwBgywG2vhAREZlKNuGlJ8+we61pI4MBAFsKzkCvFyWuhoiIyLbIJrzYkjsj/OHu7IAz1Zewr/iC1OUQERHZFIYXCTg7Kg3DpjcfOC1xNURERLaF4UUirY+Oth0qQ6O2WeJqiIiIbAfDi0RGhXqjn48rGrQ6fH2YywUQERF1FsOLRARBwAx1S+vLpz+USlwNERGR7WB4kdCMUSFQKgT8cOoCTlbUSV0OERGRTWB4kVCApzMShvoBAD5h6wsREVGnMLxI7MGb+wEANh04jctNOomrISIi6vl6ZHj54osvMGTIEAwaNAhr166VuhyLGje4D4I8nVHd2ITtR9hxl4iIqCM9Lrw0NzcjLS0NO3bswIEDB/Daa6/hwgX5TuSmVAiYGdvS+vLxvhKJqyEiIur5elx4+eGHHzB8+HD07dsX7u7umDhxIrZv3y51WRb1+9hgKARgX/EFLtZIRETUAbOHl+zsbEyePBlBQUEQBAFbt25tc8zq1asRFhYGZ2dnqNVq5OTkGPadPXsWffv2NbwPDg7GmTPyXsAw0NPF0HH3/75n6wsREdGNmD28NDQ0IDo6GqtWrWp3/4YNGzB37lwsXLgQBQUFGDt2LJKSklBS0vJHWxTbLlQoCMJ1r6fRaFBbW2v0skUP3xIKANi4vxQNGs64S0REdD1mDy9JSUn429/+hmnTprW7f/ny5Xjsscfw+OOPY9iwYVi5ciVCQkKwZs0aAEDfvn2NWlpOnz6NwMDA614vPT0dnp6ehldISIh5P5CVjBvUBwN83VCnaeZ6R0RERDdg1T4vWq0W+fn5SExMNNqemJiI3NxcAMDNN9+Mw4cP48yZM6irq8O2bdswYcKE655zwYIFqKmpMbxKS21zvhSFQkByXH8AwPrcU9Dr27ZAERERkZXDS2VlJXQ6Hfz9/Y22+/v7o7y8ZZiwg4MD3njjDcTHx+Omm27C/Pnz0bt37+ueU6VSwcPDw+hlq+5TB6OXygE/n2/A7pOVUpdDRETUI0ky2ujaPiyiKBptu+eee3D8+HGcPHkSTz75ZKfOmZGRgYiICMTGxpq1VmvqpXLAjFEt6x2tzz0lbTFEREQ9lFXDi6+vL5RKpaGVpVVFRUWb1hhTpaamoqioCHl5ed06j9SSx/SHIAA7fqpAcWWD1OUQERH1OFYNL05OTlCr1cjMzDTanpmZibi4OGuW0mP193VD/JCWYdP/YusLERFRG2YPL/X19SgsLERhYSEAoLi4GIWFhYah0GlpaVi7di3WrVuHo0ePYt68eSgpKUFKSkq3riuHx0atZl/puLtxfylqGpukLYaIiKiHEcT2JlbphqysLMTHx7fZnpycjPXr1wNomaRu2bJlKCsrQ2RkJFasWIFx48aZ5fq1tbXw9PRETU2NzXbeFUURSW/m4KfyOsyfMASp8QOlLomIiMiiTPn7bfbwIjU5hBcA2FJwGvM2/AjfXk7Y/WICnB2VUpdERERkMab8/e5xaxt1lZweGwHApBFB6Ovlgsp6LTYfkPfyCERERKaQTXiRy2ijVo5KBR67LQwA8F7OL9Bx0joiIiIAMgovcjQzNgSeLo4ormzAN0fKO/4FIiIiOyCb8CK3x0YA4KZywCNjWhZsfHvXz+0uWklERGRvZBNe5PbYqFVyXH+oHBT48XQNvv/lgtTlEBERSU424UWufHupDEsGrNp5QuJqiIiIpMfwYgNSbg+Ho1LAnpNV2H+KrS9ERGTfZBNe5NjnpVWwtyumq1taX978jq0vRERk3zhJnY0ovdCI+H9koVkvYvPTcRjZz1vqkoiIiMzGLiepk7sQH1dMG9kXAPDmt2x9ISIi+8XwYkNS4wdCqRCw6/h5FJZWS10OERGRJBhebEhobzdMiWlpfXmLfV+IiMhOMbzYmDkJA6EQgB0/VeDg6WqpyyEiIrI62YQXOY82ulqYrxum3NTS+vKPb45LXA0REZH1cbSRDSqpakTCGy0jjz598hbcMqC31CURERF1C0cbyVy/3q64/+YQAMDr249xzSMiIrIrDC826tmEQXB2VCD/14vY8VOF1OUQERFZDcOLjfLzcEZyXH8ALa0vej1bX4iIyD4wvNiwp24Ph7vKAT+V1+F/B89KXQ4REZFVyCa82Mtoo6t5uTrhyXEDAAArMo+jSaeXuCIiIiLLk014SU1NRVFREfLy8qQuxar+cFsYers54VRVI/6zv1TqcoiIiCxONuHFXrmpHDAnYSAAYEXmCTRomiWuiIiIyLIYXmTgodGhCO3tisp6Dd7J/kXqcoiIiCyK4UUGnBwU+NNdQwEA72b/jPKayxJXREREZDkMLzJxV2QA1KHeuNykx/LMY1KXQ0REZDEMLzIhCAIW3j0MALAx/zSOltVKXBEREZFlMLzIyMh+3rh7RCBEEXh121GpyyEiIrIIhheZeXHCUDgqBeScqMSu4+elLoeIiMjsZBNe7HGSuvb06+2K5DH9AQCvfnkUOi4bQEREMiOIMluS2JQlteWqulGL21/PQs2lJrw6NQoPju4ndUlEREQ3ZMrfb9m0vNBvvFyd8OzvBgEA/vHNMdRcapK4IiIiIvNheJGpR8aEYqBfL1xo0OLNb09IXQ4REZHZMLzIlKNSgT9PigAAfLj3FE5W1ElcERERkXkwvMjY7YP74I5hfmjWi3jli6OQWfcmIiKyUwwvMvfy3RFwUiqQffw8vjtaIXU5RERE3cbwInP9fd3wh9vCAAB//bIImmadxBURERF1D8OLHZiTMBB+7ir8WtWID/ackrocIiKibmF4sQO9VA548cqq0//87gQqarnqNBER2S6GFzsx9aa+iAnxQoNWh9e+5qrTRERku3pkeJk6dSq8vb0xffp0qUuRDYVCwOJ7hgMANh04jfxfL0hcERERUdf0yPDy7LPP4sMPP5S6DNmJCfHC70cFAwBe3noEzTq9xBURERGZrkeGl/j4eLi7u0tdhiy9eNdQeLo44mhZLT76/lepyyEiIjKZyeElOzsbkydPRlBQEARBwNatW9scs3r1aoSFhcHZ2RlqtRo5OTnmqJXMoHcvFV64awgA4I1vjqOijp13iYjItpgcXhoaGhAdHY1Vq1a1u3/Dhg2YO3cuFi5ciIKCAowdOxZJSUkoKSkxHKNWqxEZGdnmdfbsWZM/gEajQW1trdGLbuz+2H6IDvZEnaYZ6dt+krocIiIikwhiN+aMFwQBW7ZswZQpUwzbRo8ejZEjR2LNmjWGbcOGDcOUKVOQnp7e6XNnZWVh1apV+Oyzz2543OLFi7FkyZI22zuzpLY9O3i6Gvdm7IEoAp8+eQtuGdBb6pKIiMiO1dbWwtPTs1N/v83a50Wr1SI/Px+JiYlG2xMTE5Gbm2vOSxksWLAANTU1hldpaalFriM3I4K98ODN/QAAf/nvYTSx8y4REdkIs4aXyspK6HQ6+Pv7G2339/dHeXl5p88zYcIEzJgxA9u2bUNwcDDy8vKue6xKpYKHh4fRizpn/oQh8HFzwvFz9fhgT7HU5RAREXWKRUYbCYJg9F4UxTbbbmT79u04f/48Ghsbcfr0acTGxnb4OxkZGYiIiOjUsdTCy9UJf0pqmXl35bcnUFZzSeKKiIiIOmbW8OLr6wulUtmmlaWioqJNa4y5paamoqio6IatNNTW9JHBUId6o1Grw9++OCp1OURERB0ya3hxcnKCWq1GZmam0fbMzEzExcWZ81JtsOWlaxQKAX+9NxIKAfjyUBmyj5+XuiQiIqIbMjm81NfXo7CwEIWFhQCA4uJiFBYWGoZCp6WlYe3atVi3bh2OHj2KefPmoaSkBCkpKWYt/Fpseem6iCAPJMf1BwAs+vwILjfppC2IiIjoBhxM/YX9+/cjPj7e8D4tLQ0AkJycjPXr12PmzJmoqqrCK6+8grKyMkRGRmLbtm0IDQ01X9Vkdml3DsaXB8tQXNmANVk/Y96dg6UuiYiIqF3dmuelJzJlnDgZ+/JgGVI/PgAnpQLbnhuLgX69pC6JiIjshGTzvEiJfV66b2JUAOKH9IFWp8fCLYcgs1xLREQywZYXMlJ6oRF3rtiFy016vD59BGaMCpG6JCIisgN22fJC5hHi44p5d7T0d3l121FcaNBKXBEREZEx2YQXPjYynz/cFoahAe642NiEv3/JuV+IiKhn4WMjateBkou4b00uRBH4+InRiAv3lbokIiKSMT42om4b2c8bD49uGd7+8pbDnPuFiIh6DIYXuq75dw1BH3cVfrky9wsREVFPIJvwwj4v5ufh7IjFk4cDANZk/YyTFfUSV0RERMQ+L9QBURTxh/V52HnsPEaH+eDTJ28xaYVwIiKizmCfFzIbQRDwyr2RcHZUYF/xBXyWf1rqkoiIyM4xvFCHrp775e/bjqKqXiNxRUREZM8YXqhTWud+qW5swt849wsREUlINuGFHXYty1GpwNL7RkAhAFsKziDrWIXUJRERkZ1ih10yyV+/KML7u4vR18sF38wbBzeVg9QlERGRDLDDLlnM84mDEeztgjPVl/CPb45JXQ4REdkhhhcyiauTA16dGgUAWJ97CgdKLkpcERER2RuGFzLZuMF9MG1kX4gi8KdNB6Ft1ktdEhER2RGGF+qSP98dgd5uTjh+rh5v7+LSAUREZD0ML9Ql3m5OWHRPy9IBq3acxMmKOokrIiIieyGb8MKh0tY3eUQgEob6QavT48VNh6DXy2rgGhER9VAcKk3dcqb6EhKX70KDVodX7h2OR8b0l7okIiKyQRwqTVbT18sFLyYNBQC89tVPOFt9SeKKiIhI7hheqNseHh0Kdag3GrQ6/HnrYcisMY+IiHoYhhfqNoVCwNJpUXBSKvDdTxX438EyqUsiIiIZY3ghsxjk747U+IEAgCWfH8HFBq3EFRERkVwxvJDZPDU+HIP9e6GqQYu/flkkdTlERCRTDC9kNk4OLStPCwKw+cAZ7Dp+XuqSiIhIhhheyKxG9vPG7Lj+AIAFmw6i7nKTtAUREZHsyCa8cJK6nmP+hCHo5+OKszWXsfSrn6Quh4iIZIaT1JFF5P5ciQff2wcA+Pjx0Ygb6CtxRURE1JNxkjqSXFy4Lx4a3Q8A8OLmg2jQNEtcERERyQXDC1nMgonD0NfLBaUXLuH17cekLoeIiGSC4YUsppfKAenTogAA63NP4YfiCxJXREREcsDwQhY1bnAfzBwVAgB4cdNBXNLqJK6IiIhsHcMLWdxLdw+Dv4cKxZUNWJ7Jx0dERNQ9DC9kcZ4ujobHR+/vLsaBkosSV0RERLaM4YWsImGoP6bd1Bd6EXjhs4O43MTHR0RE1DUML2Q1f5kcAd9eKpysqMdb352QuhwiIrJRDC9kNV6uTvjblEgAwDvZv+DQ6RqJKyIiIlvU48JLaWkpxo8fj4iICIwYMQIbN26UuiQyo7siAzBpRCB0ehHzP/sR2ma91CUREZGN6XHhxcHBAStXrkRRURG+/fZbzJs3Dw0NDVKXRWa05J7h8HFzwk/ldcjYeVLqcoiIyMb0uPASGBiImJgYAICfnx98fHxw4QInN5OT3r1UWHLPcABAxs6TOHKWj4+IiKjzTA4v2dnZmDx5MoKCgiAIArZu3drmmNWrVyMsLAzOzs5Qq9XIycnpUnH79++HXq9HSEhIl36feq5JIwJx1/AANOtFPP+fH6Fp5ugjIiLqHJPDS0NDA6Kjo7Fq1ap292/YsAFz587FwoULUVBQgLFjxyIpKQklJSWGY9RqNSIjI9u8zp49azimqqoKjzzyCN59990b1qPRaFBbW2v0op5PEAT8bWqk4fERRx8REVFnCaIoil3+ZUHAli1bMGXKFMO20aNHY+TIkVizZo1h27BhwzBlyhSkp6d36rwajQZ33nknnnjiCcyaNeuGxy5evBhLlixps70zS2qT9L4+XIaUjw5AIQCbnorDTf28pS6JiIgkUFtbC09Pz079/TZrnxetVov8/HwkJiYabU9MTERubm6nziGKImbPno2EhIQOgwsALFiwADU1NYZXaWlpl2onadwVGYgpMUHQi8Dz//mRax8REVGHzBpeKisrodPp4O/vb7Td398f5eXlnTrHnj17sGHDBmzduhUxMTGIiYnBoUOHrnu8SqWCh4eH0Ytsy5J7IuHvocIvlQ14fTvXPiIiohtzsMRJBUEwei+KYptt13PbbbdBrzd97o+MjAxkZGRAp+O/3G2Np6sjlt43Ao9+kId1e4pxZ4Q/xoT3lrosIiLqocza8uLr6wulUtmmlaWioqJNa4y5paamoqioCHl5eRa9DllG/BA/PHBzy6iy+Z/9iHpNs8QVERFRT2XW8OLk5AS1Wo3MzEyj7ZmZmYiLizPnpdrIyMhAREQEYmNjLXodspyFd0cg2NsFpy9ewt+/PCp1OURE1EOZHF7q6+tRWFiIwsJCAEBxcTEKCwsNQ6HT0tKwdu1arFu3DkePHsW8efNQUlKClJQUsxZ+Lba82L5eKge8Pj0aAPDJDyXIOlYhcUVERNQTmTxUOisrC/Hx8W22JycnY/369QBaJqlbtmwZysrKEBkZiRUrVmDcuHFmKbgjpgy1op5pyf+O4IM9p+DvocI3c2+Hp6uj1CUREZGFmfL3u1vzvPQkV3fYPX78OMOLDbuk1eHut3LwS2UDpt7UFytmxkhdEhERWZhdhpdWbHmRhwMlFzF9TS70IvD2w2rcFRkgdUlERGRBkk1SR2QuI/t5I+X2cADAwi2HcL5OI3FFRETUUzC8UI/13B2DMDTAHVUNWrzw2Y+QWSMhERF1kWzCC4dKy4/KQYk3778JTg4K7Dx2Hh/tK+n4l4iISPbY54V6vHW7i/HKF0VwdlTgi2fGYqBfL6lLIiIiM2OfF5KV2XH9MXaQLy436TF3QwG0zaYvH0FERPLB8EI9nkIh4B8zouHl6ojDZ2qx8tvjUpdEREQSkk14YZ8XefP3cMbSaVEAgDW7fsYPxRckroiIiKTCPi9kU+Zv/BEb80+jr5cLvpo7Fh7OnH2XiEgO2OeFZGvRPcPRz8cVZ6ovYdF/j0hdDhERSYDhhWxKL5UDVsyMgUIAthScwec/npW6JCIisjKGF7I56lBvzEkYBAB4ecshnL7YKHFFRERkTbIJL+ywa1+eTRiImBAv1F5uxnOfFqJZx+HTRET2gh12yWaVXmjExDdzUKdpRmp8OOZPGCp1SURE1EXssEt2IcTHFUvvGwEAWJ31M3afqJS4IiIisgaGF7Jpd48IxAM394MoAvP+U8jVp4mI7ADDC9m8v0yKwGD/Xjhfp0Hafwqh18vqSSgREV2D4YVsnouTEqseHAlnRwVyTlTi3ZxfpC6JiIgsiOGFZGGwvzsWTx4OAPjH9mM4UHJR4oqIiMhSZBNeOFSaZsaGYNKIQDTrRTz7SQFqLjVJXRIREVkAh0qTrNRebsKkt3aj5EIj7hjmj3dnqaFQCFKXRUREHeBQabJbHs6OyHhwJJyUCnx79BzeyWb/FyIiuWF4IdmJCvbEkntb+r+8vv0n5P7M+V+IiOSE4YVk6f7YEExXB0MvAs9+UoDymstSl0RERGbC8EKyJAgC/npvJIYFeqCyXovUjw+giesfERHJAsMLyZaLkxJrHhoJd2cH5P96EenbfpK6JCIiMgOGF5K1/r5ueGNGNABg3Z5ifHHwrMQVERFRdzG8kOwlDg/AU+PDAQDzNx5E0dlaiSsiIqLukE144SR1dCPP3zkYYwf54lKTDk98uB9V9VzAkYjIVnGSOrIbNY1NuDdjN05VNeLmMB989NhoODnIJr8TEdk0TlJH1A5PV0esTR6FXioH/FB8AYv/d0TqkoiIqAsYXsiuDPRzx1sPxEAQgI/3leDf3/8qdUlERGQihheyOwlD/fHChKEAgCWfH+EMvERENobhhexSyu0DcG9MEJr1IlL+nY+TFXVSl0RERJ3E8EJ2SRAEvHbfCIzs54Xay82Y/UEeKuq4hAARkS1geCG75eyoxHuPjEL/3q44ffESHlu/H43aZqnLIiKiDjC8kF3r3UuF9Y/eDB83Jxw6U4NnPi5AM9dAIiLq0RheyO7193XDe4+MgspBge9+qsDi/x2BzKY/IiKSFYYXIgDqUG+8eX/LEOqPvi/Bm9+dkLokIiK6jh4XXurq6hAbG4uYmBhERUXhvffek7okshN3RQZi0aQIAMDKb0/g/d3FEldERETtcZC6gGu5urpi165dcHV1RWNjIyIjIzFt2jT07t1b6tLIDsy+NQy1l5uxPPM4/vpFEdxVDvh9bIjUZRER0VV6XMuLUqmEq6srAODy5cvQ6XTsf0BW9UzCQDwxNgwA8KfNB7HtUJnEFRER0dVMDi/Z2dmYPHkygoKCIAgCtm7d2uaY1atXIywsDM7OzlCr1cjJyTHpGtXV1YiOjkZwcDBeeOEF+Pr6mlomUZcJgoCXJg7D/bEh0IvAc58W4Luj56Qui4iIrjA5vDQ0NCA6OhqrVq1qd/+GDRswd+5cLFy4EAUFBRg7diySkpJQUlJiOEatViMyMrLN6+zZswAALy8v/PjjjyguLsbHH3+Mc+eu/4dDo9GgtrbW6EXUXYIg4O9TozBpRCCadCJSPsrH9iPlUpdFREQABLEbz2QEQcCWLVswZcoUw7bRo0dj5MiRWLNmjWHbsGHDMGXKFKSnp5t8jaeeegoJCQmYMWNGu/sXL16MJUuWtNnemSW1iTrSpNNj7oZCfHmwDA4KAW89cBMmRgVKXRYRkezU1tbC09OzU3+/zdrnRavVIj8/H4mJiUbbExMTkZub26lznDt3ztB6Ultbi+zsbAwZMuS6xy9YsAA1NTWGV2lpadc/ANE1HJUKvDkzxrAO0jOfFOB/P56VuiwiIrtm1tFGlZWV0Ol08Pf3N9ru7++P8vLONbmfPn0ajz32GERRhCiKmDNnDkaMGHHd41UqFVQqVbfqJroRB6UCy38fA6VCwOYDZ/DcpwVo1DZjZmw/qUsjIrJLFhkqLQiC0XtRFNtsux61Wo3CwkKTr5mRkYGMjAzodDqTf5eoI0qFgNenR8NRocCG/aV4cdMhVNRqMCdhYKe/20REZB5mfWzk6+sLpVLZppWloqKiTWuMuaWmpqKoqAh5eXkWvQ7ZL6VCwNL7opAaHw4AeCPzOP7838PQ6TmUn4jImswaXpycnKBWq5GZmWm0PTMzE3Fxcea8VBsZGRmIiIhAbGysRa9D9k0QBMyfMBSLJ0cYlhJ4+v/yuRo1EZEVmRxe6uvrUVhYaHi0U1xcjMLCQsNQ6LS0NKxduxbr1q3D0aNHMW/ePJSUlCAlJcWshV+LLS9kTbNvDcOqB0bCSanA9iPnMH3NXpypviR1WUREdsHkodJZWVmIj49vsz05ORnr168H0DJJ3bJly1BWVobIyEisWLEC48aNM0vBHTFlqBVRd+WduoCUf+ejqkGL3m5OeHuWGrH9faQui4jI5pjy97tb87z0JFd32D1+/DjDC1nNmepLeOJf+1FUVgtHpYC/TB6Oh0f3Y0deIiIT2GV4acWWF5JCo7YZ8zcexJdX1kG6OyoQr06LgqeLo8SVERHZBskmqSOyV65ODlj14E1YOHEYHBQCvjxUhrvfykFhabXUpRERyQ7DC5GZCIKAJ8YNwGdPxSHExwWnL17C9DW5WJF5HNpmvdTlERHJhmzCC4dKU08RE+KFL54Zi7ujAtGsF/Hmdydwz6rdOHymRurSiIhkgX1eiCxEFEV8cbAMiz4/ggsNWigVAp4YOwDPJAyEm8oik1sTEdks9nkh6gEEQcDk6CBkzhuHu0cEQqcX8faun5HwRha2FpyBzP7dQERkNWx5IbKSzKJz+OsXRSi50AgAGBXqjQUTh0Ed6i1xZURE0rPLodKc54VsweUmHd7fXYxVO07iUlPLIqLjh/RB2p2DMSLYS9riiIgkZJfhpRVbXsgWlNVcwsrME/jswGnDwo53DPPDk+PCEdvfmxPcEZHdYXhheCEbcaqyAW99dwJbC8+gdXHqqL6eeHxsGCZGBcJRyW5pRGQfGF4YXsjG/Hy+HmtzirH5wGlorswJ49tLhWkj+2KGOhiD/N0lrpCIyLIYXhheyEZV1Wvw8b4S/Gvvr6is1xi2x4R4YepNfTFheAACPJ0lrJCIyDLsMrywwy7JSZNOj50/VeA/+09j57EKQ78YALipnxfuGh6A3w3zR3gfN/aPISJZsMvw0ootLyQ35+s0+G/hGXx9uBz5JRdx9X+xgZ7OuHWgL8YO8sWY8N7wc2erDBHZJoYXhheSqYray9hedA7bD5fjh1MX2qyZFOLjgptCvHFTPy/EhHghIsgDKgelRNUSEXUewwvDC9mBS1od8k5dwJ6Tlcg5UYmj5bW49r9mpUJAmK8bhgS4Y6i/OwYHuGOwvzuCvV04komIehSGF4YXskO1l5twsLQGBSUXUVBajYKSi7jY2NTusQoBCPJyQWhvV/TzcUM/H1eE+LjA38MZ/u7O8PNQwdmRLTZEZD0MLwwvRBBFEeW1l/FTeR2Ol9fhWHkdjp2rw8/n63G5Sd/h73u5OhqCjG8vFbxcHeHt6gQvV0d4uTrB+8p7TxdHeLo6ws3JAUoFOw8TUdcwvDC8EF2XKIqoqNOg5EIjfq1qRElVA3690Iiz1ZdwrlaDc7WXDXPNmMrZUYFeKge4OjnATeUANycl3FQOV7Yp4eqkhMpRCZWD4spLCZXjVT87KK68b/nZyUEBB4UCjkoBSoUAR6UCSoUAB6UAB4XiyrYr+xQKKBieiGyWKX+/HaxUk8VdPVSaiK5PEISWx0Mezojt79NmvyiKqL3UjHN1l3Gu9jLO1WpwoUGDi41NqG7U4mJDE6ovaVHd2ISLjVpcbGwydBy+3KTH5SYtAK2VP1ULQQAcFVcHHAFKhQJKBaAQBCgEAYLQ+jOueX/Vz4rWfb8dpxBwzXvjcwmCAOGqOnDlnSDgmu2AAOG3n6/aBsPPrfuuPWfLvtbh8YaoJlz5/TbHXXXu1lqu/qVr6jMXS4zeF8xcpblrtERs7snTIIwJ740JwwMkuz5bXoio2zTNOjRodGjQNKNB29zyv1fe12ua0ajVoV7TDE2TDppm/ZWXDpqmq35u1l95/9sxl5t0aNaL0OlFNOn00OlFNOtENOv10Mvq/7mIbMvjt4Xh5UkRZj2nXba8EJF0Wh7zKOHj5mS1a+r1Ipr1LUGmWS9CpxPRpL864Iho1rXs04siRBHQiyL0V/5XbP1Z3/K/4lX7Wo/XXfnd6+2/9nwAIIpAa65q/aehCPGqn413ilcf1942GO+79rw3uubV743O387x5iLCzCeEJWo0Mwu0AZj7jOYuUd3f27wnNBHDCxHZJIVCgJNCgBM45JvI3vC/eiIiIrIpDC9ERERkUxheiIiIyKYwvBAREZFNYXghIiIimyKb8JKRkYGIiAjExsZKXQoRERFZECepIyIiIsmZ8vdbNi0vREREZB8YXoiIiMimMLwQERGRTWF4ISIiIpvC8EJEREQ2heGFiIiIbIrsVpVuHfldW1srcSVERETUWa1/tzszg4vswktdXR0AICQkROJKiIiIyFR1dXXw9PS84TGym6ROr9fj7NmzcHd3hyAIZj13bW0tQkJCUFpaygnwOsB71Xm8V53He9V5vFedx3tlGkvdL1EUUVdXh6CgICgUN+7VIruWF4VCgeDgYItew8PDg1/wTuK96jzeq87jveo83qvO470yjSXuV0ctLq3YYZeIiIhsCsMLERER2RSGFxOoVCosWrQIKpVK6lJ6PN6rzuO96jzeq87jveo83ivT9IT7JbsOu0RERCRvbHkhIiIim8LwQkRERDaF4YWIiIhsCsMLERER2RSGFyIiIrIpDC+dtHr1aoSFhcHZ2RlqtRo5OTlSl2R1ixcvhiAIRq+AgADDflEUsXjxYgQFBcHFxQXjx4/HkSNHjM6h0WjwzDPPwNfXF25ubrjnnntw+vRpa38Us8vOzsbkyZMRFBQEQRCwdetWo/3mujcXL17ErFmz4OnpCU9PT8yaNQvV1dUW/nTm1dG9mj17dpvv2S233GJ0jD3cq/T0dMTGxsLd3R1+fn6YMmUKjh07ZnQMv1e/6cz94nerxZo1azBixAjDDLljxozBV199ZdhvE98rkTr06aefio6OjuJ7770nFhUVic8995zo5uYm/vrrr1KXZlWLFi0Shw8fLpaVlRleFRUVhv1Lly4V3d3dxU2bNomHDh0SZ86cKQYGBoq1tbWGY1JSUsS+ffuKmZmZ4oEDB8T4+HgxOjpabG5uluIjmc22bdvEhQsXips2bRIBiFu2bDHab657c9ddd4mRkZFibm6umJubK0ZGRoqTJk2y1sc0i47uVXJysnjXXXcZfc+qqqqMjrGHezVhwgTxgw8+EA8fPiwWFhaKd999t9ivXz+xvr7ecAy/V7/pzP3id6vF559/Ln755ZfisWPHxGPHjokvvfSS6OjoKB4+fFgURdv4XjG8dMLNN98spqSkGG0bOnSo+Kc//UmiiqSxaNEiMTo6ut19er1eDAgIEJcuXWrYdvnyZdHT01N8++23RVEUxerqatHR0VH89NNPDcecOXNGVCgU4tdff23R2q3p2j/I5ro3RUVFIgDx+++/Nxyzd+9eEYD4008/WfhTWcb1wsu999573d+x13tVUVEhAhB37doliiK/Vx259n6JIr9bN+Lt7S2uXbvWZr5XfGzUAa1Wi/z8fCQmJhptT0xMRG5urkRVSefEiRMICgpCWFgY7r//fvzyyy8AgOLiYpSXlxvdJ5VKhdtvv91wn/Lz89HU1GR0TFBQECIjI2V9L811b/bu3QtPT0+MHj3acMwtt9wCT09P2d2/rKws+Pn5YfDgwXjiiSdQUVFh2Gev96qmpgYA4OPjA4Dfq45ce79a8btlTKfT4dNPP0VDQwPGjBljM98rhpcOVFZWQqfTwd/f32i7v78/ysvLJapKGqNHj8aHH36I7du347333kN5eTni4uJQVVVluBc3uk/l5eVwcnKCt7f3dY+RI3Pdm/Lycvj5+bU5v5+fn6zuX1JSEv7v//4PO3bswBtvvIG8vDwkJCRAo9EAsM97JYoi0tLScNtttyEyMhIAv1c30t79AvjdutqhQ4fQq1cvqFQqpKSkYMuWLYiIiLCZ75VDt89gJwRBMHovimKbbXKXlJRk+DkqKgpjxoxBeHg4/vWvfxk6vXXlPtnLvTTHvWnveLndv5kzZxp+joyMxKhRoxAaGoovv/wS06ZNu+7vyflezZkzBwcPHsTu3bvb7OP3qq3r3S9+t34zZMgQFBYWorq6Gps2bUJycjJ27dpl2N/Tv1dseemAr68vlEplm6RYUVHRJpnaGzc3N0RFReHEiROGUUc3uk8BAQHQarW4ePHidY+RI3Pdm4CAAJw7d67N+c+fPy/r+xcYGIjQ0FCcOHECgP3dq2eeeQaff/45du7cieDgYMN2fq/ad7371R57/m45OTlh4MCBGDVqFNLT0xEdHY0333zTZr5XDC8dcHJyglqtRmZmptH2zMxMxMXFSVRVz6DRaHD06FEEBgYiLCwMAQEBRvdJq9Vi165dhvukVqvh6OhodExZWRkOHz4s63tprnszZswY1NTU4IcffjAcs2/fPtTU1Mj6/lVVVaG0tBSBgYEA7OdeiaKIOXPmYPPmzdixYwfCwsKM9vN7Zayj+9Uee/1utUcURWg0Gtv5XnW7y68daB0q/f7774tFRUXi3LlzRTc3N/HUqVNSl2ZVzz//vJiVlSX+8ssv4vfffy9OmjRJdHd3N9yHpUuXip6enuLmzZvFQ4cOiQ888EC7w+uCg4PFb7/9Vjxw4ICYkJAgi6HSdXV1YkFBgVhQUCACEJcvXy4WFBQYhtOb697cdddd4ogRI8S9e/eKe/fuFaOiomxqiKYo3vhe1dXVic8//7yYm5srFhcXizt37hTHjBkj9u3b1+7u1VNPPSV6enqKWVlZRkN7GxsbDcfwe/Wbju4Xv1u/WbBggZidnS0WFxeLBw8eFF966SVRoVCI33zzjSiKtvG9YnjppIyMDDE0NFR0cnISR44caTT8zl60jvV3dHQUg4KCxGnTpolHjhwx7Nfr9eKiRYvEgIAAUaVSiePGjRMPHTpkdI5Lly6Jc+bMEX18fEQXFxdx0qRJYklJibU/itnt3LlTBNDmlZycLIqi+e5NVVWV+NBDD4nu7u6iu7u7+NBDD4kXL1600qc0jxvdq8bGRjExMVHs06eP6OjoKPbr109MTk5ucx/s4V61d48AiB988IHhGH6vftPR/eJ36zd/+MMfDH/P+vTpI/7ud78zBBdRtI3vlSCKotj99hsiIiIi62CfFyIiIrIpDC9ERERkUxheiIiIyKYwvBAREZFNYXghIiIim8LwQkRERDaF4YWIiIhsCsMLERER2RSGFyIiIrIpDC9ERERkUxheiIiIyKb8f47QC8TqX1l4AAAAAElFTkSuQmCC"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 140
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2024-09-16T17:01:21.450267Z",
     "start_time": "2024-09-16T17:01:21.448934Z"
    }
   },
   "cell_type": "code",
   "source": "",
   "id": "5165d1738793dd22",
   "outputs": [],
   "execution_count": 140
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
