{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "243b356a",
   "metadata": {},
   "source": [
    "## Bernoulli Randomization Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5c0b4759",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading base arrival rates (b_d,t) from data0.csv...\n",
      "Base arrival rates loaded successfully.\n",
      "\n",
      "--- Running 500 Randomized Experiment Simulations ---\n",
      "Saving full simulation history for 500 runs to: outcomes/uniformized_simulation_experiment_output_multi_run.csv\n",
      "  Starting randomized experiment run 1 of 500...\n",
      "  Starting randomized experiment run 50 of 500...\n",
      "  Starting randomized experiment run 100 of 500...\n",
      "  Starting randomized experiment run 150 of 500...\n",
      "  Starting randomized experiment run 200 of 500...\n",
      "  Starting randomized experiment run 250 of 500...\n",
      "  Starting randomized experiment run 300 of 500...\n",
      "  Starting randomized experiment run 350 of 500...\n",
      "  Starting randomized experiment run 400 of 500...\n",
      "  Starting randomized experiment run 450 of 500...\n",
      "  Starting randomized experiment run 500 of 500...\n",
      "Randomized experiment histories successfully saved to outcomes/uniformized_simulation_experiment_output_multi_run.csv.\n",
      "Completed randomized experiment simulations.\n",
      "\n",
      "--- Calculating 'True' Average Treatment Effect using 500 runs per scenario ---\n",
      "  Simulating 500 runs for PRICE_TREATMENT (1.75)...\n",
      "    Treatment run 1 of 500...\n",
      "    Treatment run 50 of 500...\n",
      "    Treatment run 100 of 500...\n",
      "    Treatment run 150 of 500...\n",
      "    Treatment run 200 of 500...\n",
      "    Treatment run 250 of 500...\n",
      "    Treatment run 300 of 500...\n",
      "    Treatment run 350 of 500...\n",
      "    Treatment run 400 of 500...\n",
      "    Treatment run 450 of 500...\n",
      "    Treatment run 500 of 500...\n",
      "  Calculated True Mean Queue Length under Treatment (mu_1_true): 0.052422\n",
      "\n",
      "  Simulating 500 runs for PRICE_CONTROL (0.25)...\n",
      "    Control run 1 of 500...\n",
      "    Control run 50 of 500...\n",
      "    Control run 100 of 500...\n",
      "    Control run 150 of 500...\n",
      "    Control run 200 of 500...\n",
      "    Control run 250 of 500...\n",
      "    Control run 300 of 500...\n",
      "    Control run 350 of 500...\n",
      "    Control run 400 of 500...\n",
      "    Control run 450 of 500...\n",
      "    Control run 500 of 500...\n",
      "  Calculated True Mean Queue Length under Control (mu_0_true): 0.367258\n",
      "\n",
      "  'True' Average Treatment Effect (ATE = mu_1_true - mu_0_true): -0.314837\n",
      "Completed 'True' ATE calculation.\n"
     ]
    }
   ],
   "source": [
    "import csv\n",
    "import math\n",
    "import random\n",
    "import pandas as pd\n",
    "\n",
    "# --- Configuration Constants ---\n",
    "DEPARTURE_RATE_MU_BASE = 20\n",
    "\n",
    "# Prices for the Bernoulli experiment\n",
    "PRICE_CONTROL = 0.25        # p0\n",
    "PRICE_TREATMENT = 1.75      # p1\n",
    "PROB_Q_TREATMENT = 0.5     # Probability of choosing PRICE_TREATMENT\n",
    "\n",
    "A_FACTORS = {              \n",
    "    1: 0.9, 2: 1.0, 3: 1.1, 4: 1.2\n",
    "}\n",
    "SIMULATION_WEEKS = 4\n",
    "DAYS_PER_WEEK = 7\n",
    "HOURS_PER_DAY = 24\n",
    "TOTAL_SIM_HOURS = float(SIMULATION_WEEKS * DAYS_PER_WEEK * HOURS_PER_DAY)\n",
    "\n",
    "UNIF_TIME_STEP_MINUTES = 1\n",
    "DELTA_T_HOURS = UNIF_TIME_STEP_MINUTES / 60.0 \n",
    "R_UNIF = 1.0 / DELTA_T_HOURS\n",
    "\n",
    "# Number of simulation replications\n",
    "NUM_SIMULATION_RUNS = 500  # For the randomized experiment output file\n",
    "NUM_ORACLE_RUNS = 500      # For calculating \"true\" ATE\n",
    "\n",
    "# Random Seeds for reproducibility\n",
    "SEED_MAIN_EXPERIMENTS = 42    # Seed for the 500 randomized experiment runs\n",
    "SEED_ORACLE_CALCULATION = 123 # Seed for the 500+500 oracle runs for true ATE\n",
    "\n",
    "# --- Function to Load and Prepare Base Arrival Rates (b_d,t) ---\n",
    "def load_b_rates(filename=\"data0.csv\"):\n",
    "    try:\n",
    "        df = pd.read_csv(filename, header=None, encoding='utf-8-sig')\n",
    "    except Exception as e:\n",
    "        print(f\"Warning: CSV reading with 'utf-8-sig' failed ({e}). Trying default encoding.\")\n",
    "        df = pd.read_csv(filename, header=None)\n",
    "    df.columns = ['time_csv', 'rate_b', 'day_str', 'day_numeric']\n",
    "    b_rates_lookup = {}\n",
    "    for day_idx, group in df.groupby('day_numeric'):\n",
    "        b_rates_lookup[day_idx] = dict(zip(group['time_csv'].astype(float), group['rate_b']))\n",
    "    return b_rates_lookup\n",
    "\n",
    "# --- Helper Function to Get Current Base Arrival Rate b_d,t ---\n",
    "def get_base_arrival_rate_b_dt(b_rates_lookup, day_numeric_idx, time_within_day_current):\n",
    "    if time_within_day_current >= HOURS_PER_DAY:\n",
    "        time_within_day_current = 0.0 \n",
    "    time_slot_index = math.floor(time_within_day_current / 0.5)\n",
    "    time_csv_key = (time_slot_index * 0.5) + 0.5\n",
    "    time_csv_key = float(time_csv_key)\n",
    "    try:\n",
    "        return b_rates_lookup[day_numeric_idx][time_csv_key]\n",
    "    except KeyError:\n",
    "        day_keys = b_rates_lookup.get(day_numeric_idx, {})\n",
    "        max_key_for_day = max(day_keys.keys()) if day_keys else -1\n",
    "        if time_csv_key > max_key_for_day and abs(time_csv_key - (max_key_for_day + 0.5)) < 1e-9 :\n",
    "             return day_keys[max_key_for_day]\n",
    "        raise ValueError(\n",
    "            f\"Failed to lookup b_rate for day_idx={day_numeric_idx}, query_time_key={time_csv_key} \"\n",
    "            f\"(derived from time_within_day={time_within_day_current}). \"\n",
    "            f\"Available keys: {sorted(list(day_keys.keys())) if day_keys else 'None'}\"\n",
    "        )\n",
    "\n",
    "# --- Simulation function for randomized experiment ---\n",
    "def simulate_uniformized_queue_experiment(base_b_rates, initial_queue_length=0):\n",
    "    current_k = initial_queue_length\n",
    "    simulation_log = [] \n",
    "    num_steps = int(round(TOTAL_SIM_HOURS / DELTA_T_HOURS))\n",
    "\n",
    "    for step_idx in range(num_steps):\n",
    "        current_T_start_of_step = step_idx * DELTA_T_HOURS\n",
    "        abs_day_number = math.floor(current_T_start_of_step / HOURS_PER_DAY)\n",
    "        time_within_day = current_T_start_of_step % HOURS_PER_DAY\n",
    "        current_week_num = math.floor(abs_day_number / DAYS_PER_WEEK) + 1\n",
    "        day_of_week_idx = abs_day_number % DAYS_PER_WEEK\n",
    "        \n",
    "        a_w = A_FACTORS[min(current_week_num, max(A_FACTORS.keys()))]\n",
    "        b_dt_rate = get_base_arrival_rate_b_dt(base_b_rates, day_of_week_idx, time_within_day)\n",
    "\n",
    "        Z_t = 0 \n",
    "        chosen_price = PRICE_CONTROL\n",
    "        if random.random() < PROB_Q_TREATMENT:\n",
    "            chosen_price = PRICE_TREATMENT\n",
    "            Z_t = 1\n",
    "\n",
    "        price_effect_term = 2.0 - chosen_price\n",
    "        if price_effect_term < 0: price_effect_term = 0 \n",
    "        arrival_rate_lambda_k = (4.0 * price_effect_term / (1.0 + 0.2 * current_k)) * a_w * b_dt_rate\n",
    "\n",
    "        if arrival_rate_lambda_k < 0: arrival_rate_lambda_k = 0.0\n",
    "        departure_rate_mu_k = DEPARTURE_RATE_MU_BASE if current_k > 0 else 0.0\n",
    "        \n",
    "        total_natural_rate = arrival_rate_lambda_k + departure_rate_mu_k\n",
    "        prob_arrival, prob_departure, prob_self_loop = 0.0, 0.0, 1.0\n",
    "\n",
    "        if total_natural_rate > 0:\n",
    "            if total_natural_rate > R_UNIF:\n",
    "                prob_arrival = arrival_rate_lambda_k / total_natural_rate\n",
    "                prob_departure = departure_rate_mu_k / total_natural_rate\n",
    "                prob_self_loop = 0.0\n",
    "            else:\n",
    "                prob_arrival = arrival_rate_lambda_k / R_UNIF\n",
    "                prob_departure = departure_rate_mu_k / R_UNIF\n",
    "                prob_self_loop = 1.0 - prob_arrival - prob_departure\n",
    "        if prob_self_loop < 0: prob_self_loop = 0.0\n",
    "\n",
    "        rand_draw = random.random()\n",
    "        if rand_draw < prob_arrival: current_k += 1\n",
    "        elif rand_draw < prob_arrival + prob_departure:\n",
    "            if current_k > 0: current_k -= 1\n",
    "        \n",
    "        time_at_end_of_step = (step_idx + 1) * DELTA_T_HOURS\n",
    "        simulation_log.append((time_at_end_of_step, Z_t, current_k))\n",
    "        \n",
    "    return simulation_log\n",
    "\n",
    "# --- New simulation function for fixed price scenarios (for \"True\" ATE) ---\n",
    "def simulate_fixed_price_run_and_get_sum_Y_and_steps(base_b_rates, initial_queue_length, fixed_price_to_use):\n",
    "    current_k = initial_queue_length\n",
    "    sum_Y_t_for_run = 0\n",
    "    num_steps_in_run = int(round(TOTAL_SIM_HOURS / DELTA_T_HOURS))\n",
    "\n",
    "    for step_idx in range(num_steps_in_run):\n",
    "        current_T_start_of_step = step_idx * DELTA_T_HOURS\n",
    "        abs_day_number = math.floor(current_T_start_of_step / HOURS_PER_DAY)\n",
    "        time_within_day = current_T_start_of_step % HOURS_PER_DAY\n",
    "        current_week_num = math.floor(abs_day_number / DAYS_PER_WEEK) + 1\n",
    "        day_of_week_idx = abs_day_number % DAYS_PER_WEEK\n",
    "        \n",
    "        a_w = A_FACTORS[min(current_week_num, max(A_FACTORS.keys()))]\n",
    "        b_dt_rate = get_base_arrival_rate_b_dt(base_b_rates, day_of_week_idx, time_within_day)\n",
    "\n",
    "        chosen_price = fixed_price_to_use # Price is fixed\n",
    "\n",
    "        price_effect_term = 2.0 - chosen_price\n",
    "        if price_effect_term < 0: price_effect_term = 0 \n",
    "        arrival_rate_lambda_k = (4.0 * price_effect_term / (1.0 + current_k)) * a_w * b_dt_rate\n",
    "        if arrival_rate_lambda_k < 0: arrival_rate_lambda_k = 0.0\n",
    "        departure_rate_mu_k = DEPARTURE_RATE_MU_BASE if current_k > 0 else 0.0\n",
    "        \n",
    "        total_natural_rate = arrival_rate_lambda_k + departure_rate_mu_k\n",
    "        prob_arrival, prob_departure, prob_self_loop = 0.0, 0.0, 1.0\n",
    "\n",
    "        if total_natural_rate > 0:\n",
    "            if total_natural_rate > R_UNIF:\n",
    "                prob_arrival = arrival_rate_lambda_k / total_natural_rate\n",
    "                prob_departure = departure_rate_mu_k / total_natural_rate\n",
    "                prob_self_loop = 0.0\n",
    "            else:\n",
    "                prob_arrival = arrival_rate_lambda_k / R_UNIF\n",
    "                prob_departure = departure_rate_mu_k / R_UNIF\n",
    "                prob_self_loop = 1.0 - prob_arrival - prob_departure\n",
    "        if prob_self_loop < 0: prob_self_loop = 0.0\n",
    "        \n",
    "        rand_draw = random.random()\n",
    "        if rand_draw < prob_arrival: current_k += 1\n",
    "        elif rand_draw < prob_arrival + prob_departure:\n",
    "            if current_k > 0: current_k -= 1\n",
    "        \n",
    "        sum_Y_t_for_run += current_k\n",
    "        \n",
    "    return sum_Y_t_for_run, num_steps_in_run\n",
    "\n",
    "# # --- Main Execution Block ---\n",
    "print(\"Loading base arrival rates (b_d,t) from data0.csv...\")\n",
    "base_b_rates_data = load_b_rates(\"data0.csv\")\n",
    "print(\"Base arrival rates loaded successfully.\")\n",
    "\n",
    "# --- Part 1: Run multiple copies of the randomized experiment and save history ---\n",
    "print(f\"\\n--- Running {NUM_SIMULATION_RUNS} Randomized Experiment Simulations ---\")\n",
    "random.seed(SEED_MAIN_EXPERIMENTS) # Seed for this block of experiments\n",
    "\n",
    "output_csv_filename = \"outcomes/uniformized_simulation_experiment_output_multi_run.csv\"\n",
    "print(f\"Saving full simulation history for {NUM_SIMULATION_RUNS} runs to: {output_csv_filename}\")\n",
    "\n",
    "try:\n",
    "    with open(output_csv_filename, 'w', newline='') as csvfile:\n",
    "        csv_writer = csv.writer(csvfile)\n",
    "        csv_writer.writerow([\"RunID\", \"TimeAtEndOfStep_Hours\", \"TreatmentIndicator_Zt\", \"QueueLength_Yt\"])\n",
    "        \n",
    "        for run_id in range(NUM_SIMULATION_RUNS):\n",
    "            if (run_id + 1) % 50 == 0 or run_id == 0: # Print progress\n",
    "                print(f\"  Starting randomized experiment run {run_id + 1} of {NUM_SIMULATION_RUNS}...\")\n",
    "            \n",
    "            # Each run uses a subsequent part of the random number stream\n",
    "            single_run_history = simulate_uniformized_queue_experiment(\n",
    "                base_b_rates_data, \n",
    "                initial_queue_length=0\n",
    "            )\n",
    "            for time_val, Z_val, Y_val in single_run_history:\n",
    "                csv_writer.writerow([run_id, f\"{time_val:.6f}\", Z_val, Y_val])\n",
    "    print(f\"Randomized experiment histories successfully saved to {output_csv_filename}.\")\n",
    "except IOError:\n",
    "    print(f\"Error: Could not write simulation history to {output_csv_filename}.\")\n",
    "\n",
    "print(\"Completed randomized experiment simulations.\")\n",
    "\n",
    "# --- Part 2: Calculate \"True\" Average Treatment Effect (ATE) ---\n",
    "print(f\"\\n--- Calculating 'True' Average Treatment Effect using {NUM_ORACLE_RUNS} runs per scenario ---\")\n",
    "random.seed(SEED_ORACLE_CALCULATION) # Use a different seed for this oracle block\n",
    "\n",
    "# Calculate True Mean under Treatment (mu_1_true)\n",
    "grand_total_Y_treatment = 0\n",
    "grand_total_steps_treatment = 0\n",
    "print(f\"  Simulating {NUM_ORACLE_RUNS} runs for PRICE_TREATMENT ({PRICE_TREATMENT})...\")\n",
    "for i in range(NUM_ORACLE_RUNS):\n",
    "    if (i + 1) % 50 == 0 or i == 0: # Print progress\n",
    "        print(f\"    Treatment run {i + 1} of {NUM_ORACLE_RUNS}...\")\n",
    "    sum_y, num_s = simulate_fixed_price_run_and_get_sum_Y_and_steps(\n",
    "        base_b_rates_data, \n",
    "        initial_queue_length=0, \n",
    "        fixed_price_to_use=PRICE_TREATMENT\n",
    "    )\n",
    "    grand_total_Y_treatment += sum_y\n",
    "    grand_total_steps_treatment += num_s\n",
    "\n",
    "mu1_true = (grand_total_Y_treatment / grand_total_steps_treatment) if grand_total_steps_treatment > 0 else float('nan')\n",
    "print(f\"  Calculated True Mean Queue Length under Treatment (mu_1_true): {mu1_true:.6f}\")\n",
    "\n",
    "# Calculate True Mean under Control (mu_0_true)\n",
    "grand_total_Y_control = 0\n",
    "grand_total_steps_control = 0\n",
    "print(f\"\\n  Simulating {NUM_ORACLE_RUNS} runs for PRICE_CONTROL ({PRICE_CONTROL})...\")\n",
    "for i in range(NUM_ORACLE_RUNS):\n",
    "    if (i + 1) % 50 == 0 or i == 0: # Print progress\n",
    "        print(f\"    Control run {i + 1} of {NUM_ORACLE_RUNS}...\")\n",
    "    sum_y, num_s = simulate_fixed_price_run_and_get_sum_Y_and_steps(\n",
    "        base_b_rates_data, \n",
    "        initial_queue_length=0, \n",
    "        fixed_price_to_use=PRICE_CONTROL\n",
    "    )\n",
    "    grand_total_Y_control += sum_y\n",
    "    grand_total_steps_control += num_s\n",
    "\n",
    "mu0_true = (grand_total_Y_control / grand_total_steps_control) if grand_total_steps_control > 0 else float('nan')\n",
    "print(f\"  Calculated True Mean Queue Length under Control (mu_0_true): {mu0_true:.6f}\")\n",
    "\n",
    "# Calculate \"True\" ATE\n",
    "true_ATE = mu1_true - mu0_true\n",
    "print(f\"\\n  'True' Average Treatment Effect (ATE = mu_1_true - mu_0_true): {true_ATE:.6f}\")\n",
    "print(\"Completed 'True' ATE calculation.\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f1b0b6bd",
   "metadata": {},
   "source": [
    "## Bernoulli Switchback Experiments"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "317d1ebf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading base arrival rates...\n",
      "Base arrival rates loaded.\n",
      "Running 500 switchback simulations...\n",
      "  Run 1/500\n",
      "  Run 51/500\n",
      "  Run 101/500\n",
      "  Run 151/500\n",
      "  Run 201/500\n",
      "  Run 251/500\n",
      "  Run 301/500\n",
      "  Run 351/500\n",
      "  Run 401/500\n",
      "  Run 451/500\n",
      "Switchback outcomes saved to outcomes/switchback_simulation_experiment_output_multi_run.csv.\n"
     ]
    }
   ],
   "source": [
    "import csv\n",
    "import math\n",
    "import random\n",
    "import pandas as pd\n",
    "\n",
    "# --- Configuration Constants ---\n",
    "DEPARTURE_RATE_MU_BASE = 20\n",
    "\n",
    "# Prices for the Bernoulli experiment\n",
    "PRICE_CONTROL = 0.25        # p0\n",
    "PRICE_TREATMENT = 1.75      # p1\n",
    "PROB_Q_TREATMENT = 0.5     # Probability of choosing PRICE_TREATMENT\n",
    "\n",
    "A_FACTORS = {1: 0.9, 2: 1.0, 3: 1.1, 4: 1.2}\n",
    "SIMULATION_WEEKS = 4\n",
    "DAYS_PER_WEEK = 7\n",
    "HOURS_PER_DAY = 24\n",
    "TOTAL_SIM_HOURS = SIMULATION_WEEKS * DAYS_PER_WEEK * HOURS_PER_DAY\n",
    "\n",
    "UNIF_TIME_STEP_MINUTES = 1\n",
    "DELTA_T_HOURS = UNIF_TIME_STEP_MINUTES / 60.0\n",
    "R_UNIF = 1.0 / DELTA_T_HOURS\n",
    "\n",
    "NUM_SIMULATION_RUNS = 500\n",
    "SEED_MAIN_EXPERIMENTS = 42\n",
    "SWITCHBACK_INTERVAL_MINUTES = 60\n",
    "\n",
    "# --- Load base arrival rate ---\n",
    "def load_b_rates(filename=\"data0.csv\"):\n",
    "    df = pd.read_csv(filename, header=None)\n",
    "    df.columns = ['time_csv', 'rate_b', 'day_str', 'day_numeric']\n",
    "    b_rates_lookup = {}\n",
    "    for day_idx, group in df.groupby('day_numeric'):\n",
    "        b_rates_lookup[day_idx] = dict(zip(group['time_csv'].astype(float), group['rate_b']))\n",
    "    return b_rates_lookup\n",
    "\n",
    "# --- Get b_d,t ---\n",
    "def get_base_arrival_rate_b_dt(b_rates_lookup, day_numeric_idx, time_within_day_current):\n",
    "    if time_within_day_current >= HOURS_PER_DAY:\n",
    "        time_within_day_current = 0.0\n",
    "    time_slot_index = math.floor(time_within_day_current / 0.5)\n",
    "    time_csv_key = (time_slot_index * 0.5) + 0.5\n",
    "    return b_rates_lookup[day_numeric_idx].get(time_csv_key, 0.0)\n",
    "\n",
    "# --- Generate switchback treatment assignment ---\n",
    "def generate_switchback_schedule(num_steps, steps_per_interval, seed):\n",
    "    random.seed(seed)\n",
    "    schedule = []\n",
    "    current = random.choice([0, 1])\n",
    "    for i in range(0, num_steps, steps_per_interval):\n",
    "        if random.random() < 0.5:\n",
    "            current = 1 - current\n",
    "        schedule.extend([current] * min(steps_per_interval, num_steps - len(schedule)))\n",
    "    return schedule\n",
    "\n",
    "# --- Simulate queue ---\n",
    "def simulate_queue(base_b_rates, Z_schedule, initial_k=0):\n",
    "    log = []\n",
    "    k = initial_k\n",
    "    for step_idx, Z_t in enumerate(Z_schedule):\n",
    "        time_hr = step_idx * DELTA_T_HOURS\n",
    "        abs_day = math.floor(time_hr / HOURS_PER_DAY)\n",
    "        time_in_day = time_hr % HOURS_PER_DAY\n",
    "        week_num = math.floor(abs_day / DAYS_PER_WEEK) + 1\n",
    "        day_idx = abs_day % DAYS_PER_WEEK\n",
    "\n",
    "        a_w = A_FACTORS[min(week_num, max(A_FACTORS.keys()))]\n",
    "        b_dt = get_base_arrival_rate_b_dt(base_b_rates, day_idx, time_in_day)\n",
    "        price = PRICE_TREATMENT if Z_t == 1 else PRICE_CONTROL\n",
    "        price_effect = max(0, 2.0 - price)\n",
    "        lambda_k = (4.0 * price_effect / (1.0 + 0.2 * k)) * a_w * b_dt\n",
    "        mu_k = DEPARTURE_RATE_MU_BASE if k > 0 else 0.0\n",
    "\n",
    "        total_rate = lambda_k + mu_k\n",
    "        if total_rate > R_UNIF:\n",
    "            p_arr = lambda_k / total_rate\n",
    "            p_dep = mu_k / total_rate\n",
    "            p_self = 0.0\n",
    "        else:\n",
    "            p_arr = lambda_k / R_UNIF\n",
    "            p_dep = mu_k / R_UNIF\n",
    "            p_self = max(0.0, 1.0 - p_arr - p_dep)\n",
    "\n",
    "        r = random.random()\n",
    "        if r < p_arr:\n",
    "            k += 1\n",
    "        elif r < p_arr + p_dep:\n",
    "            k = max(0, k - 1)\n",
    "\n",
    "        log.append((time_hr + DELTA_T_HOURS, Z_t, k))\n",
    "    return log\n",
    "\n",
    "# --- Main ---\n",
    "if __name__ == \"__main__\":\n",
    "    print(\"Loading base arrival rates...\")\n",
    "    base_b = load_b_rates(\"data0.csv\")\n",
    "    print(\"Base arrival rates loaded.\")\n",
    "\n",
    "    num_steps = int(TOTAL_SIM_HOURS / DELTA_T_HOURS)\n",
    "    interval_steps = int(SWITCHBACK_INTERVAL_MINUTES / UNIF_TIME_STEP_MINUTES)\n",
    "    output_file = \"outcomes/switchback_simulation_experiment_output_multi_run.csv\"\n",
    "\n",
    "    print(f\"Running {NUM_SIMULATION_RUNS} switchback simulations...\")\n",
    "    with open(output_file, 'w', newline='') as csvfile:\n",
    "        writer = csv.writer(csvfile)\n",
    "        writer.writerow([\"RunID\", \"TimeAtEndOfStep_Hours\", \"TreatmentIndicator_Zt\", \"QueueLength_Yt\"])\n",
    "\n",
    "        for run_id in range(NUM_SIMULATION_RUNS):\n",
    "            if run_id % 50 == 0:\n",
    "                print(f\"  Run {run_id+1}/{NUM_SIMULATION_RUNS}\")\n",
    "            Z_sched = generate_switchback_schedule(num_steps, interval_steps, seed=SEED_MAIN_EXPERIMENTS + run_id)\n",
    "            hist = simulate_queue(base_b, Z_sched)\n",
    "            for t, z, y in hist:\n",
    "                writer.writerow([run_id, f\"{t:.6f}\", z, y])\n",
    "\n",
    "    print(f\"Switchback outcomes saved to {output_file}.\")\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "51e140dc",
   "metadata": {},
   "source": [
    "## Estimation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b1d25ebc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loading HT data from: outcomes/uniformized_simulation_experiment_output_multi_run.csv\n",
      "Loading DM data from: outcomes/switchback_simulation_experiment_output_multi_run.csv\n",
      "[ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20]\n",
      "\n",
      "Estimating ATEs for 500 runs...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 500/500 [05:35<00:00,  1.49it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "--- Truncated DQ ATE Statistics ---\n",
      "k=0  | Mean: -0.099795 | Std: 0.006031 | Count: 500\n",
      "k=1  | Mean: -0.172045 | Std: 0.011460 | Count: 500\n",
      "k=2  | Mean: -0.226169 | Std: 0.016696 | Count: 500\n",
      "k=3  | Mean: -0.268031 | Std: 0.021853 | Count: 500\n",
      "k=4  | Mean: -0.300871 | Std: 0.026967 | Count: 500\n",
      "k=5  | Mean: -0.327208 | Std: 0.032111 | Count: 500\n",
      "k=6  | Mean: -0.348246 | Std: 0.037244 | Count: 500\n",
      "k=7  | Mean: -0.365316 | Std: 0.041936 | Count: 500\n",
      "k=8  | Mean: -0.379162 | Std: 0.046818 | Count: 500\n",
      "k=9  | Mean: -0.390488 | Std: 0.051277 | Count: 500\n",
      "k=10 | Mean: -0.399963 | Std: 0.055787 | Count: 500\n",
      "k=11 | Mean: -0.407749 | Std: 0.059944 | Count: 500\n",
      "k=12 | Mean: -0.414133 | Std: 0.064067 | Count: 500\n",
      "k=13 | Mean: -0.419369 | Std: 0.068170 | Count: 500\n",
      "k=14 | Mean: -0.423866 | Std: 0.072082 | Count: 500\n",
      "k=15 | Mean: -0.427651 | Std: 0.075827 | Count: 500\n",
      "k=16 | Mean: -0.431044 | Std: 0.079476 | Count: 500\n",
      "k=17 | Mean: -0.433834 | Std: 0.083102 | Count: 500\n",
      "k=18 | Mean: -0.436057 | Std: 0.086588 | Count: 500\n",
      "k=19 | Mean: -0.438042 | Std: 0.090112 | Count: 500\n",
      "k=20 | Mean: -0.439581 | Std: 0.093499 | Count: 500\n",
      "\n",
      "--- Switchback DM ATE Statistics ---\n",
      "Mean: -0.416835 | Std: 0.036178 | Count: 500\n",
      "\n",
      "--- Bias-Corrected Switchback ATE Statistics ---\n",
      "Burn-in 0 min | Mean: -0.418087 | Std: 0.025537 | Count: 500\n",
      "Burn-in 10 min | Mean: -0.403891 | Std: 0.027438 | Count: 500\n",
      "Burn-in 20 min | Mean: -0.333846 | Std: 0.030101 | Count: 500\n",
      "Burn-in 30 min | Mean: -0.261070 | Std: 0.033725 | Count: 500\n",
      "\n",
      "--- DQ ATE Statistics ---\n",
      "Mean: 0.000138 | Std: 0.021903 | Count: 500\n",
      "\n",
      "--- OPE ATE Statistics ---\n",
      "Mean: -2.392503 | Std: 0.445627 | Count: 500\n",
      "\n",
      "--- Truncated DQ: HAC vs Monte Carlo variance ---\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm\n",
    "from sklearn.linear_model import Ridge\n",
    "from typing import Optional\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import colorsys\n",
    "from collections import defaultdict\n",
    "\n",
    "sns.set()\n",
    "\n",
    "# --- Configuration ---\n",
    "CSV_INPUT_FILENAME_HT = \"outcomes/uniformized_simulation_experiment_output_multi_run.csv\"\n",
    "CSV_INPUT_FILENAME_DM = \"outcomes/switchback_simulation_experiment_output_multi_run.csv\"\n",
    "SWITCHBACK_INTERVAL_MINUTES = 60\n",
    "\n",
    "\n",
    "# --- HAC helpers for truncated DQ ---------------------------------------------\n",
    "\n",
    "def _truncated_dq_contributions_from_arrays(Y: np.ndarray, Z: np.ndarray, q: float, k: int):\n",
    "    \"\"\"\n",
    "    V_t = ((Z_t - q) / (q*(1-q))) * sum_{h=0}^k Y_{t+h}\n",
    "    Returns (V, tau_hat) with tau_hat = mean(V).\n",
    "    \"\"\"\n",
    "    T = len(Y)\n",
    "    if T == 0 or not (0 < q < 1):\n",
    "        return None, None\n",
    "    coeff = 1.0 / (q * (1.0 - q))\n",
    "    Ypad = np.concatenate([Y.astype(float), np.zeros(k, dtype=float)])\n",
    "    future_sum = np.convolve(Ypad, np.ones(k + 1, dtype=float), mode=\"valid\")  # length T\n",
    "    V = (Z.astype(float) - q) * coeff * future_sum[:T]\n",
    "    return V, V.mean()\n",
    "\n",
    "def _newey_west_hac(V: np.ndarray, L: Optional[int] = None, center: bool = True) -> float:\n",
    "    \"\"\"\n",
    "    Newey–West (Bartlett) HAC long-run variance:\n",
    "      Omega_hat = Gamma_hat(0) + 2 * sum_{ell=1}^L w_ell * Gamma_hat(ell),\n",
    "    with w_ell = 1 - ell/(L+1). Returns the long-run variance (not divided by T).\n",
    "    The asymptotic variance of the sample mean is Omega_hat / T.\n",
    "    \"\"\"\n",
    "    V = np.asarray(V, dtype=float)\n",
    "    T = V.shape[0]\n",
    "    if T == 0:\n",
    "        return np.nan\n",
    "    if L is None:\n",
    "        L = int(np.floor(T ** (1.0 / 3.0)))\n",
    "        L = max(L, 1)\n",
    "    e = V - V.mean() if center else V.copy()\n",
    "    gamma0 = (e @ e) / T\n",
    "    Omega = gamma0\n",
    "    for ell in range(1, L + 1):\n",
    "        cov = (e[: T - ell] @ e[ell:]) / T\n",
    "        w = 1.0 - ell / (L + 1.0)  # Bartlett\n",
    "        Omega += 2.0 * w * cov\n",
    "    return float(Omega)\n",
    "\n",
    "\n",
    "# --- Estimators ---\n",
    "def calculate_truncated_dq_estimator(simulation_history, q, k):\n",
    "    if not simulation_history or not (0 < q < 1):\n",
    "        return None, None, None\n",
    "    N = len(simulation_history)\n",
    "    Y = [y for _, _, y in simulation_history]\n",
    "    Z = [z for _, z, _ in simulation_history]\n",
    "    one_minus_q = 1.0 - q\n",
    "    s1 = sum((Z[t] * sum(Y[t:min(t + k + 1, N)]) / q) for t in range(N))\n",
    "    s0 = sum(((1 - Z[t]) * sum(Y[t:min(t + k + 1, N)]) / one_minus_q) for t in range(N))\n",
    "    return s1 / N, s0 / N, (s1 - s0) / N\n",
    "\n",
    "def calculate_switchback_dm_estimator(df, interval_minutes=SWITCHBACK_INTERVAL_MINUTES):\n",
    "    df = df.copy()\n",
    "    df['TimeAtEndOfStep_Hours'] = pd.to_datetime(df['TimeAtEndOfStep_Hours'] * 3600, unit='s')\n",
    "    df = df.sort_values('TimeAtEndOfStep_Hours')\n",
    "    df['block'] = (df['TimeAtEndOfStep_Hours'].astype(np.int64) // (interval_minutes * 60 * 1e9)).astype(int)\n",
    "    treated = df[df['TreatmentIndicator_Zt'] == 1].groupby('block')['QueueLength_Yt'].mean()\n",
    "    control = df[df['TreatmentIndicator_Zt'] == 0].groupby('block')['QueueLength_Yt'].mean()\n",
    "    common_blocks = treated.index.intersection(control.index)\n",
    "    block_diffs = treated.loc[common_blocks] - control.loc[common_blocks]\n",
    "    return block_diffs.mean()\n",
    "\n",
    "def compute_bias_corrected_switchback_ate(df, burn_in_minutes=5, block_minutes=60):\n",
    "    df = df.copy()\n",
    "    df['ts'] = pd.to_datetime(df['TimeAtEndOfStep_Hours'] * 3600, unit='s')\n",
    "    block_duration = pd.Timedelta(minutes=block_minutes)\n",
    "    df['block_start'] = df['ts'].dt.floor(f'{block_minutes}min')\n",
    "    df['block'] = df['block_start'].rank(method='dense').astype(int) - 1\n",
    "    df['block_time'] = df['ts'] - df['block_start']\n",
    "    df['in_focal'] = df['block_time'] > pd.Timedelta(minutes=burn_in_minutes)\n",
    "    focal = df[df['in_focal']]\n",
    "    mu1 = focal[focal['TreatmentIndicator_Zt'] == 1]['QueueLength_Yt'].mean()\n",
    "    mu0 = focal[focal['TreatmentIndicator_Zt'] == 0]['QueueLength_Yt'].mean()\n",
    "    tau_dm = mu1 - mu0\n",
    "    block_treat = df.groupby('block').first()['TreatmentIndicator_Zt'].astype(int)\n",
    "    block_treat_prev = block_treat.shift()\n",
    "    k11_blocks = block_treat[(block_treat == 1) & (block_treat_prev == 1)].index\n",
    "    k00_blocks = block_treat[(block_treat == 0) & (block_treat_prev == 0)].index\n",
    "\n",
    "    def burnin_avg(block_ids):\n",
    "        if len(block_ids) == 0:\n",
    "            return 0.0\n",
    "        burnin_rows = df[(df['block'].isin(block_ids)) & (df['block_time'] <= pd.Timedelta(minutes=burn_in_minutes))]\n",
    "        block_sizes = df[df['block'].isin(block_ids)].groupby('block').size()\n",
    "        burnin_sums = burnin_rows.groupby('block')['QueueLength_Yt'].sum()\n",
    "        correction_terms = burnin_sums / block_sizes\n",
    "        return correction_terms.mean()\n",
    "\n",
    "    correction_11 = burnin_avg(k11_blocks)\n",
    "    correction_00 = burnin_avg(k00_blocks)\n",
    "    block_counts = df.groupby('block').size()\n",
    "    burnin_counts = df[df['block_time'] <= pd.Timedelta(minutes=burn_in_minutes)].groupby('block').size()\n",
    "    avg_block_size = block_counts.mean()\n",
    "    avg_burnin_size = burnin_counts.reindex(block_counts.index, fill_value=0).mean()\n",
    "    tau_bc = ((avg_block_size - avg_burnin_size) / avg_block_size) * tau_dm\n",
    "    if len(k11_blocks) > 0 and np.isfinite(correction_11):\n",
    "        tau_bc += correction_11\n",
    "    if len(k00_blocks) > 0 and np.isfinite(correction_00):\n",
    "        tau_bc -= correction_00\n",
    "    return tau_bc\n",
    "\n",
    "# --- Load Data ---\n",
    "print(f\"Loading HT data from: {CSV_INPUT_FILENAME_HT}\")\n",
    "df_ht = pd.read_csv(CSV_INPUT_FILENAME_HT)\n",
    "print(f\"Loading DM data from: {CSV_INPUT_FILENAME_DM}\")\n",
    "df_dm = pd.read_csv(CSV_INPUT_FILENAME_DM)\n",
    "\n",
    "unique_run_ids = sorted(df_ht['RunID'].unique())\n",
    "# k_values = [0, 1, 2, 3, 4, 5, 10, 20]\n",
    "k_values = np.arange(0, 21, 1)\n",
    "print(k_values)\n",
    "burnin_minutes_list = [0, 10, 20, 30]\n",
    "\n",
    "ate_estimates_by_k = {k: [] for k in k_values}\n",
    "dm_estimates = []\n",
    "bc_estimates_by_burnin = {b: [] for b in burnin_minutes_list}\n",
    "dq_estimates = []\n",
    "ope_estimates = []\n",
    "\n",
    "# --- Collectors for HAC on truncated DQ (across runs) -------------------------\n",
    "dq_hac_long_run_by_k = {k: [] for k in k_values}   # list of Omega_hat per run\n",
    "dq_tau_by_k_for_hac  = {k: [] for k in k_values}   # list of tau_hat per run (same V as HAC)\n",
    "dq_T_per_run = []                                   # T per run (for MC scaling)\n",
    "\n",
    "\n",
    "print(f\"\\nEstimating ATEs for {len(unique_run_ids)} runs...\")\n",
    "for run_id in tqdm(unique_run_ids):\n",
    "    df_run_ht = df_ht[df_ht['RunID'] == run_id].copy()\n",
    "    df_run_ht['lag_Y'] = df_run_ht['QueueLength_Yt'].shift().fillna(0.0)\n",
    "    history = list(zip(df_run_ht['TimeAtEndOfStep_Hours'], df_run_ht['TreatmentIndicator_Zt'], df_run_ht['QueueLength_Yt']))\n",
    "\n",
    "    # --- Arrays for HAC on this run ----------------------------------------------\n",
    "    Y_series = df_run_ht['QueueLength_Yt'].to_numpy()\n",
    "    Z_series = df_run_ht['TreatmentIndicator_Zt'].to_numpy().astype(float)\n",
    "    T_run = len(Y_series)\n",
    "    dq_T_per_run.append(T_run)\n",
    "\n",
    "    # Choose q for this run: prefer global PROB_Q_TREATMENT if defined & valid; otherwise infer from Z\n",
    "    try:\n",
    "        q_global = float(PROB_Q_TREATMENT)\n",
    "        q_run = q_global if (0.0 < q_global < 1.0) else float(np.mean(Z_series))\n",
    "    except NameError:\n",
    "        q_run = float(np.mean(Z_series))\n",
    "\n",
    "    # Compute HAC long-run variance and paired tau_hat for all k on this run\n",
    "    for k in k_values:\n",
    "        V_k, tau_hat_k = _truncated_dq_contributions_from_arrays(Y_series, Z_series, q_run, k)\n",
    "        if V_k is None:\n",
    "            continue\n",
    "        Omega_hat_k = _newey_west_hac(V_k, L=None, center=True)  # long-run variance (sigma_k^2)\n",
    "        dq_hac_long_run_by_k[k].append(Omega_hat_k)\n",
    "        dq_tau_by_k_for_hac[k].append(float(tau_hat_k))\n",
    "\n",
    "\n",
    "    # Use only lagged queue length as state\n",
    "    ss = df_run_ht[['lag_Y']].values[:-1]\n",
    "    snews = df_run_ht[['lag_Y']].values[1:]\n",
    "    rs = df_run_ht['QueueLength_Yt'].values[:-1]\n",
    "    Z = df_run_ht['TreatmentIndicator_Zt'].values[:-1]\n",
    "\n",
    "    # DQ Estimator (value-difference via LSTD)\n",
    "    A = ss.T @ (ss - snews)\n",
    "    b = ss.T @ (rs - np.mean(rs))\n",
    "    theta_dq = np.linalg.solve(A + 1e-3 * np.eye(A.shape[0]), b)\n",
    "    xbar1 = df_run_ht[df_run_ht['TreatmentIndicator_Zt'] == 1]['lag_Y'].mean()\n",
    "    xbar0 = df_run_ht[df_run_ht['TreatmentIndicator_Zt'] == 0]['lag_Y'].mean()\n",
    "    dq_estimates.append(theta_dq @ (xbar1 - xbar0).reshape(1,))\n",
    "\n",
    "    # OPE Estimator (off-policy value difference)\n",
    "    ss1 = ss[Z == 1]\n",
    "    snews1 = snews[Z == 1]\n",
    "    rs1 = rs[Z == 1]\n",
    "\n",
    "    ss0 = ss[Z == 0]\n",
    "    snews0 = snews[Z == 0]\n",
    "    rs0 = rs[Z == 0]\n",
    "\n",
    "    A1 = ss1.T @ (ss1 - snews1)\n",
    "    b1 = ss1.T @ rs1\n",
    "    eta1 = np.linalg.solve(A1 + 1e-3 * np.eye(A1.shape[0]), b1)[0]\n",
    "\n",
    "    A0 = ss0.T @ (ss0 - snews0)\n",
    "    b0 = ss0.T @ rs0\n",
    "    eta0 = np.linalg.solve(A0 + 1e-3 * np.eye(A0.shape[0]), b0)[0]\n",
    "\n",
    "    ope_estimates.append(eta1 - eta0)\n",
    "\n",
    "    for k in k_values:\n",
    "        _, _, ate_k = calculate_truncated_dq_estimator(history, PROB_Q_TREATMENT, k)\n",
    "        if ate_k is not None:\n",
    "            ate_estimates_by_k[k].append(ate_k)\n",
    "\n",
    "    df_run_dm = df_dm[df_dm['RunID'] == run_id]\n",
    "    ate_dm = calculate_switchback_dm_estimator(df_run_dm)\n",
    "    dm_estimates.append(ate_dm)\n",
    "\n",
    "    for b in burnin_minutes_list:\n",
    "        bc_est = compute_bias_corrected_switchback_ate(df_run_dm, burn_in_minutes=b)\n",
    "        bc_estimates_by_burnin[b].append(bc_est)\n",
    "\n",
    "# --- Summary ---\n",
    "print(\"\\n--- Truncated DQ ATE Statistics ---\")\n",
    "for k in k_values:\n",
    "    arr = np.array(ate_estimates_by_k[k])\n",
    "    print(f\"k={k:<2} | Mean: {arr.mean():.6f} | Std: {arr.std():.6f} | Count: {len(arr)}\")\n",
    "\n",
    "print(\"\\n--- Switchback DM ATE Statistics ---\")\n",
    "dm_arr = np.array(dm_estimates)\n",
    "print(f\"Mean: {dm_arr.mean():.6f} | Std: {dm_arr.std():.6f} | Count: {len(dm_arr)}\")\n",
    "\n",
    "print(\"\\n--- Bias-Corrected Switchback ATE Statistics ---\")\n",
    "for b in burnin_minutes_list:\n",
    "    bc_arr = np.array(bc_estimates_by_burnin[b])\n",
    "    print(f\"Burn-in {b} min | Mean: {bc_arr.mean():.6f} | Std: {bc_arr.std():.6f} | Count: {len(bc_arr)}\")\n",
    "\n",
    "print(\"\\n--- DQ ATE Statistics ---\")\n",
    "dq_arr = np.array(dq_estimates)\n",
    "print(f\"Mean: {dq_arr.mean():.6f} | Std: {dq_arr.std():.6f} | Count: {len(dq_arr)}\")\n",
    "\n",
    "print(\"\\n--- OPE ATE Statistics ---\")\n",
    "ope_arr = np.array(ope_estimates)\n",
    "print(f\"Mean: {ope_arr.mean():.6f} | Std: {ope_arr.std():.6f} | Count: {len(ope_arr)}\")\n",
    "\n",
    "# --- HAC vs Monte Carlo variance for truncated DQ -----------------------------\n",
    "# HAC long-run variance: average Omega_hat across runs\n",
    "# MC long-run variance: Var( sqrt(T_r) * (tau_r - mean_tau) ) across runs\n",
    "hac_summary_rows = []\n",
    "T_vec = np.array(dq_T_per_run, dtype=float)  # run-specific horizons\n",
    "\n",
    "for k in k_values:\n",
    "    Omega_list = np.array(dq_hac_long_run_by_k[k], dtype=float)\n",
    "    tau_list   = np.array(dq_tau_by_k_for_hac[k], dtype=float)\n",
    "\n",
    "    if len(Omega_list) == 0 or len(tau_list) == 0:\n",
    "        continue\n",
    "\n",
    "    hac_lr = np.nanmean(Omega_list)  # E[Omega_hat]\n",
    "    tau_mean = np.mean(tau_list)\n",
    "    # align T to the number of tau's retained (should match number of runs used)\n",
    "    T_used = T_vec[:len(tau_list)]\n",
    "    mc_terms = np.sqrt(T_used) * (tau_list - tau_mean)\n",
    "    mc_lr = np.var(mc_terms, ddof=1)\n",
    "\n",
    "    T_bar = np.mean(T_used)\n",
    "    est_var = hac_lr / T_bar\n",
    "    est_se  = np.sqrt(est_var)\n",
    "\n",
    "    hac_summary_rows.append({\n",
    "        \"k\": k,\n",
    "        \"hac_long_run_var\": hac_lr,\n",
    "        \"mc_long_run_var\": mc_lr,\n",
    "        \"ratio_hac_over_mc\": hac_lr / mc_lr if mc_lr > 0 else np.nan,\n",
    "        \"estimator_var\": est_var,\n",
    "        \"estimator_SE\": est_se,\n",
    "        \"num_runs\": len(tau_list),\n",
    "        \"T_bar\": T_bar,\n",
    "    })\n",
    "\n",
    "hac_df = pd.DataFrame(hac_summary_rows).sort_values(\"k\")\n",
    "\n",
    "print(\"\\n--- Truncated DQ: HAC vs Monte Carlo variance ---\")\n",
    "# print(hac_df.to_string(index=False, float_format=lambda x: f\\\"{x:.6g}\\\"))\n",
    "\n",
    "# Optional: save a summary CSV\n",
    "# hac_df.to_csv(\"outcomes/truncated_dq_hac_summary.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c66640bd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "--- Truncated DQ: HAC vs Monte Carlo variance (with error bars) ---\n",
      " k  hac_long_run_var     hac_se  mc_long_run_var     mc_se  num_runs\n",
      " 0           1.59015 0.00723391           1.4693 0.0868195       500\n",
      " 1           5.85276  0.0286374          5.30569   0.31191       500\n",
      " 2           12.4171  0.0634554          11.2626  0.721949       500\n",
      " 3           21.0041   0.111588           19.294     1.254       500\n",
      " 4           31.3741   0.173441          29.3803   1.65492       500\n",
      " 5           43.3149   0.248315          41.6568   2.94013       500\n",
      " 6           56.6586   0.335246          56.0399   3.09199       500\n",
      " 7           71.2613   0.434401          71.0503   4.11107       500\n",
      " 8           87.0159   0.545229          88.5559   5.91177       500\n",
      " 9           103.829   0.668261          106.227   6.53683       500\n",
      "10           121.628   0.800344          125.733   7.41546       500\n",
      "11           140.364   0.939559          145.171   8.49695       500\n",
      "12           160.008    1.08697          165.831    11.384       500\n",
      "13           180.493    1.24112          187.746    11.519       500\n",
      "14           201.794    1.40133          209.917   12.6523       500\n",
      "15           223.907    1.56706          232.295    14.344       500\n",
      "16           246.796    1.73682          255.191    14.885       500\n",
      "17           270.466    1.91208          279.007   15.7538       500\n",
      "18           294.943    2.09084          302.901   19.8689       500\n",
      "19           320.104    2.27582          328.059   20.9776       500\n",
      "20            345.95    2.46486          353.186   18.6318       500\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAm8AAAHPCAYAAAAFwj37AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAADOJElEQVR4nOzdd1yV1R/A8c9djAuyxL1QQXEjuDLNnaaZI2c2bGm50jIzR9kwf2VlrsyVqWnixD3QcKWhAg5URBTcCwTZcMfz++PG1StcuMplet6vV6/kec7zPOfeA9wvZ3yPTJIkCUEQBEEQBKFEkBd1BQRBEARBEATLieBNEARBEAShBBHBmyAIgiAIQgkigjdBEARBEIQSRARvgiAIgiAIJYgI3gRBEARBEEoQEbwJgiAIgiCUICJ4EwRBEARBKEGURV0BwZQkSej1BZM3WS6XFdi9haIh2rT0EW1a+og2LX0Kqk3lchkymSzPciJ4K2b0eon791Osfl+lUo6rqwOJialotXqr318ofKJNSx/RpqWPaNPSpyDb1M3NAYUi7+BNDJsKgiAIgiCUICJ4EwRBEARBKEFE8CYIgiAIglCCiOBNEARBEAShBBHBmyAIgiAIQgkigjdBEARBEIQSRARvgiAIgiAIJYgI3gRBEARBEEoQkaS3lNDpdOj1OrPn9XoZ6ekKMjMz0OlEpu/SQLRp6SPatPQpbm0qlytQKBRFXQ0hn0TwVsJlZmaQnJxAZmZ6nmVjY+Xo9SLDd2ki2rT0EW1a+hS3NrWxscPR0QUbG9uirorwlETwVoJptRri4++iUChxdi6LUqkCzG+roVDIisVffoL1iDYtfUSblj7Fp00ltFoNKSlJxMffpWzZiv99bggljQjeSrCkpATkcjlubhWQy/OevqhUysXeeqWMaNPSR7Rp6VOc2lSlssXWVk1c3C2SkxNwcSlX1FUSnoJYsFBCSZJEZmY69vYOFgVugiAIggAgl8uxs3MgIyMdSSoOPYLCkxKf+iWUTqdFkvSoVGLOgiAIgvBkbGxskSQ9Op22qKsiPAUxbFpCZf21VFi9bgnJGTxIzjR73tnRBhdHEUgKgiCUBFmfHaLnzTL61ASk1ATDFwo5Gen2aJPS0OkMw+EytQtytUuh1UcEbyWe+QUK1rQ/7AZb/okxe/6V5z3o3bZWodRFEARByK/C+ewoLTTngsgM3Wz8Oumx8za+vbBt1qfQ6iOCN8Ei7ZtWoalXOTI1OmasCgXg8yG+2KgM+YKcHW2KsnqCIAiCUGBU9Tug9GiKpNGQtnU6AI59pqCXGcIoWSH2uoEI3gQLuTja4uJoS0bmw0TA1SuUwdZGJHsUBEEQSje52gXULkiaDOMxpXsNdLKiSbUiFiwIQgljzTkqYr6LIAhCySOCN6HUCg09QZs2zWjbtjknT4bmWnbUqGG0adOM48eDC6l2T2fv3t1MmzYp3/dJSkril19+ZNeu7SbHp0+fRps2zdi6NSDfzyjpli5dSJs2zZg+fVqu5W7dukmbNs1o06ZZruV27dpuLHfkyGGL63H37h3++GMJ77//Jj17vkj79q3o27cHX375OaGhJyy+z+O2bdtM585tuHPn9lPfQ8hOkiT27NnJhAlj6dWrK+3bt6Jr1468//5b/P77IhITE7Nd8+j3kCX/7dix1XhtUNBeOnZ8nkuXogrzZQpFTAybCqWeJEnMmPE1y5evwc7Orqir89ROngxl2rTJNGrUJN/3mjv3Z3bs2Mpnn02xQs0ES2zfvgVbW1syMjIICFhP69Zt8rwmIGADc+b8TGZmBuXKlad2bU/s7e25ciWGffsC2bcvkMGD32DkyI+eqC43b95g9uwfef31oVSoUPFpX5LwmMzMTD77bBzHjwdjb29P/fqNcHFxJiEhnqioi/z++yI2bPDnp5/m4u1dP8d7vPjiS3k+p0qVqsZ/d+jQmYCAjXz11WR+/30VSqX4WH8WiFYWnohe/3CYLfJaAg1quiGXF/9VSzduXOe33+Yxduz4oq7KU7Pm3ojmhkuHDx/F668PpWxZd6s9SzAESydPhtKuXUeuXbvCv/8e4fbt21SsaD5wWrVqOQsWzMXJyZkpU76iffuOJqmBgoOP8uWXk/jrr5XY29vzzjvDLK7PTz99j1rtwODBr+frdZVGo0YN4+TJUNat20KlSpWf6No//ljC8ePBNG/ekm+++R5HR0fAsMNCcnIqv/02j/Xr1zBx4if4+wdga5s9vdIXX3zzxHUeOXIM7777BqtXr+DNN9954uuFkkcMmwoWC7lwl8lL/jV+PWvdKT5dcISQC3eLsFZ5K1u2LAqFgo0b13Lq1Mmirk6x5u7uTo0aHsYPHcE6tm/fgiRJtGr1HJ07d0Wv17Nly0az5S9evMDixQuwsbFlzpzf6Nixc7acji1bPsc338wA4M8/lxMff9+iuoSGniA4+Aj9+g3E1rbk9kQXR3v27ARg/PjPs/0M2dnZMWbMx3h61iE29h7//HPIas+tU8eb5s1bsmrVch48SLDafYXiS/S8CRYJuXCX+ZvCsx2PT8pg/qZwRvZpiF/d8kVQs7xVrlyV7t1fYeXKZcyY8RXLl//1RB9aR44cZv36NZw/f46MjHTKl6/ICy+05/XX38LJydmkbJs2zfD0rMO8eYtYunQhBw78TXz8fcqXr0Dnzl154423sw3d7ty5je3bt3DlSgwpKSmUK1eOli2f4/XXh1K+fAXAMBdt585tAJw5c4o2bZrh4+PLb78tAUCr1bJr1zYCA3cTFRVJcnIyarUDnp5evPJKH7p06WZSxyzff/8t33//LZMmfUn37j2Nz/nssyn07NnbWE6r1RIQsJ6dO7dz5Uo0AB4etXjppR706vWqyVBNaOgJxoz5gP79B9Onz6ssWvQrYWEhpKWl4+FRk1dfHUCPHq9ke58jIs6zbt1qTp8+RVxcLHK5nAoVKvL88y/wxhtvU6ZMGWPZpUsXsmzZYr76agYnThxj795dKBRKevToya5d23nw4AGrV2+gevUa2Z7z8cejOXbsKAsWLLXKEHRe9Ho9O3duQyaT0bJlayRJYvHiBWzfvpl33hmW4zDX+vX+aLVaBgzoj6enl9l7N2/eirZt26FQKLhz5w6urm551ufPP/9AoVBka4MdO7by3XdfMW7cp3h61uH33xdx7txZFAoFjRv7MGrUWKpXr8GhQ/tZsWIZ0dGXcHV14/nnX2DYsBGo1WqT++l0OrZu3cT27VuJiYkGJGrV8qR371fp1q0HMplpj31GRjqbNq3nwIG/iYmJITU1hTJlyuDtXZ8BA16jRYtWJuWf5metoGUF0OaSp8vlcvr3H8SpU2E4OzvnWOZpvfJKH44d+5dNm9YzdOh7Vr23UPyI4K0UkySJTM3DoTadXnqqzZH1eolVgZG5llm99yL1a+R/CNVGJc/2S90a3nlnGIcPHyA6+jILF85nzJhPLLpuwYK5rFq1HIVCQaNGTXBxceHs2XBWr17B338HMnv2ApP5JwDp6WmMHPke169fo2HDJtSqVZuQkOMsX76Uixcj+eGHWcay69atYfbsH7G3t6dx46bY2dly4UIEGzeu48CBIP74YzWurm40bNiYe/fucuLEMVxcXGnRohU1angAhnaeMmUChw8fxMnJmfr1G2BjY0tMzGXCwkIICwshISGB/v0HAYY5NeHhp7l58wYNGjSiSpWq2V7DozIyMhg/fgxhYSHY26vx9W0GyAgLC2HWrJkcOnSAH374BRsb01x/ly9f4r333sLW1paGDRvz4MEDwsNPM2PG1yQmJpoM2f39916++moykiTRoEEj6tatR3z8fcLDT7N69QpCQ0+waNEf2T4UlyxZwJ07t2nRohW3bt3C07MOL74osW7dX+zevYP33//QpHxs7D1CQo5RrVr1QgncAE6cOMbdu3fw82tOuXKGP3D8/Jpz/HgwBw/up2PHzibldTodBw78DUDnzl3zvP+MGT9ZXJd79+5y/HgwjRo1wc2tbI5ljhz5h9mzf6JKlao0b96SiIhzHDlyiIsXLzBo0BDmzp1F3br1aN68JSdOHGf9+jXcunWD779/+H2t1WqZOPFj/v33CA4ODjRs2AiVSkVYWCjTp08jNPQEkydPM5bPyMhg1KjhnD9/Fnf3cjRu3ASZTEZU1EX+/fcIwcFH+e67mbRt296krk/ys1YYPD3rcPbsGb799kvGj/+cmjWzJy7v0eOVHP94ya+WLVujUqnYsWOrCN6eASJ4K6UkSWLGn6FE3XhQKM+LT8pg5C8H830fz6rOfD7E1+oBnEqlYtKkL/ngg3dYv96f9u070bixT67XHD58kFWrluPs7GwywVij0fDzz9+zdWsAX3zxOUuWrDCp7/Xr1/DwqMnKlWupXLkKYOhV+uCDtzly5BCXL0dRq5YnmZmZLFw4D2dnZ5Yv98fd3TDPTKvV8uWXn3PgQBCbN29k6ND36NWrL9WqVefECUPg8ei8mIMHgzh8+CD16zdkzpzfTHobVq78g4UL57Fhg78xePvii2+YPn0aN2/e4OWXe5n0sOVk0aL5hIWFUK9efX744Rdj7058/H0mTBjLiRPHWLhwPqNHjzO5LiTkGO3bd2LSpC+NvTLr16/hl19+ZNWq5QwaNASZTPbf+/k/5HI5c+cupGHDxsZ7XLkSw7BhbxERcY7w8NPZ2uzGjev8+utSGjZsBBh6uerU8Wbdur/Ys2cn7733gUnb7Nq1HZ1OR/fuln94njoVxtdfTzV7Pi0tLdfrt283ZGV/9AO7e/eeHD8ezObNG7IFb3FxsSQnJ6NQKKhbt57F9bTEsWP/IkkSTZo0NVsmOPgIgwe/wYgRY5DJZKSkJPPGGwO5e/cOc+fOYuLEKbz8cm8AoqMvM3ToYP755xBxcbHGuZJ//LGEf/89QtOmfnz99f9wdXUF4P79OMaPH8POndto3NjH+L23adM6zp8/ywsvdODrr2cYeyN1Oh2//PIjmzatY8OGtdmCN0t/1grLsGEj+PjjUZw6FcYbbwygZs1a+Pm1wNfXj8aNm+Li4lJgz7a3t6du3XqEh5/m+vVrVK1arcCeJRQ9MeetNCv+6wgKVb16DRg06HX0ej0zZnxNRkZ6ruXXrl0NwIgRH5msDFOpVHzyyUSqVq3GhQvnCQk5nu3a4cNHGj9MALy96xkDj8uXLwGQkpJMeno6trZ2ODk5GcsqlUo++GA048dP5Lnn8l6RqNFoaNPmBT74YFS2YaLevV8FDKkInoZhZeQG5HI506Z9ZzIs5+rqxrRp3yGXy9m0aT2pqakm1yoUCj799HOT4bRevV7FxsaGhIR47t+PAyAuLo4WLZ5j0KDXTQI3gBo1PPD1bW72NTRo0MgYuIFhWKp2bU+8vetz69ZNTp0KMym/a9d2FAoF3bp1t/g9uHnzBnv27DT736FD+81em5iYyKFDB3B0dKRduw7G4y+80AFHxzKEhp7g6tUrJtfExsYC4OzsgkJh3STYYWEhANSubT6gcXJyZtiwEcag18HBkdat2wJQv35DY+AGULNmLTw8DL1L169fBwzfj+vXr0GlUvHFF98YAzcAN7eyTJgwGYC//lppPK5SqXjuuef54IORJsPICoWCV14xbDlk7nvYkp81c3JK0ZGVVqh//1fMpucwx8+vObNnLzC+J9HRl1m/fg2TJn1Kz55dGDZsKDt3bss1v2JeaUJGjTK/MCWrXfOTQkYoGUTPWyklk8n4fIivybCpUil/qmHTyGsJzFp3Ks9y4/o3oU41lye+/6MKatg0y7vvDueffw4SExPNokULsvUWZdFqtZw5cwqZTEaHDp2ynVcqlbRr15FVq5YTFhZCs2YtTM4/HoQAuLuXAyA93RA0urq6UaOGB1euxPDOO0N46aWXadXqeWrX9qRatepUq1bdotfUuXPXbMNrmZmZXLkSzZkzpwFDD4ZOp3viYCAi4hwZGRl4e9fPcWi1SpWqeHvX59y5cM6dCzd5H6pVq46zs4tJeZVKhbOzC/fu3TW+DxUrVsy2wk6SJO7cucOFC+eNH9oaTWa255sLQnr0eIWIiHPs3r0DHx9fAM6eDScmJppWrVobhy8t8dJLL5sM8T3u1q2b9O+fc09eYOAuMjMzeemll03mWdra2tK5c1cCAtazefNGk+/DrDbS6bQW19FSWTndKlasZLZMnTp1UalMs8ZnBWBeXnWylc+ai5iZacg8f+HCeZKTk6ld2yvH99nbuz6urm5cvXrF2Fv36qsDefXVgSbl0tPTuXw5iqNH/wEMQWFOLPlZM8feXp0tNcfx48HEx9+nbdv22NvbG4/nNrXgUT4+vvz551rOng3n6NHDhIae4Pz5s2g0GuPPyZ49O/nf/37OcbVpXqlCsqZL5CRrdezdu3csqqtQcongrRSTyWQm21cplXIUTzEnrUFNN1zL2BKflGG2jFsZ2xKRNsTGxobPP/+SESPeZd26v+jQoVOOv/wTEx+g0WhwcXFBrXbI8V5Zvyjj4mKznStTxinbsawP5Uf/6v766/8xZcoEYmKiWbBgLgsWzMXdvRzPP9+WXr36UqeOt0WvKyUlmS1bAggOPsLVq1eIjb2HXq83CYSfZjeF2Nh7QO4f9pUqVebcufBs78OjCwweldP7AHD06D/s2rWNy5cvcfPmDTIyDN9vWa8hp+rn9D4DdOnSjXnzZhEUtJexYz/F1tbWuODjSYZM82v79i2AIUff4z0mCQnxgGHByrBhI4wf5FnD50lJSWi1Wqvm7YqPNzzT3Pc0kG0RzqMeD8ZzcueOIXC4dOlinomL7969YxxqvX8/jk2b1hMWFsK1a1e5fz8OSZIeaf+cv38t/VnLiYuLS7Y/HEaNGkZ8/H3GjPn4iVOFPKpBg4Y0aNAQAK02k9DQUHbu3Mbevbs5fjyYpUsXMmLEmGzXPU2qkCxZK1yzerUF69EnxyGlJyE98keENvbKw71N7cogd8x5HmlBKHXBm0ajYeXKlWzatImYmBjUajWNGjXirbfeom3bttnKt2zZkoSEBLP3O336tMlfR3q9no0bN7J69WpiYmJQqVT4+fkxcuRIGjRoUBAvqcjJ5TJe6+yV42rTLIM7exX7wC1LgwYNGTjwNVavXsl3333FsmWrs5V5+Es/t9dkKKNS2eRSJne1a3vy55/rCAk5zuHDBzh+PJhr166yefNGtmzZxLhxE+jbt3+u97h8+RIfffQh8fH3cXV1w9u7Hp06vYiXVx18fHzp27fHU9cv633IvTfU3Ptg2feDXq/n888/4Z9/DqFSqahbtx4vvtidWrVq07BhI9av92f37h05XmuuXo6OjrRv35Hdu3dy5Mgh2rZtz759e3BycqZNmxcsqld+RUVdJDIyAjDM3btyJSbHcomJD/j770BeeullwDC0WK5cee7du0tExLkc/7h41D//HOLq1Su0atU6xwnyj9JqDb15uQU1+Q0W9XrD/scVKlTMdW4dPAwiQ0NP8Nln40hLS6N8+QrUr98QD4+a1KlTl0qVKvPee2/mq06F4f79OK5fv4a7ezmTYVwwpAlp0aIVLVq0on79hsye/SN79uzMMXjLD53OMLJizZyQgiFwS/GfCDrT3t/kTd8+/EKhwmHg/wotgCtVwZskSYwbN47AwECcnJxo3bo1GRkZ/Pvvvxw6dIixY8fy4YcPV5/duHGDhIQEKlSoQIsWLXK85+Or26ZNm4a/vz/Ozs60bt2a2NhY9u3bx8GDB1m0aBGtW7cu0NdYVPzqlmdkn4asCowkIfnh8JVbGVsGd/YqtmlCzHn33Q84fPggV69eYcmS37Kdd3Z2QaVSkZj4gNTUlBx7Km7evAGAm1ve6Rlyo1AojL/YAW7fvs26dX/h77+KBQvm8sorfXL9QJ016wfi4+8zZMhbDB8+0uR7NqeteJ5E1vBTbnPm8vs+7N69g3/+OYSnZx1+/HGOsecpS0pK8lPdt0ePXuzevZP9+/ehVjuQlJTIq68OyLYqtqBs22ZYqPDGG28zfPjIHMusXr2CX3+dw+bNG43Bm0wm4/nnXyAgYD1BQfvyDN5WrVrO6dMniY29y+jRH+daNmtuZVavX0HI6kkrX76CRb1IkiTxv/99Q1paGp98MpE+ffqZnM8KgIu77du3sHDhfHr37sf48RPNlnv55V7Mnv0jiYnWX0yWlePt0Tm0Qv5J6UnZArdsdBpDuUIK3krVgoU1a9YQGBhIvXr12LNnDwsXLuSPP/5g/fr1ODo6Mnv2bC5dejiB9fz58wB069aNH3/8Mcf/Hp37ERQUhL+/P15eXuzatYt58+axZs0a5syZg16vZ+LEicahntLIr255pr/3MNfSuP5N+OHD1iUucAPDnKNJk75ELpfj778q26RxpVJJgwaN0Ov1HDgQlO16rVZrPN60qd9T1SEsLIQhQ/rxww/TTY5XrFiR0aPH4ehYhrS0VJKSkgDzvUxnz54BDEHC439sHD/+MKnyo70tls4r9Pauj52dHZGREdy4cT3b+Rs3rnPhQgT29vZmt/vJS3i4YV5e9+49swVuqampxvNP2pvQtKkfVapU5ciRf9i3b89/zyicIVONRkNgoCFha27pPl58sTsKhYLw8NNERV00Hu/ffxBKpZJNm9b9lyMtZwcOBHHmzCkUCgW9evXNs15Z8yizhsMLQr16DbC1tSUqKtK4+OJRsbH3GDKkH2PHjiA1NZX79+O4efMGjo5lsgVuYFghC8W/NykryN67d3euCZOzftfUrFnb6nXIatdq1bLnNxRKl1IVvG3ebPhLd+LEiSYrnLy9venZsyeSJHHw4MN0FmfPngWweLhz6dKlAEyYMMGkl6Fr16707NmTO3fusHPnzny/juLs0aHROtVcSsxQaU4aNmxM//6D0ev1Oc4RGTjwNQDmz59t8te/Vqvlp5++58aN63h51ckz5Yg5tWrV5vr1a+zatYPTp0+anDty5DDJyUlUqlTF+L1sY2MYvn+8J8rFxXD+0KH9JsdPngxl1qyZxq+zJpQb7mXofUpOzr1Xy87Ojlde6YNer+err6aYTDGIj49n2rRJ6PV6evR45akTombV/99//zEO64GhF+HLLz83PjMzM/uChdzIZDJeeull0tJS2bVrO7Vre1G3rmVzCPPr8OEDPHjwgJo1a+W6stPd3R0/P0Ovf0DAeuPxGjU8eP31oWRmZjJq1PscPnwg21Dn/v37+PbbL5Ekiddee5Pq1T3yrFejRoYAIzz8zFO8KsvY29vzyit9SUtL45tvppoEMqmpqUyfPo0rV2Kwt1ejVqtxdHREpVKRnJxkXOmZ5cCBv/njD0Mi6idt/6c1b94iDh8+8cTz3Zo29cPPrznJyUl89NGHnD2bfZrJ5ctRfPPNFwC89tobVqnvo7L+0CmsHIZC0SlVw6bLly8nOjoaL6/sGcmz0hg8utouq+etYcOGed47OTmZkJAQ1Gp1jkOjXbp0ISAggP3799O7d++nfAVCYRs27EOOHDnEtWtXs51r27Y9gwe/wV9/reT999+icWMfnJ1dOHcunLt371CpUmW++mqG2WzqeXF2dmHkyI+YM+dnRo58n4YNG1G2bDnu3bvL2bNnUCgUfPzxBGP5ypUro1AojHPcatf25OOPP2XgwNeYO3cW06dPY8uWTZQt686NG9e4eDESZ2dnypYtS1xcHHFxcTg4GCY0Z+WAWr58CeHhp+jWrUe2HFpZhg8fSWTkBU6eDGXAgF74+Pgik0FYWCipqSn4+TXnww9HP9V7AIZhpPXr13Ds2L8MGtSHunW9SUlJ4cyZU2RkZODhUYuYmMtPNQm7e/ee/P77ov8CzJ5PXccnlbVQ4dGdLczp1q0Hx44dZc+eXYwY8RFOToY2eu+9D9Dr9axY8TsTJ35ChQoVqV3bE5VKRWRkJLduGYar+/cfnC0ZsTmtW7dFLv+BU6dC8y6cDx98MJKLFy8QEnKcgQP7UK+eoQf3zJnTJCY+oFq16nz66ecA2Nra0avXq6xfv4aPPvoQHx9fHB0diY6+zNWrV6hYsRIPHjwgJSWZjIx0q27plZCQwJw5liU57tWrb55z+L755ns++2wsZ86cZvjwoVStWh0PDw9UKhXXrl3j0qWLyGQy3nlnGJ06vZjjPXLLKZilRg0P3nrrXZNjiYkPiI6+/N8za1r0moSSq1QFb7a2tnh7Z//Leu/evezatQt7e3tefPHhD8zZs2exs7MjPDycKVOmcPGi4QfL19eXESNG0KTJw79eoqKi0Ov11KpVK8f5R7VrG7rAIyNz34lAKF5sbe34/PMvGDVqWI7DMiNHfkSTJj6sX+9PRMR5MjMzqVy5Mm+99S4DBw7J99ySAQNeo2xZdwICNnDxYiTnzp3FxcWVTp1e5PXX38LLq66xrKurGxMnTuX33xdz6lQYt2/f+i94G0LZsu74+68mOvoS0dGXqFChIv36DWTIkLdYtWo569f7888/h4zbRfXp04+oqIscPnyAf/89godHLbPBm62tHbNmzWfTpnXs2rWD0NDjKBQKatasRffuPenZs/dTB7BgWK26ePFyFi/+jbNnz3D06BFjj1T//gNxcnLh3Xdf559/DpqdO2ZO+fIVqFixEnfv3qFLl9xTMFhLbOw9jh8PBizbIaFdu/Y4ODiQkpLCnj076dfv4QKVYcNG8Nxzz7N1awCnT5/ixInj6PU63NzK0qVLN/r06fdEPb/ly1egRYtW/PvvEa5ejbGot+5pZH3PBARsYM+eHZw7Fw7IqFy5Mv36DaR//8Emq5FHjx5HtWrV2bJlE+fOhWNjY0OFCpV44423ee21N/n22y/4559DHD36D+3bZ0/d87TS0lKN+5HmpVmzFnkGb05OTvz661L27t3NgQNBxjyQer2esmXd6d69J717v0q9euZHeyypj4+Pb7bgbf/+v5EkiZ49e1n0eoSSTSY9Tf6AEuDBgwdMmTKFqKgoLl++TKVKlZgxYwbPPfccYEgM+mgPmo+PD+7u7kRGRnL16lWUSiUzZ86ke3dDMs/AwEBGjRpFhw4d+O237BPck5OT8fPzw9nZmWPHjj11vXU6PYmJuWdsB8MQ2N27NylbtpJFqx1lMlAo5Oh0+hxTLlgqI1PHhz8fAGDBx+1MUpEIhctabVqaXbgQwbvvvk779p349tvvi7o6eSqMNg0PP8MHH7zNwIFDzOY5FKynsH5O3333De7cucXatVuy7TObE40mk7i4W5QvX9k4JUPIWeqhFWSc2ZtnuTL9v0ZZziNfz3JyskehyPuP4VLV8/aoa9eusWfPHuPXhn3yoozBW9Z8N1dXVxYsWEDTpoa/qCRJYvny5cyYMYPPP/8cX19fKlasSEpKCoBJ0sZHZc33eTzL/JOSy2W4uprPwZQlPV1BbKwchUKGUml5r4cl3xQ5SUjKICE5wyTp743YFGxUhvu5ONriUkb8AigKT9umpVVmZiZKpZLk5GTmzPkRgAEDBj3Rz0lRK8g29fFpQuvWbdi5cxvDh39o0Qe9kH8F2aZnzpziwoXzjBr1cNg9L3q9DLlcjrOz+qnnqxYn2qR4dMnmV1ErHF1RlnE1e96chKMBFgVuAE5l7LG14PPbGkpt8FazZk2OHTuGJEkcOXKE6dOn8+2335KcnMyHH35I27ZtOXToEJIkUaFCBeN1MpmMoUOHcvz4cfbu3cv69esZNWqUca5cXqv08tuRqddLJCbmHQBmZmag1+vR6SzbbD6/f/3tPXGNLf/EmBz7dsXDLVheed6D3m1zzzElWJfoecvZiROGnGE6nQ69Xk/r1m1o3LjpU+0uUtgKq03Hjv2UoUNfY9mypU88FC08mcJo0zlzfsHLqw6vvjrI4u9znU5Cr9fz4EEqaWm6gqlYIUo7to30EwFmz9s16419i7xXZD9K0maSdGo/AHpkyDHfgDoUJGsUpManPNEzHvfM97w5ODyMfrt3707FihV57bXXWLRoEW+++SYODg6UL28+xUWHDh3Yu3cv4eGGFUNZf52a224l67i5nrknYckPn073ZL8Fsn5pPO0vj/ZNq9DUq5zZ886OhZM7S3gov21aWlWtWo2yZd158OABrVs/z6efTi7qKlmssNq0cuUqjBv3KTNnzqBXr7657qAh5E9Bt+m+fXu4cCGCpUtXZtvWzBKWdgAUdwrv9qir+yBpNKRtNaRfsu85Gdl/74lM7fIUr1OJXY8JaC4dZ0ZQJvq0JPPPty/DVFtX5IX0Xpba4O1xvr6+VK9enStXrhATE5NnepBy5QyBSlqaYf5ZVqCXU94igHv37plcV9q4ONri4iiGRYXir3LlKqxfn/cm4s+6l1562ZgYWCi5OnV60ezK1WeJXO0CahckzcOUSAr36shUT/65pbt/HYWbYS9buV0Zoh2bcjU5DMglAW+yYR9w7xpPPjT7NErOJJA8pKWl8b///Y/x48ebHbrMym2l1Wrx9/dn7Nix7N2b81j2tWvXAEPCVABPT0/kcjmXL1/OcVViVFQUAHXqZN+4WRAEQRCE4i8zPJDU9VPJPPcwOXtCimXJ9y0tZw2lJnizs7Nj06ZNbN26lePHj2c7f+3aNaKjo7GxscHLy8uYUHfdunXZykqSZEz426ZNG8AwHNq8eXOSkpIIDg7Odk1gYCAA7dq1s+bLEgRBEAShEGSe3UvGkVWAhJT8MK+kk4Nl04JcHApvdKrUBG8ymYyBAwcChv1H7969azx3+/ZtPv74Y7RaLYMHD0atVtOnTx9sbGzYv38/a9euNZbV6/XMmTOH06dP4+npSbduD5NsDhkyBIBvvvnGOEwKsGfPHrZt20b58uV5+WUxDCEIgiAIJUnmub/J+OdPAGyadMem+auAoTMnJOJubpcCYGejoE41l4KsoolSlectPT2d9957j+PHj6NWq/Hz80Oj0XD69GlSU1Np06YNCxYsMA6fbtiwgSlTpqDX66lbty4eHh5ERERw5coV3N3dWblyJbVqma6gHD9+PFu3bsXR0ZFWrVoRHx9PaGgoKpWKJUuW0LJly3y9Bp1Oz/37ea9WycrRY2meNwClUl4qJqYKD4k2LX1Em5Y+xbFNn+YzpCSQNBkkLxsOgOPbCy2a85Z5LoiMw8sBUDV+CduWA5DJZEiSxLqgS+w6ln0HnscNfcmbF5o82ZZqOXFzc7BotWmpCt7AsCH0ihUr2Lx5M9HR0SiVSry8vOjbty/9+/c32R4LIDQ0lMWLFxMaGkpKSgrly5enY8eOfPjhh5Qtm31yok6nY/Xq1axdu5YrV67g5ORE48aNGT16NPXq1ct3/UXwJjwJ0aalj2jT0qc4tqkI3gwyz+8n49AfAKgad8O25UBjSrCAQ5eNKbLe6lYXR3sVqwMjiU9+uM+uWxlbBnf2wq+u+ewVT+KZDd5KuuIavOlTE5BSE8yel6ldDKt9hEJVHD8UhPwRbVr6FMc2FcGbQcaJTWSGbkbVqCu2rQYZA7ftR2PYcOAyAIM7e9GlmWE/aF1GOqeWfEmi3p7Kr4zEs5o7cnnu+V+fhKXB2zOTKkTIH825IDJDN5s9b+PbC9tmfQqxRoIgCIKQP7bN+qCoUBtF1UbGwC3w+DVj4NavfW1j4AaGXZC8VHcAcKnugi6PxP0FRQRvgkVU9Tug9GiaawJEQRAEQSjutFdPo6hcF5nS0CunrNbYeG7/yRv8te8iYNg5qHurGkVSx7yI4E2wiDUTIAqCIAhCUdBE/kP6/iUoKtXF/qWPkSkfDhn/c+YWK3ddAOClltXp1aZmUVUzTyJ4E4RiRJKkPPfPFQRBEJ6c5uIR0vcvASTkrpVB8XA7sWPn7/D7jvNIQCe/qvRrX9vkd3HWvG9JozEe08ZeQS8zhFGFPe9bBG9CqbVjx1a+++4rAFxcXNm8eVe21caPCg8/wwcfvA1Ao0ZNWLBgaaHUM8v582eZNWsmv/66BKWyYH80MzMzOXRoP7t37yA6Opq4uHvY2NhSq1ZtOnbszCuv9DWm1Ckoo0YN4+TJUGbNmk/z5vlLsZMbvV7PRx99iFqt5vvvZxXYc55FCQkJrFv3F0eP/sPNm9fJzMzE2dkFb+/6dO7clY4dO2f7Y2Tp0oUsW7bY4mccPnzC+O8JE8aRmprC7NkLcv1ZFoTHaaKOkr5/MSChqtce2+dfN35vhkXeY/HWc0gSvNCkEoM7e2X7vs1p3nfypm+N/y7sed8ieBOeCQkJ8YSFhdCsWQuzZfbt21OINcpu2LChZrd2s6bo6Mt88cVEoqMvY2dnR+3aXtStW5e4uFgiIs5x+vRJNm/eyOzZC3Bzy2UvvxLir79WEh5+mj//zL6bivD0IiLOMW7cKJKSEqlUqTI+Pr4olUru3LnNkSOHOHRoP9u3b+F///spxz8EKleuQsOGjbMdz81HH33C66/3Z/XqFbzxxtvWeSFCqaBPjkNKTzLpGdPFXkWmUqG9dobM4xsAUHm3w7bNm8hkhhWd4ZfjWLA5HJ1e4rkGFXizqzfyHEY/suZ9AygUcpzK2JOYlIZOZ1hFXNjzvkXwJpR6jo5lSE5OIihor9ngTa/XExS0F5VKheaRH/7CVBiB2/Xr1xg+/G1SU1Po128Qb7/9Hs7OLsbzd+/eYcaMrzl+PJgxYz5k6dIV2NraFXi9CsqtWzf5/fdF9O7djypVqhZ1dYqVW7du0r//K/j4+DJv3qInular1TJ16kSSkhL5+OPP6Nu3v8n5q1evMGnSpxw7dpSFC+czevS4bPdo0qQpkydPe6LnVqlSld69+7Fs2RI6duwi2lQADIFbiv9E0Jn+7s5aXJdFWasFtm3fMgZu56/EM3fjGbQ6iWbe5XmnRz2zaT+y5n2DIfWLrasDSrsUKKIUMKVmeyyhYOmT49DFxqCLfZhpWhd79b9jMegf2QeuuGnWrDlqtQMHDgSh0+lyLHPqVBixsfdo2fK5Qq5d4ZEkia++mkxqagpvvPE2Y8eONwncAMqXr8B33/1I1arViYm5zNatAUVSV2tZunQhWq2WQYOGFHVVSpXTp09y69ZNGjf2yRa4AVSvXoOpU78GYMuWTVb9w2Tw4NfR6bQsXbrQavcUSjYpPSlb4JYTVZOXjIHbxesJzFl/Go1Wj4+nO8N61kchLzkhkeh5E/Jk0V81ChUOA/+H3LH4DbPZ2Njy/PNtCQzcxcmTofj5Nc9WZt++Pcjlcjp2fJHDhw/meJ/bt2+xcuUygoOPEht7D0dHRxo18mHIkLdo2LCRSdnp06exc+c2li1bxaVLUaxbt4aYmMvY2trh6+vHO+8Mp1at2oDp3DyA9u1bAaZzfZKSkli9egUHDvzN7du3sLOzp2HDRrz55ts0bNjEovfh9OmTnD9/jrJl3Rk69F2z5ezt7XnzzbfZvn1LtnOJiYmsW/cXR44c5vr1q2RkZODs7EyjRk147bU3qV+/obFsVs9O27bt6NLlJebP/4X4+HiqVavGggW/m32+VqslIGA9O3du58qVaAA8PGrx0ks96NXrVYvnA969e4fAwF20bPkcFSpUNDmXNd9u1679bNmyka1bA7hz5zYuLq507dqdd98djk6nY9myxQQG7uLBgwSqVavOG2+8Q8eOnbM9Kzb2HitW/M7Ro//8971RBl9fP956611q1fLMVv7q1Sv4+68iJOQEsbF30esl3N3dadHiOd555z3c3NyNZbO+P8aM+ZgGDRrz+++LOHv2NDqdDi+vurz22pu0afOCRe+JtcTHxwMgz+XDrm5db7p374lKpSI9PR17e3urPLt8+Qq0bNmaffv2MGzYCCpWrGSV+wqlX9Y8tuhbifyy7hQZGh0NarrxYe8GKC1IjFuclKzaCkXCor9qdBpDuWIq6wM3KGhvtnM6nY79+/+mcWMf3N3ds50HOHs2nLfeGsTmzRtRKpW0adOOKlWqcejQfkaMeJfNmzfmeN2yZUv49tsv0Wq1tGrVGjs7O/bv/5sPP3yHmzdvAIahoBdffMl4TZcu3Uy+vn37Nu+++zorVy4jPT2dFi1aUatWbYKDjzJixPts2xZg0XuQNaevbdv2eQ6Fdu/ek/nzF9Ov3yDjsfj4+7z//pssW7aY5OQkfH2b07x5SyQJ9u//m5Ej3yci4ly2e126FMVXX03Gzc0NX18/3N3Lo1arc3xuRkYG48aN5JdffuTq1Sv4+jbD17c5V67EMGvWTMaPH0NmZmaO1z5u9+4d6HQ6XnihvdkyX389hd9+m0e5cuVp2rQZ8fH3WblyGbNn/8Qnn4xmw4a1eHjUwsurLhcvRvLFFxM5cOBvk3tcvHiBoUNfY+PGdcjlcp57rg0VK1Zi375A3nvvLY4e/cek/KlTYbzzzhA2b9743x7Jz9OoUWPu348jIGA9w4YNJTU1+y4rJ04cZ8SId4mOvkTTps2oUqUap0+fZOLEj3P8vi5Inp5eAJw8GcqyZYtJSUnOsdykSV/y6aeTrBa4ZWnT5gV0Oh27dm236n2F0u/a3WR+9j9JWoaOutVcGNW3ESplyVv8InreSrlH87JJkhzp0fF5mcwkx82jZU3vYdkcMEmjMdzj8ftqM8DcqIkMY6LEgtSyZWscHR05cCCIceMmmKxUCwk5TkJCPJ07f5DjtRkZGUyZMoGUlBTefXc4Q4e+Z/wL7ujRf5g8eQI///w99erVp04db5NrDx8+wBdffGMMxjIyMhg7dgRnzpxi48Z1jBo1liZNmtKkSVP27NkJwOTJ00x6l775Zio3b95gwIDBjBjxkfHc2bPhjB8/mp9++p4GDRpTs2atXN+DK1euANCgQcNcy5mzfPlSbty4Tr9+g/joo0+M70FGRgZffvk5hw8fZPPmjXh71ze57ubNG/Tp059PPvkMMMwvNGfRovmEhYVQr159fvjhF1xd3QBD4DhhwlhOnDhmdg7V44KDjwLQpImv2TKhoSdYsOB343ty4EAQkyd/yqZN6yhfvgIrVqyhUiXDZtMLF85n5cplbN68iXbtOgKGXsIpUz4jISGeESM+YvDghyvYDh8+yNSpn/H111NZvXoDrq6uAPz88/ekp6czffoPxvsAxMXFMnz429y+fYvDhw+aBPAAR44col+/gYwaNc74PTB37iz8/Vfx55/L6dAhe49gQalRw4MePV5h+/YtLF26kJUrl+Hj44uPjy9NmvjSoEHDAl0x7eNjaNPg4KMMHfpegT1HKF3uxafx484wUtK11K7ixJh+jbFVlbzADUTwVupl7fGWE0W1xqhf+vhh2ZWjQWtZr0ZOsoZR5eVq4tDnS+PxlLWTkMzMiZO7Vsah/3dP/UxL2djY8PzzL7B79w5OnQrD17eZ8dy+fXtQKBS0b9+Jy5ejsl3799+B3Lt3Fx8fX95++32Tc8899zxDhhh6o/z9VzF16jcm559//gWTD2FbW1teeaUPZ86c4vLlS3nW++zZcE6dCqN2bS9GjRpnMkzVoEFDhg59l7lzf2H9+jV8+umkXO8VFxcLYAyInlSZMk60bNmad98dbrKM3tbWlh49XuHw4YPcvHkzx2sHDnzN+G9zQ20ZGRkEBGxALpczbdp3JvV0dXVj2rTvGDy4L5s2refdd4eb7b0DQyqU8PDT2Nra5jqpvUePV0yC2RdeaI+dnR3p6em8+ebbxsANoEOHTqxcuYwbN64Zjx048Dc3blyndes2vPbaGyb3btPmBXr27M3GjevYtm0zb7wxlNTUVOrWrYe3d32TwA2gbFl3XnihPWvX/mXslX2Ui4urSeAG0L//YPz9VxEdnff3krkUHSdPhtKmTTOTY48O2Zvz6aeTqFSpMqtWrSAtLZVjx/7l2LF/AbC3V9O6dRveeuudHIeNAXbu3MbOndtyfcakSV/SvXvPbMerVq2GnZ0d586Fk5GRXqIX1QiFZ8WeCySlOlGjQhnG9W+CvW3JDYFKbs0F4Ql17NiF3bt38Pffe43Bm0aj4eDB/TRv3hIXF5ccrzt5MhTAbM9G585dWbZsMWFhodnOPT4XDsDdvRwAGRnpedY5NPQ4AE2b+uUY9LRu3Ya5c38hLCwkz3tl9TaaW7SRl3ffzf6HQHJyMpcuRREcbPjQ1miyB/+2trZUrVot2/HHRUScIyMjA2/v+jkGXFWqVMXbuz7nzoVz7lx4rmlf7t+PQ6vVUqlS5VznZTVoYNo+MpkMZ2cX0tNv4+lZ1+Sco2MZAJNh25AQQ/vkNI8SDMH9xo3rCAsL4Y03hqJWq5k06cts5WJjY7l4MYKoKMO2PDmtePb2rpetNytrmD8zMxO9Xp/ra/X09DL5QyItLY1Dh/bj6ur2VHn2lEolQ4e+x4ABr/Hvv0c4fvxfwsJCuH79Gmlpqezbt4f9+/cxbtwEevd+Ndv1lqQKMRd4y+VyKlSoyJUrMcTGxopVp4JFklM1VCnnwCeDfFDbqfK+oBgTwVsp5/j2wxVZSqUc7WPDpiZl35ib4z10sVezLbnOiX3PySjcq2e7r8OA73IdNi0sLVq0wtGxDAcPBvHxxxOQy+UEBx8lKSmRTp1eNHtdbKyhx+rRXphHZR3P6tl6VJkyTtmOZQVRuQ0fZrlzx7AB8vr1a1i/fo3Zcnfv3snzXmXLunPp0kXi4+/nWdacmzdvsGnTes6cOcX161dJSEgAHk4EzmlVYVbQk5fY2HsAuU5Ar1SpMufOhef4Xj8q6zU6ODjmWi6n9sl6LY8H8zntfJH1vs+dO4u5c80nAH68fc6cOcXWrQFERl7gxo3rpKWlmjwjp/cxp7o+GszlFby1a9fRpLfv1q2bHDq0nxo1PPjii2/MXpcXtVpNx46djfNK7927y7//HmHt2tVER1/m55+/p3FjH+MCnSxPkyrkUVltGx9/XwRvzzjdrUiLypV1tmPooKY42pfswA1E8FbqPbr3qEwpRyYzHzCY26c0a/P5vJ+lyvEehTGnzRIqlYoXXmjPjh1bOXkyFF/fZvz9dyA2Nra5TmrP+iA1t2tV1nlVDu9Tfre60usNvWT16tWnWrXsGyTLZCBJ5uv2qLp1vTl27CjnzoXz8su9ci2bnJzMH38swc+vGc2bt0KpVBIYuItvv/0SnU5H1arVaNq0GR4eNfH2ro8k6Zk48ZMc75VbQPGoh+9zbi8m673OffcHrVYL5B0g53deVtb9fX2bGXtUc/JoIPjTT9+zadM6FAoFnp516NChEx4etWjQoCH//nuElSuX5XiP4rRtWnT0ZeLiYo2JeR9Vrlx5evbsTdeu3Rkz5gPCw08TGLiL4cNHWrUOWe99VpJUofjL2mLKnKfZYkp39xIZwf55ltNKCt7s1Qxnh4LdOaawiOBNeKZ06NCZHTu28vffe2nQoBGHDx/kueda59pDkzU0ZW4+V9b8JFdX66dJKVvW8OzmzVsxbNiIbOez9abmom3bdqxcuYwjRw6TkZGBra35oHr//r2sWfMnu3ZtZ/PmXaSmpjJz5gwA/ve/n2jTpp1J+QMHgix9SWZlBT+3buX8PsPD99rNLfd5e05OzoBhZ42ClNU+Xbp0o2fP3nmWDwsLMS6GmDVrPjVqeJicDwraVwC1tL5Jk8Zz7dpVFi36wyQ9zKNsbGzo0qUb4eGnSUx8YPU6PHiQAICTU/YeSaF4ymmLqUc9zRZTcrdqKKo04H5iGkuueqI3k0SjXQsvOpWitDIiVYiQJ5ldGZMNfHOkUBnKFXPNm7fEycmZQ4eCOHr0MKmpKXTq1DXXa7JWtu3fn/MH699/BwLQtKn5VY1Pq2lTP8Cwqi6nXqSDB/fzxhsD+Omn7/O8V/36DWnSpCmxsffM9u4AJCY+YMUKw/levfqiUCi4fPkSqakp1KpVO1vgBnD8uGHOW36SsXp718fOzo7IyAhu3Lie7fyNG9e5cCECe3v7bCtaH1e5chUUCgUJCfFPPcfPElnfG4+nA8myYcNahg59jT/+WAIY9s8FaN++Y7bATafTERJyDCic3Tbyo1EjQ27BdevMD+UDXLtmWOH8+JBpful0Ou7fj0OhUFC5chWr3lsoOKr6HVD3nYZ9z8nGY/Y9J6PuOw1132mo6nd44nvKlDbYdh7F9zee46quHNd1ZXP8b0PIA/T64v1z9SSKLHg7f/58UT1aeEJyx7I4DPxfrj90xTVB7+OUSiUvvNCeuLg4Fi9egL29muefb5PrNR07dsHdvRxhYSEsX77U5IP133+PsGrVChQKRY6Tsp+EjY2hJ+zRnFlNm/pRp05dLlw4z/z5s00msl+/fo2ffvqB6OjLVKtW3aJnfPLJRGxtbfnjjyXMnz+bpCTT3Hw3b95gwoRx3Lx5g2rVqjNkyFsAxjQXV69e4erVGGN5SZIICFjPli2bAMjMzDndjCXs7Ox45ZU+6PV6vvpqinE+HRiSwk6bNgm9Xk+PHq9gZ5f76kKVSkXduvXIzMwkMjLiqeuUl06dXsTdvRwHDwaxZs2fJt8b586Fs3jxAqKiIqld27Di0tXVBYATJ46Rnv5wwUp6ejo//DCd6OjLQP7eR0tVqlSZw4dPPPHWWABDhryFra0tgYG7mDnzu2w9a3q9ni1bNhEQsAFXVzdeeulla1UbgIsXI8nIyKBOHe9ce5CF4kWudkHh7mGYG/0fhXv1/455WDxkqr15noxj640/bxdvppCSR6KE9EwdkdcSnrLmxc8TD5smJSURHR2Nq6sr1arlvILs2rVrhISE0Lt3b7P3GTVqFBs3bsTZ2flJqyAUAbljWXAsa5ILTuFe3ew8ueKsY8cubNu2mStXYnjxxZfyTDNgZ2fHN9/8j08//YjFixewc+d2vLzqcO/eXcLDT6NQKPjoo/Fmh48sVa1aNS5dimL06OFUr16DyZO/wt7enmnTvuOjjz7E338V+/btoU4dbzIyMjh1KhStVku7dh149dUBFj2jVq3azJ79GxMnjuOvv1ayadM6vL3r4+ZWlnv37nDu3Fl0Oh21atXmhx9mG9NxVKlSlTZtXuDw4YMMHTqEpk39sLGxITIygjt3buPhUYuYmMvcv//0iyEAhg8fSWTkBU6eDGXAgF74+Pgik0FYWCipqSn4+TXnww9HW3SvNm1e4Ny5cE6eDKNevQb5qpc5j35vzJv3Cxs2rMPT05MHDx5w5swpJEmif//BtG3bHjAM2//++2IuX77EgAG9aNCgERqNIa1JcnIyNWvW+m8+mfW3mztw4G+Lh7fzWsBQo4YH06fPZNq0yWzevJHt27dQr1593N3Lk5GRTkTEee7fj8PNrSw//DALtdoh2z1OnQrj66+n5lmXXr360qRJ08euNazsLuydJYSip715nrSds0CXicypHDbe7UhIseyPHUvLlQRPFLzNnz+f3377zTgZ2MfHh6+//hovLy+TcmFhYXz++ee5Bm92dnZ8/PHHLFmyJMeJuJmZmUyaNIkff/zxSaooCHny9W2Gi4sLCQkJua4yfVSjRk34/fdVrFz5B8HBRzh8+ADOzi506tSFgQOH5DtwA5g4cSo//vg/oqMvERsby82bN6hd25Pq1Wvw+++r+OuvFRw6dIATJ4JRq9V4e9end+++dO7czSTpcF4aNmzEypXr2LRpHUeP/kNUVCRpaWmo1Q40atSETp1e5OWXe2VbgPHVV9/x119/snfvbk6eDMHBwZGKFSvRp08/+vcfzLBhb3HpUhQREefx9q73VO+Bra0ds2bNZ9OmdezatYPQ0OMoFApq1qxF9+496dmzt8ULILp168Hvvy/iwIG/GTz49aeqjyUaNWrCsmWrWbVqOcHBR/n33yM4OTnh69uMV18daLIYxsHBkYULl7F06UJCQo4THHwEV1c3vL3r07Nnb/z8WtCzZxeOHfsXrVZr1US3UVEXjYmg82LJ6tNWrVqzZs0mAgLWc+zYv1y/fo2IiPPY2tpRtWo1+vbtz6uvDqRMmZynU9y8eSPHfHaPa9asRbbgbf/+fahUKqv36AnFm/bWBdJ2GQI3RbXGqLxaA+DiYFkngqXlSgKZZOHkiq1bt/Lpp5/i4eFBhw4duHPnDoGBgSgUCmbNmkWHDg/Hqrds2cJnn32W69Do5cuX6d+/P4MGDeLTTz81OXf//n0+/PBDzp49S3h4+FO+tJJJp9Nz/372rXEep9FkEhd3i7JlK+W58i7Lk0xuN0fSZBgT/zq+vbBE9ryVJtZo09Js5szv2Lx5I8uXrzEOXRZ3ok1zd/lyFG++OYjevV9l/PjPi7o6FimObfo0nyHW8jSfI9pbF0jb+TNoM1BUbYj9i2OMO/mkpWsZPfsguU1ps7NRMG/sC8jl+V+1rVTKcXV1ID4+xert6ubmgMKCfVYtnvP2559/UqdOHWNg9vPPP7Np0yaqVKnC6NGj2bnTsr/ostSqVYsZM2bw+++/s2vXLuPxyMhI+vXrR0xMDIsXZ88GLgiCYKm33noXGxsb1q/PO5WAUDKsX++PjY0Nb7zxdlFXRSgk2tsXDT1u2gwUVRqYBG4ZGh1zN57ONXADGNTJyyqBW3FhcfAWGRlJ3759sbF5GKF7enri7++Pj48P48ePJyAg4Ike/uKLL/LOO+8wadIkoqKiOHDgAIMGDcLGxoa1a9fy3HPPPdH9hIKjT01AFxuDLvaq8Zgu9up/x2LQ55K7RxCKSvnyFXjvvQ/ZsWMLMTHRRV0dIZ+ioy+zffsW3nvvAypUqFjU1REKgZSeTNqun0GTbgjcun5kErjNWX+aiKsJ2NsqeLVdLVwdTXsR3crYMrJPQ15oknOS9ZLK4gkVcrkcB4fsk04dHR1ZunQpI0aMYNKkSWRkZGBvb5+t3OjRo/H29qZu3bp4e3tTtaohI/Ynn3xCeHg4Q4cOJT4+npYtWzJ79myz8ySEopFTfp5Hd114mvw8glAYBg9+neDgo8ydO4uffppT1NUR8mHevF9o3NiHQYMKbg6jULzI7Byxa/06motHsO/6sMctU6Nj7obTnL8Sj52NgnEDfPCs4kw334qcWvIliXp7KvQYQV2PcqWqxy2LxcFb1apVOXv2LP379892ztbWlt9++42PPvqIadOm0axZs2xlTp06RWCgIR+WTCbD0dHRGMi1bt2akJAQ+vbty1dffWXxhGSh8Kjqd0Dp0dTsedkTZsUWhMIik8mYPfvXoq6GYAUi+H52SJJkXMyoqvM8Sq/Wxq+zArdzMfHY2ij4+L/ADUAul+GlMmxH51jNGVkpDNzgCYK3Vq1asXXrViZNmmQydJpFpVIxd+5cxo8fz86dO7OtID148CAJCQmcP3+eCxcucP78eSIiIlizZo1x9eqmTZs4efIkdevWpV69enh7e/P888/n8yUK1iBXu4AI0ARBEIQCprsXTfo/f2L/4mhj7resmEKj1TFv4xnOxsRjq1Iwrn8TPKs+eynHLA7eevXqxb179zh37hw+Pj45llEoFPz888+UL1+ec+fOZTvv4uLCc889ZzKXTaPRcOnSJSIiIowB3aFDh9i2bRsymUwk8xUEQRCEZ4TuXgyp22dCZioZx9Zj3/494zmNVs+8jeGER9/HRiVnbP/G1KnmUnSVLUIWB2/169fn559/zrXMhg0b8Pb2Zvz48Tlu0p0TlUqFt7c33t7eJnnhbt++TUREwWVGFwRBEASh+NDFXiF1hyFwU1Twwq71EOM5jVbP/E1nOHM5DhulnLH9mlC3umsR1rZoWXVy2eTJk+nXrx/bt2/P970qVqxI+/bt81+pUq/07NUmCIIgFJbi9dmhi71C6vYfICMFeQVP7F/6GJmNYfGjVqdnQUA4py8ZAreP+jXGu8azG7jBU2yP9SRiY2PRarW4u7tbNVO4gHFRh06nw8JOTkEQBEEAQKczzDUvzAWC+uQ4pPQkpEf2aNbFXkVKiSP90B+gSUdevhbqlz7JFridjIpFpZQzpl9j6nm4Zb93agJSakK2e8v++4CUqV0s3ju1JLB4h4XH/f3333Ts2NHkmLe3NzKZjCZNmnDlyhXjxtJyuZy6devSrl07+vfvT+XKBZdvRaPRsHLlSjZt2kRMTAxqtZpGjRrx1ltv0bZt22zlY2Nj+fXXXzl06BB37tyhXLlydOvWjREjRuSYGkWv17Nx40ZWr15NTEwMKpUKPz8/Ro4cSYMG+d8/0dIdFgx1v4VcrsDVtVyOW4w9rjhm+RbyR7Rp6SPatPQpbm0qSRLx8ffQ63W4u1cqlGfqk+NI8Z8IOk0upWSo+32Dws2QSkyr0/Pb5rOERt5DqTD0uDWomT1wA8g4sSlbOqtHWTOdVXHYYeGJg7fExES+/vprtm/fnm0xQVbwBoZvjmwPk8lQKBS88cYbjBs3LsdVq/khSRKjR48mMDDwv70FfcnIyODEiRNoNBrGjh3Lhx9+aCx/9+5dBg0axI0bN6hTpw41a9bkzJkz3Lx5k7p167J69WocHR1NnvHFF1/g7++Ps7MzLVq0IDY2lrCwMFQqFYsWLaJ169b5eg1PErylpaXw4EEsNjb2qNUOKBRKwHwQp1DI0OmKV1e5kD+iTUsf0aalT/FpUwmdTktqagqZmWk4O7tjb5+9k6Ig6GJjSN04Lc9y6r7TULh7oNXpWbjlLCEXDIHbmFcb0bBWWbPXZfW8mWPNnrfiELw90Vjm3r17mTZtGg8ePGDKlClmy0mSRPfu3enQoQMuLi7ExcVx/Phx/v77b+Lj4/njjz84c+YMCxcuzLF362mtWbOGwMBA6tWrx7Jly3B1NYyJR0REMGTIEGbPns2LL75I7dq1Afj222+5ceMGw4YN45NPPgEgMzOTCRMmsHPnTubNm8fEiRON9w8KCsLf3x8vLy9WrFiBm5vhL4Ddu3czbtw4Jk6cSGBgILa2hbPfZ9YPXUpKIgkJsXmWl8vl6PXF568/If9Em5Y+ok1Ln+LWpkqlTaEGbk9Kp9ezaOu5/wI3GaP65h64wbOXzsri4O2vv/7i66+/plq1aixcuDDXIcJJkybx5ptvmhzr3bs3er2ev/76ix9//JGQkBA+//xz5syxXtLFzZsNXaYTJ040Bm5g6BHs2bMnf/31FwcPHqR27dpcvXqVwMBAKlWqxJgxY4xlbWxs+Oabbzh48CD+/v6MHTsWOzs7AJYuXQrAhAkTjIEbQNeuXenZsycBAQHs3LnTZNVsQbO3d8De3gGdTpvrLweFQoazs5oHD1KLyV+AQn6JNi19RJuWPsWtTeVy+X+jNMWTXi+xdOs5TkTcRSGXMbJPIxrXzj1wexZZ3IJxcXFIkkS/fv1yDdwUCgWDBg3K8ZxcLmfIkCG0atWK119/ncDAQI4ePWq1PUyXL19OdHQ0Xl5e2c6lpqYa6weGpMF6vZ527dplS2tSpkwZWrVqxb59+wgODqZdu3YkJycTEhKCWq3OcWi0S5cuBAQEsH///kIN3rIoFEr+e2k5Uirl2NnZkZamK1ZzL4SnJ9q09BFtWvqINn0ymw5Fc+wixsCtiad7UVepWLJ4mclLL71E/fr1mTVrFuPGjSMlJfu8LDs7OxwcHPKcy1a7dm0+++wzJEli/fr1T15rM2xtbfH29jYGaFn27t3Lrl27sLe358UXXwQgMjISgDp16uR4L09PT5NyUVFR6PV6atWqlePK2ayh2KzygiAIgiA8mfDLcSjkMkb0boiPlwjczLG456127dqsW7eOhQsXsmDBAs6dO8fu3btNyri5uXH79m3u379vMqyYk+7duzNlyhRCQ0OfruZ5yJqXFxUVxeXLl6lUqRIzZsygYsWKANy7dw+AcuXK5Xh91vHY2NinKp8fSqX1l25nTYC0ZCKkUDKINi19RJuWPqJNDbRxVywqJ5fLGNmrEc28yxdwjZ5ecWjTJxr4VigUjBgxgs6dOzNp0qRs5xs1asStW7dYvXo1o0aNyvVeNjY2qNVq4uLinqzGFrp27Rp79uwxfi2TyYiKijIO0WYNo2bNZ3tc1vGsclk9jfb29haVf1pyuQxX14KbROrklHP9hZJLtGnpI9q09HmW2zT1Uhjxh1daVPbN7vVp+VzNAq6RdRRlmz7VrMU6deqwdu3abMf79OnD7t27+e2336hcuTJ9+/Y1e49bt26RmJiIs3PBbChbs2ZNjh07hiRJHDlyhOnTp/Ptt9+SnJzMhx9+aBxaNZcfLSvVSdb/8yr/+HVPS6+XSEzMXwCYE4VCjpOTPYmJaeh0Yt5FaSDatPQRbVr6iDaF1PMhoNMiIUOWy84OOpkCT4+KxMdbli6rqBRkmzo52Vs/VcijcsrK3L59ezp06EBQUBCTJ09m//79vP322zRt2tSkXHJyMpMnTwagbt26T1uFXD2agqR79+5UrFiR1157jUWLFvHmm2+iVqsByMjIyPH6rONZPW1Z5dPT03Msn3XcXM/ckyjISa06nV5Mmi1lRJuWPqJNS59nuU1VLQYglanA93+noE0z3zmhsC/DVFtX5CXkfSrKNrX6euFffvmFjz/+mH379hEYGEhgYCDu7u40btwYV1dXEhISCA4OJjk5GZlMxsCBA61dhRz5+vpSvXp1rly5QkxMDOXLG8bTs+ayPe7xOW5Z5c3NactrTpwgCIIgPCu0106jqFwPmUKFTCYj2qEJMclhQC4dHMkQeS3hmd+31BJWD95sbW2ZP38+AQEB/Pbbb8TExHDv3j327duXbfeF119/nR49eljluWlpacyePZvY2FhmzpyZ4/Bm1ipYrVZrXGV66dKlHO938eJF4GHPoKenJ3K5nMuXL6PX67P1PEZFRQHmV68KgiAIQnFnjZ0KMsP3knHkT5Qevth1HolMriAhJedRrsdZWu5ZV2CZ+nr37k3v3r0JCwvj6NGjREZGcufOHZRKJTVr1uSVV16hWbNmVnuenZ0dmzZtIiEhgQEDBtCiRQuT89euXSM6OhobGxu8vLxwdzcsQQ4KCuLzzz83SS+SlJREcHAwarUaPz8/wDAc2rx5c4KDgwkODs6Wmy4wMBCAdu3aWe01CYIgCEJh0pwLytceoRknd5B5zDAnXlamHMgMHR0uDpbtPGRpuWddgadZbtq0abY5bwUhawh24cKFTJs2jT/++MM41Hn79m0+/vhjtFotb731Fmq1GrVabZyfN3PmTD777DNkMhmZmZl88cUXpKSk8M4775jsbTpkyBCCg4P55ptvWL58uXGIdM+ePWzbto3y5cvz8ssvF/hrFQRBEISCoKrfAaVHUySNhrSt0wGw7zkZ2X/J7GVmet0kSSIzJMAY+Nn4voKNXx/jKJhnFWcUchk6vfkFC3Y2CupUy/n+gqniu0fGUxgxYgShoaEcP36crl274ufnh0aj4fTp06SmptKmTRvGjx9vLD916lTOnj3LsmXLOHDgAF5eXsaN6Rs0aJAt3UnWNlhbt26lW7dutGrVivj4eEJDQ1GpVPz44495JigWBEEQhOIqa49QSfNw+FLhXh2ZynyPmCRJZAT7ozm9CwCbFv2w9XnYkaHT61my/VyugRvAoE5eyOW5Z3QQDGRSfnNbFDMajYYVK1awefNmoqOjUSqVeHl50bdvX/r3759t94U7d+4wd+5c9u/fz4MHD6hcuTLdunXj/fffN+l1y6LT6Vi9ejVr167lypUrODk50bhxY0aPHk29evXyXX+dTs/9+9ZfJq1UynF1dSA+PuWZXfFU2og2LX1Em5Y+JbVNJU0GycuGA+D49sJcg7eM4LVkntoBgG3rIdg07GI8p9XpWbTlLCcu3EMhl9GlWVWCz90hPjnTWMatjC2DO3vhV7f4JuZ9VEG2qZubg0WpQkpd8FbSieBNsJRo09JHtGnpU1Lb9EmCN+3tSNJ2/oxtq0HY1Gv/8LhOz2+bzxIaaQjcRvRpSFOvcugy0jm15EsS9fZU6DGCuh7lSlSPW3EI3krVsKkgCIIgCIVLWbEODoN+QG7vZDym0epZEBDOyahYlAo5o/o2pHFtw0JBuVyGl+oOAI7VnJGVoMCtuHi2N1sTBEEQBOGJSDoNafsXo4u7ajxmGrjpmL/pDCejYlEp5Yx5tZExcBOsQwRvgiAIgiBYRNJmkLZ7NtrIf0jb9QuSTmNyPlOjY86GM5y+FIeNUs6Yfo1pWKtsEdW29BLDpoIgCIIg5EnKTCNt9y/obl0ApQ127d9DplAZz2dodMxZf5rzV+KxUckZ26+J2C2hgIjgTRAEQRAEAPTJcUjpSUiahz1qutirIGlJ/2cVUvx1UNlj/9LHKCt6GcukZ2qZs/40EVcTsLVRMK5/E5GzrQAVaPB26NAhgoKCuHz5MklJSWzYsIHExERWrFjBa6+9hpubW0E+XhAEQRAEC+mT40jxnwiPDYVmJevNYtdxuEnglpah5Zd1p7h4/QF2Ngo+HuCDZ1Xn7Pf/b+utxwPDRxMA57X1lmBQIMFbXFwcY8eO5cSJE4AhgV9WluWbN28yb948Vq5cyaJFi2jSpElBVEEQBEEQhCcgpSdlC9xyIndwMf47LUPLz2tPculGIva2Sj4e2ITalbMHbpDz1luPBoZ5bb0lPGT14C0zM5N3332XiIgIHB0dad26NadOneLu3bsAyOVyXFxcSEhI4O2332br1q1UqVLF2tUQBEEQBKEApaZr+Mn/FNG3ElHbKvlkkA81KzmZLZ+19ZY55rbeErKz+mrTVatWERERgY+PD3v27GHOnDkmwVmdOnXYu3cvTZs2JS0tjWXLllm7CoIgCIIgFKDkNA0z15wk+lYiDnZKPh3cNNfADQxbbyncPcz+J4ZMLWf14G379u3I5XJmzpxpdk6bo6MjP/74IwqFgkOHDlm7CoIgCIIgFJDUdC0//hXGldtJONqr+HRwU2pULFPU1XqmWD14u3z5MrVr16ZatWq5lqtSpQoeHh7cunXL2lUQBEEQBKGALN91gat3k3FSq5jwWlOqVxCBW2GzevCm11u+z5dKpcq2UbwgCIIgCIVPH3fNonJ341NxdrBhwmu+VC3nWMC1EnJi9eCtSpUqxMTEkJycnGu5+Ph4Ll68KBYrCIIgCEIR096MIP2flRaVLfNfj1tld4cCrpVgjtWDt3bt2qHRaJg5c2au5b799lt0Oh1t27a1dhUEQRAEQbCQ9tpp0nb+BNpMIPdN4jWSgrd6N6NSWRG4FSWrpwp599132bBhA2vXriUuLo6ePXuSlJQEwKVLl4iMjGTVqlWEhITg4ODA0KFDrV0FQRAEQRAspE+KA50GRfUmRFV4kfV7z5kt+2KberSpUrUQayfkRCZJkmTtm4aEhDBixAgePHhgTM77KEmSUKvV/PLLL7zwwgvWfnyJptPpuX8/xer3VSrluLo6EB+fglZr+bxEofgSbVr6iDYtfUpKm2qvhCGr3JDxC4N5kJxptpyLow0/jngeuTz3HrrSrCDb1M3NAYUi70FRqw+bAvj5+bFlyxbefPNNKlWqhCRJxv/Kli1Lv379CAgIEIGbIAiCIBQBzeVjSOkP56YrazTl4s3kXAM3gITkTCKvJRRw7YS8FNjephUqVGDSpElMmjSJ1NRUkpKSUKvVJCQkUK5cOezs7Arq0YIgCIJQKmXtD2qOJfuDZoYHknFkFXL3Gqh7TkKmsgUgISXDojpYWk4oOAUSvGm1WubOncuWLVvYtWsXarUatVoNwOTJkzl8+DBDhgxh9OjR2NjYFEQVBEEQBKHUyWl/0EfltT9oRtg2Mo+vB0BRuR4oH34GuzjYWlQHS8sJBadA9jZ9//33OXbsGADR0dF4e3sbz9+7d4/U1FSWLFnChQsXWLRokbWrIAiCIAilUtb+oJJGY9zU3b7nZGQqFWB+f1BJksg8voHMk9sAsPHrjY1vL5N56ZbMY7OzUVCnWs7PEAqP1ee8rVy5kuDgYFxdXZk5cyaenp7Zzs+fPx93d3cOHTrEunXrrF0FQRAEQSiVHu4PWt14TOFePdf9QSVJIuPoamPgZttyALZ+vU0Ct/Mx95m19lSezx/UyeuZXqxQXBTY3qaLFy/m5ZdfRqk07dxTKpV06tSJ+fPnA7BhwwZrV0EQBEEQhP9kntiIJjwQANvn38CmSXeT86eiYpm17jQZGh0NPFwZ1rM+ro6mU5rcytgysk9DXmhSudDqLZhn9WHT6OhoPDw8aNCgQa7lGjduTNWqVYmMjLR2FQRBEARB+I+qbls0kf9g26wPqrqmifGPnb/D4q3n0Oklmnq580GvBqiUCpp7unBqyZck6u2p0GMEdT3KiR63YsTqwZtMJrN4EUKZMmW4d++etasgCIIgCM80SZKMw6Jyp/I4DJyBTGm60ODQ6Zv8sTMCSYJW9SvwTo96yDMS0SUkIGk0eKnuAGBv/wDpfio6LFvNKhQ8qwdvVatWJSoqivv37+Pm5ma23IMHD4iKihJ7mwqCIAiCFUnaTNL3LUDl3Q5lDR+AbIHbvpDrrAo0jHy90KQyb3ati1wuIyOH1axZCyMg79WsQuGwevDWqVMnIiMjmTRpEnPmzMmxF06r1TJ16lQ0Gg3t2rWzdhUEQRAE4ZkkZaaRtns2ulsRaG9H4jj4R2Q29iZlth+NYcOBywC82LwaAzt6GnvpslazmmNuNatQuKwevA0ZMoS1a9dy4MABunfvTq9evfD29katVpOSkkJkZCRbt27l6tWrODk58c4771i7CoIgCILwzJEyUkjd+TP6u5dAZYd9149MAjdJkth48DLbj14B4JXnPejVpqZpuhC1C4gArdizevDm7u7OnDlz+Oijj7h+/Tq//vprtjKSJOHi4sK8efMoX768tasgCIIgCKWSPjkOKT0JSaMxHtPFXkXSZZLxz0qkB7fB1gF19/EoytV8eJ0k8dfei+wLuQ7AgA6edGtZPdv9hZKhQHZY8PPzY8eOHaxZs4b9+/dz9epVEhISsLe3x8PDg3bt2vHaa6/lOidOEARBEISH9MlxpPhPBJ3G5Pijc9IA7Dp9YBq46SX+2BnB4TO3AHjjxTp08K1a8BUWCkyB7W3q5OTEsGHDGDZsWEE9QhAEQRCeGVJ6UrbALSdyuzLGf2t1ehZvPcfxiLvIZPBuj3q0blipIKspFIICC96Kil6vZ926dWzcuJGLFy+i0WioXLkynTt3Zvjw4Tg5OZmUb9myJQkJCWbvd/r0aWxtH67S0ev1bNy4kdWrVxMTE4NKpcLPz4+RI0fmmdtOEARBEAqLRqvj103hnLoUh0Iu44NeDfCrK6YqlQYFGrylpaWRlJSETqdDkiSz5SpXtk7GZr1ez5gxYwgMDMTOzo7GjRujVqs5ffo0S5YsITAwkNWrV+Pu7g7AjRs3SEhIoEKFCrRo0SLHe8rlpptQTJs2DX9/f5ydnWndujWxsbHs27ePgwcPsmjRIlq3bm2V1yIIgiAITys9U8vcDWc4fyUelVLOqL6NaFSrbFFXS7CSAgneDhw4wC+//EJERESeZWUyGefOnbPKczds2EBgYCAeHh4sWbKEatWqAZCcnMz48eMJCgri22+/5ZdffgHg/PnzAHTr1o1Jkyblef+goCD8/f3x8vJixYoVxjl7u3fvZty4cUycOJHAwECTnjpBEARBKEzpGVp+8T/JpRuJ2NooGNuvMXWruxZ1tQQrsvrepidOnGDEiBFEREQgSVKe/+n1eqs9O2uf1IkTJxoDNwBHR0e+++47ZDIZe/fuJT09HYCzZ88CWDzcuXTpUgAmTJhgstiia9eu9OzZkzt37rBz506rvBZBEARBeBrLd13g0o1EHOyUfDqoqQjcSiGr97wtWbIEnU5H3bp1GTVqFLVq1cLOzs7aj8mRi4sLtWrVwsfHJ9s5Nzc3nJ2dSUhIID4+nkqVKhl73ho2bJjnvZOTkwkJCUGtVuc4NNqlSxcCAgLYv38/vXv3zu9LEQRBEAQT2isnLSp3+34qTmonPhnUlGrlHQu2UkKRsHrwFhYWhq2tLUuXLjXOLSssv/32m9lz165dIyEhAZVKZew1O3v2LHZ2doSHhzNlyhQuXryITCbD19eXESNG0KRJE+P1UVFR6PV6atWqhVKZ/W2rXbs2AJGRkVZ+VYIgCMKzLvP0TjJDAiwq66S2YcRgPyq6qQu2UkKRsXrwlpaWhqenZ6EHbnnJmufWvn17bG1tiYuL4+7du4BhGNTHx4eWLVsSGRnJ/v37OXz4MDNnzqR79+4A3Lt3D4By5crleP+s47Gxsfmuq1Jp9dFsFAq5yf+Fkk+0aekj2rT0sUabph3fRMbxTYYvZHKQzE830koK3u3XgnKix63AFIefU6sHb5UrVyYuLs7at82XlStXsm3bNuzt7Rk3bhzwcL6bq6srCxYsoGlTw15ukiSxfPlyZsyYweeff46vry8VK1YkJSUFAHt7+xyfkTU0nJqamq+6yuUyXF0d8nWP3Dg55Vx/oeQSbVr6iDYtffLTprZejbgduhW3FwYRmunBuh1hZsv26NSIlxvWeepnCZYryp9Tqwdv3bp1Y+HChRw9epTnnnvO2rd/YitWrDAuVpg+fbpxeLNt27YcOnQISZKoUKGCsbxMJmPo0KEcP36cvXv3sn79ekaNGoVCoTCez01uKVEsoddLJCbmLwDMiUIhx8nJnsTENHQ66y0SEYqOaNPSR7Rp6WOVNnXxxOm1H9A5lGXBj/tJ15lP+bHiwB2ea5aMXJ77Z5Xw9Ary59TJyd6iHj2rB2/Dhw9n3759TJgwgS+//JIXXngBGxsbaz8mT5Ik8eOPP7JkyRIUCgXTp0+nR48exvMymSzXfVU7dOjA3r17CQ8PB0CtNswdyFqp+ris4+Z65p6EVltwv7R1On2B3l8ofKJNSx/RpiWbPjUBKTUBMHzQZ6TYk5H08INepnYxbABvhpSZRvqBpdg064vC9b88qPZunI++T3qmLtdnp2XoOBd9H+8aYoVpQSvKn1OrB29TpkyhYsWKXLx4kdGjR6NQKHB2dkalUuVYXiaTERQUZNU6pKen8+mnn7Jnzx7s7Oz46aef6Ny58xPdI2sOW1paGoAx0DM3py2vOXGCIAjCs0FzLojM0M3Gr5MeO2/j2wvbZn1yvFaflkjazp/Qx15Bn3AL9avfIPsvWXxCSoZFz7e0nFByWT142759u/HfkiSh1WpznQOX1zDkk0pOTua9994jLCyMsmXLsmDBApNVo1n8/f05evQoL7/8co6B3bVr1wCoWLEiAJ6ensjlci5fvoxer8+280JUVBQAdeqIuQaCIAjPMlX9Dig9miJpNMZN4x37TEEvM3zkysz0uumTYkndMRPpwR1kdmWw6/C+MXADcHGwLAG8peWEksvqwduMGTOsfUuLaTQahg0bRlhYGDVq1GDp0qUmyXoflZVQNy0tLVvwJkkSmzcb/mpq06YNYBgObd68OcHBwQQHB2ebzxcYGAhAu3btrP2yBEEQhBJErnYBtQuS5mEPmNK9BjpZziNQALr7N0jbMRMpNQGZY1nU3T9F7lLReF6SJC5cjc/z2S6ONtSp5pKf6gslgNWDtz59cu4KLgzz5s0jJCSEcuXKsXLlSpOFCI/r06cPixcvZv/+/axdu5YBAwYAhv1R586dy+nTp/H09KRbt27Ga4YMGUJwcDDffPMNy5cvNw6R7tmzh23btlG+fHlefvnlgn2RgiAIQqmiuxNF6q5ZkJGC3LUy9t0/Re7wcM6aXpL4K/Ai+0Kv53mvIV3qiMUKz4AC3Zi+MD148IDly5cDULZsWWbOnGm2bNb2WdOmTWPKlClMnTqVP//8Ew8PDyIiIrhy5Qru7u7MnTvXZK5e1jZYW7dupVu3brRq1Yr4+HhCQ0NRqVT8+OOPRbI4QxAEQSi5MkICDIFb+dqou41DZvcwR5tWp2fp9vMEn7sDGIIzF0cbVgdGEp+caSznVsaWwZ298KtrfiGeUHrIpPzmtshFXFwcaWlp2dJnaLVa0tPTuX37NkFBQXz99df5ftbBgwd5//33LSq7Z88eatSoAUBoaCiLFy8mNDSUlJQUypcvT8eOHfnwww8pWzb7cmydTsfq1atZu3YtV65cwcnJicaNGzN69Gjq1auX79eh0+m5fz8l3/d5nFIpx9XVgfj4FLGKrZQQbVr6iDYtXSRNBsnLhgPg8v5is8OmUkYKGSEB2Dbvh0z1cL5aRqaO+QFnCL98H4Vcxrsv16OFhx1SagK6jEzCA5aSqLenXJtXqVPFEblcludKViH/CvLn1M3NwaJUIQUSvK1bt47Zs2dbnKw3a49RQQRvguVEm5Y+ok1Ll9yCN93dSyjK1zZ7bXKahtnrT3HpRiI2Sjkj+zaiUa2yZJzYZLKS9XG5rWQVrKM4BG9WHzY9evQoU6dOtaisq6urmOAvCIIgPDMkSSIzJIDM0M3YPvcaNo1ezFYmPimDn/1PciM2BQc7JR/1b4JnFWfg4UpWc8ytZBVKF6sHb3/99RcALVq0YMyYMdjZ2dGvXz969+7Nhx9+yO3bt1m7di3bt2+nUqVKTJ8+3dpVEARBEIQio0+OQ0pPQtJojMe0sVfQoUBzcgfa6OOAIRnv427fT+WnNSeJS0zHxdGGTwb6UKXcwzlwWStZhWeb1YO3kydPolQqmTlzpnG1Z40aNThz5gw1atSgRo0atGzZkjJlyuDv78+6desYNGiQtashCIIgCIVOnxxHiv9E0GlMjidv+tbka5tmfbD17WVyLOZ2IrPWniIpVUMFV3s+GeiDu4vY51bILu+B1ScUHx9PlSpVTNJ01K1bl+joaONuBQBjxoxBoVCwbds2a1dBEARBEIqElJ6ULXDLibK6afL481fi+WF1GEmpGmpUKMPnr/uJwE0wy+rBm1KppEyZMibHqlevjiRJXL582XjMzc2NGjVqcOnSJWtXQRAEQRBKjJALd5m19iTpmTq8q7sw4bWmODmItFOCeVYP3tzd3bl165bJsaxdDi5evGhy3MbGhqSkx3d9EwRBEIRnw8FTN/k1IBytTsK3TjnGDWiCvW2pScEqFBCrB28+Pj7cv3+fgIAA47HatWsjSRKHDh0yHktMTCQmJibHXGqCIAiCUJpJksT2ozH8sTMCSYK2jSvxYe8GqJSKoq6aUAJYPXgbMGAAkiQxefJkxo4dS2ZmJj4+PpQvX54dO3Ywb948goKCGD16NOnp6Xh6elq7CoIgCIJQrO05fo0NBwxTibq3qsHQl7xRyK3+kSyUUlb/TmnevDnvv/8+Op2OoKAgbGxsUCqVvPPOO0iSxPz58xkxYgTBwcEAFu+KIAiCIAjFnfamZUnn/z1r2O5qQAdP+rWvjUwm9iMVLFcgA+uffPIJbdq04fDhw8ZjQ4cOJTk5md9//53U1FScnZ0ZO3YsrVq1KogqCIIgCEKhyjz3N5n/+ltUVi6T8W6PejzfqFIB10oojQp0b9OcaLVa4uPjcXNzQ6EQY/uPE9tjCZYSbVr6iDYtmR7dNQEAmRwk8+2nkRTcbD2Rho28CqmGgjWVyu2x8nygUkm5cuUK+7GCIAiCYHWSXkfG4eVoIg4Chr1FI5T12BB4xuw1zzfzoqsI3IR8EOuRBUEQBOEpSelJaK+Fg0yG7fNvovRuzx+//sMDnflMCrvPJtOlnYRcLua5CU8nX8Fb+/btkclkrFixwpjLrX379k90D5lMRlBQUH6qIQiCIAhFQq52wf6lT5AS76L0aErElXgeJGfmek1CciaR1xLwruFaSLUUSpt8BW+3b99GJpOh1WpNjj0JscJGEARBKEz61ASk1ASz52VqF8MG8OauT4pFH38dZXUfABRuVcCtCgAJKRkW1cHScoKQk3wFbzNmzAAwmcOWdUwQBEEQiiPNuaCHiwtyYOPbC9tmfXI8p7t/jbQdPyGlJ2Pf41OUleqanHdxsLWoDpaWE4Sc5Ct469Mn+zd3YmIiXl5etG7dOj+3FgRBEIQCoarfAaVHUySNhrSt0wGw7zkZmUoFGHrecqK9GUHantmQmYbctQryMqaL7yRJIupGQp7Pt7NRUKdazs8QBEtYfcHCkiVLSEpK4sCBAzg7O1v79oIgCIKQL3K1C6hdkDQPhy4V7tWRqcz3hmkuHyf974Wg16KoWAf7rh8hs3UwntfrJVYFRhIUdiPP5w/q5CUWKwj5YvXgLSEhAS8vLxG4CYIgCKVCZvheMo6sAiSUHn7YdRyOTGnz8LxGx8ItZwm7GIsMGNTZC7cytqwOjCT+kcULbmVsGdzZC7+65Qv/RQilitWDt1q1anH9+nVSUlJwcHDI+wJBEARBKKa0V0+TceRPAFT1O2Lb+nVkj+xBmpSayZwNp7l0IxGlQs6wnvXxrW6DlJpAoz7lCQ9YSqLengrt+uFZ0QG5PBV9akKuCyIEIS9WD96+/PJL3nvvPd577z3GjRuHj48PNjY2eV8oCIIgCMWMolpDlJ6tkLtUxqZpT5MMCfcS0vh57Snu3E/FwU7J6FcbU6eaCxknNhkXRHip/iv874+k//fP3BZECIIlrB68rVq1iurVq3Py5Eneeust5HI5ZcqUwc7OLsfyIs+bIAiCUJxImgyQy5EpVMhkcuw6DM+W1irmdiK/rDtNYkomZZ1sGTfAh8ruhtGmrAURAAqFHKcy9iQmpaHTGbZSMrcgQhAsZfXgbfv27SZf63Q6EhISzJYXed4EQRCEwqRPjkNKT0LSaIzHdLFXkalU6NNTyPjXH4VLRew6fYBMJs/2OXXmchy/bgonQ6OjajlHxg1ogmuZh4sdshZEgGEfTFtXB5R2KSD2qxWsxOrBm8jzJgiCIBRX+uQ4Uvwngk5jcjwrZUgWbXIsUlIsMifTxQWHT9/ij50R6CWJejVcGdW3Efa2YqdJoXBZ/Tsup9xvgiAIglAcSOlJ2QK3nNi1ewf5I4GbJElsOxLDpkPRALRqUIF3utdDqZCbu4UgFBjx54IgCIIgPEZext34b51ez597Ijlw8iYA3VvVoG+7WsjFtB+hiBRo8BYXF0daWhqSJJkc12q1pKenc/v2bYKCgvj6668LshqCIAiC8FQyMg053E5GGXK4vdalDp38qhZ1tYRnXIEEb+vWrWP27NnExcVZVF4Eb4IgCEJxk5iayZz1p7l8MxGVUs6wng3wq1su7wsFoYBZPXg7evQoU6dOtaisq6sr7dq1s3YVBEEQBCFf7iem89OGEO7Gp+Fgp+Sjfk3wrCp2DhKKB6vPtPzrr78AaNGiBX/++Sfr168HoHfv3uzevZvly5fTo0cPACpVqsT06dPN3ksQBEEQrEnS5r1YAWDp9vPcjU/D3dmOSW/4icBNKFas3vN28uRJlEolM2fOpEKFCgDUqFGDM2fOUKNGDWrUqEHLli0pU6YM/v7+rFu3jkGDBlnt+Xq9nnXr1rFx40YuXryIRqOhcuXKdO7cmeHDh+Pk5GRSPjY2ll9//ZVDhw5x584dypUrR7du3RgxYkSO23vp9Xo2btzI6tWriYmJQaVS4efnx8iRI2nQoIHVXocgCIJgXVJGinGrq7ykpmupXsGRcf2b4OxofsN6QSgKVu95i4+Pp0qVKsbADaBu3bpER0eTlpZmPDZmzBgUCgXbtm2z2rP1ej1jxozhiy++ICIiggYNGtC6dWsSExNZsmQJ/fr1IzY21lj+7t27DBgwgFWrVmFnZ0f79u3R6/UsWbKEwYMHk5ycnO0Z06ZNY/LkyVy/fp3WrVtTs2ZN9u3bx8CBAzly5IjVXosgCIJgPfrkOFK3fIc+9kqeZTWSnMpVK/DZa74icBOKJav3vCmVSsqUKWNyrHr16kiSxOXLl429U25ubtSoUYNLly5Z7dkbNmwgMDAQDw8PlixZQrVq1QBITk5m/PjxBAUF8e233/LLL78A8O2333Ljxg2GDRvGJ598AkBmZiYTJkxg586dzJs3j4kTJxrvHxQUhL+/P15eXqxYsQI3NzcAdu/ezbhx45g4cSKBgYHY2oofdkEQhOJCd/8aaTt/RkqJR6Z24Wrtvqw5fMds+QoVyzN8QBuRw00otqz+nenu7s6tW7dMjmUFURcvXjQ5bmNjQ1JSktWevWHDBgAmTpxofCaAo6Mj3333HTKZjL1795Kens7Vq1cJDAykUqVKjBkzxqRO33zzDQ4ODvj7+5Oenm48t3TpUgAmTJhgDNwAunbtSs+ePblz5w47d+602usRBEEQ8kd78zypW75DSolH7lIZu56TWRwi57qurNn/Lj1QiBxuQrFm9eDNx8eH+/fvExAQYDxWu3ZtJEni0KFDxmOJiYnExMRQtmxZqz3bxcWFWrVq4ePjk+2cm5sbzs7OaDQa4uPjOXjwIHq9nnbt2qFSqUzKlilThlatWpGamkpwcDBg6L0LCQlBrVbTunXrbPfv0qULAPv377fa6xEEQRDyJ/P0LshMQ1GxDupXJhGVoORBcmau1yQkZxJ5LaFwKigIT8HqwduAAQOQJInJkyczduxYMjMz8fHxoXz58uzYsYN58+YRFBTE6NGjSU9Px9PT02rP/u2339i5cyeurq7Zzl27do2EhARUKhVubm5ERkYCUKdOnRzvlVWvrHJRUVHo9Xpq1aqFUpl9tLl27dom5QVBEISiZ9/xA2yadMe++3hkdo4kpGRYdJ2l5QShKFh9zlvz5s15//33Wbx4MUFBQdjY2ADwzjvv8L///Y/58+cDhn3iZDIZ77//vrWrkKOseW7t27fH1taWe/fuAVCuXM4JF7OOZy1weNLy+aFUWn+eheK/uRsKMYej1BBtWvqINn1In5KAPjXB7Hm52gW5g0u245KkRxMdhqqmLzKZDJQOqJ5/mNGgrJOdRc8v62Rnld/Fok1Ln+LQpgWyw8Inn3xCmzZtOHz4sPHY0KFDSU5O5vfffyc1NRVnZ2fGjh1Lq1atCqIKJlauXMm2bduwt7dn3LhxAKSmpgJgZ5fzD3LW8axyKSkpANjb21tU/mnJ5TJcXbOnKLEWJ6ec6y+UXKJNSx/RpnD/zDaSDq01e96l7QBcXxhockzSari7dS4p5/7BrdObuLTqle066WpCns92c7KjZZOqKOTWm/cm2rT0Kco2tXrwlpqailqtpmXLlrRs2dLk3KhRo/jggw+Ij4/Hzc0NhUJh7cdns2LFCuNihenTpxuHN7OeLTMzKTVrP9as/+dV/vHrnpZeL5GYmL8AMCcKhRwnJ3sSE9PQ6fRWv79Q+ESblj6iTR+SarWhTMWGSNpMkjd9C4BjnynIlIbRHEntQnx8irG8PiOFlJ1z0N48D3IF6dibnJckiZ3/XsV/n+nCuZy89kIVEh9Y5/ewaNPSpyDb1MnJ3qIePasHb88//zzdunWjd+/e2YI3MKQSMTf0aE2SJPHjjz+yZMkSFAoF06dPN+7sAKBWqwHIyMh5XkPW8ayetqzyj64+fVTWcXM9c09Cqy24H3CdTl+g9xcKn2jT0ke0KWDrZPhP88jvaJdqoDKkYtID+v/eI33yfdJ2/ow+/jqo7LDvMgpF1YbG91Cr07MqMJIDJ28C8ELVDGrFHyUgtTkJ0sORDhdZCn0djtMg/QFabQ2rvhzRpqVPUbap1YO3tLQ0AgICCAgIoHLlyvTt25fevXtTpUoVaz/KrPT0dD799FP27NmDnZ0dP/30E507dzYpU758eeDhXLbHPT7HLau8uTltec2JEwRBEKxPd/8GaTt/Qkq5j8zeGfuXPkbh/jDwSk3XsiDgDGdj4pEBgzp50bG+I6TV4zm9xMXb6SSk6XCxV+BV0Q65vBEytUuRvR5BsITVg7fVq1cTEBDA7t27uXHjBvPmzWP+/Pm0aNGCPn360LVrV7PzzKwhOTmZ9957j7CwMMqWLcuCBQto0qRJtnJZq0zNJQnOyklXt25dwLD6VC6Xc/nyZfR6PXK5abdmVFSUyX0FQRCEgiVlpJC69TvISEHuXBH77p8gL/PwD+jYhDR+WX+am7Ep2KoUDH+lAT5e7oaTDq4ogPrli6bugpAfVl8q4evry9dff83hw4eZO3cuHTp0QC6X8++//zJx4kSef/55pk6dSkhIiLUfjUajYdiwYYSFhVGjRg38/f1zDNwA2rZtCxh2TdDpdCbnkpKSCA4ORq1W4+fnBxiGQ5s3b24897jAwEAA2rVrZ82XJAiCIJghs3XA1q8P8gqeqHtNMQncLt18wLcrTnAzNgUXRxsmDvF9GLgJQglXYOtcVSoVXbp04ddff+Xw4cNMnTqVxo0bk5KSwrp163j99dfp2rUrCxcutNoz582bR0hICOXKlWPlypUmuyw8rkqVKnTo0IHr168zc+ZM40KDzMxMvvjiC1JSUhg0aBCOjo7Ga4YMGQLAN998YzLcumfPHrZt20b58uV5+eWXrfZ6BEEQnlX65Dh0sTHoYq8aj+lir6KLjUF7KxJ9chwANg07o+75OTK7h7+rT0Tc5YfVYSSmaqhe3pEpbzajRsUy2Z4hCCWVTMrv8sgndO3aNbZu3crSpUtJSUlBJpNx/vz5fN/3wYMHtGvXjrS0NLy9vfHy8jJbduLEibi7u3Pjxg0GDRrE3bt3qVWrFl5eXpw5c4abN2/SoEEDVq5ciYODadqO8ePHs3XrVhwdHWnVqhXx8fGEhoaiUqlYsmRJjos0noROp+f+/ZS8Cz4hpVKOq6sD8fEpYtJsKSHatPQRbWqgT44jxX8i6DTmC8mVOAz6Hrnjw116JElix79X2HDgMgBNapdleK8G2NkUSFYsi4g2LX0Ksk3d3ByKZrWpORqNhgMHDrB7924OHDhgzJvm4uJilfufOnWKtLQ0ACIiIoiIiDBbdvTo0bi7u1OlShXWr1/P3Llz2b9/P0FBQVSuXJkPPviA999/P1vgBvD999/TpEkT1q5dy6FDh3BycqJjx46MHj2aevXqWeW1CIIgPMuk9KTcAzcAvdZQ7r/gTavTs3L3BQ6dNuyt3dmvKoM6eSG3Yq42QSguCrzn7cSJE2zZsoXdu3eTmJiIJEkolUratGnDq6++SocOHXLcbupZJXreBEuJNi19RJsa6GJjSN04Lc9y6r7TULh7kJKu4ddN4Zy/Eo9MBq91rkMnv6oFXk9LiDYtfUptz9vFixfZunUr27Zt49atW8b5ZLVr16ZPnz707t0bd3cxcVQQBEHIn7sJacxed4pbcanY2ij44JUGNPEUny9C6Wb14K13795cuHABMMw/cHR0pHv37rz66qtmV34KgiAIwpO6dieZn/deIzlNg2sZWz7q15jqFcTCBKH0s3rwFhERgUwmo2XLlvTt25euXbtia2tr7ccIgiAIz7jluy6QrHGlRoUyjOnXGNcy4rNGeDZYPXgbNWoUffr0KdQdFQRBEIRnj06vx8fTneGvNMDWpuD3yhaE4qJAgjdBEARBeFKSJJF5cjtIlk0Cb9WgAt26NRIrSoVnjljmKQiCIBQ5Sa8j45+VaM7vB5kcvUyBXNKZLa9DQbcXGojATXgmieBNEARBKFKSJoO0fb+iu3oKkGHTchAzDurRpyWZvUZhX4aparfCq6QgFCMieBMEQRCKjD71AWm7f0F/LxoUKuw6fsAleS2uJocBZc1fmAyR1xLwruFaaHUVhOJCBG+CIAhCkdAn3CZ1509ISfeQ2Tpi320sigqeJJy7bdH1CSkZBVxDQSieRPAmCIIgFAnN5WOGwK1MOdQvfYLcpSIAZexVFl3v4iBSgwjPJhG8CYIgCE9Fn5qAlJpg9rxM7YJc7WL2vE3TngCo6rVHbu8EQFJqJlv/icnz2S6ONtSpZv7eglCaFXrwdv36ddzd3bGzsyvsRwuCIAhWpDkXRGboZrPnbXx7Ydusj+k1Uf+i9PBFprRBJpNh6/uK8dz1u8nM2XCa2AfpqBQyNDrzW28PfqGKWGkqPLMKJHjTarXMnTuXLVu2sGvXLpMdFn744QcOHz7MkCFDGD16NDY2NgVRBUEQBKGAqep3QOnRFEmjIW3rdADse05GpjIMe8oe6XWTJD0ZR9egCd+D0sMPuy4jkckebsAdGnmPxVvPkaHRUc7Fjg+873EjPISNKc1JkByM5VxkKfR1OE7jzAdAzUJ5nYJQ3Fg9eMvMzOT999/n2LFjAERHR+Pt7W08f+/ePVJTU1myZAkXLlxg0aJF1q6CIAiCUAjkahdQuyBpHi4cULhXR6YynYsmaTNJD1qENvqE4brytQBDr5kkSWw7EsOmQ9EAeFd3YUSfRqilFKo3bEJLvcTF2+kkpOlwsVfgVdEOubyRSWAoCM8aqwdvK1euJDg4GDc3NyZNmoSnp2e28wcOHGDatGkcOnSIdevW0b9/f2tXQxAEQSgGpPRk0nbPRnfnIsgV2LV/D5XncwBkaHQs23GeY+fvAtDJtyoDO3miVMgBF1C7oADqly+y6gtCsWT14G379u3I5XIWL15MgwYNsj9QqaRTp06UK1eOgQMHsmHDBhG8CYIglEL6xHuk7fwJ/YPbYGOP/YtjUFauB8D9xHTmbjjDlTtJKOQyhrxYh/Y+Yk9sQbCE1YO36OhoPDw8cgzcHtW4cWOqVq1KZGSktasgCIIgFDFJ0huS7z64jczBDfuXPkHhZgjOom48YN7GMySmZOJor2Jkn4bUrS6S7QqCpawevMlkMosXIZQpU4Z79+5ZuwqCIAhCIdAnxyGlJyFpNMZjutirxgULNs36knl6J/adRyJ3MARn/5y5xfJdEWh1ElXLOTD61caUc7EvkvoLQkll9eCtatWqREVFcf/+fdzczO879+DBA6KioqhSRXSTC4IglDT65DhS/CeCTmNyPGvVKQAKFeoBM5A7uKLXS6zbH8XuY9cAaOrlzvs962NnI9KNCsKTkudd5Ml06tQJrVbLpEmTyMzMzLGMVqtl6tSpaDQa2rVrZ+0qCIIgCAVMSk/KFrhlo9NARjKp6Rp+WX/KGLi93NqDkX0bicBNEJ6S1X9yhgwZwtq1azlw4ADdu3enV69eeHt7o1arSUlJITIykq1bt3L16lWcnJx45513rF0FQRAEoZiIe5DOLxtDuH0/FRulnHd61KNFvQpFXS1BKNGsHry5u7szZ84cPvroI65fv86vv/6arYwkSbi4uDBv3jzKlxdrwAVBEEqrJdvOcTvNBdcytox5tTE1KpYp6ioJQolXIH3Wfn5+7NixgzVr1rB//36uXr1KQkIC9vb2eHh40K5dO1577bVc58QJgiAIJV96po7aVZwY1acRzo5iI3lBsIYCm3Dg5OTEsGHDGDZsWEE9QhAEQSgi+oTbFpVr4lmWV3r6olJafYq1IDyzxGxRQRAE4YnJnCyb8tKrTU2UInATBKvKV/DWvn17ZDIZK1asoFq1asZjT0ImkxEUFJSfagiCIAiFQNJmgkyOTKFE+m9v0jyvkQq4UoLwDMpX8Hb79m1kMhlardbk2JOQySz7BSAIgiAUHX1qAml75qJwq4Zt27eIuS9RVpKjkunNXqOR5Ny+L+El1qUJglXlK3ibMWMGAOXKlct2TBAEQSgddLFXSNs9GynlPvqEW9j49iROr+a3B71xkGWYvS5FsqW/Xo1XIdZVEJ4F+Qre+vTpY9ExQRAEoWTSXD5O+v7FoM1E7lwR+25jkTuWRaW4S7zekXgcc73exUGsMBUEa7P6goV58+ZRuXJl+vbtm2fZ3377jcuXL/PDDz9YuxpGAQEBfPbZZyxbtozWrVtnO9+yZUsSEhLMXn/69GlsbR/+8tHr9WzcuJHVq1cTExODSqXCz8+PkSNH0qBBg4J4CYIgCIVOkiQyw7aQeWITAIqqDbHv9CEyWwcu3XzAqsDIPO/h4mhDnWouBVxTQXj2FEjw5ufnZ1HwtmfPHqKjo61dBaPTp0/zzTffmD1/48YNEhISqFChAi1atMixjFxuukpq2rRp+Pv74+zsTOvWrYmNjWXfvn0cPHiQRYsW5RggCoIglDQZh5ajidgPgKrhi9i2GggyOftP3mB1YCRanYSLow0JyTlvgwgwpEsd5HIxr1kQrC1fwduNGzc4evRotuOxsbGsX7/e7HWSJHHz5k0iIyNRq9X5qYJZf//9N5999hnJyclmy5w/fx6Abt26MWnSpDzvGRQUhL+/P15eXqxYscKYZHj37t2MGzeOiRMnEhgYaNJTJwiCUBIpPXzRXPwH2+dfx8a7HRqtjpV7Ijh8+hYAvnXK8XaHypyLus2ao7HEp+qM17o6KBjUyp2m1WyKqvqCUKrlK3grW7Ysc+fO5e7du8ZjMpmMq1evMnXq1DyvlySJ5557Lj9VyObOnTv88ssvbNq0CTs7O9zd3YmNjc2x7NmzZwEsHu5cunQpABMmTDDZHaJr16707NmTgIAAdu7cSe/evfP3IgRBEKxAn5qAlJpg9rxM7YJc7WL8WtJmIlMaAi5l9cY4DJ6JXO1C3IN05m86Q8ztJGQy6PtCLbq3qkFmSADeYZv5wlbGJUV5EvX2OMnTqK28izxMQiPrhW0zMQ9aEKwtX8GbnZ0d48ePZ9asWcZjN2/exMbGBnd3d7PXyeVy1Go19evXZ8KECfmpQjazZs1i06ZNNGzYkO+++45vv/3WbPCW1fPWsGHDPO+bnJxMSEgIarU6x6HRLl26EBAQwP79+0XwJghCsaA5F0Rm6Gaz5218HwZXmqh/yQj2R93zc+T/JeCVq104F3Of3zafJTlNg4Odkg96NaRBTcMfr6r6HVB6NAWgSQ73lz0SGAqCYD35nvPWs2dPevbsafza29ubRo0asWrVqvze+qnUqlWL77//nldeeSXbfLXHnT17Fjs7O8LDw5kyZQoXL15EJpPh6+vLiBEjaNLk4a+jqKgo9Ho9tWrVQqnM/rbVrl0bgMjIvCfxCoIgFIas4ErSaEjbOh0A+56TkalUgCG4kiQ9mSc2kRm2FYDM8EDsWg9BkiR2HbvK+v2XkCSoXsGRUX0a4e5ib7y/XO0CIkAThEJn9QULo0aNolKlSta+rcUs3Us1Li7OONw7YcIEfHx8aNmyJZGRkezfv5/Dhw8zc+ZMunfvDsC9e/cA05x2j8o6bq6X70kUxFYyCoXc5P9CySfatPSxeps6uYGTG5Img7T/DtlW9ECmMszLlTTppOydjyY6xHCuaQ/sW/YnXaNnybZzHD9v+B3ZpnElhr7kjY1KYZ16PUPEz2npUxzatECCt5Iga76bq6srCxYsoGlTQ9e/JEksX76cGTNm8Pnnn+Pr60vFihVJSUkBwN7ePsf72dnZAZCampqvesnlMlxdHfJ1j9w4OeVcf6HkEm1a+lirTbUP7qFLTUKvzSDhv2P2GXeQ62zRJccTt28FmrjroFBSrvuHlGncnut3k/huRQjX7iShVMh4v3cjXnrOQ+yGk0/i57T0Kco2LbCN6ZOTk/nzzz/Zu3cv0dHRpKamolarqVGjBu3ateOtt97CxcWloB6fp7Zt23Lo0CEkSaJChQrG4zKZjKFDh3L8+HH27t3L+vXrGTVqFAqFwng+N1I+N/LT6yUSE/MXAOZEoZDj5GRPYmIaOp357WyEkkO0aeljzTbVJ8XyYPVnoNOYHL+1YoppQVtHynQfh7aSF3v/jWbh5rOkZ+pwcbRh9KuN8armQkKC9X8nPSvEz2npU5Bt6uRkb1GPXoEEb5GRkXzwwQfcunXLJJhJSUnh3LlznD9/noCAABYsWIC3t3dBVCFPMpmM8uXNb7jXoUMH9u7dS3h4OIAxpUl6enqO5bOOm+uZexJabcH9gOt0+gK9v1D4RJuWPtZoU11KYrbALSd2Hd5HX7YWa/++yLYjVwCoU9WZD3s3xNnRVnxvWYn4OS19irJNrR68JSUlMXz4cG7duoW7uzuvvvoqDRs2xNHRkQcPHhAeHk5AQAC3bt1i5MiRbN68GUfH3LdXKQpZc9jS0gwzRbICPXNz2vKaEycIglAcpcsdWLzuFOHR9wHo7FeVAR09UYo5WoJQbFk9eFu+fDm3bt2iadOmLFy4ECcnJ5Pz3bp1Y9iwYQwbNoxTp06xZs0a3nvvPWtXI0/+/v4cPXqUl19+mc6dO2c7f+3aNQAqVqwIgKenJ3K5nMuXL6PX67OtZI2KigKgTp06BVxzQRAE61m89RzhDxyxUcp56yVvnmtQsairJAhCHqz+p9XevXtRKBTMnDkzW+CWxcnJiZkzZyKTydi1a5e1q2CRO3fusHPnTtatW5ftnCRJbN5syI3Upk0bwDAc2rx5c5KSkggODs52TWBgIADt2rUrwFoLgiBYV0JyBu7Odkx6w08EboJQQlg9eLty5Qq1atWiatWquZarVq0atWvX5urVq9augkX69OmDjY0N+/fvZ+3atcbjer2eOXPmcPr0aTw9PenWrZvx3JAhQwD45ptvjMOkYNijddu2bZQvX56XX3658F6EIAhCPtWu4swXQ5tTvUKZoq6KIAgWsvqwqSRJqP5LAJnnw5VKNJq8J9QWhGrVqjFt2jSmTJnC1KlT+fPPP/Hw8CAiIoIrV67g7u7O3LlzTV5L1jZYW7dupVu3brRq1Yr4+HhCQ0NRqVT8+OOP2NiIvfwEQShakk5DRuhWi8oO7uiFjb1lv7MFQSgerN7zVqVKFS7+v737Do+qTBs4/JuSSTKThHSS0NuE3pEivaugAkpTdy0LCmJ3FVxxBUSWBT8s2KWIClKkCEqHAAoGISgtQGhpQEJ6nZSZ8/2RzUhIhUwymfDc18UFOec9Z56TlwNP3hoRQVJSUpnlkpKSiIiIsOuCvmPGjOG7775j4MCBxMXFsWfPHvLz83nsscf48ccfadq0abFr5s+fz5tvvklQUBAHDhwgKiqKgQMHsmbNGrp3726HpxBCiL8oikL21v/DfPlohcpHX0+v4oiEELZm85a3vn37smzZMt566y3ef//9EreSys/P580338RsNlf5GLFvvvmmzPOdO3fm008/rfD9NBoNjz32GI899lhlQxNCCJtTqVQ4texHTtwlyM9Fqyp9KYM8RU1KnvQWCOFobJ68Pf7446xbt47du3czZswYJkyYQJs2bXB3dyc9PZ1Tp06xcuVKIiIicHNz4/HHH7d1CEIIcUdRFAtKZjJqNx8AnJr3IF6pzxcbwjCockq9LlNxZpJP3VLPCyFqJpsnb3Xr1uXDDz/k2Wef5ezZs8yaNatYGUVRMBgMvP/++0V2NxBCCHFrlNwsTHu/xHz9EvrRbxdsFg+oXNxIUdxItpS+jqanmw5jA89qiVMIYTtVsgpjz5492bJlC2PHjsXf3x9FUay//Pz8GDt2LBs3buTuu++uio8XQog7gjkpmsz1s8iPPIZiysBy/TKKorAtNIoFq45R3m59E/rWQ62WPUuFcDRVtrdpUFAQs2fPBgq2xcrIyMBgMNTI3RSEEMLR5EUcxLR/OZhzUbn54DpkGtlu9Vn6wwn+OF+wE0yXurm0zghlc1ZnUhSD9VpPVSajDb/TPjcVaGKfBxBC3DabJ2+LFy8mKCiI0aNHW48ZDAYMBkOxsp9++ikXL15kwYIFtg5DCCFqJcWcT85vq8g7tRsATf22uAx8mkuJFj5bdpjEtBy0GjUTBregr1EP2S3pbVGIuGYiJduMp6uGFgEuqNXtUP2vi1UI4ViqJHnr0qVLkeStNDt37uTSpUu2DkEIIRyGJSsFJSul4AuNmhyTK/np2ZjNBbNEVXpP6zg2gNxjm62Jm67TSJw6P8iuo7GsDbmA2aLg7+XKlAfa0ijgf4vuGrzQAK39q++ZhBBVq1LJW2xsLIcOHSp2PCEhgXXr1pV6naIoXLlyhXPnzqHX6ysTghBCOLS803vJDdtk/frmVdd0nR/Aueuov75uP5z8mJM4dxpBTt22fLHxFMciCrpJu7b054l7WuLqXGUjYoQQNYBKUcob0lo6k8nEsGHDiI+Pv63rFUVh2LBhfPDBB7cbQq1jNltISsq0+X21WjVeXgaSkzPJzy993SfhOKROa4fCljclL4/szXMBcBv1JhbV/xIw1zpYrl9C26gTKlXB5AJFUbh0NZ1PN54kMc2EVqNiwqAW9O9Uz1pG1AzyntY+VVmn3t4GNJry55JW6sczFxcXXn31VRYtWmQ9duXKFXQ6Hb6+vqVep1ar0ev1tG7dmtdee60yIQghhGOzmEs9peTlkPv7UszRJ3DuMQFd+2EoisLOIzGs3Xses0XBz9OFqQ+2+6ubVAhR61W6bX3kyJGMHDnS+nXLli1p164d3333XWVvLYQQtZolI5HM1dPBXHSP54wN7xQtqFKD1oksUx5Lfz5D2LnrAHQJ9uOJe1qhd5FuUiHuJDZ/46dNm2bX/UqFEMJRKKb0YolbSVz6PkGMRwc+XfY7CakF3aTjBrZgYGfpJhXiTlQlyZsQQgjb+T1Ox7JNRzFbFHzruDDlwbY0CfSwd1hCCDupsrZ2i8XCtm3b2L17N5cvXyY9PR1vb29atGjB8OHDZXcFIYSooG2hUZgtPnQx+vHEvS3RuzjZOyQhhB1VSfIWERHByy+/zPnz57lxMmtUVBR//PEH69ato3v37syfP1/2NhVCiHKo1SomDGjB4C71pZtUCGH75C0hIYGnnnqK+Ph43N3dGTJkCMHBwej1ejIyMggPD2fXrl389ttvTJkyhZUrV+Li4mLrMIQQosar6EpNT97bioatGlRxNEIIR2Hz5G3JkiXEx8fTqVMnPv74Y7y9vYuViY+PZ8qUKZw+fZpVq1bxxBNP2DoMIYSo0ZS8HHJ+X1+hsoE+spi5EOIv5a8Ed4v27NmDk5MTH3zwQYmJG4C/vz8ffPABarWaTZs2lVhGCCFqK0tqHFmb5mCJOVGh8lFxN++7IIS4k9m85e3atWu0aNECf/+yN9KrX78+RqORy5cv2zoEIYSosfIj/yB77+eQm02+Vg95JrSq0ldpz1PUpOTpqjFCIURNZ/PkzdPTk5SUlAqVNZlMGAwGW4cghBA1jmKxkBu2kdywHwFQ123OpUZj+W7HGQyqnFKvy1ScmeQjE7uEEH+xebfp4MGDuXr1Kj///HOZ5Y4ePcqlS5cYOHCgrUMQQogaSMF89RwATm0Gcar5EyzZc5VkixsxZp9SfymuXhgbeNo3dCFEjWLzlreXXnqJw4cPM2PGDFJSUnjooYfQ6Yo2+YeEhPDGG28QFBTECy+8YOsQhBCixlGpNbgMmkJ21Cm+u+DJrwfOAuDnauZ6duHP0TcuA1IwE3VssxTUalkeRAjxF5VS0bnqFTRt2jQyMjL47bffUKlU6PV6goODqVOnDtnZ2Zw/f57ExEQA3N3d0euLz6JSqVTs3bvXlmE5DLPZQlJSps3vq9Wq8fIykJycSX5+6eNrhOOQOq358s4ewJx8BZce4wC4eCWNL348RXxKNirgvl6NGNHJmz/PXOH73xJIzvxrk3ovg4bxPXzp0qYear2nfR5AVJq8p7VPVdapt7cBjab8TlGbt7zt2rXL+mdFUcjMzCQsLKzEsmlpaaSlpRU7LotQCiEcmWLOI+fgd+SFhwCgqdeG7dFubPrlEmaLgo+HM/8Y0Zrghl4AdOvmRZcuCheupJKnqHBSKTQLqiMtbkKIEtk8eZs3b56tbymEEA7DkpFI9s6PsVy/CKgwtx3B/+3L4WxMPAB3tfLnb8OCi21xpVaraNXYW1pphBDlsnnyNmrUKFvfUggh7MqSlYKSlVLqeZXeE7Xek/zY05h2f4piSgdnA9EtxvNJqEJWTirOOg2PDjHSq22A9C4IISqlyjamF0KI2iLv9F5yw0pfUFzX+QFULu7kHPoOFAW8G/CT073s2J8NQJNADybf35q6XrJTghCi8qosecvNzeXixYtkZGSUu39ft27dqioMIYSoNKfWA9A27oSSl0f25rkAuI78Fyqngq5Pld4Tc/xFUBRM9e/ig+h2XEn+a1LC/Xc3QVuBQchCCFERVZK8LVq0iBUrVmAymcotq1KpOH36dFWEIYQQtmExl3hYsZhRqTVgMaNp2Iljzf7BN0dzMVvy8PZwZtINkxKEEMJWbJ68LV++nM8//7zC5W28UokQQtiUJSORzNXTwZxX5HhhCxyAotbyjfNjHI0tSPK6tfTnb8ODMdw0KUEIIWzB5snbmjVrUKlUjB49mmeffRZ/f3+0WhlaJ4RwTIopvVjidjOVJZ+4a/E4O/nzyBAjd7eTSQlCiKpj80EY0dHR+Pj4MGfOHIKCguyeuG3cuJHg4GAOHjxY4vmEhARmz57NkCFDaN++PYMGDWLBggVkZpa8UK7FYmHdunWMHj2azp070717d6ZOncqpU6eq8jGEEDVckK+Bt5/sRu/2gZK4CSGqlM2TNzc3N/z8/FCr7T849/jx48yZM6fU8/Hx8YwdO5bvvvsOFxcX+vfvj8Vi4auvvmLChAlkZGQUu+btt9/mX//6FzExMfTq1YsmTZqwe/duxo0bV2qCKISo/Z68t5XMJhVCVAubZ1jdunXj0qVLpbZcVZc9e/bw1FNPlZiAFXrnnXeIjY1l8uTJbN68mQ8//JDt27dzzz33cPbsWRYvXlyk/N69e1m9ejUtWrRg27ZtLF68mO+//54PP/wQi8XC9OnTycnJqepHE0JUI4ulYuNypbFNCFFdbJ68TZ06FbPZzKxZs+wyGSEuLo4ZM2YwdepU8vLy8PX1LbFcVFQUO3fuJDAwkOeff956XKfTMWfOHAwGA6tXry4yY3bJkiUAvPbaa3h7e1uPDxs2jJEjRxIXF8fWrVur6MmEEPYQFZdu03JCCFFZNh+Q1rJlSz744AOmTZvGH3/8wd133423t3eZY0CmTZtms89ftGgRGzZsoG3btrz77ru88847JCQkFCu3f/9+LBYL/fr1w8mp6Iwwd3d3evTowe7duwkNDaVfv35kZGRw9OhR9Ho9vXr1Kna/IUOGsHHjRkJCQnjwwQdt9jxCiOqnWCzknz+EtnlP0rLy8K/ANenZZU9qEEIIW7F58paRkcEXX3yBxWIhOjqa77//vtxrbJm8NW3alPnz53P//feXOe7u3LlzABiNxhLPN2/enN27d3Pu3Dn69evH+fPnsVgsNG3atMRJGM2aNStyXyGEY7JkJGLa+wXmq2fJS4jjYLiO5hW4zt1VlgURQlQPmydvixYt4o8//gDAz8+PoKCgYi1bVWny5MkVKnf9+nWgIMaSFB4vbLW71fKVodXafrKH5n+ru2tklfdaQ+rU9nLPh5K1bxlKThZmtY4NR5K4aPInr44aJ1XpG8XnKRqaNa1f6XdX6rT2kTqtfWpCndo8edu9ezcqlYp33323Rm9Sn5WVBYCLi0uJ5wuPF5YrnIDh6upaofK3S61W4eVlqNQ9yuLhUXL8wnFJnVaeJSeLhB1LyDweAsB1bQCfJfQgweJBm6Y+XGzyAj+GlN6q/th97Qhu3Mhm8Uid1j5Sp7WPPevU5slbUlISjRo1qtGJG4BGowEodSxe4WSLwt/LK3/zdbfLYlFIS6tcAlgSjUaNh4craWnZmM2ltyAIxyF1ahv58RfJ3PExlrTrKKjYk9ueLUnt0Gi1TBzUnKF3NSDn9w2YXE+wPrMbKcpfP1x5qjIZbfidxiYnkpNbVzoWqdPaR+q09qnKOvXwcK1Qi57Nkzd/f39rolOT6fUF6zGVtrRH4fHClrbC8qXt11p4vLSWuVuRn191L7jZbKnS+4vqJ3VaOWa0mDOSyVB7sDSlJxfz69IsyIMn72tFoI8Bi1lB07I/PRt2pLtFIeKaiZRsM56uGloEuKBWt0Ol97RpHUid1j5Sp7WPPevU5snbsGHDWLp0KadOnaJNmza2vr3N+PsXzB8rHMt2s5vHuBWWL21MW3lj4oQQNYeSm41K54qiKPx+VUto1iDOZnuRr3bm4f5NGXZXQ9Tqv1rZ1XpP0HuiAVpXZOqpEEJUIZuPtpsyZQoNGzZkypQpbNu2ze6L9ZamcJbphQsXSjwfEREBQHBwMFAw+1StVnPx4kUsluKZ9vnz54vcVwhR8yiKQt65X8hY9SppkWf4eMNJvth8mj+z6lK3rg//frwb9/RoVCRxE0KImsbmLW+zZ8+mQYMG/PLLL7z00kuoVCrc3d1L7U5UqVTs3bvX1mGUq0+fPkDBrgkzZswo0tWbnp5OaGgoer2eLl26AAXdod26dSM0NJTQ0FB69uxZ5H47d+4EoF+/ftX0BEKIQpasFJSslFLPq/SeqDROmA4sJ//i7wAc+2kdYWm90KhV3H93Y+7p0QitzAgUQjgAmydvP/74o/XPiqKgKAqpqamkpqaWWN5eGzjXq1ePAQMGsHfvXhYsWMDrr7+OSqUiNzeXt956i8zMTJ588knc3Nys1zzyyCOEhoYyZ84cvv76a2sX6Y4dO9iyZQv+/v6MGDHCLs8jxJ0s94+fyDu5s9TzmsZdsFy/hJKZhAU1P2d1YJepDfX93PjHiFY0rOtejdEKIUTl2Dx5mzdvnq1vWWVmzpzJqVOnWLZsGfv27aNFixacOHGCK1eu0KZNm2KLBxdug7V582aGDx9Ojx49SE5OJiwsDCcnJxYuXIhOp7PT0whxZ7JkJJJ3uuzWe/PlowAkWDz4Or03MRY/7uvViPvvbiytbUIIh2Pz5K13794OM2i/Xr16rFu3jo8++oiQkBD27t1LUFAQzzzzDJMmTcJgKL7e2vz58+nQoQNr1qzhwIEDeHh4MHDgQJ577jlatWplh6cQ4s6mmNLBkl9uuT9zGvBtZm98fT35132taBLoUQ3RCSGE7akUG+8e37ZtW3r37s3o0aMZMGBAte6uUBuYzRaSkmw/yUOrVePlZSA5OVOmq9cSUqcFzAmXyVr/drnlFqbdR9sunXiwTxOctDVzOSOp09pH6rT2qco69fY22GedN7PZTEhICPv27aNOnTqMHDmS0aNHS6uUEMKunri3FY1bV2SXUiGEqNlsPthj7969vPjiizRu3JiUlBS++eYbRo8ezahRo/jmm29ITk629UcKIe5gFkvFOg/q+VbdtnNCCFGdbJ68BQQE8Mwzz7B161ZWr17NuHHj8PDwIDw8nHfffZe+ffvy/PPPExISUuJ6aUIIcSuiY5MqVC4qLr2KIxFCiOph827TG3Xo0IEOHTrwr3/9iz179rBp0yYOHjzIjh072LlzJz4+Pjz44IOMGjWKZs2aVWUoQohayHz9EnX+/KZCZdOz86o4GiGEqB7VMkdep9MxfPhwPv30U0JDQ5k+fTqurq4kJiayZMkSRowYwSOPPMKuXbuqIxwhRC2Qd/F3MjfOQZebUqHy7q4yeUoIUTtUacvbjWJiYtiyZQs7duwgPDycwkmuLVu2JCEhgaNHjxIWFkbv3r354IMPrBvBCyHEzfLNFkKuGGht1hGV50Ow7ipOqtKHYeQpGho1CqrGCIUQoupUafKWnp7O1q1b2bRpE2FhYUDBrguFs1AfeughWrZsidlsZvfu3cyePZtffvmFuXPnMnfu3KoMTQjhYBRFwXz1LFEEsXzrGWKuZ+ChGkG9BkHk1TOz6/DlUq8d1b8FnTx8qy9YIYSoQlWyVMi+ffvYtGkTISEh5ObmoigKarWanj17MmbMGAYPHlxkJwKNRsPQoUPR6/X84x//YNeuXZK8CSGsFFMGmfuWoUQe5eeMPsTkNsHN1YmHB3ahV9sAco9uRO16gvWZ3UhR/ppV6qnKZLThd1qrtEBHu8UvhBC2VCU7LKSkpFi7RRs0aMCoUaMYPXo0AQEBZV7btGlTgCKbxAsh7mz5MSdJ3/UF2tw0zIoKN5WJXm0DGDewOe76gh8CnVoPoGfjTnS3KERcM5GSbcbTVUOLABfU6nao9J72fQghhLAhmydvycnJuLi4MHToUMaMGUP37t0rfG1OTg5jx46lXbt2tg5LCOFglPxc0n79HvXZPWiBa+Y6bFENZOioPrRp7F2krFrvCXpPNEBrf3tEK4QQ1cfmydusWbO47777cHNzu+VrmzRpwuzZs20dkhDCweQlRJK89WNcs+MBOGAKxtR2FFP7tMDZSVrmhRB3Npsnb+PGjbP1LYUQd5DY6xns/ekoD+TGk2ZxYY9uMP3GDaNhXXd7hyaEEDVCtS0VAhAXF8eOHTswm8306dNHFuYV4g5ksSici04hJTMHT4MzxgaeqNUqcnNz+Om3WH7+LRKzxZMcfW+adevNI92DUatV9g5bCCFqjCpJ3s6cOcN7771H8+bNef311wE4evQo//jHPzCZTAD897//5ZVXXuGpp56qihCEEDVM/vVLnD59iR0nkknL/mtNNg9XNYP8E/BL/pNfU4djtrjRsbkvo4b2wtvDxY4RCyFEzWTz5C02NpZHH32UzMxMVKq/flqeNWsW2dnZuLm5ERgYSEREBAsXLqRLly507NjR1mEIIWoQS0YimRvm0AQLT+sA3U0FUgAVjHQ/gdvASXQ2+hX590MIIcRfbL491vLly8nIyKBjx448//zzQEFL3Llz53BycuKHH35g8+bNzJw5E0VR+Pbbb20dghCihjFnpaGm9B0QCnW+72G6BPtL4iaEEGWwefJ28OBBnJ2d+fjjj2nbti0A+/fvB6BHjx40atQIgIkTJ+Ll5cXRo0dtHYIQooaJikuvULn4VFMVRyKEEI7P5snb1atXady4Md7ef63D9Ouvv6JSqejZs6f1mEqlIigoiISEBFuHIISoYdKz82xaTggh7mQ2T95u7u7Iycnh2LFjANx1111FzqWnp6PVVuuEVyFENVMUhfjErAqVdXd1quJohBDC8dk8c6pfvz7R0dFkZ2fj6urKL7/8Qm5uLl5eXtZuVICLFy8SExND8+bNbR2CEKKGiIxNJGL7ahqZzlXoXxtZy00IIcpn8+StW7dunD17ljfeeIMRI0awcOFCVCoVQ4YMsZY5deoUM2bMQFEU+vbta+sQhBB2lpaVy6HtOzBe20Z3TUaF/6WR9dyEEKJ8Nk/eJk2axM8//8y2bdvYtm0biqJgMBiYPHkyUDCh4amnnkJRFIKCgnjyySdtHYIQwk7MFgu/HjqJ7s919NJGgQay1G44txuC5s8N9g5PCCFqBZsnb3Xr1mX16tX83//9H2fPnqVRo0a88MIL1K9fH4BGjRqhVqvp27cvs2fPLjKxQQjhuMIvXufS7rV0txxFpzVjRk12k/4E9HsYJTeLzBObwZJf+g3UWlQu0m0qhBDlUSmKolT3h6akpODp6cm1a9dYs2aNdT04AWazhaSkTJvfV6tV4+VlIDk5k/z88tfbEjVfTanThNRsVu85z9Gz8Tzvvp1mTvGkuzfBf+hTaH3qW8tZMhJRTKUvGaJycUft5lMdIddYNaVOhe1IndY+VVmn3t4GNJry55LaZarnn3/+yffff8/+/fuxWCySvAnhgHLzzOz55QQ/H40nI1+LSqUiqvH9NG8KgS3vLjbzXO3mA3d4ciaEELZQbclbUlIS69atY82aNcTGxgIFSwjISupCOBZFUQgLv0rMvg30VoeR6xTMmaDBTBxspL6/m73DE0KIWq/Kk7fDhw+zatUqdu3aRX5+PoW9tK6urowcOZKJEydWdQhCiFtgsSici04hJTMHT4Mzxgae1lmgMdczOLBtF90y9mDUpAFwV2AuI8Z0QK3R2DNsIYS4Y1RJ8paens769etZvXo1ly5dArAmbS1atGD8+PE88MADuLnJT+lC1BSWjEROn4lkW2g0aVm51uMeeh0Du9Tj2vV03CNDGKGLBA3kaAzo755A3eDiXaRCCCGqjk2Tt+PHj7Nq1Sq2bt1KTk6ONWHT6/VkZWVRt25dNm/ebMuPFELYgCUjkfRVr9NIyedpJ6DOTQWOQ3MFVDqwoMLSoj8+dz+MSqe3R7hCCHFHq3TylpWVxebNm/n+++85c+YMUNDKptVq6dmzJ/fffz+DBw+mU6dO8tO5EDWUOSsNtVLGMh6ASgU5boF4DZuCxqdhNUUmhBDiZpVK3mbNmsWPP/5IVlaWtZWtffv2jBgxghEjRjjMGm579uxhypQppZ6/9957WbRokfXrhIQEPvnkEw4cOEBcXBx+fn4MHz6cqVOnYjAYqiNkIWwqKi4d/wqUS207Hl9J3IQQwq4qlbytWrUKlUpFhw4dGDhwIPfccw8NGjSwVWzV5vTp00DB1l4BAQHFznfq1Mn65/j4eMaPH09sbCxGo5H+/ftz4sQJvvrqKw4cOMDKlStlLJ9wOOnZeRVK3tJNZbfOCSGEqHo2GfN2+fJljh07Rp06dRg4cCB+fn62uG21KUze3nzzTVq2bFlm2XfeeYfY2FgmT57MK6+8AkBubi6vvfYaW7duZfHixUyfPr3KYxbCVrJM+UREp9CsAmXdXZ2qPB4hhBBlK38Z3zIsXLiQnj17kpaWxt69e3n77bfp378/TzzxBBs3biQz0/Y7BVSF06dP4+zsTPPmzcssFxUVxc6dOwkMDCyysLBOp2POnDkYDAZWr16NyWSq6pCFqLS8fDPbD0fx/hdbaH3tpwpd07CubF8lhBD2VqnkbcSIESxdupTdu3czbdo06tWrh9ls5tChQ8yYMYO7776bV155hZCQEBuFa3vJyclcvXqV4OBgtNqyGyILd4To168fTk5FWyDc3d3p0aMHWVlZhIaGVmXIQlSKxaLwy/GrvPHFb6zZc47xTrtp6JRUoWsL13sTQghhP5VK3goFBgYybdo0du3axfLlyxkxYgTOzs6YTCZ+/vln62SA7OxsaxdlTVEYT2BgIAsWLGD48OG0b9+egQMHMn/+fFJTU61lz507B4DRaCzxXoUtd4XlhKhJFEXhWMR1Zi05xLKfT5GYloOnuysZLUeirtfG3uEJIYSoIJsv0tujRw969OhBRkYGmzdvZsOGDRw/fhyAtLQ0xowZg9Fo5KGHHmLkyJF4enraOoRbcurUKQC2b9+OwWDgrrvuIiAggBMnTrB06VL27NnDt99+i5+fH9evXwcodUxf4fGEhIRKxaTV2iSnLqJwo9uKbHgrHMOt1Om56BRW745AG3eax/S/c8itLf7dhzOkawN0Thos6V1JXfkamMuYkKDR4mTwQF0Ffz9FAXlPax+p09qnJtRplW2P5ebmxoQJE5gwYQIXLlxg7dq1bN68mcTERM6ePcu7777LggULGDhwIO+//35VhVGu8PBwAPr378/ChQtxdy8Y05OUlMRLL73Eb7/9xsyZM/nss8/IysoCwMXFpcR7FR4vLHc71GoVXl5Vt9yIh4drld1b2EdZdRp5NY0VP4dz+cxZRumP0Nq9YF/hMf5RNLynFSrV//7x8TJQZ8pizFnppd5Lo3dHW8exJiM5KnlPax+p09rHnnVaLRvTN2vWjOnTp/Pqq68SEhLCDz/8wIEDB8jNzWX79u3VEUKp5s+fzwsvvEBAQECRpMzb25v//ve/DB8+nL179xITE4Pmf3s3lrbYcOFad4W/3w6LRSEt7faTv9JoNGo8PFxJS8vGbLbY/P6i+pVVpwkp2azff5GwE5EMdf2T8XXOoFEpoNbg3H4orl0eICUl+6Y76sGljB0TLECyY0xCclTyntY+Uqe1T1XWqYeHa4Va9KolebN+mFbL4MGDGTx4MAkJCWzYsIGNGzdWZwjF6HQ6GjduXOK5unXr0rp1a44cOcKpU6fQ6wv+Y8vJySmxfOFxV9fKZeP5+VX3gpvNliq9v6geFovChStJ5CkqnFQKzYLqoFarSM/K5adDkewJiyFYHcW/6hzETV3w91LTsAMuPSag9gzADCB/D2oseU9rH6nT2seedVqtyduNfH19mTRpEpMmTbJXCBXi6+sLFEy28PcvWMa0cOzbzcobEydEZZW2eby73omGdd35M8bENVPBDw9eAXUxZOei9gzCuecEtA3a2StsIYQQNmS35K0myM3NZdasWSQnJ7Nw4UJry9qNoqOjAQgICLCu33bhwoUS7xcREQFAcHBwFUUs7mTlbh6fBENdVSx1f5RhAzrSpok35tj6aIJaolLf0a+6EELUKnf09BedTsfBgwfZvXs3+/fvL3b+zJkznDlzBnd3dzp27EifPn0A2Lt3L2azuUjZ9PR0QkND0ev1dOnSpVriF3eWimwer1UpPNvfg7ZNfVCpVGjrt5XETQghapk7OnkDGDduHAD/+c9/iIqKsh5PSEjgjTfewGw289RTT+Hi4kK9evUYMGAAMTExLFiwwDoxITc3l7feeovMzEzGjx8ve5uKKhEVV/pM0BtdS7T9hBchhBA1xx3/I/mTTz7J77//zi+//MKIESPo2rUrOp2O0NBQsrKyGDZsGJMnT7aWnzlzJqdOnWLZsmXs27ePFi1acOLECa5cuUKbNm2YNm2aHZ9G1FY5eWaORSQwrAJlU5AfHoQQoja745M3nU7HF198wXfffceGDRs4evQoarWaFi1a8PDDD/PQQw8VWRqkXr16rFu3jo8++oiQkBD27t1LUFAQzzzzDJMmTcJgqLo12sSdJzsnnz1hMez4PZo6OYkMu3mcWwlk83ghhKjdVEplFiUTNmc2W0hKsv1aWlqtGi8vA8nJmTJd3QGkZ+Wy80gMu4/GYMrJw6i9ilbvxmTtxnKvdXnw3zj5N6n6IIXNyXta+0id1j5VWafe3oaat86bEKJsyek5bD8cRcgfseTl5dNRF8l93ifxIxltz0fJP1T+PWTzeCGEqN0keROiBohPyWbbb5H8cuIqZrOZzrrL3Od9Ch+SCwo4uaLOqdiEBSGEELWbJG9C2FFsQiY/H7pM6Ol4FMVMV90l7vM8hZeSUlBAp0fXbhi6toNR8kzk/vETWMpYLkStReXiXi2xCyGEsA9J3oSoIhaLwrnoFFIyc/A0OGNs4Gnt0rx8LY2fDkZy9Nxfu3W0a+zNePMOtJkp4GxA1344ujaDUekKdkxQORswjJ+PYipogdNo1Hi4u5KW/tf+eioXd9RuPtX7oEIIIaqVJG9CVIGjZ+NZuSuC5PS/9sH1cnemf8cgImJSOXkpCQ1muusuojTqxrBezWkS6EHeJQVLahy61gOsSduN1G4+8L/kTKtV4+xlQOuSKfuUCiHEHUSSNyFs7M8/z7Jpx3EMgEFzw4ks+P3gFbIVJ3o7X+Ve99MYLOk4BzdDF+gBgFMT2Z1DCCFE2SR5E8KG8tMSaPDbf/lnHXOpZRQFVCrAAiq9JyqdS/UFKIQQwuFJ8iaEDUVGXsFfVXriBgWJW77ODUO3B3EK7otKq6um6IQQQtQGd/zepkLYgqIonI9JZc+xmAqVj2r5t4LJCJK4CSGEuEXS8iZEJeTkmvnt9DX2hsUSFZ9BfU0GVGALKzeDdJUKIYS4PZK8CXEbriVlsScshl9PXCM7Jx9ncunrepmhbmeg7F5TABrWlbXYhBBC3B5J3oSoILPFwp/nE9kTFsPpywU7H9TXJDLY6wLtNRfRWHIrlLiBbGElhBDi9knyJu5YZS2ie6PUzFz2/3mFfX/EkpRWsG6bCujUzJNH09eiyc8GC6g9A9E06EDeiW3V/CRCCCHuJJK8iTtSaYvoThzcgi7B/gUTEGJT2RMWy5Ez8ZgtCoGaZB5wjyGv9X3071QPX09Xcg4PxJKeiFPrAWgCjFgSIyV5E0IIUaUkeRN3nLIW0d304xUutGrIyTgVMdcz0GKmk+4yg9wvEqRcBcA1eChaz4LdD5zverjIvVUu7qBxAnNe6QFonGT/USGEELdNkjdxR6nIIrp5sWrOpw1itOEKPVwv4GwxgQKo1Ggbd0al05d6rdrNB8O4/1j3Hy2J7D8qhBCiMiR5E3eUiiyi66Sy8FydnQVfWEDl5oNTy344teyLWu9Z7mfcuP+oEEIIYWuSvIk7SmpGLv4VKJfj4oXevxG61v3R1G+PSi3rWQshhKgZJHkTtV6+2UJ4ZDKhp+O4ci6Sl9zKvya1w9/w7dCp6oMTQgghbpEkb6JWKlwG5HB4HEfOXicjOw8fdTr9nc9V6PqGgZ5VG6AQQghxmyR5E7WGoihcvJrG4dPx/H4mjpSMHFSAggoPvRMPByTQKuVshe4li+gKIYSoqSR5EzVaeQvpKopCzPVMDofHEXo6joTUbBpqEumji6SjZzQRvgOo17UfLRt6QkpTTPuvYIm/YL8HEkIIISpJkjdRI1kyEjl9JpJtodGkZeVaj3vodQzv3gC/AH9CI/MIPR3HtcQMmmqv01cXSQfPKDzVWdbyAd5xuDb2LvjCux4uvR8ja/3b1fw0QgghhO1I8iZqHEtGIunfv04jSz5POwF1bioQBnmKmn2pD2JSdMzx3Ii72vTXeScXtA3ao23SFW3D9kUulUV0hRBCODpJ3kSNY85KQ23JL7OMk8pCu/rOtGjXHvezByEzEW2jTjg16YKmXhtUWl2J18kiukIIIRydJG+iRklMNfH70WjurkDZPu0CadYuEEvj51EZPFGpK/bXWRbRFUII4cgkeRN2lZGdx5nIZE5HJhN+OYm45GzqaxK5++au0hKkZxd0fardfas4SiGEEKLmkORN3DZLRiKKKR2LRSEqLp307DzcXZ1oWNcdtVpVYvdjTp6ZiJgUwi8nE34pEUtiJE2d4mmmjeNEVlfUKg/8PF0K9hIth7urUxU9mRBCCFFzSfImboslI5HM1dOtA//9//cLwDp1QOOEy8PvEpWu43RkMucuxZMfd4FG6jiaO8UxQHsd5zp/jW0LaN+ToO590KZGY9r4Q7kxNKwrkwqEEELceSR5E7dFMaWXPWMTwJzHh8t2cSq7LgDtnKKY6h5S9D5OerSBLdAEBNOkcWfUzlrMFVwgVxbSFUIIcSeS5O02HT58mM8++4zw8HBMJhPBwcH8/e9/55577rF3aNXCYqlAvybQVnWByy71aNnIi/ZB9bCc+wNdoBFNoBFNQDBq73qoVLLpuxBCCFFRkrzdhs2bN/PPf/4TrVZL9+7d0Wg0HDp0iBdffJELFy4wbdo0e4cIFB2Tdul6BvmKCq1Kob6fW6lj0kqTb7YQl5xN7PUMrsSlkhB1gXEVuK51XRVDHu5jbSVT7lqESlV2i5msxSaEEEKUTpK3W5SYmMibb76Jq6srK1asoF27dgBcuHCBv/3tbyxevJjBgwfTsmVLu8Z585i0G+dj3jgmzTDuP0USOIuikJCSTWxcGklXo8mOj4W0a7iYEvBTp9JQk0pefl3CstsXXzy3BIlNhtPghu7N8hI3kLXYhBBCiLJI8naLvvvuO0wmE5MmTbImbgDNmjXj5Zdf5o033uDrr79m3rx5doyy4mPSzoef43p6PknJGYSl+3I1IZPcfDPzPL+nufqG653/+mNjfRZdG/nD1fLjuN0ZobIWmxBCCFEySd5uUUhICABDhgwpdm7QoEGoVCr27dtXzVEVV9ExaYHHPicQuJLvyYa0+wHQajRkqOvgpEolx8UXPAJw8auHwb8+Gq8g3OrUxT/pCqaN5d9fZoQKIYQQtiXJ2y06f/48AM2bNy92ztPTE19fX65fv05iYiI+PvZrOYqKS7cu3VGeDLU7Tl51eXZQO+r5GfD3dEWV1w10+lK7OSs601NmhAohhBC2JcnbLUhNTSUnJweDwYDBYCixjL+/P9evX+f69eu3nbxptZWffZlpKntv0EKXO0yl0909ip/Qld1ipjZ4VGhSgZPBA7UNnkcUp9Goi/wuHJ/Uae0jdVr71IQ6leTtFmRlZQHg6upaahlnZ+ciZW+VWq3Cy6vkxPBWBPhWrLuyrr/X7X2el4E6Uz7CnJWOWVG4FJNKamYOdQzONKlfB41KhUbvjraO363fW9wSD4/S/z4KxyR1WvtIndY+9qxTSd5ugVpdkGWXNWNSUZQiv98qi0UhLe32Er8b+XnoyKhgueTkzNv8FD246AEIahFA0P+O5hSetgC3fW9RHo1GjYeHK2lp2ZjNFnuHI2xA6rT2kTqtfaqyTj08XCvUoifJ2y0o7Co1mUyllsnNzQVAr9ff9ufk51f+L4OlgsmjRVFs8nnCfsxmi9RhLSN1WvtIndY+9qxT6YS/BQaDAb1eT3p6eqkJXHx8PAB+fvbtLrQudFsWWehWCCGEcDjS8nYLVCoVRqORP/74gwsXLtCmTZsi51NSUkhISMDb2xtfX99S7lI9blzo1mJRiKnkDgtCCCGEqBkkebtFffr04Y8//mDXrl3Fkrddu3ahKAr9+vWzU3RFFS50qwFaBKnx8jKQnJwpTfdCCCGEA5Nu01s0ZswYXF1dWb58OWFhYdbjFy9e5P3330elUvHEE0/YMUIhhBBC1GbS8naLAgMDeeONN5g5cyaPPvoo3bt3R6fTcejQIXJycnjllVcIDg62d5hCCCGEqKUkebsNY8eOJSAggC+//JI//vgDjUZD69atefLJJxk6dKi9wxNCCCFELSbJ223q27cvffv2tXcYQgghhLjDyJg3IYQQQggHIsmbEEIIIYQDkeRNCCGEEMKBSPImhBBCCOFAJHkTQgghhHAgKkWp4A7molooioLFUjVVotGoMZtld4XaROq09pE6rX2kTmufqqpTtVqFSqUqt5wkb0IIIYQQDkS6TYUQQgghHIgkb0IIIYQQDkSSNyGEEEIIByLJmxBCCCGEA5HkTQghhBDCgUjyJoQQQgjhQCR5E0IIIYRwIJK8CSGEEEI4EEnehBBCCCEciCRvQgghhBAORJI3IYQQQggHIsmbEEIIIYQDkeRNCCGEEMKBaO0dgKh6hw8f5rPPPiM8PByTyURwcDB///vfueeee+wdmrgNe/bsYcqUKaWev/fee1m0aFE1RiRux8aNG3n99ddZtmwZvXr1KnY+ISGBTz75hAMHDhAXF4efnx/Dhw9n6tSpGAwGO0QsylNenXbv3p2UlJRSrz9+/DjOzs5VGKEoj8ViYe3ataxfv56IiAjy8vIICgpi8ODBPP3003h4eBQpb6/3VJK3Wm7z5s3885//RKvV0r17dzQaDYcOHeLFF1/kwoULTJs2zd4hilt0+vRpALp160ZAQECx8506darukMQtOn78OHPmzCn1fHx8POPHjyc2Nhaj0Uj//v05ceIEX331FQcOHGDlypW4ublVY8SiPOXVaWxsLCkpKdStW5e77rqrxDJqtXSG2ZPFYuH5559n586duLi40L59e/R6PcePH+err75i586drFy5El9fX8DO76kiaq2EhASlffv2SseOHZXjx49bj58/f17p1auXEhwcrISHh9sxQnE7pkyZohiNRqk7B7V7926la9euitFoVIxGo/Lrr78WK/Pcc88pRqNRWbhwofVYTk6O8sILLyhGo1GZN29edYYsylGROt25c6diNBqVuXPn2iFCURFr1qxRjEajMnToUCUqKsp6PD09XXn66acVo9GovPDCC9bj9nxPJc2vxb777jtMJhOPPPII7dq1sx5v1qwZL7/8Moqi8PXXX9sxQnE7Tp8+jbOzM82bN7d3KOIWxMXFMWPGDKZOnUpeXp71p/ebRUVFsXPnTgIDA3n++eetx3U6HXPmzMFgMLB69WpMJlN1hS5KUdE6BTh16hQAbdq0qa7wxC364YcfAJg+fToNGjSwHndzc+Pdd99FpVKxa9cuTCaT3d9TSd5qsZCQEACGDBlS7NygQYNQqVTs27evmqMSlZGcnMzVq1cJDg5Gq5VRD45k0aJFrF+/njZt2rB69WqaNm1aYrn9+/djsVjo168fTk5ORc65u7vTo0cPsrKyCA0NrY6wRRkqWqcA4eHhALRt27a6whO3yNPTk6ZNm9KxY8di57y9valTpw55eXkkJyfb/T2V5K0WO3/+PECJLTSenp74+vqSmJhIYmJidYcmblPheLfAwEAWLFjA8OHDad++PQMHDmT+/PmkpqbaOUJRmqZNmzJ//nzWrl1LcHBwqeXOnTsHgNFoLPF84ftcWE7YT0XrFApa3lxcXDh58iQTJkyga9eudOvWjaeffpo///yzmiIWZfnss8/YunUrXl5exc5FR0eTkpKCk5MT3t7edn9P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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# --- HAC vs Monte Carlo variance for truncated DQ WITH error bars -------------\n",
    "# Assumes:\n",
    "#   - dq_hac_long_run_by_k[k] : list/array of Ω̂ per run for this k\n",
    "#   - dq_tau_by_k_for_hac[k]  : list/array of τ̂ per run for this k\n",
    "#   - dq_T_per_run            : list/array of T_r (horizon) per run\n",
    "#   - k_values                : iterable of k values you want to evaluate\n",
    "\n",
    "rng = np.random.default_rng(12345)   # reproducible bootstrap\n",
    "n_boot = 100                        # bootstrap reps for MC estimator SE\n",
    "\n",
    "hac_summary_rows = []\n",
    "T_vec = np.array(dq_T_per_run, dtype=float)  # run-specific horizons\n",
    "\n",
    "def compute_mc_lr(tau_vals, T_vals):\n",
    "    \"\"\"Compute MC long-run variance from a set of runs (subset allowed).\"\"\"\n",
    "    tau_mean = np.mean(tau_vals)\n",
    "    mc_terms = np.sqrt(T_vals) * (tau_vals - tau_mean)\n",
    "    return np.var(mc_terms, ddof=1)\n",
    "\n",
    "for k in k_values:\n",
    "    # Per-run HAC Ω̂ and per-run τ̂ for this k\n",
    "    Omega_list = np.asarray(dq_hac_long_run_by_k[k], dtype=float)\n",
    "    tau_list   = np.asarray(dq_tau_by_k_for_hac[k], dtype=float)\n",
    "\n",
    "    # Skip if missing\n",
    "    if Omega_list.size == 0 or tau_list.size == 0:\n",
    "        continue\n",
    "\n",
    "    # Align T to the number of tau's retained (should match number of runs used)\n",
    "    n_runs = len(tau_list)\n",
    "    if n_runs < 2:\n",
    "        # Need at least 2 runs to form a variance; skip or handle specially\n",
    "        continue\n",
    "    T_used = np.asarray(T_vec[:n_runs], dtype=float)\n",
    "\n",
    "    # === Point estimates ===\n",
    "    # HAC long-run variance: E[Ω̂] across runs\n",
    "    hac_lr = np.nanmean(Omega_list)\n",
    "\n",
    "    # MC long-run variance: Var( sqrt(T_r)*(τ_r - mean τ) ) across runs\n",
    "    mc_lr = compute_mc_lr(tau_list, T_used)\n",
    "\n",
    "    # === Error bars ===\n",
    "    # HAC SE: standard error of the mean across runs (ignoring NaNs)\n",
    "    valid = ~np.isnan(Omega_list)\n",
    "    n_eff = valid.sum()\n",
    "    if n_eff >= 2:\n",
    "        hac_se = np.nanstd(Omega_list[valid], ddof=1) / np.sqrt(n_eff)\n",
    "    else:\n",
    "        hac_se = np.nan\n",
    "\n",
    "    # MC SE: bootstrap across runs (resample run indices with replacement)\n",
    "    mc_boot = np.empty(n_boot, dtype=float)\n",
    "    idx_all = np.arange(n_runs)\n",
    "    for b in range(n_boot):\n",
    "        idx = rng.choice(idx_all, size=n_runs, replace=True)\n",
    "        mc_boot[b] = compute_mc_lr(tau_list[idx], T_used[idx])\n",
    "    mc_se = mc_boot.std(ddof=1)\n",
    "\n",
    "    # If you also want the implied estimator variance/se for tau_k:\n",
    "    T_bar = np.mean(T_used)\n",
    "    est_var = hac_lr / T_bar if T_bar > 0 else np.nan\n",
    "    est_se  = np.sqrt(est_var) if est_var > 0 else np.nan\n",
    "\n",
    "    hac_summary_rows.append({\n",
    "        \"k\": k,\n",
    "        \"hac_long_run_var\": hac_lr,\n",
    "        \"mc_long_run_var\": mc_lr,\n",
    "        \"hac_se\": hac_se,\n",
    "        \"mc_se\": mc_se,\n",
    "        \"ratio_hac_over_mc\": hac_lr / mc_lr if mc_lr > 0 else np.nan,\n",
    "        \"estimator_var\": est_var,\n",
    "        \"estimator_SE\": est_se,\n",
    "        \"num_runs\": n_runs,\n",
    "        \"T_bar\": T_bar,\n",
    "    })\n",
    "\n",
    "hac_df = pd.DataFrame(hac_summary_rows).sort_values(\"k\")\n",
    "\n",
    "print(\"\\n--- Truncated DQ: HAC vs Monte Carlo variance (with error bars) ---\")\n",
    "print(hac_df[[\"k\",\"hac_long_run_var\",\"hac_se\",\"mc_long_run_var\",\"mc_se\",\"num_runs\"]]\n",
    "      .to_string(index=False, float_format=lambda x: f\"{x:.6g}\"))\n",
    "\n",
    "# --- Plot with error bars (no explicit colors) --------------------------------\n",
    "import numpy as np\n",
    "\n",
    "plt.figure()\n",
    "plt.errorbar(hac_df[\"k\"], hac_df[\"hac_long_run_var\"],\n",
    "             yerr=hac_df[\"hac_se\"], fmt=\"o-\", capsize=3, label=\"Nonstationary HAC (mean ± SE)\")\n",
    "plt.errorbar(hac_df[\"k\"], hac_df[\"mc_long_run_var\"],\n",
    "             yerr=hac_df[\"mc_se\"], fmt=\"s--\", capsize=3, label=\"Monte Carlo (mean ± SE)\")\n",
    "\n",
    "plt.xlabel(\"Truncation size k\", fontsize=18)\n",
    "plt.ylabel(r\"Asymptotic variance $\\hat\\sigma_k^2$\", fontsize=18)\n",
    "\n",
    "# Ticks at multiples of 5 only\n",
    "max_k = int(hac_df[\"k\"].max())\n",
    "plt.xticks(np.arange(0, max_k + 1, 5), fontsize=16)\n",
    "plt.yticks(fontsize=16)\n",
    "\n",
    "plt.legend(fontsize=16)\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"hac_vs_mc_variance.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1d1a3134",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Plotting ATE estimate distributions (Box Plot)...\n",
      "Saved box plot to plots/queue_boxplot.pdf\n"
     ]
    },
    {
     "data": {
      "image/png": "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tdc+WrjwLc2ePavNCfAzzjhLp5xyepvbOfroIz79/7G6+OKpbbZpa8mTbbVvSzG+tmvWfKRLLvmx6us3a5ddhulHP6rWXnvto/XrP9EDD9ynxx57RM8//6x+//vf6fzzf9yhbT///LO6+ebs38GoUXvo7LPP1ahRo7Vx40b97W9P6c9/vlsLF76ln/1sqm644ebtbu+2227WzJkzOvU8AQAAAAAAAABAaWMCHCXJYgn0cDjc7pmwTctWuK6rioqKgvajJ7jiip82T34fe+wJqq6erPLy8lZt+vbtpxEjRmrChJP0m9/8Wg8//IBefvklzZ79kCZOPGmb23/22b9p8+bNikajOvvsc3XRRedryZL3tWDBfzRmzP6t2kYiEUUikW1uLxQKdeh12V57i7wV2owZd2nDhg2qrOytm266TTvssIMkqV+/fpo8+TKVl5fr/vtn6oEHZmrixJM0ePCQvLf9+9/fJEkaOnSYbrrp96qo6CVJGjBgB5199rnq06ePbrxxuubOfVVvvvmG9t13vza3s2nTJl111eV68cXnu/hsi5fjOCorC6uxMVX0mUPPRtZgibzBEnmDJfIGS+QNlsgbrJA1WCJv8ANLoBdO/hdcBYA2PPPMX/Wvf/1TkvTlL39VP/3p5TmT3y2Fw2FVV1+ivfbaR5I0Y8Yft/uBomn58wMOOEgHHvhZ7bjjTpKk2bNndcdTCLyNGzdqzpxsjU888ZvNk98tff/756hXr15KpVJ68snH8972kiXva9myDyVJ3/zmqc2T3y0dffRxzT+//fabObenUik9/PCDOvXUE5snv0eN2iPvPpQaPn/DClmDJfIGS+QNlsgbLJE3WCJvsELWYIm8AaWDM8BRkorlCK05cx7TVVddoR133En33feQfve73+iZZ55SMpnQ4MFDdMEF1dpll6GaNOlrkqTJky/T+PET2tzWSSeN10cfrdbRRx+rn/3slzm3p1IpPf74I/rb357WBx+8r/r6elVV9dd++x2gE0/8lvbZZ99OPYd77vmDJKmiopd+8pPJed3HcRydfvqZmjr1YtXXb9ayZR9q112Ht9l25coVeuON+ZKkL33py3JdV1/5yjGaOXOGnn327/rRj36ivn37darv3aUrebvzzt/rj3+8vUP3OfbYE/TTn17e6cfc2vz5c5VIJCRJhx9+RJttKip6aezYg/Ti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AKUnkUiouvo8v7vhqylTLvS7C76YNu3mgp8IZ3+xXJ/U19frO9/5jm666SatWLFCu+++uyoqKvTSSy/pBz/4gW666aYOb3PJkiWaOHGiHnzwQdXX12v06NFKJBKaPXu2Jk6cqBdffLEAzwT5KKUjtPr06as+ffpKkl544VllMq2vjp5Op/XHP97e5n3D4bCOO268JOmVV17WP/7xtzbb3X77LaqpWa81az5q9+zf9hx77Ak6/PAjJEnPPfcPXXbZJdq4ccM277N8+TL95Cc/0rp163Jue+GF55rvf8wxx+XVhxNO+JokKZPJ6LHHHu5I97tFseetvLxcX/zikZKk+++/Vx999FFOm9tvv1X19ZsViUR04onfzHvbn/vcYerdO7sqwB//eJsaGhpy2ixbtlR//vM9krJno++11z6deRqB4HmeGhuTRZ859HxkDZbIGyyRN1gib7BE3mCJvMEKWYMl8gaUlsCcAf6LX/xCb7zxhvbcc0/dcsstGjRokCTpkUce0U9/+lPdeOONGjt2rA477LC8tpdKpXTOOeeotrZWX/va1/TLX/5SZWVlSiQSuvbaa/WnP/1J1dXVevrpp1VVVVXIp4YAOPzwIzRnzmNavHiRfvazqTrzzO9rwIAd9P77/9U99/xBr78+V71799GmTRtz7vvd735fL7zwrNauXaMrrvip3nnnbR177PEaMGAHrV69Wg8+eJ/++tcnJGXPuD7qqKM73L/LL79KP/3pJXrllZf13HP/0Pz58/SVrxyjww//ogYPHqLKykqtX79e7767UC+88JxefvlFpdPZs78HDx7SPEkvSU888aik7BIYX/5y22cLb+0rXxmnm266QY2NjXr88dn67nfP7tbrZKfTadXX1+fdPhRy213qu6f6wQ/O1wsvPKcNGzbo/PO/rwsuuEj77TdWGzbU6i9/+bMee+wRSdJJJ52snXYamHP/H//4XH388VrtuONO+s1vbmn+91isTOef/2Ndc80vtXTpB/rBD76jH/zgPO255z5KpVL65z9f0J13/l51dZsUjcY0efJP270GOQAAAAAAAACg9Fz6+e8qGirMpUJ7oqYDLQq9DHhPkkgnddU//2j2eIGYAF+2bJkeffRRua6r66+/vnnyW5ImTJigDz74QLfeeqtuvPHGvCfAH330UX344YcaPHiwrrzySkWjUUnZSbvL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PE7cXFBPBvAyKb+7EEi8lxZeoCbAFy9erFtuuUWvvPKKNm7cqJ122klHHHGEzj33XA0cOLDD20skErrnnnv0xBNPaMmSJQqFQho+fLiOP/54nXbaaXyJ5RPHcRSJhJVKZZrftIBCIW+wsmDBfNXUrJckrV+/TgsWzNeBBx7sc68AAChOQftSC/4ib7DAvikskTdY473UHysXzvG7C0DJ4r208AIzAT537lydddZZisfjqqqq0qhRo/TBBx9o5syZmjNnju6++27tueeeeW9vw4YN+u53v6u3335bjuNo6NChikQiWrRokd5++2099NBDmjFjhvr371/AZ4W2ZDKeNm8O7hKasEXeYGXMmANUVdVfNTXr1b//AI0Zc4DfXSp50WhU06bd7Hc3zMXj8eYzca++enpgD+iLRqO+PfYlw6Wo69vDm2vazwvad1qJjHTdUr97EVwsNQdL5A0W2DeFJfIGa7yXAig1vJcWXiAmwGtra3XeeecpHo/r7LPP1oUXXqhwOKy6ujpdeumleuqpp3TBBRdozpw5eX/Z+atf/Upvv/22dt55Z910003ad999JUkffvihfvjDH2rx4sW69NJLdeuttxbyqQEAAiISieiUU87QrFn36cQTT2b5cwOO4wR28rdJLBYLfA38EHWDNQEOAAAAAOgZOBmAkwGAUhGICfAZM2Zow4YN2n///XXxxRc3/3tlZaWuv/56vf3221q+fLlmz56tSZMmbXd7a9as0eOPPy5JuvLKK5snvyVp11131a9+9St985vf1LPPPquPPvpIO++8c/c/KbTLcRyVl0fU0JBk6QgUHHmDpX32GaPPfvZA8gYzLDMHoFQxvsESeYMF9k1hibzBGu+ldjgZQCorK2MiGAXHe2nhmZ1b8uabb+q1117Ta6+9ZvWQzR5++GFJ0kknnZRzWzQabf73pknt7WlsbNS3vvUtHXHEETrssMNybh89enTzz6tWrepMl9ElntLpjCQGDVggb7BE3mCNrAEoVYxvsETeYIF9BVgib7BG1mCJvMEC76WFZnYG+CWXXKKlS5fKcRwtXLjQ6mG1du1arVy5UpI0duzYNts0/fvrr7+uZDK53WVld911V11++eXt3v7WW29JklzX1dChQzvRa3SF50nxeMrvbiAgyBsskTdY4wBUAKWK8Q2WyBsssK8AS+QN1ngvhSXyBgu8lxae6RLofpzGv2zZMknZ5QTam4weMmSIJCmRSGj16tUaNmxYpx7L8zw9//zzuuKKKyRlzzjfcccdO7UtdI3j8EYFO+QNlsgbUPoSGb97AAu8zgCA7sa+AiyRNwAAuob30sIymwA/7bTTVFNTY/VwzdatWycpe73v9q7b0K9fv+afa2pqOjwB3tjYqG9/+9tasWKFamtrFQ6HdeaZZ7a63jjsuK6jioqo6usTymQYPVBY5A2WyBusuS7XWbPS8kDR65b61w/4g+t92WN8gyXyBgvsK8ASeYM13kthibzBAu+lhWd2DfBvf/vb+uEPf6gf/vCHnd7GlClTNHr06Lz/e+edd9TQ0CBJisVi7W63rKys+eem9h2xcuVKvfXWW6qtrZUkpVIpLVy4sHkp9K5qOeC6riPHafs2x9n69462ddpsm3vfrrXdVp860ra9umQynuLxVPOgsa22Hdnu9toGtd7d2bYYa+h5UkNDUpmM1yNqWOr17mmZta53JuOpoSGploJUbzJr21ZqPSlHvQvbtmXfEUw9IYdBGpOb/i2f/lPv9tsW05jsVw0ltdg3Le4aFkO9SymzHa2353mt9k231ZZ6k9muts1kPDU2tt43pd5t978ntC32ekv575tSwy19IrNt3Xf7n9uk7BhHvbfVlnx3Rw3b+p43977BqWFH2ubLdAl0P4RCIUm5b5rtcd2OHxMwcOBAvfjii6qsrNSiRYs0bdo0vfrqqzrzzDN111136YADDujwNps4jlReHtHmzQlJUllZROl0RvF4So6TPUKkoSGhdNpTOBxSNBrW5s3x5raZTFNbfdo2qXQ6o3A4pFgsrLq6prZheZ6aP7xWVETV2JhUKpVROOyqrCzS3DYWy8Ym37aOo+Y/5IqKqOLxlJLJtEIh99PnFpfnSdFoWK7rqqEh+1zLy6NKJJraOiovj2rz5oQ8z1M0GlYo5Kq+vqltRMlkWolEWq7rKBYLK53OKJPxFImEFQ5vaVtWFlEqlVEikZLrtj7KJhIJKRJpXcMt9c6toX/1TimVSrfRNiTHcfKud+saRpVMppprWFGxpd5b1zBb7/ZqGFYk4rbKbFO9mzLbXr3Ly7dd79waempsTLVRw5DKysI+Z7bj9W5Zw45lNsQY0cExomv19neMyL4vRBkjGCMKNkY0NDSqSTSarQ1jROHHiPLySHPdLxkuRc0OU4VfEpktZ/s7jmM6RmzeHFdjY1zRaEiRiNvibyzSfDCp4zjq1SuiRCKpdDqb72g01OJvrGVbqVevbP/T6YwikZBisdZts9c3yz5OZWW2/01/95FIuLltWVn2byHfto6zZTyprIwqHk+3qGFYjY0JeV7TeJJurr/rZpROtxwjImpsTMrzPMViYbmu09yHXr2a3tea6h1RPJ6dZIpGwwqHt7StqIgonfZa1Ltl2+yY3NT/1vXOrWEh6l1RUcbnCKPPEfF47t99ED5HsK9R3PsafB/BvkZHMtv0/RtjBGNEocaIxsYt+6aRSPY7fsaI4hkjivFzREuMET1/jCiFzxHpdEaVlTHGiA6OEflyvE6ut3fTTTdJks455xyFw9ufR6+rq9OVV16p+vp6/eY3v+nMQyqRSCiZzD0ioj3l5eV69tlndd5556lPnz567bXX2u3bgQceKEl64IEHNGbMmE71r0kmk9FZZ52lf/3rXzr44IM1Y8aMTm8rnc6otra++Yhx180e1dv0qrmu0+pM56YjR7K/O5I60nbL0XQt2+bet2ttt9V/ycm7bcv+t2zrOFIkElYymWr+vb22Hdku9aaG7fUpFHKVSqXVdNS9nzUs9Xr3tMxa19txpHA4pEwmo3Q6ePUmszZtGxoaVV19niTphhtuViQSo94GbROJhC666FxJ0mUjmAAPgkRG+tWS7M/Tpt2s8vIysxy2/DtHsDRlLYhjsvXniHg83vx3Nn36zYpGY0Vfw55c73zblnK9HcdTKBRq3jel3mS2kDVsa9+UevfsMaIY693Y2PF9U2pIZjtb760/u8ViZdS7gPXOp20x1bszNZS8nPfSINcw37b9+/dSKJTfl2adPgP8pptukuM4+t73vpfXBHgymdTDDz+sioqKzj6kotFou9fxbk9VVZWk7CR3MplUJBLJadPy2uT9+/fvdP+auK6rs88+W//617/0+uuvK5VK5VWj9rQMdMuft/7d81ovB9Py5660zb1vodpKUueea8vbHMdRNJrd6Wv6g2mvbUe2u722Qa13d7Ytxho6jlqtOJBv/3tC22Ksd0/LrHW9HSd7hH3TUXTb227u4xR3vcmsbdssJ6+21LvrbXNrj6DxI4cIpqCOyX59jpByv4zKt/89rYbFUO9SymxH6920r7D1vin1zq8tme1Y27b2Tal32/3vCW2Lvd5Z+e2bUsMtfSKzbd13222bOI5DvTvRNve+wcl3Z2rournvpbn3DU4NO9I2X9udlfU8T6tXr2739tWrV7e6hnZbksmkHnvsMUktj26wsdtuu0mSMpmMVq9erWHDhuW0WblypaTsdcIHDRq03W0mEgmtXLlSqVRKu+++e5ttBg8eLCl7PfCamhrtuOOOnX0K6KBMxmte9gEoNPIGS+QN1trbGQRQOqoHNypiu4vmq6Z9ZuPdUl8lPWnaqm3vs6OweD+FBfYVYIm8wRrvpbBE3mCB99LC2+4EuOM4+r//+z+9/PLLOf8uSccff3zeD+Y4jvbdd98OdrFr+vbtq+HDh2vp0qWaP39+mxPg8+fPlyTtt99+zdcM35bbb79dv/3tbzVy5Eg98cQTbbZZtWqVpOxZ6/369ev8EwAAAACAAok4LLlf8jJ+dwAAAHSF53lKJBLbb1hi4vF4mz8HTTQaNT+pEABKQV7rcl9++eU64YQTuvxGM2jQIF166aVd2kZnjBs3Trfeeqvuv/9+ff3rX291WyKR0KxZsyRJEydOzGt7hx9+uH7729/qvffe06uvvqqDDz44p83dd98tSfrCF77Q5rLrKBzHcVRWFlZjY6pTyyIAHUHeYIm8wRo72QAAdB3vp7DAvgIskTdbiUSi+drEQTV16kV+d8E306bdrFgs5nc3AoXPbrDAe2nh5TUBPnToUD3wwAOqra2VlD3q7Dvf+Y4cx9Hvf//7bS6B7jiOQqGQ+vXrp1133TWvM6y72xlnnKGZM2dq7ty5+tWvfqVLLrlE0WhUdXV1uvTSS7V8+XINHTpU48ePb3W/hoaG5jO5Bw8erPLycknZM8UPP/xwvfTSS7rkkkt0/fXX66CDDpIkbdq0Sddcc42ef/55lZWV6cILL+xa59NphRf8p9U/Zfr2U2bX4VJjo8KL3825S2rM/pKk0Hv/lVO/ufXmhg6TV9VfziefKLRqRavbvMpKpUeMzD7m22/mbnfPvaVIRO4HS+Ru2th6uzsPlrfTTnJqaxRa9mHr7ZaVKz1qtCQp/OYbW9YdbNru7qOl8nK5y5fJrVnf+rnuuJMygwbLqduk0JL3W283HFF6r72zz3Xh23JSyU9vceREXTlDPyOvV6Xc1avkfry29Xar+iszdJjU0KDwfxe1fqKOo9S++2W3u3iRnMaG1s912K7y+lXJWbtWoY9Wtd5u7z7KfGaElEwq/M7bW5dQqb33lUIhhZa8J6eurvV2B+8ib4cd5NSsV2j5stbPtaKX0iOzy+1vnQdJSo3aQyork/vhUrkbalv3aeDOygzcWc6mjQp9sKT1dqMxpffYM/tc335LTjrVersjRkqVlXJXrZT7ycett9t/gDK7DJXq6xV+b3Hr7Tqu0vuOyW530bty4o2tn+uuw+X17SdnzRqF1rS+xEKmT19lhn9GSiQUfndh7nPdZ4zkugq9/185m7fK95Ch8gYMkLNunUIrl7fuU69eSu+2u5TJKPzWgtzt7rGXFI3KXfqB3I0bWm934CB5AwfK2VCr0IdLW9+xrFzemE9z+OYCOV7rU2xSI0dJFRVyVyyXu35d6+e6w47KDB4i1dUpvOS91v0NhZXee5/sdt99R06i9QFI6c+MkNe7j9w1H8ld81Hr7TJGZLfb7hjxaZ9G7CavsndRjRHacUd569Yp9N4HanmdFsaIFn3qYWOEFytTevQe2edaJGNEfHT2NR+0aZMib76hcIsD+RgjPt1uAcaITCKhgXV1WlNZKaUziq1tnTNJiu/UT3IdRdZvkpvY6u+xT4XSFTG5DQlFNrTOvhcJKzGgtyQp9lFNznYTO/SRFw4pUrtZbmPrM0tSlWVKV5bLjScVqWk9LnkhV4kd+2a3u7ZW2mqZuET/3vKiYYU31itUv1VGy2NK9a2Qk0wpum5T6w45juID+0mSop9slJNKt7o52a+XMmVRheoaFa5rXd9MLKJk1ac1/LiNGg7sJzmOIus2yU22XcNQfVzhjfWttxsJKzmgt+R5iq2pzd3ujn2lkKtITZ3ceOsspSrLla4sk9uYUKR2y2sTykhDNoa0sk+f7O+GY0Ri8C6SpH4NDSpfu6HVEujpsqiSfSvkpNKKbf3aSGpsem3W1+XUMNmnQunyqEL1cUU2bfXaRMNKVFVKGU9lbbw2jTv0kUKuorWb26xhqldMbmNC0Q2tXxsvHFL803yXrd2QM0bE+/eWFwkpsrFeoYat8l0RU6p3udxEStGt8+26iu+YfW1iH2+Uk2n92iSqKpWJhhXe1KBwTr6jSvapkJNMK7Y+N9+NO336d7NuU06+E30rlCmLKrw53ma+E/16SemMyj5pPY5KUuOOfSXXUbSmrtUYEfKk3vEqbYrF5NTUKLy29fsCnyNa9KkbP0dkEgl9pubTMTeRCMznCPY1Pu2TD/saXp++8vbYPbuvsfAtbY3vIz59rj1kjGi13SLc11CfvtLqVQotW6VW1xBljMhut5vHiKb3FE/S0qoqSdKQjRsVTbf+HLG2Vy9tjkbVt7FR/Rtajx/1kYjWVFYqlMlo2Ibcz2JL+/WT5zjaedMmlada/z1+UlGhTbGYeiUS2mmr7DeGw1rdO/tZrPl9r4UVffooGQppx82bVbnVWew1ZWWqLS9XeTKpnbcal5KuqxV9s5+ZhtXWKrTVa7Oqd2/Fw2H1r69X361O2tsYi2ldRYWiqZSGbGr9WSzjOPrw09Va26rhml69VN9ODTdHIlqbRw0HbdqksnZq2Dse1w71rT/PNtXQ8TwN/3T+pZVEQorFimqMKM7PEbXNGW76LqRYxohmzGts2W5RfI7IzmOFEhmlh+wSqM8RXR0j8uZ10ujRo7099tjDq6+v7+wmTP3jH//w9t57b2/UqFHewQcf7H3jG9/wDjjgAG/UqFHeQQcd5C1evDjnPv/+97+9UaNGeaNGjfL+/e9/t7pt/fr13oQJE5pvP/LII72JEyd6++67rzdq1Chv7Nix3nPPPdflfqc/WZe9vnuL/xpO/Ka3du1G75N/z8+5zZO8tWs3emvXbvQSB34257YNv7vNW7t2o7fx6utzbot/6cve2rUbvY/fX9Hmdj9euMRbu3aj13jMsTm3bbriKm/t2o1e7R1359yW2He/5j5lotGc29e98Iq3du1Gr/7bZ+TctvlH1d7atRu9moefyLktNWhw83ZTgwbn3F7z8BPe2rUbvc0/qs65rf7bZ3hr12701r3wSs5tmWh0Sw333S/n9to77vbWrt3obbriqpzbGo85NlvDhUvaruH7K7y1azd68S99Oee2jVdf761du9Hb8Lvbcmt44Geb+9TWdj/593xv7dqNXsOJ38y5re7iKdka3vdQbg2Hf6Z5u+kBA3JuX//EM9ka/s/5uTX87ve9tWs3euv/9kLObenK3s3bTY7eI7eG99yXreFPf55bw/ETsvn+zztt53v5x9kaHnZ4bg2n3ZjN97Qbc/N92OHZPi3/uO0a/uedbL7HT8jN909/ns33Pffl3JYcvceWGlb2zq3h317I5vu738/N9/+cn63hE8/k1nDAgC35Hv6Z3Hzf95C3du1Gr+7iKTm3MUYwRuTkmzEiW0PGCM/T9seI5cs/9iZNmuQt6t8/5zbGiMKOEa8NGuRNmjTJm3/+19qs4ZsXTvDemDzJ2zh8YM5tK756gPfG5EnehyccnHNb3eD+3huTJ3lvTJ7U5nbf+cGx3huTJ3nr9xqWc9tHn9/Le2PyJO/9SV/Iua2xX6/m7SbLc1+b/572Ze+NyZO8tQftnpuHA3bz3pg8yVv8na/kvjbRcPN2Gwb0ybn9g2983ntj8iRv1RH75L5uo3fx3pg8yVt47vFtPtcFP/mG98bkSd6moTvmZn/cgd4bkyd5y8cdmJvRoTt6b0ye5C34yTfa3O7Cc4/33pg8yasZvUvObauO2Md7Y/Ik74NvfD7ntmV9+niTJk3yli//2HSMWDvjL96kSZO8+/faK/cx9xjiLage77373dz3Ik/yFlSP9xZUj/c2D6rKfT7jDvAWVI/3Vnw597XZuOuO3oLq8d5b549rc7tvn3O0t6B6vLdhRG6+V31xL29B9Xhv6Qm5r039Tn2a+5QOuTm3LzrjS96C6vHeun1y873msyO9BdXjvfcnHZpzW6KyrHm7icqynNvfn3Sot6B6vLfmsyNzblu3zzBvQfV4b9EZX8p9bUJu83brd8rN99ITDvQWVI/3Vn0x97XZMGKgt6B6vPf2OUe3WcO3zh/nLage723cNTffdxxwgDdp0iRv3W9uzn2ufI7Y8rdRoM8Rq159IzCfI9jX+LSG7Gt4nhgjmvPNvsaWGjJGZGvYyTEi4brepdf8xbvsulneysG5r83M037iXXbdLG/OCd/Jue2dPQ/yLrtulnfVz/7QZg1/+YsZ3mXXzfIWj8odex6d8H3vsutmeQ+c/KOc2z4cNsq77LpZ3mXXzWpzu9Muucm77LpZ3n8OOCLntr9/5ZveZdfN8u763mW5fxcDdvYuu26W99NrH/TqeuV+Zvr9+Vd5l103y3vpCyfk3PbvQ8d5l103y/vdj/5fbkZj5c39XTMw97P7n74zxbvsulne0+O+nXPbm/se6l123Szvuktzx0pP8n5+1X3eZdfN8paM2DvntodPPNe77LpZ3sMnnptz25IRe3uXXTfL+/lVuX/nnvgc0fRfoceIT265I/dvrsjGCD5HtMg3nyOy+S7BMSKVSuc9v+p4nud1bMo8a+XKlZKkIUOGdObuvli0aJFuvfVWvfrqq6qtrVVVVZUOP/xwnX/++Ro6dGhO+1deeUVnnHGGJOmee+7RIYcc0ur2RCKhe++9V4899piWLFmidDqtQYMG6YgjjtBZZ52lQYMGdbnP6URSG1/8d6t/69lHShXv0ZTNOFJqy3aL4kipFtsN2BHXxXk0JWMEYwRjRKvtbmOMSA/YQY077Chnc53CW+Vb4bCSe2bzHV70bs4YkRo+Ql7v3nLXfKTQ2jWtbsv07af0sF2lxkZFts63pLpRe2jq1Is0aNMmXXzOjxWNbjkDPLXLMHlVVXLXfaLQqpWtn2tlpVKf2U1KpxVp46yj5B57SZGIQks/aGOMGKTMjtkjrsPLs2NEJBKR4ziBGSMSiYR+deOvOStDxXlWxrK+fZV2Xe1UV6deydZZWl9erg1lZapIJDRwq9cmEcqeAT5t2s2qWLzI7HNE/eBddNHPJ6tfQ4Mu7MMZ4KV+BnjSk35dlz0DfPr/XakKzgA3+RyRSCQ0bdo1kqQLfn+3Yr17s6/BvkZ2u+xrZLcb8DGi1Xb5PiK7XcaI7HbbGCOa3lM8SbGjz5UbCmuHNcsVSW712b3/QDVWVKrXplr12dD6NW8sq1DNDoPkplMauLp1HSTpo8HD5bkh9f94lWLx1mPPhn47qL6yr8rrN6nf+tb9TURjWrdTdnWhQSu22m+V9PHAoUpFouq3bo3KG1qPPZv6VKmuT3/FGuvV/5PWf4+pcEQf7zxMkjRw1VK5mdafmdbtOFiJWLn61H6iXnWt/27qe/XRhqodFUnEtcParbLkOPpoyAhJ0o4fLVN4q9emZsBANZZXqnJjjXpvbP2aN5b3Us2AnRVKJbXTR63HSkn6aPBn5LmuBny8UtGtxp4N/XZUfWUfVdRtVN/a1mNaIlamdTsOkZPJaOdVH0iSMum0Plz4lCQ+RzRvt8BjRGLNGv32onMlSdXVUxSNRotmjGjG54gt2+VzRHa7JThG9O/fS6GQm3NbWzo9AZ6P1atXa82aNRo6dKgGDBhQqIcpael0RuvXb95+QzRzXUcVFVHV1yeUyRQs3oAk8gZb5C04PM/TtGnXaMlWHyKDZMSIkaqunhKYa2/F4/HAX9cvyKyv69cyb5OHNCqa374jilQiI127MnvZMq4haafl39kNN9yiSCTqc49Q6thXgCXyZqvle8roz54sN5TXVU1RxDLplBa9dp8kPr9Z4bMbrPFe2jkdmQDv8rvlG2+8occff1znn3+++n16pkZ9fb3+93//V//4xz8kZa8Dfuyxx+qKK65QZWVlVx8S2KZMxlNjY5JBAybIGyyRN6B0RaNRTZt2s9/dMBePxzV16kWSpKuvnh7YL3aiUf++XElktt8GxY3X2H98doMF9hVgibwBKGWMbbDAe2nhdWkCfPr06brtttskSSeccELzBPgvf/lL/f3vf29u53me5syZo5UrV2rmzJmBOZMH/kml+JYHdsgbLJG3YHAcR9XVU5TYajlqK00LBPn5mS0ajQbqM6PjOIGd/G0Si8UCXwMrLRcBm766zMeewFoBF4AD0AOwrwBL5A0AgK7hvbSwOj0B/vrrr+v3v/+9JKlv375Kfnqtu48//liPPvqoHMfRnnvuqfPOO08LFy7UbbfdpjfeeEMPP/ywvvGNb3RP74F2hMMhpba6nh5QKOQNlshbcPg5Ifr2229q1qz7dOKJJ2vvvff1pQ8AAADoGPYVYIm8AQDQNbyXFlanJ8Dvv/9+SdL++++vO+64o3lp86efflrpdFqO4+jXv/61PvOZz+grX/mKHMfR7373Oz3xxBNMgKOgXNdRWVlY9fUZlo9AwZE3WCJvsJBMJjVz5j2qqVmv++6boZ/97EpFIhG/u4UAcN3gnPHvt5arK1w0iGuAl7pEZsuZ/kFaWaMnYXyDBfYVYIm8AShlfHaDBd5LC6/TE+Bz5879dHnO6lbX9X7hhRckSbvvvrs+85nPNP/7cccdp9/97ndatGhRF7oLbF8m46muLu53NxAQ5A2WyBssLFgwXzU16yVJ69ev04IF83XggQf73CsEATt8/oi6YgIcKDDGN1hgXyFYPM/z7XJJTY9fX9/g24FVQbtcUkuZdMrvLsAAr7O/+OwGC3x2K7xOT4B/8sknkqSRI0c2/1sikdCrr74qx3H0+c9/vlX7AQMGSJJqa2s7+5AAAAAosDFjDlBVVX/V1KxX//4DNGbMAX53CQAAAMCnPM/TtGnXaMmS9/zuim9GjBip6uopgZkE97wtk3H/ff1BH3sCP7R8/QEA+evysf4tjzacN2+eGhoaJEmHHXZYq3ZNE+ZlZWVdfUhgmxzHUVlZJDAfguEv8gZL5A0WIpGITj31O9p550E65ZQzWP4cZhjbAJQqxjdYYF8BAIDuwXspLPDZrfA6fQb40KFD9d5772nhwoXaeeedJUl/+9vfJGUnuQ855JBW7Z955hlJ0vDhwzv7kAAAADCw9977auzYAxSPpzjaHAAAAOhBspeknOLbEujxeFxTp14kSbrmmhsUjUbN+xC0JdBbPtfdx54kN9Tpr/RRJDLpVPPZ/kHKOgB0p06/Wx5++OH673//q//3//6fqqqq9Mknn+jBBx+U4zj60pe+1OrDz5w5c3TbbbfJcRx98Ytf7JaOA+3xPE+NjUm/u4GAIG+wRN5g5a23FmjWrPt04okna++99/W7OwgIDrYAUKoY32CBz2/B4jiOYrGY391QNBrtEf0IEjcUZgIcKDA+u8EC3/MWXqeXQD/zzDPVt29fLV26VKeeeqp+9KMfKR6PKxQK6Qc/+EFzu6OOOko/+clP1NDQoAEDBuiMM87olo4DAACg+yWTSc2ceY/WrPlI9903Q8kkH8YBAAB6Mj6/AQAAAK11+nCxgQMH6o477tAll1yiDz74QJLUr18//exnP9Oee+7Z3K53797yPE/Dhw/Xb3/7W/Xt27frvQa2wXUdVVREVV+fUCbD0VooLPIGS+QNFhYsmK+amvWSpPXr12nBgvk68MCDfe4VgsB1WdoPQGlifEOh8fkNfmF8A9DdPM/z5RIP8Xi8+edk0p9LTATt8g5Bx/e8hdel9VL23XdfPfnkk3rvvfcUj8e1++6751z35fTTT1dlZaWOOuoohcMsz4LCy2SyS0cwaMACeYMl8gYLY8YcoKqq/qqpWa/+/QdozJgD/O4SAoKxzR9JT1LG717YaVrNMEjfKyX50/Id4xsKjc9v8AvjG4Du5Hmepk27RkuWvOdrPyZPvtCXxx0xYqSqq6cwCR4QfM9beN0yIz1y5Mh2bzvxxBO74yGADkmlAvQtHnxH3mCJvKHQIpGITjnljOZrSEYiEb+7BKCApq0q87sLAIAu4vMbAABA8eF73sIyPSW7rq5OklRZWWn5sAigcNhl8IAZ8gZL5A0W9t57X+23335kDQAAoEjw+Q0Ihkwm5XcXTHmfLt8TtDNig/Y6N3EcR9XVU3xZAl3K5i0cdpVO+3NGLkugBw/f8xZWXhPgU6dOleM4uuKKKzp9FGl9fb0OOuggua6rhQsXdmobQD5c11FZWYRrJ8AEeYMl8gYrZA1+4BqSdqLRqKZNu9nvbpiLx+OaOvUiSdK1196gSCS6nXuUnq0vWQYbjG+wwOc3+IHxzd5/5z3odxeAgnIcR7FYzJfH5prMsMRnt8LLawL84YcfluM4+r//+782J8AbGxt13HHHyXVd/e1vf9vmtpqO2gIKJZPxVFcX97sbCAjyBkvkDVbIGvzADp8dP79U6ikikWjgawA7jG+wwOc3+IHxDUAp4b0Ulshb4XXLEuiZTEarVq1ieQYAAAAAAAAAALoJq/dIV189PbAHL7KCj523335Ts2bdpxNPPFl7772v390B0EWm1wAHLGTPaAkrHk+x4gAKjrzBEnmDFbIGP3AwLSyRN1gib7DA5zf4gfHNBqv3SGVlZUwEo6CSyaRmzrxHNTXrdd99M/Szn13Z6csBA/ngs1vhMQGOksTnb1gib7BE3mCFrAEAuoPneUokEn53w1w8Hm/1cxC/1IpGo4GbHPM/72HF42lf8hbE1xsAUDoWLJivmpr1kqT169dpwYL5OvDAg33uFUodH50KiwlwlBzP89TQkPS7GwgI8gZL5A1WyFrw+PWFfcsJosbGRr6wh5kgTkb6JZFIqLr6PL+74aspUy70uwu+mDbt5kCdseh5nqZNu0ZLlrznd1d8MWLESFVXT+E9NWB4P4UVsoZCGzly9DZ/B7ob370VHhPgAAAAQID1lC/sm67vZ40v7AEAAAAg2J5++omc3ydNOtWn3gDoDkyAo+S4rqOKiqjq6xPKZDg6EIVF3mCJvMEKWQNQ6lyXAx788MuDdlQ0QLVvOlstSAfYJDKe/m/ux353wxeO46i6eopvK6o0HUh27bU3KBKxv04uK6oEE++nsELWUGjHHz9Bzz//rDwvI9d1dfzxE/zuEkoc370VHhPgKDme5ykeT7E0DkyQN1gib7BC1oLFzy/sszyFwyGl0xn5ETm+sA8mxjd/RF1HsZDrdzdQUBm/O+Arx3F8X/Y9Go0qGg3O0vPwF++nsELWUGgVFRU6/viv6cknH9Oxx45XRUWF311CieO7t8JjAhwlx/OkZDLtdzcQEOQNlsgbrJC14OkJX9iHQr4+PAKG7xgAlCrGN1gib7BC1mDh2GPH69hjx/vdDQQE370VHodeoySFOKsAhsgbLJE3WCFrsETeAAAAAAB+Y98UlshbYXWouiwNiGLguo7KyyNcGwYmyBsskTdYIWuwRN7gB/IGoFQxvsESeYMVsgYL7JvCEnkrvA4tgX7ccce1OQneco36o446qs37so49rGQynjZvjrM0DkyQN1gib7BC1mCJvMEPmQyBA1CaGN9gibzBClmDBfZNYYm8FV6HJsBXrVq1zds9z9PKlSu71CGgOzBowBJ5gyXyBitkDZbIGwAAAADAb+ybwhJ5K6y8JsA/+9nPFrofQLdxHCkaDSuRSDGAoODIGyyRN1gha7C0cOGbmjXrLzrxxG9pr7329bs7CAiu7gWgVDG+wRJ5gxWyBgt8FwJL5K3w8poAnzFjRqH7YWLx4sW65ZZb9Morr2jjxo3aaaeddMQRR+jcc8/VwIEDu+Ux7rrrLl199dU6+OCDS6ZuxceR67qSHEmMHCg08gZL5A1WyBpsJJNJ3XvvPaqpWa+ZM2foZz+7UpFIxO9uIRD4FhVAqWJ8s+B5nhKJhN/d8EU8Hm/xcyKQX9pHo9E2LxOKQqLesMB3IbBE3gqtQ0ugF7O5c+fqrLPOUjweV1VVlUaNGqUPPvhAM2fO1Jw5c3T33Xdrzz337NJjfPDBB5o+fXo39Rid5XmeGhqCuRMCe+QNlsgbrJA1WFmwYL5qatZLktavX6cFC+brwAMP9rlXCAIviN/WAwgExjcbiURC1dXn+d0N302ZcqHfXfDFtGk3KxaL+d2NQGFsgwW+C4El8lZ4rt8dsFBbW6vzzjtP8XhcZ599tl566SU99NBDevHFF3XMMcdow4YNuuCCC7p05GY6ndbkyZPV2NjYjT0HAAAASteYMQeoqqq/JKl//wEaM+YAn3sEAAAAAACAYheIM8BnzJihDRs2aP/999fFF1/c/O+VlZW6/vrr9fbbb2v58uWaPXu2Jk2a1KnHuP322/XGG2+ovLxcDQ0N3dV1dILrOiovj6qhIaFMhqMDUVjkDZbIG6yQNViJRCL69re/owcfvE8nnXQyy5/DjOuyjCaA0sT4Zm+/L5wmNxSIr1ibNZ2NG6RlwDPplN548U9+dyOwGNtgge9CYIm8FV4gPp09/PDDkqSTTjop57ZoNKqTTjpJN9xwgx5//PFOTYAvWrRIN910kwYPHqxjjjlGf/zjH7vcZ3Re9jpMKZbGgQnyBkvkDVbIGixlc+aRN5gibwBKFeObPTcUVijEQXxAITG2wQLfhcASeSu8kl8Cfe3atVq5cqUkaezYsW22afr3119/XclkskPbTyaTmjx5slKplK688kr16tWrax1Gl3melEymxbgBC+QNlsgbrJA1WEkmk7r33nv00UcfaebMGR3+LA50FuMbgFLF+AagFDG2wQLfhcASeSu8kp8AX7ZsmaTskjxDhw5ts82QIUMkSYlEQqtXr+7Q9m+66Sa98847+ta3vqXDDjusa51FtwmFSj7a6EHIGyyRN1gha7CwYMF81dSslyStX79OCxbM97lHAAAAAICg4rsQWCJvhVXyS6CvW7dOUvZ639FotM02/fr1a/65pqZGw4YNy2vbCxYs0B133KEhQ4bokksu6XJf0T2y106IqL6eayeg8MgbLJE3WCFrsDJmzAGqquqvmpr16t9/gMaMOcDvLiEguI6kPxJpT1LG726ggLKvsT+yy0gmfHt8P8Xj8eafk8lg1iAajQbqetRA0PDZDRb4LgSWyFvhFdUE+JQpU5qv552PRx55RA0NDZKkWCzWbruysrLmn5vab088HteUKVOUTqd11VVXFXTpc9d1mv8AXNeR53nNyyK0vM1xsme6b/ndUfZ6ivm23XI9lZZtc+/btbbb6r/k5N22Zf9bts1kPDU0JPJq25HtUm9q2FafPE/avDkuz+sZNSz1eve0zFrXO5PxtHlzvNUXO0GqN5m1a5vJeKqvT7S6DhH1Jt+FqHckEtG3v/0dPfDATJ144smKRiPUkMwWrN5bT4w0fZaj3oXNd8v3kv+b97EQJLafIxKJhKqrzyvkEyoKkydf6HcXfDFt2s0qK4uZjbNMtgeb6zp8juiGttv7HNFSvvum1JB9ja7UW9ryPS/1Jt+FrmEmk/s9b5Br2JG2+Sr58+tDoZCk3C872uO6+ZVk2rRpev/993Xqqafqc5/7XKf7tz2OI5WXR5p/LyuLKBoNf3qbo4qKqEKh7HMLh0MqL4+201aftnWb21ZUtGwbViy25XiIioqowuGmtm6rtrFYx9qWlW3dNvuahELZtk0vTTQaVlnZludaXt6yrfNpW6edthFFItm2ruuovDwq1822jURaty0riygSCTe3raho2bZjNfSv3qF22oY6VO+W2Sovj7aqYct6b13DbL3bq2E4J7NNbZsy2169y8s7WsNQOzUMmWa2aVBundnt53vrenc+s4wRHR0julZvf8eIprpsu96MET1pjGhZw2IaI2IxxojO1ZvPER0dIz772QN1+eVXae+992WMKKIxojg/R2xpW14eYYxot97dP0YgmPwYIxBsfn2OSKeT/BeQ/1rmhc8Rtp8j+D6CfQ2rfY2m73n5PqJ4xohi/s7S8xgjWrbNd4zIl+O1PHyqh0skEkomk9tv+Kny8nI9++yzOu+889SnTx+99tprbbarq6vTgQceKEl64IEHNGbMmG1ud+7cuTr99NM1ZMgQPfroo6qoqGi+7cYbb9RNN92kgw8+WDNmzMi7r+1JpzOqra3nyJ3t9L9lW8fJfmkfjyebf++pR/mUQr2DXkPHcRSJhJRIpOQ4/tew1Ovd0zJrXW/HyX7oSKXSSqeDV28ya9c2+14aViKRUiZDvcl3YesdCjkKh7PvpU39oIalnVnHkRobtyzXa1XveDyhKVMulCRdd90NikSi5jWMxWKtbgtCvuPxePNZub88cEdFP/0SA6Upkfaaz/SfPv1mRaPZ1fgsMtsya4cd832FQsE6CGPLGBucv7F0OqmXn7pDkv0Z4I2Njaw4EGDTp9+c855eqp/b/Pwc0fLv7IYbblYksv33FGrIvkZX6t1635R6F7repZTvztRQ8nK+5w1yDfNt279/r7yvnV5US6BHo9F2r+PdnqqqKknZSe5kMqlIJHcHqKampvnn/v37b3N79fX1mjJlijzP01VXXdVq8rtQWga65c9b/+55rZeDaflzV9rm3rdQbaWWS6R15Lm2vM1xHLludjmqpj+Y9tp2ZLvbaxvUendn22KsoeNkj4pqOVjn0/+e0LYY693TMmtdb8dxFAq5SibTeW0393GKu95k1q5t9r3UVXaHz9vudql319sGOd+e1/q9lBpuv/89oW1n6+15nn7962u0ZMl78tMll1zoy+OOGDFS1dVTOvzZsdjz3SQachTL88sKFKst13hvGRmrzDYJhSIKhYM1AQ7b97Wt2yNYsp9ZW//epJQ+tzW19TxPiURC1uLxeIufE8pkttG4gNqajyi2z2I9IYfF8Nl3633T/LcrUe+27hucfHemhq6b+z1v7n2DU8OOtM1XUU2Ad8Zuu+0mScpkMlq9erWGDRuW02blypWSskfjDxo0aJvbe/PNN7V8+XJJ0umnn95uu1dffVWjR4+WJP3973/XLrvs0qn+o+Mymex1SwEL5A2WyBuskDVYIm8AAKDYtDzTfswXvh24FQeCKJ1OasGLf5YUrJUWPM/TtGn+H7w4efKFvj12ywMYUdrYN4Ul8lZ4JT8B3rdvXw0fPlxLly7V/Pnz25wAnz9/viRpv/32a75meHt69+6tsWPHtnv76tWrtXr1alVWVmrUqFGSshPrAAAAABB0juOounqKL2cRSVuOGvfrC8xoNMqXpwBQYkKhCBPgAAAAPUzJT4BL0rhx43Trrbfq/vvv19e//vVWtyUSCc2aNUuSNHHixO1ua6+99tLMmTPbvb3pGuB77bVXt1wDHB3nuo7Ky6NqaEi0uxwa0F3IGyyRN1gha7BE3oLHcRzfDhImbwAAAPnz++DFd999W7Nnz9KECSdp9Oi9fOkDBzAGB/sKsETeCi8QE+BnnHGGZs6cqblz5+pXv/qVLrnkEkWjUdXV1enSSy/V8uXLNXToUI0fP77V/RoaGrRq1SpJ0uDBg1VeXu5H99FBnucpmUxxPSaYIG+wRN5ghazBEnmDJfIGBEM6lfS7CzDA6wzY8OvgxWQyqXvvvUd1dZt0771365e//H+KRFhtAYXDvgIskbfCC8QE+IABA3Tttdfqggsu0IwZM/TYY49pl1120QcffKDNmzerT58+uuWWW3LeQBcsWKAzzjhDknTPPffokEMO8aP76CDPkxKJtN/dQECQN1gib7BC1mCJvMESeQNKV8svD19++g4fewI/8OUxUHpef32u6uo2SZI2bdqk11+fq0MOOdTnXqGUsa8AS+St8AIxAS5JRx55pGbNmqVbb71Vr776qt59911VVVXp6KOP1vnnn6+hQ4f63UV0I9d1WDYCZsgbLJE3WCFrsETeYIm8AQC6Uyad8rsL5poOOAjSstBBfJ39t/XnNT6/ofDYV4Al8lZYgZkAl6TRo0dr+vTpebc/5JBDtGjRog49xgUXXKALLrigo11DN3JdRxUVUdXXc+0EFB55gyXyBitkDZbIGyyRN6B0tZyIO+zo7ysUZpncUpdOJZvP9vdzIvaNF//k22MDpWzfffff5u9Ad2NfAZbIW+EFagIcwZDJeAwaMEPeYIm8wQpZgyXyBkvkDQiGUDjCBDgAFLk333wj53eWQEchsa8AS+St8JgAR0li0IAl8gZL5A1WyBoskTdYIm8AgK6KRqOaNu1mv7vhi3g8rqlTL5IkXX31dMViMZ97ZC8ajfrdhYBgCXTYY18BlshbYTEBjpLjOFIkElYymZLH+IECI2+wRN5ghazBEnmDpYUL39SsWX/RiSd+S/+/vTsPb6pM/Db+Tdq0UChLETuIuELYiwVGEAVlmWETlE3FBdCREUf5jTqMAuKOGyOOgooijiIOqCiCIMKMiCsoImAVkcompZZFylagTdqc94++ybQ0LW1pnpyk9+e6uAaSJ+mTeM9pkifnnFat2oZ7OgCACOVwOKrlwu+JatSIV1wczwNCo33732vBgreUk5Oj2rUT1b7978M9JUQ53pvCJHoLPWe4JwBUNYfDodhYZ1jP/4Tqg95gEr3BFFqDSfQGU7xer+bOfV27d2dp3rw58nq94Z4SAAARjddvCCWXy6VRo0brd79rpFGjbpbLxaktEFq8N4VJ9BZ67AGOqOM/dwJgAr3BJHqDKbQGk+gNpqSlrdeBA9mSpOzs/UpLW68OHS4M86wAAIhcHLoVodayZRvdd9/kcE8D1QTvTWESvYUeC+AAAAAAgKiXkpKq+vWTdOBAtpKSGiglJTXcUwIQIgUF1e8ID9b/P3ZmddqLqDr+dwaqm40bv9e7776pIUOuUevWnL4GAFB+LIAj6jidDtWo4VJurpdvoiLk6A0m0RtMoTWYRG8wxeVy6ZJLLtXSpe/r4ou7cRhNIIqtWj4r3FMAqgWns/p84QLmeb1ezZv3ug4cyNabb87R/fc/yus3hBTvTWESvYUeC+CIOpZlKT/fF/j2MxBK9AaT6A2m0BpMojeY4vV69cUXn6qgoEBffvmZevbszYeohnl8liRfuKdhTHXcI9fDh3dAtcLrN4QSp6+Babw3hUn0FnosgCPqWJbk8eSHexqoJugNJtEbTKE1mERvMIUPUcPvvrX7wj0FRLG4uDg9/fQL4Z5GWOTl5WnChDslSY8//k/Fx8eHeUbmxcXFhXsK1RKf2SOUOH0NTOO9KUyit9BjARxRyel0cNgIGENvMIneYAqtwSR6gwl8iApEN4fDUS0Xfk8UHx/P8wAgKrhcLg0fPiJwDnCO3AMTeG8Kk+gttFgAR9RxOh1KSIjTsWMeNh4IOXqDSfQGU2gNJtEbTHG5XLruupF8iGpYdd0rt+geuU8++Yxcruq3dyp75IYH52SGSfSGUGvbNkWdOnXkvQKM4L0pTKK30GMBHFHH57PYaMAYeoNJ9AZTaA0m0RtMatmyje6//1F6M4i9ciWXK67aPwcwh+0bTKI3hBrvFWASvcEkegs9Z7gnAIQCGw2YRG8wid5gCq3BJHqDSfQGAAAQOXjtBpPoDSbRW2ixAI6o43BIcXExcnAUJhhAbzCJ3mAKrcEkeoNJ9IZwoDeYRG8wid4Qarx2g0n0BpPoLfRYAEfUcTgccrli5GDLAQPoDSbRG0yhNZhEbzCJ3hAO9AaT6A0m0RtCjdduMIneYBK9hR7nAEfU8fksHT3qCfc0UE3QG0yiN5hCazCJ3mASvSEcOLQhTKI3mERvCDVeu8EkeoNJ9BZ67AEOAAAAAAAAAAAAAIgKLIAj6jidDiUkxMnp5NARCD16g0n0BlNoDSbRG0yiN4QDvcEkeoNJ9IZQ47UbTKI3mERvoccCOKKOZVkqKPDJsjgME0KP3mASvcEUWoNJ9AaT6A3hQG8wid5gEr0h1HjtBpPoDSbRW+hxDnBEHcuS8vLywz0NVBP0BpPoDabQGkyiN5hEbwgHPtOCSfQGk+gNocZrN5hEbzCJ3kKPPcARlRwODhsBc+gNJtEbTKE1mERvMIneAAAAIgev3WASvcEkegstFsARdZxOh2rV4twJMIPeYBK9wRRag0n0BpPoDeFAbzCJ3mASvSHUeO0Gk+gNJtFb6LEAjqjj81k6ftwjn4/jMCH06A0m0RtMoTWYRG8wid4QDvQGk+gNJtEbQo3XbjCJ3mASvYUeC+CISgUFbDRgDr3BJHqDKbQGk+gNJtEbAABA5OC1G0yiN5hEb6EVG+4JAFXN4ZBiY2OUn18gi+0HQozeYBK9wRRag0n0BpPoDeHAqf1gEr1VD5ZlyePxhOVn5+XlBf7+/fcb1LbtBcbnEBcXx3lTqwleu8EkeoNJ9BZ6LIAj6jgcDsXFxaqgwCeLLQdCjN5gEr3BFFqDSfQGk+gN4cAiDUyit+hnWZaefvoJbdu2JdxT0auvzgzLzz3vvKa6667x9F4N8NoNJtEbTKK30GMBHFHH57N09GjeyQcCVYDeYBK9wRRag0n0BpPoDeHAef1gEr0BiCa8doNJ9AaT6C30WAAHAAAAAAAAgAjgcDh0113jw3YI9GPHjum++/4uy7LkdDr18MNTlJCQYHQOHAIdAACcDAvgiDoOh0M1ariUm+vl0BEIOXqDSfQGU2gNJtEbTKI3hAOLNNVHuM7LXPSczOFaFGVB0iyHw6H4+Piw/Owffvgu8DvU5/Np27af1aHDhWGZC6Ifr91gEr3BJHoLPRbAEYUs+Xw+SWw0YAK9wSR6gym0BpPoDSbRG8KB3qoDu5yXefz4O8Lyczknc/WRkpKq2rVrKycnR7VrJyolJTXcU0JU47UbTKI3mERvoVatFsDT09M1Y8YMff311zp8+LBOP/10devWTbfeequSk5MrfH/Tp0/Xc889V+aYCRMmaNSoUZWcMSrDsqS8vPxwTwPVBL3BJHqDKbQGk+gNJtEbwoEdOgBEn8IvOvB9B4Qar91gEr3BJHoLvWqzAL527VrddNNNysvLU/369eV2u7V9+3bNmzdPS5cu1ezZs9WyZcsK3edPP/0kSTrvvPNUr169oGMqs7COU+dw8CEDzKE3mERvMIXWYBK9wSR6AxAK4Twvs9fr1QMP3KPc3FzVqFFTDz30hFwul9E5cAj06iMtbb1yco5Iko4cOaK0tPUcAh0hxWs3mERvMIneQqtaLIAfPHhQf/nLX5SXl6fRo0frjjvuUGxsrHJycjRx4kQtX75cY8eO1dKlSxUXF1fu+/UvgD/xxBNq165dqKaPCnI6HUpIiNOxYx75fGw9EFr0BpPoDabQGkyiN5hEbwgHp5NFweoiXOdl/vbbNcrNzZUk5eYeV1raenXp0tX4PFA9pKSkqn79JB04kK2kpAYcAh0hxWs3mERvMIneQs8Z7gmYMGfOHB06dEgXXHCBxo0bp9jYwnX/2rVr66mnntKZZ56pjIwMLVq0qNz3mZOTo8zMTDkcDjVt2jRUU0cl+HyWjh/3stGAEfQGk+gNptAaTKI3mERvCAd6Q6jt3LmjzH8DVcnlcmn48BFKTv6drrnmBuNHG0D1wms3mERvMIneQq9aLIC/9957kqShQ4eWuC4uLi5w+ZIlS8p9nz/99JMsy1Ljxo1Vq1atqpkoqkxBgS/cU0A1Qm8wid5gCq3BJHqDSfQGINr07TuwzH8DQCTjtRtMojeYRG+hFfUL4Hv37lVmZqYkqX379kHH+C9ft26dvF5vue538+bNkiS3210Fs0RVcjgklytGnHoKJtAbTKI3mEJrMIneYBK9IRzoDaG2ZcvmMv8NVCWv16t5817Xnj279eabc8r9WSpQGbx2g0n0BpPoLfSi/hzgO3fulFR4HqYmTZoEHdO4cWNJksfjUVZWls4666yT3q///N/NmjXTihUrtGLFCmVmZiohIUHt2rXTsGHD1KBBgyp6FKiIwnNuxaqgwCfL4vARCC16g0n0BlNoDSbRG0yiN4SDg0+1EGIpKamqUaOmcnOPq2bNmpyTGSGVlrZeBw5kS5Kys/crLW29OnS4MMyzQrTitRtMojeYRG+hF/UL4Pv375dUeL7vuLi4oGPq1asX+PuBAwcqtAD+xhtv6KWXXip23ccff6yZM2dqypQp6tWrVyVnjsry+Szl5OSFexqoJugNJtEbTKE1mERvMIneEA6c1w+h5vV6lZeXK0nKzc2V1+vlvMwImZSUVNWvn6QDB7KVlNSAL1wgpHjtBpPoDSbRW+hF1CHQx48fr+bNm5f7z6ZNm3T8+HFJUnx8fKn3W6NGjcDf/ePL4vP59PPPPwfud/LkyVq9erW+//57vf322+ratauOHj2qO+64Q99+++0pPmrJ6XQU+3vRL48Xvc7hOPHfFR3rCDq25G1PbWxZc6rI2Mo+L6Eay/N96mN5Ds2O5fk2O5bn+9TH8hyaHcvzbXYsz/epj+U5NDuW59vsWJ7vUx8bruewqEh/DiPh+Y6mZisy9oMPFgX2HLIsS0uXLip1LM938LE0W/6xLpdLw4ePUHLy73TttSMCX7bg+Q4+fzuM5fk+9bE8h2bH8nybHcvzfepjeQ7Nji2viFoAr4yYmBhJxf9jlsXpPPlTkpubq5EjR+ryyy/XG2+8oWHDhikpKUlxcXFq166dZs6cqUsuuURer1dPPPHEKc3f4ZBq1vzft3Zr1HApLi72/1/nUEJCnGJiCh9bbGyMataMK2Ws/v9YZ2BsQkLRsbGKj//fAQESEuIUG+sf6yw2Nj6+YmNr1DhxbOF/k5iYwrH+/zRxcbGqUeN/j7VmzaJjHf9/rKOUsS65XP+73zp1agQeq8tVfGyNGi65XIVzcjoL79f/fx6Xq2LPYfie75hSxsZU6Pku2lbNmnGB59D/vPif7xOfw8Lnu7TnMLZEs/6x/mZLe75r1qzocxhTynMYY6zZmjVdqlnTJYfDcUKzJ+/7xOe76HNYsWbZRlRkG3Hqz3f4thEOh0O1asUpIeF/X+piG2HvbUTpzdp7G+FwOJSYGK/4eFcFnm+2EeHeRpT/+bbbNiJeCQmFv0vZRkTGNqLk2MjZRhS+ZnOdMJZtRLDn0D7biMh9HeHnf6xsI+y/jQj+fNt/GzF06NDA51lOp1PDhg1jGyH7byMi+XVEmzYpmjLlKXXs2KHYWLYR9txGRPLriML3pjVKPC9sI+y9jfjfcxhpryPiA5/zso2IjG2E//mOxNcR/3tvGs82QhXbRpSXw4qgg8t7PB55vd5yj69Zs6ZWrlypv/zlL6pTp46++eaboONycnLUoUPhC7b58+crJSXllOe6bt06DR8+XJL02WefKTk5uVL3U1Dg08GDxwKHTHM6HbIsS/7/ak6nI3Cd/1sb//u3Q1JFxirwjeGiY0ve9tTGljV/yVHusUXnX3Ssw+FQjRqxys3Nl2VZZY6tyP3yfPMcBp+TU3FxMcrLy5fDobA/h9H+fNutWdPPt/8FuNdboIICX7V7vmnW3Fj/79K8vPxit+X5pu9QPN8xMU65XIW/SyWL55BmQ/p8Swr8LvX5fDzf1ahv089hXl6e7rrrL5Kkf/5zhuLi4iL+ObTz813esdH8fH/44WItXfq++vYdqP79B/B8V+I5pNnyjw323pTn297biEh9viv63pTnkGZP5fku/t5UPN8hfr6jqe/KPIeSSvwurc7PYXnHJiXVCny54GQiagG8MvwL0U6nU2lpaUHPgZSRkRE4V/eKFSt05plnnvLPzc3NVbt27SRJc+fODSywV1RBgU/Z2UdPeT4AAAAAAMCMogvgTz/9QpmnZQMAAAAAnFxFFsCj/hDo559/vqTC83ZnZWUFHZOZmSmp8HzejRo1Kvd95+WVfoJ6n+9/39gItugOAAAAAAAAAAAAAKhaUb8AXrduXZ1zzjmSpPXr1wcd47+8Xbt2gXOGl2XevHlq166dunbtqoKCgqBjfvzxR0mF5yA/99xzKzFzVJbT6VDt2vFyOh0nHwycInqDSfQGU2gNJtEbTKI3hAO9wQS2bzBp06YfNHnyJG3a9EO4p4Iox7YNJtEbTKK30Iv6BXBJ6tOnjyTp7bffLnGdx+PRu+++K0kaNGhQue6vdevWys3N1aFDh7RixYqgY2bNmiVJ6tq1qxITEyszbVSSz2cpN9db7FwIQKjQG0yiN5hCazCJ3mASvSEc6A0msH2DKV6vV//+92xlZWVp7tzX5fV6wz0lRDG2bTCJ3mASvYVetVgAHzFihOrWrau1a9dq8uTJ8ng8kqScnByNGzdOGRkZatKkiQYMGFDsdsePH9fWrVu1detWHT9+PHB5SkqKOnfuLEm6//77tXr16sB1OTk5uu+++7Ry5UrFx8dr3LhxBh4hTpSf7zv5IKCK0BtMojeYQmswid5gEr0BiFZs32BCWtp6HTiQLUnKzt6vtLTgR9wEqgrbNphEbzCJ3kIrNtwTMKFBgwZ68sknNXbsWM2ZM0eLFy/WmWeeqe3bt+vo0aOqU6eOZsyYUeJc3WlpaRoxYoQk6fXXX1enTp0C102dOlU33nij0tPTNWrUKDVq1EhJSUnatm2bjh8/rpo1a+rZZ59Vs2bNjD5WFIqNdbLxgDH0BpPoDabQGkyiN5hEbwCiFds3mJCSkqr69ZN04EC2kpIaKCUlNdxTQpRj2waT6A0m0VtoVYs9wCWpe/fuevfdd9WvXz/Fxsbqp59+UkJCggYNGqQFCxZUeKH6tNNO0/z583X33XerTZs2OnTokH7++Wc1bNhQ1113nZYuXapLL700RI8GZXE6HapRw8W5E2AEvcEkeoMptAaT6A0m0RvCgd5gAts3mOJyuXTddSPVqFEjXXvtiBI7FAFViW0bTKI3mERvoeewLIsDzNtYQYFP2dlHwz0NAAAAAABQTnl5ebrrrr9Ikp5++gXFx8eHeUYAAAAAENmSkmopJqZ8+3ZXmz3AAQAAAAAAAAAAAADRjQVwRB2Ho/DQEQ4Hh45A6NEbTKI3mEJrMIneYBK9IRzoDSawfYNJ9AZTaA0m0RtMorfQYwEcAAAAAAAAiGAbN36ve++9Rxs3fh/uqQAAAABhxwI4oo5lWcrN9YrT28MEeoNJ9AZTaA0m0RtMojeEA70h1Lxer+bOna3du7M0b97r8nq94Z4Sohy/T2EKrcEkeoNJ9BZ6LIADAAAAAAAAESotbb0OHMiWJGVn71da2vowzwgAAAAIr9hwTwCoak6nQwkJcTp2zCOfj2/PILToDSbRG0yhNZhEbzCJ3qofy7Lk8XiM/9y8vLzA371e8z9fkuLi4jinYDWRkpKq+vWTdOBAtpKSGiglJTXcU0KU4/cpTKE1mERvMIneQs9hsX+9rRUU+JSdfTTc04g4sbFO5ef7wj0NVBP0BpPoDabQGkyiN5hEb9WHZVl6+ukntG3blnBPJSzOO6+p7rprPIvg1cTGjd/r3Xff1JAh16h167bhng6qAX6fwhRag0n0BpPoreKSkmopJqZ8BzdnD3BEJTYaMIneYBK9wRRag0n0BpPoDUA0at26LQvfMIrfpzCF1mASvcEkegst9gC3OfYArxy+OQOT6A0m0RtMoTWYRG8wid6ql3AdAt3/s2NjnSooCM/HLhwCvfph+waT6A2m0BpMojeYRG8Vxx7gqNacTodq1HBx7gQYQW8wid5gCq3BJHqDSfRW/TgcDsXHx4flZ3NeP5jE9g0m0RtMoTWYRG8wid5Cjz3AbY49wAEAAAAAAAAAAABUZxXZA7x8owAAAAAAAAAAAAAAsDkWwBF1HI7CQ0dwrjOYQG8wid5gCq3BJHqDSfQGk+gNJtEbTKI3mEJrMIneYBK9hR4L4IhKbDNgEr3BJHqDKbQGk+gNJtEbTKI3mERvMIneYAqtwSR6g0n0FlqcA9zmOAc4AAAAAAAAAAAAgOqMc4ADAAAAAACE0caN3+vhh+/Vxo3fh3sqAAAAAFCtsACOqON0OlS7drycTo4fgdCjN5hEbzCF1mASvcEkeoMpXq9X8+a9rj17duvNN+fI6/WGe0qIcmzfYBK9wRRag0n0BpPoLfRYAEfUsSxLeXn54uj+MIHeYBK9wRRag0n0BpPoDaakpa3XgQPZkqTs7P1KS1sf5hkh2rF9g0n0BlNoDSbRG0yit9BjARxRx7Ikr7dAbDdgAr3BJHqDKbQGk+gNJtEbTElJSVX9+kmSpKSkBkpJSQ3zjBDt2L7BJHqDKbQGk+gNJtFb6LEAjqgUE0PaMIfeYBK9wRRag0n0BpPoDSa4XC4NHz5Cycm/0zXX3CCXyxXuKaEaYPsGk+gNptAaTKI3mERvoeWw2L/e1goKfMrOPhruaUQUp9OhhIQ4HTvmkc9H3ggteoNJ9AZTaA0m0RtMojeYRG8wid5gEr3BFFqDSfQGk+itcpKSapX7iwMsgNscC+CV43CIQ0fAGHqDSfQGU2gNJtEbTKI3mERvMIneYBK9wRRag0n0BpPoreIqsgDO/vWISmw0YBK9wSR6gym0BpPoDSbRG0yiN5hEbzCJ3mAKrcEkeoNJ9BZaLIAj6jgcUnx8rByOcM8E1QG9wSR6gym0BpPoDSbRG0yiN5hEbzCJ3mAKrcEkeoNJ9BZ6LIAjCjnkdDolseWACfQGk+gNptAaTKI3mERvMIneYBK9wSR6gym0BpPoDSbRW6hxDnCb4xzgAAAAAAAAAAAAAKozzgEOAAAAAAAAAAAAAKh2WABH1HE6HapVK15OJ4eOQOjRG0yiN5hCazCJ3mASvcEkeoNJ9AaT6A2m0BpMojeYRG+hxwI4oo5lWfJ48sXR/WECvcEkeoMptAaT6A0m0RtM+uCD9/WnP43UBx+8H+6poBpg+waT6A2m0BpMojeYRG+hxwI4oo5lSV5vgdhuwAR6g0n0BlNoDSbRG0yiN5hy7NgxffDB+yooKNDSpe/r2LFj4Z4SohzbN5hEbzCF1mASvcEkegu9arUAnp6erjvvvFNdunRRmzZt1KNHDz344IPas2dPpe/zt99+0xNPPKE+ffqoXbt2at++va699lq9/z7f8A6nmBgOGwFz6A0m0RtMoTWYRG8wid5gwgcfLJRl+SRJPp9PH3ywMLwTQrXA9g0m0RtMoTWYRG8wid5Cq9osgK9du1ZDhw7V0qVL5fP55Ha7deDAAc2bN08DBgzQpk2bKnyf69atU9++ffXqq69q9+7dOvfccxUXF6dvv/1Wf//733XvvfeG4JHgZJxOh2rWjOPcCTCC3mASvcEUWoNJ9AaT6A2m9O9/pRyOwo9cnE6n+ve/MrwTQtRj+waT6A2m0BpMojeYRG+hVy0WwA8ePKi//OUvysvL0+jRo/XFF19owYIF+vzzz9W7d28dOnRIY8eOlcfjKfd9Zmdn69Zbb9Xhw4fVp08fffrpp1q4cKG++uorPfjgg3I6nXrnnXf04YcfhvCRIRifz9LRox75fBw7AqFHbzCJ3mAKrcEkeoNJ9AZTEhIS1L//QMXExKhfv4FKSEgI95QQ5di+wSR6gym0BpPoDSbRW+hViwXwOXPm6NChQ7rgggs0btw4xcbGSpJq166tp556SmeeeaYyMjK0aNGict/n9OnTdfDgQaWmpurpp59W3bp1A9cNHz5cAwcOlCS98847VftgUC4WJ06AQfQGk+gNptAaTKI3mERvMKVv3wGaNm2m+vYdEO6poJpg+waT6A2m0BpMojeYRG+hVS0WwN977z1J0tChQ0tcFxcXF7h8yZIl5bo/j8ejDz74QJI0btw4xcTElBhz44036q677tKgQYMqO21UksMhxcfHysGRI2AAvcEkeoMptAaT6A0m0RtMojeYRG8wid5gCq3BJHqDSfQWerHhnkCo7d27V5mZmZKk9u3bBx3jv3zdunXyer1yuVxl3ucPP/ygQ4cOKSkpSR07dgw6pkWLFmrRosUpzByV5XA4FBPjlMPh4Bs0CDl6g0n0BlNoDSbRG0yiN5hEbzCJ3mASvcEUWoNJ9AaT6C30on4BfOfOnZIKY2rSpEnQMY0bN5ZUuGd3VlaWzjrrrDLvc/PmzZKkpk2bSpK2bNmi9957T+np6ZKkVq1a6aqrrgrcL8zy+SwdO1b+87kDp4LeYBK9wRRag0n0BpPoDSbRG0yiN5hEbzCF1mASvcEkegu9qF8A379/v6TC833HxcUFHVOvXr3A3w8cOHDSBfBff/1VklS/fn29/PLLeuaZZ5Sfnx+4/rPPPtOrr76qxx9/XP379z/FRwAAAAAAAAAAAAAAKI+IWgAfP3584Hze5bFw4UIdP35ckhQfH1/quBo1agT+7h9flqNHj0qSvvnmGy1fvly9e/fW2LFjdfbZZysjI0PTpk3TsmXLdPfddys5ObnUw6SXh9PpUFJSrUrfvrrisBEwid5gEr3BFFqDSfQGk+gNJtEbTKI3mERvMIXWYBK9wSR6qzins/wnTY+oBfDKiImJkVQYUnk4nc6TjsnNzZUkZWdnq1evXpo2bVrguvPPP1/PPvusbrjhBq1Zs0ZPPfWU3nzzzUrMvFDheQDK/x8URfG8wSR6g0n0BlNoDSbRG0yiN5hEbzCJ3mASvcEUWoNJ9AaT6C1UImoB/OGHH9Z9991X7vE1a9YMHK48Ly+v1HH+BW2p+N7gZd2v3+233x50zG233aY1a9Zow4YNys7OVlJSUnmnDQAAAAAAAAAAAACohIhaAI+Liyv1PN6lqV+/viQpJydHXq9XLperxJgDBw4E/l6eherExERJhXuLN2/ePOgYt9stSbIsS7t27WIBHAAAAAAAAAAAAABC7OTH+45w559/viTJ5/MpKysr6JjMzExJhecJb9SoUYXu0+v1Bh3jP/S6pAov2gMAAAAAAAAAAAAAKi7qF8Dr1q2rc845R5K0fv36oGP8l7dr167YwnVpLrjggsDf09LSgo7Ztm2bpMK9xBs3blyBGQMAAAAAAAAAAAAAKiPqF8AlqU+fPpKkt99+u8R1Ho9H7777riRp0KBB5bq/Jk2aBBbBX3nllaBjZs+eLUnq0qVL4JDpAAAAAAAAAAAAAIDQqRYL4CNGjFDdunW1du1aTZ48WR6PR1LhecHHjRunjIwMNWnSRAMGDCh2u+PHj2vr1q3aunWrjh8/Xuy6v//973I4HFq5cqUmT56so0ePSio8LPqsWbP04Ycfyul06rbbbjPzIAEAAAAAAAAAAACgmnNYlmWFexImrFy5UmPHjpXX61W9evV05plnavv27Tp69Kjq1KmjuXPnqlmzZsVu8/XXX2vEiBGSpNdff12dOnUqdv27776r+++/X/n5+UpISNC5556r3bt3a//+/YqJidG9996r6667zthjBAAAAAAAAAAAAIDqrFrsAS5J3bt317vvvqt+/fopNjZWP/30kxISEjRo0CAtWLCgxOJ3eQwZMkSLFi3SoEGDVKdOHaWnpysmJkZ9+vTR3LlzWfwGAAAAAAAAAAAAAIOqzR7gAAAAAAAAAAAAAIDoVm32AAcAAAAAAAAAAAAARDcWwAEAAAAAAAAAAAAAUYEFcAAAAAAAAAAAAABAVIgN9wSAonbt2qWePXsGvS4mJkbx8fFq2LChWrVqpYEDB6pHjx5BxzZv3jzw9+7du+vFF1886c9etmyZ/vrXvwb+vXHjRsXG8n+RSLdgwQJNmDChwre78MILNWfOHPXo0UOZmZlBx8TGxqpmzZpq1KiROnXqpJEjR6pJkyZl3q/H49GHH36oFStW6Mcff9S+ffvk8/mUlJSkZs2a6dJLL9XgwYNVq1atCs8Z4UdvMIXWYBK9wSR6g0n0Brsp6zMRh8OhunXrqlGjRurWrZtGjRqlpKSkMu8vMzNT8+fP16pVq7R9+3YdO3ZMtWrVUtOmTXXZZZfp6quvVt26dUPxUBAB6A0m0RtMojeYUFVrWUXl5eXp/fff10cffaQff/xRBw4cUGxsrM444wx17NhRgwYNUmpqalU/lKjlsCzLCvckAL+iGw23263atWsHrvP5fDpy5IgyMjLk8XgkSZdccomeeeYZJSYmFrufogvgcXFxWr16dbH7Cub//u//tHz58sC/WQCPDp9++mnQL0BkZWUpKytLcXFxatOmTYnrW7Vqpfvuuy/woVajRo3UqFGjYmMKCgp05MgR7dy5U/n5+YqLi9Ozzz5b6i+zTz/9VPfff792794tSUpISFDjxo0VHx+vPXv2aN++fZKkpKQkPfbYY+revfupPnwYRm8whdZgEr3BJHqDSfQGuynrM5GCggIdOnRIu3btUn5+vurXr6/Zs2cX+/zDz+fzaebMmZo+fbry8/PlcDjUsGFDNWzYUHv27NFvv/0mSapfv76efPJJXXrppWYeIGyF3mASvcEkeoMJVbWW5bd+/XrdeeedysrKklTY1RlnnKGcnBz9+uuv8nq9kqS+fftq8uTJJ13vgiQLsJGMjAzL7XZbbrfb+uqrr4KOycvLs95++20rNTXVcrvd1vXXX2/l5eUVG+O/j1atWllut9tauHBhmT/36NGjVkpKSuB2brfb8nq9Vfa4YD/Tpk2z3G631b179zLHde/e3XK73da0adNKHbNz505r4MCBltvttjp27Gjt37+/xJj33nvPatGiheV2u60hQ4ZYn332meXxeIqN2bhxo3XzzTcH2l21alXlHhxsh95gCq3BJHqDSfQGk+gN4VKez0Sys7OtP//5z5bb7bb++Mc/WgUFBcWu9/l81pgxYyy32221adPGmjp1aonuNm7caI0cOdJyu91Wy5Ytrc8//zxkjwn2RW8wid5gEr3BhKpay7Isy1qyZInVunVry+12W9ddd521du1ay+fzBa4/cuSI9a9//cvq0KGD5Xa7rT59+lh79uwJ2WOLFpwDHBEnLi5Ow4YN00svvaSYmBitWbNGs2fPDjq2c+fOkgoPb16Wjz/+WLm5uWrVqlWVzxfRr0mTJpo6daok6fDhw1q4cGGx69PT0zVp0iT5fD717dtX8+bNU9euXeVyuYqNa9WqlWbOnKl+/fopPz9fDzzwgHw+n6mHgQhBbzCF1mASvcEkeoNJ9IaqVr9+fT3xxBOKi4vTjh079MUXXxS7/uWXX9bHH3+suLg4Pffcc7rrrrtKHNq1VatWmjVrljp16qSCggJNmDBBx44dM/kwECHoDSbRG0yiN5hQnrWsnTt3atKkSfJ6vRoyZIhmz56tDh06yOFwBMbUrl1bN954o+bNm6fTTz9d27Zt08SJE2VxgO8ysQCOiPX73/9eV199tSRp1qxZys3NLTGmT58+kqQvvvhCOTk5pd7X0qVLJUn9+vULwUxRHTRt2lTnnHOOJGnDhg3FrpsyZYq8Xq+aNGmiJ554osSHWUU5HA5NmjRJ8fHx+uWXX7R69eoQzhqRit5gCq3BJHqDSfQGk+gNVa1+/fpq1qyZJOnnn38OXL57925NmzZNkjRy5MgyD8UaGxur+++/Xw6HQ3v37tWSJUtCO2lELHqDSfQGk+gNppS1lvXAAw/o2LFjatWqlR566CHFxMSUej/NmjXT5MmTJUmff/65Fi1aFNqJRzhOcIyIdvXVV2vu3Lk6ePCg1q5dq0suuaTY9Y0bN1ZKSorS0tL08ccfa+DAgSXuIycnR59//rmaNGmilJQUU1NHFPKfv+Po0aOBy3bu3Bn4BuGf/vQn1ahR46T306BBA912222qXbu23G53aCaLiEdvMIXWYBK9wSR6g0n0hqqWn58vSapVq1bgsnfffVder1cxMTG66aabTnofTZs21ZQpU3TOOedwRDyUid5gEr3BJHqDKcHWsrZu3apVq1ZJkkaPHl3ml2H9Lr30UrVv317r1q3TnDlzdOWVV4Z45pGLBXBEtBYtWqh27drKycnRmjVrSiyAS1Lfvn2VlpamZcuWBV0A/+ijj+TxeNS/f38TU0aUsixLO3fulCQ1atQocPknn3wiy7LkcDjUo0ePct/fLbfcUuVzRPSgN5hCazCJ3mASvcEkekNV27lzp37++Wc5nU517do1cLn/qAAtW7YscZjW0gT7nAQoit5gEr3BJHqDScHWsj755BNJUkxMTJlHGjjRH/7wB61bt04bN27U/v371aBBgxDNOrJxCHREvMaNG0uSfv3116DX9+3bVw6Ho9TDoH/wwQeSOPw5Ts2CBQt06NAhSdJll10WuPzHH3+UJP3ud79TcnJyOKaGKERvMIXWYBK9wSR6g0n0hqpQUFCgAwcO6OOPP9bo0aPl8/n05z//OfCZiCRt27ZNUuEHrMCpoDeYRG8wid4QTieuZf3000+SpCZNmhQ7CsHJtGzZUlLhF23T09OreJbRgz3AEfH8G4aDBw8Gvb5Ro0Zq166dNmzYoJUrV2rAgAGB6w4ePKjVq1eradOmat68ub7++msTU0aU8Hq92r17t/7zn//oueeekySlpqYW23tj3759ksS3sHDK6A2m0BpMojeYRG8wid5wqkaMGFHm9aNHj9Ydd9xR7DL/Fy3Ku7ca4EdvMIneYBK9wU5OXMvKzs6WJNWtW7dC93PaaacF/u6/D5TEAjgintfrlSQ5HI5Sx/Tt21cbNmzQsmXLii2A//e//5XX62Xvb5zUc889F/jgqjSpqamaNm2anM7/HVzDsqyT3veoUaMCh9Y5Ufv27TVv3ryKTRYRj95gCq3BJHqDSfQGk+gNoeB2u1W7du3Av30+n44ePapffvlFHo9Hr732mo4fP66JEycqJiZGklSzZk0dOXIkcD5ToLzoDSbRG0yiN9jJiWtZ/vcDZa1tBVN0fNH3FyiOBXBEvCNHjkiS6tSpU+qYvn376oknntDnn3+unJycwC+9pUuXShLn/8ZJNWrUqNj5+iTJ5XIpMTFR5513nrp06aKLLrqoxO3q168vSdq/f3+p9+12u5WXl1fssqysLGVlZVXBzBGJ6A2m0BpMojeYRG8wid4QCpMmTVKnTp1KXO7xePTee+/pkUce0RtvvKGCggI9+OCDkqSGDRvqyJEjOnDggOHZItLRG0yiN5hEb7CTE9ey/EcZqGhrRY+GzJEKSscCOCKax+NRZmamJOn8888vdVxycrJSU1O1bt06ffLJJ7r88suVnZ2tr7/+Wq1bt9Y555xjaMaIVEOGDNHYsWMrfLvmzZtryZIl2rdvnw4dOhT0cCYTJ04scdn06dNPuhcJohe9wRRag0n0BpPoDSbRG0yKi4vT1VdfrX379mn69Ol6++23dcstt6hRo0Y699xztW3btgqdCzIjI0OJiYmqV69e6CaNiEVvMIneYBK9wbRga1ktWrTQ4sWLlZGRUWzHzZPZuHGjpMI9wctaF6vu2DceES0tLS1w2Ij27duXObZv376SpGXLlgX+t6CggL2/EVLdunWTJOXn52vFihVhng2iHb3BFFqDSfQGk+gNJtEbTkXPnj0lSQUFBfrxxx+LXbZp06Zy70n04IMPqnPnzrr77rtDM1FEBXqDSfQGk+gNpgRby7r00kslFR6af+XKleW+L//YFi1aFDsfOIpjARwRbf78+ZKk008/Xb///e/LHNunTx85nU59/vnnOnr0qD788EM5HA7O/42QatGiRaDNmTNn6vjx42GeEaIZvcEUWoNJ9AaT6A0m0RtORdFzP/rPH9mjRw8lJCTI5/PplVdeOel9bN++XatWrZJlWWrVqlXI5orIR28wid5gEr3BlGBrWc2aNVPnzp0lFb4f8Hg8JW43YcIEPf7449qxY4ckae3atVq9erUk6brrrjMw88jFAjgi1po1a/T+++9Lkv785z8rJiamzPGnn3662rdvr9zcXL377rtau3atUlNTS5yrDahqEydOlMvl0vbt2zV+/Hjl5uaWOT47O1urVq0yNDtEG3qDKbQGk+gNJtEbTKI3VNann34qqfCD+9atW0sqPK/8rbfeKkmaPXt24MPRYHJzczVhwgT5fD41bNhQV111VegnjYhFbzCJ3mASvcGEstayHn74YSUkJCg9PV0PPPCACgoKAtd5vV598cUXeu211zRgwAA988wzuvPOOyUVfpl20KBBZh9IhGEBHBHn6NGj+ve//61bbrlFPp9PF110kYYPH16u2/oPg/7MM8/I5/Nx+HMY0apVK02ZMkUul0vLli3T4MGDtWTJkhJ7ePzyyy+aNm2aevfurXXr1kkq/BYYUBH0BlNoDSbRG0yiN5hEb6goy7L0n//8Ry+++KIkqXfv3sW+2H/jjTfqwgsvlMfj0ejRozVt2jTt37+/2H2sX79e1113ndavXy+Xy6V//OMfSkhIMPo4EBnoDSbRG0yiN5hQnrWss88+W48++qhcLpcWLFigkSNHat26dbIsSy6XSytXrtT9998vn8+nGTNmaO/evWrQoIFefPFFxcbGhumRRQaeHdjW5MmTVbt27cC/8/PzdfjwYWVkZAS+BdOjRw/94x//KPf/0Xv37q1HH31UR48eVUxMjPr06ROSuQMn6tevn5KTk3X//fdry5Yt+tvf/qa4uDidccYZql27tvbt26c9e/YExrvdbv31r39Vr169wjhrRCp6gym0BpPoDSbRG0yiNwRz4mciUuHnIpmZmYEP4Fu3bq0HH3yw2BiXy6VXXnlF48eP1wcffKDnn39eL774oho1aqSkpCRlZWVp3759kqTTTjtNTz75pC666CIjjwn2RW8wid5gEr3BhFNdy+rXr5/OOOMM3XHHHfrmm280fPhwJSUlqVGjRvJ4PNqxY4fy8/MD4w8cOKAZM2bojjvuUFJSUugfYIRiARy2lZ6eXuzfTqdTNWvW1Hnnnae2bdtq4MCBFf6l0rBhQ3Xs2FFr1qzRhRdeqNNOO60qpwyUqUOHDlq8eLE+/fRT/ec//9F3332nrKws7dq1S3Xr1lXbtm3VsWNH9ezZ86TntAdOht5gCq3BJHqDSfQGk+gNJzrxMxFJio+PV1JSkrp3764//vGPGjhwYNAPUePi4vT000/r6quv1qJFi7RhwwZlZWUpKytLiYmJ+v3vf68ePXpo2LBhSkxMNPFwYHP0BpPoDSbRG0yoirWsCy64QMuXL9eiRYv03//+V5s2bdLmzZtVu3ZtnXfeeWrXrp369+8vn8+nhx56SG+99Zbef/993X333br22mtD+fAilsOyLCvckwAAAAAAAAAAAAAAlM7j8Wj+/Pl64403NGnSJF188cXhnpItsQAOAAAAAAAAAAAAAIgKznBPAAAAAAAAAAAAAACAqsACOAAAAAAAAAAAAAAgKrAADgAAAAAAAAAAAACICiyAAwAAAAAAAAAAAACiAgvgAAAAAAAAAAAAAICowAI4AAAAAAAAAAAAACAqsAAOAAAAAAAAAAAAAIgKLIAjbKZOnao2bdrol19+kSQ1b95czZs316pVq4zN4dtvv9WYMWPUqVMntW3bVn/84x/1j3/8Q4cPHy4x1uv1qk+fPrr22mtVUFBgbI44dXZorajjx4+rV69e6tatW9DraS2y2aG3pUuX6k9/+pM6d+6s1q1bq3Pnzho9erQ+/vjjEmPpLbKFuzefz6e3335b11xzjVJTU3XBBRdowIABmjZtmo4cOVJiPL1FtnD3FsxHH32k5s2bq0ePHiWuo7fIFu7eFixYEPiZpf159NFHA+Ppzf7C3dSJTvaeoKiPP/5YI0eOVIcOHdSuXTtdfvnlmjFjhvLy8kqMPXTokDp16qS//e1voZg2TpFdOjxw4IAee+wx9ezZU23atFGXLl10++23a8OGDUHHP/fcc2rbtq02b95sdJ44Obs0FWxe5ZnHr7/+qnvvvVfdunVTmzZt1LVrV919993aunVr0PETJkxQp06dtHfv3lBMG2WwS2tbt27VpEmT1KtXL7Vt21apqakaNGiQXnjhBeXk5JR6O1qLLHbp7YcfftCdd96pSy65RG3atFG3bt00btw4paWllXk7eotcJ7bnl5OTo1deeUU33HCDLr74YrVp00adO3fW4MGDNWXKFG3btq3M+83Pz9f27durdK7Hjx/Xrl27yj1+4cKFatGihT7//PMqnYedsQCOsFi7dq1mzZqlESNG6Oyzzw7LHJYuXarrr79eK1euVHx8vJo1a6asrCzNmjVLV1xxhbKysoqNd7lcmjBhgr799lvNmjUrLHNGxdmhtaJ8Pp8mTZqkjIyMUsfQWuQKd28FBQW64447dOedd+qLL76Qz+dTs2bNVFBQoM8++0y33nqrHnrooWK3obfIFe7ePB6PbrnlFt13331av3696tWrpyZNmmjHjh16/vnn1b9//xIv7uktcoW7t2Cys7P1wAMPlHo9vUUuO/T2008/SZLOPPNMtW/fPuifJk2aBMbTm73ZoamiyvOewO+VV17Rrbfeqq+++kr16tXTueeeq23btumZZ57R1VdfXeLD/rp16+qvf/2rlixZoiVLloTqIaAS7NLhb7/9pquuukqzZ8/W/v375Xa75XA49N///lfXXnut3nnnnRK3GT16tBo2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f/zjH5KkTp06ac6cORU+hwu92ZtdervooovkdDp15MgRLVmyJOiY1157TZLUokWLYnuDF0Vv9maH3ho2bKh58+aV+ueWW24pMa60D+zpzd7s0JsktWzZMnD4/UWLFgUd8/LLL0tS4JB3wdBb+NmlqcpKTk4OLGy/+eabJa7ftm2bvv76a8XExGjgwIGl3o+/xfPOOy80E0WZytvhu+++G/Ry/5EHunXrJpfLdcrz6du3r6TC9w3BDq8/b948SVK/fv1K3Rtoz549kqQmTZqUehQMhI7dmqosf4sLFiwIek56/3avrM/l/C2yfQsNu7V26NAhjR49WgcOHFBiYqJeffVV9erV66S3o7XIYKfeYmNjA0cUmzt3btAxGzZsCHyZrHv37oHL6S3ylNVehw4dAud/f+yxx0rdAUQqPILYihUrJEmXXXZZsetOPD2Dn/+IPKUdWfGdd94J/D0/Pz/ofVb23OD+9wg1a9Ys9TO7aMACOIxp2bKlEhIS5PP5Sv228YlatGgROP/atGnTtHXr1iqZy5gxY+RyufT+++9r5syZgUMY7t+/X7fddptycnLUoUOHoIfPlCSPx6ONGzdKKtwQwl7s1NqpojX7s0tvR44c0f333y+p8EXyjBkzSj03Umnozf7s0ltycrKGDRsmSXr00Uf10UcfBa7Ly8vTM888o3nz5snpdOruu+8Oeh/0Zn926a0q0Jv92aW35ORkXXnllZKkf/7zn1q6dGngOo/Ho2effVb//ve/5XA4AoerOxG92YNdmjoVt99+u6TCL10UPezizp07NXbsWBUUFKh///46++yzg95+165dgcNZ02J4lLfDFStW6Omnnw58WO7xePTkk0/q448/lsvl0m233VYl87nooovUoUMHHTlyRLfddpt+++03SYWndXj55Ze1ePFiuVwujR49utT78J9PlabCw25NVdbAgQN11llnKSMjQ+PGjVNOTk5gnpMnT9a3336rxMREXX/99aXeBy2Glt1ae/LJJ/Xrr7/K6XTqn//8p9q3b1+u29FaZLBbb7feeqscDofWrFmjRx55pNih11evXq3bbrtNlmXpiiuuKPYFbHqLPGW153K5NHHiRDmdTq1atUrXXXedvvrqqxJHikpLS9ONN96onTt3KjU1NfBFCD//YfT9Rw3w83/J4a233gp88UGScnJyNH36dM2cOTNwWW5ubrnuUyo8IuPWrVuLHZnxRP7OUlNTS12gjwYsgMMYl8ulzp07S5K+/fbbct/utttu07nnnqu8vDxNmDChSg5F17RpU917771yOByaOnWqunXrpsGDB6t79+5au3atGjdurGeeeabU26elpcnj8ahevXqBQ5vAPuzU2qmiNfuzS29vv/12YC8Or9erm2++WcOHDy/1j/8cRUXRm/3ZpTdJuvfee3XJJZcEPkDt2rWrhgwZoosuukgzZsyQy+XS5MmTdfHFFwe9Pb3Zn516O1X0Zn926m3SpEm68MILlZeXpzvvvFMXX3yxhgwZoi5duuiFF15QbGws27cIYKemKuviiy/WLbfcovz8fN1zzz3q0aOHrrzySvXp00dbtmxR69at9eCDD5Z6e//jbt68eamH2URolbfD3r1766WXXgq8nrrkkkv0r3/9Sy6XS48//rhatmxZJfNxOBx68sknlZycrLVr16p79+4aPHiwunXrpqeeekoOh0OPPfZY4Bz0wfgfx6WXXlolc0LF2K2pyoqPj9fUqVOVmJio5cuXB+bZtWtXzZkzRy6XS88991yph5H1er2B0xrSYmjYqbW9e/cGjsxTo0YNvfDCC2V+3lF0r0laiwx26k0qXHx+6KGHFBsbqzfeeEMXX3yxBg0apB49emjUqFH67bff1L17dz3yyCPFbkdvkedk7fXq1UtPPfWU6tWrp++++04jR45Up06dNHDgQA0ePFhdunTRsGHDtG7dOnXq1EkzZsxQTExMsfvwf0li8eLFGjBggB566CFJ0p133imn06ktW7aoZ8+eGjBggAYMGKAuXbroueeeU+PGjQOH9D/xcOj++5w1a5YGDRqkF154IXDdPffco379+umee+4p9XFXl9dzLIDDqCuuuEKS9Pnnn5f7NnFxcZo8ebIcDoe+++47/etf/6qSuQwfPlxvvPGGunfvLq/Xq82bN+u0007T9ddfr/nz55d6vlLpf/Pv379/WA8ZhdLZqbVTQWuRwQ69ffPNN4G/Z2RkaN26dWX+ycvLK3Ef9BYZ7NCbVPjG7uWXX9ajjz6qjh076tixY9q8ebPq1aunoUOHatGiRRoyZEipt6e3yGCX3k4VvUUGu/SWkJCg1157TY888og6duyo3Nxcbd68WYmJiRo8eLAWLlyooUOHlnp7erMPuzR1Ku666y49//zz6ty5sw4fPqwtW7aoSZMmGjNmjObMmVPmEX8+++wzSf97HhAe5elw0qRJuv/++9WwYUOlp6crJiZG/fr10zvvvKMBAwZU6XyaNGmihQsXauTIkUpOTlZ6erry8vLUtWtXvfbaa2UeUn/Hjh3auXOn6tWrF/UfmNqZ3ZqqrJSUFC1atEhDhw5VnTp1tHnzZjkcDvXu3Vvz588PLEgEs2bNGuXm5qpZs2alnv4Gp84ura1fvz5w+N9jx46d9POOrKysYrentchgl978rr76as2fP1+XX365ateurfT0dB09elQXX3yxnn76ac2YMUPx8fElbkdvkedk7fXv31/Lly/XhAkT1LVrV9WpU0cZGRnasmWLatSoob59++q5557T66+/HvTLDaNHj9awYcNUr1497dixQ5s3b5ZUePj8d955R7169VLDhg21bds2ZWVlye12629/+5sWLVoU6HrlypXF7vOee+5R7969VbNmTW3btq1CR67KycnR+vXrFRsbq/79+5f7dpHIYVX2IPFAJRQUFKhv37765ZdftGTJEjVr1izcU6qw/Px8de/eXdnZ2Vq2bJmaNGkS7ikhCFqDSfQGk+gNJtEbTKI3VLVoaKqyDh06pK5duyo+Pl4ff/yxEhMTwz2laiuaOpwyZYpeeeUVjR07NnCIfpgXTU1V1l//+lctW7ZMTz75ZODUJah6tEZrJtEbvYVLdWvv3//+tx5++GENHjxYjz/+eLinE1LsAQ6jYmJiNGbMGEmFh+uNRJ988on27t2rgQMH8oGWjdEaTKI3mERvMIneYBK9oapFQ1OV9d577ykvL08jR45k8TvMoqVDr9erhQsXKjExUSNHjgz3dKq1aGmqsrKzs7VixQqdffbZttmbPVrRGq2ZRG/0Fi7Vrb358+crJiZGt956a7inEnIsgMO4gQMH6rzzztOCBQuUnZ0d7ulU2CuvvKK4uLhqsYGIdLQGk+gNJtEbTKI3mERvqGqR3lRleDwezZkzR/Xr19eIESPCPR0oOjpcuHCh9u/frz/96U98qcIGoqGpypo9e7a8Xq9uv/32EudZRdWjNVozid7oLVyqS3urVq3Spk2bNHjw4MD5xaMZC+AwLjY2Vk888YSOHz+u559/PtzTqZDly5dr3bp1uvPOO6vFBiLS0RpMojeYRG8wid5gEr2hqkVyU5X1xhtvaNeuXXrooYdUp06dcE8HivwOjx07pmeffVatWrXSzTffHO7pQJHfVGXt3r1br732mrp3717m+epRdWiN1kyiN3oLl+rQns/n05NPPqnf/e53uvvuu8M9HSNYAEdYtGvXTqNHj9Zbb72lHTt2hHs65eL1ejV16lT9/ve/16hRo8I9HZQTrcEkeoNJ9AaT6A0m0RuqWiQ2VVkHDx7Uiy++qIEDB6p3797hng6KiOQOZ82apUOHDmnKlClyuVzhng7+v0huqrL++c9/qmbNmpo8eXK4p1Kt0BpMojeES7S3995772nz5s16/PHHq82XZB2WZVnhngQAAAAAAAAAAAAAAKeKPcABAAAAAAAAAAAAAFGBBXAAAAAAAAAAAAAAQFRgARwAAAAAAAAAAAAAEBVYAAcAAAAAAAAAAAAARAUWwAEAAAAAAAAAAAAAUYEFcAAAAAAAAAAAAABAVGABHAAAAAAAAAAAAAAQFVgABwAAAAAAAAAAAABEBRbAAQAAAAAAAAAAAABR4f8BiaHjw7eAMLUAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 2000x450 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "import colorsys\n",
    "from collections import defaultdict\n",
    "\n",
    "sns.set()\n",
    "\n",
    "# --- Define subtle tinting function ---\n",
    "def tint_color(color, intensity=1.0):\n",
    "    \"\"\"\n",
    "    Slightly darkens the base color.\n",
    "    intensity = 1.0 -> original color, <1.0 -> slightly darker.\n",
    "    \"\"\"\n",
    "    r, g, b = color\n",
    "    h, l, s = colorsys.rgb_to_hls(r, g, b)\n",
    "    l = l * (0.4 + 0.6 * intensity)\n",
    "    s = s * (0.4 + 0.6 * intensity)\n",
    "    return colorsys.hls_to_rgb(h, l, s)\n",
    "\n",
    "# --- Base colors per estimator type ---\n",
    "base_colors = {\n",
    "    'DM': sns.color_palette(\"Set2\")[0],\n",
    "    'TPG': sns.color_palette(\"Set2\")[1],\n",
    "    'BC': sns.color_palette(\"Set2\")[2],\n",
    "    'DQ': sns.color_palette(\"Set2\")[3],\n",
    "    'OPE': sns.color_palette(\"Set2\")[4],\n",
    "}\n",
    "\n",
    "# --- Configuration for plotting ---\n",
    "print(\"\\nPlotting ATE estimate distributions (Box Plot)...\")\n",
    "plt.figure(figsize=(20, 4.5))\n",
    "\n",
    "plot_config = {\n",
    "    \"trunc_ht\": [0, 1, 2, 3, 4, 5, 10],\n",
    "    \"switchback_dm\": False,\n",
    "    \"bc_switchback\": [0, 10, 20, 30],\n",
    "    \"include_dq\": True,\n",
    "    \"include_ope\": False\n",
    "}\n",
    "\n",
    "# --- Custom display names ---\n",
    "name_map = {\n",
    "    \"trunc_ht\": {0: \"DM\\n(k=0)\", 1: \"TPG\\n(k=1)\", 2: \"TPG\\n(k=2)\", 3: \"TPG\\n(k=3)\", 4: \"TPG\\n(k=4)\",\n",
    "                 5: \"TPG\\n(k=5)\", 10: \"TPG\\n(k=10)\"},\n",
    "    \"switchback_dm\": \"Switchback DM\",\n",
    "    \"bc_switchback\": {0: \"BC\\n(b=0)\", 10: \"BC\\n(b=10)\", 20: \"BC\\n(b=20)\", 30: \"BC\\n(b=30)\"},\n",
    "    \"dq\": \"DQ\\n(Stat.)\",\n",
    "    \"ope\": \"LSTD-OPE\"\n",
    "}\n",
    "\n",
    "# --- Collect data and labels ---\n",
    "plot_data = []\n",
    "plot_labels = []\n",
    "\n",
    "for k in plot_config[\"trunc_ht\"]:\n",
    "    if k in ate_estimates_by_k:\n",
    "        plot_data.extend(ate_estimates_by_k[k])\n",
    "        plot_labels.extend([name_map[\"trunc_ht\"][k]] * len(ate_estimates_by_k[k]))\n",
    "\n",
    "if plot_config[\"switchback_dm\"]:\n",
    "    plot_data.extend(dm_estimates)\n",
    "    plot_labels.extend([name_map[\"switchback_dm\"]] * len(dm_estimates))\n",
    "\n",
    "for b in plot_config[\"bc_switchback\"]:\n",
    "    if b in bc_estimates_by_burnin:\n",
    "        plot_data.extend(bc_estimates_by_burnin[b])\n",
    "        plot_labels.extend([name_map[\"bc_switchback\"][b]] * len(bc_estimates_by_burnin[b]))\n",
    "\n",
    "if plot_config.get(\"include_dq\", False):\n",
    "    plot_data.extend(dq_estimates)\n",
    "    plot_labels.extend([name_map[\"dq\"]] * len(dq_estimates))\n",
    "\n",
    "if plot_config.get(\"include_ope\", False):\n",
    "    plot_data.extend(ope_estimates)\n",
    "    plot_labels.extend([name_map[\"ope\"]] * len(ope_estimates))\n",
    "\n",
    "# --- Prepare DataFrame ---\n",
    "df_plot = pd.DataFrame({\n",
    "    \"Estimator\": plot_labels,\n",
    "    \"Est. GATE\": plot_data\n",
    "})\n",
    "\n",
    "# --- Generate shaded color palette ---\n",
    "def get_type(label):\n",
    "    if \"TPG\" in label:\n",
    "        return \"TPG\"\n",
    "    elif \"DM\" in label:\n",
    "        return \"DM\"\n",
    "    elif \"BC\" in label:\n",
    "        return \"BC\"\n",
    "    elif \"DQ\" in label:\n",
    "        return \"DQ\"\n",
    "    elif \"OPE\" in label or \"LSTD\" in label:\n",
    "        return \"OPE\"\n",
    "    else:\n",
    "        return \"Unknown\"\n",
    "\n",
    "label_color_map = {}\n",
    "type_counts = defaultdict(int)\n",
    "type_total = defaultdict(int)\n",
    "\n",
    "for label in df_plot[\"Estimator\"].unique():\n",
    "    type_total[get_type(label)] += 1\n",
    "\n",
    "for label in sorted(df_plot[\"Estimator\"].unique()):\n",
    "    est_type = get_type(label)\n",
    "    idx = type_counts[est_type]\n",
    "    total = max(type_total[est_type] - 1, 1)\n",
    "    intensity = 1.0 - 0.3 * idx / total  # From 1.0 (base) to 0.7\n",
    "    label_color_map[label] = tint_color(base_colors[est_type], intensity=intensity)\n",
    "    type_counts[est_type] += 1\n",
    "\n",
    "# --- Create box plot ---\n",
    "sns.boxplot(data=df_plot, x=\"Estimator\", y=\"Est. GATE\", palette=label_color_map, fliersize=2)\n",
    "\n",
    "# Add true ATE line\n",
    "plt.axhline(true_ATE, color='red', linestyle='--', linewidth=1, label=f\"True GATE = {true_ATE:.2f}\")\n",
    "\n",
    "# Formatting\n",
    "plt.xticks(rotation=0, fontsize=18)\n",
    "plt.yticks(fontsize=18)\n",
    "plt.ylabel(\"Est. GATE\", fontsize=20)\n",
    "plt.xlabel(\"\")\n",
    "plt.legend(fontsize=20)\n",
    "plt.ylim(-0.6, 0.1)\n",
    "plt.grid(True, linestyle=\":\", alpha=0.6)\n",
    "plt.tight_layout()\n",
    "\n",
    "# Save and show\n",
    "filename = \"plots/queue_boxplot.pdf\"\n",
    "plt.savefig(filename)\n",
    "print(f\"Saved box plot to {filename}\")\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
