{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "84a1fde2",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "# Code"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9b77fae7",
   "metadata": {
    "code_folding": [],
    "hidden": true
   },
   "outputs": [],
   "source": [
    "# Import packages\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import time as time\n",
    "from scipy.optimize import linprog\n",
    "from matplotlib.ticker import MaxNLocator\n",
    "from scipy.sparse import csr_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3c274d9c",
   "metadata": {
    "code_folding": [],
    "hidden": true
   },
   "outputs": [],
   "source": [
    "def phase_scheme(c, A, x_prime, n, lam, alpha_r = None, start = 0, delta = 0.01):\n",
    "    all_x = np.zeros(n)\n",
    "    r = 1\n",
    "    i_r = 1\n",
    "    if alpha_r == None:\n",
    "        alpha_r = min(c[j] / max(A[1][j], 0.001) for j in range(n))\n",
    "    x_r = np.zeros(n)\n",
    "    for j in range(n):\n",
    "        x_r[j] = alpha_r / (2 * n * c[j])\n",
    "    m = A.shape[0]\n",
    "    y = np.zeros(m)\n",
    "    for i in range(start, m):\n",
    "        if (i % 1000 == 0):\n",
    "            print(i)\n",
    "        if A[i,:].sum() > 0:\n",
    "            x_r, y = online_covering_one(A, c, x_r, x_prime, y, n, i, i_r, lam,\n",
    "                                         alpha_r, delta)\n",
    "            all_x = np.maximum(all_x, x_r)\n",
    "            while c.dot(x_r) >= alpha_r:\n",
    "                r += 1\n",
    "                alpha_r *= 2\n",
    "                i_r = r\n",
    "                x_r = [ alpha_r / (2*n) ] * c**(-1)\n",
    "                x_r, y = online_covering_one(A, c, x_r, x_prime, y, n, i, i_r, lam, alpha_r)\n",
    "                all_x = np.maximum(all_x, x_r)\n",
    "    return all_x\n",
    "\n",
    "\n",
    "def online_covering_one(A, c, x_r, x_prime, y, n, i, i_r, lam, alpha_r, delta = 0.01):\n",
    "    D = np.zeros(n)\n",
    "    Y = np.zeros(n)\n",
    "    B = np.zeros(n)\n",
    "    A_i = A[i, :]\n",
    "    y_i = y[i]\n",
    "    x_bar = np.copy(x_r)\n",
    "    \n",
    "    if A_i.dot(x_prime) >= 1:\n",
    "\n",
    "        x_c = np.multiply((x_bar < x_prime), x_prime)\n",
    "        if A_i.dot(x_c) > 0:\n",
    "            D = np.ones(n) * lam / (A_i.sum()) + [\n",
    "                (1 - lam) / ( A_i.dot(x_c) )\n",
    "            ] * np.multiply((x_bar < x_prime), x_prime)\n",
    "        else:\n",
    "\n",
    "            D = np.ones(n) * lam / (A_i.sum())\n",
    "    else:\n",
    "        D = np.ones(n) * 1 / (A_i.sum())\n",
    "\n",
    "    Y = (A[i_r:i,:].T).dot(y[i_r:i])\n",
    "    B = (x_bar + D) / np.exp((Y + y_i * A_i) / c)\n",
    "    B = np.squeeze(np.asarray(B))\n",
    "    if A_i.dot(x_r) < 1:\n",
    "        flag, x_r, y_i, delta = online_covering_two(A_i, c, x_r, x_prime, D, Y, B, y_i, alpha_r, delta)\n",
    "        y[i] = y_i\n",
    "        if flag:\n",
    "            x_r, y = online_covering_one(A, c, x_r, x_prime, y, n, i, i_r, lam, alpha_r, delta + 0.01)\n",
    "            return x_r, y\n",
    "        else:\n",
    "            return x_r, y\n",
    "    else:\n",
    "        return x_r, y\n",
    "\n",
    "\n",
    "def online_covering_two(A_i, c, x_r, x_prime, D, Y, B, y_i, alpha_r, delta = 0.01):\n",
    "    while A_i.dot(x_r) < 2:\n",
    "        y_i += delta\n",
    "        x_r = np.multiply(B, np.exp((Y + y_i * A_i) / c)) - D\n",
    "        x_r = np.squeeze(np.asarray(x_r))\n",
    "        if np.any(np.isclose(x_prime, x_r)):\n",
    "            return 1, x_r, y_i, delta\n",
    "        if x_r.dot(c) >= alpha_r:\n",
    "            return 0, x_r, y_i, delta\n",
    "    return 0, x_r, y_i, delta\n",
    "\n",
    "# graph dataset loader\n",
    "def file_to_sparse_array(filename, edge_hash_table = None, vertex_hash_table = None, max_e = None, max_v = None):\n",
    "    row_indices = []\n",
    "    column_indices = []\n",
    "    vertices = {}\n",
    "    if edge_hash_table is None:\n",
    "        edge_hash_table = {}\n",
    "        vertex_hash_table = {}\n",
    "        max_e = 0\n",
    "        max_v = 0\n",
    "    with open(filename) as file:\n",
    "        while (line := file.readline().rstrip()):\n",
    "            curr_edge = line.split('\\t')\n",
    "            v1 = int(curr_edge[0])\n",
    "            v2 = int(curr_edge[1])\n",
    "            if v1 in vertex_hash_table:\n",
    "                v1_id = vertex_hash_table[v1]\n",
    "            else:\n",
    "                vertex_hash_table[v1] = max_v\n",
    "                v1_id = max_v\n",
    "                max_v += 1\n",
    "                \n",
    "                \n",
    "            if v2 in vertex_hash_table:\n",
    "                v2_id = vertex_hash_table[v2]\n",
    "            else:\n",
    "                vertex_hash_table[v2] = max_v\n",
    "                v2_id = max_v\n",
    "                max_v += 1\n",
    "                  \n",
    "                \n",
    "            if v1_id > v2_id:\n",
    "                v1_id,v2_id = v2_id, v1_id\n",
    "            if (v1_id,v2_id) in edge_hash_table:\n",
    "                edge_id = edge_hash_table[(v1_id,v2_id)]\n",
    "            else:\n",
    "                edge_hash_table[(v1_id,v2_id)] = max_e\n",
    "                edge_id = max_e\n",
    "                max_e += 1\n",
    "            \n",
    "            row_indices.append(v1_id)\n",
    "            column_indices.append(edge_id)\n",
    "            row_indices.append(v2_id)\n",
    "            column_indices.append(edge_id)\n",
    "    data = [1]*len(row_indices)\n",
    "    return csr_matrix((data, (row_indices, column_indices)), shape = (max_v, max_e)).T, edge_hash_table, vertex_hash_table, max_e, max_v\n",
    "\n",
    "\n",
    "def listen_to_advice(A, hint):\n",
    "    m = A.shape[0]\n",
    "    curr_v = np.copy(hint)\n",
    "    for i in range(m):\n",
    "        while(A[i,:].dot(curr_v) < 1):\n",
    "            value = A[i,:].dot(curr_v)\n",
    "            if (value > 0):\n",
    "                curr_v *= 1/value\n",
    "            else:\n",
    "                support = np.where(A[i,:] == 0)[0]\n",
    "                curr_v[support] = 0.01\n",
    "    return curr_v\n",
    "        \n",
    "def noisy_alter(hint, p):\n",
    "    new_hint = np.copy(hint)\n",
    "    for i in range(len(hint)):\n",
    "        if np.random.random() < p:\n",
    "            new_hint[i] = 0.0\n",
    "    return new_hint"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "96aed1d0",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "# Synthetic Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "bd8cc746",
   "metadata": {
    "hidden": true,
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/k6/fv5gmm5j6k17qmldfthm5w6h0000gn/T/ipykernel_39924/2321711996.py:9: OptimizeWarning: Solving system with option 'cholesky':True failed. It is normal for this to happen occasionally, especially as the solution is approached. However, if you see this frequently, consider setting option 'cholesky' to False.\n",
      "  res = linprog(c, A_ub=A, b_ub=b, bounds=bounds)\n",
      "/var/folders/k6/fv5gmm5j6k17qmldfthm5w6h0000gn/T/ipykernel_39924/2321711996.py:9: OptimizeWarning: Solving system with option 'sym_pos':True failed. It is normal for this to happen occasionally, especially as the solution is approached. However, if you see this frequently, consider setting option 'sym_pos' to False.\n",
      "  res = linprog(c, A_ub=A, b_ub=b, bounds=bounds)\n",
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=4.36885e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[4.3993351  4.41258173 4.42494262 4.45294917 4.46688684 4.47474637\n",
      "  4.45068807 4.46080673 4.44022977 4.44252026 4.47950884 4.45789039\n",
      "  4.48652502 4.47190398 4.49987326 4.52555882 4.50096369 4.57487005\n",
      "  4.57334726 4.57183955 4.56737445 4.60383334 4.62206064 4.64793411\n",
      "  4.67745943 4.69909105 4.68550468 5.002736   5.0593301  4.76947638\n",
      "  4.81447921 5.19856866 5.30140866 4.62725809 4.87854282 4.86810704\n",
      "  4.90301534 4.91341777 4.98021289 5.04107959 5.085265   7.9990037\n",
      "  5.17491051 5.33614741 5.35857004 7.14771394 7.19166788 7.20026211\n",
      "  7.36763388 7.4153617 ]\n",
      " [3.61494141 5.36237836 3.65499633 3.59434191 5.34806104 5.3340016\n",
      "  3.63427842 3.62604638 3.63635757 3.64946734 3.64504282 5.42010977\n",
      "  3.68848347 5.4129741  5.44823445 5.44448404 5.4641581  5.48609905\n",
      "  5.52055121 5.51800326 5.36990137 3.26733763 5.39037024 3.30083272\n",
      "  5.40563978 3.33943698 3.34851677 3.37793391 3.38897759 3.42502824\n",
      "  5.53753774 3.4594601  5.47371048 5.94049205 5.9329449  5.96762823\n",
      "  5.9914632  5.45434778 5.47793614 5.51946271 6.19953995 5.56199122\n",
      "  5.60300401 6.38004746 6.15635247 6.19195433 6.25206736 6.31422041\n",
      "  6.43943884 6.47876789]\n",
      " [4.36976166 4.37816792 4.39880351 4.33077594 4.3353285  4.33754857\n",
      "  4.31248005 4.46081902 4.3211818  4.34550903 4.39640402 4.39373501\n",
      "  4.54582394 4.66991063 4.3819028  4.44283341 4.54183896 4.42827671\n",
      "  4.44193251 4.43920708 4.40899282 4.43887604 4.45602956 4.47537101\n",
      "  4.44816739 4.82827624 4.87304824 4.53545123 4.5492582  4.59973025\n",
      "  4.93872557 4.99973993 5.07531876 5.06688644 5.04100342 5.00102498\n",
      "  4.99681315 5.04089966 5.12617208 5.15321393 5.17154228 5.08419057\n",
      "  5.09569419 5.17724745 7.5513512  7.6115465  7.61809949 7.68668308\n",
      "  7.25237331 7.76562017]\n",
      " [2.62208195 2.61172624 2.60010131 2.62019509 2.65241813 2.63979305\n",
      "  2.65072436 2.66934168 4.28541814 2.67777364 4.29801453 4.3262342\n",
      "  4.29020205 4.31187008 4.36860762 4.38949786 4.40397972 4.35615585\n",
      "  4.43014962 4.38104477 4.39257164 4.4714289  4.46418522 4.35832694\n",
      "  4.37829926 4.39454724 4.40675764 4.43125848 4.43840898 4.46985145\n",
      "  4.49660649 4.501165   4.54995287 4.56257633 4.54987572 4.62151009\n",
      "  4.57185961 4.66403101 4.70722145 4.74922814 4.81482219 4.84664499\n",
      "  4.8736938  5.08800721 4.92300861 5.00637694 5.03394532 5.09744757\n",
      "  7.57573015 7.63217469]\n",
      " [3.46225536 3.48199316 3.47378496 3.54315262 3.53790216 3.52867872\n",
      "  3.52472671 3.49852622 3.50249389 3.50596181 3.53109459 3.58295256\n",
      "  3.60539368 3.62640618 3.62707038 3.64697998 3.64854759 3.61817855\n",
      "  3.70070898 3.68550156 3.76919628 3.72386993 3.79358174 3.76763302\n",
      "  3.81418422 3.88450804 3.8538475  3.90670304 3.91529721 3.95542685\n",
      "  3.99044471 4.00688181 4.00297054 4.06659688 4.07004127 5.97040013\n",
      "  6.0317446  6.05046566 6.07498502 6.33196669 6.41420803 6.38566326\n",
      "  6.39499482 6.48115276 6.56799416 6.62911817 6.70841408 6.71008418\n",
      "  6.78306832 6.36710688]\n",
      " [3.1604593  3.24660383 3.23584083 3.24595466 3.17410602 3.29019423\n",
      "  3.31746434 3.34695233 3.37203012 3.35921421 3.3767735  5.21802584\n",
      "  3.41293259 3.31956829 3.38491412 3.38390594 5.21214534 5.22504747\n",
      "  5.25329268 5.24557086 5.28674467 5.28721293 5.29340742 5.29268562\n",
      "  5.32799106 5.30986946 5.37039628 5.56441311 5.45235969 5.61001969\n",
      "  5.62735819 5.59340463 5.41124954 5.59643673 5.64415723 5.65447674\n",
      "  5.7295416  5.76845674 5.85212922 5.87059156 5.90286052 5.94763328\n",
      "  5.99830981 6.07786127 6.09876064 6.15037851 6.27911905 6.55515509\n",
      "  6.58670603 6.74767756]\n",
      " [3.03241205 3.14302025 3.16222093 3.0959326  3.0840014  3.18306168\n",
      "  3.17721651 3.16556165 3.19970843 3.18482249 3.23967904 3.27728729\n",
      "  3.12559433 3.30399645 3.22474083 3.11462705 3.11133923 5.21656168\n",
      "  4.86966497 4.75955714 4.76073651 4.79601813 4.81845804 4.83824603\n",
      "  4.91226862 4.93403541 4.93304641 4.92720761 4.95514629 5.01325445\n",
      "  5.24142914 5.1386965  5.18939708 5.20775118 5.17657486 5.18371888\n",
      "  5.22223632 5.22355101 5.24537086 5.27943243 5.30714988 5.36471012\n",
      "  5.40092136 5.43347954 5.98250942 6.0486526  5.94149428 6.02951982\n",
      "  6.13749347 8.32814871]\n",
      " [2.40342583 2.3932773  2.41875704 2.4376669  2.46888025 2.71786216\n",
      "  2.59280119 4.17978547 4.15487118 2.55168381 2.56321358 4.20811885\n",
      "  2.56324934 2.57374083 2.49663225 2.50301496 4.25472903 4.23488329\n",
      "  4.23961627 2.64405131 4.14093636 4.23783141 4.27232779 4.19529821\n",
      "  4.33045142 4.30599639 4.34257329 4.36697065 4.44817205 4.48937285\n",
      "  4.22922846 4.43823101 4.2657876  4.30137236 4.37240175 4.35666919\n",
      "  4.38051475 4.46065529 4.49898511 4.47544888 4.47989682 4.60513947\n",
      "  4.75301726 4.79430947 4.85469011 4.92748159 4.71132308 4.82980043\n",
      "  5.06025975 4.49028351]\n",
      " [4.26857853 4.28511313 4.26780598 4.27392441 4.35208093 4.28157522\n",
      "  4.28622051 4.2878752  4.29588446 4.29348961 4.36104253 4.39530578\n",
      "  4.40664762 4.60051694 4.36263943 4.38673866 4.40160174 4.41238013\n",
      "  4.5010655  4.47714755 4.52934947 4.85123019 4.86609181 4.88911359\n",
      "  4.91395537 4.93976337 4.91781956 5.04462888 4.98879614 4.95785686\n",
      "  4.96304262 4.98245129 5.02231595 5.07734082 5.12607881 5.15995331\n",
      "  5.14487256 5.19166894 5.21485828 5.33677164 5.35713109 5.44585193\n",
      "  7.6669384  7.62053201 7.64128597 7.67044354 7.72653855 7.78071452\n",
      "  7.8554379  5.31108922]\n",
      " [3.43194357 3.75525956 3.73871284 3.76899826 3.77614541 3.76550895\n",
      "  3.80041463 3.83124205 3.47630528 4.08746325 3.93773798 4.10567654\n",
      "  4.15902872 3.97380648 5.9693619  5.97955133 4.01196329 5.96685707\n",
      "  5.90157773 5.98990117 5.95430882 4.15644224 5.98947625 4.21532566\n",
      "  6.20007407 6.22752751 6.21952659 6.24673822 6.3217709  6.36080319\n",
      "  6.4258352  6.4110185  6.46302865 6.46041605 6.54606625 6.60681876\n",
      "  6.66382671 6.72940057 6.74905626 6.81671265 6.62279718 6.89648271\n",
      "  6.95276009 7.03475098 7.13516846 7.20795469 6.95958763 7.05295894\n",
      "  7.11522555 7.23506722]\n",
      " [3.44447405 3.58461842 3.59023305 3.56755456 3.56184165 3.52652876\n",
      "  3.79150216 3.54768832 3.36163258 3.62218626 3.8544056  3.90580568\n",
      "  3.92416959 3.90530486 3.98173207 3.65743413 4.0090235  3.58129159\n",
      "  3.70884024 3.639997   3.59259399 3.6317881  3.6371879  5.71482326\n",
      "  3.7531736  5.68340026 4.07589382 4.1132592  5.71022064 5.70352331\n",
      "  5.87111298 5.86851292 5.85649332 3.92743208 3.89506854 3.9382848\n",
      "  3.94590462 3.99369255 4.02759181 4.04221169 4.10058973 4.14386112\n",
      "  4.16168212 6.19261045 6.19155031 6.24609038 6.28351071 6.35113657\n",
      "  6.44852012 6.82110929]\n",
      " [3.13065769 3.11423993 3.12917828 3.15325515 3.15260517 3.15959462\n",
      "  3.17032606 3.18713368 3.20682286 3.22252373 3.24344348 3.23183095\n",
      "  3.2384642  3.2830392  3.28823124 3.36026227 3.34136196 3.35029623\n",
      "  3.39944297 3.39407904 3.41346236 3.472841   3.50371445 3.50924558\n",
      "  5.31838562 5.31981617 5.36241418 5.37994662 5.41878606 5.4102215\n",
      "  5.46030668 5.47890495 5.50037212 5.56571418 5.60471432 5.7942483\n",
      "  5.61548067 5.65252968 5.7376644  5.73362929 5.75940112 5.83463979\n",
      "  5.77551444 5.82792538 6.20704967 6.1044898  6.46540493 5.93735768\n",
      "  5.98752756 5.94327611]\n",
      " [3.47251416 3.45528338 3.48335734 3.53197349 3.51344312 3.53704975\n",
      "  3.57616723 3.59965764 3.61387749 3.4643558  3.47184586 3.4917865\n",
      "  3.47605486 3.48499182 3.57971195 3.57115812 5.30386671 5.39010548\n",
      "  5.38144538 5.40243372 5.01656079 5.62614046 5.64100182 5.54659074\n",
      "  5.69487259 5.66623642 5.7000475  5.72378633 5.74737452 5.71946964\n",
      "  5.81037551 5.8367831  5.77784628 5.82364503 5.89663789 5.90757603\n",
      "  5.90723184 6.0272553  6.06694352 6.11639045 6.04047471 6.08427141\n",
      "  6.14740543 6.17114976 6.22166154 6.31593309 6.37193638 6.47314466\n",
      "  6.61930223 6.7492688 ]\n",
      " [2.68680675 2.70179356 2.701493   2.70829446 2.71905639 4.167118\n",
      "  4.33205121 4.18367933 4.23385344 4.18965772 4.18810938 4.24546746\n",
      "  4.21622722 4.2500711  4.20069687 4.19780987 4.17754938 4.20652664\n",
      "  4.19401493 4.20915028 4.26482081 4.25080724 4.2648701  4.27675169\n",
      "  4.29309129 4.23857735 4.24402072 4.28813328 4.28052119 4.32120092\n",
      "  4.35276107 4.45366966 4.28309154 4.49223369 5.07692347 5.11419974\n",
      "  4.6999156  5.19199434 5.29024698 4.83956572 4.89228423 4.94748801\n",
      "  5.24535322 5.12903428 5.18164496 6.80054734 5.3112623  7.26268608\n",
      "  7.25727067 7.26586767]\n",
      " [3.1343097  3.22652844 3.14663964 3.13303094 3.18811209 3.21373546\n",
      "  3.19807294 3.2968339  3.30646719 3.32620521 3.30821512 3.33567015\n",
      "  3.39928788 3.40089188 3.43000336 3.42160851 3.46047293 3.49006176\n",
      "  3.46712664 3.50905497 3.54779423 3.53856278 3.5421591  3.57272038\n",
      "  3.60709059 3.57261071 5.22255669 5.2595345  5.44289408 5.28368614\n",
      "  5.31552074 5.31008369 5.46224477 5.38125528 5.48803569 5.5170291\n",
      "  5.62498424 5.62415544 5.68034336 5.7514655  5.3572823  5.6604369\n",
      "  5.72088483 5.74094417 5.38433019 5.86179788 5.92403056 5.99258077\n",
      "  6.08130949 6.12921737]\n",
      " [4.67763913 4.71728815 4.73880641 4.77297867 4.7884177  4.46371383\n",
      "  4.38008105 4.84336734 4.84625513 4.36252948 4.35777081 4.44227158\n",
      "  4.45507067 4.46077662 4.88160168 4.79860772 4.77852707 4.98917686\n",
      "  4.78202796 4.8238785  4.85004092 4.86851742 4.85505079 4.90084599\n",
      "  4.91715357 4.89684531 4.94111211 4.83618619 4.8653237  4.87282778\n",
      "  7.73527346 7.76680091 7.76230893 7.82533709 7.81275721 5.07241432\n",
      "  5.10452805 5.18425401 5.22231562 5.24306222 5.28259764 5.36457931\n",
      "  5.37710518 5.41758434 8.46820467 8.56485233 8.60294925 8.99262501\n",
      "  9.10594493 9.21647877]\n",
      " [2.72717826 4.35825708 4.34098674 4.38012523 4.38781755 4.38357193\n",
      "  4.16807838 4.41812908 4.41170322 4.43219621 4.46824124 4.47236675\n",
      "  4.49110008 4.50790769 4.49077084 4.53908957 4.59139113 4.27470719\n",
      "  4.27699955 4.30507295 4.29366471 4.65536569 4.33037549 4.35415673\n",
      "  4.37476027 4.39738667 4.42755903 4.44452459 4.45986645 4.38772541\n",
      "  4.4049952  4.41685615 4.48987699 4.51143028 4.50614933 4.51849158\n",
      "  4.81451498 4.85793918 4.85549282 4.89023103 4.93875292 4.96174426\n",
      "  5.05689811 5.06203981 7.33931991 5.21676388 5.27276688 5.33274574\n",
      "  5.3746146  7.27343064]\n",
      " [4.97581907 4.97288247 3.28924319 5.01900538 4.99451284 3.34148856\n",
      "  3.32302374 3.36693836 3.31470302 3.31535361 3.31101285 5.09644489\n",
      "  3.38059114 3.37753023 5.06540037 5.0867628  5.15767743 5.26674629\n",
      "  5.00820703 5.31132815 5.31793709 5.31750901 5.33805509 5.40428708\n",
      "  5.39613772 5.44096925 5.46043816 5.5067551  5.05552089 5.0804164\n",
      "  5.07009982 5.05403716 5.15516843 5.37490685 5.41846665 5.4130095\n",
      "  5.45062178 5.45610351 5.39540027 5.53693478 5.56299269 5.58598529\n",
      "  5.63577819 6.11428971 6.18546702 6.28033055 6.07330305 6.13552172\n",
      "  6.24510042 6.17035344]\n",
      " [3.09418901 3.11111727 3.23553882 3.23356502 3.24223135 3.22957799\n",
      "  3.2463692  3.12276894 3.13962555 3.29966371 3.12448625 3.14516127\n",
      "  3.19915336 3.18656812 3.18112032 3.21633111 3.26410899 3.27409785\n",
      "  3.29774222 3.31467969 3.29867907 3.34998059 3.36638242 3.37467915\n",
      "  3.27835517 3.29494931 3.35217998 3.33148267 3.37249321 3.36414\n",
      "  3.3905591  3.40309236 5.37829434 5.38408905 5.21477259 5.30829591\n",
      "  5.26452085 5.28465804 5.94013471 5.46671294 5.47222599 5.57663383\n",
      "  5.53610457 5.63333573 5.68899523 5.71899363 5.70105215 6.53231251\n",
      "  6.44038137 6.22689266]\n",
      " [4.39485195 4.47678724 4.50180212 4.47142937 4.57307287 4.58526903\n",
      "  4.36050609 4.47219905 4.37763522 4.59134983 4.58891908 4.49318933\n",
      "  4.49523673 4.52982584 4.69177372 4.60303794 4.62678747 4.66941165\n",
      "  4.61418972 4.62260533 4.65453822 4.6616992  4.67322325 4.68806776\n",
      "  4.70147481 4.75298615 4.79200027 4.78921186 4.83345557 4.81680691\n",
      "  4.85169256 4.38965544 4.93243727 4.96444797 5.12164439 5.16421737\n",
      "  5.26317036 5.11692534 5.26933989 7.13146161 7.22362916 7.91059622\n",
      "  7.9477168  8.07481292 8.05330362 8.18837407 8.23527038 8.32257192\n",
      "  8.38400613 8.72042616]]\n",
      "[0.85107215 0.85977762 0.79793981 0.69362964 0.65419671 0.82216523\n",
      " 0.73718905 0.67025376 0.84223327 0.80204592 0.77835679 0.66636825\n",
      " 0.74175072 0.73909364 0.75085052 0.95185066 0.76003635 0.79118318\n",
      " 0.77226042 0.84478112]\n"
     ]
    }
   ],
   "source": [
    "n = 500\n",
    "values = np.zeros((20, 50))\n",
    "c = np.random.random(n)*20\n",
    "comp_ratios = np.zeros(20)\n",
    "for i in range(20):\n",
    "    A = -np.random.randint(low=0, high = 2, size = (n,n))\n",
    "    b = -np.ones(n)\n",
    "    bounds = [(0, None) for t in range(n)]\n",
    "    res = linprog(c, A_ub=A, b_ub=b, bounds=bounds)\n",
    "    comp_ratios[i] = c.dot(res.x)\n",
    "    lambdas = np.linspace(0.0, 1.0, 50)\n",
    "    curr_values = np.zeros(50)\n",
    "    for idx, lam in enumerate(lambdas):\n",
    "        curr_values[idx] = c.dot(phase_scheme(c, -A, res.x, n, lam))\n",
    "    values[i,:] = curr_values\n",
    "    \n",
    "print(values)\n",
    "print(comp_ratios)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "id": "b25794d7",
   "metadata": {
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAgQAAAGFCAYAAACCBut2AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABd7klEQVR4nO3dd3hkZ3X48e+Zrl5W2t77rru97n2xDbaxIQbzI4CBhNiQ0CEhhFAMJKEm9BBMAqYFCKZjY4p7t9e9bu+rXfU2vZzfH3c0K2lVZqSp0vk8j57RzL0zc+aq3HPfcl5RVYwxxhgzu7lKHYAxxhhjSs8SAmOMMcZYQmCMMcYYSwiMMcYYgyUExhhjjMESAmOMMcYAnlIHUEotLS26fPnyUodhjDHGFMXjjz/eqaqtY22b1QnB8uXL2bJlS6nDMMYYY4pCRPaOt826DIwxxhhjCYExxhhjLCEwxhhjDJYQGGOMMQZLCIwxxhiDJQTGGGOMwRICY4wxxmAJgTHGGGOwhMAYY4wxWEJgjDHGGCwhMMYYYwyWEBhjjDEGSwiMMcaYspRMaVHfzxICY4wxpgz1hGJFfT9LCIwxxpgyk0wpfeF4Ud+z5AmBiLxWRL4mIveJSL+IqIj8cJLnnCMit4lIt4iEROQZEXmfiLiLFbcxxhhTKN3BGKrF7TLwFPXdxvZR4CRgEDgArJ9oZxF5FfBzIAL8FOgGrgK+BJwLXFvIYI0xxphC6w7GcBf5kr3kLQTA+4G1QD3wtxPtKCL1wLeBJHCRqr5NVf8BOBl4CHitiLy+sOEaY4wxhTMQiRNLpIr+viVPCFT1LlXdrtm1jbwWaAV+oqpbhr1GBKelASZJKowxxphy1h0s7mDCISVPCHK0OX17+xjb7gVCwDki4i9eSMYYY0x+xBIpBiKJkrx3pSUE69K320ZvUNUEsBtnXMTKYgZljDHG5ENPKEaRxxJmVFpC0JC+7Rtn+9DjjeO9gIjcICJbRGRLR0dHPmMzxhhjpkxVS9ZdAJWXEExG0rfj5leqepOqblLVTa2trUUKyxhjjJlYfzhBIlmi5gEqLyEYagFoGGd7/aj9jDHGmIrQFYyW9P0rLSHYmr5dO3qDiHiAFUAC2FXMoIwxxpjpiMSTBKPJksZQaQnBnenbV4yx7QKgGnhQVUubZhljjDE5KOXYgSGVlhDcAnQCrxeRTUMPikgA+Jf03W+WIjBjjDFmKlIpLfpCRmMpeeliEXk18Or03fnp27NF5Ob0952q+vcAqtovItfjJAZ3i8hPcEoXX40zJfEWnHLGxhhjTEXoDcdJFb8w4TFKnhDglB1+y6jHVnK0lsBe4O+HNqjqr0TkQuCfgdcAAWAH8AHgq1lWPDTGGGPKQneJBxMOKXlCoKo3Ajfm+JwHgCsKEY8xxhhTLKFYgnCsDJoHqLwxBMYYY8yM0TVY+rEDQywhMMYYY0ogkUzRF46XOowMSwiMMcaYEugOlm7dgrFYQmCMMcYUWSyRon2gPAYTDrGEwBhjjCmytr5wWbUOgCUExhhjTFH1R+L0hxOlDuMYlhAYY4wxRZJKKYd6w6UOY0yWEBhjjDFF0j4QJZ4os76CNEsIjDHGmCKIxJN0DpbXQMLhLCEwxhhjiuBQb/kNJBzOEgJjjDGmwHqCMYLRZKnDmJAlBMYYY0wBJVNKW1+k1GFMyhICY4wxpoAO90dIpsq4ryDNEgJjjDGmQEKxBN1ltIDRRCwhMMYYYwpAtXxrDozFEgJjjDGmALqCMcKxVKnDyJolBMYYY0yeBaMJDlfAQMLhLCEwxhhj8igcS7KnK1jWNQfGYgmBMcYYkyeReJLdnUFSldNTkGEJgTHGGJMHsUSKPV3BiphiOBZLCIwxxphpSiSdZKBcFy7KhiUExhhjzDQkU8qeriDReAX2EwxjCYExxhgzRal0MlBJ0wvHYwmBMcYYMwWqyr7uEKEyX7QoW55SB2CMMcaUUiqlxJIpIvEk0USKaDxFNJFERPC6BbdL8LpdeFyCx+XC4xY8bqG9P8pAJFHq8PPGEgJjjDGzTncwRn84TjSRIpYYv7m/cgoPT58lBMYYY2YVVaWtL1yRtQIKycYQGGOMmVX6IwlLBsZgCYExxphZpS8UL3UIZckSAmOMMbNGMqX0RywhGIslBMYYY2aN/nC84hYdKhZLCIwxxswavWFrHRhPRSYE4vhrEXlYRAZEJCQiT4rIe0TEXer4jDHGlJ94MkUwOnPqBuRbRSYEwPeA/wFWAD8Fvg34gK8APxURKWFsxhhjylCfdRdMqOLqEIjIq4HrgN3AGaramX7cC/wf8BrgLcDNJQrRGGNMGeq12QUTqsQWgmvSt/8+lAwAqGoc+Fj67ruLHpUxxpiyFU0kCcdmxpoDhVKJCcH89O2uMbYNPXaqiDQWJxxjjDHlzmoPTK4SE4KhVoEVY2xbOez79UWIxRhjTAWw2QWTq8SE4Hfp2w+ISPPQgyLiAT45bL+msZ4sIjeIyBYR2dLR0VHAMI0xxpSDcCxJNG61iidTiQnBT4DfA6uAF0TkJhH5MvAUcAWwPb3fmJ1FqnqTqm5S1U2tra1FCNcYY0wp9YZjpQ4hZ6rKDx7ay6+ePFi096y4hEBVU8DVwN8Dh3FmHPw1cAA4D+hK79pekgCNMcaUlb4K6y6IxJN87g9b+d5De/nQz5/hqf29RXnfiksIAFQ1oar/rqonq2qVqtar6iuAF4CTcZawfr6kQRpjjCm5wWiCeKJyig90DET5x188wwM7nOFysUSKmx/YXZT3rrg6BJO4DggA30tPQzTGGDOL9YYqp7vgpbZ+/vX3L46ol/CWs5fx0VduLMr755wQiEg1Ti2AU4BGoA94AvilqgbzGt34MdSrav+ox04HPgsMAp8qRhzGGGPKl6rSH66MUsV3vHiEr9+1g0TKac1wu4R3b17F+y5ZV7QYckoIROQKnLLBzcDw8sAKfElE/kpVfzfmk/PrTyISBp4DBoDjcAYURoFrVHWsGgXGGGNmkYFogmSqvLsLkinlew/t4ZfDBg/WBTz80+UbOGPFmJPlCibrhEBETgV+AbiBHwF3Am3AAmAz8JfALSJyrqo+XoBYh7sFeD3wJqAKOAT8N/BZVd1T4Pc2xhhTAXqD5d1zHIwm+OIft7Jlb0/msWXN1Xz0lRuZXx8oejy5tBD8M05LwPmq+vCobTeLyDeAu4GP4KwnUDCq+gXgC4V8D2OMMZUrlVL6I+WbELT1hfn0715gf08489gZy5v54GVrqfaVZnhfLu96PvCzMZIBAFT1ERG5BXh5XiIzxhhjpqg/Ur4rGw5GEnz0V8/RPhDNPHbtaYt501nLcJVwsd5cEoIGYP8k++wD6qcejjHGGDN95bqyoaryjbt3ZJIBr1t4z+Y1XLRubokjyy0hOAScMck+m3DGFRhjjDElcaQ/wkCkPGcX/PnFI9y/I7NQL39/2TrOWdVSwoiOyqUw0W3AZhH5sIi4h28QEZeIfBC4JL2fMcYYU1SplLKvK0R7f3TynUvgQE+Ib917dBLcy4+bXzbJAOTWQvBp4NXAvwJvF5H7cFoD5uOUDF6OU0r4X/IbojHGGDOxWCLFvu4g4Vh5LmIUT6b44h+3Ek048S1uquJvzhtr0d7SyTohUNXDInIu8C3gUmDZqF3+BLxDVa3LwBhjTNGEYgn2doVIJMt0FCHww4f3srPDqd3ncQn/cNk6Al73JM8qrpzmNqTn+L9cRBbhVCpswKlU+KSqFm9JJmOMMQboCcY42Bsu2xkFAE/u6+EXwwoPvfWc5axsrS1hRGOb0mTH9MnfEgBjjDEl09YXpnOgvNcq6AvH+dKft2Xun7q0iatOWljCiMY30xY3MsYYM8OoKimFlCqavj3cV74zCYaoKl+5Yxs96SmQjVVe3nfJmpLWGpjIuAmBiHwHpzLhR1T1SPp+NlRV35aX6Iwxxsw6h3rD9IbipNL9AOXcHTCRW59t47E9R8sSv++StTRV+0oY0cQmaiF4K05C8DngSPp+NhSwhMAYY0zO4skU3cFYxSYBQ/Z0BvnOA7sz968+aSGnLSvuYkW5mighGJoPcXDUfWOMMaYgZkIyEE0k+cIftxJPz3pY0VLDW89ZXtqgsjBuQqCqeye6b4wxxuRTKqV0DZb3IMFsfPeBPezrDgHg87j4h8vW4XXnUgewNLKOUEQ+LiIXTLLP+SLy8emHZYwxZrbpCcVIpiq7eeDR3d3c+uzRcjzXn7eSJc3VJYwoe7mkLDcCF02yzwXAJ6YajDHGmNmrK1jZrQM9wRhfuePoFMOzV87h5cfNK2FEucl3G4YHKM+6kcYYY8pWXzhONF65p4+UKl/68zb601Mhm2t8vOvi1UiZTjEcS74TgtOAzkn3MsYYY4bpGizPBYmy9ZunD/Hk/l4ABPjApWupr/KWNKZcTViYSETuHPXQW0XkojF2dQNLcNY3+HFeIjPGGDMrhGNJgtFkqcOYsl0dg3zvwT2Z+9ecuoiTFjeWLJ6pmqxS4UXDvlecFQ2Xj7FfCugCfgq8Pw9xGWOMmSU6y7B14HB/hMYq76QLEEXiSb74x60k0oMhV7fW8sYzR6/9VxkmTAhUNdOlICIp4EZV/VTBozLGGDMrxBIp+sLxUoeREU+m+Ood27l7Wwc1PjeXH7+Aq05aSHPN2BUGv/PAbvb3hAHwe1x88LK1FTHFcCy5rGXwV8CThQrEGGPM7NMVjJZNIaJIPMlnfv8ST+xzyg0HY0lueeIAv3rqIJvXz+UvTlnE4qajUwgf3tXF7587nLl//fkrR2yvNFknBKr6vUIGYowxZnZJpZTuMplqOBhJ8KnfPc+LhweO2ZZIKX984Qh/euEIZ62cwzWnLqK11s9X79ye2eecVXO4bGPlTDEcy5RWOxSRxcAiwD/WdlW9dzpBGWOMmfm6QzFSZTDTsCcY4+O/eY49XaHMY68/fQkrW2r4+RMH2XrESRIUeGhXFw/t6qLW72Ew6kwxbKmtvCmGY8kpIRCRy4AvAesn2XXiURjGGGNmNdXyKFN8pD/Cx379HG19kcxj15+/gqtPWgTAWSvn8EJbPz9/4sCIlQuHkgEBPnDJWuoClTXFcCxZJwQicibwO6AD+DrwbuAeYCtwPrAB+A02zsAYY8wk+sMJYonSNg/s6w7xsV8/l+m2cAm892Vr2Lz+aNO/iHDcwgaOW9jA3q4gv3jyIPds68iUWH7NqYs5oQKnGI4llxaCjwAR4HRVPSQi7wbuUtVPidNOciPwQeCf8x+mMcaYmaSjxFMNtx0Z4MbfPM9A+krf6xb+8RXrOXPFnHGfs2xODe+/ZC1vOnMZ92zroMbv5rKN84sVcsHlkhCcDfxGVQ8Ne8wFoKoKfEJErgA+Cbw2fyEaY4yZSUKxBOFY6QoRPXOgl3+59UXCcSeGKq+bj165gROzvNJvrfPz2tMWFzDC0sglIWgA9g27HwNqRu3zAPCG6QZljDGmcqkqKYVkSkmpourU+k+pkko5Uw1LJRRL8Jnfv5RJBuoCHj551XGsmVdXspjKRS4JQTvQNOr+qlH7eIGq6QZljDGmMh3pj9DeX36VB4c8tLMrMyCwudrHv7z6+IpZnrjQcimntI2RCcDDwKUishZAROYDrwG2j/FcY4wxM1y5JwMA927vyHz/qpMXWjIwTC4Jwe3AhSLSnL7/FZzWgCdF5DHgJaAV+HJeIzTGGFP22isgGegNxXgqvSIhwHlrWkoXTBnKJSH4FnABEAdQ1QeAa4HdwPFAG/C3qvr9fAc5FhG5UkT+KCIHRCQsIrtE5GcicnYx3t8YY4yjvT/CkTJPBgAe2NFJerYgGxfUM7cuUNqAykwupYv7gUdGPfZL4Jf5DmoyIvI54EM4Kyz+CugEVgOvAl4jIm9W1R8WOy5jjJltKiUZALhne2fm+wvXtpYwkvI0pdLF4xERD/B2Vf1GPl931HvMB/4eOAKcqKrtw7ZdDNwJfAqwhMAYYwqofaBykoH2/ggvtvUDTgGic1dbd8FoeVmjURxvwRl4+NV8vOYEluHE/cjwZABAVe8CBnDGMhhjjCmQ9oEIR/oqIxkAuHdY68DJS5poqKr8UsP5NmkLgYg0Ae8CTscZP3Af8F+qGklvfyXweWBd+imF7kLYjlMD4QwRaVHVzE9ZRC4A6nC6EYwxxhRAx0C0opIBGDm7wLoLxjZhQiAiLcCjOFflQ8s4vRq4WkQuBf4L+Ov0tt8BH1fVpwoVLICqdovIPwL/AbwgIr/CGUuwCrga+BPw9kLGYIwxs1EqpRwZiNA5UPpFiXKxrzvE7s4gAD63i7NWNk/yjNlpshaCDwPLgaeBH+Gc+K8DLgRuBS7DGWj4XlV9tHBhjqSqXxaRPcB3gOuHbdoB3Dy6K2E4EbkBuAFg6dKlhQzTGGNmjMFogoM94ZIvSDQV92472jpw+vImqn15HT43Y0w2huByYC9wpqp+UVW/AJwJHAAuBX4CnFPMZABARD4E3ALcjNMyUAOcBuwCfiQinx/vuap6k6puUtVNra3WbGSMMRNJJFPs7w6xuyNYkcmAqnLPNusuyMZkCcFy4DZVzbQPqWoYp3sA4GPphY2KRkQuAj6Hs9DSB1R1l6qGVPUJ4C+Ag8AHRWRlMeMyxpiZpicYY9uRQXpD8VKHMmXb2wc53B8BoNrn5rRl1l0wnskSgiqc6X2jDTXJ78pvOFl5Zfr2rtEbVDWEM+bBBZxSzKCMMWamiCaS7O4McqAnTDJV1Gu+vBveOnD2yjn4PHmZXDcjTasjpditA2n+9O147T5Dj1fWqBdjjCmxaCJJXyhO+0CUkvx3z7NkSrnPZhdkLZuE4GQRefPoxwBE5DqOzj7IKHD54vtwpkHeICLfUtWDQxtE5HLgXCACPFjAGIwxpuKpKsFYkoFInIFIgmi88sYITOS5Q330pLs7Gqu8nLi4sbQBlblsEoJXpb9GE5xBfWMpZEJwC/Bn4BLgRRH5JXAY2IDTnSDAh1W1q4AxGGNM2YklUoRiCVwuwS2CSwSXi2HfC8mUZhKA/kic1MzKAUYYPrvgvNUtuF3HXL+aYSZLCL5XlChyoKopEbkCeCfwepyBhNVAN3Ab8FVV/WMJQzTGmKJLppQ9XcEJr/IlfT6cCd0Bk4knUzyw82h1wgusu2BSEyYEqvpXxQokF6oax1lm+culjcQYY0pPVdk7STLg7FekgMrAE/t6CEaTAMyt87N+fl2JIyp/NtzSGGMq3MHecObkZxzDuwsuWNOKSPl1F1T73aUOYQRLCIwxpoK1D0ToCVZunYBCCMeSPLy7O3O/HLsLGqq8rGqtZVlLddmMbbCEwBhjKlRfKF5xiwwVwyO7uzJVFZc2V7N8TnWJIxqp2u9mcVMVAPUBL6vn1lLlK/3puPQRGGOMyVkolmB/T6jUYZSl4cWILlhbXt0FPo+LZc3VuIa1Cvg8Lla11tJUU9olmS0hMMaYChNNJNnTGZpVgwSz1R+O8+T+3sz9C9a0lC6YUdwuYXlLNR73sadeEWFxUzWLm6ooVf5iSz4ZY0wFSaaUvV2hii8pXCg/f+JA5tism1fHgoaqEkfkEIFlc6rxeyYeSNhU46PK52ZvV/Fbf6yFwBhjKkS20wtnq62HB/jVU5nitVx+/PwSRjPSkqZqavzZXYMHvG5Wz62lLlDcLgRrITDGmDKXTCn94TjdoRghm144pngyxVfu3M5Qw8lJixvYvH5uaYNKm9fgp6E6t5O72yXMqw8UKKKx5ZwQiMhVwBtxSgXXqOrq9OMbgKuAHw1fX8AYY2a6VEoZjCXwuV0EvPmZW55KKQORBL3hGAORhI0XmMSPH93H/m6nmT3gdfHuzWvKYjBhc62PuXXFPbFPVdYJgThH9mbgTemHwjjLIw/pAf4NZy2Bz+UpPmOMKUtDawL0h501AYZO2H6vi7qAh/qAN+sm4iGqSn8kQX84Tl84bklAlna0D/LzJw5k7r/17OVFv7oeS13Aw8KG0seRrVx+W/8OuA74DvBB4P3Ax4Y2quphEXkAuBJLCIwxM1AimaI/kqAvHCcYHfuqPRpPEY3H6ByI4XaJkxxUeanze3C5hFRKiSVTxJIp4omhWyWWTBJNpGb0YkOFEE+m+Mod2zJdBcctrOfyExaUNiicJv8lzdVl0UqRrVwSgrcBTwPXq6qKyFi563bg5XmJzBhjysi+rhB94dwqAiZTSm8oTm8ojgi4RGx2QJ7d8vgB9qRH5Ps8Lt6zeQ2uMjgJz6v3l00FwmzlMstgHXCX6oSNWO1A+dWINMaYaTjSH8k5GRhNFUsG8mx3Z5CfbtmfuX/dWctY2Fj6aYZVPhdzav2lDiNnuSQECWCyzpBFwODUwzHGmPIyEInT3m/lgctNIt1VMJRkrZ9fx1UnLixxVI5yqX2Qq1wSgheAi2ScDhERCQCbgSfzEZgxxpRaLJFif3e41GGYMfziyYPs7AgC4HUL73nZmrJoom+oyn0wabnIJSH4AbAe+JKIjHieiLiB/wAW4sxEMMaYiqaq7Ou2ioDlaG9XkB8/ui9z/41nLmNJU+kXMBKB+RU0q2C0XNKYbwFXA+8BrgUGAETkFuAsnGTg16r6o3wHaYwxxXaoL0I4ZkWAyk0oluCrd24nkU7U1syt5dUnLypxVI7WOj8+T+UWAM46IVDVpIi8Evgo8E5gbXrTNUAv8On0lzHGVLTeUIzuwVipw5i14skUR/ojHOoNc6AnzKHeMAd7wxzqjdAdOvpz8biE9xaoq6Da7yYST2Y9DdTrEVorcCDhcDl1dKhqArhRRD6JkxDMAfqAl1TVUmljTMWLxJMc6LFxA6Xy08f28ZPH9mdaACby+jOWsmxOTd5jcLlgaXN1ZiGpWGLyrGBBfdWIJY0r0ZRGPqSnHm7NcyzGGFNSqZQzbsAqBJbGE3t7+OEj+ybcx+MSFjQEOG1ZE689dXFB4phbF8DrduF1w6rWGvZ1hwhOsIZEtd+d81oF5SiX0sWP4AwY/Imq9hQsImOMKZEDPWFbSbBE+sNxvnLH9sz9xiovy1tqWNhYxaLGAIsaq1nUWEVrXWEL/vi9LlpqfZn7HreLFS01HOwN0xMcuxbFwgqdZjhaLi0Em9JfXxKR3+IkB7dbV4ExptypKsmUIiIMnUpEGFFWtnMwOu3iQ2ZqVJVv3rMzMz6gscrL1/7yFBqrfZM8M/8WNASOKTcsIixuqibgjXK4LzKiBampxkuVLz8LWpVaLgnBYpy1DN4CvAZnMGGHiPwI+L6qPl2A+IwxZlqcMQEhwrHxr/xFsG6CErpnWwf37+jM3H/35tUlSQbqqzzUBcZv+m+p9eP3uNjXHSKVcsYazC+DRZTyJev5EarapqqfV9XjgNOB/wTcOIscPSEiT4rIe0XEShcbY0pOVTnSH2FH++CEyYCzb5GCMsfoGIjyX/fszNy/bOM8zlgxp+hxZFtDoC7gZVVrLT6Pi3n1ATzuyp1mONqUPomqPq6q7wYW4LQW/BbYiFOcaP9EzzXGmEILx5LsaB+kvT9qJ/syllLly3dsI5iu9zCv3s/bzltRklha6/z4Pdk1/Qe8bla11jCnpvitGIU0rdRGVROq+kucroRP4Kx3UPlDLY0xFWmoVWBnxyARGxxY9n73zCGeOdAHgEvgA5euo9pX/LK/U6kh4HG7Kmpp42xM+cin1zS4DGdMwatwFj5S4I78hGaMMdkLx5yxApYIVIZ93SFufnBP5v41pyxm44L6ksQyE2oI5EPOCYGIbMRJAt4EzAcE2A58D2dw4YG8RmiMMeNIpZTBWIKBSIKeYMy6BypEPJniP/60lXjS+YGtaKnhDWcuLUksNTOkhkA+5FKH4F04icCpOElAH/DfwPdU9cHChGeMMSOFYgkGIwkGognCsaQlARXoJ4/tz6xU6HEJH7x0Ld4SDM4TgYWNM6OGQD7k0kLwVSAF/AmnNeCXqhopSFTGmFmjazBKdzCGyyW4RXC7JPO9ywUelwtVJRhNMhhN2OqDFe7Ftn5uefzo2PO3nL28IOWHs9Fc4yPgnRk1BPIhl4TgIzhdAocKFYwxZvZQVQ71RWwRoRmuPxxnW/sA2w4PsPXIIC+29TOU0524qIGrT15YkrjcLmHeDKohkA+5rHb42UIGYoyZPRLJ1KT14U1l2tcd4un9vWw7MsDWIwO09Y3dkFztc/PeS9bgKtFI/bn1hS2BXImKP78jD0TkrcB3J9ktparWFmRMmYnEk+zpChJPWNP/TDIQifPdB/bwpxePTLpvS62P92xew9y60lyhizjlkc1I4yYEIrILZxrhJaq6O30/G6qqq/IS3fieAj45zrbzgc3A7wscgzEmR33hOPttNcEZRVW5f0cnN927i94x1oLwuISVrTWsnVfHunl1rJ1XN+Z6AcVU6/fMqAqD+TJRC4ELJyEY7/54Cv5TVtWncJKCY99c5KH0tzcVOg5jTPba+yMc6Y+WOgyTR+0DEb5590627B25AO5py5o4dWkT6+bVsbK1piQzCCbSaNMMxzRuQqCqyye6X45E5HjgLOAgcGuJwzHG4NQKONATtpUEZ5BkSrnt2TZ+8PBewvGj40Dm1Ph4x4WrOGtl8dciyJYI1E+wgNFsVpFjCCbw9vTt/9iyzMaUhw5bVnhG2dMZ5Ot37WDrkYHMYwJcfsIC3nL2spKUHs5FfcBrVQnHkUthojuBm1X1+xPs8ybgr1V1cz6Cy4WIVOFUT0zhFEwyxpRYMqV0Dlo3wUwwEInzf1v289tn2kbUgljSXM27L17NhhKVHc6VVSUcXy6p3EXA3ZPsswy4cKrBTNPrgEbgVlUdd8VFEbkBuAFg6dLSlMo0ZrboGoySsqUFKlo8meLWZ9r46Zb9DEYTmcc9LuF1m5bw2tMWl90YgfG4XFDnL+8WjFLK95GpwlnxsBRuSN9+a6KdVPUm0gMON23aZGOdjSmQVErptKJDFWto9sD3HtpzzGDQ4xbW886LVrOkubpE0U2NdRdMLNeEYMwTaHrlw6XAFcC4V+eFkl5w6RzgAHBbsd/fGHOszmDUygxXqOcP9fHdB/aMGCcAsKAhwFvPWc7ZK+dU5NK/NrtgYhMmBCKSYmQScKOI3DjRU4B/y0NcubLBhMaUkVRK6bLWgYoSS6TYdmSA3zx9iId2dY3YVuf38PozlnL58fMrpntgNLdLqLXugglNdnTu5WhCcAGwD9gzxn5JoAu4gyIP6BORAHAdzmDC/ynmextjxtYdipFIWutAOQvFErzYNsDzh/p4/lA/244MkBjVouNxCVeftJBrNy2p+JNpQ7W3Ils1imnCn7CqXjT0fbq14Luq+qlCB5Wja4Em4HcTDSY0xhSHqtIxYDMLSiGZUsKxJOF4kkjcuQ3Hk4RjR+8f6Anz/KE+dncGmahH58K1rVx31rIZswCQlSqeXC4p3wqgt0BxTMfQYEKrTGhMGegOWutAsYRiCV5qG+CFtn6eP9THtiODxJJTn9axqLGK4xbW8/Lj5rN2Xl0eIy0tj1uoqfAWjmLIZbXDvYUMZCpEZANwHjaY0JiyoKp0WN2BgukJxXjhkHPyf6Gtf9Kr/IkIsKK1huMW1HPcwgY2LqynqdqX13jLhQ0mzM5Eixt9HGf8wDdUtTt9Pxuqqp/OS3STv9GLFGHtBGNMdnpDcVvFcAy9oRhfvXM74ViSi9bN5cK1rQS82S3GmlLliX09/PqpQzy1v3fS/au8bqp8buc2/X3A66LK66HK66Kx2sf6BXVsmF8/a66aG6y7ICui4yw7NmyGwQZV3Za+nw2tlGWHN23apFu2bCl1GMbMCKrqNFknrBLRcKrKv9z6Io/u6c48VuN3c+mGeVxxwgIWNFSN+bxIPMldW9v5zdOHONATHnMfAZa3OFf5GxfWs3FBPXNq/YX4GBXL53Gxbv7M6f6YLhF5XFU3jbVtovTw4vTtvlH3jTHmGH3huCUDY3hwZ9eIZAAgGE3yq6cO8eunDnHasiauPHEBpy5twiVCdzDGrc+28fvn2hiIjKzz5hLYsMA58W9cWD+rrvKnyroLsjfRaof3THTfGGOGs5kFxwpGE9x0767M/RMWNdA5GKWtLwI4TbBb9vawZW8PCxoCrGyt5ZFdXcdM/6v2ubls4zxeeeLCGTPqv1isuyB7uSxu9GbgKVV9ZoJ9jgdOnWgBJGNM5UgkU3QFY9T6PRNeifaF4kTi1jow2vce2kN3yCnQ1FTt5SNXbKDa5+bJfb387plDPL63J1Popa0vkkkUhsyr93PViQu5dOO8sl9FsBwFvK6sx2qY3KYd3gzcCIybEACvAj4FWEJgTIVTVfZ2hwhFk7QTxeMW6gIe6qu81Pk9I4q8dAxGJnil2enFtn5uf+5w5v4NF6zKFPc5bVkTpy1roq0vzG3PHuZPLx4mGD1aZHXDgnpeffJCzlwxB7fV3p8yW9kwN/lOOd2Ms96BMWakWCKFCGVbCnZ/d5jQsJNUIqn0BOP0BOO4XM5CMfUBL4oSjlnrwHDxZIqv37Uj889w07Imzl0155j9FjRU8bbzVvDGM5dy7/YODvaEOXd1y4yqAVBK1l2Qm3wnBGuBnjy/pjEzUltfmIFIgsZqLy21/rJq2jzcF6EvHB93eyrlTDHsDY2/z2z2yycPsq87BDjN1n974aoJy+YGvG4u2zi/WOHNClU+N35P+fxNVYLJFjf6zqiHXi0iy8fY1Y2z2uH5wK35Cc2YmSsUS9AfdkaQD1111wU8tNT5S14zvmswagMERznUG+aJfT2ctqxp3GmCw/f9yWP7MvffeOYy5tpAwKKz1oHcTfaf563Dvlfg5PTXWBR4BHj/dIMyZqYbvb48wEAkwUAkQZXPRUutn4aq4i/G0h+JHzOwbbYLRhN8+BfP0BOK43EJrzxxIf/v9LEX+1FVvnH3DuLp0s2rW2u56sSFxQ551hOx6YZTMVlCsCJ9K8Au4MvAV8bYLwn0qGowf6EZMzMNRhMMjppfPlw4lmJ/d5jDngg16ZHlQ3nBUIIg6cfcIlT53NT4PLimOfgsHEuyryvEOLXKZq1fPHmQnnTXSCKl/Oqpg9z50hHedNYyLts4f8SgvztfaueZA32AUzPgnRevtkGBJdBQ5S3bsTnlbLLVDjPrF4jIJ4G7ynFNA2MqyeEsr8DjCaU3kV0fvYjTD13jd1Pt81Djc+PJ4R9iLJFiT1fQkoFRuoMxfv3UwWMe748k+M+7d3LrM238zfkrOXlJI33hOP/zwO7MPleftIjVc2uLGa5Ja62zao1TkcviRp8sZCDGzAZ94TjhWHLyHXOk6lzhO6/tzHv3e13U+D0EPM5c7IDXPebVajKl7O0K2gqFY/jJY/uIpqsvrmip4drTFnPzg3toT4+x2Nsd4mO/fo4zljcjQqay4Nw6P288c2nJ4p7NagOeshqgW0lyHr0kIlcBbwQ2ADWqujr9+AbgKuBHqnpsSm2Mob2/eP3z0XiKaDw24jGvRwh43OkEwUkU2voiVlRoDId6w/zh+aN1BN589jI2LWvmjBXN/PqpQ/zs8f2Z4za6NPHfXrjKTkol0lI7M1dsLIZcKhUKTnGiN6UfCgPDh9v2AP+G0735uTzFZ8yM0RuKlfzEG08o8UTimBr55lg/eHhvZmnhExY1cNrSJgD8Hjev27SESzbM4/sP7eGOl9pHPO/8NS1sWt5c7HANzhTPuoANJpyqXEZd/B1wHfBdoBn44vCNqnoYeAC4Mm/RGTNDqOqYMwtMedp+ZID7d3Rm7r/l7OXHzPhorvHxvkvW8qXXnczGBfUALGgIcP15K4saqzmqxVZ6nJZcugzeBjwNXK+qKiJjdThuB16el8iMmUF6QrYSYCX53kN7Mt+fvXLOhMvnrp5by2evOYGuYIwan4cqn3UVlILHLTbVcJpyaSFYhzPLYKKRR+1A6/RCMmZmSaWUI0UcO2Cm58l9PTw9bOrgm89eNulzRISWWr8lAyU0p9ZX9LodM00uCUECmKzc1iJgcOrhGDPzdAVjNoK/QqRUR7QOXLphHoubqksXkMmKywVzaqy7YLpySQheAC6ScVIwEQkAm4En8xGYMTNBMqVWBriC3L+9k50dTn01n9vFX55hUwcrQXONzwpA5UEuCcEPgPXAl0RkxPNExA38B7AQZyaCMQZnXYBkyloHKkE8meKHjxytu3b1SQuZY4PUyp6ItQ7kSy6DCr8FXA28B7gWGAAQkVuAs3CSgV+r6o/yHaQxlSiRTNExaK0DleKPLxzJrONQ6/fwmtMWlzgik42GKi8+j5Upzoesj6KqJoFXAp8CfDhLHQtwDVANfBonUTBm1lNV2voipGxiQUUIx5L85NGjKxRee9rikq86abJjUw3zJ6ffeFVNADem1zVYC8wB+oCX0gmDMbNeIplib3eIUNT+JMrFod4wPaEYHpcLj1vwul14XOJ873Jx63Nt9IaddSNaan1ceeKCEkdsslHjd9vMjjyaUgqcnnq4Nc+xGFPxwrEke7uDxBM2bqActA9E+O/7dvPQrq6sn/OGM5bi99hJphK02CJGeTWlhEBEzgdOARpwWgieVNX78hmYMZWmNxTjQE/YVgwsA/Fkil88eZD/27I/p4JQS5qr2bx+XgEjM/kS8LqotzLFeZVTQiAi5wLfAVYPPQRoett24G2q+kBeIzSmArT1hekciE2+oym4LXu7ueneXZkBgkPWzK1FBBJJJZ5MkUgp8aSSSKWIJ1M0BLy872VrbPpahbAZIPmXy+JGpwF/wilOdA9wN3AYmA9cDFwA/FFEzlfVJ/IfqjHlJ5lS9nWHGLTFgkruSH+Eb9+3i0d2j1x5cEVLDe+4cFVmvQFT+ar9bpqsTHHe5dJC8K/p/V+lqr8dte2TIvIq4Jb0fpfnKT5jylYknmRvV8jWKCghVaVjMModL7Zzy+MHiCWP/ixqfG7edNYyLj9+gV31Vzifx0VtwEOtz0NtwGM/zwLJJSE4B/jFGMkAAKr6axH5Jba4kZkBookkbb0RFKecrTMuwLlVQNXpp7bxAsWjqhwZiLKzfZCdHc7XjvZB+sdonblkw1zecvZyGqt9JYjUTJfbJdQFPNT4PdT6PVZnoEhySQhSwI5J9tkOXDb1cIwpD52DMQasG6BkQrEE+7pD7OsOsb87xJ6uEDvbBxmITvwzWdlaw99esIr11j1QsZprfcyvD1grQAnkkhBsAU6aZJ+TgEenHo4xpZdMKT1BGyBYDPFkit2dQfZ0BdnXFWJ/j5MEdA5mf/yrfW5WttRw4dq5XLpxnp1IKpTf62JRYxU1VhCqZHI58h8F7haRv1XVb47eKCLvBF4GXJSn2CaVnv74PpzujGagG3gW+LKq3lasOMzM0h2MWVdAASRTyv7uENvbB9jePsj2I4Ps6QqSyGGthxq/m9WttaxqrWX1XOd2fkMAly17W7FEoLXOz9w6vy1fXGK5JASXAXcCXxeR9wH3AUeAecB5wBrgduDlIjJ8HIGq6qfzE+5RIvJRnHLJncDvgDagBac+wkWAJQQmZ6pKV9DWH8iXvnCcXz55kBfb+tnZMUg0ywGYHpewqLGKJc3VLE1/rWqtZV69nTRmkiqfi8VN1QS8VgiqHOSSENw47Ps16a/RLufYGQaKc+LOGxG5Nv2afwauUdWBUdttPoqZkv5IwqoM5omq8vnbX+KZg30T7regIcCq1lqWzalmSVM1S+dUs6A+gMdtA8lmKhGYVx+gpdZnCV4ZySUhuLhgUeQgvfTy54AQ8IbRyQCAqsaLHpgpmlgiRTiepKEq/3lfl61OmDd3be04JhloqfWxem4ta+bWsSZ9WxuwPuPZwu0Smmq8NNf4rDx0Gcr6L1FV7ylkIDk4B1iBU/OgR0SuBI4HIsCjqvpQKYMzhdcXjhOMJvKeEETiSYK2IFFeDETifOeB3Zn7Lz9uPm84YynNNTYNcLYRcZaTbqrxUR/wWItAGavE1Pz09O0R4AnghOEbReRe4LWq2lHswExx9IXjROJJEslUXpuVOwasdSBfvv/QXvqGrR74tnNX2Kp0s4zP46KpxktTtQ+vdf9UhKkubiQ4JYvHvERT1X1jPZ4nc9O37wB2A5cAjwDLgH/HKYz0M8aZ7SAiNwA3ACxdurSAYZpCiCVShGPOVXxPKE5rnlY7SyRTmROYmZ6X2vq5/fnDmfs3nL/SkgHA6xEaq3wzOvH0e13U+j00VHlt+mAFynVxo2uBD+NclY/3F665vm6Oht5XcFoCnk7ff15E/gLYBlwoImeP1X2gqjcBNwFs2rTJRo9VmOEn7d5QLG8JgU01zI9kSvnG3Ufrl52+vImzVs4pYUTlo9bvYX5DABFo758ZSYHHLdSmqwnWBjzWElDhclnc6J3AV4EEcD9wMP19sfWkb3cNSwYAUNWwiPwBeBtwBmDjCWaYvvDRgjWRuNNaMN2rT2eqoRUiyoffPn2IPV0hwGkyfvsFq6zPOK0uvVTvvHonKTjSV5lJQbXfTUOVl1q/x6YLzjC5XMm/H2gHzlHV3ZPtXEBb07e942wfShiqCh+KKaZoIkk4NnIee08oRpVvej/qvnCcRNKaB6arYyDKjx7dm7n/l6cvZV59oIQRlQ8RqBvWhD63LoAgHB61RPNkqv1uQiUa+FoX8DC33k+1z7oCZqpcfrKLgG+XOBkAuBenZWKNiPhUdfSl3fHp2z1FjcoU3Fh9/L2hOAsaAtO6Cs2lTO5sEk0k+fa9u9jfE+ayjfO4eP3cCSsCfvu+XUTiTsK2tLmaV5+8sFihlr1qnxvXqJLKrXV+XAKHeidPCmr8bhY0VFHlczMYTXCgJ1SUehki0FDlpbXOb60Bs0AuCcF+ID8dttOgqp0i8lPgjcDHcUoqAyAil+IMKuzDqZpoZpD+MRKCZErpj0x9CmIolsgMUjQjffu+3fzhhSMAvNDWz63PtnH9+SvZMMbCQY/u7uahXV2Z+3930SorLDTMUHfBaHNqncqLB3vCY26v8rmYVx8Y8fxav4c1c+s41BumN1SYgbAi0FjtJAJWL2D2yCUhuBl4h4jUjVUMqMg+AJwJ/LOIXICzoNIy4C+AJHC9qvaWLjyTb2N1FwzpDcWmnBB0DljrwFju2trOH4bNFADY3j7Ih37+DBesaeUt5yxjbp3THRCJJ/nWvTsz+12yYS7HLWwoarzlrm6C4kvNNT5cAgd6wpmBrV6PML8+MO7yzW6XsKS5mvqqOAd7wiRzWA9iPC4XVHndVPs8zKm1qYKzUS4JweeA04A/i8iHgCdKlRioaruInInTOvAXwFnAAHAr8BlVfbgUcZnCmWhK4EAkMaWaBLFEiv5IaaYaJlPK43u7UWBBQxULGgJl8w94f3eIb9x1dKbAypYa9veEiKfHWdy7vYOHd3dxzSmLeM2pi/npY/tpT0+lq/N7eOs5K0oSd7nyemTS5vbGah+CcKgvTGudnzk12ZX0bajyUuNzc7A3TH84uzHeIs6AzyqvG7/XRcDrJuBx4/OUx++fKZ1cKhUmReQbOHP87wTG+4VVVS34qBNV7cZpKfhAod/LlN5Y3QVDVKdWk6BUUw1Vla/euZ07X2rPPCY4fcoLG53kYGFjFQsbqljVWsOc2uL11EXiST57+0uZRYgWNVbxmWtOoD+S4OYHdvPATqdbIJZI8ZPH9vOnF47QO+xn81fnLi9ISelKNl53wWgN1V7qq3Kv5Odxu1g2p4aeYIxDfWFS6YY0t0vweVz4PS78Xhd+t5MA+NyuY8YzGAO5TTt8FU65YDdOQaBDlGbaoZllJuouGJJrTYJUSuku0VTDO15qH5EMgFO8o30gSvtAlKf2H31cgEs3zuO6s5aN23w8FlXl4d3dPLizk+MXNnDpxnlZLRH8zXt2sq87PW3Q7eLDr1hPtc9Dtc/Dhy/fwLMH+/jv+3axqzMIMGK65oYF9bxsw7ysY5wtJuouGG06g2ObanzU+D0kUil8bpeN4TA5y3W1wxBwpareX5hwjDlWXxYDp3KtSdA5GM1Lv2uu9nWH+K97jva3L2qsIp5M0TEQZaxoFPjjC0e4f0cnrz99Ca88ceGEXQuqyhP7evnhI3vZ0T4IwN1bO7h/Ryfve9maCVsb/vzCkRGJyjsuXMnylpoR+5ywqIH/eN3J3PHSEX7w0N5M64DbJfzdhauySjpmExGoLeI0PZ/HhQ9LBMzU5PKbug74viUDptiyLSmcbU2CrsEoR0pQKS6aSPL5Yc3xi5uq+NLrTibgdRNPpjjcF+FQX5hDvWEO9UbY3Rlk6xFnmE4oluQ7D+zh9ucO87bzVnL68qZjriafO9jHDx7eywtt/ce891P7e3nXj5/k7y5axflrWo/ZvrszyDeHJSqb18/lknGu9t0u4bKN8zlvdQs/f+Igzx3s4+qTFh6TPBio8Xused5UjFwSgk7AhmSboorEk5m57ZPJpiZBdzCW1bzvQvj2fbvZO6w5/h9fvj4z2MzrdrGkuZolzdUjnrNlTzf/ff9uDvY609IO9UX49K0vcOrSRv7mvJUsaa5m25EBfvDwXp7a3zviuT63i5OXNPLYHmfw4mA0wef/sJVHd3fz9gtXUZsulBOKJfjc7S8RSzrHeUlzNX974eQVBqt9Hq47a9l0D8uMlkt3gTGllstv68+BV4iIV1VtFRhTFBMNJhxtspoEvaHYuPO9C+3ebR0jpvFdf/6xzfFj2bS8mZOXNHLrs238+NF9BNM1E57Y18u7fvwEa+fV8dLhkZN9PC7hsuPm87rTFjOn1s9zB/v40p+3ZWYC3L2tg+cO9fP+S9ZwwqIGvnHXjkzC4fe4+KdXrLciNHlSawv8mAoimuUwaxGpAf6EU774faq6p4BxFcWmTZt0y5YtpQ7DTGD7kYGsWwgA6qs8LJtz7Im2Lxxnf3eoJLMKDvWGed9PnyIcd07m569p4R8uW5fzALK+cJwfPbKXPzx/mLGGP7jEaep//Rglg4PRBDfdt+uYmQ2nLG3kiX29mcc+cOlaLl43FzN9Po+LdfPrSh2GMSOIyOOqummsbbmkr8/iLHd8JnCViPTiVAQcTVV1Vc5RGjNKLt0FQ8aqSdAfKV0yEE+m+MIftmaSgQUNAd518eopjSZvqPLydxet5vLj5/Pt+3bz7MGjf34XrGnhL89YyuKm6jGfW+P38P5L1nLG8ma+cdcOBqIJFEYkAy/fOM+SgTyy7gJTaXL5jXXhTDPcN+yxsf6r2Qgakxe5dBcMUYXecJyW9Gj6wWiCfV2lSQYAbn5wDzs6nNH+HpfwoZevn/biMCtaavnXVx/PY3t62HZkgHNXt7AiywF9565uYcOCer5yx3ae2NeTeXxFSw3XX7ByWnHNdCLk9HtUawmBqTC5FCZaXsA4zAyhqiRTmpc50L1TSAgAeoIxWmr9BKMJ9nQGS5YMPLyri988fShz/6/OXc7qubV5eW0R4YwVzZyxojnn5zbX+Ljxqo3c9txhfvLYPuoDXj78ivVWs34Sy1tq2NsVzBT+mUixpxsakw/2GzuDRBNJIrEUDdWlqRTXG4pxpD+Kxy2sap3eiS8STxLNsbvg6HNTdAdjtPWFS5YMtA9E+Mod2zP3z1zRzFUnls/qfyLClScs4Irj55NSZyqhGV9twEOt38Oixir2d08+MLXWphuaCjTlhEBE6oEGoE9Vj534bIoqmkiyuzNIPKE0RrwsbKwq2j/5YDRBW18ks2pgLOEU/mmZRsndbGsPjKdUswkAUqr8+x+3MRh1Cnm21Pp578vWTKsKXaGICO7yC6vsNNc4VSIbq330heOTrhtg3QWmEuXUrisibhH5sIjsAHqAPUCPiOxIP25/BeNIppSOgcIUwxmeDIAzH397+wDBaGErS0fiSfZ2BdnVETxmCeHDfRGiiakvKzzdhKCUbnu2LVMcyCXwoZevy7qevSk/HrdQP+wEv6ixCs8kWZQNKDSVKOuEQER8ONMO/xVYDuzHWXZ4f/r+v+KshJh9wfVZpH0gQvtAJO/lciPxJLs6jiYDQ+IJZVdHkMN9EbKdWpqtRDLFwd4wO9oHx71SUnWWc52KYDQx5e6CUmsfiPD9h/Zm7l+7aQkbFtSXMCIzXaNXHvS4XSxsHL8ipt/rsvEYpiLl0kLwAeAinCWGN6jqclU9Oz3YcB3wW+B8bPXBY8QSKboGY6RSTlN6vkTiTstAIjn+Cb9jIMrOjkEi8alfrQ8XjCbYemSA7sHJVwoMRZM5f16n1SE0jQhLR1X55t07M1MMlzRV8f82LSlxVGY6RJxFg0ZrqPLSOM5YHStGZCpVLgnBG4DngFer6vbhG1R1J3AN8DzwxvyFNzMc6Y9kTp75WlQnm2RgSDiWYkf7IF3TTEbiyRT7ukNZjbIekkvXwdBnKsWiQ/lw7/ZOtux1pvIJ8O7NayZciMiUv/qAd9yf4cLGKryeY7sOrLvAVKpc/lutBn6vqmOeDtKP/x6wokTDROLJEf3hqRTTPjEPdRNkkwwMUYVDvRH2d0/t6ltV2dcdyuk9h943mwF+sUSKPV25faZy0heOc9O9RxcHuuKEBdZVMAM0147fA+p2yTGFoESshcBUrlwSghgw2VyyGqByR4MVgNOHP/Kxjmm0EgwlA1N9fm8oPqWk4HB/hFB0at0OwWhywiQonkyNGBRZif7n/l30R4ZmFfh489m26E+l83tdk57ca/0e5gxLGmr9nrKcTWJMNnJJCJ4BXisix66dCohIC/Ba4Ol8BDYTBKMJBiLHDrqbaivBdJOBIb2hOId6sx/w1xeK0zkwvYUu2/oixBLHNi4l0snAWNsqxeN7e7hra0fm/t9dtHra1QhN6TWPMXZgLPPrA/i9zr9S6y4wlSyXhODrQCvwqIi8TURWikiViKwQkb8CHklv/3ohAq1Eh/vHX2a3czBGKocTeyKZYm9XKG/9612DMQ73Tb4McCSeZH/P9Af5qZJZUW/IUDKQ64yCoWqI5SAcS/Kfd+/I3L9gTSunL8+9eqApLyLQVJ1dQuByCYubqhDBppeaipZL6eL/E5GTgQ8DN42xiwCfV9X/y1NsFa0vHJ+wiT2ZUjqDUebWBcbdZ8hQ/32+r6I7BqK4BObWjx1DKuW8b75mLQ5GEnQHYzTX+EimlD1doZwXL+oJxvjwL55hIJrgxquOY+280q4m98NH9maWFa7ze7j+/BUljcfkR2O1N6fCXtU+D4ubqvB5bBCpqVw5/faq6keAc4DvAE8Cu9K33wHOVdUP5z3CCqSqHJmgdWBI50B2rQSH+yMEp9h/P5kj/dFxpwYe6AnnvR5AW1+YSDzJnq5jixll49dPH+RQX4SBSILvPbQnr7HlauvhAX47bK2Cvzl/JY1ZXlWa8janJvcqm/azN5Uu5w4vVX0YeLgAscwYPaF4VifSZErpCsZorRv/n09PMDbt/vvJtPVGcImM6DPtGIgWpFpgKgU72gen1OqQTOmIvvpnDvSxvzvEkuaxl/ydjmRKiSdTBLxjF5iJJ1N87c7tDH2MU5Y0cvG6MYfXmApT5XNT5bPCQmb2sREweZZKZdc6MKRjIMqcGt+YC6GEYolj+t0L5WBPGJc4VznBaCKnz5CrqXZBPL2/l+7gyOTotufaePsF+Z3p+uzBPv7l1hcIxZIEvC4aq3w0VXtprPbRWO2lqdrH4b4Ie9OzNfweF++8eLWNLp8h5mQ5mNCYmWbChEBE/MB9wADwClUd85IxXa749zjTDs8fb7/ZoDMYzWku/XitBPH0IMJirtZ3oCdMMqW0D0RLtkrgRO54qf2Yx+58qZ03n7U8b1d0PcEYn7/9JULp7oxIPMXheGTCAaLXnbWMeeOMwzCVxeVyqhAaMxtNNobgjcBpwL9PdJJX1RjwBeAMZnGlwkQyNaUFjDoHoyPGEky1CNB0DRUvKsfiQMFogod3dWXuDy02E4oluXvbsYnCVCRTyhf/tJXeHLpK1s6r5ZVltKyxmZ7mcVrrjJkNJusyuAbYpaq3TfZCqnq7iGwHrgVuzkNsFadjMJpTWd8hiaTSHYpllgs+2BuechGgmer+HZ3Eks7BXdFSwyUb5vHt+3YBzuqCrzhu/rSb7G95fD/PHOgDnCkzn3rV8ayZW0tPKEZvKE5PKEZPKE5v+r7HLbz+9KVFW2baFF62Uw2NmYkmSwhOASZNBoa5F7hi6uFUtq7BqQ/+GxpL0B2M0ROctT0u47pzWHfB5vVz2bx+Lt9/aA/RRIo9XSFeaOvnuIUNU3795w728b+P7svcf92mJZy8pBGAGr+HxU1TfmlTIWr87nEHkRozG0zWZdACHMnh9Y4Ac6YeTmWbTr97Iqkc6AnTlkWxoNmmrS/MC239ALgELlzbSq3fw0Xr5mb2ue3Zw1N+/b5wnC/8cStDvTbHLaznL89YOq2YTXmp8rlpqnFWKGyo8lIX8FDjd2YTBLwufB4Xc2pzn2pozEwyWQtBmMnXLxiuFrAz2hT1hqxlYCzDWwdOW9aUada94vj5/OF5JxF4cGcnPaEVOTf5plT50p+3ZWYv1AU8/MNl66wbYIbwe13Mqw/YQEFjsjBZC8F+4PQcXm8TsG/SvYzJUkp1RELwsvXzMt+vbK1lw3ynUmEipfzxhVwasxy/evIgj6eXLAb4wCVr7UpxBvB6nHLCa+bWWjJgTJYmSwjuBs4SkU2TvZCInIZTxfCuPMRlDADPH+rPlAau9Xs4Y8XIdQKuOGFB5vvbnzuc0xoHLx3u5/sP783cv+aURWyydQgqmtslzG8IsG5eHU01PqsNYUwOJksIvg4o8DMR2TDeTiKyHvgZkAT+M3/hjft+e0REx/maemeyKTt3vnT0qv/8NS143SN/Zc9d3ZK5AuwcjPLYnu6sXncwkuALf9iaSSDWzavjurNsyeJKJQJz6/2sm19Ha53fEgFjpmDCMQSqulVEPgXcCDwpIrcAdwIHcBKFxcDLgNcAfuDjqrq1oBEf1Qd8eYzHB4v0/qbAIvEkD+w4WntgeHfBEK/bxWUb5/Gzxw8AcOuzbZy1cuJxrarKV+7clml5qPG7+YeXr8PjtoVpCkFkegNuh17D4xZ8bhdetzMI0Od24fW48KYftyTAmOmZtHSxqn5KRBLAJ4A3AH85ahcB4sA/q+pn8h/iuHpV9cYivp8psod2dRGOO/UYFjVWsXbe2ONbX3HcfH7+xAFSCk/t7+VgT5hFTVVj7ptMKT9+dB8P7zrakvDezWus0mCBiMCyOdW4XUJ30KnfkEtyUON301zjo6HKayd8Ywosq7UMVPXfRORHwF8D5wILcBKBQ8D9wHdVde8EL2FMzkYOJpw77glhbn2A05c388hu5yR/23NtXH/+ymP2a++P8B9/3sbzh/ozj73yxAWcvaolz5GbIQsaAtQFnC6dap+HBQ1KTyhGdzA27gJgHrfQVO2jqcaL32N1AYwplqwXN0qf8D9RwFhy5ReRNwFLgSDwDHCvqlqJvxmgYyDK0/t7ASfzvHj93An3v+L4BZmE4I4Xj3DdWcsyRWZUlXu2dfDNe3Zm1igAp97AX5+7oiDxzyRTbfKfU+s7ZsaG2yW01PppqfUzGE3QE4xlVtWs9XtoqvFRH/BYa4AxJVDJqx3OB34w6rHdIvJXqnpPKQIy+XP31vbM0sInLWnMlHUez8lLG1nQEKCtL0IwluTe7R1ctnE+g5EE/3nPDu7b3pnZ1yVOJcL/t2mJjRuYRLXfzaLGKvZ0BYknss8KagMeFjRM3A1T6/dQ6/ewIJkipeDz2M/CmFKq1L/A7+IMZpyPs8LiCcC3gOXA70XkpPGeKCI3iMgWEdnS0dFRjFhNjlR1xMqGmydpHQBwiXDF8UenIN76bBtPH+jl3T95YkQysKAhwOeuOZE3nrnMkoFJiMDipioCXjerW2up9mfXfO/3uljaXJ31Vb4nPUjQGFNaFflXqKqfVNU7VfWIqoZU9TlVfQfwH0AVzqyI8Z57k6puUtVNra2txQp5VgjFEtz+3GH+95G99Iamvq7DtiODHOwNA1DldXP2JLMGhrxsw1x86ZP8ro4gH/3Vc3QOW1/iso3z+Mr/O4X1C+qnHFulmVfvxzXFv/L5DYFMH77H7WJlSw2N1RMX+XG7JDOI0BhTWSq5y2As/wV8ELig1IHMJnu7gtz6bBt3b+3IzAq4d3snn73mBBqnsHrcHcNqD5y7ek7WC87UBbxcsLaFP7/YPupxD+/evCbrxKJURMDvceH3uPF7XQQ8bnpCMQYiiSm93pxaH3PrA1T53OztCuU0DqDa7z6mm0ZEWNJcTcAb5fAYa24MzSiwgYDGVKaZlhAMnQlqShrFLBBPpnh4Vxe3Pts2YtT+kIO9YT7x2+f5t1efQI0/+1+zeDI1ool/8xi1ByZy5QkLRyQEpy5t4r0vW0NzTfkta1vlc1Ef8OL3utOJwLFz6esCHnZ1DhKO5baudrXfnenDrwt4mVcfGPMkPpahroLxtNb58Xtd7O8OjVjue1FjVU4/a2NMeZlpf71np293lTSKGaxrMMrtzx/mD88fpmeMxZgWNVbR1hcmpU6z/advfYFPXn1c1leND+7sYjDqXBHPrfNz3MLcmvdXz63lurOW8dCuLi7bOI9XHDe/LEesN1Z7WdRYhWuSpnWXS1g2p4ZdHUFiieySAo9bjunDb63zE4kns1pAa3hXwXjqA15WtdaytytELJGitc5PUxkmXcaY7FVcQiAixwFtqto96vFlOKWWAX5Y9MBmgTtePMI37t5BPDmy7dntEs5aOYcrT1jA8Qvr+dOLR/janTsAZy2Cz/7+Jf75ig0TDuJTVX77TBvffWB35rHN6+fimsLJ/HWblvC6TUtyfl4xiDgDG3NZQMnrdrFsTjW7OoKTrtUgAkubq48p8QzOVX80kSIcG39mbs0YXQXjCXjdrGqtoTsYY64VdjKm4lVcQgBcC3xYRO4CdgMDwCrgSiAA3AZ8sXThzTyqyk8e28//PjpyIcvmah+vOH4+l22cN+IENzTd77sP7gFgy94evnzHdj5w6doxT/B94ThfvWM7jw5bh6DO7+EVx80vzAcqEY/bGXBX7cv9zy7gdbNsTjW7O4MTjgWY3xAYt9lexHn/nR2DY04hFGHcCo/j8bhdlgwYM0NUYkJwF7AOOAWni6AG6MWpmPgD4Aeq062cXnl6gjF+/Ng+trcPkkwpiZSSTKZIpJSUDt1X/F4XF6+by+s2LclqsF4imeIbd+8Y0S+/pLmaN5yxlLNWNI971X/NqYsZjCYyawzcs62DWr+Ht1+wckRT9rMHevnin7bRHTw6G2Blaw0fumz9jFqGuNrvHvfKPVs1fg9LmqrZ1x0ac3tjtXfSq3uv28Wy5hp2dgwek1hk01VgjJm5Ki4hSBcdqrjCQ/FkisFIIu/9rKrKnS+189/37870vU9kIAo/e/wAd2/r4PrzV3LWiuZx+9hDsQSf+f1LPJWuGAhw8pJG/uny9Vld5V531jIGowl+/5yzAOWtz7ZR6/fwprOWOWsKPLaP/3tsP8PPS1eftJC3nrN8WifOcjOn1seChkBexjI0VHuZnzx2gGDA62JRY3ZX91U+N4ubqtjfHc48lktXgTFmZqq4hKAS9YXj/OPPn+Fgb5hrT1vMdWcty8vJoX0gwjfu2skT+3pyfm7HQJR/u+1FNi1r4u0XrGL+qKpyXYNRbvzt8+zpOno1+rL1c3nXxauzLugjIrz9glUEownuTc8c+OmW/QA8e7CPF9qOzk6oD3h43yVrOX15c86fpVyJOIMs850Ettb5iSVTdKdrLLhcsHRO9aQDFIdrrPYRiafoGIhOqavAGDPzWEJQBN+6d2em0M7PHj9Ard/DNacunvLrpVT5/XOH+d6DezLz/sEpQvO2c1cwtz6AxyW4XYLH5cLlAo/LhdslPLa7m+8+uJv+9Nz2LXt7eOZ/n+DaTYu55pTF+Dwu9nQG+eTvnh9R1OcNZyzl9acvyTmRcbuE912ylmAsyeN7ncRlKCkYcuKiBj5w6doZ1UUAhUkGhixsCJBIpugPJ1jSPLW5//MbAkTiSeoCHusqMMYgs7C7PWPTpk26ZcuWvL3eswf6jnns/h2dfO72l455/P2XrMl5jj3Aod4wX71z+4i5/wJcddLCEQv6TGQgEuf7D+3lD88fHtFcv6AhwBUnLODHj+7LLALkdgnvung1l2zIPdbhIvEkn/jN8yNaBVwCbzxzGa85dfGMq2zncQvr59cVdMpjKqX0hePTSjpSKc2pZcEYU9lE5HFV3TTmNksICpcQ9IZivPN/n8hcjQe8LiLpJV9dAh+7ciObsmwiT6aUXz91kB89so9Y8uh89MVNVbxn8xo2TKEc77YjA/zn3TvY2REcc3uV181HrtjAyUsac37tsQxGE3z818+xvX2Q1jo//3DZuinFXQnm1ftt9L0xpuxYQjCOQiYEqspnb3+JB3d2AdBS6+Nz15zIp299IdMv7/e4+NdXn8C6+XUTvu7uzkG+escOdnQMZh5zCbz2NGfFvuksDJNMKbc/18YPHt5LcNj89Dk1Pj5x1XGsaMlv0cdkStndGWTZnOmNuC9nIrB+fp0tnmSMKTsTJQT2H6tA7t/RmUkGAN598Rrm1ge48arjmFvn9JVHEyk++bvn2d8z9jSyeDLFDx/ey/v/7+kRycDK1hq+9LqTue6sZdNeJc7tEq48cSHffNNpbF43F7fLaer+4rUn5T0ZGHq/1XNrZ2wyAM70P0sGjDGVxloICtBC0BN0ugoG0tMAX75xHu/avCaz38GeMB/6+dOZroTWOj9feM2JIwbVvdDWz9fu3M6BnqNTw7xu4S9PX8pfnLKoYCeceDKFxyVlWe63UqyZV5v1gkzGGFNM1kJQRKrKf96zI5MMtNb5+evzVozYZ1FTFZ+46jj86av7joEon/jN8wxGEoRjSb51704+/PNnRiQDGxfU89XXn8K1m5YU9OrT6z52gZ1y4/O4qK8qzwkyNX63JQPGmIpUnv9VK9g92zp4eNfRErzv2bxmzCI+a+fV8U+Xb+DTt75AMqXs7Q7x8d88R284TsdANLNfldfNW85ZzuXHz59SXf+ZqKnGS53fS394cPKdi2ymTZ00xswe1kKQR93BGN+69+hCi5cfP3/CEfqnLXOW5h2yvX1wRDJw2rImvv6GU7jyhAWWDKSJOGsoVPnc1PjL60rc53HRUOUtdRjGGDMl1kKQJ6rKN+7aMWLp3rees3zS5128bi49wVhmISCAuoCHG85fyYVrW8u++b7YGqqODthrrfMTjI49ILMUmm35X2NMBbOEIE9+8cTBEav1vedlY3cVjOWaUxejwO+eOcRJixv5q3NX2JXmOObUHj3p1gW8VPlchGOpCZ5RHCKWEBhjKpslBHlwuC/CJ3/7fOb+lScs4KTFjTm9xmtOXcxrplHOeDao8rmOSbJaawPjrv5XTM01vhlXbdEYM7vYGIJpUlX+6RfPZKYQzq8P8Jazl5c2qBmquebYAXv1VZ5p12LIB2sdMMZUutL/J61wqnD6imZ86X7t97xsDVW+8hrsNhO4XNA4RjeKiNBSW9qTcV3AY1MNjTEVz7oMpsnlEv7uotW8bP08bnl8Pycsaih1SDNSU7Vv3EV4mqp9tA9ESSRLU2RrTokTEmOMyQdrIciTdfPruPqkRaUOY8aaqEne5ZKSnZT9Xhd1ARsAaoypfJYQmLJXm0WT/JwaP64S/DbPsbEDxpgZwhICU/ayGbDndkneBvaJOIMVG6u9+L3j/4m4XE53hTHGzAQ2hsCUNa9HqA9k92vaUuunazDGVNfr8ntdNFX7aKz2jliNMZlSwvEk4ZjzFYoniCc03SphUw2NMTODJQSmrDVX+7Ku1uh1u2is9tITjGf9+iJO9cPmGh81/rH/HNwuodbvoXbY9kQyZVUkjTEziiUEpmyJQFOO3QAttf6sEoIq31BrwNQKChVyxUljjCkFSwhM2aoPjGy6z0bA66a+ykN/OHHMNq9HaKxyugSsboAxxoxkCYEpW1OdStha588kBC6X0yXQWO0b0eRvjDFmJPsPacpSwOsat09/MtU+D611fqq8buoCHhv4Z4wxWbCEwOSFz+OiNuAMvBOBtt4IscTUVyGc7hTC+Q2BaT3fGGNmG0sIzJSI4Iy8TycBo/vka+d6aB+I0jkYzXkaoM3vN8aY4rOEwGRtaIpeY7WXGt/ETfEulzC/IUBDlZeDvSHCsclbC7weobnaR1PN+OsWGGOMKQxLCMykRJwm/JZaf85LDVf53KxqraVzMMaR/siYrQW1AQ/NNT7qAx6b22+MMSViCcEsI0LWTfju9KJBc2p805p3LyK01vmpr/JwqDfCYCSR6RZorvHZFEBjjCkDlhDMInNqfSxoCJBIKdFEikg8efQ2niKZcjIFr0doqfXTPMGSw1Ph97hZ0VLDYDRBtddt3QLGGFNGLCGYBVwuWNxUTUOVs0yv1y143a5j5uUnkiliyRRVXndBm+6tHoAxxpSfGVN/VUSuExFNf/1NqeMpF1U+N2vm1mWSgYl43C6qfdaPb4wxs9GMuFQTkSXA14BBoLbE4ZSNljof8+sDdoI3xhgzqYpvIRDnbPddoAv4rxKHUxbcLmF5SzULGqosGTDGGJOVmdBC8B5gM3BR+nZWq/G7WdJcnfOiQMYYY2a3ik4IRGQD8FngK6p6r4jMyoTA6xHqA14aqrxTrv9vjDFmdqvYs4eIeIAfAPuAj5Q4nKzU+N3EkiniiRxr+Y7B73VlkoAqn83jN8YYMz0VmxAAHwdOAc5T1XC2TxKRG4AbAJYuXVqg0I41t97PvHpnwZ1kSonEk4TjSSKZr9QxBYNcLmc8gFsEV/q22u+mPuC1Yj7GGGPyqiITAhE5A6dV4N9V9aFcnquqNwE3AWzatGn6l+pZaKz2ZpIBcE7yNX7PiOZ9VSWWTCGIkwRY0R5jjDFFVHEJwbCugm3Ax0oczqRqAx4WN1VNup+I4PfYVb8xxpjSqMSh6LXAWmADEBlWjEiBT6T3+Xb6sS+XKkiAKp+LZc3VNvXPGGNM2au4FgIgCvzPONtOxRlXcD+wFcipOyGffB4Xy+bUWL1+Y4wxFaHiEoL0AMIxSxOLyI04CcH3VPW/ixnXcG6XsGyO1QIwxhhTOeyMlWcisLyl2mYBGGOMqSiWEOSRCCxprqbaV3ENL8YYY2a5GZUQqOqNqiql6i5Y0BDIalVBY4wxptzMqISg1ObU+ksdgjHGGDMllhAYY4wxxhICY4wxxlhCYIwxxhgsITDGGGMMlhAYY4wxBksIjDHGGIMlBMYYY4zBEgJjjDHGYAmBMcYYY7CEwBhjjDFYQmCMMcYYLCEwxhhjDJYQGGOMMQZLCIwxxhgDiKqWOoaSEZEOYG8eX7IF6Mzj681Gdgynz47h9NkxzA87jtOX72O4TFVbx9owqxOCfBORLaq6qdRxVDI7htNnx3D67Bjmhx3H6SvmMbQuA2OMMcZYQmCMMcYYSwjy7aZSBzAD2DGcPjuG02fHMD/sOE5f0Y6hjSEwxhhjjLUQGGOMMcYSAmOMMcZgCcG4RGSxiHxHRA6JSFRE9ojIl0WkqRSvU6mm+/lFZI6I/I2I/FJEdohIWET6ROR+EXmbiMz43+FC/A6JyHUioumvv8lnvOUon8dQRM4XkZ+LSFv6tdpE5I8ickUhYi8XefyfeGX6eB1I/z3vEpGficjZhYq9HIjIa0XkayJyn4j0p//2fjjF1yrIecXGEIxBRFYBDwJzgV8DLwFnABcDW4FzVbWrWK9TqfLx+UXkHcA3gTbgLmAfMA+4BmgAfg5cqzP0F7kQv0MisgR4FnADtcD1qvrf+Yy7nOTzGIrIR4FP4xSK+R3O72ULcApwl6p+KO8foAzk8X/i54APAV3Ar3CO42rgasADvFlVp3SSLHci8hRwEjAIHADWAz9S1Tfl+DqFO6+oqn2N+gL+ACjw7lGP/0f68f8q5utU6lc+Pj+wGbgKcI16fD5OcqDAa0r9Wcv5GI56ngB/BnYCX0i/xt+U+nNWwjEErk3v/yegbozt3lJ/1nI+hum/2SRwGJg7atvF6dfZVerPWsBjeDGwJv03eFH68/6wFD+LcV+71Aep3L6AlemDunuMk1AdTnYXBGqK8TqV+lWMzw98JP0eXyv1562UYwi8F0gBFwA3zvSEII9/zy5gV3rf1lJ/rgo9hmemX+fX42zvBwZK/XmLdEynlBAU+v/qjO9/nYLN6ds/qmpq+AZVHQAeAKqBs4r0OpWqGJ8/nr5NTOM1yllej6GIbAA+C3xFVe/NZ6BlLF/H8BxgBXAb0JPuB/9HEXnvTO/7Jn/HcDsQA84QkZbhG0TkApwT2p/zEvHMVdD/q5YQHGtd+nbbONu3p2/XFul1KlVBP7+IeIA3p+/ePpXXqAB5O4bp4/UDnG6Wj0w/tIqRr2N4evr2CPAEzviBzwJfBh4UkXtEZMwFY2aAvBxDVe0G/hFnDNALInKTiHxGRP4P+CNOV8zb8xDvTFbQ/6ueqTxphmtI3/aNs33o8cYivU6lKvTn/yxwPHCbqv5hiq9R7vJ5DD+OM/DtPFUNTzOuSpKvYzg3ffsOnObaS4BHgGXAvwMvB36G0xQ80+Tt91BVvywie4DvANcP27QDuFlV26cY42xR0P+r1kKQO0nfTndUe75ep1JN+fOLyHuAD+KMrr0un0FVmKyOoYicgdMq8O+q+lDBo6os2f4euoft/1pVvUNVB1X1eeAvcEaNXzgLug/GkvXfsoh8CLgFuBlYBdQAp+GMz/iRiHy+QDHOFtM6r1hCcKyhDKthnO31o/Yr9OtUqoJ8fhF5J/AV4AXg4nQz5Ew17WM4rKtgG/Cx/IVWMfL1e9iTvt2lqk8P35BucRlqpToj5wjLX16OoYhcBHwO+I2qfkBVd6lqSFWfwEmqDgIfFJGV0w95xiroecUSgmNtTd+O1wezJn07Xh9Ovl+nUuX984vI+4CvA8/hJAOHpxxdZcjHMaxNP38DEBlWjEiBT6T3+Xb6sS9PN+AylO+/595xtg8lDFXZhVVR8nUMX5m+vWv0BlUNAY/inJNOyTXAWaSg5xUbQ3CsoV/Wy0TENXwkp4jUAecCYeDhIr1Opcrr5xeRf8QZN/AUcKmqduY33LKUj2MYBf5nnG2n4vzzvR/nH81M7E7I1+/hvTizWdaIiE9VY6O2H5++3TP9kMtOvo6hP3073uDLocdHH1tzVGHPK6Wej1mOX+RQ+AHw4lScWjWd15mJX3k8jh9L778FaC7156rEYzjOa9/IDK9DkM9jCPwwvf+/jHr8UpzaDr1AY6k/b7keQ+B16X0PA4tGbbs8fQzDwJxSf94iHM+LmKAOQanOK1a6eAxjlIZ8EaeoxsU4TTHnaLo0pIgsxxl1vFdVl0/1dWaifBxHEXkLzgCkJPA1xu4b26OqNxfoY5RUvn4Xx3ntG3G6DWZb6eKp/j3PxZnnvRq4D6eJexlO/7cCb1DVnxX+ExVfnv6WXTgns0uAAeCXOMnBBpzuBAHep6pfKcqHKjIReTXw6vTd+TgzU3bh/C4BdKrq36f3XU4pziulzpTK9QtYAnwXp1Z5DNiLM5itedR+y3H+GeyZzuvM1K/pHkeOXsVO9HV3qT9nOR/DCV536NjO6BaCfB5DoBnnSmx3+nW6cP4pn1Xqz1gJxxDnyvd9OE3a/TjdMO04dR0uK/VnLPDxm+x/2Z5h+5bkvGItBMYYY4yxWQbGGGOMsYTAGGOMMVhCYIwxxhgsITDGGGMMlhAYY4wxBksIjDHGGIMlBMYYY4zBEgJjTBGJyA3phZQ6ReRL6ep1xpgyYH+Mxphi2g18kaMV6y4taTTGmAxLCIwxRaOqf1LVf8BZuRLgrFLGY4w5yhICY0wpDC3PelJJozDGZFhCYIwphd3p2xNLGoUxJsMSAmNMKXwsfbtSRGpLGokxBrCEwBhTZCJyGfDXQ3eBE0oYjjEmzRICY0zRiEgd8G2gF/hh+mHrNjCmDFhCYIwpps8DS4H3ArelH7OBhcaUAU+pAzDGzA4icjHwduB3qvp9EdmY3mQtBMaUAVHVUsdgjJnhRKQGeAZoBo5T1UMi4gYGgDjQqPbPyJiSsi4DY0wxfAZYCbxHVQ8BqGoSeB6oB5aXLjRjDFhCYIwpMBE5D3gn8FtV/cGozU+lb63bwJgSs4TAGFMwIlIF/A/QhzN+YLSn07c2sNCYErNBhcaYQvo0sBZ4s6q2jbH9qfSttRAYU2I2qNAYY4wx1mVgjDHGGEsIjDHGGIMlBMYYY4zBEgJjjDHGYAmBMcYYY7CEwBhjjDFYQmCMMcYYLCEwxhhjDJYQGGOMMQZLCIwxxhgD/H/DSmZMhDO5VgAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "transformed = (values.T/comp_ratios).T\n",
    "plt.figure(figsize=(8,6))\n",
    "plt.plot(lambdas, transformed.mean(axis=0), '-', linewidth=3)\n",
    "plt.fill_between(lambdas, transformed.mean(axis=0) - transformed.std(axis=0), transformed.mean(axis=0) + transformed.std(axis=0), alpha=.2)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.xlabel('$\\lambda$', fontsize=20)\n",
    "plt.ylabel('Competitive Ratio', fontsize=20)\n",
    "plt.title(\"\")\n",
    "plt.savefig(\"synthetic_lambda.pdf\", bbox_inches = 'tight', dpi=100)\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "e03d09ff",
   "metadata": {
    "hidden": true,
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.1\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    }
   ],
   "source": [
    "n = 500\n",
    "A = -np.random.randint(low=0, high = 2, size = (n,n))\n",
    "b = -np.ones(n)\n",
    "c = np.random.random(n)*20\n",
    "bounds = [(0, None) for t in range(n)]\n",
    "res = linprog(c, A_ub=A, b_ub=b, bounds=bounds)\n",
    "p_vals = np.linspace(0, 0.5, 15)\n",
    "all_result = []\n",
    "\n",
    "for lam in [0.1]:\n",
    "    print(lam)\n",
    "    curr_result = np.zeros((15,20))\n",
    "    for j in range(15):\n",
    "        p = p_vals[j]\n",
    "        for i in range(20):\n",
    "            new_hint = noisy_alter(res.x, p)\n",
    "            curr_result[j,i] = c.dot(phase_scheme(c, -A, new_hint, n, lam))\n",
    "    all_result.append(curr_result)\n",
    "\n",
    "advice_only = np.zeros((15,20))\n",
    "for j in range(15):\n",
    "    p = p_vals[j]\n",
    "    for i in range(20):\n",
    "        new_hint = noisy_alter(res.x, p)\n",
    "        advice_only[j,i] = c.dot(listen_to_advice(-A, new_hint))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "38b89508",
   "metadata": {
    "hidden": true,
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[array([[4.40699331, 4.40699331, 4.40699331, 4.40699331, 4.40699331,\n",
      "        4.40699331, 4.40699331, 4.40699331, 4.40699331, 4.40699331,\n",
      "        4.40699331, 4.40699331, 4.40699331, 4.40699331, 4.40699331,\n",
      "        4.40699331, 4.40699331, 4.40699331, 4.40699331, 4.40699331],\n",
      "       [4.40699331, 4.40699331, 5.43619357, 7.7125888 , 4.76335156,\n",
      "        5.43619357, 4.40699331, 4.44624446, 4.40699331, 5.47009964,\n",
      "        4.40699331, 4.40699331, 4.40699331, 4.49166873, 4.40699331,\n",
      "        4.40699331, 4.40699331, 4.40699331, 4.40699331, 4.40699331],\n",
      "       [4.40699331, 4.40699331, 7.60573564, 7.68273072, 5.47009964,\n",
      "        4.40699331, 7.7125888 , 4.40699331, 7.56502802, 7.7125888 ,\n",
      "        4.40699331, 7.7125888 , 5.19533057, 4.53435959, 5.19533057,\n",
      "        4.40699331, 4.40699331, 4.40699331, 5.21944072, 4.45884041],\n",
      "       [7.67061667, 4.77168545, 4.76335156, 4.40699331, 4.72502779,\n",
      "        5.02991172, 5.38829391, 4.77652284, 7.43754337, 5.1686509 ,\n",
      "        5.08479923, 5.43619357, 7.73655487, 5.43619357, 7.52183658,\n",
      "        5.09706144, 4.61333689, 4.40699331, 7.63202048, 4.64386577],\n",
      "       [7.76596622, 4.9136406 , 5.05027742, 5.41243995, 4.64386577,\n",
      "        4.90421297, 4.75626041, 4.40699331, 5.20513518, 4.40699331,\n",
      "        4.40699331, 7.32543962, 5.42459204, 4.98439488, 4.8416546 ,\n",
      "        7.66210152, 7.71865535, 7.6907442 , 5.47009964, 4.43829191],\n",
      "       [5.08753686, 4.94839533, 6.66907243, 7.65570749, 4.40699331,\n",
      "        4.76335156, 7.51958343, 5.16695233, 7.57645634, 7.66864072,\n",
      "        7.32293425, 7.75972903, 4.49166873, 7.60573564, 4.40699331,\n",
      "        7.50378089, 7.73655487, 4.61333689, 7.72251406, 7.71567302],\n",
      "       [7.53092173, 7.41288795, 5.45058155, 7.72546578, 5.19029468,\n",
      "        7.60532873, 7.75128947, 4.71113995, 4.77652284, 4.7835073 ,\n",
      "        8.38330662, 5.11007377, 4.98439488, 4.40699331, 7.19215539,\n",
      "        5.06337926, 8.83661916, 8.33669835, 5.01176232, 7.58078498],\n",
      "       [7.52960574, 7.53551112, 7.32474866, 4.70970128, 7.71169919,\n",
      "        5.47009964, 4.95535911, 4.37819914, 5.04619413, 4.76335156,\n",
      "        7.7125888 , 7.708715  , 5.08753686, 5.58258031, 5.24532802,\n",
      "        7.57503663, 4.93775071, 8.57198266, 5.39804727, 4.70399365],\n",
      "       [5.39804727, 7.7580883 , 7.38753024, 8.34937035, 5.21944072,\n",
      "        5.1961487 , 7.71835252, 4.67837074, 7.46738992, 7.34865336,\n",
      "        5.05616097, 5.53634926, 7.32474866, 4.94839533, 7.52907984,\n",
      "        5.11804866, 5.27314823, 7.52996532, 5.43619357, 7.68826329],\n",
      "       [7.54312503, 7.34989175, 4.8372566 , 4.79508589, 7.5617863 ,\n",
      "        7.59202777, 7.62972452, 7.69875357, 4.33198757, 7.43582412,\n",
      "        5.49774126, 6.7669612 , 7.36050514, 7.52359643, 7.48186653,\n",
      "        7.51661547, 4.40699331, 7.4743984 , 8.83534749, 7.77374533],\n",
      "       [7.3533305 , 5.12077396, 5.05027742, 5.16778318, 4.33198757,\n",
      "        7.7125888 , 8.58625833, 7.3236005 , 7.39831042, 8.69347495,\n",
      "        7.52996022, 7.69326589, 7.72781781, 7.34544414, 8.64857066,\n",
      "        7.49916469, 7.52573459, 7.70456991, 4.7309201 , 7.55461141],\n",
      "       [8.67655893, 7.70111884, 7.46008423, 7.69292484, 7.69084638,\n",
      "        4.69047547, 7.34505843, 8.76710003, 7.32037954, 7.33230492,\n",
      "        8.79738326, 7.68613037, 4.39376125, 7.54257932, 7.8741008 ,\n",
      "        7.52705963, 5.15550087, 7.54147488, 7.6639322 , 7.32655043],\n",
      "       [7.352731  , 7.38145104, 8.79573402, 7.521295  , 7.55225176,\n",
      "        7.68357074, 7.43736898, 6.8190243 , 7.50187784, 4.73506565,\n",
      "        7.35386483, 5.21843276, 7.38145104, 7.56906109, 7.34851631,\n",
      "        7.50187784, 7.52492843, 7.70012349, 7.54122616, 7.32000806],\n",
      "       [7.39579165, 7.72714149, 4.84417371, 7.4003429 , 4.3659932 ,\n",
      "        7.36676586, 7.26121116, 7.37254638, 7.50659113, 7.67589821,\n",
      "        7.53766558, 7.36249043, 7.33279178, 7.61815139, 7.5385043 ,\n",
      "        7.30813944, 7.3349241 , 7.52982041, 4.90594013, 7.35556949],\n",
      "       [4.43489661, 7.35971893, 7.32000806, 7.34989175, 8.60732181,\n",
      "        7.39328518, 7.38193673, 7.98679171, 7.48536975, 4.78418425,\n",
      "        5.13994597, 5.38149297, 7.52233742, 7.4012251 , 7.35825209,\n",
      "        7.36074977, 7.41996834, 7.5477986 , 8.0098317 , 7.42124858]])]\n",
      "0.8565934591231654\n",
      "[1.00000000e+00 1.16291337e+00 1.62550112e+00 2.42079047e+00\n",
      " 3.29855577e+07 1.87984110e+08 6.81012050e+07 2.53136169e+08\n",
      " 2.70685763e+08 2.63776592e+08 5.99705255e+08 5.03611228e+08\n",
      " 5.88759736e+08 7.26730615e+08 6.42522513e+08]\n"
     ]
    }
   ],
   "source": [
    "print(all_result)\n",
    "print(c.dot(res.x))\n",
    "print(advice_only.mean(axis=1)/c.dot(res.x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "be4edcf8",
   "metadata": {
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_vals = np.linspace(0, 0.5, 15)\n",
    "plt.figure(figsize=(8,6))\n",
    "plt.plot(p_vals, all_result[0].mean(axis=1)/c.dot(res.x), linewidth=3, label='$\\lambda = 0.1$')\n",
    "plt.fill_between(p_vals, all_result[0].mean(axis=1)/c.dot(res.x) + all_result[0].std(axis=1)/c.dot(res.x), all_result[0].mean(axis=1)/c.dot(res.x) - all_result[0].std(axis=1)/c.dot(res.x), alpha=.2)\n",
    "plt.legend(fontsize=20)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.xlabel('Corruption Fraction', fontsize=20)\n",
    "plt.ylabel('Competitive Ratio', fontsize=20)\n",
    "plt.xlim([-0.01, 0.5])\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "id": "52c9675a",
   "metadata": {
    "hidden": true,
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "1\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/k6/fv5gmm5j6k17qmldfthm5w6h0000gn/T/ipykernel_39924/1553872448.py:28: OptimizeWarning: Solving system with option 'cholesky':True failed. It is normal for this to happen occasionally, especially as the solution is approached. However, if you see this frequently, consider setting option 'cholesky' to False.\n",
      "  res = linprog(c, A_ub=-A, b_ub=b, bounds=bounds)\n",
      "/var/folders/k6/fv5gmm5j6k17qmldfthm5w6h0000gn/T/ipykernel_39924/1553872448.py:28: OptimizeWarning: Solving system with option 'sym_pos':True failed. It is normal for this to happen occasionally, especially as the solution is approached. However, if you see this frequently, consider setting option 'sym_pos' to False.\n",
      "  res = linprog(c, A_ub=-A, b_ub=b, bounds=bounds)\n",
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=2.74372e-54): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "2\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "3\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=2.03537e-31): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "4\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/k6/fv5gmm5j6k17qmldfthm5w6h0000gn/T/ipykernel_39924/1553872448.py:16: OptimizeWarning: Solving system with option 'cholesky':True failed. It is normal for this to happen occasionally, especially as the solution is approached. However, if you see this frequently, consider setting option 'cholesky' to False.\n",
      "  res = linprog(c, A_ub=-A, b_ub=b, bounds=bounds)\n",
      "/var/folders/k6/fv5gmm5j6k17qmldfthm5w6h0000gn/T/ipykernel_39924/1553872448.py:16: OptimizeWarning: Solving system with option 'sym_pos':True failed. It is normal for this to happen occasionally, especially as the solution is approached. However, if you see this frequently, consider setting option 'sym_pos' to False.\n",
      "  res = linprog(c, A_ub=-A, b_ub=b, bounds=bounds)\n",
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=5.28041e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=5.03674e-23): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=9.80783e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=3.93026e-22): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=9.79036e-22): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "6\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "7\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "8\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=3.12424e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=3.69634e-20): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "9\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=1.00817e-20): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "10\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "11\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=6.57325e-20): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "12\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "13\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=2.29777e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=8.63452e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=2.24984e-22): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=7.14247e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "14\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "15\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=6.01429e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "16\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "17\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=1.15373e-20): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "18\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=1.04637e-36): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n",
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=1.23828e-37): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n",
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=7.40314e-22): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=8.03288e-23): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=1.92381e-20): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "19\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=2.01537e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "20\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=1.46828e-20): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "21\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "22\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "23\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "24\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/sandeepsilwal/opt/anaconda3/lib/python3.9/site-packages/scipy/optimize/_linprog_ip.py:117: LinAlgWarning: Ill-conditioned matrix (rcond=1.32721e-21): result may not be accurate.\n",
      "  return sp.linalg.solve(M, r, sym_pos=sym_pos)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "0\n",
      "[[4.58396471 6.99420766 4.78947635 4.77905852 4.77892011 4.74639774\n",
      "  4.74590491 4.74639641 4.80200212 4.80595797 4.8050299  4.80598631\n",
      "  4.8053026  4.80621143 4.80564395 4.80528234 4.80585162 4.80566791\n",
      "  4.82258151 4.82249965]\n",
      " [6.77575445 6.77647761 7.0767133  7.0602366  7.89774559 7.01997756\n",
      "  7.01949751 6.73745818 4.36228322 4.28752291 4.49924497 4.49904679\n",
      "  4.49874516 4.49877691 4.49856591 7.11922796 7.14665493 7.14642009\n",
      "  4.47409391 8.28593995]\n",
      " [4.13947702 4.14719937 3.96295911 3.96298598 4.15137383 3.97351755\n",
      "  6.48014708 4.05459031 6.49077246 4.16266666 6.53097727 6.53143799\n",
      "  6.53054989 6.99419967 4.08614025 4.08605314 4.08616137 4.04931148\n",
      "  4.04778441 4.13178804]\n",
      " [7.14063519 6.84103859 6.9325901  6.92775061 6.92814743 6.92830041\n",
      "  4.42537996 6.98581836 6.98571395 6.98538226 6.98435186 6.98365365\n",
      "  4.33998079 4.30167208 4.45154719 4.45075385 4.37176429 7.00262683\n",
      "  7.00193292 7.00173442]\n",
      " [4.11243648 4.11199528 4.11223859 4.11141632 4.11147227 4.11143941\n",
      "  4.05037844 4.16717524 4.24540085 4.08391459 4.04200443 4.0420819\n",
      "  4.04202351 4.03275672 4.07990629 3.92938052 3.9888794  4.01245237\n",
      "  3.93012094 3.92967206]\n",
      " [4.20975632 4.36565158 4.30187163 4.3016008  4.30204419 4.14988552\n",
      "  6.51948508 4.15012584 4.14752673 4.2994393  4.29892444 4.29908117\n",
      "  4.46720933 4.46614512 4.47481212 4.45209651 4.452249   6.61235636\n",
      "  6.61218302 4.27088632]\n",
      " [3.97337866 4.44502178 4.44536235 4.18353458 4.18431872 4.2116049\n",
      "  4.37356403 4.18344022 4.18376112 4.23051037 4.23189674 4.232218\n",
      "  4.23284813 4.23471226 4.23465454 4.22151788 4.29090101 4.29061415\n",
      "  4.2579485  4.28122682]\n",
      " [5.93800295 5.96838108 5.9683716  5.99838646 5.99869468 5.93670788\n",
      "  5.93705674 5.92599915 5.92595335 6.01305457 6.01312416 5.85098028\n",
      "  5.85095884 6.2008005  6.02921692 6.10870627 6.10704263 6.1319415\n",
      "  5.85778543 6.1221032 ]\n",
      " [4.20342365 4.2033994  4.27499361 4.20320246 4.42759956 4.2970369\n",
      "  4.28550673 4.28565159 4.28565507 4.6565276  4.65652601 4.7094637\n",
      "  4.70967602 4.73579514 4.62265399 4.68814245 4.71056002 4.87415182\n",
      "  4.88743169 7.11142804]\n",
      " [5.66953251 5.36417595 5.49297962 5.49295387 5.59564312 5.5956655\n",
      "  5.72519518 5.69956696 5.71797646 5.53910858 5.89967026 5.59590609\n",
      "  5.67453933 5.67434748 5.63313881 5.39105024 5.56979344 5.28928776\n",
      "  5.67855234 5.6260276 ]\n",
      " [4.46622407 4.46339075 4.57437861 4.65486733 4.61803462 4.50503382\n",
      "  4.46070851 4.42259321 4.40171678 4.40233062 4.51007163 4.48120158\n",
      "  4.505898   4.47328639 4.48036386 4.54284442 4.52589084 4.57037246\n",
      "  7.0354768  4.48397822]\n",
      " [4.57517732 6.36742716 7.22786706 7.14265144 7.13272964 7.1348543\n",
      "  7.15348564 4.62622381 4.6042688  4.75042551 4.46050829 4.53618695\n",
      "  7.30276601 6.81518542 6.75141378 6.89270719 6.89245629 6.96002074\n",
      "  6.95494191 6.68683959]\n",
      " [3.77523406 5.73795776 5.73977067 5.74001506 5.73901233 5.73900882\n",
      "  5.78843334 5.79459036 5.74514408 5.74439355 5.6850012  5.68941168\n",
      "  5.68920615 5.5789658  5.58003527 5.62650723 5.64453309 5.64515413\n",
      "  5.64690429 5.64690656]\n",
      " [4.23197006 4.232208   6.76918943 6.76918388 4.20422332 4.18807528\n",
      "  4.18195378 6.6681947  8.03789505 3.88435178 3.88496222 3.70748235\n",
      "  3.9289102  3.9291138  3.9300875  3.93038205 3.93054564 3.93074807\n",
      "  4.19488185 3.93244243]\n",
      " [3.98591395 4.19713679 4.08952584 3.98929721 3.98893105 3.98921555\n",
      "  6.59071582 6.45795736 6.46023242 4.01322858 4.22220857 6.48079742\n",
      "  6.48080204 4.12094767 4.16621003 4.16522024 6.51508414 4.08803786\n",
      "  4.08785793 4.13744517]\n",
      " [4.10354806 4.12810288 4.1349559  4.02240967 4.0222287  4.00414477\n",
      "  3.92571757 3.92417055 3.92415053 3.92365757 5.13854332 5.00143538\n",
      "  4.76059537 5.11968534 5.12013379 4.99359433 5.14724589 5.15734723\n",
      "  5.11792383 5.10226049]\n",
      " [5.58023943 5.58023224 5.58013963 5.57857962 5.57853558 5.52307819\n",
      "  5.5237639  5.54911811 5.54922903 5.52511687 5.52479864 5.44581976\n",
      "  5.44564453 5.45111076 5.54631143 5.53387588 5.53145788 5.43047436\n",
      "  5.43186179 5.43179159]\n",
      " [5.29030787 6.37086974 6.37091217 6.37010229 6.3704855  5.93727041\n",
      "  5.93760679 5.90693541 6.01518476 6.01503324 5.97428283 5.67977863\n",
      "  5.85512144 5.64995152 5.65006484 5.76272365 5.76262521 5.79883496\n",
      "  5.86623307 5.86073571]\n",
      " [6.77882931 4.34880745 4.26485163 6.49531173 6.5753876  6.56370446\n",
      "  6.56368313 6.56388706 7.1565646  6.56361506 6.5631229  7.33039894\n",
      "  6.56288089 6.55453407 6.55494543 6.71920796 6.71507783 6.76467824\n",
      "  6.76391999 6.76383261]\n",
      " [3.93957475 3.9393735  3.93943597 3.93868016 4.00048872 4.00009702\n",
      "  4.0012117  3.96171779 3.96183598 3.96268242 4.1307404  4.22468138\n",
      "  4.22479092 4.24955385 4.24929635 4.1815843  4.20479949 4.20495619\n",
      "  4.20496881 4.20536716]\n",
      " [4.30220114 4.36830847 4.45990434 4.45769939 4.45684804 4.45657439\n",
      "  4.45680262 4.4568425  4.45685134 4.36882148 4.36877688 4.1297368\n",
      "  4.13069429 4.13577302 4.06456886 4.09650578 4.09658756 4.09671921\n",
      "  4.11751453 4.18491528]\n",
      " [5.30119594 5.3129307  5.40714101 5.38048684 5.34314933 5.33198277\n",
      "  5.31521686 5.20201154 5.22886577 5.08587416 5.42308938 5.4535957\n",
      "  5.41360254 5.41761082 9.1466357  5.51022832 5.50402967 5.05884871\n",
      "  5.12160223 5.10830963]\n",
      " [6.81735299 6.81592874 6.81623648 6.78944574 8.10038743 6.82040498\n",
      "  6.73779208 6.73683273 6.73697613 6.70366647 6.73175488 6.73132214\n",
      "  6.7163842  6.71632863 6.75147196 6.6806247  6.79871803 4.07593731\n",
      "  3.93394575 6.67393486]\n",
      " [5.35941043 5.1059092  5.12681891 5.22920385 5.47495025 5.47398143\n",
      "  5.46919942 5.21546894 5.60927277 5.39806865 5.40789807 5.46418652\n",
      "  5.46161849 5.46561921 5.08625669 5.08296945 5.32852234 5.32832699\n",
      "  5.27549368 5.54929407]\n",
      " [5.39968141 5.39958284 5.33524254 5.40892521 5.41074246 5.1784208\n",
      "  5.67767675 5.14082284 5.14129761 5.14241666 5.14225117 5.18825115\n",
      "  5.35184104 5.27884902 5.30853393 5.26384077 6.2615478  5.3525393\n",
      "  5.44162013 5.29791915]]\n",
      "[[ 4.58396471  4.58669143  7.85638853  7.85547333  7.85556623  7.85578382\n",
      "   7.85567519  7.85452649  7.85502145  7.85724267  7.85497996  7.8527046\n",
      "   7.85273476  7.85549958  7.9046275   7.90458895  7.90415413  7.90184781\n",
      "   7.8998207   7.91874171]\n",
      " [ 6.77575445  6.77647761  6.82370586  6.81400291  6.81597158  7.98115387\n",
      "   7.9448027   7.94430337  7.79929249  7.80529014  7.74622928  7.74603421\n",
      "   7.76274879  7.76212338  7.76165188  7.7477515   7.89656382  7.89441332\n",
      "   7.89473863  7.98691119]\n",
      " [ 4.13947702  4.14719937  7.91035254  7.95701184  7.78492824  7.77752222\n",
      "   4.25769998  4.25772243  4.24878777  4.24892345  4.2487079   6.92415509\n",
      "   6.62517527  6.62450119  6.62483218  7.00295421  6.60012888  6.60192295\n",
      "   6.58247708  7.82867916]\n",
      " [ 7.14063519  7.1251447   7.12539791  7.1261539   7.12518075  6.89603478\n",
      "   6.89592781  7.20583391  7.30019343  7.28512377  7.28532378  7.28572581\n",
      "   7.19073861  7.05506622  7.05617715  7.05645417  7.01421086  7.01511233\n",
      "   7.01545003  7.01549362]\n",
      " [ 4.11243648  4.11199528  4.11223859  4.11141632  4.11147227  4.11143941\n",
      "   4.11147438  4.14200972  3.97328429  4.14837831  4.14800189  4.22454225\n",
      "   4.22427378  4.19559626  4.14427707  4.14412447  4.1439335   4.14409428\n",
      "   4.14387099  4.1206245 ]\n",
      " [ 4.20975632  4.43059931  4.39757823  4.3978052   4.39797392  4.16033948\n",
      "   4.17776446  4.17769749  4.17777439  4.61220793  4.6123805   4.57553103\n",
      "   4.57567636  4.57565659  4.56990539  6.72135497  6.72072408  8.09314989\n",
      "   8.09324024  9.13949723]\n",
      " [ 3.97337866  4.48976524  4.49012022  4.41652769  4.41647687  4.41641624\n",
      "   4.41813971  4.42590554  4.42605828  4.35587775  4.35605639  4.35644049\n",
      "   4.35710649  4.359555    4.35957858  4.35952606  7.48635879  7.4819365\n",
      "   7.48225088  7.49235626]\n",
      " [ 5.93800295  5.92285579  5.92288383  5.92357117  5.93425045  5.94525347\n",
      "   5.94564634  5.94643968  5.94627573  6.23422047  6.19420733  6.17662211\n",
      "   6.17652293  5.84626606  5.71520024  5.84090593  5.83717231  5.91485963\n",
      "   6.01823718  6.5461323 ]\n",
      " [ 4.20342365  4.20339937  4.20308245  4.17837022  6.59858028  6.52102792\n",
      "   6.52143816  6.53250181  6.53223321  7.09298811  7.09298572  7.08773446\n",
      "   7.08299486  7.1097051   7.72422423  7.72360104  7.72359841  7.72341614\n",
      "   7.72253645  7.72234893]\n",
      " [ 5.66953251  5.58730139  5.57382597  5.57161228  6.35941938  6.35912995\n",
      "   6.37845827  5.63702768  5.67295627  5.65177241  5.4718229   5.4761037\n",
      "   5.46447133  5.46435681  5.46171791  5.46120265  5.46120899  5.47305886\n",
      "   6.96285468  6.93481224]\n",
      " [ 4.46622407  4.46339075  8.32580743  8.32532408  8.32475145  8.32468291\n",
      "   8.32650257  8.32486453  8.32106396  8.31235257  7.72270225  7.51481281\n",
      "   7.70754756  7.70972481  7.47970463  7.48644182  7.4843612   7.33784852\n",
      "   7.34287886  7.51391351]\n",
      " [ 4.57517732  8.68292529  8.68278457  8.68373219  4.53496031  4.73663132\n",
      "   4.55144096  4.55257678  8.55516257  8.54863316  8.54863116  9.24787996\n",
      "   7.80684012  7.83026235  7.82925708  7.81895739  7.82026155  7.81771259\n",
      "   7.81788983  7.81490459]\n",
      " [ 3.77523406  3.77601687  3.77717884  3.77720082  3.77717394  3.77717394\n",
      "   3.77715484  3.77704794  3.77582004  3.77463651  3.77595473  3.78137203\n",
      "   3.780857    8.04929664  8.04959157  8.07178447  8.07198643  8.07445788\n",
      "   8.08382261  8.08180411]\n",
      " [ 4.23197006  4.232208    8.21362524  8.21563861  8.21562902  8.00298388\n",
      "   8.00619724  8.0200848   8.02102326  3.7691158   3.76941651  4.14902186\n",
      "   3.76813769  3.76813627  3.76805161  3.76904195  3.76916741  3.76583675\n",
      "   3.76605751  3.76626352]\n",
      " [ 3.98591395  4.2044134   4.20314679  4.20296881  4.20264492  4.20311669\n",
      "   4.00916712  4.03988588  4.03990769  4.08625895  4.08650205  4.08618335\n",
      "   4.08662688  4.08671061  4.08648985  4.08433537  4.08436882  4.08486462\n",
      "   7.62346986  8.43250993]\n",
      " [ 4.10354806  4.1035313   4.10455002  4.01932262  4.02030803  4.00807021\n",
      "   4.00768252  4.00899801  4.1014548   4.10130884  5.33790483  5.33789176\n",
      "   5.33830383  5.33851968  5.33885461  5.41812675  5.41788382  5.41769884\n",
      "   5.68338221  5.68276939]\n",
      " [ 5.58023943  5.58023223  5.58013963  5.56622311  5.56617916  5.30295638\n",
      "   5.30344951  5.3035111   5.30362291  5.30436279  5.30441339  5.30319078\n",
      "   5.30297367  5.30408937  5.30409476  5.46568191  5.46563354  5.46151846\n",
      "   5.46214635  5.46209827]\n",
      " [ 5.29030787  5.91023763  5.91071633  5.90863028  5.90891401  6.55428342\n",
      "   6.55365672  6.79608941  6.69287404 10.16988216 10.18209219 10.18042791\n",
      "  10.78384855 10.77239399 10.76937597 10.54164676 10.54161905 10.53999029\n",
      "  10.53890864 10.56835757]\n",
      " [ 6.77882931  6.59346537  6.59521933  6.59118191  6.59270041  6.56831058\n",
      "   6.56825654  6.56846962  6.5686057   6.56816573  6.56763506  6.5674839\n",
      "   6.56738643  6.56638567  6.56776469  6.56763553  6.56675381  6.57304723\n",
      "   6.57211531  6.57185162]\n",
      " [ 3.93957475  3.93937349  3.93943597  3.93868016  3.93708259  3.93733061\n",
      "   3.94036912  3.9260734   3.92622357  3.92809772  3.92863186  6.37205644\n",
      "   6.37487658  6.37859041  6.37461182  7.97318503  7.97279358  7.96611214\n",
      "   7.97670808  7.97032044]\n",
      " [ 4.30220114  4.30248343  7.48294401  7.16907366  7.15902525  7.15860462\n",
      "   7.29151043  7.30589894  7.30590759  7.30633087  7.31779552  7.31923964\n",
      "   7.29539452  7.23488368  7.2346859   7.48243008  7.48162882  7.48182697\n",
      "   7.57127579  7.4662693 ]\n",
      " [ 5.30119594  5.30013354  5.28198959  5.28224261  5.28198643  5.17295302\n",
      "   5.16550363  5.16538762  5.16484514  5.63283997  5.73887571  5.73999018\n",
      "   9.61102577  9.4334513   9.43345445  9.29193828  9.19248307  9.19186545\n",
      "   9.19187453  9.45161043]\n",
      " [ 6.81735299  6.34918048  6.34916475  7.7828913   7.76319099  7.76288024\n",
      "   7.76227342  7.7582421   7.75806665  7.75136445  7.74265566  7.74314867\n",
      "   7.74297325  7.74297176  7.74374037  7.74450235  7.7185191   7.64783646\n",
      "   7.64799673  7.73495388]\n",
      " [ 5.35941043  5.1059092   5.12681891  8.04825444  7.81546407  7.8154564\n",
      "   7.81482761  7.81315184  7.82446678  7.81005671  7.80935495  7.85297904\n",
      "   7.86454428  7.86000288  8.89600672  9.43703141  9.04590734  9.04990814\n",
      "   9.04828278  9.03610172]\n",
      " [ 5.39968141  5.39958284  5.37770014  5.377886    5.37816016  5.20097852\n",
      "   5.19661704  5.19659932  5.19705305  5.19819392  5.19802115  5.24991201\n",
      "   5.32379541  5.32406139  5.31599193  5.31676595  5.31769277  5.31784414\n",
      "   5.31717938  5.33472457]]\n",
      "[[ 8.71736483  8.68411618  8.68693226  8.69112357  8.67496698  8.67540605\n",
      "   8.67623834  7.73819889  7.73720051  7.73746418  7.7385851   8.61682764\n",
      "   9.01311724  8.99447553  8.99101915  8.99396002  8.59794753  8.59800247\n",
      "   8.99338481  8.99159669]\n",
      " [ 8.53186317  8.53278495  8.5675904   8.56713895  8.53086532  8.8522748\n",
      "   8.85414062  8.85383561  8.45145027  8.45018085 12.07284474 12.07204358\n",
      "  12.07204919 12.06360675 12.07557794 12.0767617  12.07778079 12.06329965\n",
      "  12.04410725 12.04582896]\n",
      " [ 7.23056608  7.23103494  7.20678502  7.1812444   7.21105531  7.20687412\n",
      "   7.87321071  7.98402287  7.98432117  7.98445633  8.00677742  7.98540182\n",
      "   8.02499257  8.02802543  7.99881192  7.8612403   7.86226386  7.8556088\n",
      "   7.85557475  7.84430147]\n",
      " [ 8.15207698  8.15563982  8.15620433  8.16756369  7.86143507  7.86066726\n",
      "   7.85661762  7.85781205  7.85803193  7.84875782  7.87604598  7.85170662\n",
      "   7.70633297  7.7072525   7.70726987  7.7255508   7.73167479  7.73137131\n",
      "   7.93944406  7.93562466]\n",
      " [ 7.49502696  7.49467697  7.51914582  7.4941533   7.20511656  7.2052396\n",
      "   8.32930837  7.27131258  7.4961984   8.30477303  8.30511395  8.30699898\n",
      "   8.30592054  8.28647825  7.3243708   7.33287213  7.33276385  7.32618028\n",
      "   7.33184643  7.33118435]\n",
      " [ 7.5903892   7.52349364  7.523525    7.52532866  7.52643933  7.52739298\n",
      "   7.52748968  7.52249276  7.51995231  7.96467221  7.9647415   7.96442297\n",
      "   7.96436887  7.96864136  7.97674866  7.95926845  7.95907788  9.06115768\n",
      "   9.06007644  9.06824004]\n",
      " [ 7.08315864  8.13877068  8.14013692  8.01531856  8.0147885   8.01448439\n",
      "   8.02832983  7.85943502  7.85931891  7.28819115  7.99573129  8.12037507\n",
      "   7.36233328  7.31534373  7.31543684  7.31551527  7.2401537   8.02408061\n",
      "   8.03839234  8.03896431]\n",
      " [10.03379789 10.00350262 10.00356577 10.00626157 10.00841929 10.06602799\n",
      "  10.06682616 10.0728091  10.07456958 10.09209217 10.08077994 10.08568227\n",
      "  10.08324493 10.08540518 10.08455351 10.08537902 10.08481812  9.40933166\n",
      "   9.41191166  9.46421635]\n",
      " [ 7.9423289   7.94425738  7.94439587  7.94615655  7.94553277  7.69946915\n",
      "   7.69935248  8.03666206  8.03705128  7.86383709  7.86348131  7.86358427\n",
      "   7.86486337  7.87200995  7.90997392  7.90920669  7.90908767  7.9087417\n",
      "   7.90729302  7.90657256]\n",
      " [ 9.37537671  9.6605798   9.66048087  9.65808096  9.77222969  9.77059265\n",
      "   9.77103159  9.77681644  9.7838303   9.36837346  9.27835005  9.26757755\n",
      "   9.27092362  9.27097253  9.27054292  9.28749474  9.28778398  9.28903822\n",
      "   9.69081999  9.67261479]\n",
      " [11.14435811 11.12174923 11.14523971 11.16497696  7.92050488  7.92068564\n",
      "  11.08801816 11.18283742 11.18163283 11.15572127 11.06919153 11.066302\n",
      "  11.07180781 11.08001524  8.16869931  8.1684524   8.1663085  11.1624202\n",
      "  11.15404616 11.27705156]\n",
      " [ 8.44188698  8.41521041  8.42157262  8.41977614  8.42020011  8.41986477\n",
      "   8.42041601  8.28641919  8.2857409   8.28246572  8.54880203  8.50770205\n",
      "   8.50316455  8.4702759   8.47160709  8.46681397  8.46659031  8.46183081\n",
      "   8.50760554  8.50818382]\n",
      " [ 9.03571257  9.03560299  9.04016547  9.03960543  9.04057803  6.96194835\n",
      "   6.96136136  6.96154279  7.12644509  7.12830854  9.14124576  9.13947807\n",
      "   9.1419962   9.68744412  9.68539324  9.68366389  9.68373871  9.6853693\n",
      "   9.70099494  9.69854588]\n",
      " [ 7.94841469  7.02992116  7.02934079  8.20047171  7.0269953   7.02763588\n",
      "   7.02684269  8.22434999  8.22416366  7.64132571  7.64374663  7.30593274\n",
      "   7.29588346  7.29538559  7.27149712  7.27451301  7.27568906  7.2807436\n",
      "   7.2899772   7.28931422]\n",
      " [ 7.62043618  7.6199579   7.62072016  7.61242996  7.6131801   7.61153991\n",
      "   7.41917238  7.55777797  7.55765212  7.55670172  7.55701183  7.54891538\n",
      "   7.55840429  7.58250482  7.58162666  7.57839657  7.5784334   7.9220911\n",
      "   7.91591685  7.91886421]\n",
      " [ 7.63559897  7.63490084  7.43242665  6.89523988  6.89700401  6.89720468\n",
      "   6.89889484  7.28959675  7.28794437  7.28829195  5.86766183  5.86765505\n",
      "   8.77151404  8.77199795  8.76778888  5.87748147  5.87715463  5.87686705\n",
      "   5.87810034  5.87770393]\n",
      " [ 9.85933406  9.8607404   9.85847069  9.9114568   9.91258809  9.64222731\n",
      "   9.64009845  9.63747457  9.63746485  8.75346042  8.74728941  8.74654005\n",
      "   8.74831018  8.74771614  8.74873827  6.31520583  6.31583604  6.29353128\n",
      "   6.29351682  6.29350281]\n",
      " [11.0707628  11.05730463 11.05340166 11.05271224 11.05187606 10.23048277\n",
      "  10.22845202 10.22934089 10.22959635 10.22790592 10.21854788 10.24518776\n",
      "  10.2380688  10.20935055 10.21304864 10.21351929 10.21351981 10.21227177\n",
      "  10.21301938 10.23659684]\n",
      " [ 7.78625904  7.68433169  7.68444474  7.68448569  7.66880279  7.61705715\n",
      "   7.61713314  7.66795544  7.05723935  7.04836997  7.04820152  7.04815263\n",
      "   7.04848106  7.0339262   7.03423026  7.60384074  7.6272587   7.6280199\n",
      "   7.62754199  8.03496313]\n",
      " [ 8.80918607  8.80678843  8.82023648  8.22374048  8.2230478   8.22239361\n",
      "   8.19482515  8.21042214  8.21253875  8.21833039  8.20710366  8.35602498\n",
      "   8.35985413  8.37253361  8.34759043  8.36010867  8.36033227  8.32851682\n",
      "   8.29100252  8.29203137]\n",
      " [ 8.10848145  8.1102169   8.11549629  8.1013884   8.1001131   8.09756168\n",
      "   8.1078014   8.07554944  8.07949342  7.84067658  7.84079505  7.84152749\n",
      "   7.84930402  7.80647991  7.80867526  7.82004294  7.8202127   7.82409497\n",
      "   7.88503701  7.88454182]\n",
      " [ 8.54311813  8.54203     8.54244901  8.54321395  8.54078777  8.53919515\n",
      "   8.51388967  8.51409982  8.51513652  8.51652457  8.53986255  8.55150195\n",
      "   9.81211643  9.78499016  9.78353263  9.84433122  9.78737922  9.78786834\n",
      "   9.78821949  9.75978261]\n",
      " [11.16029668 11.15949174 11.1601     11.1598753  10.95370082 10.95385008\n",
      "  10.95731263 10.95531152 10.95433216  8.32336166  8.32268827  8.34846824\n",
      "   8.32287982 11.23392065  8.42984899  8.42967329 11.23205897 11.2714812\n",
      "  11.27234009 11.23846566]\n",
      " [10.3313296  10.30096894 10.3292243   9.08480753  9.48607825  9.48799057\n",
      "   9.49063662 10.01096086 10.0096901  10.00893903 10.01067255  9.9976269\n",
      "  10.0114014  10.00977828 10.00582843 11.00919457 11.00564836 10.8178871\n",
      "  10.80691096 10.80814133]\n",
      " [ 6.59651617  6.59624434  6.60576372  6.51388038  6.51380763  6.52659634\n",
      "   6.52608208  6.52689347  6.5229708   6.52195069  6.51929921  6.52048671\n",
      "   6.19906071  6.23131048  6.21126318  6.21114702  5.89985947  6.19758413\n",
      "   9.48757023  6.19750904]]\n",
      "[1.1316405  1.23793811 1.03942749 1.13528345 0.94304623 0.9747995\n",
      " 1.03216146 1.16120622 1.0662397  1.25448185 1.14251816 1.17163038\n",
      " 1.04416733 1.14268874 1.09357204 0.95705526 1.13303352 1.38081664\n",
      " 1.11294319 1.10431587 1.08001325 1.18011245 1.2546846  1.15572334\n",
      " 1.04857267]\n"
     ]
    }
   ],
   "source": [
    "# changing roughly 500 entries \n",
    "online_results = np.zeros((25,20))\n",
    "batch_results = np.zeros((25,20))\n",
    "regular_results = np.zeros((25,20))\n",
    "comp_ratio = np.zeros(25)\n",
    "\n",
    "n = 500\n",
    "c = np.random.random(n)*20\n",
    "b = -np.ones(n)\n",
    "lam = 0.1\n",
    "bounds = [(0, None) for t in range(n)]\n",
    "\n",
    "for j in range(25):\n",
    "    print(j)\n",
    "    A = np.random.randint(low=0, high = 2, size = (n,n))\n",
    "    res = linprog(c, A_ub=-A, b_ub=b, bounds=bounds)\n",
    "    fixed = res.x\n",
    "    comp_ratio[j] = c.dot(res.x)\n",
    "    for i in range(20):\n",
    "        learned = c.dot(phase_scheme(c, A, res.x, n, lam))\n",
    "        regular = c.dot(phase_scheme(c, A, res.x, n, 1.0))\n",
    "        batch = c.dot(phase_scheme(c, A, fixed, n, lam))\n",
    "        online_results[j,i] = learned\n",
    "        batch_results[j,i] = batch\n",
    "        regular_results[j,i] = regular\n",
    "        corruption = np.random.choice(2, size = (n,n), p = [0.998, 0.002])\n",
    "        A = np.abs(A - corruption)\n",
    "        res = linprog(c, A_ub=-A, b_ub=b, bounds=bounds)\n",
    "        \n",
    "print(online_results)\n",
    "print(batch_results)\n",
    "print(regular_results)\n",
    "print(comp_ratio)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "id": "3251ceaf",
   "metadata": {
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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/vnnOX36tKvDcwmllMXN09OTkJAQevfuzXfffefq8AqFtQRECOEEpnT4bzZ83BGWvgSH/imSl7WnM2ORUUp1B8YBXYAKQCywG5iptV5ix/OjMNalsCZaa13VOZGK7LTWvPjii7z11lt4eXnRt29fhg0bRkpKChs2bOCdd97hk08+4euvv2bo0KGFEkONGjXYt28fQUFBhXL+gpo8eTIAqampHDhwgIULF7Jy5Uq2bt3Ke++95+LosjzxxBPcfffd1K5du1DO7+6/JyHc1rnd8MfTcHprVtmf/4Mnt4Fn4Q7Td5tEQSn1CjANuIAx8+NZIARoA9wA5JsomF0GZlopv1rgIIVV06ZN46233iI0NJTFixfTvHlzi/2//PILI0aM4O677+aff/6hV69eTo/B29ubJk2aOP28zjJlyhSLxytWrKBv377MnDmTp556itDQUJfElVNISAghISGFdn53/z0J4XZSEmDVG7DxY9DZ5vEIaQSDPij0JAEwvg26+gYMAzTwDxBgZb+3neeJAqIKGk+7du20PSIjI+06riQ7duyY9vLy0t7e3nrXrl02j/v00081oBs3bqzT09Mzy+fMmaMBPWfOHP3vv//qnj176nLlyumAgAA9cOBAqz/jkSNHakAfO3bMIg5Ajxw50uaxn332mW7RooX29fXVlStX1g8//LCOi4uzGu/Jkyf1448/ruvWrat9fHx0hQoV9KBBg/TmzZsd+vmY/66t7mvatKkG9M8//6y11nry5Mka0CtXrtTfffed7tChgy5btqyuU6dO5nMSEhL0a6+9plu3bq39/f112bJldadOnfT3339v9TWSk5P1q6++quvVq6d9fHx0aGionjBhgk5KStKA7tmzp8Xx2WPIad++fXr06NG6Tp062sfHR1eqVEl369ZNf/LJJ1rrrN+ltdvkyZO11rZ/T1prfebMGf3YY4/pOnXqaG9vbx0SEqKHDBmiIyIich17PX83586d088++6xu1KiR9vf310FBQbpRo0Z65MiR+siRI1Z/fjnJ/7woUgf/0fr9FlpPDsy6vRqi9co3tE5NcupLARHaxjXR5TUKSikP4E3gGjBca51rjlStdWqRBybsMmfOHNLS0rjzzjtp2bKlzeMeeughpk2bxoEDB1i9enWuWoXFixezaNEibrrpJsaOHUtkZCRLlixhy5YtREZGFvhb7vjx41m6dCmDBg2iX79+rFy5kv/7v//j8OHD/PvvvxbHbtu2jX79+hEbG0v//v25/fbbuXDhAgsXLqRbt2789ttvDBw4sEDxABnJba6JfN59913++ecfBg0aRK9evbh8+TIAcXFx9O7dm+3bt9O2bVseeOABTCYTS5cuZfjw4ezdu5fp06dbnP/OO+9k0aJF1K9fnyeeeIKUlBS++uordu/e7VCsf/75J8OGDSM5OZkBAwZwzz33EBcXx86dO3nrrbd49NFHCQsLY/LkyUydOpU6depYdFjMr8/CsWPH6NatG2fOnKF3797cc889nDx5kvnz5/Pnn3/yyy+/cMstt+R6nr1/N9euXaNr164cOXKEvn37MmjQILTWHD9+nEWLFjF06FDq1avn0M9EiEITH230Qdjzi2V5aHe45X0IaVik4bg8UcDoj1AXWABcUkrdDLQAkoDNWuuNDp7PVyk1AqgNJAC7gDVa6yKdezX0xT+L8uUKJOqNm6/7uevWrQPgxhtvzPM4Ly8vbrjhBr7//nvWr1+fK1FYuHAhS5cupU+fPpllL730Em+88QZfffUV48ePv+4YATZt2sTu3bsz297T0tLo3bs3K1euZPPmzXTo0CGz/M477+Tq1ausXLmSnj17Zp7jzJkztG/fngcffJCoqKgCrSK4fPlyDhw4gFKK9u3bW+z7999/2bhxI23atLEoHzduHNu3b+fNN9+0+HkkJSVx22238dprrzF06FDCwsIA+OGHH1i0aBGdOnVi5cqV+Pn5ATB16tRcr5mXCxcuMHz4cNLS0vj3338tfiYAp06dAiAsLIywsDCmTp1KaGhoruaWvIwdO5YzZ84wffp0JkyYkFn+2GOP0aNHD0aOHMnx48cpV66cxfPs/btZsWIFR44cYdy4cbz//vsW50hJSSE5OdnuWIUoNCYTbPsalk+GpMtZ5WWCod90CLsXXDBDqDuMesj4xIoGtmH0T3gDo5/BBqXUaqVUJQfOVxX4FphhPse/wCGlVM+8niSuz9mzZwGoVatWvsdmHHPmzJlc++6++26LD3uAMWPGALB58+aChsmkSZMsOuh5eXkxevToXOf/888/OXLkCE8++WSuC2L16tUZP348586dY8WKFQ69/pQpU5gyZQoTJkxg6NChDBgwAK0148aNo04dy/63Y8aMyZUkXLx4kXnz5hEeHp4rafLz8+PNN99Ea83333+fWT5nzhwAXnvttcwkAaBChQpMnDjR7ti//vprrly5wqOPPprrZwJQs2ZNu89lzalTp1i2bBm1a9fO9d66dOnCPffcQ2xsLL/++muu5zr6d1OmTJlcZT4+PgQEBBTkLQhRcDH7Ye5AWDzOMklodRc8EQFtRrgkSYDrqFFQSg0C7gWaAmW11g3M5U2BQcB3WmtHxsJVNm/HAseAG4H/MEYvvAv0B+ZjdGjMzxxgLbAXiAfqAU8AY4C/lFKdtdY7bbyvMebjCq3Hd0lkq/rc0WPDw8NzlWUkFpcuXSpIiA6df+NGowLr+PHjVr8RHzp0CIB9+/Y51PwwdepUwHjv5cuXp3v37jz44IOMGDEi17EZtRvZbdmyhfT0dJRSVuNKTU3NjCvDtm3b8PDwoFu3brmOd2T44qZNmwC46aab7H6OI7Zv3w5A9+7drS6y1rt3b+bNm8f27du5/37LZWfs/b327NmTGjVq8MYbb7Bt2zYGDhxI165dCQsLw9PT05lvRwjHpCbB2ndg3UwwZWtlD64Lt7wH9Xu7LLQMdicKyvh0nwtkfLIlYixDneES8BrGGhBvOhBDxn+pAoZmu5DvVUoNAQ4CPc0X+TybIbTWU3MU7QHGKqWuAs8CU4AhNp77OfA5QHh4eIFXxSxIdX5xUq1aNfbv38+JEyfyPTajirpatWq59pUvXz5XmZeX8efpjBX77D3/xYsXAZg/f36e57t61bFBNBlJkj2qVs09ijcjri1btrBlyxa74rp8+TIVKlSwevG19hq2xMXFAcbQxsKQ0QfD2t9F9vKMOLKz9/caGBjIpk2bmDx5Mr///jtLly4FjFEejz32GK+88oqsBCuK3rE18Mc4iD2SVebhBV2fhh7Pg3fuGjBXcKTp4THgPoxv7RWAd7Lv1FqfA9YDjl4hM9L+ozm/7WutE4Gl5oe5v2bZ7zPztkcBziGsyPi2unz58jyPS09Pz5ztr2vXroUd1nXLGN+/aNGiPEfGZMyLUBis1bhkxPXMM8/kGdfKlSstnhMbG5tZ25DduXPn7I4n42JcWJNmZbw3WzFlNG8VdO6FmjVr8uWXXxITE8OePXv48MMPqVixIq+++iqvvvpqgc4thEOuxcLCx+DrQZZJQs0O8Mha6DPJbZIEcCxReBDYCTystb6MMewpp0MYHRMdccC8jbOxPyORKMhPLca8LVuAcwgrRo0ahaenJ7/99ht79+61edxXX33FmTNnaNy4sdV2bnfRqVMnANauXeviSCx16NABDw8Ph+Jq27YtJpMps8Npdo5M0ZzxM/nrr7/sOt7Dw8OhWqCM/hjr1q0jLS0t1/6M5Kdt27Z2nzMvSimaN2/Ok08+yT//GDPbLVy40CnnFiJPWsPOH2FWOOzINjOrbyDc/B48sBSqNHNdfDY4kig0BlbqvOtQYwBHOh4CrAHSgIZKKR8r+1uYt1EOnje7zubt0QKcQ1hRr149Xn75ZVJTU7n11luJjIzMdczChQt5+umn8fT05JNPPsHDwx360Fo3ePBg6tevz8cff8ySJdbn+Nq4cSPXrl0r0rgqV67MvffeS0REBNOmTbN6QT1y5AjHjh3LfJzRWXPChAkkJSVllsfGxloMo8zPyJEjCQwM5NNPP2XNmjW59mc0KWWoWLEiJ0+etPv8NWvWpG/fvkRFRTFz5kyLff/99x/ff/89wcHBDBlitdXQLnv27LFYGyRDdHQ0AP7+/td9biHscvEIfDMYfnsErl3MKm92GzyxBdo/CG762ehIZ8Y0wC+fY2rg4AyIWusLSqmfMDpITgJeydinlOqL0ZnxMvC3ucwbqA+kaq2PZDu2OXBWax2b/fxKqTrALPPDeY7EJuwzZcoUEhISeO+992jdujX9+/enefPmpKamsmHDBv777z/KlCnDDz/8QO/eru+Ykxdvb29+/fVX+vfvz80330yXLl0ICwvD39+fkydPsmXLFo4ePcrZs2eL/OIya9YsDh06xKRJk/j222/p1q0bVapU4cyZM+zbt48tW7bwww8/ULeuUal3zz338NNPP/H777/TokULBg8eTGpqKgsWLKB9+/YcOXIkn1c0hISE8P333zN06FB69erFTTfdRKtWrbhy5Qq7du3i5MmTFglKnz59+PHHHxk0aBDt2rXDy8uLHj160KOH7Za/zz77jK5du/L888+zbNkywsPDM+dR8PDwYM6cOQUambB8+XL+97//0aVLF5o0aULlypU5deoUixYtwsPDg+eff/66zy1EntJSYMOHsOZtSMtK2AmqBQPfgcYDXBebnRxJFCKBG5RSylqtglLKD+gNbL+OOP4HdAQmKKV6AJsxRj0MAdIxmjvizMfWAPYBx4HQbOcYBryolFqJMXoiHiOhuBkjwVlCjn4Vwjk8PDx49913ueuuu/j4449Zs2YNK1aswNPTk9DQUJ599lnGjRtX4GF0RaVVq1bs3LmT9957j8WLFzNnzhw8PDyoVq0abdq0YerUqYU6zbEtgYGBrF69ms8//5zvv/+eX375haSkJKpUqULDhg15//336du3b+bxSinmz5/PG2+8wdy5c5k1axbVqlVj9OjRTJo0yWLIZH5uvvlmIiIiePPNN1mxYgXLli0jODiYJk2a8NJLL1kc+8EHH6CUYsWKFSxZsgSTycTkyZPzTBTq1atHREQE06dPZ8mSJaxatYrAwEAGDBjAhAkTHJr3wZr+/fszbtw41qxZw6JFi7hy5QrVqlWjb9++mQmEEE53Zgf8NhbOZ41GQnlAx0eh18vgW87mU92Jsrc3tlLqMYxv5h9iXNgnApO01p5KKU/gI+AR4H6ttcPL4imlKmDUJgzBSAbigXXA61rrTdmOC8VIBI5rrUOzlffEGGLZBmMuhbIY/R52YMyr8G0+zSaZwsPDdURERL7H7du3j6ZNm9pzSiFECSD/88Ju27+Dxc9AerbJvKq1NtZnqN7G9vNcRCm1VWude7wxjtUozAZuBZ7C+PYebz75AqATUB1YdD1JAoC5yeB/5ltex0VhDKXMWb4aWH09ry2EEEI4RVoK/P0iRHyZVeZdFnpPgA6PgKc7TIjsGLsj1lqnK6VuwfjW/zjQyLzrdoxv7tPMNyGEEKL0uXIWfr4fTmWbFbRyM7hrHlSs77q4Csih1EZrnQZMUUpNxUgUKmJ0NNxf1GspCCGEEG7j+Ab4eSQkxGSVNb8dbv2o2PRFsOW66kDMbf0H8j1QCCGEKMm0hs2fw9KXwWQetqw8oe+r0Plxl63P4EyOTOH8H8YUzj9qrQs++b4QQghRnKVcMzos7voxq8w/BIbNgbolZyJgR2Z3CMcY9XBWKTVfKXWzebSDEEIIUbpcioKv+lkmCdXbwiOrS1SSAI4lCjWBl4AjwB3A78BppdS7SqnWhRGcEEII4XYOL4fZPeHc7qyyNvfB6L8gqHjMF+MIuxMFrfVZrfVbWuvmQHvgE4yVH58BtimltiulnlZKOTqFsxBCCOH+tIY178C8oZAUZ5R5eMMtM2HwLPC2fxKz4uS6JpbWWm/VWj8JVMOoXfgDaAa8B9g/ybsQQghRHCRdgZ9GwL/TyFwTMaC6UYsQPtqloRW2As38YB4u+ZtSajnG3ApTAVnUXQghRMlx/gD8eC9cPJRVVqcrDJsL5Sq7LKyict2JglJKAf2AkcBgjPUUNLDCOaEJIYQQLrbvD2O9hpRs6x12eswY/uhZOr4XO5woKKWaYSQHIzDWVFDAIeBr4But9ak8ni6EEEK4P1M6/Dsd1r2XVeZVxphAqdUw18XlAo7Mo/AERoLQFiM5uAx8AXyttd5QOOEJIYQQRexaLCx4AI6uzCoLDoW7voOqLVwWlqs40pnxQ4yVGf8B7gWqaa0fkSRBFDdRUVEopRg1apSrQyl0oaGhhIaGWpTNnTsXpRRz584ttNdVSnHDDTcU2vmFKDRnd8LnPS2ThAZ9YcyqUpkkgGOJwstAba31AK31D1rrpMIKShQvSqlcN19fX0JDQxk5ciT79u3L/yR2vo47XnxCQ0Mt3ruHhwfly5enS5cufPzxx6Slpbk6RKezloAIUezt/BG+7AdxJ7LKeoyH4T9BmWDXxeVijqwe+UZhBiKKv8mTJ2fev3z5Mps3b+abb77hl19+Yd26dYSFhbkuuCLw9NNPU758edLT0zl27Bi//vorGzduZMWKFfz666+uDi/TkCFD6NSpE9WqVSu019i3bx/+/v6Fdn4hnCIxDs5shzPb4PhGOPxP1j7fQBgyG5oMdFl47qL4LYwt3NaUKVNylT355JPMmjWLmTNnFmpVtzsYN26cxbfsvXv30r59e3777TdWr15Nz549XRdcNkFBQQQFBRXqazRp0qRQzy+Ew1KTjJkUz2yD01uN28XD1o+t1MTojxDSoGhjdFM2mx6UUkeVUkeUUnWzPbbndqTowhfurl+/fgCcP3/eovzy5cu8/fbb9O7dm5o1a+Lj40OlSpW49dZb2bRpk8WxGW3qAKtXr7ao5s+ZnGzevJm77rqLGjVq4OvrS7Vq1ejXrx8///yz1fiioqK4++67CQkJwc/Pj/DwcBYvXuyU9968efPMppLNmzdbvJe5c+fy999/c8MNNxAUFJT5/gDS0tL45JNP6NSpE4GBgfj7+9OmTRtmzZqFyWTK9Tpaa2bNmkXz5s3x8/OjRo0aPPHEE1y+fNlqXHn1UTh16hRPPfUUDRs2xM/PjwoVKtChQwemTZsGwKpVq1BKcfz4cY4fP27xu8je58NWM9Hly5d56aWXaNy4MX5+fgQHB9O/f3+WL1+e69iM15oyZQo7duzg5ptvpnz58vj7+9OzZ082bMjdPSo+Pp5p06bRokULAgMDCQgIoH79+tx1111s3brV6s9DlECmdIiOhG3fGos2ze4Br9eAL2+Ev8bDrp9sJwnNb4eHVkiSkE1eNQoeZE4/ZfWxLcV/TU3hNBkXgPDwcIvyffv2MWHCBHr06MHNN99McHAwJ06c4Pfff+evv/7ijz/+YMCAAQCEhYUxefJkpk6dSp06dSwuSNkvRv/3f//Ho48+iqenJ7feeisNGzYkJiaGiIgIPvnkE+68806LGI4fP06HDh2oV68e9913H7Gxsfz0008MHjyY5cuX06tXrwK/f2NFdiwSAYAFCxbw999/c9NNNzF27FiioqIASE1NZdCgQSxdupTGjRszfPhw/Pz8WLlyJU8++ST//fcf3377rcW5xo0bx4cffki1atUYM2YM3t7eLFq0iP/++4+UlBR8fHzsijUiIoL+/fsTGxtLjx49uP3227l27RqRkZFMmTKFiRMnEhoayuTJk5k5c2bma2fIr2kpLi6Orl27EhkZSfv27Rk3bhwXLlzg559/pl+/fnz66ac88sgjVuN666236Ny5Mw899BAnTpzgl19+oU+fPuzYsYPGjRtn/qwHDBjAhg0bMo/18vLi5MmTrFq1iu7du9OuXTu7fhaiGNEa4o7DaXNNwZntcGYHpCbk/1wPL6jS3FjMqUY7qNUBKjUu9JCLG5uJgtY6NK/HIh9TCrdq16mmWP/m6fBpsn27v3LlClu2bGH9+vXccsstPPfccxbHNm3alDNnzhASEmJRfurUKTp06MAzzzxjkSiEhYUxdepUQkNDrTZxREZG8thjjxEYGMjatWtp3rx5rvPmtGrVKqZMmWLRt2L48OEMGDCAt99+u8CJwt69e1m9ejUAHTt2tNi3ZMkSlixZkvkeM8yYMYOlS5fyxBNPMHPmTDw9jQVa09PTGTNmDF999RVDhw5l8ODBAGzYsIEPP/yQ+vXrs3nzZipUqJB5nl69enH27Fnq1KmTb6wpKSkMGzaM2NhYvvvuO4YPH26x/+RJY2b2jJ9/Rm2Etd+FLS+88AKRkZGMGTOGzz77LDN5euGFFwgPD+epp56if//+uTpJ/vnnn8yZM8ciQZw9ezZjx47lgw8+4JNPPgFgz549bNiwgdtuu43ffvvN4hwmk8lmDYsoZtLTIGotnNiU1Yxw7aJ9z63YwEgIMhKDqi3Au0zhxlsCSB8F4TRTp07NVdasWTPuueceAgICLMpttZHXrFmToUOH8tFHH3HixAlq165t12t/+umnpKWlMXHixFxJQsZ5c6pTpw6vvPKKRVn//v2pXbt2ZlOBI2bOnJmrM2NiYiJDhgyhe/fuFscOHjw4V5JgMpmYNWsWVatW5f33389MEgA8PT159913mTNnDt99911mojBnzhwAJkyYkJkkAPj5+fH666/bnez88ccfREVFceutt+ZKEgBq1apl3w/BhtTUVObNm0e5cuV4/fXXLWpYGjZsyFNPPcX06dP55ptvmDRpksVzu3btmmso6wMPPMATTzxh9fdUpkzuD34PDw+Cg0tvr/USIXov7PwBdv0MV6PzPz6gmjkpaJO1LVO+0MMsiRyZcOlfYK7W+ps8jhkBPKC17u2M4ETxklHNDpCQkMDevXt58cUXuffee9m7dy8zZsywOH79+vV88MEHbNy4kZiYGFJSUiz2nz592u5EIaNfw0033WR3vGFhYRYX4wy1atVi48aNdp8nwwcffAAYzQzlypWjVatWjBgxgrFjx+Y6tkOHDrnKDh48yMWLF2nYsCHTp0+3+hplypSxGG66bds2AKsdJbt3746Xl33/4tfz83PE/v37uXbtGl27drVIaDL07t2b6dOns3379lz7cjZbAXh7e1OlShUuXbqUWdasWTPCwsL44YcfOH78OIMHD6Zbt26Eh4fb3fwi3MzV87B7vpEgnNtl+zjfIKjRJlttQVsIrF50cZZwjtQo3ACsyueYOoB7dO12NSdV5xdXZcuWpUOHDvz666/UrFmTt956i7Fjx2Z+M/3tt98YOnQofn5+9O3bl/r161O2bFk8PDxYtWoVq1evJjk52e7Xi4uLA6BGjRp2P6d8+fJWy728vKx2GszPsWPH7J5boGrVqrnKLl40qk8PHTpktXYmw9WrWXPOZ1SnV6lSJddxnp6eVKxY0a54rufn54iMOG0Nycwoz4gju7x+T+np6ZmPPT09+ffff3n11VdZsGABL7zwAgABAQGMHDmS119/nXLlyhXgXYgikZoEB/82koND/4BOz31M2crQ7Fao2cFIDirUA4/rWgxZ2MHZTQ9lgJI3u4y4buXLl6dx48Zs27aNbdu2ZSYKEydOxMfHh4iICJo2bWrx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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[7.71889012 7.72510484 7.72113976 7.66696637 7.49913527 7.38760711\n",
      " 7.5639189  7.57766044 7.55863349 7.42407419 7.59087986 7.61822477\n",
      " 7.75119893 7.85979124 7.62582343 7.47267679 7.53226056 7.70546734\n",
      " 7.86783092 7.76091561]\n"
     ]
    }
   ],
   "source": [
    "ax = plt.figure(figsize=(8,6)).gca()\n",
    "plt.plot(range(20), ((online_results.T/comp_ratio.T).T).mean(axis=0), '-', linewidth=3, label=\"Online Predictions\")\n",
    "plt.plot(range(20), ((batch_results.T/comp_ratio.T).T).mean(axis=0), '-', linewidth=3, label=\"Batch Predictions\")\n",
    "plt.plot(range(20), ((regular_results.T/comp_ratio.T).T).mean(axis=0), '-', linewidth=3, label=\"$\\lambda = 1$\")\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.xlabel('Time Step', fontsize=20)\n",
    "plt.ylabel('Competitive Ratio', fontsize=20)\n",
    "plt.legend(fontsize=20)\n",
    "ax.xaxis.set_major_locator(MaxNLocator(integer=True))\n",
    "plt.show()\n",
    "print(((regular_results.T/comp_ratio.T).T).mean(axis=0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 130,
   "id": "731872c6",
   "metadata": {
    "hidden": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.7192474  0.68699562 0.6322062  0.69604742 0.8708483  0.72575181\n",
      " 0.77673266 0.65291425 0.67302619 0.72703168 0.69421785 0.65164388\n",
      " 0.66443659 0.72616341 0.71539051 0.85719404 0.87459241 1.13943269\n",
      " 0.85489926 0.89933935]\n",
      "[0.7192474  0.68690867 0.67703139 0.80295709 0.81707586 1.02986494\n",
      " 1.19300467 1.15506155 1.14596573 1.23208198 1.39300089 1.27131502\n",
      " 1.26565664 1.33061284 1.49498254 1.52281829 1.56737478 1.4648851\n",
      " 1.46088595 1.24326371]\n"
     ]
    }
   ],
   "source": [
    "# std / variance was constant\n",
    "print(online_results.std(axis=0))\n",
    "print(batch_results.std(axis=0))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9f4b3a1e",
   "metadata": {
    "heading_collapsed": true
   },
   "source": [
    "# Graph Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 134,
   "id": "6a66c206",
   "metadata": {
    "hidden": true,
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[149580.35667001 147773.15576922 154354.2065352  152404.38754231\n",
      " 152650.52099574 155918.88969318 153602.97763791 155698.02940003]\n",
      "[164279.08289507 165057.09224563 167560.07006572 169482.29301284\n",
      " 168217.50302243 172633.1610776  168887.26430938 172381.51332193]\n",
      "[148229.5712175  146660.87290493 152067.47407438 149639.07700869\n",
      " 150602.74433126 150327.95163849 149871.29634213 153667.33031479]\n",
      "[68698.79104149279, 69186.20099391465, 69890.47500744162, 70500.85742625335, 70770.62270756005, 70690.66999400358, 70631.09557155857, 71783.23469103634]\n"
     ]
    }
   ],
   "source": [
    "batch_hints = []\n",
    "no_hints = []\n",
    "online_hints = []\n",
    "comp_ratio = []\n",
    "\n",
    "filename = 'graph1.txt'\n",
    "graph1, edge_hash_table, vertex_hash_table, max_e, max_v = file_to_sparse_array(filename)\n",
    "n = max_v\n",
    "m = max_e\n",
    "b = -np.ones(m)\n",
    "bounds = [(0, None) for t in range(n)]\n",
    "c = np.random.random(n)*100\n",
    "res = linprog(c, A_ub=-graph1, b_ub=b, bounds=bounds, method='highs')\n",
    "# fixed hint\n",
    "print(res.x)\n",
    "\n",
    "for t in range(2,10):\n",
    "    print(t)\n",
    "    curr_filename = 'graph' + str(t) + '.txt'\n",
    "    graph, edge_hash_table, vertex_hash_table, max_e, max_v = file_to_sparse_array(curr_filename, edge_hash_table, vertex_hash_table, max_e, max_v)\n",
    "    n = graph.shape[1]\n",
    "    \n",
    "    curr_idx = 0\n",
    "    non_zero_indices = graph[curr_idx,:].nonzero()[1]\n",
    "    while len(non_zero_indices) == 0:\n",
    "        curr_idx += 1\n",
    "        non_zero_indices = graph[curr_idx,:].nonzero()[1]\n",
    "    alpha_r = min(c[j] /graph[curr_idx,j] for j in non_zero_indices)\n",
    "    curr_hint = np.zeros(n)\n",
    "    for i in range(len(res.x)):\n",
    "        curr_hint[i] = res.x[i]\n",
    "    curr_hint += np.ones(n)*np.random.random()*0.0001\n",
    "    curr_c = np.random.random(n)*100\n",
    "    for i in range(len(c)):\n",
    "        curr_c[i] = c[i]\n",
    "    batch_hints.append(curr_c.dot(phase_scheme(curr_c, graph, curr_hint, n, 0.10, alpha_r, start = curr_idx)))\n",
    "    no_hints.append(curr_c.dot(phase_scheme(curr_c, graph, curr_hint, n, 1.00, alpha_r, start = curr_idx)))\n",
    "\n",
    "    m = max_e\n",
    "    b = -np.ones(m)\n",
    "    bounds = [(0, None) for t in range(n)]\n",
    "    b[graph.getnnz(1)==0] = 0\n",
    "    online_res = linprog(curr_c, A_ub=-graph, b_ub=b, bounds=bounds, method='highs')\n",
    "    online_hints.append(curr_c.dot(phase_scheme(curr_c, graph, online_res.x, n, 0.10, alpha_r, start = curr_idx)))\n",
    "    comp_ratio.append(curr_c.dot(online_res.x))\n",
    "\n",
    "\n",
    "\n",
    "batch_hints = np.array(batch_hints)\n",
    "no_hints = np.array(no_hints)\n",
    "online_hints = np.array(online_hints)\n",
    "print(batch_hints)\n",
    "print(no_hints)\n",
    "print(online_hints)\n",
    "print(comp_ratio)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "052ca8c7",
   "metadata": {
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "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99zDAw88wCmnnNIoMfTv359Zs2bRpUuXRqm/ocaPHw9AWVkZ33zzDU899RRTp07lk08+4a9//WuGo9vmoosu4qc//SmDBg1qlPqb+89JRGpLJVEoBTrWU6YDUJZiDNcQJAgbgcXA8BSPr8XMBgJ3hXXWF7M00MSJE7n11lspKCjgueeeY7fddqu2//HHH+eMM87gpz/9Ka+++iqjR49Oeww5OTkMH97g/zqNZsKECdWev/7664wdO5Y77riDSy65pNmsx9GzZ89GXUCsuf+cRKS2VLoePgdOMbNe8XaaWU/gFOCzFGO4DPge0Bm4MMVj48VhwGRgNfD3htYndSsqKmLixInk5OTwzDPP1EoSAH70ox9x++23U1FRwYUXXkhl5bZGqSlTpmBmTJkyhalTp3L44YfTqVMnOnfuzDHHHMOsWbOSjiNe33fseIb77ruPPfbYg7y8PPr06cP5559PcXG8Vchh8eLFXHTRRQwZMoR27drRo0cPjj/+eD7++OPkP5w6HHHEEQwfPhx3r6ozdnzAv/71L77//e/TsWPHaknE5s2b+fOf/8yIESPo0KEDHTt25MADD+SRRx6J+zqlpaVMnDiRoUOH0q5dO3bccUeuueYatm7dGrd8XWMUvv76a84991wKCgpo164dvXv35pBDDuHee+8Ftv0sAaZNm1atyyWaKNU1RmHp0qX85je/oaCggNzcXHr16sXJJ5/MJ598Uqvs9vy/Wb58OZdffjnDhg2jQ4cOdO3alWHDhnH22Wczb968uJ+HiKTWojAJ+DfwkZndCEwlmPXQl2CQ4zVAL+CSVAJw96nRx2map3wJMCaMaUw6KpTEJk+eTHl5OT/+8Y/ZY489Epb7xS9+wcSJE/nmm2+YNm1arVaF5557jqeffpqjjz6aCy64gJkzZ/LCCy/w8ccfM3PmzAZ/y73iiit4+eWXOe644zjyyCOZOnUq//M//8O3337LG2+8Ua3s9OnTOfLII1mzZg3jxo3j5JNPZtWqVTz11FMcfPDBPPnkk/zwhz9sUDwQdNlA7f/3t912G6+++irHHXcco0ePrkpm1q1bx5gxY5gxYwb77LMP5557LpWVlbz88sucfvrpfPXVV9x4443V6v/xj3/M008/zdChQ7nooosoLS3lH//4B1988UVKsT7//POceuqpbN26laOOOorTTjuNdevW8dln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8AawmCCBGAAcAfwIaAdc5+7fNGrEIiIi0mTqXcLZ3W8ws3KCQYGnA6fVKGJAGfBHd/9z+kMUERGRTEnqWg/u/iczexg4FxgF9CNIEL4jWMxosrsvaLQoRUREJCOSvihUmAjUNY1RREREWpnmu5auiIiIZJwSBREREUlIiYKIiIgkpERBREREElKiICIiIgkpURAREZGElChIm1NUVISZcfbZZ2c6lEZXUFBAQUFBtW1TpkzBzJgyZUqjva6Zcfjhhzda/SLSdJQoSIOZWa1bu3btKCgo4KyzzmLWrFlpe53mePIpKCio9t6zsrLo2rUrBx10EHfffTfl5eWZDjHt4iUgItI6Jb3gkkh9xo/fth5XcXExH330EQ8++CCPP/4477zzDiNGjMhccE3gt7/9LV27dqWiooL58+fzxBNP8P777/P666/zxBNPZDq8KieddBIHHHAA/fr1a7TXmDVrFu3bt2+0+kWk6ShRkLSZMGFCrW0XX3wxkyZN4o477mjUpu7m4NJLL632Lfurr75iv/3248knn2TatGkcdthhmQsuRpcuXejSpUujvsbw4cMbtX4RaTrqepBGdeSRRwKwcuXKatuLi4v57//+b8aMGcOAAQPIzc2lV69eHH/88XzwwQfVykb71AGmTZtWrZm/ZnLy0Ucf8ZOf/IT+/fvTrl07+vXrx5FHHsn//d//xY2vqKiIn/70p/Ts2ZO8vDxGjhzJc889l5b3vttuu1V1lXz00UfV3suUKVN46aWXOPzww+nSpUvV+wMoLy/nnnvu4YADDqBz5860b9+evffem0mTJlFZWVnrddydSZMmsdtuu5GXl0f//v256KKLKC4ujhtXXWMUFi9ezCWXXMLOO+9MXl4e3bt3Z//992fixIkAvPnmm5gZCxYsYMGCBdV+FrFjPhJ1ExUXF3PVVVcxbNgw8vLy6NatG+PGjeO1116rVTb6WhMmTODTTz/lmGOOoWvXrrRv357DDjuM9957r9YxGzZsYOLEiey+++507tyZTp06MXToUH7yk5/wySefxP08RKRualGQRhU9AYwcObLa9lmzZvHHP/6RQw89lGOOOYZu3bqxcOFCnnnmGV588UWeffZZjjrqKABGjBjB+PHjuf766xk8eHC1E1Lsyeh//ud/uPDCC4lEIhx//PHsvPPOrFixgsLCQu655x5+/OMfV4thwYIF7L///gwZMoQzzzyTNWvW8J///IcTTjiB1157jdGjRzf4/bs7QLVEAOCxxx7jpZde4uijj+aCCy6gqKgIgLKyMo477jhefvllhg0bxumnn05eXh5Tp07l4osv5sMPP+Sf//xntbouvfRS/va3v9GvXz/OP/98cnJyePrpp/nwww8pLS0lNzc3qVgLCwsZN24ca9as4dBDD+Xkk09m8+bNzJw5kwkTJnDttddSUFDA+PHjueOOO6peO6q+rqV169YxatQoZs6cyX777cell17KqlWr+L//+z+OPPJI7r33Xn71q1/FjevWW2/lwAMP5Be/+AULFy7k8ccf54gjjuDTTz9l2LBhVZ/1UUcdxXvvvVdVNjs7m0WLFvHmm29yyCGHsO+++yb1WYhIDHfXrcZt33339WTMnDkzqXKtHeCAjx8/vup22WWX+cEHH+xm5scee6yvX7++2jHr1q3zlStX1qpr0aJF3q9fPx8+fHjc1znssMPixvDVV195dna2d+vWzb/88su49UbNnz+/KuYJEyZUK/fSSy854EcffXQyb93d3QcPHuyAz58/v9r2L7/80vPz8x3wt956y93dJ0+e7ICbmb/44ou16ho/frwDftFFF3l5eXnV9vLycj/33HMd8Keeeqpq+7vvvuuADx061FevXl21vaSkxA844AAHfPDgwdVeIxrD5MmTq7Zt3brVCwoKHPCHH364VlwLFy6s9Z5r1hsr3s/q/PPPd8DPP/98r6ysrNo+e/Zs79y5s+fm5lb7DKdOnVr1c4qN1d3973//uwN+4YUXVm37/PPPHfATTzyxVjwVFRW+Zs2ahPEmS7/z0loBhZ7gnKgWhcYyoXH7gNNqQvwm6lRdf/31tbbtuuuunHbaaXTq1Kna9kR95AMGDOCUU07hrrvuYuHChQwaNCip17733nspLy/n2muvZbfddotbb02DBw/mmmuuqbZt3LhxDBo0qKqrIBV33HFHrcGMJSUlnHTSSRxyyCHVyp5wwglVLSZRlZWVTJo0ib59+3L77bcTiUSq9kUiEW677TYmT57Mww8/zAknnADA5MmTAfjjH/9I9+7dq8rn5eXx5z//OelWkWeffZaioiKOP/54Tj/99Fr7Bw4cmNyHkEBZWRkPPfQQHTt25M9//nO1Fpadd96ZSy65hBtvvJEHH3yQ6667rtqxo0aNqjWV9dxzz+Wiiy6K+3PKz8+vtS0rK4tu3bo16D2ItFVKFCRtPGxmB9i0aRNfffUVV155JT/72c/46quvuOmmm6qVf/fdd7nzzjt5//33WbFiBaWlpdX2L1myJOlEITqu4eijj0463hEjRlQ7GUcNHDiQ999/P+l6ou68804g6Gbo2LEje+65J2eccQYXXHBBrbL7779/rW2zZ89m9erV7Lzzztx4441xXyM/P7/adNPp06cDxB0oecghh5Cdndyv+PZ8fqn4+uuv2bx5M6NGjaqW0ESNGTOGG2+8kRkzZtTaV7PbCiAnJ4c+ffqwdu3aqm277rorI0aM4JFHHmHBggWccMIJHHzwwYwcOTLp7hcRqU2JgjSKDh06sP/++/PEE08wYMAAbr31Vi644IKqb6ZPPvkkp5xyCnl5eYwdO5ahQ4fSoUMHsrKyePPNN5k2bRpbt25N+vXWrVsHQP/+/ZM+pmvXrnG3Z2dnxx00WJ/58+cnvbZA3759a21bvXo1AHPmzInbOhO1cePGqsfRAYt9+vSpVS4SidCjR4+k4tmezy8V0TgTTcmMbo/GEauun1NFRUXV80gkwhtvvMENN9zAY489xh/+8AcAOnXqxFlnncWf//xnOnbs2IB3IdI2KVFoLGlqzm/punbtyrBhw5g+fTrTp0+vShSuvfZacnNzKSwsZJdddql2zK9+9SumTZuW8utA0ArREqbm1RzcCNu6Y0466aSk112IHrN8+XKGDBlSbV9FRQWrV69O6uQf+/k1hmicy5Yti7t/6dKl1cptr27dunH77bdz++238+233zJt2jTuu+8+Jk2axLp162oNBBWR+ml6pDS6aPNw7Lf0b7/9ll133bVWklBZWck777wTt56srKxq3yBjHXDAAQC8+OKL6Qg5I4YPH07Xrl354IMPKCsrS+qYffbZByBuYvX2228nvSpkqp9fJBJJ+LOIZ9iwYbRv355PP/20WndB1NSpU4Ft7ycddtppJ8477zymTZtGx44defrpp9NWt0hbokRBGtVTTz3F/PnzycnJ4aCDDqraXlBQwJw5c/juu++qtrk7119/PTNnzoxbV48ePVi0aFHcfRdeeCHZ2dlMnDgx7vGLFy9u4DtpfNnZ2Vx88cUsXbqUSy65hJKSklplli5dWu39RQf53XTTTaxZs6Zq+5YtW7jqqquSfu3jjjuOgoICnnnmGR555JFa+2u2NPTo0YOVK1fGjTGe3Nxcfvazn7Fx48ZagxXnzp3L3/72N3JycjjzzDOTjrmm+fPn89VXX9XavnbtWrZu3Rp3kKOI1E9dD5I2sYsfbdq0iZkzZ1Z9Q/3Tn/5UrR/9sssu44ILLmDvvffmRz/6ETk5Obz77rvMnDmT4447jmeffbZW/UcccQT//ve/Oe6449h3333Jzs7m0EMP5dBDD2XXXXflnnvuqarzhBNOYOedd2b16tUUFhbSqVOnqm+tzdm1117LZ599xt///neeffZZxowZQ//+/VmxYgVz5szh3Xff5aabbmLXXXcFghkBF198MXfddRe77747p5xyStU6Ct26dUt6mebc3FweffRRjjzySE4//XTuu+8+DjjgALZs2cKsWbN4/fXXq7VOHHHEEXz88cccddRRHHroobRr14699tqL4447LuFr3Hzzzbz99ttMmjSJjz/+mNGjR1eto7BhwwYmTZrEjjvuuN2f3WeffcZJJ53Evvvuy+67784OO+zAypUrefrppykrK6sasyAiKUo0b7It37SOQmoI57rH3iKRiPft29ePP/54f+WVV+IeN3nyZN9rr728ffv23qNHDz/xxBP9888/r1pLYOrUqdXKL1++3E877TTv3bu3Z2VlVa3dEOu9997zk08+2Xv16uU5OTner18/HzdunD/66KNVZaLrKJx11llx4zrssMM8+NVITqJ1FBK9Z+KsCxCrsrLSH3zwQR8zZox369bNc3JyfIcddvBRo0b5TTfdVGtNg8rKSr/rrrt8+PDhnpub6/369fNf//rXvm7durjrHdQVw4IFC/zCCy/0goICz8nJ8e7du/v+++/vN954Y7VyGzdu9AsuuMD79+/vkUik1udJgjUv1q5d61dccYXvtNNOnpub6126dPEf/OAH/vLLL9cqG11HoebPOKrme1u0aJFfddVVftBBB3mfPn08NzfX+/fv70cddZS/8MILcetIlX7npbWijnUUzGOmtElg5MiRXlhYWG+5WbNm1epjF5HWS7/z0lqZ2SfuXnsuMs1gjIKZnWJmd5nZ22a23szczB5KsY4eZvYLM3vSzL41sxIzKzazd8zsPDPL+PsUERFpiZrDGIVrgL2AjcBiYHvmtp0K3AssBaYCC4E+wMnA/wJHm9mpruYTERGRlDSHROEyggThW+Aw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\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "batch_hints = np.array([149580.35667001, 147773.15576922, 154354.2065352, 152404.38754231, 152650.52099574, 155918.88969318,153602.97763791,155698.02940003])\n",
    "no_hints = np.array([164279.08289507, 165057.09224563, 167560.07006572, 169482.29301284, 168217.50302243, 172633.1610776, 168887.26430938, 172381.51332193])\n",
    "online_hints = np.array([148229.5712175, 146660.87290493, 152067.47407438, 149639.07700869, 150602.74433126,150327.95163849, 149871.29634213,153667.33031479])\n",
    "comp_ratio = np.array([68698.79104149279, 69186.20099391465, 69890.47500744162, 70500.85742625335, 70770.62270756005, 70690.66999400358, 70631.09557155857, 71783.23469103634])\n",
    "plt.figure(figsize=(8,6))\n",
    "plt.plot(range(2,10), online_hints/comp_ratio, linewidth=3, label=\"Online Predictions\")\n",
    "\n",
    "\n",
    "plt.plot(range(2,10), batch_hints/comp_ratio, linewidth=3, label=\"Batch Predictions\")\n",
    "plt.plot(range(2,10), no_hints/comp_ratio, linewidth=3, color='C2', label='$\\lambda = 1$')\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.xlabel('Graph #', fontsize=20)\n",
    "plt.ylabel('Competitive Ratio', fontsize=20)\n",
    "plt.legend(fontsize=20)\n",
    "plt.ylim([1.0, 2.5])\n",
    "plt.show()\n",
    "# plt.plot(online_hints/comp_ratio)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 151,
   "id": "1a440b56",
   "metadata": {
    "hidden": true,
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "2\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "3\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "4\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n",
      "1000\n",
      "2000\n",
      "3000\n",
      "4000\n",
      "5000\n",
      "6000\n",
      "7000\n",
      "8000\n",
      "9000\n",
      "10000\n",
      "11000\n",
      "12000\n",
      "13000\n",
      "14000\n",
      "15000\n",
      "16000\n",
      "17000\n",
      "18000\n",
      "19000\n",
      "20000\n",
      "21000\n",
      "22000\n",
      "23000\n",
      "24000\n",
      "25000\n",
      "26000\n"
     ]
    }
   ],
   "source": [
    "p_vals = np.linspace(0.05, 1, 5)\n",
    "\n",
    "curr_result = np.zeros((5,3))\n",
    "for j in range(5):\n",
    "    print(j)\n",
    "    p = p_vals[j]\n",
    "    for i in range(3):\n",
    "        new_hint = noisy_alter(curr_hint, p)\n",
    "        curr_result[j,i] = curr_c.dot(phase_scheme(curr_c, graph, new_hint, n, 0.1, alpha_r, start = curr_idx))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "id": "17ca4fe4",
   "metadata": {
    "hidden": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[158882.40843886 160647.27963697 155534.56302182]\n",
      " [161452.64899551 162324.04960058 162479.86066922]\n",
      " [173007.14075696 171143.25354974 173517.37510552]\n",
      " [176770.1009693  172382.72177414 180072.41675823]\n",
      " [311658.35548096 311658.35548096 311658.35548096]]\n"
     ]
    }
   ],
   "source": [
    "print(curr_result)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "976cfbc9",
   "metadata": {
    "hidden": true
   },
   "outputs": [],
   "source": [
    "curr_result = np.array([[158882.40843886,160647.27963697,155534.56302182],\n",
    "                        [161452.64899551,162324.04960058,162479.86066922],\n",
    "                        [173007.14075696,171143.25354974,173517.37510552],\n",
    "                        [176770.1009693,172382.72177414,180072.41675823],\n",
    "                        [311658.35548096,311658.35548096,311658.35548096]])\n",
    "\n",
    "comp_ratio = [68698.79104149279, 69186.20099391465, 69890.47500744162, 70500.85742625335, 70770.62270756005, 70690.66999400358, 70631.09557155857, 71783.23469103634]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "5d3d619e",
   "metadata": {
    "hidden": true
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhcAAAGFCAYAAABOn9GdAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAABfcklEQVR4nO3deXxddZ3/8dcn+560WVpa2qYtbVkKIpYduoCgyK7y++mM66iMjjMMo/50ZJfFZXTGdX6o4wguMz8cYUAFREfowqZQZGmBNi1tutAlW5M2e3Lz+f1xTtIs9ya5yU1yk7yfj8d93N5zvud7vydJc98557uYuyMiIiKSKCkT3QARERGZWhQuREREJKEULkRERCShFC5EREQkoRQuREREJKEULkRERCSh0ia6AVNFSUmJl5eXT3QzRERExsULL7xQ4+6l0fYpXCRIeXk5GzdunOhmiIiIjAsz2xVrn26LiIiISEIpXIiIiEhCKVyIiIhIQilciIiISEIpXIiIiEhCKVyIiIhIQilciIiISEIpXIiIiEhCTXi4MLNiM/u4mT1oZtvNrMXMGszsKTP7mJkNu41mVmlmHuNxYJDjzjGzR82szsyazewVM7vezFITc5YiIiLTRzLM0HkNcDewH1gL7AZmAe8GfgRcYmbXuLsPs74G4FtRtjdGK2xmVwIPAK3AL4A64HLgm8C5YftERERkmGz4n9lj1ACzC4Bc4BF37+q1fTbwHDAPeK+7PzCMuioB3L18mO9dAGwHCoFz3X1juD0LeAI4G3i/u983VF0rVqxwTf8tIiLThZm94O4rou2b8Nsi7v6Eu/+md7AItx8Avh++XD1Gb/9eoBS4rztYhO/dCtwUvvzUGL23iIjIlJQMt0UG0xE+d8ZxTKaZfQCYDzQBrwAb3D0SpewF4fNjUfZtAJqBc8ws093b4miDiIhI0mhs6yQvc/w+8pM2XJhZGvCh8GW0D/9YZgM/67dtp5l91N3X99u+LHyu6F+Ju3ea2U7gJGAR8HocbRAREZlwjW2dHGhoAeC4svxxe98Jvy0yiK8Cy4FH3f13wzzmHuBCgoCRC5wM/AAoB35rZm/pV74wfG6IUV/39qJoO83sWjPbaGYbq6urh9lEERGRsdXWGWFXbRM7q5toae8a+oAES8orF2Z2HfBZYAvwweEe5+5f6rdpM/BJM2sM67sNuDqepnRXHeP9fgj8EIIOnXHUKyIiknCRLqfqSCu1je1M5HiNpLtyYWafBr4NvAascfe6BFTb3TF0Zb/t3VcmComuoF85ERGRpOPu1DS2sfXAEWqOTGywgCQLF2Z2PfA9gisOa8IRI4lQFT7n9tu+NXxeGqUtacBCgs6kOxLUDhERkYRqaOlgW1Uj++tbiXQlx0X0pAkXZvYFgomrXiIIFlWDHxGXs8Pn/iHhifD5nVGOWQnkAM9opIiIiCSblvYIO6ob2V3bTFvH+PerGExShAszu5mgA+cLwIXuXjNI2XQzO97MFvfbfpKZzYxSfgHB1RCAn/fbfT9QA7zPzFb0OiYLuDN8eXe85yMiIjJWOiJd7KlrZntVI01t0WZZmHgT3qHTzD4M3A5EgCeB68ysf7FKd783/PdcgmGhuwhGgXS7BvhHM1sL7ASOAIuBS4Es4FHgG70rdffDZvYJgpCxzszuI5j++wqCYar3E0wJLiIiMqG6uoJ+FVVH2ia8T8VQJjxcEPRrAEgFro9RZj1w7xD1rCUIBG8luA2SC9QDTxHMe/GzaOuTuPtDZrYKuBF4D0EQ2Q58BvhOHGuaiIiIjIlDTe0cONxKZ2RyfCRN+NoiU4XWFhERkUTrngRrtHNVZGekJHwSrcHWFkmGKxciIiLSS1tnhAMNrRxuiWf1i+ShcCEiIpIkOiNdVB1po65p4ueqGA2FCxERkQnm7tQ2tXPwcCtdyTWqdEQULkRERCZQQ0sHBxpaae+cAqkipHAhIiIyAVraI+xvaEnauSpGQ+FCRERkHHVEujjQ0Ep9c8dEN2XMKFyIiIiMg64up7qxjepJMAnWaClciIiIjLHJNgnWaClciIiIjJFETYI12ShciIiIJFhrR4SDhyfvJFijpXAhIiKSIFNlEqzRUrgQEREZpak2CdZoKVyIiIiMwlScBGu0FC5ERERGoKU9wr6GFpqn4CRYo6VwISIiEof2zi4OHp7ak2CNlsKFiIjIMEynSbBGS+FCRERkEO5OfXPHtJoEa7QULkRERGKYrpNgjZbChYiISD+tHREONLRypHV6ToI1WgoXIiIiIU2ClRgKFyIiMu25OzWN7VQd0SRYiaBwISIi05omwUo8hQsREZmWNAnW2FG4EBGRaUWTYI09hQsREZkWNAnW+FG4EBGRKc3dOdTcwUFNgjVuFC5ERGTKamzrZH99C60d6qw5nlImugEiIiKJ1toRobKmiZ3VTQoWQFtHhOcr68bt/XTlQkREpgxNgnVUlzub3mxg3dYqnnmjls6I8/yNb6cwJ33M31vhQkREJj1NgnXUrtom1m6tZn1FFTWN7X32PbxpH3955oIxb8OEhwszKwauBi4FTgbmAu3AJuAe4B53H9GPipl9EPhp+PIT7v6jfvvLgZ2DVPELd3/fSN5bRETGR0O4Yul0ngSrrqmdDRXVrN1axY6apqhlFpbkkp2eOi7tmfBwAVwD3A3sB9YCu4FZwLuBHwGXmNk17vFd4DKzecB3gUYgb4jiLwMPRdm+OZ73FBGR8dPc3sn+htZpOwlWa0eEZ3fUsnZLFS/vracryqdkQVYaK5eU8o7ls7jslDmY2bi0LRnCRQVwBfBI7ysUZnYD8BzwHoKg8cBwK7Tgq3cPUAv8N/C5IQ55yd1vi6/ZIiIyEabzJFiRLuflvfWs3VrFH3fURu2smp5qnLmwmDXLSjlt/gzSUlPIzkgZt2ABSRAu3P2JGNsPmNn3gbuA1cQRLoDrgAvC4y4YZRNFRCQJRLqcmmk4CZa7s7OmibVbq9hQUUNdc3vUcifPLWTNslLOWVxCbubEfrxPeLgYQncs7RzuAWZ2AvBV4NvuvsHMhhMu5pjZXwPFBFc7nnX3V+JurYiIJNx0nQSrprGNdVurWbe1il11zVHLzJuZw5plpaxaWkpZftY4tzC2pA0XZpYGfCh8+Vgcx/yMoN/GDXG83UXho3dd64APu/vuOOoREZEEOtIarFg6XeaqaG7v5JnttaytqGLT3gaiRaminHRWLillzbIyFpfmjuvtjuFK2nBBcPVhOfCou/9umMfcArwVOM/dW4ZRvhm4g6Az545w2ynAbcAa4HEzO9Xdo3a9NbNrgWsB5s+fP8wmiojIUFo7IhxoaOVI67AvXE9anZEuXtxTz7qtVfxxRx3tkYFBKiMthbMXFbNmWRmnzisiNSX5AkVvSRkuzOw64LPAFuCDwzzmDIKrFf/s7s8O5xh3ryIIJL1tMLOLgaeAM4GPA9+OcfwPgR8CrFixYvpcqxMRGSOdkS4OHmnj0BSfBMvd2VbVyLqtVWzYVkNDy8DOqQa8ZV4Ra5aVctaiYnIykvIjO6qka6mZfZrgw/w14EJ3H3K+0l63QyqAm0fbBnfvNLMfEYSLlcQIFyIikhjTZRKsg4dbWVdRzdotVbxZH/0Ce3lxDmuWlbFqaSnFeZnj3MLESKpwYWbXA98kmF/iwvDKwnDkAUvDf7fGuP/0b2b2bwQdPa8fRp3V4XPuMNsgIiIjMNUnwWps6+Tp7TWs3VrFq/sORy0zMzeD1UtLWb2sjIUlk/9jJ2nChZl9gaCfxUvARe5eE8fhbcC/x9h3GkE/jKeArcCwbpkAZ4XPOwYtJSIiIzKVJ8HqiHTxwq5DrN1axXM76+iMMsNVdnoqZy8O+lGcPLcw6ftRxCMpwoWZ3QzcDrwAXDzYrRAzSwcWAx3u/gZA2Hnz4zHK30YQLn4SZfrvM4EX3b293/YLgH8IX/58JOckIiLRTdVJsNydrQeO8MTWKp7aVsORtoGdUVMM3jp/BquXBv0ossZpOu7xNuHhwsw+TBAsIsCTwHVRbmtUuvu94b/nAq8Du4DyUb7914CTwmGne8Ntp3B04q2b3f2ZUb6HiIgQTIJVfaSNmsapNQnWvvoW1m2tYl1FNfsbWqOWOa40j9XLSlm5tJQZORnj3MLxN+HhAlgYPqcC18cosx64dwze+2cEi6adDlwCpAMHgf8CvufuT47Be4qITCvdk2AdaGglEm0BjEnocEsHT4X9KLYcOBK1TGl+Zk8/ivkzc8a5hRPL4lwPTGJYsWKFb9y4caKbISKSVKbSJFjtnV08X1nH2q1VvLDrUNR+FDkZqZx7XAlrlpVx0pwCUpJkgqvsjBSOK8tPaJ1m9oK7r4i2LxmuXIiIyBQzVSbB6nLn9f2HWbuliqfeqKEpSufT1BTjbfNnsOb4Mk4vn0Fm2tTsRxEPhQsREUmYqTIJ1t5DzawN1/WoOtIWtcyyWfmsWVbKeUtKKcxOH+cWJjeFCxERGbWuLqemKVixdLJOglXf3M6GbUE/iu1VjVHLzC7IYvWyYF2POUXZ49zCyUPhQkRERqWhuYP9h1vo6Jx8lyraOiP8aUfQj+LPuw8Rrb9pXmYa5y8pYfWyMk6YnZ+UC4UlG4ULEREZkeb2TvbVt9LSPrkmwepyZ9ObDazbWsXT22tp6RjY/rQU4/TymaxZVsqK8pmkp6ZMQEsnr7jDhZnlAO8mmJiqCGgA/gw8GGv1UBERmTom6yRYu2qbWLu1mvUVVdQ0tkctc+IxBaxeVsp5x5WQn6V+FCMVV7gws3cBPwFmEizY1s2Bb5rZR9394QS2T0REksRknASrrqmdDRXVrN1axY6a6H//zinMYs3xZaxeWsbswqxxbuHUNOxwYWanAf9NMNnVfwBPAPuBYwhmtHw/cL+ZnevuL4xBW0VEZAK4O3VN7Rw83DYpJsFq7Yjw7I5a1m6p4uW99VH7URRkpbFySSlrji9jSVme+lEkWDxXLm4kuEJxvrv/sd++e83sX4F1wA3AexLTPBERmUiTZRKsSJfz8t561m6t4o87aqO2Nz3VOHNhsFDYafOLSFM/ijETT7g4H/hllGABgLv/yczuB96RkJaJiMiEae2IsL+hlcYkngTL3dlZ08TarVVsqKihrjl6P4qT5xayZlkp5ywuITdT4xjGQzxf5UJgzxBldgMFI2+OiIhMpO5JsOpidHhMBjWNbawLJ7jaVdcctcy8mTmsWVbKqqWllOWrH8V4iydc7APOGKLMCoJ+GCIiMokk+yRYze2dPPNGLWu3VrFpbwPRen4U5aQH/SiWlbG4NFf9KCZQPOHiUeCTZvaPwNfdvWdgsJmlAP8AvB34fmKbKCIiY6m+uZ0Dh1uTbhKszkgXL+0J+1HsrKO9c2DqyUhL4exFQT+KU+cVkZqiQJEM4gkXdwBXAXcBf21mTxJcpZgNnAeUAweAOxPbRBERGQvJOAmWu7O9qjHoR7GthoaWgXNppBiccmwRa5aVctaiYnIy1I8i2Qz7O+LuB8zsXOAHwEXAgn5F/gf4pLvrtoiISBJr7+ziQENr1A/uiXLwcCvrKoJ+FHsPtUQts7Akl9VLg34UxXmZ49xCiUdccc/dK4F3mNlcghk6Cwlm6HzR3d9MfPNERCRRkm0SrMa2Tp7eHiwU9uq+w1HLzMzNYPXSoB9FeUnuOLdQRmpE15LCIKEwISIyCSTTJFgdkS5e2HWIdVureK6yjo7IwPZkp6dy9uJiLlhWxvK5hepHMQnpRpWIyBR2pLWD/Q2ttE3gJFjuztYDR1hbUc2T26o5EmXujBSDt86fwZplZZy5cCZZ6akT0FJJlJjhwsx+TDAj5w3ufjB8PRzu7h9LSOtERGREkmESrH31LazbWsW6imr2N7RGLXNcaR5rji/l/CWlzMjJGOcWylgZ7MrFRwjCxdeAg+Hr4XBA4UJEZAJ0RLqomsBJsA63dPBU2I9iy4EjUcuU5mf29KOYNzNnnFso42GwcLEwfH6z32sREUlCtY1tHDjcOu6TYLV3dvF8ZR1rt1bxwq5DdEbp15GTkcq5x5WwZlkZJ80pIEUTXE1pMcOFu+8a7LWIiCSPmsY29tdHv/UwFrrceX3/YdZuqeKpN2poahs4V0ZqivG2+TNYc3wZZ5TPJCNNC4VNF/EsuX4LsM7dNwxS5nxgjbvfnojGiYjI0Oqa2sctWOw91MzacF2PqiNtUcssm5XPmmWlnLeklMLs9HFplySXeEaL3BY+YoYLYCVwK6BwISIyDuqb23kzxqRTiXyPDduCfhTbqxqjlpldkMXqZUE/ijlF2WPaHkl+iR6KmgYk4ZI3IiJTT0NzB3vqxiZYtHVG+NOOoB/Fn3cfItr0GHmZaZy/pITVy8o4YXa+FgpLQqkpRmZ6CvnjvNR8ot/tbUBNgusUEZF+Drd2sOdQ9OXGR6rLnU1vNrBuaxVPb6+lpWNgP4q0FOP08pmsWVbKivKZpKeqH0UySEs1stJTyUxLITMtpeffaRP0/Rk0XJjZE/02fcTMVkcpmgrMI1hv5P8lpGUiIhLVkdYOdtc2J2wK7121TazdWs36iipqYgxhPfGYAtYsK+Pc44rJz1I/iomSEYaHzPQUstJSyUxPITMtNelmMR3qysXqXv92gpVPy6OU6wJqgV8QLL0uIiJjoLGtk10JCBZ1Te1sqKhm7dYqdtQ0RS0ztyibNctKWbWsjNkFWaN7Qxk2syBEHA0PQYDITEshJclCRCyDhgt377meYmZdwG0aCSIiMjGa2zuprGkacbBo7Yjw7I5a1m6p4uW99VH7URRkpbEynOBqSVme+lGMITPISj8aHDJ73daY7F/3ePpcfBR4cawaIiIisbW0R9g5gmAR6XJe3lvP2q1V/HFHLa1R1hjJSE3hjIUzWbOsjNPmF03YffqpKiWFngCRld73asRUNexw4e4/GcuGiIhIdK0dQbAY7syb7s7OmibWbq1iQ0UNdc3R+1GcPLeQNctKOWdxCbnjPJpgKkpNseBKRHpqn06V07HT64h+mszsWGAukBlt/2ATbUWpqxi4GrgUODmstx3YBNwD3OPuIxreamYfBH4avvyEu/8oRrlzgJuAs4AsYDvwY+C77j6wu7SIyDhp7Yiwo7ppWEul1zS2sS6c4GpXXfSRJPNm5gT9KJaWUpavfhQjkZ5mfa9EhLcydMXnqLjChZldDHwTOH6IovFc67kGuBvYD6wFdgOzgHcDPwIuMbNr3OO7GGhm84DvAo1A3iDlrgQeAFoJOqTWAZcTnOe5YftERMZdW2dwxWKoYNHlzr8/tZPfvLyPaCWLctJZtaSUNceXsagkd9Lfzx8vGWkp/fpEJOfIjGQUz/TfZwIPA9XA94C/A9YDW4HzgROAXxN/v4wK4Argkd5XKMzsBuA54D0EQeOBONpqBFc9aoH/Bj4Xo1wB8G9ABFjt7hvD7TcDTwDvNbP3uft9cZ6TiMiotHd2sbOmic7I4MEi0uV8b+02/vB6VZ/tmWkpnL2omNXLyjh1XpE+EGMw4+hojF7DOzNSJ8/IjGQUz5WLGwj+uj/d3feZ2d8Ba9399vDD/Dbgs8CN8TTA3fvPpdG9/YCZfR+4i2BI7LDDBXAdcEF43AWDlHsvUAr8tDtYhO/damY3AY8DnwIULkRk3HREgmDR0Tl0sPjO49t4YuvRYHHiMQW846RZnLWomJwM9aPo1mdkRu+rEVNgZEYyiucn72zg1+6+r9e2FIDwlsWtZvYu4EsEH9qJ0BE+dw73ADM7Afgq8G1332Bmg4WL7n2PRdm3AWgGzjGzTHePvkKPiEgCdYbBor1z8K5mkS7nm3+oYH1Fdc+2t59Qxt+uWTKtr1KkpNCrH8TRqxFakXV8xRMuCgn6Q3RrB3L7lXka+IvRNgrAzNKAD4Uvo334xzrmZwTtvGEYhywLnyv673D3TjPbCZwELAJeH04bRERGqjtYtEUZLtq/3L/8oYIntx1dbeEdJ87ib9YcR8o0+Ss8LdV65obI6jVHxHQcmZGM4gkXVcCMfq8X9yuTDiRqObyvAsuBR939d8M85hbgrcB57j6c1XwKw+eGGPu7txdF22lm1wLXAsyfP3+YTRQRGSjS5VTWNkedh6K3zkgXX//9Vp55o7Zn2yXLZ/PJVYunZLBIT7M+01x3j9CYzldnJoN4wkUFfcPEHwlGcix19wozm03Q+XLbaBtlZtcR9N/YAnxwmMecQXC14p/d/dnRtqG72vA56o1Pd/8h8EOAFStWJGiWfxGZbrq6nMraJlraBx/53hHp4p9+t4U/7qjr2XbZKcdw7fmLJnW/ge7prrtvZfQeoaFOlZNTPOHiMeBOM5vp7nXAtwlGcbxoZq8BS4B84POjaZCZfTqs+zXgwvC9hjqm+3ZIBXBzHG/XfWWiMMb+gn7lREQSqjtYNLcNHSy++tstPFd59FfiFW+Zw8fPWzhpgkXvkRl9O1eqU+VUE0+4+AFBJ8cOAHd/2syuAe4guH1RCXze3X8as4YhmNn1BPNLbCYIFlWDH9EjD1ga/rs1xg/pv5nZvxF09Lw+3LYVWBEe+0K/tqQBCwk6k+4Y/lmIiAyPu7OrrpmmIYJFe2cXX/nt62zcdahn29VvnctHzylPyg/lYGRG37khssLhncnYXkm8eKb/Pgz8qd+2B4EHE9EQM/sCQT+Ll4CL3L1m8CP6aAP+Pca+0wj6YTxFECZ63zJ5AvhL4J0MXCp+JZADbNBIERFJNHdnd10zja2DD4Zr64zw5Udf58+763u2XfO2Y/ngWQsm/IM6NcV6rjz0HqGhkRmS0EHQ4V/7f+3u/xrncTcDtxNcPbh4sFshZpZO0Pejw93fAAg7b348RvnbCMLFT6JM/30/8DXgfWb23V6TaGUBd4Zl7o7nXEREhuLu7D3UwuGWwYNFa0eEux59nZf21Pds+9+nz+Mvz5g/rsGie2TG0asRwQgNTXctsSQkXISTaH0IuBVYAAw7XJjZhwmCRQR4Erguyn+aSne/N/z3XIJhobuA8tG0290Pm9knCELGOjO7j2D67ysIhqneTzAluIhIwuw91EJ9c8egZVo7Itz+8GtsevNol6+/OGM+7z9j7Eam9XSq7DVTpaa7lpEYMlyY2Qzgb4HTCfpbPAl8391bw/2XAf/E0Tkj4r1NsjB8TgWuj1FmPXBvnPUOi7s/ZGarCGYWfQ9HFy77DPCdeNc0EREZzJv1QweL5vZObn/4NV7dd7hn2wfOWsD/XjFv1O/fe2RGn8mmNDJDEsgG++w0sxKC9T0W0HdY5nrgIuD7wF+F+x4GbnH3l8awvUlrxYoVvnHjxqELisi0ta++hdrG6Mufd2tu7+S237zG6/uPBosPn13Oe992bFzv1We66zSNzJDEM7MX3H1FtH1DXbn4R4JbDy8D/0EQIj4IrAIeAS4m6OT59+7+XKIaLCIy1RxoaB0yWDS1dXLrr19l68EjPdv+6txyrn7r8IJFcV4GeVlpZKZpZIZMrKHCxSUEfRvOdPd2ADP7HsHkVhcRLOj1l7p1ICISW9XhVqqPDD7orLGtk1t+tZltVY092z5x/kKueMvcYb3HnKIsivMyR9VOkUQZqqtvOcH02z1xOxyZ8XD48mYFCxGR2KqPtHHw8ODB4khrBzc9tKlPsPjkykXDChZmMG9mtoKFJJWhrlxkAwejbO+e3EqTS4mIxFDb2MaBhtZByzS0dHDLrzazo6apZ9vfrF7MJcuPGbJ+M5hfnENBVvqo2yqSSKMaiqqrFiIi0dU1tbOvfuhgcdNDm6isbQaCTm1/e8FxXHzi7CHrT0mBBcW55GUmdLoikYQYzk/lqWb2of7bAMzsgxwdRdJjNFOAi4hMdvXN7bx5aPCFmQ81t3PTQ5vZXXc0WFx34RLefsKsIetPTTEWluSSnZGaiOaKJNxwwsWV4aM/I/bcEwoXIjItNTR3sHeIYFHX1M6ND23qKZdicP3bl7JmWdmQ9aenGeXFuWSlK1hI8hoqXPxkXFohIjIFHG7tYM+hZga7YVzb2MaND23mzfqjweIzFy1j1dLSIevPTE+hvDhXa3dI0hs0XLj7R8erISIik9mR1g521w4eLKqPtHHjQ5vYH3byTDH4P+84nvOOKxmy/uyMIFhoPQ+ZDNQTSERklJraOtk1RLCoOtzKDQ9t6hmWmppifP4dyzhn8dDBIiczlfLiXK3xIZOGwoWIyCg0t3eys6Zp0GBx4HArNz64iapwIq20FOML7zyesxYVD1l/flYa82fmaN0PmVQULkRERqilPTJksNjf0MKND23umaEzLcX44iUncMbCmUPWX5STzrEzsjWNt0w6ChciIiPQ2hEEi66u2GX21bdw40ObqAnXFElPNW541wmsWDB0sJiZl8HcouxENVdkXClciIjEqTtYRLpiX7LYe6iZGx/cTF1zECwyUlO48dITOG3+jCHrLyvIZFZBVsLaKzLeFC5EROLQ1hmhsraJzkjsYLG7rpkbH9pEfXMHABlpKdxy6Ym8ZV7RkPXPLsyiNF/rhMjkpnAhIjJM7Z1d7KxpoqMzdrDYVdvETQ9tpr4lCBZZ6SncctlJnDy3cMj6587IZmZuRsLaKzJRFC5ERIahIzJ0sNhZ08RND23icGsnANnpqdx6+YmcNGfwYBGsbJpDYbYWIJOpIe7ZWMzscjO7z8xeNrPtvbafYGafN7Oh1wgWEZlEOiNdVNY00d4Zu/fmG9WN3Phg32DxpStOGlawWFCsYCFTy7CvXFgwFupe4APhphaCJdm7HQK+TLDmyNcS1D4RkQkV6XIqa5to7YgdLLZXNXLzrzbT2BYEi5yMVG6/YjnLZucPWndKCiwsySUnQxeRZWqJ58rF3wAfBO4BZgLf6L3T3Q8ATwOXJqx1IiITKNLl7KxpoqU9drCoOHiEmx7a1BMscjNTuePKoYNFWqqxuDRPwUKmpHjCxceAl4FPuHsDEO3G4zZgYSIaJiIykbrCKxYt7ZGYZbbsP8zNv9pMU1gmPzONO688maWzBg8WGWkpLCrVyqYydcUTLpYBa90Hm4uOKmDopf1ERJJYd7BobosdLF7d18Atv36V5u5gkZXGXVcv57iyvEHrzkoPgkVmmoKFTF3xXI/rBIaa1WUu0Djy5oiITCx3Z3ddM02DBIvNbzbwpYdf7emHUZidzp1XLqe8JHfQurMzUikvztHKpjLlxRMuXgNWm5lFu3phZlnABcCLiWqciMh46g4WR8IRH9G8sree2x9+jbZw5EhRTjp3XXUy82fmDFp3XlYaC7QAmUwT8cTnnwHHA980sz7HmVkq8C/AHIIRJSIik4q7s/dQC4dbYgeLl/bU86VewWJmTgZfvnroYFGYnU55sYKFTB/xXLn4AXAFcB1wDXAEwMzuB84iCBa/cvf/SHQjRUTG2t5DLT3TdUfz512HuOvR12mPhMEiN4MvX3Uyc2cMvrjYjNx05hZpZVOZXoZ95cLdI8BlwO1ABrCUYE6LdwM5wB0EoUNEZFJ5s37wYLGxso47HnmtJ1iU5GXylauHDhYl+RkcOyNHwUKmnbgGWLt7J3CbmX2JIFwUAw3AljB8iIhMKvsbWqgLl0SP5rmdtXzlt1voDFdALcvP5K6rT2b2EKuWzirMpCxfK5vK9DSi2VvCDp1bE9wWEZFxdfBwKzVHYgeLZ9+o4Z9+t7UnWMwqyOSuq04ecjn0OUVZFOdpZVOZvoZ9W8TM/mRmnzKzGWPZIBGR8VB1pJWqw20x9z+9vYav9QoWxxRm8eWrBw8WZjB/Zo6ChUx78YwWWQF8D9hvZr80s0vDUSIiIpNKTWMbBxtiB4snt1XzT7/bQiQMFnPCYDHYbQ4zmF+cQ2GOFiATiSdcHAt8EXgDeA/wa+BNM/tnM3vLSBtgZsVm9nEze9DMtptZi5k1mNlTZvax/sNeh6jra2b2uJntCeupM7MXzexWMyuOUr7czHyQx30jPS8RSU61jW3sr2+NuX/d1iq+8futhLmCuUXZfPnqkykZ5GpE9wJkBVkKFiIANvhs3jEOMnsb8BHgfQSdOh14hWCOi/909+o46vokcDewH1gL7AZmEYxCKQQeAK4ZYtrx7rragT8TTPhVBeQSDJNdAewDznL3Pb3KlwM7CdZMeShKlZvd/f7hnMeKFSt848aNwykqIhPkUFM7ew+1xNz/+OsH+fbj23oWTpo3M4e7rlzOjNyMmMekphgLS3LJztCFXJlezOwFd18Rdd9IwkWvitOAy4EPA5cQdBDtcPdhd5E2swsIQsAj7t7Va/ts4DlgHvBed39gGHVlufuAP0nM7C7gBuBud/+bXtvLCcLFT9z9I8NtczQKFyLJrb65nT11sYPF/7x2gO8+sb0nWCyYmcOdVy2nKCd2sEhPM8qLtQCZTE+DhYtRTXDv7p3u/iDBUuy3Eqw/Etd1QXd/wt1/0ztYhNsPAN8PX64eZl2xrnX+V/i8JJ62icjU0NDSMegVi8c2H+A7vYLFwpJc7rr65EGDRWZ6CotK8hQsRKIY0VBUAAtmhbmY4KrFlQSLmjnweGKaBkD3rDax5+MdnsvD51di7J9jZn9NcIunFnjW3WOVFZFJ5HBrB3vqmol1kfbRTfu5e/0bPa8XleZyxxXLKciO/XdSdkYK5cW5WoBMJIa4w4WZnUgQKD4AzCaYpXMb8BPgp+6+NxENC2+5fCh8+Vicx34OyCPos7ECOI8gWHw1xiEXhY/edawDPuzuu+N5bxFJHo1tneyujR0sfvPyPn745I6e18eV5XHHFcvJy4r9qzE3M5UFxbmkap0QkZiGHS7M7G8JQsVpBIGiAfgRQX+FZ8agbV8FlgOPuvvv4jz2cwSdQrs9BnwkSkfTZoJpyx8Cun/DnALcBqwBHjezU929KdqbmNm1wLUA8+fPj7OJIjKWmto6qaxpihksHnrpTf79qZ09r5fOyuNLVywnLzP2r8WC7DTmzdACZCJDGXaHTjPrArqAPxBcpXhwkD4Oo2uU2XXAt4EtwLnuXjfCemYB5xAElXzgMnf/8zCOSwOeAs4Ernf3bw91jDp0iiSP5vZOdtY00dUVff9//3kv9zxT2fP6+Nn53Hb5SeQOEiyKctI5doYWIBPplqgOnTcA8939ne7+/8YwWHyaIFi8BqwZabAAcPeDYYfTiwn6U/x0mMd1ElyVAVg50vcXkfHX2hEZNFj8cuOePsHixGMK+NIVgweL4rwM5s3UAmQiwzXs2yLuHqu/QsKY2fXAN4HNwIXuXpWIet19l5m9BpxqZiXuXjOMw7pvoeQmog0iMvZaOyLsqI4dLO57fjf/8aej3aiWzynglstOGnSOilkFmZQNsZaIiPQ14tEiiWZmXyC4ffEScNEwA0A85oTPw1299azwecegpUQkKbR1Blcsuqfs7s3d+c/ndnPf8z1z6HHKsYXcfOmJgw4lPaYoa9CZOUUkupjhwsx2EAwtfbu77wxfD4e7++J4GmFmNwO3Ay8AFw92K8TM0oHFBJN1vdFr+/FAfTg/Ru/yKQSdNsuAZ9z9UK99ZwIvunt7v2MuAP4hfPnzeM5FRMZfe2cXO2ua6IxEDxY//9Nu/mvj0WBx6rwibnzXCTGDhVkw7fdgM3OKSGyDXblIAXyQ17HEdVPSzD5MECwiwJPAdVHua1a6+73hv+cCrwO7gPJeZd4JfN3MNhCsf1JLMGJkFbAIOAB8ol+9XwNOCoeddg+hPQW4IPz3zWM0EkZEEqQjEgSLjs7oweInz1bywJ/f7Nl22vwZ3PCu48lMix0s5s3MoXCQeS5EZHAxw4W7lw/2OoEWhs+pwPUxyqwnWLdkMH8AfgicC7wFKAKagArgZ8B3olwR+RlwNXA6wfTl6cBBghk9v+fuTw7/NERkvHUHi/bOgZ0s3J0fP72Th17a17NtxYIZfPGSE8hIi96X3QzKS3IHHY4qIkMb1doicpSGooqMr84wWLR2RA8W//bkDn7zyv6ebWcunMkX3nk86TFm1UxNMcpLcsjJULAQGY6EDEU1syfM7ENDlPmAmT0RbwNFROIR6XIqa6MHiy53vr+hb7A4e1HxoMEiLdVYVJqrYCGSIPHMc7Gavn0collA0MdBRGRMRLqcnTVNtLRHDxZ3r3uDRzcdDRbnHlfC59+xLGawyEhLYXGpFiATSaREx/RsRr/ImIhIVF3hFYuW9oEjyrvc+d7a7fzPawd7tq1cUsJnLloWcx2QrPQUyktyYwYPERmZeMNF1A4a4Qqp84F3AXuilRERGY2uLmdXXTPNbQODRaTL+c4T23hiy9F591YvK+X6C5fGDBY5mamUawEykTExaFw3sy4zi5hZ9//m27pf934QXK3YAZwK3De2TRaR6cbd2V3XTGPrwAujkS7nW3+o6BMsLji+bNBgkZeVxkIFC5ExM9SViw0cvVqxEtgNVEYpFyGYV+Jxjq7JISIyau7OnroWjsQIFv/yP1vZsO3ohL4XnTiLv11zHCkx1gEpzE5n3kwtQCYylgYNF+6+uvvf4aqo97j77WPdKBERCILF3kMtNLR0DNjXGeniG/9TwdPbjwaLd540m0+tXhwzWMzMy2BOYZaChcgYi6fPxUKgfozaISIywJv1LdQ3DwwWHZEuvv67rTy7o7Zn26UnH8Nfr1wUMziU5mcyu1ALkImMh3hWRd01lg0REeltX30Lh5qiB4uvPbaFP+08OuHuFW+Zw8fPWxgzWMwqzKQsX8FCZLwMtnDZLQT9Lf7V3evC18Ph7n5HQlonItPS/oYWahvbB2xv7+ziK799nY27etYf5KpT5/BX58YOFnNnZDNTC5CJjKvBrlzcRhAufgHUha+HwwlWIRURidvBw63UHBkYLNo6I3z50S38effRYPGe0+by4bPLowYLM5g3I4fCHC1AJjLeBgsXa8Ln3f1ei4iMiaojrVQdbhuwvbUjwl2Pvs5Le+p7tv2vFfP4wJnzYwaLBcU55GcpWIhMhMFWRV0/2GsRkUSqaWzjYEP0YHHHI6/xyt6Gnm3vP30e7z8jerBISYHy4lxytbKpyISJZ+GyD5nZKUOUWT7U4mYiIv3VNbWzv751wPaW9ghf+s2rfYLFX545n784c0HUYJGWaiwuzVOwEJlg8Uyofy9w1RBlrgTuGWljRGT6OdTUzpuHWgZsb27v5LbfvMrmfYd7tn3orAW87/T5UetJTwtWNtUCZCITL9HxPpUY64+IiPTX0NzB3ijBoqktCBZbDhzp2fbRc8p592nHRq0nMz2FhVqATCRpJDpcLAUODVlKRKa9hpYO9hxqHrC9sa2TW3+9mYqDjT3bPnbeQq46dW7UerIzUikvziFNwUIkaQwaLszsx/02XWVm5VGKphKsino+8EhimiYiU9WR1g721DXjPnD7Lb96le3VR4PFtecv4vK3zIlaT25mKgu0AJlI0hnqysVHev3bCVY9PTVGWQf+BPzDaBslIlNXY1snu2oHBovDLR3c/OvN7Khu6tn2qVWLedfJx0StpyA7jXkzckhRsBBJOkOFi4XhsxEsqf4t4NtRykWAQ+7eFGWfiAgQ9KWorGkaECwaWjq46aFNVNYevU3yt2uO4x0nzY5aT1FOOsfO0MqmIslqqFVRe9YTMbMvAWu1xoiIjERLe4TK2oHBor65nZse2syuuiBYGPB3FxzHRSdGDxbFeRnMKcoe49aKyGjEs3DZl8ayISIydbV2RNhR00hXV9/th5raufFXm9nTK1hc//YlXHD8rKj1zCrIpKxAC5CJJLu4u1eb2eVmdp+ZvWxm23ttP8HMPm9m0bt0i8i01NoRYUd104BgUdvYxhcf3NQTLFIMPnPR0pjBYk5RloKFyCQx7CsXFtzcvBf4QLipBeh9bfIQ8GWCPz6+lqD2icgk1tYZYWdNE5GuvvdCahrbuPHBTexrCGblTDH43MXLOH9J6YA6zODYGdkU5WhlU5HJIp4rF38DfJBgBs6ZwDd673T3A8DTwKUJa52ITFrtnV3srGmiM9I3WFQdaeWL/300WKSmGJ9/x/Exg8X84hwFC5FJJp5w8THgZeAT7t5A9Jk4t3F0hImITFMdkSBYdHT2/TVx8HAQLA4cDoJFWorxhXcez7nHlQyoIyUFyktyKdDKpiKTTjzhYhnBaJHBpveuAgb++SEi00ZnGCzaO/t2sjjQ0MoXH9xE1ZFg5dO0FOOLlxzP2YuKB9SRmmIsKskjTwuQiUxK8fzP7QSG6k01F2gcooyITFHdwaKto2+w2Fffwo0PbaKmsR2A9FTjhktOYEX5zAF1pKcZ5cVagExkMosnXLwGrDYzi3b1wsyygAuAFxPVOBGZPCJdTmVtE639gsWbh1q44aFN1DUdDRY3vetETlswY0AdmekplBfnkpGmdUJEJrN4/gf/DDge+KaZ9TnOzFKBfwHmEIwoEZFppCsMFi3tfYPFnkPNfPHBV3qCRUZqCrdcdlLUYJGdkcKiEgULkakgnv/FPwB+D1wH7AHeD2Bm9wO7gE8Cv3b3/4inAWZWbGYfN7MHzWy7mbWYWYOZPWVmH+sfZIao62tm9riZ7QnrqTOzF83sVjMbeGP36HHnmNmjYflmM3vFzK4PQ5OIDKI7WDS3Rfps31XbxA0PbuJQcwcAmWkp3Hr5iZw6r2hAHTmZqSwsydPKpiJThA3eP7NfYbM04Cbg00DvD+t64LvAHe7eGVcDzD4J3A3sB9YCu4FZwLuBQuAB4JohOpJ219UO/JngFk4VkAucBawA9gFnufuefsdcGb5HK/ALoA64nKAD6/3ufs1wzmPFihW+cePG4RQVmTLcncraZhpb+/63r6xp4qZfbaahJQgWWekp3HrZSSyfWzigjvysNObP1AJkIpONmb3g7iui7osnXPSq0IClBAGjAdji7pHBj4pZ1wUEIeARd+/qtX028BwwD3ivuz8wjLqy3L01yva7gBuAu939b3ptLwC2E4SYc919Y3c9wBPA2cD73f2+od5b4UKmG3dnd10zh1v6Bosd1Y3c9KvNHAkDR3Z6KrddcRInHlMwoA4tQCYyeQ0WLkZ0DdIDW939GXd/daTBIqzrCXf/Te9gEW4/AHw/fLl6mHUNCBah/wqfl/Tb/l6CobP3dQeLXvXcFL781HDeW2Q6cXf21LUMCBbbqxq58aGjwSInI5XbYwSLmXkZzJuZo2AhMgWNaBC5mZ0PvJXgL/4G4EV3fzKRDQt1hM9x3WqJ4vLw+ZV+2y8Inx+LcswGoBk4x8wy3b1tlG0QmTL2HmrpueXRreLgEW759Waawr4XuRmp3H7lcpbOyh9wfFlBJrO0TojIlBVXuDCzc4EfA8d1byKcqdPMtgEfc/enE9GwsH/Hh8KX0T78Bzv2c0AeQfhZAZxHECy+2q/osvC5on8d7t5pZjuBk4BFwOvxtEFkqtp7qJn65r7BYsuBw9z661dpbg+CRV5mGndcuZzjyvIGHD+7MIvS/MxxaauITIx4Fi57G/A/BBNprQfWAQeA2cAaYCXwezM7393/nIC2fRVYDjzq7r+L89jPEXQK7fYY8BF3r+5Xrrt3WUOMerq3F0XbaWbXAtcCzJ8/P84mikw+++pbONTUN1i8vj8IFi0dQbDIzwqCxeLSgcFi7oxsZuZqnRCRqS6ePhd3EYSRK919jbt/yd1/ED6vBq4GMsJyo2Jm1wGfBbYQLJYWF3ef7e5GEHzeTXDl4UUzOy3epnRXGeN9fujuK9x9RWmpZj2Xqe1AQyu14Qyb3V7d19AnWBRkpXHXVScPCBbdC5ApWIhMD/GEi3OA/3b330Tb6e6/Ah4My42YmX0a+DbBcNI17l430rrc/aC7PwhcTDCy5af9inRfmRg4Pi5Q0K+cyLRUdbiV6iN9ux1t2lvfJ1gUZafz5atPZmFJbp9yZrCgOIfCbC1AJjJdxBMuugiGbQ5mGzH+yh8OM7se+B6wmSBYHBhpXb25+y6CsHKSmfVefnFr+Lw0SlvSCFZ47QR2JKIdIpNR9ZE2Dh7uGyxe3lPPbQ+/Rlu4ONmMnCBYLCjuGyxSUmBRaS75WtlUZFqJJ1xsBN4yRJm3EMxNETcz+wLwTeAlgmBRNZJ6BjEnfO49bPaJ8PmdUcqvBHKAZzRSRKarmsY2DjT0HeH9592HuP3h13pWPZ2Zk8GXrz6ZeTNz+pRLSzUWl+aRk6GVTUWmm3jCxU3ARWYWdd6H8HbGhcDN8TbCzG4m6MD5AnChu9cMUjbdzI43s8X9th8fTrzVv3xKOIlWGUFQONRr9/1ADfA+M1vR65gs4M7w5d3xno/IVFDX1M7++r7BYuOuOu585DXaI0GwKM7N4CvvPpljZ/QNFhlpKSwq1cqmItNVPH9SXEzwl/73wtsXTwIHCUZlnEcwQdVjwDvM7B29jnN3vyNWpWb2YeB2gisKTwLXRZlUp9Ld7w3/PZdgWOguoLxXmXcCXzezDcAbQG3YtlUEHToPAJ/oXam7HzazTxCEjHVmdh/B9N9XEE7/TTAluMi0Ut/czpuHWvpse25nHV/57et0dgV3PkvzM7nrquUcU5jdp1xWegrlJbmka50QkWlr2NN/m1nX0KWicneP+eeLmd0G3DpEHevDESmYWTmwE9jl7uW96llOMJvmucCxBMNHmwjmsHgE+E6szqHh/B03Ekz3nUXQt+TH4THDmn1U03/LVNHQ3MHuuuY+2/64o5avPbalJ1iU5Wfy5atPHjARVnZGKuXFOVqATGQaSMjaIma2aqQNcPf1Iz12slC4kKngcGsHu2ub6f1r4entNXz991uJhMFidkEWd121nLJ+wSIvK40FWoBMZNoYLFwM+7bIdAgIItPZkSjB4slt1Xzj91sJcwXHFGZx11UnD5hhszA7nXkztQCZiATUjVtEaGzrZFe/YLFuaxXf/ENFT7CYW5TNXVctpzivb7CYkZvO3CIFCxE5aqQLl3XPfhl18Lq77x5No0Rk/DS3d1JZ09QnWDyxpYpvP340WBw7I5u7rjp5wAybJfkZAzp0iojEu3DZNcA/AicDsTpperz1isjEaGmPsLNfsPjD6wf5zuPbembDmz8zhzuvWs6MnL7BYlZhJmX5WtlURAaKZ+GyTwPfIZix8ingTUa/FLqITJDWjiBYdPUaB/a7Vw/wr2u39wSL8uIc7rzq5AFTd88pyhpwe0REpFs8Vxj+AagCznH3nWPUHhEZB60dEXZUN/WMAAH47eb9/N91b/S8XlSSy+1XLu8TLMyCWyRFOVqATERii2cw+lzglwoWIpNbW2dwxaJ3sHj4lX19gsXi0lzuvGpgsJhfnKNgISJDiufKxR5A10FFJrH2zi521jTRGTkaLH710pv86KmjfzMsKcvj9iuWk5d19NdDSgqUF+eSm6nuVCIytHiuXNwLXGJm+WPUFhEZQx2RIFh0dB4NFg++uLdPsFg2K587ruwbLFJTjEUleQoWIjJs8YSLrwHPA38ws1UKGSKTR2cYLLpXMgW4/4W9/Pjpyp7XJxxTwO1XntQnRKSnGYtKc8nO0AJkIjJ88czQGTGzfwV+SbhUeYxJc9zd9SeOSJLoDhZtHUeDxS827uHnf9zV8/qkOQXcetlJfUJEZnoK5cW5ZKRpnRARiU88Q1GvJFglNJVg4bB9aCiqSFKLdDmVtc20hsHC3bnv+T3853NH57k7ZW4hN192Yp/l0bMzgmChBchEZCTiucJwG9AMXOruT41Nc0QkUbq6nMraJlrag4V93Z3/+NNufrFxT0+ZU+cVceO7TugTLHIzU1lQnEuqFiATkRGKJ1wsA36qYCGS/LqDRXPb0WDx02d3cf+f9/aUeeu8Im689AQy044Gi/ysNOZrZVMRGaV4wkUN0D5WDRGRxHB3dtc109QrWNzzTCUPvvhmT5m3LZjBDZec0Kc/RVFOOsfO0AJkIjJ68YSLB4B3mlm6u3eMVYNEZOS6g8WR1s6e1z96aie/fnlfT5nTy2fwxUtOIL1Xf4rivAzmFGkBMhFJjHh6a90EHAJ+aWblY9McERkpd2fvoRYOtxwNFj/csKNPsDhr0cwBwaKsIFPBQkQSKp4rF5sIllg/E7jczOqBhijl3N0XJ6BtIhKHvYdaqG8OLip2ufP99W/w280Hevafs7iY/3Pxsj4jQI4pyqJEC5CJSILFEy5SCIae7u61LdrNWd2wFRlnb9b3DRb/unY7v3/tYM/+85eU8Jm3L+0JFmYwtyibGblaJ0REEi+eSbTKx7AdIjJC+xtaqGsM+lpHupzvPrGNx7dU9exftbSUf3j70p6hpWYwb2bOgGXURUQSRTNpikxiBxpaqTlyNFh8+/EK1m6t7tm/Zlkpf39h32BRXpJLntYJEZExNOLfMGZWABQCDe5+OHFNEpHhqDrcSvWRNiAIFt/8QwXrK44Gi7efUMbfrlnSEyxSU4zykhxyMhQsRGRsxTW3r5mlmtk/mtl2gpEjlcAhM9sebtdvLZFxUH2kjYOHg2DRGeniG7/f2idYvOPEWfzdBUeDRVpqsACZgoWIjId41hbJAB4DVgEO7AH2A8cA5cBdBPNgXOzummxLZAx0dTl1ze0caGgFgmXUv/H7rTzzRm1PmUuWz+aTqxaTEk6GlZGWwsISLUAmIuMnnj9jPgOsBh4GPuvu27p3mNli4J+By8NyX01gG0WmpUiX09oRoaUjQkt7hNaOCG2dXbgH+zsiXXztsS38aWddzzGXnXIM156/qGeWzaz0FMpLcvvMayEiMtbiCRd/AWwGrnL3rt473P0NM3s38BLwlyhciMSlM9IVhIiOCK3tXbR2Rvoskd5fR6SLr/z2dZ6vPNSz7Yq3zOHj5y3sCRY5mamUawEyEZkA8YSL44Dv9g8W3dy9y8x+C/xdQlomMkV1hEGitT3SEyg6On3Yx7d3dvHl377OC7uOBour3zqXj55T3hMs8rLSWKAFyERkgsQTLtqBvCHK5AJad0Qk1NYZXIlo6XV7I9I1/CARrb67HnmdF/fU92x772nH8qGzF/QEi8LsdObN1AJkIjJx4gkXrwDvNbPb3L26/04zKwHeC7ycqMaJTBbuTltnV58+Ei0dEbpi39mIS2NbJ8++UcOjmw6wvbqxZ/v/Pn0ef3nG/J4gMSM3nblFChYiMrHiCRffA+4DnjOzO4G1BKNFZhN09LwJKAWuS3AbRZKKu9Pa0fdqRGtHpKejZaK0dUZ4vvIQ6yuq2Fh5iM5+Vzz+4oz5vP+M+T2vS/MzmV2YldhGiIiMQDzTf/+XmZ0K/CPwwyhFDPgnd/+vBLVNZMJ1dXmfENHWGaG1oyvhQaJbZ6SLl/c2sL6iij/uqKOlIzKgTIrBh84u5z2nHduzbVZhJmX5ChYikhzimlHH3W8ws18DHwPeSjhDJ/Ai8GN3fzbeBphZMXA1cClwMjCXoH/HJuAe4J5YnUhHW0+4dPzOQar9hbu/L85Tkkkq0h0kwisRLR2Dj9hIlC53thw4wvqKap7eXkNDS/RuS4tLc1m1tJTzl5T2Wcl07oxsZmoBMhFJInFP1+fufwT+mMA2XAPcTXCLZS3BqquzgHcDPwIuMbNr3If8W3E09bwMPBRl++a4z0YmhdGO2EiEypom1ldUs2FbNVXhNN79zSnMYtXSUlYuLeXYGTl99pnBvBk5FOZoATIRSS7JMBdwBXAF8EjvKwtmdgPwHPAegoDwwBjW85K73zaKc5Ak1t4ZBoleHS07I+MbJLodONzKhopq1ldUs7uuOWqZmbkZrFxSwsolpRxXlhe1c6YZLCjOIT9LwUJEks+g4cLMMoEngSPAO9096vXacGrw3xIMRT0/Vrlo3P2JGNsPmNn3CaYVX80Q4SJR9cjkNdYjNkbqUHM7T22rYcO2arYcOBK1TG5mKuctLmHl0lJOmlM46MRXKSlQXpxLrlY2FZEkNdRvp78E3gZcPlhgcPd2M/s68Gh4zL0Jal/3e3aOcT1zzOyvgWKgFnjW3V8Z5XvKGOo9YqN3mBirjpbxam7v5Nk3allfUc3Le+uJNrVFRloKZy6cyaqlpZw2f8awpujOy0rjmMIsstJTx6DVIiKJMVS4eDeww90fHaoid3/MzLYR9H24d7QNC1dY/VD48rExruei8NH7uHXAh91990jfWxKjq8tp7Tx6JaK1Y2xHbIxUe2cXG3fVsb6imucr6+iIcuslxeC0+TNYtbSUMxcWk50xvJCQm5nKrIIsXa0QkUlhqN9UbyW4GjFcG4B3jbw5fXwVWA486u6/G6N6moE7CDpz7gi3nQLcBqwBHjezU929KVrFZnYtcC3A/PnzoxWROE3UiI2RinQ5r+ytZ8O2ap55o5bm9oFDRwFOmlPAqqWlnLO4hMLs4feTyAlDRZ5ChYhMIkP9xioBDsZR30GCWwujYmbXAZ8FtgAfHKt63L0KuKXf5g1mdjHwFHAm8HHg29Hqd/cfEs75sWLFiiT7Ozr59V+sq6UjQntn8gaJbu5OxcFG1ldU8eT2Guqbo98xXFjSPXS0JO45KBQqRGQyG+o3VwtDryfSWx7QOvLmgJl9muDD/DXgQnevG+KQhNfj7p1m9iOCcLGSGOFChi+ZRmyM1O665mDoaEU1Bw5H/zGfXXB06Oj8mTlRywwmOyOVWQWZGgUiIpPaUOFiD3B6HPWtIJhfYkTM7HrgmwTzS1wYXlmYqHq610/JHUkbprPWXv0iErFY10SqOtzKhm01rK+oorI2+tDRopx0Vi4pZdXSUpbEGDo6lOyMFMoKsihQqBCRKWCocLEO+BszW+HuGwcraGZvA84BvjuShpjZFwj6R7wEXOTuNRNZD3BW+Lxj0FLTWPfQz5ZeE1El04iNkWpo6eDp7TWsr6jmtf2Ho5bJzUjlnHDo6MlzBx86OhiFChGZioYKF98DPgX80sze5e6vRytkZscDvwQiwP+NtxFmdjNwO/ACcPFgtzDMLB1YDHS4+xsjrScsfybworu399t+AfAP4cufx3k6U9JkGbExUs3tnfxpZzDS48Xdh6IOHU1PNc4oD4aOvm3BTDLShh46GktWehAq4uncKSIyWQwaLtx9q5ndTjB64kUzux94AtgLOHAscCHB7JeZwC3uvjWeBpjZhwkCQYRgwq7rolxWrnT3e8N/zwVeB3YB5aOoB+BrwEnhsNO94bZTgAvCf9/s7s/Ecz5TQaTL+8wd0doRoa1z6gSJbh2RLl7YdYj1FdU8V1kXtTNpisGp84pYtbSUsxYVk5Mxug6WmekpzMrP0pTdIjKlDfmb0t1vN7NO4FbgL4D39ytiBJNU3ejuXxlBGxaGz6nA9THKrGfouTNGUs/PCBY7Ox24BEgnGPHyX8D33P3JId5z0pusIzZGKtLlvLqvIVgk7I0amtqiDx09YXY+q5aWcu5xJRTljH5RsMz0FMryMynMTh9RnwwRkcnEhl4PLCxotgD4K+Bc4BiCULGPYMjmPe6+a6waORmsWLHCN24ctFvKhOsesdHWMXGLdU0Ed2d7VSPrK6p5clsNdc3tUcuVF+ewckkp5y8tZXZBYpYvz0hLYVaBQoWITD1m9oK7r4i2b9jXeMPwcGvCWiVjqq3z6JWIyT5iY6T2Hjo6dHRfQ/Sho2X5mcHQ0SWllJckbmBQRlpwpaIoR6FCRKYfzdAzyUUbsdGaBIt1TZSaxjae3BasOvpGddSJVSnMTuf840pYtbSUZbPzE/rhn55mlOVnMUOhQkSmMYWLSaSrKwwS/TpbTrWOlvE63NLBM2/Usr6iilf3HSbalyM7PZWzFxezakkpb5lXNOKho7GkpxmleZnMzM1QqBCRaU/hIklNlxEbI9XaEQmHjlbx5931UW/5pKUYp4dDR1eUzyAzLfEriaalGqX5mczMySAlwYFFRGSyUrhIUq/tiz5503TWEenixd3BImF/3FFLW4yho6ccW8SqJaWctbh4zNbmUKgQEYlN4UKSWpc7r+07HAwd3V7DkbbOqOWWzcpn5dJSzj+uhBm5ox86GktqShAqinMVKkREYlG4kKTj7uyoaQqHjlZT0xh96Oi8Gdk9i4QdU5g9pm1KTTFK8jMoyc1UqBARGYLChSSNffUtbAhHeuw91BK1TEleJquWBiM9yotzx7zzZEoKlOZlUpyXmfBOoCIiU5XChUyouqb2nqGj26oao5bJz0rjvHDo6AnHFJAyDqMxFCpEREZO4ULGXWNrJ8/sCFYd3bS3IerQ0az0FM5aFAwdPXVeEWmpI18kLB4pKcHVkRKFChGREVO4kHHR1hnh+cpDrK+oYmPlITpjDB1924IZrFpayunlM8lKT/zQ0VjMukNFxrgFGRGRqUrhQsZMZ6SLl/c2sL6iij/uqKOlY+AiYQacPLeQlUtLOWdxMflZ47taqBkU52VQmpepUCEikiAKF5JQXe5sOXCkZ+hoQ0tH1HLHleWxKhw6WpyXOc6tPBoqSvIySVeoEBFJKIULGTV3p7K2uWfoaNWRtqjl5hZl9ywSNnfG2A4djcUMZuZmUJqvUCEiMlYULmTEDhxuZUNFMNJjd11z1DLFuRmcv6SUVUtLWVw69kNHYzGDGbnB7Y+MNIUKEZGxpHAhcTnU3M5T24KRHlsPHolaJi8zjXPDoaMnzRmfoaOxmEFRTjpl+VkKFSIi40ThQobU1NbJsztq2VBRzct764ky0IPMtBTOXBgsEvbW+TMm/JZDd6gozc8ckwXLREQkNoULiaq9s4uNu+pYX1HN85V1dEQGJorUFOOt84pYtbSUMxcWk52RHB/iRTnplBUoVIiITBSFC+kR6XJe2VvP+opqnt1RS3P7wKGjACfNKWDV0lLOXVxCQfb4Dh0dTPeVivGcH0NERAZSuJjm3J2tB4+woaKaJ7fXUN8cfejootJcVi0p5fwlpZTmj//Q0cEUZgdXKhQqRESSg8LFNLW7Lhg6uqGimgOHW6OWOaYwi5VLS1m1pJR5M3PGuYVDU6gQEUlOChfTSNXhVjZsq2F9RRWVtdGHjs7ISe8ZOrqkLG/Cho4OpiA7jbL8rKTp4yEiIn0pXExxDS0dPLU9GDr6+v7DUcvkZqRyTjh0dPmcwqRdsCs/K41ZBQoVIiLJTuFiCmpu7+RPO4ORHi/uPhR16GhGagpnLJzJyqWlrFgw8UNHB5OXlcasgkxyMvTjKiIyGei39RTREenihV2HWF9RzXOVdbR3dg0ok2Jw6rxg1dGzFs1M+g/rvKw0yvIzyc1M7naKiEhf+q09iUW6nM37GlhfUc0zb9TQ1BZ96OgJxwRDR887roTCJBo6GktuZiqzCrIUKkREJin99p5k3J1tVY3B0NFtNdQ1t0ctV16cw6qlZaxcUkJZQdY4t3JkcsJQkadQISIyqem3+CSx51BzzyJh+xuiDx2dVZDJynCkx4Li3HFu4chlZ6QyqyCT/Kzkv6oiIiJDU7hIYjWNbWyoqGbDtmreqG6KWqYoO53zlgQjPZbNyk/KoaOxKFSIiExNChdJ5lBTO7/dfID//NMuXt13mCgDPchOT+WcxcWsWlrKKccWJe3Q0ViyM1IoK8iiQKFCRGRKUrhIMh//6UZe2HVowPb0VGPFgmDV0RXlMyblolxZ6UGomAydSkVEZOQmPFyYWTFwNXApcDIwF2gHNgH3APe4+8BxlQmsx8zOAW4CzgKygO3Aj4Hvunv0IRhj5NKTj+kJFykGpxwbrDp69qLiSTt6Iis9hbL8LApzFCpERKaDZPi0uga4G9gPrAV2A7OAdwM/Ai4xs2vcPdodglHXY2ZXAg8ArcAvgDrgcuCbwLlhvePmslOO4eFX9rFiwUzOW1LCjJyM8Xz7hMpMT2GWQoWIyLRjQ39mj3EDzC4AcoFHel9ZMLPZwHPAPOC97v5AousxswKCqxSFwLnuvjHcngU8AZwNvN/d7xvqPFasWOEbN24c3kkPw6a9DQmra7xlpKUwqyCTwuz0SdXBVEREhs/MXnD3FdH2Tficz+7+hLv/pv8tC3c/AHw/fLl6jOp5L1AK3NcdLMJjWglukwB8apinMu1lpKVw7Ixsls7KoygnQ8FCRGSaSobbIoPpCJ87x6ieC8Lnx6IcswFoBs4xs0x3bxtlG6as9DSjLD+LGTm6UiEiIkkcLswsDfhQ+DLah38i6lkWPlf0P87dO81sJ3ASsAh4faRtmKrS04zSvExm5uoqhYiIHJW04QL4KrAceNTdfzdG9RSGz7E6OHRvL4q208yuBa4FmD9//iiaOLmkpRpl+QoVIiIS3YT3uYjGzK4DPgtsAT44gfV0f3JG7fXq7j909xXuvqK0tHSErZw80lKNY4qyWDYrn+K8TAULERGJKumuXJjZp4FvA68BF7p73RjW031lojDKPoCCfuWmpdQUozQ/k+LcDFIm2WygIiIy/pLqyoWZXQ98D9gMrAlHeoxlPVvD56VR6kgDFhJ0At0xknZMdqkpxqzCTI6fnU9pfqaChYiIDEvShAsz+wLBxFUvEQSCqnGo54nw+Z1R9q0EcoBnpttIkZQUmFWYybLZ+ZTlZylUiIhIXJIiXJjZzQQdL18guIVRM0jZdDM73swWj6ae0P1ADfA+M+uZCCScROvO8OXdcZ3MJJaSEizbfvzsAsrysybdgmgiIpIcJrzPhZl9GLgdiABPAtdF6ShY6e73hv+eSzAsdBdQPop6cPfDZvYJgpCxzszuI5j++wqCYar3E0wJPqWlpEBJXiYleZkKFCIiMmoTHi4I+jUApALXxyizHrh3LOpx94fMbBVwI/Aeji5c9hngO8NY02TSMusOFRmkpSbFRSwREZkCJnxtkaliMq0tolAhIiKjNdjaIslw5ULGiRkU52VQkpdJukKFiIiMEYWLacAMZuZmUJqvUCEiImNP4WIKM4MZuRmUKVSIiMg4UriYgrpDRWleJhlpChUiIjK+FC6mEDMoykmnLD9LoUJERCaMwsUUUZSTTllBJplpqRPdFBERmeYULia5opx0SvMzyUpXqBARkeSgcDFJKVSIiEiyUriYZAqzg9sfChUiIpKsFC4miYLsNGYVZClUiIhI0lO4SHL5WUGoyM5QqBARkclB4SJJ5WelUVaQSU6GvkUiIjK56JMrSZWX5E50E0REREZEMy2JiIhIQilciIiISEIpXIiIiEhCKVyIiIhIQilciIiISEIpXIiIiEhCKVyIiIhIQilciIiISEIpXIiIiEhCKVyIiIhIQilciIiISEIpXIiIiEhCKVyIiIhIQilciIiISEKZu090G6YEM6sGdk10O0ahBKiZ6EaMMZ3j1KBznBp0jpPfAncvjbZD4UIAMLON7r5iotsxlnSOU4POcWrQOU5tui0iIiIiCaVwISIiIgmlcCHdfjjRDRgHOsepQec4NegcpzD1uRAREZGE0pULERERSSiFCxEREUkohYspysyONbMfm9k+M2szs0oz+5aZzYijjvea2XfN7EkzO2xmbmY/H8t2x2O052hmxWb2cTN70My2m1mLmTWY2VNm9jEzm/D/Hwn6Pn7NzB43sz3hOdaZ2YtmdquZFY9l+4fZvlGfY5Q6Pxj+vLqZfTyR7R1hexLxfazsdU79HwfGsv3DbF/Cvo9mdr6ZPWBm+8O69pvZ783sXWPR9jjaNdrfOR8Z5HvY/YiM9XmMB/W5mILMbDHwDFAG/ArYApwBrAG2Aue6e+0w6nkJeAvQCOwFjgf+w90/MDYtH75EnKOZfRK4G9gPrAV2A7OAdwOFwAPANT5B/0kS+H1sB/4MvAZUAbnAWcAKYB9wlrvvGYtzGEbbEnKO/eqcB2wCUoE84BPu/qNEtjvO9iTq+1gJFAHfirK70d2/kZgWxy+R30czuwm4g2DyqYcJ/n+WAG8F1rr75xN+AsNrVyJ+55wKXBVj9/nABcAj7n5ZYlo9gdxdjyn2AH4HOPB3/bb/S7j9+8OsZw2wBDBgdXjszyf6/BJ1jgT/kS8HUvptn00QNBx4z2Q+x7B8Voztd4X1/N/Jfo69jjPgD8AbwNfDOj4+UeeX4O9jJVA5kecyDud4TVj+f4D8KPvTJ/s5DlL/s2E9V0z09zMhX6+JboAeCf6GwqLwB3RnlA/NfIKrEE1Abpz1Jk24GKtz7FfPDeF7fHcKn+Nbun+RT5VzBP4e6AJWArdNdLhI5Dkma7hI1DkS3KbfEZYtnejzGqvvY4z6l4f17wVSJ/p8E/GY8HvKknAXhM+/d/eu3jvc/QjwNJBDcFl8shqPc+wInztHUcdojMc5Xh4+vzKKOkYjoedoZicAXwW+7e4bEtnQUUj09zHTzD5gZjeY2d+b2RozS01ge0ciUed4DrAQeBQ4ZGaXmtkXwvM8O9GNjtNY/3/86/D53919SvS5ULiYepaFzxUx9m8Ln5eOQ1vGypieo5mlAR8KXz42kjoSIOHnaGafM7PbzOybZvYkwX3tVwg+kCdCws4x/J79jOB21g2jb1rCJPr7OJvgPO8i6HvxBLDNzFaNtIEJkKhzPD18PkjQR+hhgp/NbwHPmNl6M4u6SNY4GLPfOWaWDXyA4IrbhPUNSjSFi6mnMHxuiLG/e3vR2DdlzIz1OX6V4DLlo+7+uxHWMVpjcY6fA24FrgfOIwhOF7t79QjalwiJPMdbCDr8fcTdW0bZrkRK5DneA1xIEDBygZOBHwDlwG/N7C0jbuXoJOocy8LnTwLZwNsJbjksJ+jvsBL45YhbOTpj+Tvnf4XH/dYnqGP1WFC4mH4sfJ7Kw4RGfI5mdh3wWYKe4B9MZKMSLO5zdPfZ7m4EH07vJriP/KKZnTYG7UuEYZ2jmZ1BcLXin9392TFvVWIN+/vo7l9y9yfc/aC7N7v7Znf/JEGHwmyCPibJaLjn2H17x4D3uvvj7t7o7q8CVxP0R1iVBLdIohnN79Vrw+cfJKgtSUHhYurpTtCFMfYX9Cs3GY3JOZrZp4FvEwzZXOPudSNrXkKM2fcx/HB6ELgYKAZ+Gn/zEmLU59jrdkgFcHPimpYw4/H/8fvh88pR1DEaiTrHQ+HzDnd/ufeO8GpU91XEM+Ju4eiN1e+cEwn6muwl6GsyZShcTD1bw+dY9/6WhM+x7h1OBgk/RzO7HvgesJkgWEz0pERj/n10910EQeokMysZaT2jkIhzzAuPPwFo7T0ZEcEtIIB/C7d9a7QNHoHx+P9YFT7njqKO0UjUOXbXUx9jf3f4yB5esxJqrL6PU64jZ7e0iW6AJNza8PliM0vp3bPZzPKBc4EW4I8T0bgESeg5mtkXCPpZvARc5O41iW3uiIzX93FO+DwRv9gScY5twL/H2HcaQT+Mpwg+HCbilsl4fB+7bxPsGEUdo5Goc9xAMDpriZlluHt7v/3Lw+fK0Tc5bgn/PppZFsGt1y5i/wxPXhM9FlaPxD+IY7IXIJ1g5s3FQ9S5miSZ5yKR50hwKd2BjcDMiT6vRJ9juG12lLpTODqJ1tOT+RwHqfs2JtkkWoN8H0+K9vMJLCAYqeDADZP5HMN9Pw/L39lv+0UEH8L1QNFkPsdeZT4YHvebifz5HKuHpv+egqJMU/s6cCbBjJsVwDkeTlNrZuUEE8PscvfyfvVcxdGpamcD7yD46+jJcFuNu39u7M4ktkSco5l9GLiX4K/27xL9fmmlu987RqcxqASd4/UEM1VuIJi1spZgivNVBB06DwAXuvtr43FO/SXqZzVG3bcR3BpJtum/R/J9vA34R4K/oHcCR4DFwKVAFsH9+qt94F/74yKBv3PKCOaMOI7g98xzBAHqaoIP4r9w9wkZMZLon9VwOPh5BDNy/mas2z/uJjrd6DE2D2AewdC1/UA7sIugs+LMfuXKCf7TVkap47ZwX6zHgGMm0zkO4/wcWDfJz3E58K8Et3xqCC47NwDPh+c/4VdrEvGzGqPe7u/vhF65SND3cRXw/whGMdUTTPJWTTBN9ocI14mazOfYa/9MgqsBO8N6agk+zM+aQud4Qrh/D1NkRs7+D125EBERkYTSaBERERFJKIULERERSSiFCxEREUkohQsRERFJKIULERERSSiFCxEREUkohQsRERFJKIULERlXZlYeLiR270S3Zaoxs3vDr235RLdFpjeFC5EEMrPjzey7ZrbZzBrMrN3M9pnZI2b2sXCxoikv/IBbN9HtGK5egWewx+okaOdtydIWkcFoVVSRBDGzWwjWskghWB3xJ0AjwVoeq4EfAZ8CVkxQE5PFmwTTH0dby2WiNQDfirGvcvyaMWJfJFjh982JbohMbwoXIglgZjcAXyJYK+Aad/9TlDKXAZ8d77YlG3fvIFgjIxnVu/ttE92IkXL3/QTrXohMKN0WERml8P72bQSLSb0rWrAAcPeHgXdGOf5/mdmG8DZKi5ltMrMvmllmlLKV4aPAzP4l/HdHuGrmcPbHvCdvZqvDfbf1274u3J5pZnea2U4zazOzN8zsVjPL6FX2I2bWvWDRqn63FbrbELPPhZkdY2b/Gra73cyqzey/zextUcp+JKznI2a2JmznETM7HN6GOiHa92E0en+NzOyM8H3qen9Nw7b80MxeC9vSEt4muzXWbTEzSzWzT5rZ071+Drab2Y/MbElYppLgyhjA2t5f2171DPb9HcnPWY6Zfd3Mdoff8+1m9gUzs1F/MWVK05ULkdH7KJAO3Ofumwcr6O5tvV+b2ZcJLmXXAP9JcBvlEuDLwDvM7KLwL/3eMoAnCFaP/D1wmGAFyeHuH6n/Ak4H7icIUlcShKoVZnaFB6sgvkRwBedWghUj7+11/LrBKjezhcBTwJyw/f+PYBXKa4BLzew9YUDr77KwLb8Fvg+cCLwLON3MTnT3mvhPdUhnE3zfngJ+DJQQrJIJ8AXgeILluR8hWBL9XIKv1Woze7u7R7orCsPZI8DbCa58/SfB96ycYKnxp4BtBLdrriJYIfUnxHGbZoQ/Z+kEPz9zCL62neH7fzU8py8N9/1lGproZVn10GOyP4DHGcHS3gQfUA7sBmb32p4G/Cbcd0O/YyrD7X8AcqPUOdT+e8P95VH2rQ733dZv+7pwewUwo9f2LODZcN8H+x0Tc7l6ji5HfW+/7b8Lt9/Yb/s5BB9stUBer+0fCct3Ahf2O+Yr4b7PD/N70d2meoIQ0P9xVb+vkQN/HaOuRURZAh24Izzuf/fb/uVw+6+BzH77MoHSXq9vC8uujvHeA76/o/w5exTI7rW9LPwa1QPpE/1/T4/kfei2iMjoHRM+743zuL8Kn+909wPdG929k6BvRhfw8RjHftbdmwape6j9I3GHux/qfuHurQR/DcPRcxkRMzsWuJjgA/Cfeu9z92cIrmLMBN4d5fD73P3xftt+GD6fEWdTCgmuuvR/XNWv3Evu/oNoFbj7Dnf3KLu+FT6/o3uDmaUCfwO0AJ/0fle23L3N3avjPIf+RvNzdp27t/Q6pgr4FcHXadko2yVTmMKFyOh133+O9oEymNPC5yf673D3CoKwstDMivrtbgVeGaTeofaP1Poo254kuHLw1lHW3X38kz7w8jwc/RpFe5+NUbbtCZ9nxNmOXe5uUR4f6VfuuVgVmFmumd1gZs+H/Ru6wn4R3bdn5vYqfjzBB/Ur7r4vzrYO10h/zhrcfXuU+kb6tZVpRH0uREZvH8GHxLFxHlcYPsfq3b8fmB+Wq++1vSrGX8bD3T9SB/tvcPeImdUSXC4fjeF8LQCKouyrj9KuzrDPYeoo2xXLgWgbzSyd4EP8DGAz8AugmqCPCgRXQXp3oCwKn8dy6OhIf87qoxUmCJMwdl9bmQJ05UJk9J4Kny+M87jueR5mx9h/TL9y3YYKDoPt7wqfo/1hUTREvbP6bwgv6xcTdEAcjZF+LSZKrK/xlQTB4ifufrK7X+vuN3owvDXabZT68HlulH2JMtm+tjIFKFyIjN49BH+ZvsfMThysYL9hfy+Gz6ujlDuO4ErITnevT0wzAejuMzEvyr6hJvdaFWXb+QRB5cV+27uI7y/b7uPPM7NowWdN+PznOOqcCMeFzw9E2Rft67eFIGCcYmZzhlF/9yiTkXxtV/ffMYY/ZzLNKVyIjJK7VxL04s8AHjGzqB/SZvZOgiF93X4cPt9kZqW9yqUC3yD4//nvCW5ud1+BT/Rr28nA3w9x7M1m1nOfPZyz4Svhy3v6la0leoCJyt33Av9DMGrj+n5tOxP4C4Jg9OBw65wgleHz6t4bzWwR8LX+hT0Ykvp/gWzg+/3nnDCzjN4/GwRfVwhuYwzXRPycyTSnPhciCeDuXw7/4r4VeN7MniHoaNg9/fdKYAm9Oh+6+zNm9k/A54HNZnY/0EQw/8BygtstX09wU39FMGfC+8MRGn8i+KC6Mtz3vwY59nXg1bCd3fNcLCaYo+Fn/co+DrzPzH4DvEBwn36Du28YpP5PAk8DXzeziwm+Vt3zXHQBH3X3I3Gc60T4DbAd+EwY2F4k+PpeRvB1ihYKvgScCVwOVJjZw8ARgnO/GPg/HJ0vZC3B1+IrZrac8EqUu98Zq0ET9HMm091Ej4XVQ4+p9CBYM+O7BJ35DhNMrLSf4IrFx+g3j0F4zPsIfsEfIRjp8SpwI5AVpWwlUDnI+w+6Pywzj6CjYR3BEMjnCYZ4rmbweS4ygTsJJuRqA3YQdlCM8h5lBJM1HSS4lN9TLzHmuQj3zQXuJpiAq51ghMVDwOlRyn4krOcjMc4z5lwbUcp2t2mor13Ur1GUr+9/EHTSbAm/n58n+GMuapvCfX9LcGWpkeDDfxvBkNrj+pX9AMFkZS1hfd5r373EnsckIT9nDDHXhh56uHsw0YuISCwWrG66yt015bOIDIv6XIiIiEhCKVyIiIhIQilciIiISEKpz4WIiIgklK5ciIiISEIpXIiIiEhCKVyIiIhIQilciIiISEIpXIiIiEhCKVyIiIhIQv1/ViVJih2tIzkAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 576x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "p_vals = np.linspace(0.05, 1, 5)\n",
    "\n",
    "\n",
    "plt.figure(figsize=(8,6))\n",
    "plt.plot(p_vals[:-1], curr_result.mean(axis=1)[:-1]/comp_ratio[-1], '-', linewidth=3.0)\n",
    "plt.fill_between(p_vals[:-1], curr_result.mean(axis=1)[:-1]/comp_ratio[-1] + curr_result.std(axis=1)[:-1]/comp_ratio[-1], curr_result.mean(axis=1)[:-1]/comp_ratio[-1] - curr_result.std(axis=1)[:-1]/comp_ratio[-1], alpha=.2)\n",
    "plt.xticks(fontsize=20)\n",
    "plt.yticks(fontsize=20)\n",
    "plt.xlabel('Corruption Fraction', fontsize=20)\n",
    "plt.ylabel('Competitive Ratio', fontsize=20)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
