{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "Simulations.ipynb",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "eROPTqJcKzhT",
        "outputId": "bd0feec5-35d8-4cea-8cdb-13b8b90d871b"
      },
      "source": [
        "#@title ## Session Initialization\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown <b>WARNING!</b> Please execute this block of code once at the beginning of a session.\n",
        "#@markdown It imports the necessary dependencies and implements a common set of functionality used by any subsequent code blocks.\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown #### Debug Mode\n",
        "#@markdown In <i>Debug Mode</i>, the code's output is more verbose, and warning messages are not suppressed.\n",
        "#@markdown Please specify whether you want to enable Debug Mode.\n",
        "debug_mode = False #@param [\"False\", \"True\"] {type:\"raw\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "# Dependencies:\n",
        "\n",
        "!pip install --upgrade gspread\n",
        "\n",
        "\n",
        "\n",
        "# Common Libraries:\n",
        "\n",
        "import numpy as np\n",
        "import pandas as pd\n",
        "\n",
        "import matplotlib\n",
        "import matplotlib.pyplot as plt\n",
        "from matplotlib.lines import Line2D\n",
        "\n",
        "import re\n",
        "import itertools as it\n",
        "\n",
        "from copy import copy\n",
        "\n",
        "from google.colab import auth\n",
        "import gspread\n",
        "from oauth2client.client import GoogleCredentials\n",
        "\n",
        "\n",
        "\n",
        "# Constants:\n",
        "\n",
        "ws_GAME_DATA       = 'Player Data'\n",
        "c_PLAYER_ID        = 'Player ID'\n",
        "c_TEAM             = 'Team'\n",
        "c_STRATEGY_SPACE   = 'Strategy Space'\n",
        "c_INITIAL_STRATEGY = 'Initial Strategy'\n",
        "ws_SIMULATION_INFO = 'Simulation Information'\n",
        "c_SIMULATION_NAME  = 'Simulation Name'\n",
        "c_SIMULATION_TIME  = 'Simulation Time'\n",
        "c_STEP_NUMBER      = 'Discretized Steps'\n",
        "c_TEAM_ID_1        = 'Team ID 1'\n",
        "c_TEAM_ID_2        = 'Team ID 2'\n",
        "c_PLOTTED_POINTS   = 'Plotted Points'\n",
        "c_STEP_ID          = 'Step'\n",
        "c_TEAM_X           = 'T1'\n",
        "c_TEAM_Y           = 'T2'\n",
        "\n",
        "KLDIVERGENCE_DESC  = r'$- \\sum_{i \\in N_1}(\\ln(2) + 0.5(\\ln(x_i) + \\ln(1 - x_i))) - \\sum_{i \\in N_2}(\\ln(2) + 0.5(\\ln(y_i) + \\ln(1 - y_i)))$'\n",
        "LYAPUNOV_DESC = r'$\\sum_{k = 1}^{2} \\frac{1}{|S_k|} \\sum_{i \\in S_k} n_k \\cdot [\\ln(\\theta_{k,i}) + \\ln(1 - \\theta_{k,i})]$'\n",
        "\n",
        "lst_RESERVED_WORKSHEETS = (\n",
        "    ws_GAME_DATA,\n",
        "    ws_SIMULATION_INFO\n",
        ")\n",
        "\n",
        "lst_DEFAULT_COLORS = [\n",
        "    'tab:orange',\n",
        "    'tab:blue'\n",
        "]\n",
        "\n",
        "re_KEYWORD_PATTERN  = re.compile(r'^\\{(?P<keyword>.+)\\}$')\n",
        "re_INTERVAL_PATTERN = re.compile(r'\\s*(?P<lpb>\\(|\\[)?(?P<ln>\\d*\\.?\\d+)(?(lpb)\\s*,\\s*(?P<rn>\\d*\\.?\\d+)(?P<rpb>\\)|\\])|)(?:\\s*(?:,|;)|$)')\n",
        "\n",
        "\n",
        "\n",
        "# Classes:\n",
        "\n",
        "# TODO: Add a description.\n",
        "class TeamColorRegistry:\n",
        "\n",
        "  def __init__(self, default_colors=lst_DEFAULT_COLORS):\n",
        "    self.default_colors    = copy(default_colors)\n",
        "    self.registered_colors = {}\n",
        "\n",
        "  def getTeamColor(self, team_id):\n",
        "    if team_id not in self.registered_colors:\n",
        "      if len(self.default_colors) > 0:\n",
        "        self.registered_colors[team_id] = self.default_colors.pop()\n",
        "      else:\n",
        "        self.registered_colors[team_id] = np.random.rand(3,)\n",
        "    return self.registered_colors[team_id]\n",
        "    \n",
        "\n",
        "class Metric():\n",
        "\n",
        "  def __init__(self, name, description):\n",
        "    self.name        = name\n",
        "    self.description = description\n",
        "    \n",
        "  def _compute(self, x, y, *args, **kwargs):\n",
        "    raise(NotImplementedError())\n",
        "\n",
        "  def compute(self, x, y, *args, **kwargs):\n",
        "    return self._compute(x, y, *args, **kwargs)\n",
        "\n",
        "\n",
        "class KLDivergence(Metric):\n",
        "\n",
        "  def __init__(self, name='KL', description=KLDIVERGENCE_DESC):\n",
        "    super().__init__(name, description)\n",
        "\n",
        "  @staticmethod\n",
        "  def _computeStep(i, x):\n",
        "    return np.log(np.clip(x[i], 0, 1)) + np.log(np.clip(1 - x[i], 0, 1))\n",
        "\n",
        "  def _compute(self, x, y, *args, **kwargs):\n",
        "    return - np.log(2) * (len(x) + len(y)) - 0.5 * sum(it.chain.from_iterable(map(\n",
        "          lambda S: map(lambda i: self._computeStep(i, S), range(len(S))),\n",
        "          (x, y))))\n",
        "\n",
        "\n",
        "class Lyapunov(Metric):\n",
        "\n",
        "  def __init__(self, name='Lyapunov', description=LYAPUNOV_DESC):\n",
        "    super().__init__(name, description)\n",
        "\n",
        "  @staticmethod\n",
        "  def _computeStep(x, x0, Sx):\n",
        "\n",
        "    n = x.size\n",
        "    x = x[compareToStrategySpace(np.ones_like(x) * 0.5, filterStrategySpace(x0, Sx)) == 0]\n",
        "    if x.size == 0:\n",
        "      return None\n",
        "    return np.sum(n * (np.log(np.clip(x, 0, 1)) + np.log(np.clip(1 - x, 0, 1)))) / x.size\n",
        "\n",
        "  def _compute(self, x, y, x0, y0, Sx, Sy):\n",
        "    \n",
        "    s = 0\n",
        "    for x_i, x0_i, Sx_i in ((x, x0, Sx), (y, y0, Sy)):\n",
        "\n",
        "      s_i = self._computeStep(x_i, x0_i, Sx_i)\n",
        "      if s_i is None:\n",
        "        return np.nan\n",
        "\n",
        "      s += s_i\n",
        "\n",
        "    return s\n",
        "\n",
        "# Functions:\n",
        "\n",
        "def filterStrategySpace(x, strategy_space):\n",
        "  return np.array([next(it.dropwhile(lambda i: x not in i, s)) for x, s in zip(x, strategy_space)])\n",
        "\n",
        "\n",
        "# We use this function to determine whether the updated strategy of each player\n",
        "#   remains inside their strategy space.\n",
        "def compareToStrategySpace(x, strategy_space):\n",
        "  return np.array([\n",
        "      0 if x in i else -1 if x < i.left or (x == i.left and i.open_left) else 1\n",
        "      for x, i in zip(x, strategy_space)])\n",
        "  \n",
        "\n",
        "# TODO: Add a description.\n",
        "def plotStrategySpace(ax, game_data_df, color_registry=TeamColorRegistry()):\n",
        "  \n",
        "  for player_id, record in game_data_df.iterrows():\n",
        "\n",
        "    team_id    = record['Team']\n",
        "    team_color = color_registry.getTeamColor(team_id)\n",
        "    yy         = ['T{team_id}P{player_id}'.format(team_id=team_id, player_id=player_id)] * 2\n",
        "\n",
        "    for interval in record[c_STRATEGY_SPACE]:\n",
        "\n",
        "      xx = [interval.left, interval.right]\n",
        "\n",
        "      ax.plot(xx, yy, lw=12, color=team_color, solid_capstyle='butt')\n",
        "      ax.plot(xx, yy, lw=2, color='black', solid_capstyle='butt')\n",
        "      for dim_idx, is_closed in enumerate([interval.closed_left, interval.closed_right]):\n",
        "        ax.plot(\n",
        "            xx[dim_idx], yy[dim_idx], 'o',\n",
        "            color='black',\n",
        "            markersize=15,\n",
        "            mfc=None if is_closed else 'white')\n",
        "\n",
        "  return ax\n",
        "\n",
        "\n",
        "# TODO: Add a description.\n",
        "def plotStrategies(ax, game_data_df, color_registry=TeamColorRegistry()):\n",
        "\n",
        "  plotted_points = []\n",
        "\n",
        "  for player_id, record in game_data_df.iterrows():\n",
        "\n",
        "    team_id    = record['Team']\n",
        "    team_color = color_registry.getTeamColor(team_id)\n",
        "    x0         = record[c_INITIAL_STRATEGY]\n",
        "    yy         = ['T{team_id}P{player_id}'.format(team_id=team_id, player_id=player_id)] * 2\n",
        "\n",
        "    ax.plot(x0, yy[0], 'o', color='black', markersize=4, alpha=0.75)\n",
        "\n",
        "    plotted_points.extend(\n",
        "        ax.plot(x0, yy[0], 'D', color='black', markersize=7, mfc=team_color))\n",
        "  \n",
        "  return  ax, pd.Series(plotted_points, index=game_data_df.index, name=c_PLOTTED_POINTS)\n",
        "\n",
        "\n",
        "# TODO: Add a description.\n",
        "def constructInterval(match):\n",
        "\n",
        "  lpb, ln, rn, rpb = match.groups()\n",
        "\n",
        "  ln = float(ln)\n",
        "  if lpb is None:\n",
        "    return pd.Interval(ln, ln, closed='both')\n",
        "\n",
        "  if lpb == '[' and rpb == ']':\n",
        "    closed = 'both'\n",
        "  elif lpb == '[':\n",
        "    closed = 'left'\n",
        "  elif rpb == ']':\n",
        "    closed = 'right'\n",
        "  else:\n",
        "    closed = 'neither'\n",
        "\n",
        "  rn = float(rn)\n",
        "  return pd.Interval(ln, rn, closed=closed)\n",
        "\n",
        "\n",
        "# TODO: Add a description.\n",
        "def getFromKeyword(string):\n",
        "\n",
        "  keywords = re_KEYWORD_PATTERN.findall(string)\n",
        "  if len(keywords) == 1 and keywords[0] in globals():\n",
        "    return globals()[keywords[0]]\n",
        "\n",
        "  return string\n",
        "\n",
        "\n",
        "# TODO: Add a description.\n",
        "def importGameData(url):\n",
        "\n",
        "  # In order to access the Google spreadhseet we require from the user to authenticate his/her account.\n",
        "\n",
        "  auth.authenticate_user()\n",
        "  gc = gspread.authorize(GoogleCredentials.get_application_default())\n",
        "\n",
        "  game_data_values = gc.open_by_url(url).\\\n",
        "    worksheet(ws_GAME_DATA).get_all_values() # The <Player Data> worksheet should hold all the required information for the simulation parameters.\n",
        "  game_data_headers = game_data_values[0]\n",
        "  game_data_records = []\n",
        "  if len(game_data_values) > 1:\n",
        "    game_data_records = game_data_values[1:]\n",
        "\n",
        "  game_data_df = pd.DataFrame.from_records(\n",
        "      game_data_records,\n",
        "      columns=game_data_headers,\n",
        "      index=c_PLAYER_ID).astype(str) # Records are indexed by the player IDs, i.e., <Player ID> column.\n",
        "\n",
        "  # While parsing the information we need to determine the strategy space of each player.\n",
        "  # The information is stored in the column <Strategy Space>.\n",
        "  # The column is updated with lists of sonstructed pd.Interval objects that describe each space.\n",
        "\n",
        "  game_data_df[c_STRATEGY_SPACE]   = game_data_df[c_STRATEGY_SPACE].apply(lambda string: list(map(constructInterval, re_INTERVAL_PATTERN.finditer(string))))\n",
        "  game_data_df[c_INITIAL_STRATEGY] = game_data_df[c_INITIAL_STRATEGY].astype(float) # The column <Origin> describes the initial mixed-strategy of each player.\n",
        "\n",
        "  #TODO: Perform any interval simplifications that might be possible and ensure that the origin points fall inside the valid strategy space of each player.\n",
        "\n",
        "  return game_data_df\n",
        "\n",
        "\n",
        "def getMetricsDictionary(keys=None):\n",
        "\n",
        "  available_metrics = dict((metric.name, metric) for metric in [KLDivergence(), Lyapunov()])\n",
        "\n",
        "  if keys is None:\n",
        "    return available_metrics\n",
        "\n",
        "  return dict((key, available_metrics[key]) for key in keys)\n",
        "\n",
        "\n",
        "print('The dependencies were loaded successfully.')"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Requirement already satisfied: gspread in /usr/local/lib/python3.7/dist-packages (3.0.1)\n",
            "Collecting gspread\n",
            "  Downloading gspread-4.0.1-py3-none-any.whl (29 kB)\n",
            "Requirement already satisfied: google-auth>=1.12.0 in /usr/local/lib/python3.7/dist-packages (from gspread) (1.35.0)\n",
            "Requirement already satisfied: google-auth-oauthlib>=0.4.1 in /usr/local/lib/python3.7/dist-packages (from gspread) (0.4.6)\n",
            "Requirement already satisfied: rsa<5,>=3.1.4 in /usr/local/lib/python3.7/dist-packages (from google-auth>=1.12.0->gspread) (4.7.2)\n",
            "Requirement already satisfied: cachetools<5.0,>=2.0.0 in /usr/local/lib/python3.7/dist-packages (from google-auth>=1.12.0->gspread) (4.2.2)\n",
            "Requirement already satisfied: pyasn1-modules>=0.2.1 in /usr/local/lib/python3.7/dist-packages (from google-auth>=1.12.0->gspread) (0.2.8)\n",
            "Requirement already satisfied: setuptools>=40.3.0 in /usr/local/lib/python3.7/dist-packages (from google-auth>=1.12.0->gspread) (57.4.0)\n",
            "Requirement already satisfied: six>=1.9.0 in /usr/local/lib/python3.7/dist-packages (from google-auth>=1.12.0->gspread) (1.15.0)\n",
            "Requirement already satisfied: requests-oauthlib>=0.7.0 in /usr/local/lib/python3.7/dist-packages (from google-auth-oauthlib>=0.4.1->gspread) (1.3.0)\n",
            "Requirement already satisfied: pyasn1<0.5.0,>=0.4.6 in /usr/local/lib/python3.7/dist-packages (from pyasn1-modules>=0.2.1->google-auth>=1.12.0->gspread) (0.4.8)\n",
            "Requirement already satisfied: requests>=2.0.0 in /usr/local/lib/python3.7/dist-packages (from requests-oauthlib>=0.7.0->google-auth-oauthlib>=0.4.1->gspread) (2.23.0)\n",
            "Requirement already satisfied: oauthlib>=3.0.0 in /usr/local/lib/python3.7/dist-packages (from requests-oauthlib>=0.7.0->google-auth-oauthlib>=0.4.1->gspread) (3.1.1)\n",
            "Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.7/dist-packages (from requests>=2.0.0->requests-oauthlib>=0.7.0->google-auth-oauthlib>=0.4.1->gspread) (2.10)\n",
            "Requirement already satisfied: chardet<4,>=3.0.2 in /usr/local/lib/python3.7/dist-packages (from requests>=2.0.0->requests-oauthlib>=0.7.0->google-auth-oauthlib>=0.4.1->gspread) (3.0.4)\n",
            "Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.7/dist-packages (from requests>=2.0.0->requests-oauthlib>=0.7.0->google-auth-oauthlib>=0.4.1->gspread) (1.24.3)\n",
            "Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.7/dist-packages (from requests>=2.0.0->requests-oauthlib>=0.7.0->google-auth-oauthlib>=0.4.1->gspread) (2021.5.30)\n",
            "Installing collected packages: gspread\n",
            "  Attempting uninstall: gspread\n",
            "    Found existing installation: gspread 3.0.1\n",
            "    Uninstalling gspread-3.0.1:\n",
            "      Successfully uninstalled gspread-3.0.1\n",
            "Successfully installed gspread-4.0.1\n",
            "The dependencies were loaded successfully.\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 348
        },
        "id": "59jDc3weI7Jw",
        "outputId": "d31eb1bc-26be-41bd-a634-189375b1551c"
      },
      "source": [
        "#@title ## Game Parameterization\n",
        "\n",
        "#@markdown You can use thi block of code to import the game parameters from a Google Spreadheet.\n",
        "#@markdown The provided spreadsheet has to contain a worksheet named <i>Player Data</i> with the following columns: <ul>\n",
        "#@markdown <li><i>Player ID</i>: The player's name or ID</li>\n",
        "#@markdown <li><i>Team</i>: The label of the team the player is assigned to</li>\n",
        "#@markdown <li><i>Strategy Space</i>: Comma separated intervals (closed or open) that form the player's strategy space</li>\n",
        "#@markdown <li><i>Initial Strategy</i>: The prior probability that the player is going to play <i>HEADS</i> in the game</li>\n",
        "#@markdown </ul>\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown Please provide the URL of the Google Spreasheet that holds the data.\n",
        "game_data_url = '' #@param {type:\"string\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "game_data_df = importGameData(game_data_url)\n",
        "\n",
        "# After the parsing phase is complete we provide feedback to the user by visualising the imported information.\n",
        "\n",
        "color_registry = TeamColorRegistry()\n",
        "\n",
        "with plt.style.context('ggplot'):\n",
        "\n",
        "  fig, ax = plt.subplots(1, 1, figsize=(5, 3.5), dpi=100)\n",
        "\n",
        "  plotStrategySpace(ax, game_data_df, color_registry=color_registry)\n",
        "\n",
        "  plotStrategies(ax, game_data_df, color_registry=color_registry)\n",
        "\n",
        "  ax.set_xlim(-.05, 1.05)\n",
        "  legend_data = [\n",
        "    (Line2D([0], [0], color=color, lw=4), 'Team {team_idx}'.format(team_idx=team_idx)) \\\n",
        "      for team_idx, color in color_registry.registered_colors.items()]\n",
        "  ax.legend(*list(map(list, zip(*legend_data))))\n",
        "\n",
        "  ax.set_xlabel('Strategy Space')\n",
        "\n",
        "  fig.show()"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "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\n",
            "text/plain": [
              "<Figure size 500x350 with 1 Axes>"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "YmIete7aRGZ8",
        "outputId": "a040e8ca-672a-4c3f-dc37-3b7af5fd75fd"
      },
      "source": [
        "#@title ## Performing a Simulation\n",
        "\n",
        "#@markdown In order to perform a simulation you'll need to provide the following parameters. \n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown #### Simulation's Name\n",
        "\n",
        "#@markdown Please enter the name of this simulation. This is <b>required</b> if you intend to export the results of the simulation.\n",
        "simulation_name = 'Simulation' #@param {type:\"string\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown #### Team Labels\n",
        "\n",
        "#@markdown Please specify the identification labels of the two teams that are going to compete in the game.\n",
        "team_1 = '1' #@param {type:\"string\"}\n",
        "team_2 = '2' #@param {type:\"string\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown #### Simulation's Parameters\n",
        "\n",
        "#@markdown Please specify the simulation time and the number of discretized steps.\n",
        "sim_time =  100#@param {type:\"integer\"}\n",
        "disc_steps =   500#@param {type:\"integer\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown <i>Optional</i>: In order to export the results of this simulations please provide the URL of the Google Spreasheet where the results should be stored.\n",
        "flg_enable_export     = True #@param {type:\"boolean\"}\n",
        "simulation_output_url = '{game_data_url}' #@param {type:\"string\"} [\"{game_data_url}\"] {allow-input: true}\n",
        "flg_allow_overwrite   = True #@param [\"False\", \"True\"] {type:\"raw\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "assert isinstance(game_data_df, pd.DataFrame), 'ERROR! Failed to access game\\'s data. Please make sure that the game parameters have been specified.'\n",
        "\n",
        "if flg_enable_export:\n",
        "  assert simulation_name not in lst_RESERVED_WORKSHEETS, 'ERROR! Use of reserved name as simulation\\'s name. The output of this simulation won\\'t be stored in the spreadheet.'\n",
        "\n",
        "def initTeamVariables(team_data_df):\n",
        "  return team_data_df[c_INITIAL_STRATEGY].to_numpy(), team_data_df[c_STRATEGY_SPACE], team_data_df.index\n",
        "\n",
        "teams_gdf = game_data_df.groupby(c_TEAM)\n",
        "\n",
        "x, Sx, x_idx = initTeamVariables(teams_gdf.get_group(team_1))\n",
        "y, Sy, y_idx = initTeamVariables(teams_gdf.get_group(team_2))\n",
        "\n",
        "z = np.concatenate((x, y))\n",
        "\n",
        "import functools as ft\n",
        "\n",
        "class XOR():\n",
        "\n",
        "  def __init__(self):\n",
        "    pass\n",
        "\n",
        "  @staticmethod\n",
        "  def compute(x):\n",
        "    if len(x) == 0:\n",
        "      return 0\n",
        "    return ft.reduce(lambda x_1, x_2: x_2 + (1 - 2 * x_2) * x_1, x)\n",
        "\n",
        "  @staticmethod\n",
        "  def ode(t, x, n, S):\n",
        "    # TODO: We need to encode some more information about which bound was\n",
        "    #   reached and only filter the dyncamics if we continue to move outside the bound.\n",
        "    u = np.array([-1 / n] * n + [1 / (len(x) - n)] * (len(x) - n)) * 2 * x * (1 - x) * \\\n",
        "      np.product(1 - 2 * x) / (1 - 2 * x)\n",
        "    return (np.sign(u) * compareToStrategySpace(x, S) != 1) * u\n",
        "      \n",
        "  @staticmethod\n",
        "  def outSpace(x, S):\n",
        "\n",
        "    def outSpaceStep(i_1, i_2):\n",
        "\n",
        "      p = list(map(\n",
        "          lambda p: (XOR.compute([p[0][0], p[1][0]]), p[0][1] or p[1][1]),\n",
        "          it.product(*list(map(\n",
        "              lambda i: [(i.left, i.open_left), (i.right, i.open_right)],\n",
        "              (i_1, i_2))))))\n",
        "\n",
        "      left, open_left   = min(p)\n",
        "      right, open_right = max(p)\n",
        "      \n",
        "      if open_left and open_right:\n",
        "        closed = 'neither'\n",
        "      elif open_left:\n",
        "        closed = 'right'\n",
        "      elif open_right:\n",
        "        closed = 'left'\n",
        "      else:\n",
        "        closed = 'both'\n",
        "\n",
        "      return pd.Interval(left, right, closed)\n",
        "\n",
        "    return ft.reduce(outSpaceStep, filterStrategySpace(x, S))\n",
        "\n",
        "from scipy.integrate import odeint, solve_ivp\n",
        "\n",
        "out_space = (XOR.outSpace(x, Sx), XOR.outSpace(y, Sy))\n",
        "n = len(x)\n",
        "\n",
        "Z = solve_ivp(\n",
        "    XOR.ode, (0, sim_time), z,\n",
        "    method='Radau',\n",
        "    t_eval=np.linspace(0, sim_time, disc_steps),\n",
        "    args=(n, np.concatenate((\n",
        "        filterStrategySpace(x, Sx), \n",
        "        filterStrategySpace(y, Sy))))).y.T\n",
        "\n",
        "metrics = getMetricsDictionary()\n",
        "\n",
        "# We save the result in a <pd.DataFrame> in order to be use in visualization in\n",
        "#   the next step.\n",
        "simulation_output_headers = [c_STEP_ID, c_TEAM_X, c_TEAM_Y] + list(metrics.keys()) + \\\n",
        "    ['T1P{player_idx}'.format(player_idx=player_idx) for player_idx in x_idx] + \\\n",
        "    ['T2P{player_idx}'.format(player_idx=player_idx) for player_idx in y_idx]\n",
        "\n",
        "team_x      = np.apply_along_axis(XOR.compute, 1, Z[:, :n])\n",
        "team_y      = np.apply_along_axis(XOR.compute, 1, Z[:, n:])\n",
        "metrics_out = np.apply_along_axis(lambda z: [metric.compute(\n",
        "    z[:n], z[n:], x0=x, y0=y, Sx=Sx, Sy=Sy) for metric in metrics.values()], 1, Z)\n",
        "\n",
        "simulation_output_df = pd.DataFrame.from_records(\n",
        "    np.concatenate((team_x.reshape(-1, 1), team_y.reshape(-1, 1), metrics_out.reshape(-1, len(metrics)), Z), axis=1),\n",
        "    columns=simulation_output_headers[1:])\n",
        "\n",
        "if flg_enable_export:\n",
        "\n",
        "  # Since wea re going to save the results into a spreasheet we need to ask the\n",
        "  #   user for authorization.\n",
        "  auth.authenticate_user()\n",
        "  gc = gspread.authorize(GoogleCredentials.get_application_default())\n",
        "\n",
        "  simulation_output_ss = gc.open_by_url(getFromKeyword(simulation_output_url))\n",
        "\n",
        "  # In case of possible overwrite of data we act according to the provided policy.\n",
        "  flg_nosave = False\n",
        "  try:\n",
        "    simulation_output_ws = simulation_output_ss.worksheet(simulation_name)\n",
        "    if flg_allow_overwrite:\n",
        "      simulation_output_ss.del_worksheet(simulation_output_ws)\n",
        "    else:\n",
        "      print(\"Warning! Another simulation with the provided name was detected in the specified spreadsheet. Please change the simulation's name or enable data overwrites in the settings.\")\n",
        "      flg_nosave = True\n",
        "  except gspread.WorksheetNotFound:\n",
        "    pass\n",
        "  \n",
        "  if not flg_nosave:\n",
        "\n",
        "    # Exporting the simulation's results.\n",
        "\n",
        "    simulation_output_ws = simulation_output_ss.add_worksheet(\n",
        "        title=simulation_name,\n",
        "        rows='{row_number}'.format(row_number=disc_steps + 1),\n",
        "        cols='{column_number}'.format(column_number=len(simulation_output_headers)))\n",
        "\n",
        "    simulation_output_ws.update(\n",
        "        [simulation_output_headers] + \\\n",
        "        simulation_output_df.astype(str).reset_index().values.tolist())\n",
        "\n",
        "    # Exporting the simulation's informations in case we want to import the results for further processing.\n",
        "    try:\n",
        "      simulation_info_ws = simulation_output_ss.worksheet(ws_SIMULATION_INFO)\n",
        "    except gspread.WorksheetNotFound:\n",
        "      simulation_info_ws = simulation_output_ss.add_worksheet(\n",
        "          title=ws_SIMULATION_INFO,\n",
        "          rows='1', cols='6')\n",
        "      simulation_info_ws.update(\n",
        "          'A1:F1',\n",
        "          [[c_SIMULATION_NAME, c_TEAM_ID_1, c_TEAM_ID_2, c_STRATEGY_SPACE, c_SIMULATION_TIME, c_STEP_NUMBER]])\n",
        "\n",
        "    simulation_info_values  = simulation_info_ws.get_all_values()\n",
        "    simulation_info_headers = simulation_info_values[0]\n",
        "    simulation_info_records = []\n",
        "    if len(simulation_info_values) > 1:\n",
        "      simulation_info_records = simulation_info_values[1:]\n",
        "\n",
        "    simulation_info_df = pd.DataFrame.from_records(\n",
        "        simulation_info_records,\n",
        "        columns=simulation_info_headers,\n",
        "        index=c_SIMULATION_NAME)\n",
        "\n",
        "    simulation_info_new_record = [\n",
        "      simulation_name,\n",
        "      team_1, team_2,\n",
        "      ','.join(map(lambda i: str(i), out_space)),\n",
        "      sim_time, disc_steps]\n",
        "\n",
        "    if simulation_name in simulation_info_df.index:\n",
        "      simulation_info_df.loc[simulation_name] = simulation_info_new_record[1:]\n",
        "    else:\n",
        "      simulation_info_df = simulation_info_df.append(pd.DataFrame.from_records(\n",
        "        [simulation_info_new_record],\n",
        "        columns=simulation_info_headers,\n",
        "        index=simulation_info_df.index.name))\n",
        "\n",
        "    simulation_info_ws.update(\n",
        "        [simulation_info_headers] + \\\n",
        "        simulation_info_df.reset_index().values.tolist())\n",
        "  \n",
        "print('The simulation completed successfully.')"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "The simulation completed successfully.\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 717
        },
        "id": "i7FR6ovZ5FGO",
        "outputId": "6e4a114b-2290-4b50-8354-f8e20f5bfb7e"
      },
      "source": [
        "#@title ## Visualization\n",
        "\n",
        "#@markdown We can choose to visualize the results of a simulation.\n",
        "#@markdown This code block provides the neccessary functionality to sucha visual represntations of the <b>current results</b> or the results of a <b>previous</b> simulation.\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown #### Plotting Parameters\n",
        "\n",
        "#@markdown Please specify the metrics' bounds. Any value above or bellow will be treaded as positive and negative infinity, respectively.\n",
        "disp_metrics = \"x, y\" #@param {type:\"string\"} [\"None\", \"x, y\", \"KL\", \"Lyapunov\"]\n",
        "threshold_min_yrange =  1#@param {type:\"number\"}\n",
        "threshold_pinf = 10e+3 #@param {type:\"number\"}\n",
        "threshold_minf = -10e+3 #@param {type:\"number\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown #### Simulation\n",
        "\n",
        "#@markdown <i>Optional</i>: If you don't want to visualize the current results please specify the location ofthe game's data and the simulation's results.\n",
        "flg_prev_simulation = False #@param {type:\"boolean\"}\n",
        "if flg_prev_simulation:\n",
        "  simulation_name = 'Simulation' #@param {type:\"string\"}\n",
        "  game_data_url = '' #@param {type:\"string\"}\n",
        "  simulation_output_url = '{game_data_url}' #@param {type:\"string\"} [\"{game_data_url}\"] {allow-input: true}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown #### Animation Parameters\n",
        "\n",
        "#@markdown <i>Optional</i>: Please specify the number of skipped steps and the delay in milliseconds between subsequent frames.\n",
        "flg_create_anim = False #@param {type:\"boolean\"}\n",
        "frame_skip_rate =  1#@param {type:\"integer\"}\n",
        "frame_delay = 100 #@param {type:\"integer\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "#@markdown #### Animation Preview\n",
        "\n",
        "#@markdown <i>Optional</i>: Please specify whether you would like a preview of the animation.\n",
        "#@markdown It's advisable to <b>skip</b> this step if you intend to download the visual regardless in order to reduce the execution time. \n",
        "\n",
        "flg_enable_anim_preview = True #@param {type:\"boolean\"}\n",
        "embed_max_size = 50 #@param {type:\"integer\"}\n",
        "\n",
        "#@markdown The <i>embed_max_size</i> is measured in MB.\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "if flg_prev_simulation:\n",
        "\n",
        "  teams_gdf = importGameData(game_data_url).groupby(c_TEAM)\n",
        "\n",
        "  color_registry = TeamColorRegistry()\n",
        "\n",
        "  # In order to access the Google spreadhseet we require from the users to\n",
        "  #   authenticate their account.\n",
        "\n",
        "  auth.authenticate_user()\n",
        "  gc = gspread.authorize(GoogleCredentials.get_application_default())\n",
        "\n",
        "  simulation_output_ss = gc.open_by_url(getFromKeyword(simulation_output_url))\n",
        "\n",
        "  simulation_info_ws      = simulation_output_ss.worksheet(ws_SIMULATION_INFO)\n",
        "  simulation_info_values  = simulation_info_ws.get_all_values()\n",
        "  simulation_info_headers = simulation_info_values[0]\n",
        "  simulation_info_records = []\n",
        "  if len(simulation_info_values) > 1:\n",
        "    simulation_info_records = simulation_info_values[1:]\n",
        "\n",
        "  simulation_info_df = pd.DataFrame.from_records(\n",
        "      simulation_info_records,\n",
        "      columns=simulation_info_headers,\n",
        "      index=c_SIMULATION_NAME)\n",
        "\n",
        "  assert simulation_name in simulation_info_df.index, 'ERROR! The simulation with name \\'{simulation_name}\\' could not be found. Please make sure the the information you provided is correct.'.format(simulation_name=simulation_name)\n",
        "\n",
        "  simulation_info = simulation_info_df.loc[simulation_name]\n",
        "  team_1 = simulation_info[c_TEAM_ID_1]\n",
        "  team_2 = simulation_info[c_TEAM_ID_2]\n",
        "  out_space = list(map(constructInterval, re_INTERVAL_PATTERN.finditer(simulation_info[c_STRATEGY_SPACE])))\n",
        "  sim_time = float(simulation_info[c_SIMULATION_TIME])\n",
        "  disc_steps = int(simulation_info[c_STEP_NUMBER])\n",
        "\n",
        "  simulation_output_ws      = simulation_output_ss.worksheet(simulation_name)\n",
        "  simulation_output_values  = simulation_output_ws.get_all_values()\n",
        "  simulation_output_headers = simulation_output_values[0]\n",
        "  simulation_output_records = []\n",
        "  if len(simulation_output_values) > 1:\n",
        "    simulation_output_records = simulation_output_values[1:]\n",
        "\n",
        "  simulation_output_df = pd.DataFrame.from_records(\n",
        "      simulation_output_records,\n",
        "      columns=simulation_output_headers,\n",
        "      index=c_STEP_ID).astype(float)\n",
        "  simulation_output_df.index = simulation_output_df.index.astype(int)\n",
        "\n",
        "else:\n",
        "  assert all(map(lambda x: x is not None, [team_1, team_2])) or \\\n",
        "      all(map(lambda x: isinstance(x, pd.DataFrame), [teams_gdf, simulation_output_df])), \\\n",
        "      'ERROR! Failed to access game\\'s data and/or the current simulation\\'s output. Please make sure that a simulation has already been performed.'\n",
        "\n",
        "available_metrics = getMetricsDictionary()\n",
        "\n",
        "flg_xy_as_metric = False\n",
        "if disp_metrics == 'x, y':\n",
        "  flg_xy_as_metric = True\n",
        "elif disp_metrics == 'None':\n",
        "  metrics = {}\n",
        "else:\n",
        "  metrics = getMetricsDictionary(disp_metrics.split(', '))\n",
        "\n",
        "from matplotlib import animation, rc\n",
        "from IPython.display import display\n",
        "\n",
        "with plt.style.context('ggplot'):\n",
        "\n",
        "  fig = plt.figure(constrained_layout=True, figsize=(15, 7), dpi=100)\n",
        "  gs = fig.add_gridspec(9, 3)\n",
        "  _ = fig.add_subplot(gs[:-4, 0])\n",
        "  _ = fig.add_subplot(gs[:-4, 1])\n",
        "  _ = fig.add_subplot(gs[:-4, 2])\n",
        "  _ = fig.add_subplot(gs[-4:, :])\n",
        "  ax = fig.axes\n",
        "\n",
        "  plt.close()\n",
        "\n",
        "  def plotTeamStrategySpace(ax, team_id):\n",
        "\n",
        "    team_df = teams_gdf.get_group(team_id)\n",
        "\n",
        "    plotStrategySpace(ax, team_df, color_registry=color_registry)\n",
        "    _, plotted_points_df = plotStrategies(ax, team_df, color_registry=color_registry)\n",
        "\n",
        "    plotted_points_df.index = plotted_points_df.index.map(\n",
        "        lambda player_id: 'T{team_id}P{player_id}'.format(team_id=team_id, player_id=player_id))\n",
        "\n",
        "    ax.set_title('Strategy Space of Team {team_id}'.format(team_id=team_id), fontsize=11)\n",
        "    \n",
        "    return plotted_points_df\n",
        "\n",
        "  plotted_player_strategies_df = pd.concat((\n",
        "      plotTeamStrategySpace(ax[0], team_1),\n",
        "      plotTeamStrategySpace(ax[2], team_2)))\n",
        "  player_strategies_df = simulation_output_df\\\n",
        "    .drop([c_TEAM_X, c_TEAM_Y] + list(available_metrics.keys()), axis=1)\n",
        "  filtered_player_strategies_history = player_strategies_df.iloc[0::frame_skip_rate]\n",
        "\n",
        "  x_vec = simulation_output_df[c_TEAM_X].tolist()\n",
        "  y_vec = simulation_output_df[c_TEAM_Y].tolist()\n",
        "  plotted_strategy_profile_histroy = ax[1].plot([], [], lw=2, color='tab:red')[0]\n",
        "  plotted_strategy_profile = ax[1].plot([], [], 'o', color='tab:red', markersize=7)[0]\n",
        "\n",
        "  def plotMetrics(metrics):\n",
        "\n",
        "    plotted_metrics = []\n",
        "\n",
        "    def initMetric(metric):\n",
        "\n",
        "      metric_vec = []\n",
        "      for x in simulation_output_df[metric.name]:\n",
        "\n",
        "        x = x if x < threshold_pinf and x > threshold_minf else np.nan\n",
        "        metric_vec.append(x)\n",
        "\n",
        "      return metric_vec\n",
        "\n",
        "    y_min, y_max, flg_threshold_min_yrange = np.PINF, np.NINF, False\n",
        "    if flg_xy_as_metric:\n",
        "      plotted_metrics.extend(ax[3].plot(player_strategies_df, lw=1))\n",
        "    else:\n",
        "\n",
        "      for metric in metrics:\n",
        "        metric_vec = initMetric(metric)\n",
        "\n",
        "        for y in metric_vec:\n",
        "          y_min = min(y_min, y)\n",
        "          y_max = max(y_max, y)\n",
        "\n",
        "        plotted_metrics.extend(ax[3].plot(metric_vec, lw=1))\n",
        "      \n",
        "      if y_min is not np.PINF:\n",
        "        flg_threshold_min_yrange = (threshold_min_yrange > y_max - y_min)\n",
        "        if flg_threshold_min_yrange:\n",
        "          y_max = (y_max + y_min + threshold_min_yrange) / 2\n",
        "          y_min =  y_max - threshold_min_yrange\n",
        "      \n",
        "    return plotted_metrics, y_min, y_max, flg_threshold_min_yrange\n",
        "    \n",
        "  plotted_metrics, y_min, y_max, flg_threshold_min_yrange = plotMetrics(metrics.values())\n",
        "  plotted_time = ax[3].plot([], [], lw=2, color='tab:red', alpha=.5)[0]\n",
        "  artists = plotted_player_strategies_df.tolist() + \\\n",
        "    [plotted_strategy_profile_histroy, plotted_strategy_profile, plotted_time]\n",
        "\n",
        "  def init():\n",
        "    return artists\n",
        "\n",
        "  def animate(row):\n",
        "\n",
        "    step, record = row\n",
        "    \n",
        "    plotted_strategy_profile_histroy.set_data(x_vec[:step + 1], y_vec[:step + 1])\n",
        "    plotted_strategy_profile.set_data(x_vec[step], y_vec[step])\n",
        "    plotted_time.set_data([step, step], ax[3].get_ylim())\n",
        "\n",
        "    for player_id, player_x in record.iteritems():\n",
        "      plotted_player_strategies_df.loc[player_id].set_data(player_x, player_id)\n",
        "      \n",
        "    return artists\n",
        "\n",
        "  ax[0].set_xlim((-.05, 1.05))\n",
        "  ax[0].set_ylim((np.array(ax[0].get_ylim()) + np.array([-1, 1])))\n",
        "  ax[2].set_xlim((-.05, 1.05))\n",
        "  ax[2].set_ylim((np.array(ax[2].get_ylim()) + np.array([-1, 1])))\n",
        "\n",
        "  team_color_1 = color_registry.getTeamColor(team_1)\n",
        "  team_color_2 = color_registry.getTeamColor(team_2)\n",
        "\n",
        "  ax[1].set_xlim((-.05, 1.05))\n",
        "  ax[1].set_ylim((-.05, 1.05))\n",
        "  ax[1].set_title('Game History')\n",
        "  ax[1].set_xlabel('Team 1')\n",
        "  ax[1].set_ylabel('Team 2')\n",
        "  ax[1].xaxis.label.set_color(team_color_1)\n",
        "  ax[1].yaxis.label.set_color(team_color_2)\n",
        "  ax[1].spines['bottom'].set_color(team_color_1)\n",
        "  ax[1].spines['top'].set_color(team_color_1)\n",
        "  ax[1].spines['left'].set_color(team_color_2)\n",
        "  ax[1].spines['right'].set_color(team_color_2)\n",
        "  ax[1].tick_params(axis='x', colors=team_color_1)\n",
        "  ax[1].tick_params(axis='y', colors=team_color_2)\n",
        "\n",
        "  xx=out_space[0]\n",
        "  yy=out_space[1]\n",
        "  ax[1].fill(\n",
        "      [0, 0, 1, 1, 0, xx.left, xx.right, xx.right, xx.left, xx.left],\n",
        "      [0, 1, 1, 0, 0, yy.left, yy.left, yy.right, yy.right, yy.left],\n",
        "      linewidth=0, color='tab:red', alpha=.25)\n",
        "  ax[1].plot(\n",
        "      [xx.left] *2, [yy.left, yy.right], \n",
        "      lw=1, linestyle='solid' if xx.open_left else 'dashed',\n",
        "      color='tab:red', alpha=.5)\n",
        "  ax[1].plot(\n",
        "      [xx.right] *2, [yy.left, yy.right], \n",
        "      lw=1, linestyle='solid' if xx.open_right else 'dashed',\n",
        "      color='tab:red', alpha=.5)\n",
        "  ax[1].plot(\n",
        "      [xx.left, xx.right], [yy.left] *2,\n",
        "      lw=1, linestyle='solid' if yy.open_left else 'dashed',\n",
        "      color='tab:red', alpha=.5)\n",
        "  ax[1].plot(\n",
        "      [xx.left, xx.right], [yy.right] *2,\n",
        "      lw=1, linestyle='solid' if yy.open_right else 'dashed',\n",
        "      color='tab:red', alpha=.5)\n",
        "  xaxis_top = ax[1].secondary_xaxis('top')\n",
        "  xaxis_top.set_xticks([xx.left, xx.right])\n",
        "  xaxis_top.tick_params(axis='x', colors=team_color_1)\n",
        "  yaxis_left = ax[1].secondary_yaxis('right')\n",
        "  yaxis_left.set_yticks([yy.left, yy.right])\n",
        "  yaxis_left.tick_params(axis='y', colors=team_color_2)\n",
        "\n",
        "  ax[3].set_xlim(0, disc_steps + 1)\n",
        "  if flg_threshold_min_yrange:\n",
        "    ax[3].set_ylim(y_min, y_max)\n",
        "  ax[3].tick_params(axis='x', direction='in', pad=-15)\n",
        "  ax[3].set_xlabel('Step', fontsize = 9)\n",
        "  ax[3].xaxis.set_label_coords(1.020,-.09)\n",
        "  ax[3].spines['bottom'].set_position(('axes', -.2))\n",
        "  ax[3].spines['bottom'].set_color('black')\n",
        "  xaxis_time = ax[3].secondary_xaxis(-.2, functions=(\n",
        "      lambda i: i * sim_time / disc_steps,\n",
        "      lambda t: t * disc_steps / sim_time\n",
        "  ))\n",
        "  xaxis_time.spines['bottom'].set_color('black')\n",
        "  xaxis_time.set_xlabel('Time', fontsize=9)\n",
        "  xaxis_time.xaxis.set_label_coords(1.021, -.25, transform=ax[3].transAxes)\n",
        "\n",
        "  if flg_xy_as_metric:\n",
        "    f_legend = ax[3].legend(\n",
        "        plotted_metrics,\n",
        "        player_strategies_df.columns,\n",
        "        loc = 'upper right')\n",
        "  else:\n",
        "    f_legend = ax[3].legend(\n",
        "        plotted_metrics,\n",
        "        map(lambda metric: metric.description, metrics.values()),\n",
        "        loc = 'upper right')\n",
        "\n",
        "  _ = animate([\n",
        "      simulation_output_df.shape[0] - 1,\n",
        "      simulation_output_df.iloc[-1].drop([c_TEAM_X, c_TEAM_Y] + list(available_metrics.keys()))])\n",
        "  sim_img_file_path = '{simulation_name}.png'.format(simulation_name=simulation_name)\n",
        "  fig.savefig(sim_img_file_path)\n",
        "\n",
        "  if flg_create_anim:\n",
        "    anim = animation.FuncAnimation(\n",
        "      fig, animate, init_func=init,\n",
        "      frames=list(filtered_player_strategies_history.iterrows()),\n",
        "      interval=frame_delay, repeat=False, blit=True)\n",
        "\n",
        "  html_code = \"\"\n",
        "  if flg_create_anim and flg_enable_anim_preview:\n",
        "\n",
        "    rc('animation', embed_limit=embed_max_size)\n",
        "    \n",
        "    from IPython.display import HTML\n",
        "    display(HTML(anim.to_jshtml()))\n",
        "\n",
        "  else:\n",
        "    \n",
        "    from IPython.display import Image\n",
        "    display(Image(sim_img_file_path))\n",
        "    \n",
        "  \n"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "image/png": "iVBORw0KGgoAAAANSUhEUgAABdwAAAK8CAYAAAD1Zn2wAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOzdd3zT1f7H8fc3adIJHdBCGbJREBmKeFFARCooToaigCBX3AsHLlSGolyvP0EuekFUVMCB4kBUQJYIeEWlKshQ9ihQKAVKV8b5/VFbCU1LCykp7ev5ePQh+Y6TTz6JJzmfnJyvZYwxAgAAAAAAAAAAJ8UW7AAAAAAAAAAAAKgIKLgDAAAAAAAAABAAFNwBAAAAAAAAAAgACu4AAABABdK5c2dZlhXsMAAAAIBKiYI7AAAAyp0NGzbowQcf1Lnnnqu4uDg5HA7FxcXpggsu0MMPP6yffvop2CGWqfyi+eLFi4s8ZtCgQbIsS1OnTg3ofdevX1/169cPaJsAAABAZUHBHQAAAOWGMUYjR45Us2bN9PLLL8uyLN1www0aNmyY+vfvr/DwcE2YMEFt27bVxIkTgx1uufTOO+9o7dq1wQ4DAAAAqJRCgh0AAAAAkG/UqFEaMWKE6tatq/fee08XXXRRoWP27t2rcePG6eDBg0GIsPw744wzgh0CAAAAUGkxwx0AAADlwqZNm/Tss8/K6XTqq6++8ltsl6SEhASNGTNGw4YN89m+YcMGPfbYY2rbtq3i4+MVGhqqevXq6bbbbtOOHTsKtbN48WJZlqURI0boxx9/VPfu3RUdHa3Y2Fj16tVL27dvL4irb9++io+PV3h4uC655BL98ssvfmPLzMzU888/r9atWysyMlJRUVFq37693nvvvZPMTsn5W8PdGKO3335bF154oeLj4xUWFqa6deuqW7du+uCDDyT9nY+tW7dq69atsiyr4G/QoEE+7S1YsEDdu3dXXFycQkND1bRpUz322GN+vwTJjyc3N1ejRo3SmWeeqdDQUA0aNEiTJk2SZVkaOXKk38eye/duORwOnXPOOYFJDgAAAFDGKLgDAACgXHjrrbfkdrvVu3dvnX322cc9PiTE98eas2bN0n//+1/VrVtXN954o+699141b95cU6ZM0fnnn6+dO3f6bWflypXq2LGjJGnIkCFq166dZs2apa5du2rdunVq166dduzYoZtvvlk9evTQkiVLlJSUpIyMDJ920tPT1aFDBz3xxBOy2+0aPHiwBg4cqNTUVN10000aPnz4CWbm5D355JMaNGiQdu/ereuvv14PPvigunbtqp07d2rmzJmS8tZuf+aZZxQdHa3o6Gg988wzBX/XXnttQVuTJk1SUlKSli1bpmuvvVZDhw5VXFycxo4dqwsvvFDp6el+Y+jVq5deffVVXXjhhXrggQd0zjnnqF+/fqpatareeOMNeTyeQue8+eabcrvduv3228smMQAAAECAsaQMAAAAyoVly5ZJkrp06XJC5w8YMEBDhw5VaGioz/Z58+bp8ssv17PPPqvXXnut0Hlffvmlpk2bpn79+hVs++c//6k333xTF154oR566CE9+eSTBftGjx6tp59+Wm+88Ybuv//+gu0PPPCAVq1apbFjx/rMvs/Ozta1116rMWPGqHfv3mrdunWJH9PUqVOLvHBqcnJyiduZNGmSateurdWrVysiIsJn3759+yTlFdxHjBhRcBHWESNGFGpn69atuu+++xQVFaUffvhBZ511VsG+u+66S6+99pqGDRumyZMn+z139erVql69us/2AQMGaOLEifrqq6905ZVXFmw3xmjKlCmKiIjQgAEDSvxYAQAAgGCi4A4AAIByYffu3ZKk2rVrF9q3ZcuWgkJwvpiYGD3wwAMFt/2dJ0mXXXaZzj77bM2dO9fv/g4dOvgU2yVp4MCBevPNNxUdHa3HHnvMZ9/NN9+sp59+2qfgvX//fk2bNk1t27YttNRNWFiYxo4dq7lz52rGjBmlKri//fbbJT72eBwOh+x2e6HtxxbAizNt2jTl5ubqoYce8im2S9Jzzz2nadOm6d1339WECRMKffExevRov/d15513auLEiZo0aZJPwX3evHnavHmzbrnlFkVHR5c4RgAAACCYKLgDAACg3NuyZUuhdb7r1avnU3A3xmj69OmaOnWqfvnlFx04cMBnmRKn0+m37bZt2xbaVqtWLUlS69atCxWp8wv7R68Lv3LlSnk8noI14Y/lcrkkSWvXri3uYRayaNEide7c2e++QYMGlbgg369fP02YMEHNmzfX9ddfr4svvljt27cvdSH7559/luT/VwixsbFq06aNvv32W61bt06tWrXy2d+uXTu/bZ599tnq1KmTvvrqK23f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6enpGjlypFq0aKHmzZsHrN1AcLvd6tKli9LT0/X444/rrLPO0u7du7Vs2TLNnj1bDzzwQLBDLBPvvPOO3n33Xb399ttq1KiR6tevX+iYFStW+Nxu37697r33Xt10000F2xo1alTWoZ6QSZMmqVGjRuratas+/vjjYIcDnBZy3V6t3nlQd3X++/9rm83SRY2r6+et6UGMDAAAoHxinO0f4+yKN86eP3++li5dqttvv12tWrXS1q1b9fTTT2vx4sVKTk5WaGhosENEJUbBHUHzyiuvaNCgQXrppZcKtl1++eV65JFH5PV6S91eTk6OHA6HbLbT+4cbixcv1q+//qolS5aoU6dOBdv79u17Qnk5Xaxbt061atVSv379ijzmH//4R6FtZ5xxht/t5c22bdtks9m0ePFiCu5ACR3IzJXHa1Q9yvfDcnxUqDamHglSVAAAAOUX42z/GGdXvHH2jTfeqLvvvluWZRVsa9KkiS666CJ98cUX6tWrVxCjQ2V3eveYOK0dOHBAiYmJfvflv5nXr19fW7du1cSJEwv9lKl+/fq655579K9//Uv16tVTeHi40tLStG7dOvXt21d169ZVRESEmjdvrpdeeqngTXTLli1q0KCBJKlPnz4F7W7ZskVS3geKJ554QvXq1VNoaKiaNWumGTNmFIpx0qRJqlevniIiIpSUlKRVq1b5xPfQQw/pjDPOKPTm/dVXX8myrCJ/ZnfgwAFJ8puboz/kLF68WJZl6csvv1TPnj0VGRmpxMREjRkzxuec4+UjX05OjoYPH66GDRsqNDRUderU0aBBg3yOWbFihbp06aLIyEhFR0frpptu8vlZYlG2bt2q3r17Kzo6WpGRkerWrZt+++23gv3169fXSy+9pO3btxd6Pkpr6tSpatmypcLCwlS7dm09+eST8ng8BftTUlI0ePBgNWzYUOHh4WrSpImeeOIJ5eT4rgdtWZbGjh2rJ598UgkJCYqJidGwYcNkjNGCBQvUunVrRUVF6dJLL9X27cdf2uJ0/4AKAAAAoPxjnM04O19FH2dXq1bNp9guSW3atJEk7dq164QeJxAwBgiSjh07mri4OPP666+blJQUv8f8/PPPpmbNmqZ3795mxYoVZsWKFWbv3r3GGGPq1atnatasaTp27Gg++eQT8/nnn5vMzEzzzTffmKefftp8/vnnZtGiRebll182VatWNSNGjDDGGJOdnW1mzZplJJkxY8YUtJudnW2MMebqq682cXFxZvz48WbevHnmgQceMJZlmS+//LIgrs8++8xIMrfeeqv5+uuvzQsvvGAaN25sJJm33nrLGGPM77//biSZr7/+2ucx9e7d2/zjH/8oMi8bNmwwNpvNdOrUySxYsKAgrmMtWrTISDK1a9c2Dz/8sPn666/Nww8/bCSZ1157reC44+UjX48ePUx4eLgZPXq0mT9/vpkxY4bp3bt3wf7ly5cbp9Nprr32WjN79mzz/vvvm8aNGxf7WIwx5tChQ6Z+/fqmYcOGZsaMGWbWrFnmvPPOMzExMWbbtm0Fz/MNN9xgatasWej5KI4k8+KLLxbcfumll4zdbjcPP/ywmTdvnhk/fryJiooyjz76aMExv/76q3nooYfMJ598YhYvXmwmT55satWqZQYNGlSo7Tp16pj+/fubr7/+2owcOdJIMg8++KA555xzzPvvv29mzZpl6tSpY5KSko4ba778523lypUlPgeorHJcHtPw8Tnm69W+7xFDP1hl/jmV/4cAoKKp9+gXhfp8AKXDONs/xtkVe5ydb968eUaSmT9/fqnPBQKJgjuC5rfffit485RkGjRoYO677z6zefNmn+Pq1atn7r777kLn16tXz1SrVs1kZGQUeR9er9e4XC7z3HPPmcTExILtmzdvNpLMzJkzfY5fuHChkWTmzp3rs/2GG24w559/fsHt888/33Tp0sXnmNGjR/t8EDDGmA4dOpjrr7++4Pa+ffuM0+k0kydPLjJmY4wZN26ccTqdRpJxOBymQ4cO5pVXXjEul6vgmPwPAgMGDPA5d8CAAaZ27drG4/GUOB/5b0ozZswoMqZOnTqZCy+80Hi93oJta9asMZZlmTlz5hR53vjx441lWeb3338v2LZ//34TGRlpHnzwwYJt999/v6lXr16R7fhz9AeBQ4cOmaioKPP444/7HPPaa6+Z8PBws2/fPr9tuFwuM336dBMSEmKOHDni03a7du18jj3vvPMKPZYJEyYYSebAgQMlipmCO1A6V//nO/P0p78V3PZ4vOaC574xExf9EcSoAABlgYI7cPIYZxeNcXbJnI7jbGOMycrKMi1btjRt2rTxyScQDKxxgKBp0aKF1qxZozlz5uj+++9XdHS0XnnlFbVs2VLJycklaqNz586KjIz02Zadna1nnnlGjRs3VmhoqBwOh5588kmlpKQoIyOj2PbmzZunuLg4denSRW63u+Av/6dsHo9HHo9Hq1at0tVXX+1z7jXXXFOovSFDhuizzz5TWlqapLyrxTscDvXt27fYOO6//35t3bpVkyZNUp8+fbRhwwbdd9996tq1a6GfqF133XU+t3v37q2dO3dqx44dJc7HggULFBERUWRcmZmZWrZsmfr06SOPx1OQl6ZNm6pu3bpauXJlkY9l6dKlatGihZo1a1awLS4uTklJSfruu++KzUNpLF++XBkZGerTp4/Pc9e1a1dlZWVp9erVkiRjjMaNG6fmzZsrPDxcDodD/fr1k9vt1qZNm3zaTEpK8rndtGlT1apVy+exNG3aVJIK8g0gsG7t0EDvrdyuj37aoT/3HtaTn65WZq5bfc6rG+zQAAABcCTHrTW7DmrNroOSpO1pmVqz66B2pmcFOTLg9MQ4u2iMs0vvdBpn33HHHdq8ebPeeeedQkvNAKcaBXcEldPp1BVXXKFx48Zp1apV+vrrr5WZmalRo0aV6PwaNWoU2vboo4/qxRdf1JAhQ/Tll19q5cqVGj58uKS8N8Xi7Nu3T2lpaXI4HD5/t956q9xut1JSUpSamiq32634+Hifc/Ov9n60Pn36KDw8XNOmTZMkvfXWW+rdu7eqVKly3MdWs2ZN3XbbbZo+fbp27NihW265RUuWLNEXX3xR7P3m5yQlJaXE+di/f78SExOLfFM6cOCAPB6Phg4dWig327ZtK3ZttQMHDvh9nmrUqFHwASkQ9u3bJ0k699xzfeJr0qSJJBXEOG7cOD300EO65ppr9Nlnn+mHH37QxIkTJRV+fcTExPjcdjqdfrf5OxdAYFzVqpaevKKZXp6/QVeM/06/pxzS24PbKb5K6PFPBgCUe7/uOKger3ynHq/kFYienbNWPV75Tv83b0OQIwNOX4yzi8Y4u3ROl3H28OHDNX36dM2cOVMtWrQo5aMEAi8k2AEAR+vWrZtatWqltWvXluh4f29cM2fO1O23365HH320YNucOXNK1F5cXJzi4+P15Zdf+t2fkJAgu92ukJAQpaam+uzzd1GT8PBw9evXT2+99ZY6dOig5ORkvfLKKyWK5WgOh0NDhw7VW2+9pbVr1/p863/s/e7Zs0fS3xeDKUk+qlWrppSUFBlj/OY0JiZGlmXpiSee0LXXXltof/Xq1YuMPS4uTuvXry+0fc+ePYqLiyvyvNLKb2vWrFmqW7fwzNf8C/jMnDlTV199tZ5//vmCfUVdWAdA+TDwwvoaeGH9YIcBACgD7RtV05YXegQ7DKBCY5ztH+Ps4zsdxtkTJkzQmDFjNHXqVHXr1u2U3CdwPMxwR9Dkv2EdLSsrS9u3b1fNmjULtjmdzlLNHs7Kyir4NlSSPB6P3n//fZ9jivq2tGvXrkpNTZXT6VTbtm0L/TmdTtntdrVp00afffaZz7mffvqp33iGDBmi5ORkDR06VE2aNFHHjh2LjT8tLU1ut7vQ9g0b8mb5HJ0bSfrkk098bn/00UeqVauW6tSpI6lk+ejatasyMzP14Ycf+o0pMjJS7du319q1a/3mpX79+kU+ng4dOui3337z+TBw4MABffPNN+rQoUOR55VW+/btFRERoR07dviNsVq1apIK50PK+wkiAAAAAJzuGGf7xzj7xJT3cfZ7772n+++/X88//7xuvvnmMr8/oKSY4Y6gOeecc3TVVVepW7duSkxM1M6dO/Wf//xH+/bt0/33319wXLNmzbRw4ULNnz9fsbGxatCgQUGn7k9SUpJef/11NW/eXNWrV9err76qnJwcn2Nq1qypmJgYvffee2rQoIFCQ0PVsmVLJSUl6aqrrlL37t01bNgwtWzZUkeOHNGaNWv0559/asqUKZLyfq50zTXXaMiQIerTp49WrVqlt99+W5Jks/l+j9WqVSudf/75+vbbb32+7S3KwoUL9eijj2rQoEFq166dHA6HVq1apeeff15nnHFGobXkFi5cqEceeURJSUmaP3++3n33XU2cOLEgjpLko2vXrrriiis0ePBgbdy4URdccIHS0tL00Ucf6YMPPpAkvfjii+rSpYtuuOEG9e3bV7GxsdqxY4fmz5+vW265RZ07d/b7eG655Ra9/PLL6tGjh5599lmFhYXpueeeU0hIiB544IHj5qOkYmJiNGrUKA0bNkw7duxQ586dZbfbtWnTJn322Wf6+OOPFRERoaSkJI0fP17/+c9/1LRpU02bNk1//vlnwOIoypIlS5Samqo1a9ZIynvetmzZovr166tt27Zlfv8AAAAAKj7G2f4xzj4x5XmcvWTJEg0cOFBdunTRxRdfrO+//75gX506dQq+HAGCIrjXbEVlNnHiRNO9e3dTu3Zt43Q6Ta1atUz37t3NwoULfY5bvXq16dixo6lSpYrP1cmLuqr67t27zbXXXmuqVKliatSoYR599FHz+uuvG0kmNTW14LhPPvnENGvWzISGhhpJBVdtz8nJMSNHjjRNmjQxTqfTxMfHm0suucS88847Pvfz2muvmbp165qwsDBz8cUXF1yB/NNPPy0U05gxY4zdbje7du06bl62bdtmhg0bZs4991wTGxtrwsPDTdOmTc19993nc37+1dO/+OILc/XVV5uIiAhTo0YNM3r06BPKR1ZWlnnsscfMGWecYRwOh6lTp44ZPHiwT1srV640V1xxhYmOjjbh4eGmSZMm5o477jDbt28v9jFt2bLF9OzZ01SpUsVERESYpKQk8+uvv/occ7JXT8/33nvvmfPPP9+Eh4ebqlWrmjZt2pinnnqq4Mrzhw8fNoMGDTKxsbEmNjbWDBkyxMyePdtIMitXriy27YEDB5qzzz7bZ1v+83D0uf5cfPHFRlKhv4EDB5bqMQMAAABAURhn+8c4u+ROl3H2M88843eMLck888wzpXrMQKBZxhhzCur6QIX3xhtv6NZbb9XmzZsL/fSrU6dOio6O1uzZswN2f4sXL9Yll1yilStXMkMaAAAAAFDhMM4GcDpiSRngBKSlpWnkyJHq0qWLqlSpopUrV+q5557TNddc4/Mh4Mcff9TSpUu1dOlSzZ8/P3gBAwAAAABQjjHOBlBRUHAHToDD4dDGjRs1Y8YMpaenKz4+XgMGDNDYsWN9jjv//PMVHR2tp556Sl27dg1StAAAAAAAlG+MswFUFCwpAwAAyr0ct0evLtqouy5ppNAQe7DDAQAEGP08AACoKGzHPwQAACC4ct1ejV/wh3Ld3mCHAgAoA/TzAACgoqDgDgAAAAAAAABAAFBwBwAAAAAAAAAgALhoKgAAKBNZGYe18c+1Ukw9yRF2cm3lutWweqTWpRxSuJOPLwBQ0QS0n3dlS+lb1ahxM4VHVQlMgAAAACXERVMBAECZWJ38g658PzXYYQAAKqkv+sarRet2wQ4DAABUMhVmitiBAwfkdrtPqo34+HilplIYKCnyVTrkq+TIVemQr5ILVK5CQkIUGxsbgIgqtkaxIfrC+YQOJf2fPLGNTqoty7IUExOj9PR0MVfg+MhXyZGr0iFfJUeuSieQ+XIc3KKouferUexbAYqu8grEOFvi82ppka+SI1elQ75KjlyVDmNtXxWm4O52u+VyuU74fMuyCtrhA/Hxka/SIV8lR65Kh3yVHLk69cIdNrWwbVFqtFeuOOdJtWVZlhITo5Viy+T5KwHyVXLkqnTIV8mRq9IJZL7CbUaxti2Sg0uWnayTHWdLfAYrLfJVcuSqdMhXyZGr0iFfhfEJBAAAAAAAAACAAKDgDgAAAAAAAABAAFBwBwAAAAAAAAAgACi4AwAAAAAAAAAQABTcAQAAAAAAAAAIAAruAAAAAAAAAAAEAAV3AAAAAAAAAAACgII7AAAAAAAAAAABQMEdAAAAAAAAAIAACAl2AC/i5ScAACAASURBVAAA4BTYskxa/oq0K1nK2C3dMF1qdmXx52xeKs19QkpdJ1WtLXV6RGrT79TECwDAqXIi75EAAABFYIY7AACVgStTqtFC6vHvkh1/YIs043qpQSfpju+kf9wlfX6v9Oc3ZRomAACnXGnfIwEAAIrBDHcAACqDJkl5fyX145tSTD2p23N5t+PPlLatkFa8KjXuWjYxAgAQDKV9jwQAACgGM9wBAEBh21dKDTv7bmt8qbRjZTCiAQAAAADgtMAMdwAAUFjGHikq3ndbZIKUc0hyZUmO8MLnuHPy/vLlHvnrH5YsyzqpcCzLkifjiExamowxf+9wOmWrUkXG45FJTy90nq1aNUmS9+BBye32bTMqSlZoqExWlkxmpu+JISGyRUfLeL0yBw4UjicmRpbdLu+hQ5LL5bsvIkJWeLhMTo5MRobviXa7bDExeTHt31+43ehoWSEh8mZkSDk5vvvCwmRFRsrk5socPnxsgmSLi8trNy1NkuSy2wvyZVWpIsvplDlyRCY72/fc0FDZoqJk3G6ZgwcLxVSQw/R0yePxvdvicuhwyFa1apHPjRUbK8tm8//cFJfDv54bqYgc5j83hw9Lubm++8LDZUVE+ObQsvJylZ4uK/+5SUuTjn6dSbKqVpXlcPjNoRUaKquoHB793PjLYf5z4y+Hx3l9W3FxsizLfw4jI2WFhclkZ8scOeJ7Yv7r2xiZv14vPucWl8OIyLx/5LpkDh/yPfHo17e/HP71+jYZGTJFvb5dLplDx7R7dA4PHJC8Xt/d+TnMzJTJyvI9N5h9REiIPOnphfqtctFHHPvclIc+wrLkqVL1pN8v/rrnvP+4sqTso15PIaF5fwAAAGWIgjsAAAiMpf8nLXmh0Ob46tWlxMSTatqTcUTpH30k+/79sjmdBdtDz2yqqpddJk96utI++bTwfd97jyTpwHffyb17j8++KpclKax+fWX9+qsylnzrs895Rl1FX3ONvLm52j/rk0LtVvvnYNkiInTwp5+Vu3mzz77IDhcpomFD5fzxhw4tWuyzLyQ+XrF9b5AkpX7yieTxLRzG3nSjQqpV0+GFC5W95neffRHnnavICy9U7o6dOnhMu7aoKFW7ZZAkaf/Xc+XNyFC6JMdf+6Ovu07OxEQdWb5cmT/97HNu2NnNVaVLF7n379eBTz/zfaB2m+LvukuSdGDJt3Knpvrsrtq9m0Lr11fmqlU68t0yn33OBg0UfWUPeTMztd/Pc1Pt9ttkczp18IcflLttu8++qIs7KbxhQ2WvX6/Dx+awZg3F9ukjSUr96ONC7cYN6C97TIwO/fabctZv8NkX0a6dIi9opNytW31ymC4pLDpacTcPkCTtnzNH3izfomNM715yJCYqY+l3ykpO9tkXdk4LVencWa69e5V+TLyW06nqt98mSUpbuFCeNN/ibNUePRSamKjMH3/UkRXf++wLbdxIVS+/XJ6MDL+v7+p33iErJETpK76Xa+dOn31RXS5ReIMGylqzRhnHxOSoXVsxPa+Tcbu17+NZhdqNu2WQ7FFROpScrJw/N/rsi2z/D6lhA8V5PIVe3/a4WMX1y7uw8r7PZ8scU6yPueF6ORISdHjxYmX/ttpnX3jr1orq2EGulJRCObSFh6narbdKktLmfyPPMUXf6Kuvynt9/+8HZf7wg8++oPcRX8yRo5z2EUcrD32ENzdX6dWqKb53b9mjInVSzF/P5ex7pX1//L394sekSx4/ubYBAACOwzLmmOkNp6nU1FS5jplhVhqWZSkxMVEpKSmqICkpU+SrdMhXyZGr0iFfJRfIXDkcDsXHxx//wPJqRLR0w3Sp2ZVFH/Pm5VJiK+nyowroq6ZJXz8uPb7d/znHznDf/Zs09Qql9vxY7vizTypkk5Ym+9dz5bqgXcEsZEnMcC/Y6Tt71ZIUHx+v1NRUZrgfvc/PDHfLsvJytX8/M9zzzy0mh7aISCU2bKCUrdvkZYZ7sX2ELSRE8WFh2rNzJzPcS9BHmPR0Of73gzzdu8n6K9YTFXZgvWI/vEa65WupxlHvPyWZ4V6S98hK5GTH2RKfV0uLfJUcuSod8lVy5Kp0GGsXxgx3AABQWN3zpT/m+27buEiqc37R5xxbyHDmz1A0J/3Byxgjm9OZVwg8phBjjJFsNr8Fmvz7tapWLbJdhYXJCgvzv8+yiiz85Beyi2zX6Sw+puLajYyUIgvP8DTGSA5H8e3GxsqyLDkSEmR5PAWFNWOMFBEhKyLC/7l2e/Ht/lXk9ru/uBwW8dwUPNbinpuTyWFUVNHtHpXDo3N1dA6LPPd0y2FoqKzQwgXGE85h/nIfzuO/DouMKTIy7zXub19ISPHtHv2F27H7w8NlhRde7iqYfYQ9JkZWVlahAnew+4ii2g3269vmdMptTKF8ld5f5zvCpTD/zy0AAEBZ4aKpAABUBjkZUsqveX+SlL4179/pf81W/2aENOv2v49vO1g6sEWa95SUukH64XVpzSdS+7tOdeQAAJSt471HAgAAlAIz3AEAqAx2rZLePurn8XOfyPtvq5uk616TDu+RDu74e39sfemmD6W5j0v/+69UtZZ09QSpcddTGnY+q0oVRV93nfZ53Mc/GABw2glqP3+890gAAIBSoOAOAEBl0KCjNKLw2rsF/BUUGnSU7viu7GIqBcvplDMxURbrKAJAhRTUfv5475EAAAClwJIyAACg3DNHjujI8uWFL/4IAKgQ6OcBAEBFQcEdAACUeyY7W5k//SyTnR3sUAAAZYB+HgAAVBQU3AEAAAAAAAAACAAK7gAAAAAAAAAABAAFdwAAAAAAAAAAAoCCOwAAKP9CQxV2dnMpNDTYkQAAygL9PAAAqCAouAMAgHLPFhWlKl26yBYVFexQAABlgH4eAABUFBTcAQBAuWfcbrn375dxu4MdCgCgDNDPAwCAioKCOwAAKPfMwYM6MOM9mYMHgx0KAKAM0M8DAICKgoI7AAAAAAAAAAABQMEdAAAAAAAAAIAAoOAOAAAAAAAAAEAAUHAHAACnBzsfWwCgQqOfBwAAFQCfaAAAQLlnq1ZN8XfdJVu1asEOBQBQBujnAQBARUHBHQAAAAAAAACAAKDgDgAAyj1veroOvP+BvOnpwQ4FAFAG6OcBAEBFQcEdAACUfx6P3KmpkscT7EgAAGWBfh4AAFQQFNwBAAAAAAAAAAgACu4AAAAAAAAAAAQABXcAAAAAAAAAAAKAgjsAACj3rKgoVe3eTVZUVLBDAQCUAfp5AABQUVBwBwAA5Z4VGqrQJk1khYYGOxQAQBmgnwcAABUFBXcAAFDumawsZa5aJZOVFexQAABlgH4eAABUFBTcAQBAuWcyM3Xku2UymZnBDgUAUAbo5wEAQEVBwR0AAAAAAAAAgACg4A4AAAAAAAAAQABQcAcAAAAAAAAAIAAouAMAgPLP4ZCzQQPJ4Qh2JACAskA/DwAAKggK7gAAoNyzVa2q6Ct7yFa1arBDAQCUAfp5AABQUVBwBwAA5Z7xeOTNzJTxeIIdCgCgDNDPAwCAioKCOwAAKPdMerr2v/GmTHp6sEMBAJQB+nkAAFBRUHAHAAAAAAAAACAAKLgDAAAAAAAAABAAFNwBAAAAAAAAAAgACu4AAAAAAAAAAAQABXcAAFDuWbGxqnb7bbJiY4MdCgCgDNDPAwCAioKCOwAAKPcsm002p1OWjY8uAFAR0c8DAICKgk8zAACg3PMePKiDn30m78GDwQ4FAFAG6OcBAEBFQcEdAACUf263crdtl9zuYEcCACgL9PMAAKCCoOAOAAAAAAAAAEAAUHAHAAAAAAAAACAAKLgDAAAAAAAAABAAFNwBAEC5Z0VEKOriTrIiIoIdCgCgDNDPAwCAioKCOwAAKPes8HCFt2wpKzw82KEAAMoA/TwAAKgoKLgDAIByz+TkKHv9epmcnGCHAgAoA/TzAACgoqDgDgAAyj2TkaHD8+bLZGQEOxQAQBmgnwcAABUFBXcAAAAAAAAAAAKAgjsAAAAAAAAAAAFAwR0AAAAAAAAAgACg4A4AAMq/kBCF1KwhhYQEOxIAQFmgnwcAABUEBXcAAFDu2aKjFdunj2zR0cEOBQBQBujnAQBARUHBHQAAAAAAAACAAKDgDgAAyj3v/v1KnfAfeffvD3YoAIAyQD8PAAAqCgruAAAAAAAAAAAEAAV3AAAAAAAAAAACgII7AAAAAAAAAAABEBLsAAAAwCnyw+vSslekjD1SzRbS5S9Kdc4r+vgVr0o/viEd3CFFVJOaXyNd+ozkCDt1MQMAAAAAcBphhjsAAJXB6o+luU9InR+Vbv9WqtFCmnadlJHq//hfZ0rfjJAufky6+wfp6gnS6lnSglGnNOx8VkyM4gb0lxUTE5T7BwCULfp5AABQUVBwBwCgMlgxUTp3oNSmv5RwlnTlOMkRIa161//x2/8nnXGB1LKPFFtPanypdE5vaedPpzbuv1h2u+wxMbLs9qDcP3AyjNcrk5Ul4/UGOxSg3KKfBwAAFQVLygAAUNG5c6VdyVKHB//eZrNJDTtLO1b6P6fuBdKvH0o7fspbdiZts/THPKnlDaci4kK8hw/r0G+/yVu/vqyoqKDEAJSWZ+NG5Xz0sVwLF0oul+RwyNGli0J795K9UaNghweUK/TzAACgoqDgDgBARZe5XzIeKSrBd3tkvLRvg/9zWvbJO+/NbpKM5HVLbQdLnR4u+n7cOXl/+XKP/PUPS5ZlncwjkFwu5azfIKt27ZNvqxLIzxG5Or6yylXuggXKHPO8ZFmSx5O30eWS65tv5Jo/XxFPPC7npZf6PdcYk1egt9slm61cPY+8tkqOXJVSQPt5cg4AAIKHgjsAAChs81Jp6UtSj5ekOm2ltE3SV49JS/4lXTzM/zlL/09a8kKhzfHVq0uJiScVjstuV7qk+Ph4ORISjns88tSsWTPYIZw2Apmr7HXrtHnM85K/JWT+Kr5nPjdGjnXrZTIz5U5NlXv/fnnS0uTNypLJOeqLK8uS5XTKHh2d91etmhy1a8lRu7acdc9Q6JlNFdqggSyHI2DxlwSvrZIjVyUT0H7e7AlITAAAACeCgjsAABVdRDXJsksZe323H0mVomr4P2fRc1KrG6TzBubdrnG2lJspzb5f6vhw3pI0x+r4oNT+7r9v7/5NmnqFUvftk9tKOamHYNLS5JCUmpoqK3+2MIpkWZZq1qyp3bt3582WRpHKIldHXvtv3sz24hijgx99dPzGjJHJyZF771659+6V/vij8DEOh+wNGsjeqJHsZzdXSJs2siUmlsnMal5bJUeuSieQ/XxYerpiAxMWAABAqVXqgrsxRqtXr1ZycrI2bNggm80mr9erpk2bqnXr1mrRogU/AQWA0xj9/F9CnFKt1tLmJVKzK/O2eb3SpiVSuyH+z3FlStYxRXVb/oXsiigchYTm/eVzRhYcf7LFpvzzjTEShasSM+bkc19ZBCpX7j/+kGvevNK/TsPCZMXGygoPk+UMlRyOvP9P3W6Z3FyZQ4dkDh3KW2rmWC6XPBs2yLNhg/TVV5IkKyFBIW1aK6RNG4VccIFs0dEn/diOxmur5MhVyQS2nyffwcZnMACo2Ojni1cpC+4ul0vTp0/XlClTtHnzZlmWpZCQEBljZFmW3G63jDFq0KCBbr31VvXr10+OU/wzXQDAiaOf96P93dInd0q12ki1z5O+f1VyHZHa9M/bP+t2qWqi1HVE3u2ml0srJko1W/69pMzCZ6Uzux9VeD91rPBwRbRrJ1d4+Cm/b+B4XCtXKuu5MXkF8VKKnDRJ9jq1ZZXwtW0yMuTds0felBR5tm2Xd+Of8vy5Ud4dO3yKlGbvXrnmzpNr7jzJZpO9ZUs5OnWU46KLZIuPL3WcQFmjn68Y+AwGABUb/XzJVLqC+7p163Tvvffq999/L/imxRgjl5/ZQlu2bNHw4cM1ffp0TZgwQWedddapDhcAUEr080Vo0Us6sl9aNEbK2CPVPEfqP+vvC6ke3OE7o73TI3lLYix8VjqcIkVUzyu2d3kqKOFbERGKvKCRDqWkMFMU5YJnwwYdeeppmdTUE2/E4ZC9caNSzf6xoqJkj4qSvVEjHT10MVlZ8mzcKHfyL3KvWiXPmjVSbm7eTq9XnuRkeZKTlf3KBNmbN5cjKUnOS7vIioo68fiBAKKfP/3xGQwAKjb6+ZKzTAX5NJOamur3CT7aihUr1L9/f7lcLnlKsy6gzSab3aGWg8copmGrk4y04ggJCZHb7Q52GKcN8lVy5Kp0yNff0jf9ol/feFxer9v/xQqLYLfb5XA4NG3aNLVv3/64xzscDsUzQ/T4diVLky9Was+P5Kp+9sm15XKpuqR9Ut5SGyiWZVlKTExUCoWr4ypNrkx2trL+7//k+mZBSRouflkMu12OpK6KGFbERYhPksnNlWftWrn+9z+5v10q765dhQ9yOuXo2FHOy7vL3rq1LH/XZjgGr62SI1elFMB+Pjx9vWI/vFa6bUnekmo4YSUZZ0snPta22ySn3dLs2xupU+MqJxNqBWLJERIil9stlkc6HnJVOuSr5MjVsb7987CunLRRLo+Rp+RD7Uo71q40M9zXrVun/v37Kzc3V95SFGEkSV6vvCZXv7zxuGre/H9yxtcvkxiBii592Xs6+N0MRXe4STEX3RjscFDB5KZu0e53HpfxuEq99qvH45ExRv3799ecOXMq3bfvpwNz+LAOLlosc0lnWXFxwQ4HlYx79Rodue++Yo+xqlZV+BOPy9GunTwbNyrj9juK74uMUWivXgGO9Kh4nE6FtGqlkFatZIYMkXfTJrmWLpXr26XybtmSd1BurlwLFsi1YIGsGjXk7NFDzquuDPh670BJ0M+fvk5mrO3xSjnG6Kr//qkfhkSqRcKpX7bOn9FLcvTM4hyN7Byqpy4OPf4JZYDpBSVHrkqHfJUcucqzeq9HV71+RLkeyVvK7x8q61j7+NNYKgCXy6V7771XLper9MX2fMbIeNza98VLMh5mkgKllVdsn66weq108LvpSl/2XrBDQgViPG7tm/1X/3yCswi9Xq/P+wWAys0Yo5wPPtTBLpcWW2yPGD1K0QsXqOqnn8jRrp0kyd6okcIff1yy2ST7McUju12y2RT++OOyN2pUlg+hgGVZsjdqpLBBg1TlzTcU9fpkOXv2lFX179mkZs8e5bz5pg7f0FeZL/2fPJu3nJLYAJzeAjHW9hrJ5ZX6z8qSyxP8maSjl+To6cU5urShXU8vztHoJTnBDgkAgsblMeo/K+uEiu35KuNYu9AM9+uvv77YE3r37q3rr79eb775ptavX6/t27erdu3aevHFF32OW7NmjUaOHFlwOzo6WmeeeaYGDBigGjVqSJImT56s3377TWlpaQoLC9OZZ56pfv36qXbt2oF4bAWmT5+utWvXnvxPOY1Xrr2blfHLXFU5t0dgggMqgfxie3TH/oq5sK/Sl7+vg0unSRIz3REQGb/MlSt180m34/F4tHbtWk2fPl2DBg06+cAAnHaMx6OssWOLXTbG2aePwobcKiuk6B+LOi/tInv9esr5+GO5FiyUXC7J4ZDj0i4K7dXrlBXb/bE3aqTwe+5W2G1D5F6xQrlffS33jz/mLcWVmyvXnDlyzZmjkPPOk7NXL4W0O79Ey80AKF5Jxtrt2rXTp59+qvXr1+vQoUNKSEhQUlKSrrjiioLjFi9erFdffVVS3hdqsbGxatmypfr166foo36h8vPPP+ujjz7S1q1b5XQ61axZMw0L8DJWgRpru73Sr3u8ev1nl+463xmg6Eovv9g++pJQDe8Uqme/zdFTi/IK7sGa6Q4AwfT6zy79usd70gvrVLaxdqFRwuTJkwv+vXz5cn3wwQcaP358wbawsLCCf19yySX6888/tXXr1iLvYNy4cQoPD1dKSoomT56ssWPH6t///rdsNpsaNmyoDh06qHr16srIyNDMmTP17LPPauLEibIF6EO9MUZTpkwJSFt5LB368XNFtbmiVBe4AiqrY4vtkgr+S9EdgWCM0aEfPwtom2+88YYGDhxIPw9UIiY7WxnDHpXnt9/8H2BZinx1okLOPLPEbdobNVLEsGEyDz8s5eRIYWHlql+xnE45Lr5YjosvljclRTmffKLcL7+SMjMlSe6ffpL7p59ka9RIYQMGKKTDRbKOnbEPoMRKMtZevny5oqOjde+996patWpav369Jk+eLJvNpu7duxccGx4ervHjx8vr9Wrr1q169dVXdeDAAT355JOSpO+//16TJk3SjTfeqBYtWsjr9Wrbtm0BfTyBH2tL4/+XqzvbOoLSVx5bbJdU8F+K7gAqI2OMxn0f2F/5VJaxdqGCe0xMTMG/IyIiZFmWz7Z8gwcPliR9+OGHxRbco6OjFRkZqdjYWPXu3VuvvPKKdu/erVq1aqlr164FxyUkJKhv37565JFHtHfvXtWsWfOkHli+1atXa/Pmk5/1+Dcj94Gdcu3dJGeN4M1MCqbs7auV8es8udJ2yRFXS1EtL1NY3RbBDgvlkL9iez6K7giU3D0b5T7g52KAJ8gYo02bNmnNmjVq0YK+rdyw2WSPjs5bogMIIJOVpc3X36DsX3/1u9/eurUiR4+SFRl5wvdh2WxSePgJn38q2BITFX7XXQobOFC5c+cq9+NZ8qakSJK8Gzcqc8QI2Ro2VNjNN8tc3yfI0aJCqgT9fEnG2l26dPG5XaNGDW3YsEH/+9//fAruR58bFxenyy+/XB988IFyc3Nlt9s1depUDRgwwKe9OnXqBPTxBHqsbSRt2O9V8m6v2iSe2i/3/BXb81F0ByqXpVvdemOVSxv2e9W0mk3/bONQx3qV5hKYPlbt9uqPtMAt9VWZxtqn9BXjdOb9NMztLrwGenZ2thYtWqSEhARVr149YPeZnJwsy7JOfjmZY+Sk/FEpC+7Z21crbf5r8uZkynKGK3vbb8rds1FxSXdSdIeP4ort+Si6IxByd/8R8DYty1JycnKF/xBwOrHFxiru5gFKSUkJ+Hs6KifjcunIo4/Kk/yL3/3Onj0VdtedlW4pFSsyUqE9e8p5zTVyr1ihnOkz5Fm/XpLk3bRJmSNGaPP06bLfdKNCOnasdPlB2aGfL1pmZqaioqKKPcbpdMoYI4/Ho23btiktLU2WZWnYsGFKT09X/fr11b9/f51xxhkBi6ssxtqWpJW7PKe04F5csT0fRXegcli61a27v8zWoRyjSKelxVvc+jnFo4lXhFXKovvKnR5Z0kkvJ3O0yjLWPmWvlgMHDmj27NmKi4tTrVq1CrbPnTtX06ZNU05OjmrVqqXhw4crpJj1MF0ul88C+5ZlKfyvGUP+fo6wYcMGhYSEBHxR/gMLp+hgJbzooyf7sORxS5aV92eMPIf3a8+HT8seVuX4DaBS8OZmyuRmFVtsz3d00f3QD7Nkc0acihBRgXhzjgS8zZCQEG3YsKHC/8wNqIyM16usMc/LtXCh3/1hd9yu0OOss1wZWHa7HB06KOSii+T+4QflvP2OPOvWSZJy/vhDGjlKtiZNFH7nHQpp3TrI0QIV1/r167VixQo99thjRR6TkpKi+fPnq1GjRgoPD9eePXskSTNnztTNN9+shIQEzZ49WyNHjtT48eP9Fu9LO86WymasbSQ9ODdbo07RhUoP5RgdzlWxxfZ8RxfdX1yeo6qhfE4EKpq0LKNcj2SzJMsyMkbaccio+7RMxYZXvv/n07NNQIvtUuUZa5d5wf2OO+6QJOXk5KhevXp66KGHfArqHTt2VMuWLQsK8i+//LJGjx5dMBv+WJ988ok++uijgtsNGjTQ2LFjFR8f7/d4m81WJjMkjCtbHld2wNs9bRybUneuPBn7gxIKyqeweq2PW2zPF3NhX+VsW63srcny5GaVcWTA8RljZFmWEhMTgx0K/uJNS9P+OXPkbd9eVmxssMPBaSrnww+V/d9JfveF33OPnD2vO8URlX+WZclxwQUKaddO7pUr8wrva9dKkrx//KEjDz6kkAsvVNhtQ2QP4MxZVD7084Vt27ZN//rXv9S7d2+1atXKZ19mZqYGDBggY4xcLpfOOuss3X777ZJUMP7t2bOn/vGPf0iS7rrrLt1xxx1asWKFkpKSCt1XacfZUtmNtY+4pCOuU/crh64N7ccttucb3ilUS7a69c0mjw7n8ksMoKLyHPO/d6ZbyjzM//OBUFnG2mVecB81apTCw8MVHR1d8A350SIiIhQREaHExEQ1bdpUt9xyi3744Qd16NDBb3vXXXedrrzyyoLb+d+IpKam+l2qxuv1lsm3JpYjTLbQE1/L83Tlb4a7jJHsIcxwRwFvbqaytyYrffn7JSq6py9/X9lbk2U5w5nhjlLz5hyRCfAXoPk/j075a/3iY4WEhBQ7AEUZMEberOy89xyglNw//6wjDz/id1/YPwerwSOPsIzFcViWJUe7dnK0a6eqGzdq5/MvyLtpkyTJvXy5Mr7/Xs6rrlLowJtl83P9J+C46Od97NixQ6NHj1bXrl3Vq1evQvvDw8M1duxYWZal2NhYnwlr+Wu7H71mu8PhUI0aNbRv3z6/91facbZUdmPtSIcUE3ZqZj4eyjH6ZpNHz36bU6Ki+7Pf5uibTR5VcYoZ7kAF5DvDPe8tyWukULsq7Qz3I4FdMKTSjLXLvOCekJCgyBJeZMoYI2NMkW/oUt4HBYfDUeT5x2ratGmx7Z2o2C63qkrr7sc/sIL5ew33LFnOMJncbNlCw1nDHYWkL3vv77XZiym6py9/XweXTlN0h36s4Y4Tcjj5K6XNnRjQNt1ut5o2bUrxDTjNedPSdLi3/wt8Oq+6SmEP3C8ba5CXimVZiurYUVUaNFDu3HnKfvNNmf37Ja9Xuf/P3n3HR1Xl/x9/32nJpELoYAMVwsIKuPYVxYIFsItrwa+6YmHVZW3YFRDdRV0bdsXVn2BBwcKCix2xsbqKDSEqxUYJoASIWwAAIABJREFUJCE9U+79/TEkMCTAhExypryej8c8nHNm5s47l3hyz2funPvqqwq89ZYyzzpLvlNOlrWVY3YA2/bzzz9r4sSJOvTQQ3XGGU0fH1uWpa5duzb5WK9eveT1evXbb7+psLBQUuTYpri4eKtFjObOs6XWmWtbku4+OlMX/qHpb7y3hlvn1zWszb6tovuk9yPPmzgkgzXcgRS15RruVQFHeRlW2q7h/uhnAY2ZUxvXZWXSZa69w78tq1evVm1trcrKyhQIBLRixQpJkU/Rt7UGe701a9boo48+0oABA5SXl6f169frlVdekc/n06BBg3Y0ViMDBw5slX/EjG57xn2bySBz5/4qGDpGlV+9qVDJr/J03VM5ew2l2I5G6ovn2yq6U2xHPPi6xn88dhxHA1mTGEhajm2r+sYbFfpkYaPH3L17K/v++2RtZflCxMZyu+U79hh5hxyqupdeUt1zz0u1tVJVlWofe0yBef+R/69/lSeOx/VAOvjpp580ceJEDRgwQCNGjFBZWZmkyPIteXl5MW0jKytLQ4cO1YwZM9ShQwd16tRJr732miQ1LDETD60x13Yk7du97S6YKm26AOq2iu4U24H0MHhXjx4clqmpXwRVtN7Wvt3dOn+QNy2L7ZK0bw933NdwT5e59g7/xjzyyCNavHhxQ3vcuHGSpAceeECdO3fe7uu9Xq+WLFmiuXPnqrKyUu3atVPfvn01adIk5efn72isRvr376+ePXtqxYoVcToYsORp313ezr3isK3klLlzfwrsiMm2iu4U2xEvvi67y9O+u0Klv8Vle5ZlqWfPnurXr19ctgegbQU/+UTV19/Q5GO5M16Qq2PHNk6U2iy/X5lnny3f8OGq/ddTCr7+umTbslf+pKorr5L38MOVefFF7HcgRp988onKy8u1YMECLViwoKG/U6dOevDB2L/RN2rUKLlcLj3wwAMKBALaY489dPPNNzd5wdQdFe+5tiVpzw4uDeza9t882lbRnWI7kF4G7+pJ2wL7lgZ1dWnPAks/lMTn4qnpNNe2nBQ5h7+4uHirV0d/6qmndOONN8bt0/eCoWOUu/fwuGwLSAdlHz6nDR9MV/7gUWp30OkU2xF3FZ/PUcmbD8dlW5ZladKkSTr33HO3+hyv15sS68q1ut8WSY8dquKTX1KwYwsPqkIhdfJ6VRwMSjF8ky7d1V+IKJ3WJXeqqlR+womSbTd6LGvyZHn33afJ16XjvmqJ7e2vcFGRau67v+HCqpKkrCxlXnCBfMeNkJVGS/jwu9VMcRzn/WVL1X7GidKF86XuqX8WXWva1jxbiu9c25L0wLBM/WVfc99AunV+nW5+r063HpahGw/JoNgOIO099GlAl86Nz7Iy6TTXTosj3rPOOkt9+/aV293Cr6ZZLnk791ROGq7dDrREuz+eofyDz9KGBdO05vkbKbYj7nIGHC1vp56S1bI/a263W3379tWoUaPilAzxYnm98nbrxprQaFLdjBkqP+74RsV23wnHK/+dt7dabEf8uXv3VvaU++W/8gpZ9ctfVFer9r77VHX5FQr//LPZgEhYjPPJKV5zbY9L2quLSxf+wey//02HZkSK6+/WaegzVRTbAaS9C/b2aq8uLrlbeM3YdJtrp0XB3ev1asqUKfJ6vTt+YSzLkuX2qOOIK2W52nZNOSAV1Bfda1d+SbEdcWe5Pep43JWy3J7I5eR3gMvlavh7Ecu1SNC2nKoqVS74QE5VlekoSCD2hg3acPgRqn3k0UaP5c6aKf/YsQZSwXK55Bs+XDlPPyXvsZtOVAl//bUqR1+g2meflRPnCy0i+THOJ6d4zLVdluR1SdNO9svjamFFJw7qi+5vLwtTbAeQ9rxuS9NO9svnjozXOyId59rp8VNKKiws1LRp0zRq1CgFg0GFw+GYX2u53LLcHu3159vVrldhK6ZMLh6PJ+5XpU9l7C9Jx50XuW0H+6p52F8bFRSqy/l/11dPXi8nHJJjxz7Ou91ueb1eTZs2TYWFjPOJyKmtVc2iRXLaD5GVlWU6DhJA3fMvqPaxxxr1+6+7Vr6hQw0kwpZc+fnKuvpqhY44QjX/vFv2qlVSMKi6J6YqtOAD+a+7Vu5ddjEdEwmCcT55tWSu7XFFijmzL9pdffbI1dYXr2lb154YuUkykMmS1+NRMBSS4n65wlTDvmoe9lfs2Feb69Nemn1xhY579EcFw45CjVdw3Kp0nWunTcFdkg488EDNmTNHl112mb7buK7kttaaszaeJdm3sI+mTJmSVr8Y28OalM3D/ood+6p52F9b6qslpw1s9jjfpw/jPJAsnOpqlY84rlG/1b6dcp9/nuUoEpBn772VM/UJ1f7rKQVmzpRsW+GlS1V54UXKvGC0fCedlFZruwOpaEfn2r0L+zYcgxW3SdLEV398v47j++1iXzUP+yt27KvG+kr690lLmGvHKO2ObAsLCzV37lxNmjRJu+22m6TIL4HX65XH45HX6234pejZs6cmTZqkuXPnpt0vBgAkK8Z5IHUFF3zQZLE9a+IE5c2cSbE9gVmZmfKPuVjZU6bItfPOkc5AQLUPPqSqq8fJXrPGbEAALcYxGACkNsb52KXVGe71vF6vzj33XJ1zzjn69ttvtWjRIhUVFcmyLDmOo969e2vgwIHq169fwy8KACB5MM4DqcWxbVVeeJHsZcui+q28XOW++CKF9iTi6VuonEcfUe0TTygw62VJUviLL1RxwYXKuuoqeQ8ZbDghgJbgGAwAUhvjfGzSsuBez7Is9e/fX/3792dZBgBIQYzzqcPKyFDm7/srmMGFy9JN+NffVHn22Y36/deMk+/oow0kQktZmZnyX3qpvAcdpOrJd8gpLpYqK1U9frx8J5ygzDEXy/L5TMdEG2OcTy0cgwFAamOc37a0W1IGAAAkHysnR7lDhsjKyTEdBW2o7pVXmiy2577yMsX2FODZe2/lTn1C3iFDGvoCr76qyksuVfinn80FgxGM8wAAIFVQcAcAAAnPCYUUXLtWTihkOgragOM4qvi//1Pt/VOi+n3HjVD+O2/LlZdnKBnizcrJkf+mG+W/4nJp41nt9o8/qvLiixV45x3D6dCWGOcBAECqoOAOAAASnrNhg8pemCFnwwbTUdDK7PXrVX7EkbJ/+TWqP/vBB+S//HJDqdCaLMuSb8QI5Tz0oFy77hLprK1VzaTbVPPww3LCYbMB0SYY5wEAQKqg4A4AAICEEFy4UBUjT2vUn/f6XHn69jWQCG3J3auXch56SN6jj2roC7z4kqquvlp2aanBZAAAAEDsKLgDAADAuJqHH1b1dddH9XmPPlr577wti4sopg3L75d/3Dhljh0reTySpPCiL1V50cUKfbfEcDoAAABg+yi4AwAAwBjHcVQ+8jQFXnwpqj/r9tuVdc04Q6lgkmVZyjjheGXffbesDh0kSc66daq6/HIF3nvPbDgAAABgOyi4AwCAxGdZsnw+ybJMJ0EcOTU1Kj/iSDnr10f15854Qd4D9jeUConC07+fch59RO7f/z7SEQioZuKtqn3mGTmOYzYc4o9xHgAApAgK7gAAIOG5CgrU8aIL5SooMB0FcWKvXq3y4SMa9ee9+YZcHTsaSIRE5CooUPZdd8p79NENfXX/eko1f/+HnEDAYDLEG+M8AABIFRTcAQAA0KZCX36lijPPiurzDB4cWa/d7TaUConK8nrlH3e1Mi8Y3dAXfOstVV19tZyKCoPJAAAAgMYouAMAgIRnl5WpZPp02WVlpqOghQJz56rq8suj+jL/8hdlTxhvJhCSgmVZyjjjDGWNHy9tvIhu+OtvVDn2b7KLi82GQ1wwzgMAgFRBwR0AACS+cFjhklIpHDadBC1QO3Wqau76Z1Rf1uTJyjj1FEOJkGy8hwxW9r33yGrfTpJkr1ihysv+qvDKlYaTocUY5wEAQIqg4A4AAIBWVz15suqmPxvVl/P0U/Luu4+hREhWnj59lH3/FLm6dZMkOWvXqmrsWIUWLzacDAAAAKDgDgAAgFZWdfXVCs57I6ov95WX5d55Z0OJkOzcPbore8r9cu2xhyTJKa9Q1VVXK/T554aTAQAAIN1RcAcAAECrqfjz+Qr9L7oImvf6XLny8gwlQqpwFRQo55675d5770hHba2qrrtewYULzQYDAABAWqPgDgAAEp6Vm6u84cNl5eaajoJmKD/jTNkrVkT15b35hqyNF70EWsrKzlb27bfJ88eDIh3BoKpvulnBDz4wGwzNxjgPAABSBQV3AACQ8CyfTxm9esry+UxHQYzKTz9Dzpo1UX15b78ly+02lAipyvL5lHXLLfIOGRLpCIVUPX6CAu++azQXmodxHgAApAoK7gAAIOE5NTWq/uwzOTU1pqMgBuWnnyFn7dpNHS6X8t95W5ZlmQuFlGZ5PPLfcL28Q4dGOmxbNbfdruB7880GQ8wY5wEAQKqg4A4AABKeU12tqo8/kVNdbToKtqPi7P+LLra73cp/601zgZA2LLdb/mvGyTt8eKTDtlV9220Kfvih2WCICeM8AABIFRTcAQAAEBeVl1wq+9dfN3W43cp/8w1zgZB2LJdL/sv/Ju+xx0Q6wmFVT5jIhVQBAADQZii4AwAAoMWqxo9X+Lvvovry3phnKA3SmeVyyX/FFfIeeUSkIxRS9S3jFfr8C7PBAAAAkBYouAMAAKBFaqY8oND7C6L68t5+izXbYUxkeZlr5DnkkEhHIKCqm25SuKjIbDAAAACkPAruAAAg8fl8ythjd8nnM50EW6h78UUFXn45qi/vrTcptsM4y+1W1g3Xy3PAAZGOmhpVXXudwpsve4TEwTgPAABSBAV3AACQ8Fy5uco79li5cnNNR8Fmgh9+pNqHH4nqy5v3H1kuDjGRGCyvV1m33Cz37/tLkpyyMlWPu0Z2SYnhZNgS4zwAAEgVzIYAAEDCc8JhhSsr5YTDpqNgo/CyZaq+6aaovrx/z5bl9RpKBDTNyshQ9qRJcu22myTJXrVKVddeJ6eqymwwRGGcBwAAqYKCOwAASHhOWZlK/vWUnLIy01EgyS4rU+XoC6L6cl94XlZWlqFEwLZZubnKnvwPWZ07S5LsH35Q9aTbKO4mEMZ5AACQKii4AwAAIGZOOKyKk0+J6st+8EG5OnUylAiIjatTJ2XfMVnWxiVLQgsXNloSCQAAAGgpCu4AAACIWfnQo6La/htukKdvoaE0QPO4d9lFWeNvkdxuSVJg1izVvfqa4VQAAABIJRTcAQAAEJOq62+IavtGjpTviMMNpQF2jGfQIPkv/1tDu3bKFAU/+8xgIgAAAKQSCu4AAADYrrrXZiv0yScNbddOPeQfc7HBRMCO8w0bJt+fTos0bFs1kybJXrXKbCgAAACkBAruAAAg4VkFBeo45mJZBQWmo6Sl8PLlqr333qi+nKefNpQGiI/M0aPlOeAASZJTXqGqW8bLqa01nCp9Mc4DAIBUQcEdAAAkPMuyZHk8sizLdJS04wQCqjx/dFRf3px/82+BpGe53cq6/jq5duohSbJ/+EE199wrx3EMJ0tPjPMAACBVUHAHAAAJz96wQWWzXpa9YYPpKGmn/Jhjo9o5jz0qy+83lAaILysnR1kTJkiZmZKk4JtvKvAaF1E1gXEeAACkCgruAAAg8YVCCv76qxQKmU6SVmruiV5GJvOC0XLvsYehNEDrcPfsKf+4qxvatQ89rPD33xtMlKYY5wEAQIqg4A4AAIBGQt98q8Ds2Q1tq0MHZZxxhsFEQOvxDRki3ymnRBrBoKpvvVVOdbXZUAAAAEhKFNwBAAAQxQkGVfXXv0b15b7wvKE0QNvIvPACufv0kSTZv/yqmntZzx0AAADNR8EdAAAAUcqPOz6qnTt9miwXh41IbZbXK/+NN0pZWZKk4FtvK/jmW4ZTAQAAINkwcwIAIF3893Hpnt9Lt3aWHj9c+uV/235+TZk050rprt7SrZ2k+/eWit5om6xbsLKzlXP4YbKys428fzqpmzlTCgQa2pkXjJarWzeDiYC24+7RXf4rr2ho10yZIru42GCi9ME4DwAAUgUFdwAA0sE3M6V510tDrpEuel/q0l+adpJUuZVCUiggPXOiVPaTdNr/ky79TDr+finPTOHVysyUv18/WZmZRt4/XdhlZap98KGoPtZtR7rxHXaYvEceGWlUVanmrn+ytEwbYJwHAACpgoI7AADp4OMHpb3PkQaNkjoXSiPulbxZ0hfPNP38L56Rakql05+VdjlAar+rtNvBUtfft23ujZzaWtV8+62c2loj758uKk4+Jaqd95/XDSUBzPJfdqmsDh0kSaFPP1VwzlzDiVIf4zwAAEgVFNwBAEh1oYD02yKp15BNfS5XpP3Lp02/Zunr0k77RZaUuXMP6cEDpPfvkuxw6+dtglNVpcp33pVTVWXk/dNB7fTpUe2s2ybJ8vkMpQHMsnJz5b/qyoZ2zcMPy1692mCi1Mc4DwAAUoXHdAAAANDKqtdLTljK6Rzdn91JWlfU9GtKV0jL35f2Gimd9aJUsixSfLdD0pBrm35NqC5yqxeoL5pYsiyrZT/DxtdbVhy2lQaszfZXLOzyctVNfXLT6zt1ku+gg1olW6Jp7r5Kd+m0v3wHHKDQ8GEKzJkr1dSo5o47lf3Pu2K+gHA67au4iOs4zz4HAADmUHAHAACNOXakIH/c/ZLLLXUfJJWvkj66f+sF9wV3S/P/0ai7U8eOUgsvuhl0u1UmqVOnTvJ27rzd5yOia9euMT3vu8MOj2r3eedtWV5va0RKWLHuK0Sky/4KT5igZV98odBvqxRatEhZC/+rdief1KxtpMu+aqm4jvPOmrhkAgAA2BEU3AEASHVZHSTLLVWuje6vKpZyujT9mtyukssTKbbX69RHqlwTWaLG08RSI4OvkA68ZFN79dfSU8NUvG6dQtaqFv0ITkmJvJKKi4tlhc0sa5NMLMtS165dtXr16u1e7DHw/vtR7ayJE7R63brWjJdQmrOvkJ77K+PyyxW6epwkafUdd6iqfz+5cnO3+7p03FctEc9xPrOsTO3jEwsAAKDZKLgDAJDqPD6p+0Bp+Xyp74hIn21Ly+ZL+13Q9Gt23l/6+qXI8+qXT1j/g5TTteliuyR5MiK3er7sjXecFhebHLdb3h49FHC7JQpXMXOcbe97x7ZVfcv4qD7vwQenZXFwe/sK0dJpf3n+8Ad5hwxR8L335JSVqfaJqfL/bWzMr0+nfdUS8R3n2d8AAMAcLpoKAEA6OPAS6X9PS4uelYqXSnMul4JV0qBRkcdnXSS9NX7T8/c9X6oplf5zjbTuB6lonrTgn9J+o43Ed+Xnq93JJ8mVn2/k/VPVlsX23FdeNhMESHCZYy6WMjMlSYHZsxUu2sr1L7DDGOcBAECqoOAOAEA66H+KdNQk6d3bpUcOjiz3MmrWpgupbvhFqthszdv8naSzZ0m/fi49fJD0+jhp/4ulg68wEt9xHDmhEGeJxpFdWqrQhx82tH3HjZArL89gIiBxuTp1UuY550QajqOae++TY9tmQ6UYxnkAAJAqWFIGAIBEEqiSvFmSZTX9eNW6yBnqu/2x+dve/8LIrSnnzWnct/N+0gVvN/99WoFTUqJ1M2fJOWyIrIIC03FSQsUpp0a1M//2N0NJgOTgO+VkBebNk71ihcJLlij45pvyHX206Vgpg3EeAACkCs5wBwAgESx6Vrqnv/T3nSK3V/4SfcZ5vR/fkZ4e0fb5kFK2XA4j6/bbZW3tQx4AkiTL45H/sksb2rVPPS0nEDCYCAAAAImIgjsAAKYtey9SYPdmSQf8RepzrPTNLOmhA6QVH5hOhxRUefGYqLb3gP0NJQGSi2fQIHn221eS5KxZo8Ds2YYTAQAAINFQcAcAwLT375K6D5Qu/kA6+jbplCekMR9K+T2kaadEiu9AnAQ/+yyqnfPkVENJgOSUOXrTxaPrpk2XU1VlMA0AAAASDQV3AABMW7tYGnCG5PFt6uuwu3T+m1Kvw6SZo6WFj5nLh5RSPe6aqLZ7t93MBAGSlHuPPeQ9/HBJkrNhg+pefMlwIgAAACQSCu4AAJhmhyWXu3G/1y+d/mykGP+fa6R3bmv7bAnCatdOBeedK6tdO9NRklrwk4VR7dwXnjeUBEhuGeedK7kj43bdSy/Jqaw0GygFMM4DAIBUQcEdAADTOuwu/bSw6cdcLunEB6UDL5Hev1Oaf0fbZksQltstd06OLHcTH0wgZtXXX7+p4ffL1amTuTBAEnP36CHvMcdEGtXVCvx7jtlAKYBxHgAApAoK7gAAmLbnUdKSOVJ1ydafc9QkaegEaf0PbZcrgdgVFSp//XXZFRWmoyStcFFRVDt3Kmu3Ay2RMXKkZFmSpLpZs+QEg4YTJTfGeQAAkCo8pgMAAJD2Bp0tZXWQqoqlrIKtP++PY6WCXtKab9suW6IIBFT3w4/SzjubTpK0Ki8eE9V2de1iKAmQGty77CzPQQcq9OFHctatU/Cdd+Q7+mjTsZIX4zwAAEgRnOEOAIBp+T2k/S6QOvXZ/nP7HicNubb1MyGl2OXlUe2cRx42lARILRl/+lPD/boZL8pxHINpAAAAkAgouAMAAKS46gkTo9ru3r0NJQFSi6d/f7l/9ztJkr18ucKLFxtOBAAAANMouAMAAKS48BdfNNzPvPgig0mA1OM7bkTD/eC8eQaTAAAAIBFQcAcAAAnPyspS9oEHyMrKMh0l6QQ//jiq7Rs50lASIDV5DzlEysyUJAXefU9OXZ3hRMmJcR4AAKQKCu4AACDhWX6/svbZR5bfbzpK0qm+4caG+1ZBgSzLMpgGSD2W3y/voYdGGlVVCn74odlASYpxHgAApAoK7gAAIOE5gYDqli2XEwiYjpJUtryAY9atE7fyTAAt4Tv6qIb7wbffMZgkeTHOAwCAVEHBHQAAJDynokLlc+bIqagwHSWpBD/4IKrt6dvXUBIgtbn32ktW+/aSpNAXX1A03gGM8wAAIFV4TAcAAABbCFRJi1+TSldItWXSFmcpy7KkYycbiYbkUnPvfQ33rY4dDSYBUpvlcslzwP4Kvv4fqbZWoUWL5Nt/f9OxAAAAYEBaF9wdx9E333yjRYsWqaioSC6XS7Ztq3fv3ho4cKD69+/POqcAkMSScpxf9p404xypdsPWn0PBHTFySkoa7vvHjjWYBEh93v0PiBTcJYU+/oSCO9JaUh6DAQBixji/bWlZcA8Gg5o+fbqeeOIJLV++XJZlyePxyHEcWZalUCgkx3HUs2dPjR49WmeddZa8Xq/p2ACAGCX1OD/nKsmXLY38l9RjHykzz3QiJCm7qiqq7TnoQENJgPTg2ecPkscjhUIKffqp6TiAEUl9DAYA2C7G+dik3RruS5Ys0bBhw3TDDTdoxYoVkiKfygSDQYVCIQWDwYYLjK1YsUI33nijhg0bpiVLlhhMDQCIVdKP8xt+kf44Vtr9cIrtm3O75S5oL7ndppMkjbKZM6Pa6XyGCdAWrKwsufsWSpLs336TXVpqOFGSYZxPekl/DAYA2CbG+dil1RnuH3/8sUaNGqVgMChJDb8EW1P/+OIlSzT0mGHa68+3q12vAa2eM1l4PEUKhUKmYyQN9lfs2FfNw/7apGzZl/pq6nWy7cj+iHWcX7p0qYYPH65p06bpwAMNnwXcpZ9UW242QwJytWungrPO0qpVq7b774qIkmemNdx39eplMAmQPtx9f6fw199IksLffSf97neGEyUPxvnktqNz7aVLFmvEMUdq9kW765A9cls9Z3KwJI9HHUMhSfy/sG3sq+Zhf8WOfbWl93+o0IhHf1QwHNkfSTnXbkNpU3BfsmSJRo0apUAgINu2m/di25btBPTl1OvU9f/ulq/Tbq2SEQDaQtmHz2nDB88q/+Az1e6PZ5iOEzeB4hVa/f+ukxMONr7I6HaEw2E5jqNRo0Zpzpw5KiwsbKWUMRg6QXrpfGmPI6Qee5vLgaQX/Pnnhvu+4cMNJgHSh6ewUIGN98Pf/2A0C9BWWjLXDttSnePouEd+0H8vyFb/znzDoV76LcCw49hXzcP+il2q7Ktb59fplvfqNGFIhm46NKPZr/9mbVjHPV6lQFiym/n5Q0LNtdtQWiwpEwwGddlllykYDDa/2F7PceSEQ1r373/KCXMmKYDkFCm2T1fmrgO04YPpKvvwOdOR4sIJh7Ru9sbxeQfPirNtO+rvhTG7HSwd83dp6lDpoYOk6SOlZ0+Pvj2XOh+UxMouKdG6Rx+TvdlFQBE776GHmI4ApAXXrrs23A9v9qEXto9xPjnFY65tO1LQlkbNqmk4cxIAEB+3zq/Tze/V6Yhebt38Xp1unV/XrNcHw45GzarZoWJ7vYSZa7ehtCi4T58+Xd99953C4XDLNuTYCq5drsov58UnGAC0ofpie/7gUepy+iTlDx6VMkX3yi/nKVi8XHJ28EPVjcLhsL777jtNnz49Tsl2wOJXpVkXSnZYKv9VKl4irf02+rbmW3P5THEcOYHADn+gku5cBQWmIwBpwdWju+SKTLFsCu7NwziflOI11w7Z0ldrbD3+eXoUYgCgLdQX2289LENvnp2tWw/LaHbR/fHPg/pqja2Wfh6aEHPtNtRoSZnTTjttmy849dRTddppp+nJJ5/U0qVL9fPPP6tHjx668847o5737bffasKECQ3t/Px89enTR2effba6dOmiyspKzZgxQ19++aXWrVunvLw87bvvvjr99NOVlZUVpx8vsmbQE088EbftSZbKP3tNOYOGcfExAElj82J7u4NOl6SG/25YEFnnOVmXl3EcR+WfvRrXbU6dOlXnnHOOmXH+rfFSxz2l056ROu7R9u+PlOBUVpqOAKQly+eT1aGDnOJi2evXm46DBBPLXHu//fbTK6+8oqVLl6q8vFydO3fW0KFDNWzYsIbnvffee3rooYckRS6I3b59e+21114666xCLCPaAAAgAElEQVSzlJ+fL0m65JJLVFxcHLX9M888UyeeeGLcfp74z7Wl+xYGNGYfL3NtAGihzYvtNx4SWUam/r83vRspuG9veRnHcXTvJ807I357jM6121Cjgvtjjz3WcP+jjz7SCy+8oPvuu6+hLzMzs+H+YYcdph9++EErV67c6hvce++98vv9WrVqlR577DFNnjxZd911l0pKSlRSUqKzzz5bO+20k9atW6fHH39cpaWluvLKK+P18+mbb77R8uXL47Y9yVGo9FcF1y6Tr8vucdwuALSOport9Vqj6F778zeq/OoNBUt+k7egu3L2OkqZO/dv8Xa3JrDmR4VKf4vb9hzH0bJly/Ttt9+qf//Wy71VFauloRMptqNFwj/8aDoCkLasdu3kFBfLKSvj4p+IEstc+6OPPlJ+fr4uu+wydejQQUuXLtVjjz0ml8ulY445puG5fr9f9913n2zb1sqVK/XQQw+ptLRUN9xwQ8NzTjvtNB155JFR24+neM+1HUlF620tWm1rUDfWcgeAzS1YGdLUL4IqWm+rdweXzh/k1eBdm740Z1PF9nrNKbp/sdrW9yXxO5YxPtduQ43+Zdq1a9dw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qc4vdhTjIvedjWn/58gR6H1+jJk0qU8m3Pmb38vInQqdTgeLJbbPTJQTFNFWz6k7epHlkZ0nuVMFRE8WnCq5oH6fkYmKzpTLiRH1isWOVi92VK5OrDMpfu4SdHogWS+tdI58DdLvXMrAgWjpQodSDAYAnz9iZYBq5Xfk4D9UJqrLwlbeqa7rsDMmH4vKYbsy+dpTJjo602HUQpBXe4StbIwo06pWhWiZrDtXyW2tyRTbD4qUY5GchI92p5P6PDLGRbte/r7quBVtcvhUZaebfJYTHVarFc3Nze2+JjJune7uM3U5H2dwbhP0ekAfeiyWuryb31dZPackK/zhiQu/6k4nvx8I+CD6/G2JADEYfaJXFFXnAdWkb8SEr6B6F4IAZcJZfRw28ayaZBYEabI62t1lWq2UBOjgNeh0bcfqu9hCKyUZ085N8t0+er0eycnJMf3ekSu+Izf1Sm91orur+9P9Dnfmd1weS6nviFbvI8ujvaYel6kXP8nxjc5Ngkb1ODV1eQy+tyiv+vb5wuOZr4P45vdJ47TIu37DtkCUmBaxqeMUED2mKS8L0a/XRolXcplGC0F5XaOUIbJMiWdtd2NzAdO5S6PRKHenxtLpYlogEIBm+3bA5UJf7VIx4X4OkTsyRNSzBI0WMGql1dtJZ/B1PVcloj5HnoDVarUwGo3xrs4Z4QpUSiSCIIQmVHUAzJ37mp6tElGfpF54RUQ9R9BoAE0o2dzZr+nB+hD1RZ2Jaa02G8Q+9Oz9SJzGIiIiIiIiIiIiIiKKASbciYiIiIiIiIiIiIhigAl3IiIiIiIiIiIiIqIYYMKdiIiIiIiIiIiIiCgGmHAnIiIiIiIiIiIiIooBQRRFMd6VICIiIiIiIiIiIiJKdFzhTkREREREREREREQUA0y4ExERERERERERERHFABPuREREREREREREREQxwIQ7EREREREREREREVEMMOFORERERERERERERBQDTLgTEREREREREREREcUAE+5ERERERERERERERDHAhDsRERERERERERERUQww4U5EREREREREREREFANMuBMRERERERERERERxQAT7kREREREREREREREMcCEOxERERERERERERFRDOjiXYHu2LVrF95++23Y7Xbk5OSguLgY+fn58a4WEfVihw4dwrZt23D06FE0Njbi9ttvx+jRo5XXRVFE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AatWrYLD4YDBYMD555+Pe+65ByaTCddeey1efPFFvPnmm7jiiitQUlKCu+66C6+88gqWL18Ot9uNjIwMTJkyRfmeZrMZubm5WLZsGURRxOTJkzFhwoRT1oMr3ImIiIiIiIiIiIiIVKqrq7F69Wps2LDhjL5O0zPVISIiIiIiIiIiIiI6tzDhTkREREREREREREQUAwmfcPf5fKioqIDP54t3VYioD2HbQkQ9he0LEfUUti9E1FPYvhBRT+nN7cvFF198xo+TAfpIwn3Tpk298j+FiBIX2xYi6ilsX4iop7B9IaKewvaFiHpKX2xfEj7hTkRERERERERERETUGzDhTkREREREREREREQUA7p4V6C7Tp48icbGRlRUVECv18e7OkTUR/h8PrYtRNQj2L4QUU9h+0JEPYXtCxH1lGjty9SpU5GRkRHnmnWdIIqiGO9KdMeLL76I4uLieFeDiIiIiIiIiIiIiLrp5ZdfxqxZs+JdjS5L+BXukydPxujRo7Fo0SIYjcZ4V4eI+ojW1lasW7eObQsRxRzbFyLqKWxfiKinsH0hop4SrX2ZOnVqnGvVPQmfcM/IyEBOTg5mzpwJi8US7+oQUR/hcrmwa9cuti1EFHNsX4iop7B9IaKewvaFiHpKX2xf+KGpREREREREREREREQxwIQ7EREREREREREREVEMaEtLS0vjXYnu0mg0uPjii6HVauNdFSLqQ9i2EFFPYftCRD2F7QsR9RS2L0TUU/pa+yKIoijGuxJERERERERERERERImOj5QhIiIiIiIiIiIiIooBJtyJiIiIiIiIiIiIqM/avHkznnjiibPys3Rn5acQEREREREREREREfWAm2++WTn2er3QarXKM+Evuugi3HPPPWetLnyGOxERERERERERERH1CaWlpRg1ahSuueaauPz8hF7hvmvXLrz99tuw2+3IyclBcXEx8vPz410tIkogb731Fvbt24cff/wRBoMBBQUFmD17NrKyspRrvF4vNm7ciMrKSvh8PowYMQIlJSWw2WxxrDkRJZItW7bg1VdfxdVXX4158+YBYNtCRF3X0NCAl19+GQcOHEBraysGDBiAJUuW4IILLgAAiKKIiooKvP/++2hpacGwYcNQUlKCgQMHxrnmRNSbBYNBVFRU4OOPP4bdbkdaWhomTJiA3//+9xAEAQDbFyLqnEOHDmHb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tVro9Xo0NjbinXfeQU5ODpxOJ55//nmkp6fjhhtuiHf1iaiX0uv1sFqtYduePXtw3nnnYcKECWxbiKjLMjIysGnTJmg0GqSmpuLAgQP45z//iRkzZiAnJweCICAQCGDLli3Izs6G3+9HeXk5vF4viouLodVq4/0WiKiXOn78OD766CNkZWVBq9Wiuroar732GsaNG4fhw4ezfSGiTvN4PDh+/Djsdjt2796N/Px8GAwG+P1+JCUlnbYtSUlJwbfffou9e/fi/PPPR21tLdavX4/hw4dj0qRJ8X57pyWI8lRlAtq1axe2bdsGu92O3NxczJ8/H0OHDo13tYgogUTOcMqWLFmiPKfQ6/Vi48aN2Lt3L/x+P0aMGIGSkhI+9oGIzkhpaSlyc3Mxb948AGxbiKjr9u/fj1dffRU//fQTMjMzcc0112DKlCnK66IooqKiAu+99x5cLheGDRuGBQsWICsrK461JqLezu1244033sC+ffvgcDiQlpaGcePG4frrr4dOJz0gge0LEXVGdXU17rvvvnblEyZMwNKlSzvVljidTpSVlWH//v0QBAFjxoxBcXFxQiy0TuiEOxERERERERERERFRb6E5/SVERERERERERERERHQ6TLgTEREREREREREREcUAE+5ERERERERERERERDHAhDsRERERERERERERUQww4U5EREREREREREREFAP/H/Lenc4AMJWdAAAAAElFTkSuQmCC\n",
            "text/plain": [
              "<IPython.core.display.Image object>"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 17
        },
        "id": "_qK7LvnfBmGy",
        "outputId": "9018e602-a4b6-4d89-f382-fe07a69a04fa"
      },
      "source": [
        "#@title ## Download Visualizations\n",
        "\n",
        "#@markdown Please specify the files you'd like to download.\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "\n",
        "flg_download_image = True #@param {type:\"boolean\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "flg_download_animation = False #@param {type:\"boolean\"}\n",
        "anim_fps = 15 #@param {type:\"integer\"}\n",
        "\n",
        "#@markdown ---\n",
        "\n",
        "from shutil import copyfile\n",
        "from google.colab import files\n",
        "\n",
        "import uuid\n",
        "salt = str(uuid.uuid4())\n",
        "\n",
        "if flg_download_image:\n",
        "\n",
        "  assert sim_img_file_path is not None, 'ERROR! Please make sure that you have created the visualization of this simulation.'\n",
        "\n",
        "  filename = '{simulation_name}_{salt}.png'.format(\n",
        "      simulation_name=simulation_name, salt=salt)\n",
        "  copyfile(sim_img_file_path, filename)\n",
        "  files.download(filename)\n",
        "\n",
        "if flg_download_animation:\n",
        "\n",
        "  assert anim is not None, 'ERROR! Please make sure that you have created the animation of this simulation.'\n",
        "\n",
        "  filename = '{simulation_name}_{salt}.mp4'.format(\n",
        "      simulation_name=simulation_name, salt=salt)\n",
        "  anim.save(filename, writer=animation.FFMpegWriter(fps=anim_fps))\n",
        "  files.download(filename)\n",
        "\n",
        "if not flg_download_image and not flg_download_animation:\n",
        "  print('Warning! No files have been selected to download.')"
      ],
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "\n",
              "    async function download(id, filename, size) {\n",
              "      if (!google.colab.kernel.accessAllowed) {\n",
              "        return;\n",
              "      }\n",
              "      const div = document.createElement('div');\n",
              "      const label = document.createElement('label');\n",
              "      label.textContent = `Downloading \"${filename}\": `;\n",
              "      div.appendChild(label);\n",
              "      const progress = document.createElement('progress');\n",
              "      progress.max = size;\n",
              "      div.appendChild(progress);\n",
              "      document.body.appendChild(div);\n",
              "\n",
              "      const buffers = [];\n",
              "      let downloaded = 0;\n",
              "\n",
              "      const channel = await google.colab.kernel.comms.open(id);\n",
              "      // Send a message to notify the kernel that we're ready.\n",
              "      channel.send({})\n",
              "\n",
              "      for await (const message of channel.messages) {\n",
              "        // Send a message to notify the kernel that we're ready.\n",
              "        channel.send({})\n",
              "        if (message.buffers) {\n",
              "          for (const buffer of message.buffers) {\n",
              "            buffers.push(buffer);\n",
              "            downloaded += buffer.byteLength;\n",
              "            progress.value = downloaded;\n",
              "          }\n",
              "        }\n",
              "      }\n",
              "      const blob = new Blob(buffers, {type: 'application/binary'});\n",
              "      const a = document.createElement('a');\n",
              "      a.href = window.URL.createObjectURL(blob);\n",
              "      a.download = filename;\n",
              "      div.appendChild(a);\n",
              "      a.click();\n",
              "      div.remove();\n",
              "    }\n",
              "  "
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        },
        {
          "output_type": "display_data",
          "data": {
            "application/javascript": [
              "download(\"download_43f54aa5-7002-4953-ae11-0ac02a032bf7\", \"Simulation_aed614c2-8b2f-4419-8f58-0c35e50d822a.png\", 111252)"
            ],
            "text/plain": [
              "<IPython.core.display.Javascript object>"
            ]
          },
          "metadata": {}
        }
      ]
    }
  ]
}