{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [],
   "source": [
    "from itertools import combinations\n",
    "import datetime\n",
    "from math import ceil\n",
    "\n",
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import zuko\n",
    "from tqdm import tqdm\n",
    "import seaborn as sns\n",
    "\n",
    "import bayes_air.utils.dataloader as ba_dataloader\n",
    "from bayes_air.model import air_traffic_network_model\n",
    "from bayes_air.network import NetworkState\n",
    "from bayes_air.schedule import parse_schedule\n",
    "\n",
    "matplotlib.rcParams[\"figure.dpi\"] = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load the data\n",
    "top_n = 10\n",
    "n_failure = 4\n",
    "n_nominal = 5\n",
    "n_calibration_permutations = 1\n",
    "include_cancellations = False\n",
    "per_point = True\n",
    "\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "torch.manual_seed(0)\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_pickle(\"../../../data/wn_data_clean_mst.pkl\")\n",
    "df = ba_dataloader.top_N_df(df, top_n)\n",
    "nominal_df, disrupted_df = ba_dataloader.split_nominal_disrupted_data(df)\n",
    "nominal_dfs = ba_dataloader.split_by_date(nominal_df)\n",
    "disrupted_dfs = ba_dataloader.split_by_date(disrupted_df)\n",
    "\n",
    "# Get just the set of data we want to study\n",
    "nominal = nominal_dfs[-n_nominal:]\n",
    "\n",
    "if not per_point:\n",
    "    failure = disrupted_dfs[: 2 * n_failure : 2]\n",
    "    n_failure_eval = n_failure\n",
    "    failure_eval = disrupted_dfs[1 : 1 + n_failure : 2]\n",
    "else:\n",
    "    failure = disrupted_dfs[:n_failure]\n",
    "    n_failure_eval = 1\n",
    "    failure_eval = disrupted_dfs[:n_failure_eval]\n",
    "    n_calibration_permutations = n_failure\n",
    "\n",
    "# Get the total number of departures for each airport\n",
    "airport_codes = list(df.origin_airport.unique())\n",
    "num_departures = {\n",
    "    code: sum([(day_df.origin_airport == code).sum() for day_df in failure])\n",
    "    for code in airport_codes\n",
    "}\n",
    "airports_sorted_by_departures = sorted(\n",
    "    airport_codes, key=lambda code: num_departures[code], reverse=True\n",
    ")\n",
    "original_palette = sns.color_palette()\n",
    "airports_sorted_by_departures\n",
    "\n",
    "# Filter out cancellations if we're not using them\n",
    "if not include_cancellations:\n",
    "    nominal = [df[~df[\"cancelled\"]] for df in nominal]\n",
    "    failure = [df[~df[\"cancelled\"]] for df in failure]\n",
    "    failure_eval = [df[~df[\"cancelled\"]] for df in failure_eval]\n",
    "\n",
    "# Convert each day into a schedule\n",
    "nominal_states = []\n",
    "failure_states = []\n",
    "failure_eval_states = []\n",
    "\n",
    "for day_df in nominal:\n",
    "    flights, airports = parse_schedule(day_df, device=device)\n",
    "\n",
    "    state = NetworkState(\n",
    "        airports={airport.code: airport for airport in airports},\n",
    "        pending_flights=flights,\n",
    "    )\n",
    "    nominal_states.append(state)\n",
    "\n",
    "for day_df in failure:\n",
    "    flights, airports = parse_schedule(day_df, device=device)\n",
    "\n",
    "    state = NetworkState(\n",
    "        airports={airport.code: airport for airport in airports},\n",
    "        pending_flights=flights,\n",
    "    )\n",
    "    failure_states.append(state)\n",
    "\n",
    "for day_df in failure_eval:\n",
    "    flights, airports = parse_schedule(day_df, device=device)\n",
    "\n",
    "    state = NetworkState(\n",
    "        airports={airport.code: airport for airport in airports},\n",
    "        pending_flights=flights,\n",
    "    )\n",
    "    failure_eval_states.append(state)\n",
    "\n",
    "# Get some information about the network that will be needed to map\n",
    "# the vector posterior to the sample sites in the probabilistic model\n",
    "n_airports = len(airport_codes)\n",
    "pairs = list(combinations(airport_codes, 2))\n",
    "n_latent_variables = (\n",
    "    n_airports  # mean turnaround time for each airport\n",
    "    + n_airports  # mean service time for each airport\n",
    "    + n_airports * n_airports  # travel time between each pair of airports\n",
    ")\n",
    "if include_cancellations:\n",
    "    n_latent_variables += n_airports  # log # of initial aircraft for each airport\n",
    "    n_latent_variables += n_airports  # baseline cancel prob for each airport"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define plotting functions\n",
    "def map_to_sample_sites(sample):\n",
    "    \"\"\"Map vectorized samples to sample sites in the probabilistic model.\"\"\"\n",
    "    # Handle batched samples\n",
    "    single_sample = len(sample.shape) == 1\n",
    "    if single_sample:\n",
    "        sample = sample.unsqueeze(0)\n",
    "\n",
    "    assert sample.shape[-1] == n_latent_variables\n",
    "\n",
    "    # Reshape & reparameterize the sample to satisfy positivity constraints\n",
    "    airport_turnaround_times = torch.exp(sample[:, :n_airports])\n",
    "    airport_service_times = torch.exp(sample[:, n_airports : 2 * n_airports])\n",
    "    if include_cancellations:\n",
    "        log_airport_initial_available_aircraft = sample[\n",
    "            :, 2 * n_airports : 3 * n_airports\n",
    "        ]\n",
    "        log_airport_base_cancel_prob = sample[:, 3 * n_airports : 4 * n_airports]\n",
    "        travel_times = torch.exp(\n",
    "            sample[:, 4 * n_airports :].reshape(-1, n_airports, n_airports)\n",
    "        )\n",
    "    else:\n",
    "        travel_times = torch.exp(\n",
    "            sample[:, 2 * n_airports :].reshape(-1, n_airports, n_airports)\n",
    "        )\n",
    "\n",
    "    # Map to sample sites in the model\n",
    "    conditioning_dict = {}\n",
    "    for i, code in enumerate(airport_codes):\n",
    "        conditioning_dict[f\"{code}_mean_turnaround_time\"] = airport_turnaround_times[\n",
    "            :, i\n",
    "        ]\n",
    "        conditioning_dict[f\"{code}_mean_service_time\"] = airport_service_times[:, i]\n",
    "        if include_cancellations:\n",
    "            conditioning_dict[\n",
    "                f\"{code}_log_initial_available_aircraft\"\n",
    "            ] = log_airport_initial_available_aircraft[:, i]\n",
    "            conditioning_dict[\n",
    "                f\"{code}_base_cancel_logprob\"\n",
    "            ] = log_airport_base_cancel_prob[:, i]\n",
    "\n",
    "    for i, origin in enumerate(airport_codes):\n",
    "        for j, destination in enumerate(airport_codes):\n",
    "            if origin != destination:\n",
    "                conditioning_dict[f\"travel_time_{origin}_{destination}\"] = travel_times[\n",
    "                    :, i, j\n",
    "                ]\n",
    "\n",
    "    # Remove the batch dimension if it wasn't there before\n",
    "    if single_sample:\n",
    "        conditioning_dict = {\n",
    "            key: value.squeeze(0) for key, value in conditioning_dict.items()\n",
    "        }\n",
    "\n",
    "    return conditioning_dict\n",
    "\n",
    "@torch.no_grad()\n",
    "def plot_travel_times(*sample_maps, labels=None):\n",
    "    # Make subplots for each travel time pair\n",
    "    rows = n_airports\n",
    "    subplot_spec = []\n",
    "    for i in range(rows):\n",
    "        subplot_spec.append([f\"{i},{j}\" for j in range(rows)])\n",
    "\n",
    "    fig = plt.figure(figsize=(4 * rows, 4 * rows))\n",
    "    axs = fig.subplot_mosaic(subplot_spec, sharex=True, sharey=True)\n",
    "\n",
    "    already_plotted = set()\n",
    "\n",
    "    for i, origin in enumerate(airport_codes):\n",
    "        for j, dest in enumerate(airport_codes):\n",
    "            if origin == dest or (origin, dest) in already_plotted:\n",
    "                axs[f\"{i},{j}\"].axis(\"off\")\n",
    "                continue\n",
    "\n",
    "            already_plotted.add((origin, dest))\n",
    "            already_plotted.add((dest, origin))\n",
    "\n",
    "            for k, sample_map in enumerate(sample_maps):\n",
    "                axs[f\"{i},{j}\"].scatter(                    \n",
    "                    sample_map[f\"travel_time_{origin}_{dest}\"].cpu(),\n",
    "                    sample_map[f\"travel_time_{dest}_{origin}\"].cpu(),\n",
    "                    marker=\".\",\n",
    "                    s=1,\n",
    "                    label=labels[k] if labels else None,\n",
    "                )\n",
    "\n",
    "            axs[f\"{i},{j}\"].set_xlim(0, 8)\n",
    "            axs[f\"{i},{j}\"].set_ylim(0, 8)\n",
    "            axs[f\"{i},{j}\"].set_xlabel(f\"{origin} -> {dest} travel time (hr)\")\n",
    "            axs[f\"{i},{j}\"].set_ylabel(f\"{dest} -> {origin} travel time (hr)\")\n",
    "            axs[f\"{i},{j}\"].legend()\n",
    "\n",
    "    fig.tight_layout()\n",
    "\n",
    "    return fig\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def plot_initial_aircraft(*sample_maps, labels=None):\n",
    "    # Make subplots for each airport\n",
    "    max_rows = 2\n",
    "    max_plots_per_row = ceil(n_airports / max_rows)\n",
    "    subplot_spec = []\n",
    "    for i in range(max_rows):\n",
    "        subplot_spec.append(\n",
    "            [f\"{i * max_plots_per_row +j}\" for j in range(max_plots_per_row)]\n",
    "        )\n",
    "\n",
    "    fig = plt.figure(figsize=(4 * max_plots_per_row, 4 * max_rows))\n",
    "    axs = fig.subplot_mosaic(subplot_spec)\n",
    "\n",
    "    for i, code in enumerate(airport_codes):\n",
    "        for j, sample_map in enumerate(sample_maps):\n",
    "            axs[f\"{i}\"].hist(\n",
    "                torch.exp(sample_map[f\"{code}_log_initial_available_aircraft\"]).cpu(),\n",
    "                bins=64,\n",
    "                density=True,\n",
    "                label=labels[j] if labels else None,\n",
    "                alpha=1 / len(sample_maps),\n",
    "            )\n",
    "\n",
    "        axs[f\"{i}\"].set_xlabel(f\"{code} aircraft reserve\")\n",
    "        x_min, x_max = axs[f\"{i}\"].get_xlim()\n",
    "        x_min = min(x_min, -0.05)\n",
    "        x_max = max(x_max, 30)\n",
    "        axs[f\"{i}\"].set_xlim(x_min, x_max)\n",
    "        axs[f\"{i}\"].legend()\n",
    "\n",
    "    return fig\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def plot_base_cancel_prob(*sample_maps, labels=None):\n",
    "    # Make subplots for each airport\n",
    "    max_rows = 2\n",
    "    max_plots_per_row = ceil(n_airports / max_rows)\n",
    "    subplot_spec = []\n",
    "    for i in range(max_rows):\n",
    "        subplot_spec.append(\n",
    "            [f\"{i * max_plots_per_row +j}\" for j in range(max_plots_per_row)]\n",
    "        )\n",
    "\n",
    "    fig = plt.figure(figsize=(4 * max_plots_per_row, 4 * max_rows))\n",
    "    axs = fig.subplot_mosaic(subplot_spec)\n",
    "\n",
    "    for i, code in enumerate(airport_codes):\n",
    "        for j, sample_map in enumerate(sample_maps):\n",
    "            axs[f\"{i}\"].hist(\n",
    "                torch.exp(sample_map[f\"{code}_base_cancel_logprob\"]).cpu(),\n",
    "                bins=64,\n",
    "                density=True,\n",
    "                label=labels[j] if labels else None,\n",
    "                alpha=1 / len(sample_maps),\n",
    "            )\n",
    "\n",
    "        axs[f\"{i}\"].set_xlabel(f\"{code} cancel prob\")\n",
    "        axs[f\"{i}\"].set_xlim(-0.05, 1.0)\n",
    "        axs[f\"{i}\"].legend()\n",
    "\n",
    "    return fig\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def plot_service_times(*sample_maps, labels=None):\n",
    "    # Make subplots for each airport\n",
    "    max_rows = 2\n",
    "    max_plots_per_row = ceil(n_airports / max_rows)\n",
    "    subplot_spec = []\n",
    "    for i in range(max_rows):\n",
    "        subplot_spec.append(\n",
    "            [f\"{i * max_plots_per_row +j}\" for j in range(max_plots_per_row)]\n",
    "        )\n",
    "\n",
    "    fig = plt.figure(figsize=(4 * max_plots_per_row, 4 * max_rows))\n",
    "    axs = fig.subplot_mosaic(subplot_spec)\n",
    "\n",
    "    for i, code in enumerate(airport_codes):\n",
    "        for j, sample_map in enumerate(sample_maps):\n",
    "            axs[f\"{i}\"].hist(\n",
    "                sample_map[f\"{code}_mean_service_time\"].cpu(),\n",
    "                bins=64,\n",
    "                density=True,\n",
    "                label=labels[j] if labels else None,\n",
    "                alpha=1 / len(sample_maps),\n",
    "            )\n",
    "\n",
    "        axs[f\"{i}\"].set_xlabel(f\"{code} service time (hr)\")\n",
    "        x_min, x_max = axs[f\"{i}\"].get_xlim()\n",
    "        x_min = min(x_min, -0.05)\n",
    "        x_max = max(x_max, 1.05)\n",
    "        axs[f\"{i}\"].set_xlim(x_min, x_max)\n",
    "        axs[f\"{i}\"].legend()\n",
    "\n",
    "    return fig\n",
    "\n",
    "\n",
    "@torch.no_grad()\n",
    "def plot_turnaround_times(*sample_maps, labels=None):\n",
    "    # Make subplots for each airport\n",
    "    max_rows = 2\n",
    "    max_plots_per_row = ceil(n_airports / max_rows)\n",
    "    subplot_spec = []\n",
    "    for i in range(max_rows):\n",
    "        subplot_spec.append(\n",
    "            [f\"{i * max_plots_per_row +j}\" for j in range(max_plots_per_row)]\n",
    "        )\n",
    "\n",
    "    fig = plt.figure(figsize=(4 * max_plots_per_row, 4 * max_rows))\n",
    "    axs = fig.subplot_mosaic(subplot_spec)\n",
    "\n",
    "    for i, code in enumerate(airport_codes):\n",
    "        for j, sample_map in enumerate(sample_maps):\n",
    "            axs[f\"{i}\"].hist(\n",
    "                sample_map[f\"{code}_mean_turnaround_time\"].cpu(),\n",
    "                bins=64,\n",
    "                density=True,\n",
    "                label=labels[j] if labels else None,\n",
    "                alpha=1 / len(sample_maps),\n",
    "            )\n",
    "\n",
    "        axs[f\"{i}\"].set_xlabel(f\"{code} turnaround time (hr)\")\n",
    "        x_min, x_max = axs[f\"{i}\"].get_xlim()\n",
    "        x_min = min(x_min, -0.05)\n",
    "        x_max = max(x_max, 1.05)\n",
    "        # axs[f\"{i}\"].set_xlim(x_min, x_max)\n",
    "        axs[f\"{i}\"].legend()\n",
    "\n",
    "    return fig\n",
    "\n",
    "@torch.no_grad()\n",
    "def plot_posterior_grid(\n",
    "    failure_guide,\n",
    "    nominal_label,\n",
    "):\n",
    "    \"\"\"Plot DEN service times on a grid\"\"\"\n",
    "    n_steps = 2\n",
    "    fig, axs = plt.subplots(\n",
    "        n_steps,\n",
    "        n_calibration_permutations,\n",
    "        figsize=(5 * n_calibration_permutations, 5 * n_steps),\n",
    "    )\n",
    "\n",
    "    for row, j in enumerate(torch.linspace(0, 1, n_steps)):\n",
    "        for i in range(n_calibration_permutations):\n",
    "            label = torch.zeros(n_calibration_permutations).to(nominal_label.device)\n",
    "            label[i] = j\n",
    "\n",
    "            samples = failure_guide(label).sample((1000,))\n",
    "            sample_map = map_to_sample_sites(samples)\n",
    "\n",
    "            code = \"DEN\"\n",
    "            axs[row, i].hist(\n",
    "                sample_map[f\"{code}_mean_service_time\"].cpu(), bins=64, density=True\n",
    "            )\n",
    "            axs[row, i].set_xlabel(f\"{code} service time (hr)\")\n",
    "            x_min, x_max = axs[row, i].get_xlim()\n",
    "            x_min = min(x_min, -0.05)\n",
    "            x_max = max(x_max, 1.05)\n",
    "            axs[row, i].set_xlim(-0.05, 1.05)\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load the trained model\n",
    "failure_guide = zuko.flows.NSF(\n",
    "    features=n_latent_variables,\n",
    "    context=n_calibration_permutations,\n",
    "    hidden_features=(64, 64),\n",
    ").to(device)\n",
    "state_dict = torch.load(\"./models/top-10-daily-nocancel-failure_checkpoint_499.pt\")\n",
    "failure_guide.load_state_dict(state_dict[\"failure_guide\"])\n",
    "mixture_label = state_dict[\"mixture_label\"]\n",
    "nominal_label = torch.zeros_like(mixture_label)\n",
    "failure_guide.eval();"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4/4 [00:01<00:00,  2.55it/s]\n"
     ]
    }
   ],
   "source": [
    "# Get some samples from each day\n",
    "n_samples = 100\n",
    "sample_maps = []\n",
    "nominal_samples = failure_guide(nominal_label).sample((n_samples,))\n",
    "nominal_sample_maps = map_to_sample_sites(nominal_samples)\n",
    "for i in tqdm(range(n_failure)):\n",
    "    label = torch.zeros_like(mixture_label).to(device)\n",
    "    label[i] = 1\n",
    "    failure_samples = failure_guide(label).sample((n_samples,))\n",
    "    sample_maps.append(map_to_sample_sites(failure_samples))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f7f2079db80>"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA/YAAAHzCAYAAACKSobOAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAACKWElEQVR4nO3deXwU9f3H8ffMbEJ20XCogCggrSdWhXqBF6JESBAV0YpFOdRWEawI3qKICHgUTw6tXGpFKhYsQhKJCGoFxSpUResPW6xt5VARAu4GsjPz+2PZZTfZHJtsstnk9Xw88oDMtZ/dzezOZ77f7+druK7rCgAAAAAApCUz1QEAAAAAAICaI7EHAAAAACCNkdgDAAAAAJDGSOwBAAAAAEhjJPYAAAAAAKQxEnsAAAAAANIYiT0AAAAAAGmMxB4AAAAAgDTmSXUA9cVxHO3duzfVYQAAAAAAUKWMjAxZllWtbZtEYr93715t2rRJjuOkOhQAAAAAAKqlZcuWateunQzDqHS7Rp/Yu66rzZs3y7IsdejQQabJ6AMAAAAAQMPluq78fr+2bdsmSTr00EMr3b7RJ/bBYFB+v1/t27eXz+dLdTgAAAAAAFTJ6/VKkrZt26Y2bdpU2i2/0Tdf27YtScrMzExxJAAAAAAAVF+4cbq0tLTS7Rp9Yh9W1ZgEAAAAAAAakurmsU0msQcAAAAAoDFq9GPsK2LbtlzXrbfHMwyj2lMVNBX1+R7w+sfi7z/1+Puvf/zd1z9e89ThtW8YeB8aDt6L1OG1rx9NMrG3bVsDLr1MP27/vt4es1Xrg7V40avV/iMbNmyYnn/+eUmSx+NR69atdeKJJ+rKK6/UsGHDItX9jzjiCP373/8ut/+UKVN055136uuvv1bnzp11yCGH6J///KcOPPDAyDZdu3bVJZdcovvvv7/2TzBBtm3r0ssu0/bv6+c9aH3wwVr0avVf/7D//Oc/Gj9+vAoLC/X999/r0EMP1SWXXKL77rtPBx10UMy2119/vWbNmqUFCxbo8ssvj1l3//3367XXXtP69esjy9599131799fw4YN0+OPP15vw0Vs29all16q7du318vjSVLr1q21aNGihF7/6HMgfIxTTz1VjzzyiE488URJoQ/uZs2a6csvv1SnTp0i215yySVq2bKl5s2bF3PMNWvW6KyzzlLfvn21bNmy2j2pWrBtW5cNvFTf/1A/78HBB7XWq39O3uv/7bffKjc3V5s3b1a7du0i2xx66KFq1qyZvv7668iy8GfQm2++qfPPP1/nnnuuunbtqieeeCIZT63abNvWpQMu0fYfd9TbY7Zu1VKLFr+W0Of+jh079Nprr1W4zX//+1/97Gc/09FHH63PPvus3Pq3335bEyZM0Pr161VSUqLDDjtMZ5xxhp577rl6rzVj27YuGzBA3//4Y7095sGtWunVxYtr9F2bkZGhjh07asiQIbr77rv117/+Vb169dKPP/6oli1bxux3xBFHaPTo0Ro9erS+/fZbHX/88ZowYYJ+97vfRbb54IMPdNZZZ2nZsmW64IILkvYcqyP0OT9Q27f/UG+P2br1QVq06M+1/ntftWpVzOtu27aeeuopzZkzRxs3bpTX61X37t01btw4nXnmmZH94n3PSvs/g9atW6euXbvW8lkmxrZtXXbpQH1fj+/Dwa0P0qsJvg/PP/+8rr/+ej3zzDMx60aOHKkZM2Zo6NChke/TLVu2aNKkSVq2bJn+97//qU2bNuratatGjx6t888/P7Lv6tWr9eCDD2rNmjUKBAI66qijNHz4cN18880pSbhC78UAfb+9Hj+PWrfSq4uq/3kkVf/6P6xPnz5688039f777+vUU08td6yqvlPqQ+iaf4C2f19/r33rg1tp0auJfxdU5zyo7ns0aNAg7dixQ4WFhZFjFRYWKjc3V+PHj4/Jv+6//37NmTNH33zzTa2ed5NM7F3X1Y/bv9dh59wrw6j7DxfXtfW/dyYmfKeqb9++mjt3rmzb1tatW1VYWKibb75Zr776qpYsWSKPJ/T2PfDAA/rNb34Ts290Ai9Ju3bt0u9//3tNmDChdk8mSVzX1fbvv9dF45+WWccf8I5ta8mEmxJ+/f/1r3+pR48eOvroo/Xyyy+rc+fO2rBhg2677TYVFBTo/fffV+vWrSVJfr9fCxYs0O233645c+aUS+zLWrZsmS6//HLdeeeduu+++2r83GrCdV1t375dZ5xxRr3cTHBdV6tXr67RndrwOSCFLibGjRunCy+8MOaDzzAM3XfffTFJaEVmz56tm266SbNnz9a3336r9u3bJxxTMriuq+9/2K5JY0+TZdbte2A7ru6Zujapr//nn38uj8ejVatWadCgQZKkL774QoFAQH6/X19//bWOOOIISdLKlSvVrFmzmAvwVHBdV9t/3KHzj/SqPu6hua604qsdSW+hmDdvnn71q1/pnXfe0QcffKDTTz89su7zzz9X3759ddNNN+mpp56S1+vVxo0b9ec//zlSSLY+ua6r73/8UZO6dpVVDy+67bq6Z/36Gn/X7tmzR/n5+Ro5cqQyMjLUo0ePau3fvn17Pf3007r++uuVm5uro446SoFAQEOHDtV1111X70m9FP6c/0GXnXajTKPuR106rqNX185I+t+767oaNGiQ3nzzTT366KM6//zzVVxcrOnTp+vcc8/VwoULdckllyT1MZPJdV19v/0HPZZ3t6x6mG7ZdhyNyZ+c8PvQoUMHLViwQI8//nikAndJSYnmz5+vjh07Rrb7+uuvdeaZZ6ply5Z69NFHdcIJJ6i0tFRvvPGGRo4cqX/84x+SpMWLF+tXv/qVhg8frpUrV6ply5Z68803dfvtt2vNmjV65ZVX6r32Vei9+FEz+nWu8+9dKfTde+OyTbX67q3q+v+bb77R6tWrNWrUKM2ZM6dcYt9QhK75f9Rp9/5ShlUP1522q7UTP66z80Cq3nvUq1cv3XrrrQoGg5H3bOXKlerQoYNWrVoVc7yVK1eqV69eNX/S+zTJxD7MMCwZZj3cNXRqtluzZs0irWGHHXaYfvnLX6p79+46//zzNW/ePF133XWSQkl8dKtZPDfddJMee+wxjRw5Um3atKlZQHXAtCyZVsP8Mxw5cqQyMzO1fPnyyAnesWNHdevWTT//+c91zz33aObMmZKkhQsXqkuXLrrzzjvVvn17/ec//1GHDh3iHnf+/PkaPny4pk6dqlGjRtXb8ynLMIxyd37rguPU8ARQ7DnQrl073XnnnTr77LP13Xff6ZBDDpEkjRo1So899phuu+02/eIXv6jwWLt379af/vQn/e1vf9OWLVs0b9483X333TWOLRks05Bl1fV7kPzXPxAI6NRTT41J7FetWqWzzjpLjuNo1apVGjZsWGR59+7dlZWVVetnkgyGIZn1cEHpKPldDl3X1dy5czVjxgwdfvjhmj17dkxiv3z5crVr106PPPJIZNnPf/5z9e3bN+mxJMIyjHpJ7Gsq+u98xIgRWrx4sZYsWVLtxF6SrrrqKi1atEjDhg3Tu+++q7vuukulpaV69NFH6yrsajENU2YDvs6pyiuvvBK5UO7fv39k+R/+8Af98MMPuu6665STk6PmzZvXTQBJYpmmrPp4H2rol7/8pf75z39q0aJFGjx4sCRp0aJF6tixozp37hzZ7sYbb5RhGFq7dm3Ma3788cfrmmuukST99NNP+s1vfqOLLrpIf/jDHyLbXHfddWrbtq0uuugivfLKK7riiivq6dnFskxDnnpI7Gujutf/c+fO1YUXXqgRI0aoe/fueuyxxyLXqw2RYRky6/yaR3Jq+IFU3fNAqt571KtXL+3evVt/+9vf1L17d0mha6I777xTY8eOVUlJibKyslRSUqIPPvhAw4cPr8WzDqF4Xpo577zzdNJJJ2nRokUJ7XfllVfqyCOP1AMPPFBHkTUu27dv1xtvvKEbb7yx3Idku3btNHjwYP3pT3+K3A2cPXu2rrrqKrVo0UK5ubnluoCHTZ8+XcOHD9ecOXNSmtSno927d+uPf/yjjjzyyJhhEGeeeaYuvPBC3XnnnZXu/8orr+jYY4/VMccco6uuukpz5syp1/Fe6a7s69+rVy+tXLkysn7lypU699xz1bNnz5jl4W61qL2VK1fK7/erd+/euuqqq7RgwQL99NNPkfXt2rXT5s2b9c4776QwyvTn9Xq1d+/ehPd75plntHHjRg0ePFjTpk3T3LlzdcABB9RBhE3H/PnzdfTRR8ck9WFjx47VDz/8oKKiohRE1vhcc801kR5akjRnzpyYRGP79u0qLCzUyJEj495ICQ9XWb58uX744Qfdeuut5bbp379/pBckElP2+j98o/eqq67SscceqyOPPFKvvvpqiqNMf1WdB5Up+x4dffTRat++feSaaNeuXfr44491+eWX64gjjtCaNWskhYat7NmzJynXSiT2aejYY4+NGcN6xx136IADDoj5effdd2P2MQxDDz30kP7whz/on//8Zz1HnH42btwo13V13HHHxV1/3HHH6ccff9R3332njRs36v3334/cfb7qqqs0d+7ccknjF198oVGjRmnmzJmRO4Go3NKlSyN/0wceeKCWLFmiP/3pT+V6GkyZMkWFhYXl/u6jhW++SKEuVDt37tTbb79dp/Gnu8pe/169eun//u//tHnzZkmhsd09e/bUOeecE3ld//Wvf+mbb74hsU+S2bNna9CgQbIsS7/4xS/0s5/9TAsXLoysv/zyy3XllVeqZ8+eOvTQQzVgwABNmzZNxcXFKYw6fbiuqzfffFNvvPGGzjvvvMjyww8/vNx3bLxxkG3atNHEiRO1YMEC/fa3v9U555xTn+GnpejPmPBPbm5uZP3//d//Vfo9HN4GtXfVVVfpr3/9q/7973/r3//+t957773Id6YkffXVV3JdV8cee2ylxwm/HxW9b8ceeyzvWQ1FX/+/+eab8vv96tOnj6TQ+zd79uwURtc4VHUeVKVsjtarV69It/t3331XRx99tA455BCdc845keWrVq1S586dY2pF1RSJfRpyXTdmbNJtt92m9evXx/yccsop5fbr06ePzjrrLN177731GW5aq06L7pw5c9SnTx8dfPDBkqS8vDzt3LlTb731Vsx2hx9+uH75y1/q0UcfjSRDqFyvXr0if9Nr165Vnz59lJubW65gZJcuXTRkyJAKW+2//PJLrV27VldeeaWkULGTK664gi/BKlT2+p9xxhnKzMzUqlWr9PnnnysQCOiXv/ylTjnlFH333XfatGmTVq1aFSl0hdrZsWOHFi1aFHOBUfZCzrIszZ07V//973/1yCOP6LDDDtPkyZN1/PHH85lTiXBymZWVpdzcXF1xxRUxRY3efffdct+x8epz2LatefPmyefz6f3331cwGKzHZ5Geoj9jwj+zZs2K2YaeVfXjkEMOUb9+/TRv3jzNnTtX/fr1i1zXSIm/D7xvyRd9/T9nzhxdccUVkbHbV155pd577z0a72qpqvOgKmVztHPPPVfvvfeeSktLtWrVKp177rmSpJ49e8Yk9slqACGxT0NffPFFzFiPgw8+WEceeWTMT0VjbB566CH96U9/0rp16+or3LR05JFHyjAMffHFF3HXf/HFF2rVqpUOOuggPf/881q2bJk8Ho88Ho98Pp+2b9+uOXPmxOxz4IEH6s0331Tz5s3Vq1cvLrSroXnz5pG/6VNPPVWzZs3STz/9pOeee67cthMmTNDHH38ct/rr7NmzFQwG1b59+8j7NHPmTP35z3/Wzp076+GZpKfKXn+fz6fTTjtNK1eu1MqVK3XWWWfJsixlZGTojDPOiCw/88wz670ae2M0f/58lZSU6PTTT4/8Dd9xxx3661//Wq7167DDDtPVV1+tadOmacOGDSopKSlX5Rf7hZPLjRs3KhAI6Pnnn4/paty5c+dy37Hhi+lov//97/Wvf/1Lf/vb3/Tf//5XkydPrs+nkZaiP2PCP4cddlhk/dFHH13p93B4G0nKzs6O+3m+Y8cOSVKLFi2SHH3jc80112jevHl6/vnnI2Pmw4466igZhhEpkFeR8PtR2fsW3gaJCV//b9++XYsXL9aMGTMi3weHHXaYgsFguWtPJK6y86AqZXO0Xr166aefftKHH36olStXqmfPnpJCif0HH3yg7du364MPPojpJVYbJPZp5q233tKnn36qgQMH1mj/0047TZdeemmV45GbuoMOOkg5OTmaMWOGAoFAzLotW7bopZde0hVXXKH8/Hzt2rVL69ati2lxePnll7Vo0aLIBUVYq1at9Oabbyo7O1vnnnuuvv3223p8VukvXPCv7HsihaqZjho1SnfffXdMBfBgMKgXXnhBU6dOjXmP/v73v6t9+/aM9UtA2dc/3MUs+i60pEgXs7fffptu+Ekye/ZsjR07ttzf8Nlnn13phVyrVq106KGHxozFR6xwctmxY8e4CXt1bNiwQePHj9fMmTN13HHHaebMmXrwwQf1ySefJDnapmXQoEHauHGjXn/99XLrpk6dGvmulqRjjjlG//3vf7V169aY7T7++GNlZWWVq2qN8vr27au9e/eqtLQ00sU7rHXr1urTp4+mT58e9/MkfL1zwQUXqHXr1po6dWq5bZYsWaKNGzdGes+h+qKv/1966SUdfvjh+vvf/x7znTB16lTNmzcvJbOgNCaVnQeViZej/fznP1eHDh20ZMkSrV+/PpLYH3bYYTrssMM0depU7d27N2nXSg2zHHk9cV27ziq5lnucGtizZ4+2bNkSM5XClClTdOGFF2rIkCGR7Xbt2qUtW7bE7Ovz+ZSdnR33uJMmTdLxxx9f4wuYZHLq4cOnpo8xbdo0nXHGGerTp48efPDBmOnuDjvsME2aNEnXXHON+vXrp5NOOilm3y5duuiWW27RSy+9pJEjR8asa9mypYqKitSnTx+de+65WrVqVUqmXXNdt1YV6xN5nJoKnwOS9OOPP2ratGnavXt33EJKknTXXXfpueee06ZNmyI1D5YuXaoff/xR1157bbkWm4EDB2r27Nm64YYbahxjbdiOq7r+EAo9Rs1U9fr36tVLEydO1JYtW2IKJfXs2VOPPvqodu3a1eASe9etm4r18R6nJnbu3FluHu5wwZ2XXnqp3PjWK6+8Ug888IAefPBBzZ49W+vXr9eAAQP085//XCUlJXrh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f+edd+rBBx9UUVGRMjMzI8vPO+88vf/++0kNDgAAAAAAVC7hxP7TTz/VgAEDyi1v06aNvv/++6QEBQAAAAAAqifhxL5ly5bavHlzueXr1q3TYYcdVuNAHnroIRmGodGjR0eWlZSUaOTIkTrooIN0wAEHaODAgdq6dWvMft9884369esnn8+nNm3a6Lbbbis35zMAAAAAAI1VwlXxBw0apDvuuEMLFy6UYRhyHEfvvfeebr31Vg0ZMqRGQXz44Yd69tlndeKJJ8Ysv+WWW7Rs2TItXLhQLVq00KhRo3TppZfqvffekxSa67lfv35q166dVq9erc2bN2vIkCHKyMjQ5MmTaxQLADQUfr+fqviAJNe1pVr+Obsu090BABqvhBP7yZMna+TIkerQoYNs21aXLl1k27Z+/etfa9y4cQkHsHv3bg0ePFjPPfecHnzwwcjynTt3avbs2Zo/f77OO+88SdLcuXN13HHH6f3331f37t21fPlyff7553rzzTfVtm1bde3aVRMnTtQdd9yh+++/P6YGAACkm3Xr1qU6BCClDMNQlten/70zMSnHy/L6ZBhGUo4FAEBDknBin5mZqeeee0733nuvPvvsM+3evVvdunXTUUcdVaMARo4cqX79+ql3794xif1HH32k0tJS9e7dO7Ls2GOPVceOHbVmzRp1795da9as0QknnKC2bdtGtunTp49GjBihDRs2qFu3bnEfc8+ePdqzZ0/k9+Li4hrFDgB1qVu3brVusefmANKZZVkqLMiX67qRZcFgUDk5OTp94IMyTCvufq5j64M/j1NRUZE8nv2XOoZhyLLi7wMAQDpLOLEP69ixozp27FirB1+wYIE+/vhjffjhh+XWbdmyRZmZmWrZsmXM8rZt22rLli2RbaKT+vD68LqKTJkyRRMmTKhV7ABQ13w+H13x0eRVlIhbnkyZFST2jhPqdu/xeGISewDpy7HtuP8HEJLwt53runr11Ve1cuVKbdu2rdyF46JFi6p1nP/85z+6+eabVVRUpKysrETDqJW77rpLY8aMifxeXFysDh061GsMAAAAACpnGIZ8Pp8ev/namOU+H0NrgGgJJ/ajR4/Ws88+q169eqlt27Y1PqE++ugjbdu2Tb/85S8jy2zb1jvvvKNp06bpjTfe0N69e7Vjx46YVvutW7eqXbt2kqR27dpp7dq1MccNV80P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007TunXr1KlTp6QE8Omnn6pHjx4qKSnRAQccoMWLF6tLly5av369MjMz1bJly5jt27Ztqy1btkiStmzZEpPUh9eH11Vkz5492rNnT+T34uLipDwXAACQHmzbVm5engJ+vwzT1OM3Xxuz3jBN5eTkyOvzqSA/n4QDiKOi88LyZMqsILF3nNCNM4/HQ00sIIkSPptuvPFGjR07Vv/973918sknq3nz5jHrTzzxxISOd8wxx2j9+vXauXOnXn31VQ0dOlRvv/12omElZMqUKUzNBwBAE+a6rgJ+v655+FnJMCS3zBhYw5RcV3PuuJ6CVwCABi/hxH7QoEGSpN/97neRZYZhyHVdGYaR8ByNmZmZOvLIIyVJJ598sj788EM9+eSTuuKKK7R3717t2LEjptV+69atkfH97dq109q1a2OOt3Xr1si6itx1110aM2ZM5Pfi4mJ16NAhobgBAED6My1LphX/csixg/UcTd2wbbvczQm6PQNA45JwYr9p06a6iCPCcRzt2bNHJ598sjIyMrRixQoNHDhQkvTll1/qm2++UY8ePSRJPXr00KRJk7Rt2za1adNGklRUVKTs7Gx16dKlwsdo1qyZmjVrVqfPAwAAINVs21Zebq78gdi5uH1er/ILmFMbABqLhBP7ZI2tl0It57m5uerYsaN27dql+fPna9WqVXrjjTfUokULXXvttRozZoxat26t7Oxs3XTTTerRo4e6d+8uSbrgggvUpUsXXX311XrkkUe0ZcsWjRs3TiNHjiRxBwAATZ7ruvIHArrxVzmRebUdx9WMV4oYYoA64zp2hRO8uU7DndouVcr2qqFHDWqiRhUrXnzxRT3zzDPatGmT1qxZo06dOumJJ55Q586ddfHFF1f7ONu2bdOQIUO0efNmtWjRQieeeKLeeOMN5eTkSJIef/xxmaapgQMHas+ePerTp49mzJgR2d+yLC1dulQjRoxQjx491Lx5cw0dOlQPPPBATZ4WAABAo2SahiwzPBc3c2qjbhiGIa/XpzUL76p0Oy9T20XE61VDjxrURMKJ/cyZM3Xfffdp9OjRmjRpUmRMfcuWLfXEE08klNjPnj270vVZWVmaPn26pk+fXuE2nTp1Un5+frUfEwAAAEDyWZalgoJ8lZaWKicnRxdfNzVSHd9xbP1l1lgVFRUpIyODpHWfsr1q6FGDmjKr3iTW008/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RmKPGpsyZYpOPfVUHXjggWrTpo0uueQSffnllzHblJSUaOTIkTrooIN0wAEHaODAgdq6dWtk/d///nddeeWV6tChg7xer4477jg9+eSTMcdYtGiRcnJydMghhyg7O1s9evTQG2+8UWV8ixYt0gUXXKCDDjpIhmFo/fr1Meu3b9+um266Scccc4y8Xq86duyo3/3ud9q5c2elx121apUuvvhiHXrooWrevLm6du2ql156KWabDRs2aODAgTriiCNkGIaeeOKJKuMFkonzs+Lz87nnntPZZ5+tVq1aqVWrVurdu7fWrl1bZcxAMnGOVnyOLlq0SKeccopatmwZ2ebFF1+sMmYgWTg/Kz4/oy1YsECGYeiSSy6pMmbUPRJ71Njbb7+tkSNH6v3331dRUZFKS0t1wQUX6Keffopsc8stt+j111/XwoUL9fbbb+vbb7/VpZdeGln/0UcfqU2bNvrjH/+oDRs26J577tFdd92ladOmRbZ55513lJOTo/z8fH300Ufq1auX+vfvr3Xr1lUa308//aSzzjpLDz/8cNz13377rb799lv9/ve/12effaZ58+apsLBQ1157baXHXb16tU488UT9+c9/1ieffKLhw4dryJAhWrp0aWQbv9+vn/3sZ3rooYfUrl27So8H1AXOz4rPz1WrVunKK6/UypUrtWbNGnXo0EEXXHCB/ve//1V6bCCZOEcrPkdbt26te+65R2vWrIlsM3z48GolPEAycH5WfH6Gff3117r11lt19tlnV3pM1CMXSJJt27a5kty3337bdV3X3bFjh5uRkeEuXLgwss0XX3zhSnLXrFlT4XFuvPFGt1evXpU+VpcuXdwJEyZUK65Nmza5ktx169ZVue0rr7ziZmZmuqWlpdU6dlheXp47fPjwuOs6derkPv744wkdD0g2zs/456frum4wGHQPPPBA9/nnn0/ouEAycY5WfI66rut269bNHTduXELHBZKF8zP2/AwGg+4ZZ5zhzpo1yx06dKh78cUXJ3RM1A1a7JE04e49rVu3lhS6U1laWqrevXtHtjn22GPVsWNHrVmzptLjhI8Rj+M42rVrV6Xb1NTOnTuVnZ0tj8eT8H51EQ+QLJyfFcfj9/tVWlrKOYyU4hyNH4/rulqxYoW+/PJLnXPOOckIE0gY52dsPA888IDatGlTZQ8A1K/E3lmgAo7jaPTo0TrzzDP1i1/8QpK0ZcsWZWZmqmXLljHbtm3bVlu2bIl7nNWrV+tPf/qTli1bVuFj/f73v9fu3bv1q1/9KmnxS9L333+viRMn6re//W1C+73yyiv68MMP9eyzzyY1HiBZOD8rPz/vuOMOtW/fPuYCDahPnKPlz9GdO3fqsMMO0549e2RZlmbMmKGcnJxkhgxUC+dn7Pn517/+VbNnzy43rh+pR4s9kmLkyJH67LPPtGDBghof47PPPtPFF1+s8ePH64ILLoi7zfz58zVhwgS98soratOmjSTppZde0gEHHBD5effddxN+7OLiYvXr109dunTR/fffH1l+/PHHR46bm5tbbr+VK1dq+PDheu6553T88ccn/LhAfeD8rPj8fOihh7RgwQItXrxYWVlZCccGJAPnaPlz9MADD9T69ev14YcfatKkSRozZoxWrVqVcGxAbXF+7j8/d+3apauvvlrPPfecDj744IRjQR1L9VgApL+RI0e6hx9+uPuvf/0rZvmKFStcSe6PP/4Ys7xjx47uY489FrNsw4YNbps2bdy77767wsd5+eWXXa/X6y5dujRmeXFxsbtx48bIj9/vj1lf1fij4uJit0ePHu7555/vBgKBmHVff/115Lj//e9/Y9atWrXKbd68ufvss89WGLPrMsYeqcX5WfH5+eijj7otWrRwP/zwwwq3Aeoa52jl36Fh1157rXvBBRdUa1sgWTg/Y8/PdevWuZJcy7IiP4ZhuIZhuJZluV999VWFzxF1j8QeNeY4jjty5Ei3ffv27v/93/+VWx8uLPLqq69Glv3jH/8oV1jks88+c9u0aePedtttFT7W/Pnz3aysLPe1115LOM7KPvR27tzpdu/e3e3Zs6f7008/VfuYK1eudJs3b+5Omzatym1J7JEKnJ+Vn58PP/ywm52dXWmRI6AucY5W7zs0bPjw4W7Pnj2rvT1QG5yf8c/PQCDgfvrppzE/F198sXveeee5n376qbtnz56EnwOSh8QeNTZixAi3RYsW7qpVq9zNmzdHfqLvJt5www1ux44d3bfeesv929/+5vbo0cPt0aNHZP2nn37qHnLIIe5VV10Vc4xt27ZFtnnppZdcj8fjTp8+PWabHTt2VBrfDz/84K5bt85dtmyZK8ldsGCBu27dOnfz5s2u64Y+8E4//XT3hBNOcL/66quYYweDwQqP+9Zbb7k+n8+96667Yvb54YcfItvs2bPHXbdunbtu3Tr30EMPdW+99VZ33bp17saNGxN+nYGa4Pys+Px86KGH3MzMTPfVV1+N2WbXrl0Jv85ATXGOVnyOTp482V2+fLn7z3/+0/3888/d3//+967H43Gfe+65hF9noCY4Pys+P8uiKn7DQWKPGpMU92fu3LmRbQKBgHvjjTe6rVq1cn0+nztgwIDIh47ruu748ePjHqNTp06RbXr27Bl3m6FDh1Ya39y5c+PuN378eNd1Q3ckK3oOmzZtqvC4Q4cOjbtPdEtC+A5qZdsAdYnzs+Jzr1OnTpU+NlAfOEcrPkfvuece98gjj3SzsrLcVq1auT169HAXLFiQwKsL1A7nZ/WvX0nsGw7DdV1XAAAAAAAgLVEVHwAAAACANEZiDwAAAABAGiOxBwAAAAAgjZHYAwAAAACQxkjsAQAAAABIYyT2AAAAAACkMRJ7AAAAAADSGIk9AAAAAABpjMQeAIAmbtiwYTIMQ4ZhKCMjQ23btlVOTo7mzJkjx3GqfZx58+apZcuWdRcoAACIi8QeAACob9++2rx5s77++msVFBSoV69euvnmm3XhhRcqGAymOjwAAFAJEnsAAKBmzZqpXbt2Ouyww/TLX/5Sd999t/7yl7+ooKBA8+bNkyQ99thjOuGEE9S8eXN16NBBN954o3bv3i1JWrVqlYYPH66dO3dGWv/vv/9+SdKePXt066236rDDDlPz5s11+umna9WqVal5ogAANEIk9gAAIK7zzjtPJ510khYtWiRJMk1TTz31lDZs2KDnn39eb731lm6//XZJ0hlnnKEnnnhC2dnZ2rx5szZv3qxbb71VkjRq1CitWbNGCxYs0CeffKLLL79cffv21caNG1P23AAAaEwM13XdVAcBAABSZ9iwYdqxY4dee+21cusGDRqkTz75RJ9//nm5da+++qpuuOEGff/995JCY+xHjx6tHTt2RLb55ptv9LOf/UzffPON2rdvH1neu3dvnXbaaZo8eXLSnw8AAE2NJ9UBAACAhst1XRmGIUl68803NWXKFP3jH/9QcXGxgsGgSkpK5Pf75fP54u7/6aefyrZtHX300THL9+zZo4MOOqjO4wcAoCkgsQcAABX64osv1LlzZ3399de68MILNWLECE2aNEmtW7fWX//6V1177bXau3dvhYn97t27ZVmWPvroI1mWFbPugAMOqI+nAABAo0diDwAA4nrrrbf06aef6pZbbtFHH30kx3E0depUmWaoRM8rr7wSs31mZqZs245Z1q1bN9m2rW3btunss8+ut9gBAGhKSOwBAID27NmjLVu2yLZtbd26VYWFhZoyZYouvPBCDRkyRJ999plKS0v19NNPq3///nrvvff0zDPPxBzjiCOO0O7du7VixQqddNJJ8vl8OvroozV48GANGTJEU6dOVbdu3fTdd99pxYoVOvHEE9WvX78UPWMAABoPquIDAAAVFhbq0EMP1RFHHKG+fftq5cqVeuqpp/SXv/xFlmXppJNO0mOPPaaHH35Yv/jFL/TSSy9pypQpMcc444wzdMMNN+iKK67QIYccokceeUSSNHfuXA0ZMkRjx47VMccco0suuUQffvihOnbsmIqnCgBAo0NVfAAAAAAA0hgt9gAAAAAApDESewAAAAAA0hiJPQAAAAAAaYzEHgAAAACANEZiDwAAAABAGiOxBwAAAAAgjZHYAwAAAACQxkjsAQAAAABIYyT2AAAAAACkMRJ7AAAAAADSGIk9AAAAAABpjMQeAAAAAIA09v+znQcKj0bXxAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1200x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot the service times for each airport over time\n",
    "failure_airport_service_times = {}\n",
    "nominal_airport_service_times = {}\n",
    "for code in airport_codes:\n",
    "    failure_airport_service_times[code] = torch.cat([s[f\"{code}_mean_service_time\"].reshape(1, -1) for s in sample_maps], dim=0)\n",
    "    nominal_airport_service_times[code] = nominal_sample_maps[f\"{code}_mean_service_time\"]\n",
    "\n",
    "mean_service_time = {code: failure_airport_service_times[code].cpu().mean() for code in airport_codes}\n",
    "relative_change_in_service_time = {\n",
    "    code: (failure_airport_service_times[code].cpu().mean() - nominal_airport_service_times[code].cpu().mean()) / nominal_airport_service_times[code].cpu().mean()\n",
    "    for code in airport_codes\n",
    "}\n",
    "codes_sorted_by_service_time = sorted(airport_codes, key=lambda code: relative_change_in_service_time[code], reverse=True)\n",
    "\n",
    "# Update the palette to keep colors consistent\n",
    "palette = sns.color_palette()\n",
    "palette = [sns.color_palette(\"muted\")[airports_sorted_by_departures.index(code)] for code in codes_sorted_by_service_time]\n",
    "sns.set_palette(palette)\n",
    "\n",
    "df = pd.DataFrame()\n",
    "\n",
    "absolute = False\n",
    "for code in codes_sorted_by_service_time:\n",
    "    failure_dates = [f.date.unique()[0] for f in failure]\n",
    "    failure_service_times = failure_airport_service_times[code].cpu().mean(dim=-1)\n",
    "    nominal_dates = [pd.Timestamp(datetime.date(2022, 12, 20))]\n",
    "    nominal_service_times = nominal_airport_service_times[code].cpu().mean(dim=-1)\n",
    "\n",
    "    if absolute:\n",
    "        airport_df = pd.DataFrame(\n",
    "            {\n",
    "                \"Date\": nominal_dates * n_samples + [d for d in failure_dates for _ in range(n_samples)],\n",
    "                \"Mean service time (hr)\": torch.cat([nominal_airport_service_times[code].cpu(), failure_airport_service_times[code].cpu().reshape(-1)]),\n",
    "                \"Period\": [\"nominal\"] * n_samples + [\"failure\"] * n_samples * len(failure_dates),\n",
    "                \"Airport\": [code] * (n_samples * (len(failure_dates) + 1)),\n",
    "            }\n",
    "        )\n",
    "    else:\n",
    "        relative_change = (failure_airport_service_times[code].reshape(-1) - nominal_airport_service_times[code].tile(n_failure))\n",
    "        relative_change /= nominal_airport_service_times[code].tile(n_failure)\n",
    "        relative_change *= 100\n",
    "        relative_change = relative_change.cpu()\n",
    "        airport_df = pd.DataFrame(\n",
    "            {\n",
    "                \"Date\": [d for d in failure_dates for _ in range(n_samples)],\n",
    "                \"% change in service time\": relative_change,\n",
    "                \"Period\": [\"failure\"] * n_samples * len(failure_dates),\n",
    "                \"Airport\": [code] * n_samples * len(failure_dates),\n",
    "            }\n",
    "        )\n",
    "    df = pd.concat([df, airport_df])\n",
    "\n",
    "ylabel = \"Mean service time (hr)\" if absolute else \"% change in service time\"\n",
    "\n",
    "plt.figure(figsize=(12, 5))\n",
    "sns.boxenplot(x=\"Date\", y=ylabel, hue=\"Airport\", data=df, showfliers=False)\n",
    "plt.legend(bbox_to_anchor=(0.5, 1.15), loc=\"upper center\", ncol=len(airport_codes))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(0.00392156862745098, 0.45098039215686275, 0.6980392156862745)"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sns.color_palette(\"colorblind\")[airports_sorted_by_departures.index(\"DEN\")]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyError",
     "evalue": "'DAL'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyError\u001b[0m                                  Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[68], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m codes_sorted_by_service_time \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43msorted\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mairport_codes\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mkey\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mlambda\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mcode\u001b[49m\u001b[43m:\u001b[49m\u001b[43m \u001b[49m\u001b[43mrelative_change_in_service_time\u001b[49m\u001b[43m[\u001b[49m\u001b[43mcode\u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mreverse\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[1;32m      2\u001b[0m codes_sorted_by_service_time\n",
      "Cell \u001b[0;32mIn[68], line 1\u001b[0m, in \u001b[0;36m<lambda>\u001b[0;34m(code)\u001b[0m\n\u001b[0;32m----> 1\u001b[0m codes_sorted_by_service_time \u001b[38;5;241m=\u001b[39m \u001b[38;5;28msorted\u001b[39m(airport_codes, key\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mlambda\u001b[39;00m code: \u001b[43mrelative_change_in_service_time\u001b[49m\u001b[43m[\u001b[49m\u001b[43mcode\u001b[49m\u001b[43m]\u001b[49m, reverse\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m)\n\u001b[1;32m      2\u001b[0m codes_sorted_by_service_time\n",
      "\u001b[0;31mKeyError\u001b[0m: 'DAL'"
     ]
    }
   ],
   "source": [
    "codes_sorted_by_service_time = sorted(airport_codes, key=lambda code: relative_change_in_service_time[code], reverse=True)\n",
    "codes_sorted_by_service_time"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "bayes-air-GdHwFLEb-py3.10",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
