{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": [],
      "collapsed_sections": [
        "ocD_jCDdqt7i",
        "PQQ9VxkZDNb-",
        "8uO1UgJ5Dute",
        "_a8qE4oVQVFx",
        "t2xeQ7GQdDj9",
        "G2nQ1erWpRqB"
      ]
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    },
    "widgets": {
      "application/vnd.jupyter.widget-state+json": {
        "b58c20ef597e41658752857bc6b58518": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_585b8c5d232f48488ad837f9daf1c053",
              "IPY_MODEL_ddb53cc65b68406a9f27ef947d1a2e9c",
              "IPY_MODEL_53924983f3d647cc86cb42d956ad904d"
            ],
            "layout": "IPY_MODEL_fdb705c8df204372ab093694c76c2e6c"
          }
        },
        "585b8c5d232f48488ad837f9daf1c053": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_c0d38bd4d94545ce895e7b6c73658a2e",
            "placeholder": "​",
            "style": "IPY_MODEL_684706b048f640bba31a815c1c2d30a6",
            "value": "Generating train split: "
          }
        },
        "ddb53cc65b68406a9f27ef947d1a2e9c": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_0f2c6c3df9494be884676526e582393d",
            "max": 1,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_3da7051088994d5989b204e7d9384d57",
            "value": 1
          }
        },
        "53924983f3d647cc86cb42d956ad904d": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_7706dcd0bfd64f928daba54ce2a892a0",
            "placeholder": "​",
            "style": "IPY_MODEL_9f9e40c1096f4741994f003ceac3e6b0",
            "value": " 6000/0 [00:00&lt;00:00, 19094.09 examples/s]"
          }
        },
        "fdb705c8df204372ab093694c76c2e6c": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "c0d38bd4d94545ce895e7b6c73658a2e": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "684706b048f640bba31a815c1c2d30a6": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "0f2c6c3df9494be884676526e582393d": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": "20px"
          }
        },
        "3da7051088994d5989b204e7d9384d57": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "7706dcd0bfd64f928daba54ce2a892a0": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "9f9e40c1096f4741994f003ceac3e6b0": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "e169553bbbc946cfa8361765b68c574c": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_e861b4374f164a2586943adae56eb8d7",
              "IPY_MODEL_5ec06dcc4a5b442391040af351bf958c",
              "IPY_MODEL_7c6be4c3a43043f183d6ce657c2e56e8"
            ],
            "layout": "IPY_MODEL_5516c056ce474e46bd5bc1a9aa0e5f4f"
          }
        },
        "e861b4374f164a2586943adae56eb8d7": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_49d21c73bade4d89a2306debfe881ade",
            "placeholder": "​",
            "style": "IPY_MODEL_ce4c462f95c74a59b82dc6dfd22428d4",
            "value": "Generating test split: "
          }
        },
        "5ec06dcc4a5b442391040af351bf958c": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_9c4ab404cdb6408bbd712b6a8d081d73",
            "max": 1,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_d0851dcab40c4400b85b88e117120c36",
            "value": 1
          }
        },
        "7c6be4c3a43043f183d6ce657c2e56e8": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_3578362cbb1d41e8984a108ff3af55c1",
            "placeholder": "​",
            "style": "IPY_MODEL_a45b27ee7cb1418fb283f0ab324ce7b1",
            "value": " 2000/0 [00:00&lt;00:00, 13339.26 examples/s]"
          }
        },
        "5516c056ce474e46bd5bc1a9aa0e5f4f": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "49d21c73bade4d89a2306debfe881ade": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "ce4c462f95c74a59b82dc6dfd22428d4": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "9c4ab404cdb6408bbd712b6a8d081d73": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": "20px"
          }
        },
        "d0851dcab40c4400b85b88e117120c36": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "3578362cbb1d41e8984a108ff3af55c1": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "a45b27ee7cb1418fb283f0ab324ce7b1": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        }
      }
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "**ALL CODE, CHECKPOINTS, CONFIGURATIONS ETC HAVE BEEN ANONYMIZED.**"
      ],
      "metadata": {
        "id": "yjr1mVkGrqs5"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Hyper Hawkes Process Interpretability Experiments Reproduction."
      ],
      "metadata": {
        "id": "ocD_jCDdqt7i"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "This notebook contains a simple reproduction of the interpretability experiments presented in Section 6 of our \"Hyper Hawkes Process\" submission.  \n",
        "\n",
        "NOTE: This notebook can be ran locally, but it is intended to be ran in a Google Colab instance for portability.  \n",
        "\n",
        "To use this notebook:\n",
        "1. Copy `hhp-iclr2026-code.zip` to the root directory of a colab.\n",
        "2. Run the \"Install Dependencies\" section.\n",
        "3. You then need to restart the session (\"Runtime -> Restart Session\") to refresh the available packages.\n",
        "4. Re-run all cells! 🙂\n",
        "\n",
        "All data, dependencies, configurations and checkpoints are contained within `hhp-iclr2026-code.zip`.\n",
        "\n",
        "\n",
        "\n",
        "\n"
      ],
      "metadata": {
        "id": "PWy0pxFvq2gx"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Install Dependencies"
      ],
      "metadata": {
        "id": "PQQ9VxkZDNb-"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Clean out the Colab default sample data...\n",
        "!rm -rf sample_data"
      ],
      "metadata": {
        "id": "kKcs44leE0FG"
      },
      "execution_count": 1,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import warnings\n",
        "\n",
        "# Check if we have already ran the installation process\n",
        "try:\n",
        "    import easy_tpp\n",
        "    warnings.warn(\"Installation Succeeded!\")\n",
        "except:\n",
        "    # If not, then install dependencies.\n",
        "    warnings.warn(\"Running installation for HHP + Colab.\")\n",
        "    !unzip -q hhp-iclr2026-code.zip\n",
        "    !rm -rf __MACOSX  # Sometimes this comes along in the zip...\n",
        "    %cd hhp-iclr2026-code\n",
        "    !uv sync -q\n",
        "\n",
        "    # Also install a local copy of EasyTPP.\n",
        "    %cd hyper-hawkes-process/EasyTPP/\n",
        "    !uv pip install -q -e .\n",
        "    %cd ../..\n",
        "\n",
        "    # We still can't import EasyTPP yet.\n",
        "    try:\n",
        "        import easy_tpp\n",
        "    except:\n",
        "        warnings.warn(\"\\n\\n\\nNow select: `Runtime -> Restart Session` to refresh session with new installs.  Then run ALL CELLS.\")\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "hFm8eblsDVWh",
        "outputId": "2b6adf4b-8bc0-43c5-81de-279567f3185b"
      },
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/tmp/ipython-input-1248703467.py:6: UserWarning: Installation Succeeded!\n",
            "  warnings.warn(\"Installation Succeeded!\")\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# [Optional] Install extra options for Tex + Matplotlib.\n",
        "# This step can take quite a long time.\n",
        "USE_TEX = True\n",
        "if USE_TEX:\n",
        "    !sudo apt install -qq cm-super dvipng texlive-latex-extra texlive-latex-recommended\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "RksqDLfdhhIL",
        "outputId": "c149cb51-7931-426f-b0e3-cdc88f9555b8"
      },
      "execution_count": 3,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "cm-super is already the newest version (0.3.4-17).\n",
            "dvipng is already the newest version (1.15-1.1).\n",
            "texlive-latex-extra is already the newest version (2021.20220204-1).\n",
            "texlive-latex-recommended is already the newest version (2021.20220204-1).\n",
            "0 upgraded, 0 newly installed, 0 to remove and 35 not upgraded.\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Imports"
      ],
      "metadata": {
        "id": "8uO1UgJ5Dute"
      }
    },
    {
      "cell_type": "code",
      "execution_count": 4,
      "metadata": {
        "id": "cPMwrAgNCzsn"
      },
      "outputs": [],
      "source": [
        "# Basic imports.\n",
        "import argparse\n",
        "import collections\n",
        "import torch\n",
        "import torch.nn.functional as F\n",
        "import numpy as np\n",
        "from tqdm import tqdm\n",
        "from copy import deepcopy\n",
        "\n",
        "# Matplotlib imports.\n",
        "import matplotlib.pyplot as plt\n",
        "from matplotlib.ticker import FormatStrFormatter\n",
        "\n",
        "# We need to import some functionality from EasyTPP to run inference.\n",
        "from easy_tpp.config_factory import Config\n",
        "from easy_tpp.runner import Runner\n",
        "from easy_tpp.utils import set_device"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# Set up matplotlib and some configs to use\n",
        "\n",
        "if USE_TEX:\n",
        "    plt.rcParams.update({\n",
        "        \"text.usetex\": True,\n",
        "        \"font.family\": \"Serif\"\n",
        "    })\n",
        "\n",
        "y_label_2dp_formatter = lambda _ax: _ax.yaxis.set_major_formatter(FormatStrFormatter('%.2f'))\n",
        "\n",
        "COLORS = {\n",
        "    0: \"tab:blue\",\n",
        "    1: \"tab:orange\",\n",
        "    2: \"tab:green\",\n",
        "}\n",
        "\n",
        "LW = 1.0\n",
        "GRID_ALPHA = 0.3\n",
        "FULL_WIDTH = 5.5\n",
        "HALF_WIDTH = 2.7\n"
      ],
      "metadata": {
        "id": "4gF9Z15TSWo0"
      },
      "execution_count": 5,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Load the experimental configuration here!"
      ],
      "metadata": {
        "id": "_a8qE4oVQVFx"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Build the config up for the experiment.\n",
        "config = Config.build_from_yaml_file(\n",
        "    \"/content/hhp-iclr2026-code/hyper-hawkes-process/EasyTPP/examples/configs/exp_config_synthetic.yaml\",\n",
        "    experiment_id=\"HHP_train\",\n",
        ")\n",
        "\n",
        "# We just need to tweak the paths from the config to load the specific dataset.\n",
        "checkpoint_path = \"/content/hhp-iclr2026-code/checkpoints/train_memory_mark/\"\n",
        "data_path = \"/content/hhp-iclr2026-code/hyper-hawkes-process/EasyTPP/examples/backups/synth_ds/memory_mark_\"\n",
        "\n",
        "# Just refresh the config with the specifics for this dataset.\n",
        "num_marks = 3\n",
        "config.data_config.data_specs.num_event_types = num_marks\n",
        "config.data_config.data_specs.pad_token_id = num_marks\n",
        "config.model_config.num_event_types = num_marks\n",
        "config.model_config.num_event_types_pad = num_marks + 1\n",
        "config.model_config.pad_token_id = num_marks\n",
        "config.data_config.train_dir = data_path + \"train.json\"\n",
        "config.data_config.valid_dir = data_path + \"dev.json\"\n",
        "config.data_config.test_dir = data_path + \"test.json\"\n",
        "\n",
        "# Smaller batch for testing.\n",
        "config.trainer_config.batch_size = 1\n",
        "\n",
        "# Set the directory to the pretrained checkpoint.\n",
        "config.model_config.pretrained_model_dir = checkpoint_path + \"models/saved_model.pt\"\n",
        "\n",
        "# Set the device.\n",
        "device = set_device(config.trainer_config.gpu)\n",
        "\n",
        "# Build the runner, dataloader, and set them to eval mode.\n",
        "model_runner = Runner.build_from_config(config)\n",
        "data_loader = model_runner._data_loader.test_loader()\n",
        "model = model_runner.model.eval()\n",
        "model"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 514,
          "referenced_widgets": [
            "b58c20ef597e41658752857bc6b58518",
            "585b8c5d232f48488ad837f9daf1c053",
            "ddb53cc65b68406a9f27ef947d1a2e9c",
            "53924983f3d647cc86cb42d956ad904d",
            "fdb705c8df204372ab093694c76c2e6c",
            "c0d38bd4d94545ce895e7b6c73658a2e",
            "684706b048f640bba31a815c1c2d30a6",
            "0f2c6c3df9494be884676526e582393d",
            "3da7051088994d5989b204e7d9384d57",
            "7706dcd0bfd64f928daba54ce2a892a0",
            "9f9e40c1096f4741994f003ceac3e6b0",
            "e169553bbbc946cfa8361765b68c574c",
            "e861b4374f164a2586943adae56eb8d7",
            "5ec06dcc4a5b442391040af351bf958c",
            "7c6be4c3a43043f183d6ce657c2e56e8",
            "5516c056ce474e46bd5bc1a9aa0e5f4f",
            "49d21c73bade4d89a2306debfe881ade",
            "ce4c462f95c74a59b82dc6dfd22428d4",
            "9c4ab404cdb6408bbd712b6a8d081d73",
            "d0851dcab40c4400b85b88e117120c36",
            "3578362cbb1d41e8984a108ff3af55c1",
            "a45b27ee7cb1418fb283f0ab324ce7b1"
          ]
        },
        "id": "DsA7sx1KIrJQ",
        "outputId": "0fcc67dd-89c5-4a30-f6b0-fad71d74d880"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\u001b[31;1m2025-09-25 02:04:39,621 - config.py[pid:2642;line:33:build_from_yaml_file] - CRITICAL: Load pipeline config class RunnerConfig\u001b[0m\n",
            "\u001b[31;1m2025-09-25 02:04:39,623 - runner_config.py[pid:2642;line:172:update_config] - CRITICAL: train model HHP using CPU with torch backend\u001b[0m\n",
            "\u001b[38;20m2025-09-25 02:04:39,633 - runner_config.py[pid:2642;line:37:__init__] - INFO: Save the config to ./checkpoints/synthetic/HHP/train_2025_09_25_02_04_39/HHP_train_output.yaml\u001b[0m\n",
            "\u001b[38;20m2025-09-25 02:04:39,636 - base_runner.py[pid:2642;line:193:save_log] - INFO: Save the log to ./checkpoints/synthetic/HHP/train_2025_09_25_02_04_39/log\u001b[0m\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "Generating train split: 0 examples [00:00, ? examples/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "b58c20ef597e41658752857bc6b58518"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "3.982136819294393 3.6215410869352533\n",
            "min_dt: 6.977479126812902e-06\n",
            "max_dt: 45.50769811182144\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "WARNING:tensorflow:From /usr/local/lib/python3.12/dist-packages/tensorflow/python/compat/v2_compat.py:98: disable_resource_variables (from tensorflow.python.ops.resource_variables_toggle) is deprecated and will be removed in a future version.\n",
            "Instructions for updating:\n",
            "non-resource variables are not supported in the long term\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "IS ORTHOGONAL A: True\n",
            "\u001b[38;20m2025-09-25 02:04:59,865 - tpp_runner.py[pid:2642;line:62:_init_model] - INFO: Num of model parameters 1328\u001b[0m\n",
            "\u001b[31;1m2025-09-25 02:04:59,876 - tpp_runner.py[pid:2642;line:83:_load_model] - CRITICAL: Load model from /content/hhp-iclr2026-code/checkpoints/train_memory_mark/models/saved_model.pt\u001b[0m\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "Generating test split: 0 examples [00:00, ? examples/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "e169553bbbc946cfa8361765b68c574c"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "HHP(\n",
              "  (hypernet): HyperNetwork(\n",
              "    (B): Embedding(4, 32, padding_idx=3)\n",
              "    (softplus): Softplus(beta=1.0, threshold=20.0)\n",
              "    (A_norm): Identity()\n",
              "    (B_norm): Identity()\n",
              "    (embeddings): Embedding(4, 7, padding_idx=3)\n",
              "    (network): GRU(8, 8, batch_first=True)\n",
              "    (to_comps): Linear(in_features=8, out_features=64, bias=True)\n",
              "  )\n",
              "  (softplus): Softplus(beta=1.0, threshold=20.0)\n",
              ")"
            ]
          },
          "metadata": {},
          "execution_count": 6
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Now lets run some experiments!\n"
      ],
      "metadata": {
        "id": "5MpeF9ZaQ8P_"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Function to compute the DF values."
      ],
      "metadata": {
        "id": "t2xeQ7GQdDj9"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "@torch.no_grad()\n",
        "def df(\n",
        "    x_NSM: torch.Tensor,\n",
        "    mu_M: torch.Tensor,\n",
        "    sample_times_S: torch.Tensor,\n",
        "    cumulative: bool = False,\n",
        "    absolute: bool = False,\n",
        "):\n",
        "    r\"\"\"Function to compute $DF\\lambda(t)$, $DF\\Lambda(t)$, $DF|\\lambda(t)|$, $DF|\\Lambda(t)|$\n",
        "    as defined in the paper.\n",
        "\n",
        "    Notation:\n",
        "        N: number of events/particles.\n",
        "        S: total number of timesteps (normally $N * (n_monte_carlo_samples + 1)$).\n",
        "        M: number of marks.\n",
        "\n",
        "    Args:\n",
        "        x_NSM (torch.Tensor): [N, S, M] tensor of particles.\n",
        "        mu_M (torch.Tensor): [M,] tensor baseline intensity.\n",
        "        sample_times (torch.Tensor): [S,] tensor of sample times.\n",
        "        cumulative (bool, optional): Whether to compute the cumulative DF$\\Lambda$. Defaults to False.\n",
        "        absolute (bool, optional): Whether to compute the absolute DF. Defaults to False.\n",
        "\n",
        "    Returns:\n",
        "        _type_: _description_\n",
        "    \"\"\"\n",
        "    total = x_NSM.sum(0) + mu_M[None, :]  # [seq, marks]\n",
        "    dfs = total[None, ...] - x_NSM  # [particles, seq, marks]\n",
        "    dfs = model.softplus(total)[None, ...] - model.softplus(dfs)\n",
        "\n",
        "    # Take absolute if computing absolute DFs.\n",
        "    if absolute:\n",
        "        dfs = torch.abs(dfs)\n",
        "\n",
        "    # Take the cumulative integral (with trapezoidal rule) if computing cumulative DFs.\n",
        "    if cumulative:\n",
        "        return F.pad(\n",
        "            torch.cumulative_trapezoid(dfs, x=sample_times_S[None, :, None], dim=-2),\n",
        "            (0, 0, 1, 0),\n",
        "        )\n",
        "\n",
        "    return dfs"
      ],
      "metadata": {
        "id": "iCxfejs2dDHX"
      },
      "execution_count": 7,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Pull out some data"
      ],
      "metadata": {
        "id": "G2nQ1erWpRqB"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "We first pull out an example to visualize"
      ],
      "metadata": {
        "id": "E37k6yEXR75o"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Pull out a single example to plot.\n",
        "data_idx = 0  # Change this to plot other values.\n",
        "times, dts, marks = (\n",
        "    data_loader.dataset[data_idx][\"time_seqs\"],\n",
        "    data_loader.dataset[data_idx][\"time_delta_seqs\"],\n",
        "    data_loader.dataset[data_idx][\"type_seqs\"],\n",
        ")\n",
        "\n",
        "# We just need to add the terminal mark (artefact of EasyTPP).\n",
        "# These data all end at 100.\n",
        "times.append(100.0)\n",
        "marks.append(num_marks)\n",
        "dts.append(times[-1] - times[-2])\n",
        "\n",
        "# Make the final tensors we need.\n",
        "times, dts, marks = (\n",
        "    torch.tensor(times, device=device),\n",
        "    torch.tensor(dts, device=device),\n",
        "    torch.tensor(marks, device=device),\n",
        ")\n"
      ],
      "metadata": {
        "id": "6Kh2Jg7PR6Ku"
      },
      "execution_count": 8,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Now we call the subroutine in the HHP that computes the exploded particle view that we will interrogate."
      ],
      "metadata": {
        "id": "4Nlm2yZqSACi"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# The HHP model has a `.attributions` method, which runs a forward inference pass\n",
        "# on a given set of `dts` and `marks`, and returns the particle-view of the system.\n",
        "mu, attr, sample_dts, sampled_xs = model.attributions(dts, marks)\n",
        "\n",
        "# NOTE - remove the right limits.\n",
        "sample_dts = sample_dts[:, 1:]\n",
        "attr = attr[:, :, 1:]\n",
        "\n",
        "# Reshape for convenience.\n",
        "n_pts, _, n_samples, n_marks = attr.shape\n",
        "particles = attr.reshape(n_pts, -1, n_marks)\n",
        "mu.shape, attr.shape, sample_dts.shape\n",
        "sample_times = (times[:-1, None] + sample_dts).view(-1)\n",
        "\n",
        "# Recapitulate the final intensity from the particle view.\n",
        "with torch.no_grad():\n",
        "    intensity = model.softplus(attr.sum(0).view(-1, n_marks) + mu[None, :])"
      ],
      "metadata": {
        "id": "NW4K3OoBN-fV"
      },
      "execution_count": 9,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Plot! :)"
      ],
      "metadata": {
        "id": "zzAYKc62dIWl"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#\n",
        "# Set up the figure.\n",
        "#\n",
        "fig = plt.figure(figsize=(HALF_WIDTH,3))\n",
        "gs = fig.add_gridspec(3, 1, height_ratios=[3, 3, 1], hspace=0.1)\n",
        "ax0 = fig.add_subplot(gs[0])\n",
        "ax1 = fig.add_subplot(gs[1], sharex=ax0)\n",
        "ax2 = fig.add_subplot(gs[2], sharex=ax0)\n",
        "xbars = np.linspace(0, 100, 11)\n",
        "\n",
        "#\n",
        "# intensity curve\n",
        "#\n",
        "for m in range(num_marks):\n",
        "    ax0.plot(sample_times, intensity[:, m], color=COLORS[m], lw=LW)\n",
        "\n",
        "\n",
        "ax0.grid(alpha=0.3)\n",
        "ax0.set_yscale('log')\n",
        "ax0.set_ylim(0.03, 0.5)\n",
        "ax0.set_yticks(*[[0.03, 0.1, 0.3] for _ in range(2)])\n",
        "ax0.set_ylabel(r'$\\lambda_t^{1:M}$')\n",
        "ax0.tick_params(labelbottom=False)  # hide x labels on top panels\n",
        "\n",
        "#\n",
        "# DF lambda curve\n",
        "#\n",
        "c = df(particles, mu, sample_times, absolute=False, cumulative=False).sum(-1)\n",
        "for i in range(c.shape[0]-1):\n",
        "    try:\n",
        "        ti = np.cumsum(dts)[i]\n",
        "        mask = sample_times > ti\n",
        "        ax1.plot(sample_times[mask], c[i][mask], color=COLORS[marks[i].item()], linewidth=LW)\n",
        "    except:\n",
        "        pass\n",
        "\n",
        "\n",
        "ax1.grid(alpha=0.3)\n",
        "ax1.set_yscale('linear')\n",
        "ax1.set_ylim((-2.5, 1.7))\n",
        "ax1.set_yticks(*[[-2, -1, 0, 1] for _ in range(2)])\n",
        "ax1.set_ylabel(r'$\\sum_{m=1}^{M} \\mathrm{DF}\\lambda_{t}^m$')\n",
        "ax1.tick_params(labelbottom=False)  # hide x labels on top panels\n",
        "\n",
        "\n",
        "#\n",
        "# Event plot.\n",
        "#\n",
        "positions = np.cumsum(dts)[:-1]  # Drop the final terminal event (an artefact of EasyTPP).\n",
        "color_list = [COLORS[m.item()] for m in marks[:-1]]\n",
        "for p, c in zip(positions, color_list):\n",
        "    ax2.plot((p, p), (0.1, 0.4), color=c, lw=LW)\n",
        "\n",
        "\n",
        "ax2.grid(alpha=0.3)\n",
        "ax2.set_yscale('linear')\n",
        "ax2.set_ylim(0.0, 0.5)\n",
        "ax2.set_yticks([])\n",
        "ax2.set_ylabel(r'$\\mathcal{H}_t$')\n",
        "ax2.set_xlabel('Time $t$')\n",
        "for spine in ['top', 'right', 'left']:\n",
        "    ax2.spines[spine].set_visible(False)\n",
        "\n",
        "\n",
        "#\n",
        "# Add zoom indicators.\n",
        "#\n",
        "X_ZOOM = (30, 70)\n",
        "ax0.axvline(X_ZOOM[0], c='k', linestyle='--', lw=LW / 2)\n",
        "ax0.axvline(X_ZOOM[1], c='k', linestyle='--', lw=LW / 2)\n",
        "ax1.axvline(X_ZOOM[0], c='k', linestyle='--', lw=LW / 2)\n",
        "ax1.axvline(X_ZOOM[1], c='k', linestyle='--', lw=LW / 2)\n",
        "ax2.axvline(X_ZOOM[0], c='k', linestyle='--', lw=LW / 2)\n",
        "ax2.axvline(X_ZOOM[1], c='k', linestyle='--', lw=LW / 2)\n",
        "\n",
        "\n",
        "#\n",
        "# Clean up and save out.\n",
        "#\n",
        "ax0.set_xlim(0, 100)\n",
        "fig.align_ylabels()\n",
        "# fig.tight_layout()\n",
        "savename = f'./combined.pdf'\n",
        "plt.savefig(f'./combined.pdf', bbox_inches='tight', pad_inches=0.01)\n",
        "print(savename)"
      ],
      "metadata": {
        "id": "lStDGVvmZpsW",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 324
        },
        "outputId": "1dadec4f-5505-4297-b75b-919cc038b877"
      },
      "execution_count": 25,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "./combined.pdf\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 270x300 with 3 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAASkAAAEiCAYAAAClXiRBAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAWY9JREFUeJztnXl4G9W1wH8jyZZ3yWtWJ7FCSJqNxEvYAoXEadgKhThJKRQoTWwCLWV52KR9PKAtZGkptIWSjQKFtkls0rJD7AQIO7YVQyCQxYoTZ7VjW94XSTPvD1mKvNvyjCQ78/s+f5JGo3uOzmiOzz333nMFSZIkVFRUVAIUjb8VUFFRUekN1UmpqKgENKqTUlFRCWhUJ6WiohLQqE5KRUUloFGdlIqKSkCjOikVFZWARudvBQIJURQ5fvw4kZGRCILgb3VUVIYckiRRX1/P6NGj0WjkiYFUJwU888wzPPPMM7S1tVFaWupvdVRUhjzl5eWMHTtWlrYEdcb5GWprazEajRw+fBij0ehvdbpFFEUqKyuJj4+X7T8VwCuvvMKiRYtka69PPUt3wtZbnM9XHpVNbn+pb7Fx4aqdBGkF3sk6b+jbUwFqm2xcvGYnAF8/urBfn7FarYwfPx6r1YrBYJBFDzWS8sDVxYuKiiIqKsrP2nSPKIq0tLQQFRUl64911KhRsn7nPvUMDwV9e5faD7aWgmxo9GFodRoiIyOHvj0VwKFtQ6MPA+j3dxFFEUDWdImaOFcB4G9/+5tvBfo7gG8Xr1Eo9ehzeyqA6O9r1I7qpFT8gyT6VbzrBtSoAyQ9EhguSnVSKu08/fTTPpbo31vA5aSUclG+t6f8qJGUSkDx3HPP+VagnyMp1+2n1FQTn9tTAQLER6lOCpxTEKZOnUpaWpq/VfEbu3fv9q1AP98B7khKoVDK5/ZUANVJBRB33XUXe/fupbCw0N+q+I0xY8b4VqBHJNXUZvetbM7cgErlpHxuTwVQu3sqAcWTTz7pY4nOG0CUBPL3nvKxbE8npUz7vren/KhOSiWgWLJkiW8FtkdSEnCwosG3slE+ce5zeypAgPgo1Ump+In2O0BEw8naFp+LP5OTUqcg9ITqpFQCioyMDN8KbL8DJKCivtW3ss+IVyxx7nN7KkCgdPeGxLIYi8VCXl4eJpMJi8VCZmZmj2vrCgoKAOcaosLCQpYuXUpycrIPtR2ajBs3zscSXU5KQ6UfnZRSiXPf21N+AsNFDZFIavHixWRnZ5ORkUFGRgbLly/v9dyYmBgyMjKYOHEiixcv9qGmQ5c//elPvhXokZOqbPC9kzoz41yZ9n1uTwUIlEgq4J2UxWLp8NpkMrmjpe7Izc3tEDkFajWDsx6PnJRfIqn2RzUn1TMB4qMCv7tXUFBATExMh2MxMTGYzeZuu3Hp6enu57m5uWRlZfXYdmtrK62tZ26Quro6wLmS27WaO9AQRRFJkmTX7w9/+IOsbfapp+hAwxlnUdfcRoTedz9Hh8MBOEf3hoU9FcBTVn/lKqFfwDspq9Xa7fHq6uoeP2M2m9myZQsLFiwgMzOzx/NWrVrFo48+2uV4ZWUlbW1tA9bVF4iiSG1tLZIkyVqy48UXX+Tuu++Wrb2+9Aytq8WAM5IC+K7sOOOiQ2ST3xeV1c1uPa1W65C3pxJUVTW7n1dUVPTrM7W1tbLrEfBOqid6cl4AycnJmEwmcnJyyMvL63GkZeXKldx3333u13V1dSQmJhIfHx+w3URRFBEEQfbiZ3v27CEhIUG29vrU81gEcCaScgSFk5AQK5v8vqiV6gEI0mkxGo1D354KUCPWu5/397sEBwfLrkfAOymj0dglaqquru7TiRiNRhYvXsyCBQuoqanp9ny9Xo9er+9yXKPR+OyH4A2CIMiuY1xcnOzfeSB6VjbafGtzwSlLEIanPWWR5zGq0F+ZSugWuHdiO545Jk9SU1O7HCsoKCA6Otr92mQyAV2T7ypdef75530r0L12z3kjVNT5dkKnhLKTOX1uTwUIlMR5wDspl6NxYbFYSE1NdUdGZrPZ7YRiYmI6ODWz2YzRaFTnSfWDa6+91scSz9wBcRF6n09DcOV3lRrb87095SdQnFTAd/fAOUqXk5NDWloahYWF5Obmut9btWoVaWlpZGdnk5yczNKlS9mwYQMA+fn5FBcX+0ttld7wqIKQEKmnss63TkrpSGo4ECjzpIaEkzKZTKxZswboutzA02F1fr+3kT2VjlxzzTW+FehxAyRE6X2+NMa9LEah9n1uz2FMwHf3VHzD9OnTfSvQw0mNiAyhot73i4xBubV7PrenAgRIIKU6KRUnq1ev9rHEwIiklFq753t7yo8UIKv3VCel4h88clIjDSFYm2w0tvquQqfS9aSGA2Jg+CjVSak4eeyxx3wr0N2XkEiKDQegrKqR8uomMp79RPGSwu77TyEv5XN7KkCgbG6uOikVALZv3+5bgR6R1IS4did1uomtReUUHa6hsKxGWfEKF73zuT0VIDBclOqkVNr54IMPfCzxzC0QHRaMITSIsqpGRhlCAThhda4bcyjU53C1qlSpFt/bU34CJJBSnRSoW1oBRERE+FZgeyQVJTSjLfkHprgwDpyqJyHSuUzpmLWZ976rYOKv31KkvLCkcE7K5/ZUAM/uXl2LzW/dP9VJMTS2tGpqs2N3KFem41//+pdibXeLxw8++K17uMGwn5Jyq3tKwLGaZgrLnGs2Syvl36jBJf5UXSuHq+V3gj63pwJ4uqTk3+bzVMEBv+ihOqkhQsazn7Lpo0OKte9ZwXTnd6c4cKq+l7NloNMOxpfaPqKsqomqRmeJnKPWZiJDggCoa7bJL779saqxjaX/+Eb29odDRVjPwMkuSvx15wEOnW70uR4DdlLbtm1TQg+VPjhV10LxYeWSyZ7F/25/oYgFT+5STJaTjl2HsRXvo0Hkk4OnAWckFRfhLPtxWoF1fUr3XDztOVRxde/0tPE/cZ8xPkrDY2/u9bkeA3ZSy5YtY+HChfzxj3+kpKTEfdxV1VJFGVpsDvYrGN0sWLCgy7HaJvkjGDcekZRjxlK0zVVkJJzgzT0nAGdOyhDqjKQqG+QvQNg5vyJ3vqU7eyrFX3Yc4IP9lbK36xqzWKz9gF80/IX1Sbso+LaClz4t82l+asBOqri4mMzMTJKSkli3bh2pqamkpqYOi/A2kGmxixypblJs/tDFF1/c5Zj5iILTADx+4w7TfAhP4OboPdgcZ944Ut0EnBnpk5POg4anZXaE3dlzIDS3OXjh40O02Bx9nvun/P3c+vcvBiWvO1wzzqcIRwCYdOI1bjk/kYde/Ya/7Dgou7yeGLCTSkpKYtGiRRiNRnJycigqKqKoqIjZs2croZ9fOHTa9zvq9obNITKHrxkhVXFAod1+H3nkEffzh0O2MEOw8Pmhnks0DxrPnFRwBEy5iuk1O9BxxgnvOeYsRbv3hPxReuclH3LnWjzt6Q2FZdU88vpe1n/gLEN0oraZEx6VIt7ec4IJD76pbETT3vRooYqmoGiE2qP8dtoJvjcqCosP7xGvE+fz588nJiaGnTt3As5SvMOFzywK3pxe0GJz8O/gx3hLv5L9p5T/cfyMV3ld/798ZqlSUIrHzRUcBmnL0dQdI/eCw5jiwhkXE8au9i7MN8fraLPLPLLZ6d5WNGr0Alv7SO77+521xS9e8z7X//1r9/v/+sIZ3XhGgDaZR39dJholVHFk1EIYmwbvPU5cSN/RnZwManTPYDAwb948Nm3aNKzqNn11VP5i8oOhxeb88cUIDew7qUxe6qGHHupybN+xShqUWk/nEUlJQWEwcjrMWMzsb//Izh9U8JNJDmo8cmIfl56WV3yn158fktdJdWfPgeDq9u4+Yu0wodUVOU0bbQDgC49o973v+rdZQn9xrW+MFJrRhkXDFWug4lueP7GIy6pz+/i0fHg1urdy5UqWLFlCamoqCxcupKioaFiV6JXTSUmSxMGKBjZ/cYT7t37JZX94b0AjJLXNNooOnUmK7j+pzADFF190zWmksZe39pzg5k2fc9/WEnnnaXl2U4LCnI9X/REiEmDbcjK/uRkBp7zY8GA2t0cOctG5oNsnpaeplXGqQ3f2HAh2j62h9h6vI1jrnED2Sakzuh1jdO6s89edBxgZ5Xz+4qdlg5LZGZeJwmkhODQSxqbAio/RYSexZZ+ssnpjwEXvsrOzWbBgAStXrhxWeShPymuaqWpoJTai6yYN/aG6sY2PDp5m1/5KPjxQyam6VjQCTB0dhWi38d3x3p1gi83BayXHefnzw+w5Vkuk1MiV7bs9nTx2BLs4wSu9euPdd9/lrrvu6nDsRuO3rMj7yv16bHQY9y04Vx6Bnjkpl5MKNcKsG2HHb9HYm3ngnGOsPZjIL+adw6Ov7+XrY7VMH2OQR7yHjzo3PpTSqhZyi8pZdknHctWiKHGwsoFzR0QOqP3u7DkQ7A7X2kJnFHnROXG8v6+SR1/fy5u/inVHgt+1R9amuHA+PljF3uN1TB0d5bVcT1wywmihNbz9+8dN4pvgmbK0318G7KRyc3OZPXs2O3bscM+ZkiSJoqIiVq1aJbuC/iCBGkrKrcz/3oh+f+ZUXQtv7znBW3tOUni4GkmCKSMjuWFGDFcYjzKl9Wv0xz6lrfpzPq+ZC3Scb9Zic3CkuolXS47x78+PENx8ih8n1vK7WdVM4Dh86zxvdFspXx5LZvTI/uvWF42tdhptEq8UH2V/RT0rAYcmmMsEM7AUELhu1mgK9p6Sz0l1yEmFnnkeNcb5GBTGitCdZPz6HxjDgtlSWM69W0p4555L0cqw4M4zjoqPCCY1KY4/bt9HXbONkYZQwvVawoN17DtVzx/e3ccbv5w7IAep0w2u6K0rv3TxxDh2fldBWLCWsQY9ZVVNrP/AgjEsiGCthiumj+S1L49z1YxRbDMfZeOHFp5cOmtQsl1IkoQOO3rBTmi4PI7PGwZsSVf0NH/+/A7H8/Pz5dEoAMgKKaD48KV9OqkWm4N3vj7Jv784whdl1eg0AnMnxvK3hZHMZTeRR96Dkk/A0QohRhh/ETVBCRjtZ/II9c1tFP71p8xs/IRmKY50IYi7dCcI09dBBWCNAJ0eoidATRlXhO1na0kFV6ZM7Pf3kSQJa5ONY9ZmjlmbOW5t5mhNMwcrGjhY0cAxazOcdwf3537J6Cg9K4GWc64mfP9/eGpOHaeNM4k/9BpNDlOfsvqvlGck5eGkZi6FxDlQ9jHCa78kwVoCURfwy3mTuOtfZirqW9yLkAcl3iOUEgT436u/h80h8Y/PDlPbbOsy2fP1L48PyEkNdtKzvT0PtTh1LL/aXMIoQwiT40O5ZtYYnt55kEUpY0GA7Csm8843JwkN1vKzi5N47K1v+e1109yz9QeDJEEYzhHFsIgh5KR6wlWDfDhwjfARt399mAcWTu62lMdxazMvfFJGblE5NU02LjTF8uzCCC5r3kHI/lfh/TLQ6mHCxZD+CCRdCglTQaPh2BM/Iqj1TJL23XdfJ6PpHfYnZjBSD7GhWnTxGTBiujOZbEg8U+P2v3fyw4Of8OvSGh7ctofU8TG02h3Utdipa7ZR22yjrqX9sdlOXYuNumYbdS32DsnXYJ2GMYYQzou1s3xiHVODK1j7p7/x7xWzCaophVMQPnUhNJTxo5N/BWEWlP+LibppwI/lMbKnF9B6dKsFAWJMYBgH5hdhy81wz9dEhMhbjt/TB2mAkCAtf1h8XrtqEi02kfoWG+YjVu54uZjnPykjXK/j7vmT+tX+zTffzMsvv9xvfRyiRFlVI/tP1rPvVD3vfVfBL3SvcpW2jSdijBypbiLREMTd887h/X2V/Ls9Rzc2Ooz/3nkxY4yhfH7Ima/ynGs2GCQkwnCuawwKGQZOymCQJ1cQCIRLDUyr2cHHB1OYOynOffy7k3Vs+MDCa18eJyxYy62zDdwSZSb+4J/g/SJntDTtejj3Cki6BILDuzYuCNQ227hv825CgyDW/BaNweGce/sG0Gh7V2zWTUSW/JO/TT/AI/tC2Fp0FJ1GwBCiJUlfz1h9I6OC7UzV2TBG2DEaWjAITRhoJJJGDEIjEW2VBDUcR6g7BkfOLKxtO+0gqGW8M4qZ/VOYcjWMngXrL4UKZ6I/VJJxUqVnJKXt5r++Vgdz74PNN0LtURDlrSrgiqQShVM8eyIT4f27YN6vAWeNqdBgLaFiI1eEH2Dfsiju+jiEP+Xv59PSKsZGh/L9yfFcPjmBcH33t1BPKzAcokR5dRMHKxo4UNHAgVNOp1RZcYJJooXpQhmzg49wj/Sx8+58ZQv/vHg1l+wYx6goPSFBWrbecSFrXv+SxhYbNFUztf5ziL6AiNr9TBfkG8CSJAgX2n8j3f2WfYTXTmrSpEkcOHCgx9dDGSnpUrIq3ufWvIX8+urv0dhq542vTvDhgdMkRgXxzJwq5rcWoPvqbRDtcE46LH4RJl/p7Jr1wumGNqZrTpCzfwkjxAoIghZddN8OCmD8RUhTfsiV+x/jStP3kWwtaOqOOW/iZht050OCwpzOM8TgTExHjIAx5zkjNMMYMIyFmIlcEr4ebnug42dDomDcBXBoFw06o8xV0DwaE3oYZA41Oh+fTuHioAge050P4vflkd4u/h7dNsKlBti1BqbfAAlT4Phu+PAJ+O5NkET0wP8t20vBtxXUtdjYc6yN3OJy9Dotl54bz4WmWJLiwzGGBhESpMXmEBk3NZl3vj7pnIRZ28KxmmZKKxsoO13PSMcJJgvlzAw6xlJ9OedKh4jWnXLqFRSGMHImNE6E6lJI+RmJHz/I/tk3UD3uKoR3XiFq31s8VlvebptYaHJGUBcBb+ihuvUnED74LeslCULbu3tD0kl1dkjDxUEBSMm3MemNn/NTfT6/+Jfzzl86tprt08xMOvU2QslJZ/dt/kMwYwlE9j+JPTY6jNFV1UiRiXDxH+Gt/0Gv6efkOEFAun49jTv+SETNN2giR8KY2WAc73Q6EfHO2dtBYc4fVXAE6IL71fTVV1/d/Rt1zrV01fqx0NLUPz37g2dOqKeqTmHtN9rImVSGT+am0lxONZ6C6MFHVS7xk4Sj1OliiYwyIOTdDnGTYO9/IfYc57wgWyMUPMK4pq85cOV3BBlGwY7fQsgJGvQJHCofyTcHE/jIMYJjUjyNhNAqBdFSbeU//3qWEdp6JodYuVRXzQROMDK4DJ3ojE6k0BiEUTNh5FIYdR6MOg8hxtTxH5YkgWEMwTt/z8hvtyFp9ZC2DE5+BWUfgr0NBC1IDhojkwivP4TgkGeJjyhJhA9lJzWsmTgf5mSy4otnyUx4A8HejOb0aWiMgRmLYdZPnD8qL0rPTh0ZAVUgJN8CybfCW/+DEB7X9wddBIXSmJxFeEICgka+SjsPPvggr732Wtc3Gp0TBBt0MeiR10k1ho7mWuu9vN3TOfGT4eZXIPECKj99l1Gl8k0gdLnIcFrYF5tOyg/vQHj9bji9H655ytnl1epgX7t2/1qCu1M6fRFMmEtE7TFmVB1gelUpUtXHaOxnQtlrP2hi/Y1hSIIWIWwMGBMhOgUSfgojpkLCNISIhL5/Q4IAlz6AVF6IcOBduOiXzn+O5YXwXLrzeWMlHPqQg2N+zHmf3SOrjcKGcnevMyUlJcyaNUuu5vyLIMCVa2HSQrSHPnBeoHEXwPiLu8+fDITq9pxB4vnOtkbMcCbXA5UW55yuRl00eo7K164k4tCGUiqN6f28c9Llk+mB52zq00Hhzvzbio+6ObOTE4kaCzds7BDtCIAgitBihbZGsLfA53dC9hYEfZTT2Q2WUbMQD+2COVlOjRLT4O7dEJ3kdnTi9v4n6vuDJDmdODC0nJRneRZPtmzZ0sVJlZWVMWHCBAB27NjRZdpCf7FYLOTl5WEymbBYLGRmZmI0Gns832w2s3z58sEt1REEmJTu/JOTmjLnY+xEp4xubwzfk52d3ev7otCPnNmAkJD8uMW5q7sXRgtSUC83YGcdp17bff5Qo4GwGOcfkP2bh93P5UD6fjaVpuuJ94y6Y2ScEtK9VPS0z8LXhSgsq2cG7KQ2b95MbW1tl9G83bt3u5/fcccdCIKA0WgkKyuLCRMmMH/+fLZt28YNN9wwYCUXL17sdjgWi4Xly5d32V7dhcuZmc3mAcvxCS1W52PkKL+q0Zl9+/Yxd+5c3wmUJPy7652EgEiE0ILUW5TQ1D6nbU4m6KNg7j39al12ewoapJBo+drrBx3L2fjvWg3YSa1cuZKioqIuUdGOHTvcz9etW8fu3btZtWoV2dnZWCwWYmNjMZlMA3ZSndcEmkwmCgoKejw/IyNjQO37jf6M5vmQV199lZ///Odd39AboFWJBdf+j6RcExWF3pzU2DTnnK1L/mdAAyQ92nMIESi7xQzYSRkMhm67bZ2PzZ49mzVr1pCUlOS9dkBBQQExMR3D5piYGMxmM8nJyYNqu7W1tUOZV9fcFlEUET0WeMqJMH0RHN+N5GX7oigiSZLs+vXY5i/NYG9Bevkht/z+0JeegujA9d9ZkkT6atY1r0mua+MQRfdERYLDe24zxgS/+pJ24f1uX+5r1J/rLnmcK4dszzZESez4/XvQRYn7RtHRvd27dw/aSVmt1m6PV1cPvubTqlWrePTRR7scr6yspK1N/pK1AMx93PlY4V1ZDVEUqa2tRZIkNDKO7q1bt46KHnXS4bDbkSSpl3MGpmdUUxOO9vVplRWV6LS9R1WNDc46WtaaGoTgwZcksdbWEtE+ctUqaqmoqPChPQdOf657U6OzcF91dTU2afCRurX2TARdUVEBGqe7ECUJh0Ps9vvV1sofdcvupHbu3Mm6det45ZVXyMjI8CoH1R96cl4DYeXKldx3333u13V1dSQmJhIfH99rYt6fiKKIIAjEx8fLelMtX76cjRs39vh+mU6HIAgkJCT0q72+9BRCQ2htH/WKT4gnSNv7dznVvo+dMTq63zr0RtRJh7u7F2GIJSEhwaf2HCj9ue7Hw53d1piYGKLjB2+jyBNnaoklJCS4nVSVIKDVarq9DsHB/ZuXNxBkcVIlJSWsW7eO3NxcTCYTS5YsYePGjbIslTEajV2ipurqalmciF6vR6/vOkNco9HI+oOVG0EQZNexsrKy1/Zccc5AZPapZ3tOqj/fRRjAuf1UjqD2UsVBwSE+t6c39GVPz2skh2xBEBAEZydSI2icI5hn3uxWhhL3jdct1tXV8eCDDxITE8PixYuZOHEiq1evZvXq1TzwwAOyreVLT+9+CkBqaqos7as4mTNnjo8lSkh+HDFylSEBCFLgv7/v7Sk/QzZx7iIjI4OUlBSKi4s75J02btzIoUOHWLZsmSwKmkwd54JYLBZSU1PdkZTZbMZoNHY5D5xdwv5EXM888wzPPPMMDodvazcHEjfeeKNvBUqSO5Lyh6uSJAgSnNc7KGjwZU0643N7KkCHzSr8OBLrdSS1fv16Vq1a1SUxvnz5ciRJYsWKFYNWzkVubi45OTnk5eWxfv36DnOkVq1aRV5envt1QUEBOTk53b7XE0Nhm3Wluffee30rUBLx59wbCYng9kgquJsu/2DxuT0VQKEB7gHjdSTV26jd8uXL2bBhAwsXLuTdd9/1VoQbk8nkrlfVeR5U50md6enppKenD6v6VsMTf3f3cOekgoPld1LDgQDp7Q1ut5jeyMzMZOvWrUo1ryIzv/rVr3wrUAI7IOj8s/O1JIEOZ3dP0Mqfk/K5PRXAl7sU94ai86SGSiE8NScFJ06c8LFEibyQViImPU5VczojIuJ9LB13d881tC4nvrTn1n1bOVJ3hJn2wZdV9qR9+iwNgoC8JQcHRuCOs/sQNSeF76NeSaKxvbf3ysG+84ZyI0qSu7snaeRPnMttT7to51D9IZrby8HUtNTwyCeP8FTxUzxlfooX977IQ6ef54NQ+RYCS5LEgdgDXDghkWv+ey1PFT/FsYZjsrXfX9R6Uipd+LbqW1458AqJkYnMjJ/JtNhpCkiRiJCc/yPz9ueyfOYyghRwFr2IJ0hQLpIaLLWttfzPB//D+Kjx3JtyL+tK1vHC3heILo7m9um3ExsayysHXnGff/P3bmaP5RPuHdHC6/Zm5FiKLElg1zhtlDIihS37tvDc189hHCnwo+ZgfDUJKPCujoqiSJJEbWstp5tPU9lcSVVLFdXN1VycczEPffwQ1S3V7Dq6i2h9NM32ZloczqUj48LCSBMdPCKbImeGjiqbK9lxeAdXJF3R4RSbaKOkooTUEfLfDhISOhy8HRbOrm//wv2G+4kLG0DxwT7YvHlzv8+1iTbqWuuobaulrrUOa6uVL05+wWcnPuOzE5/x0bGPONZwjKigKOYlzuPP5j8jIiIgsD1jO89//TxXJV1F7Mkmvmy10CbKs6RLAkLsIRgdDh698BFy5jzIrqO7eGDXA3wXJGO9+z5QnRRdc1IlFSVcZrzMq7Zsoo2q5ioqmircf5XNlWeeN1WycMJCVszq3xQNm2jjeMNx3i17l8qmSi4cdSGJmkTiJWcOR5Ikmu3N1LXVOf9a66hpreF082lON5+mqrnK/fx082mqWqqwix23Tg/ThXHypZPMvXsuMSExLDl3CVnnZREdEk3yS85F3Ee0TQhypjwk5+ie5NBz0dgUnjI/xYWjL8Qm2lj27jJunnozcaFx/HLnL7nadDWLxPNkFO6MEoKx83Z4OO+Vv0FRVRFPXPYEM+MHt/Fli70Fa6uV++6+j1/87hfUttZS01KDtdVKTUuN83Wr87G2tZbatloabY3dtjUpehJ/vvzPrC1cy7GGY1yUcBH/d+H/8fOZP+e10tewi3ZGho9k5fkrAfgcebvNnfPmYUFhXJF0Bc/nr5RVTl+oTgpnTuquu+6irq4Og8HAnTvv5AfHfsCPzvkR50afS0RwBAICdW11WFusVLVUUdnU7niaK848b6qguqW6wyQ4nUZHQmgCCWEJxIfFc7T+KOaKnmtdNbQ18OmJT/n0+Kd8U/UNB2oOYBOdhcdiQ2LZvM/5H9rVNRIlEYfUNeGvE3TEhsYSHxpPXGgcU2KmEBca1+EvNjSW2JBYwoLCuHbLtfzzqn92aeeRCx9hz+k9VH+zizIqu7zvPZJ7mtSvz/8NP337Jpa8vgSD3kBpbSmPfvooE6ImAPCm5U0+137ELYZIrpRpxElsn4JgFzSYIkxEhkZy01s3MdEwkbiwOCRJwi7aabA1oBE0/OXyvxAdEk2ILgSbw8aXlV/yTdU37K/Zz8nGk5xoPMHp5tPunNFh82H25O8BnNcqWh+NIcTgfNQbGBc5DoPegEFvICo4CqPe6H7tOhbcPur413l/xdpspa7GORKaGJnIXbO83x25/zY6C0b3hioPn/8wL5e9zC93/rLHcwQEYkJiSAhzOqBpcdO4POxyt0NyOSWj3uhc99RO9q5sqpurkSSJU02nON18msnRk9lZvpP/HPwPn5/4HLtox2QwMSNuBtdOvJZzjOeQZEgiISyB0ppSig4X4dA7EAQBraAlPCicqOAoovRRRAZHum8ETU+7sHTDeed1H6ksOncRi85dxN3fzOu/AfuDR9G7cZGJvHzVy6z7ch17q/aSOiKVtJFpPPvls2gEDZuv3kz29rv5U0w0c9pqGCmHeCQkTQvf6nWkGCbx2PcfI788n5KKEmpaatAKWnQaHaebT/PpiU/5wSs/AOAa0zV8UP4B9bZ6QnWhTDJOYnTEaKbFTnNf7+iQaF7+6mUeWvQQRr2RMF1Yt/s3DoQofRQtmpa+T5QRCb9ONHejOqluWJi0kCWzlnC0/ihldWU025uRkNwOIDokmtjQWK8SvXbRzucnP+fCf1/YJcyfFT+LB1If4PuJ32dMRPe1v5MMSYSPDJd91X5WVpZsbfWPjv+lx0eNZ9UlqzocWzZjGc32Zgx6A0uN6aypeBlJkmcatCTBe6P3cVqn4SbTTQRpg7jGdA3XmK7pcu6+6n0UnSpi9Rer+eT4J9w89WYuT7ycSdGT0PWQdJ9w74Qer+GQQfLndNszqE6qBwRBIDEqkcSoRFnb/bLSWUDttmm3YTKYuP+D+wF46cqXmJUwS1ZZA+HOO+/sfrcYpehH+eBgbbC7yyO7eKA+qJXRNpFRYb2Xcp4cM5nJMZM5f+T5TDBM6NExeeJzeypAYHT2VCcF+HYy55OXPUlVcxWXj7vcWe0QuGj0RX51UH5BEv17E0gS0bZgZgb1/5qfE32OggoFHqIYGG5KdVJ0TZwriefokUbQkPfDPEwGpXf96Bt/d/d8jSiBRpB63j15kPjenvITGC5KdVJ+Z3LMZH+rAEBTk4wbf/YHSUJSyEH0T7yEgHJOyuf2VABnNZ32LvlQLNWiMrx46aWXfCzRY5t1P/z+nRkx5ZyU7+0pP4ESSalOSsU/+HnfPUkCDf7e+y+wcUebfkZ1UioAvPDCC/5Wwae4JyoqFMYNB3s6TeR/J646KZyje1OnTiUtLc3fqviN3//+974VKNN8p0DF5/ZUAMljVYA/UZ0UaqkWgIMHD/pWoOT/ypxK4nN7KoAkoXb3VAKHyZN9Pcp45r/0YJeMeCdd2ZvP9/aUH9c0KX8HU6qTUgFwb17hMwIgca4kPrenAnTo7qlTEFT8ze233+5jif6fzKnkbed7e8qPFBgpKdVJqfgJf+ekAiDXMhRQnZRKwHDbbbf5VqAk+rULoXR3z+f2VIBAWbunOinUKQigzC6+vRMYN4BS+N6e8uO8Qv6PpVQnhToFAWDjxo2+FejnxLnSUYLP7akAzrV7/tZCdVIqfsO/kdTwjuPkIVDydqqTUgFg3bp1vhXo78S5wvefz+2pAEqPgPYX1UmpAPD000/7WKK/Iyll70Df21MBAmQjBtVJqQDw9ddf+1agnxMeSs8B8rk9FSAwXFQAFb2zWCzk5eVhMpmwWCxkZmZiNBoHfG5BQQEAVquVwsJCli5dSnJyso++xdBl/PjxvhXo5//SksLyfW5PBQiQQCpwnNTixYspLi4GnE5o+fLl5ObmDvjcxYsXs2PHDtLT06murmbx4sWUlpb65ksMYR5//HEfS/T3ZE5l8b095UeUJHV0z4XFYunw2mQyuSOigZ6bm5vbIXLqKRpT6chNN93kW4HDfO2ez+2pAAESSAVGJFVQUEBMTEyHYzExMZjN5i5dtb7OTU9Pdx/Pzc3ttSB+a2srra2t7te1tbWAs6sYqIiiSF1dHcHBwbLuu9fW1tbr925rttOGo9+26UtPoamNFsAh9K/NpsZmHM0OauvqZbk+TQ312JodtIr4xZ4DpT/Xvbmp1Wmj2lqs4YOX3dRQT1uLDbu24zWyNTtok+zdfj/XMTm70wHhpHq6mNXV1V6dazab2bJlCwsWLCAzM7NHuatWreLRRx/tcjwpKal3hYcp0dHRfZ/zq77PGbDcX/S/zbkskF3+n1GmrEp/7KkEs7lA9ja7u0b/uLfn71dVVSXbzksB4aR6YiD/iTzPTU5OxmQykZOTQ15eHhkZGd1+ZuXKldx3330d2hg/fjxHjhxRfGsrb6mrqyMxMZHy8nKioqL8rU6PqHrKy1DRs7a2lnHjxnXp7QyGgHBSRqOxS9RUXV3dbT6pv+cajUYWL17MggULqKmp6bYtvV6PXq/vctxgMAT0DwEgKioq4HUEVU+5GSp6ytl1DojEuWceyZPU1NQBnVtQUNAhxDaZnJtudk62q6ioDB0Cwkm5nIkLi8VCamqqO/oxm81uR9PbuTExMR2cmNlsxmg0qvOkVFSGMAHR3QPnSFxOTg5paWkUFhZ2mCO1atUq0tLSyM7O7vXc5ORkli5dyoYNGwDIz893z6fqD3q9nocffrjbLmCgMBR0BFVPuTmb9RQkpafeDiFEUeT48eNERkb6ZXMAFZWhjiRJ1NfXM3r0aNnyUgETSQUCx48fJzEx0d9qqKgMecrLyxk7dqwsbalOyoPIyEgADh8+HLAz1UVRpLKykvj4eFlHUF555RUWLVokW3tK6Sk3qj3lxTWNx3UvyYHqpDxwdfECeZhXFEVaWlqIioqS9cc6atQoWb+zUnrKjWpPeRFF587UcqZLAvfbqviUv/3tbz6X2Wxv5mTjSZ/L9QX+sOdwRXVSKn7j7p13syBP/mUuKsML1UmpAP6pJPnZic98LtNXDIvKnAGC6qRUAHjuuef8rcKwQrWnfKhOSgWA3bt3+1uFYcVwsefqL1Yz48UZftVh0E7q0KFDcuih4mfGjBnjbxV8zt6qvZTVlSnS9nCx5z+//ae/VfDOSZWUlLBp0yZKSkqIjY1l06ZNcuul4mOefPJJf6vgc5a+sZTrXr1OkbbPRnsqhVdOKj8/n+joaDZv3kxGRsaA1sepBCZLlizxtwrDCtWe8uHVZE6TycSiRYtknVErF2azmeXLl6uOU0VlmOB1TmrFihXs3LmTuro6OfUZFHl5eYDTUakMjJ6ql6p4h2pP+fDKSVksFnc3LyMjg6VLl8qtl1dkZGSotaO8ZNy4cf5WYVih2lM+vHJSJpOJ+fPn88ADD7B9+3a2bNnS5ZyysjL38x07dnitoIpv+NOf/uRvFYYVqj3lw6ucVHV1NUuXLiUrK4vU1NQOCynvuOMOBEHAaDSSlZXFhAkTmD9/Ptu2beOGG26QTXE56LyllavrKoqie6FkoCGKIpIkya6f3G0ORE9/23q42VMJ+itXCf28clJWq5XMzEyKi4tZt24dgiC4o6l169axe/duVq1aRXZ2NhaLhdjYWEwmU8A5qZ62tKqsrKStrc0PGvWNKIrU1tYiSZKsq+FXrlxJRUWFbO0NRE855XqD1WodVvZUgv5+F9felXLilZPKyMjg0KFDPPDAA92+P3v2bNasWRPw+9d13tLKtW1QfHx8QNeTEgRB9rpCf//737ngAvn2axuIngkJCbLJ9Qaj0Tis7KkE/b1GwcHBssv2ykklJSX16YB2794d8E6qpy2tNBpNQNfsEQRBdh0/++wz2b9zf/X0t62Hmz2VoL8yldBN1hZ37tzJkiVL0Gq13SbTfUkgb5UeiMTGxvpbhWGFak/5GLSTKikp4Y477iA2Nta9g0t1dbVfnFRBQQE5OTmAM9/kmjel0jfPP/+8v1UYVqj2lA+vunt1dXU8/vjjbNiwgdjYWDIzM1m9erV7aoK/SE9PJz09nTVr1vhNh6HKtddey2uvveZvNYYNqj3lw+vEeUpKCsXFxR3yThs3buTQoUMsW7ZMNgVVVFTObrzq7q1fv55Vq1Z1SYwvX74cSZJYsWKFLMqp+I5rrrnG3yoMK1R7yodXTqq3Ubvly5cze/ZsFi5c6LVSKr5n+vTp/lbBpyi9J+7ZZk8lUWQsMzMzk61btyrRtIpCrF692t8q+BSH5FC0/bPNnkrideLcYrFQXV2NyWRiwoQJXc4xGAyD1U1FRTFsog0AAfn2hxtuKB1t9hevIqno6GiKiopISUnp1kGpDD0ee+wxf6vgU1xOSqdRZn/c4WBPu2j3twqAl05q+fLlLFu2DIPBQF1dXYc/laHJ9u3b/a2CT7E5nE4qSBOkSPvDwZ5tYmCsX/XKSU2cONH9vLS0lMcff5z58+dTVFQkm2IqvuWDDz7wqTx/dyVckZRSTsrX9lQClyP3N15391zMnj2b1atXs2TJEubNm+c+vm3btsFrp+IzIiIifCqvsU3ZxHVfKN3d87U9lWBIR1KlpaXU19d36OYJgtDhWH5+vty6qijIv/71L5/Kq232739ppSMpX9tTCdocQ9hJrVmzBqPRSHR0tPsvOzvbfcxoNLJhwwa5dVVRkMWLF/tUnrWh0f1cFH3f9Wu1O4sdBmvlLy0CvrenErQ6Wvs+yQd4FetmZmaSk5NDTExMt+9XVVWxdu3aQSnmLRaLhby8PEwmExaLhczMzICtDRVIeFYo9QXN1cfdz+2iRLDGt1MBGm1OJxkZHKlI+762pxI02BrczyVJQhD8M13DKyeVlZXV66xzg8FAVlaW10oNhsWLF7u3s7JYLCxfvpzc3Fy/6CInrXYHkgTBWmV+KAsWLHA/b7E5CAnSKiLHhe3k/jPPbW0E60IUldcZl5Oyi3YqWypJQN7Ce572HKo0tnlEu5KIVlD2N9ETXnX3Zs+eLcs5cmOxWDq8NplMFBQU+FwPubE5RK7+y0ds3GXp+2QvufjiiwGng5r/xAf87f2DiskCOHVkn/t5/hu+X53gihL21ezjJx/8hFNNp2Rt32VPX6BUd7neVu9+LuG/0dhBDW3U1dWxYcMGCgsLsVqtJCcnuzdf8AcFBQVduqAxMTGYzebA2eqqtQEaTkFs+zSOgkdhyjUwNqXHjwRpNVx2bjzPflDKDcmjUeL/2SOPPOIuLXLVjJGsfWcfY6PDuPa80WA9ApogiBrV5XOSJCFKrkcJhyghihJtNjvWxjY09c0gOf8Tu95zOEQ+OCbBBGcbU/es5siBPxMx6WIOG9L407541i+aAPpI3tpXz6JZIxC0QaANAo0OND1YQJKQRAeSKDpvKtGBJNqRRBHRYUd02HE47DgcNkqPf4Uk6ggWjbRKdn769k+5P/V+5o2bh17btVrrYOzZHyRJQpJAan/+celpXvi4jFGGUC6aGEvZ6QZOVtdxyfckxseGU1nfyqaPDrFw+gi2fFHOuSMimTclgeljDCTGhHXfPhKi1G4biQ6vnfKd5zgkBxISJRUlOFrjEZsTuXvn3fwq+VdMjpk8aNsMFEHycsLKH/7wB3JyckhOTsZkMgHOSObQoUNkZWXx+OOPy6pof1i7di35+fkdRhYnTpzI+vXrSU9P73J+d7vFJCYmUlVVpVgeS8j7GZz6Bmn5e+CwIbxwJULld0jTrkea/wgYu9+vra7ZxhV//hBDaBCP/CCRtMnjZC3Vet111/Hqq68Czh/0/blf8cZXJ3h53BtccPKfALRJWiQEQEBEQEJw3lQez/E4duYcz/fOvP9MvMBNdfUcaZ7J94TDJGpOc0RMYEHbWr4nHCZWqGOHmIKeNjQ4sEd9h715HJItGgawnOXMmR1/6hIa9zEBsf27dfxENPVM1xximlDGdZpPGKmpQY8NDb3vipKxuY68H0d1Oip10Frw0EfodM7H4jT+7riSQ+IojjDCQ3/PFjq/Bk3IMcSWESDTvzL9iDdoPXVlh/Z0xs9ACkJsTUBsHYlnh0xsbaL8yZ9QW1vbYRepweBVJPXKK69QWFhITU1Nt2v07rjjjoDawqqnUsL+2C1GOzOL2LwbaNt8C9YFf4brtxG6/1UivvgTmr/Oxh43FbthAmJoLJJOj6TVg1aPEGLkz9+fxn0FNdz4UgNJoWYSQ1uJDrITopUI1kjotRJ6jYRWwPmn4cxzQUKrAZ0AWo3QfkxAq5HQCAKXXzSLt7e9iAAEaQXumjgGR2UD/yiP5w1+xsEQGxWxe7igMZLJjVHoaHc5goTG7bpcz9tvfElEI4BGOPO+0H6uBolGzV6mtNn4bPZ9TPj2d2A7TbzGym+DXuAl+wKKxUkEYSOGehxBdTSP3gIC6GzhGKznYqidjCTpkCQBSfB0ls4bVwKQBBBwa+g63iaGUiaO9TjmeVOfcamzNAd4PvgJWiQdIYIdqxTGKclAK71PXbj1kkjKpNAuxzs6dpeUzscFIoUGfqXLQ0LghGTkiDSS06KBKqKolqKoI5wWgrFJWloIppVg2nQNkPQ0OPQIjRMQrLOhcQJCuxORPHQ4g6erxMMeEnZ0aKO+pLXiCgTJ+SkRDbqwMoIMXzrPc4Qg1k9BrJ0Bkg4HLb3axRu8iqRWrFjBs88+O+hz5GbDhg2sX7/enTgH58TT3NzcgImkADiwHWHrLRA7Een7OTDlh9DWAHv/i3BoF1QdhOZqcNjA0Qb2VoQ2Zw6lRQoin/P5XJzCcTGGWsn5Y22RgmgliFYpCBENdjQ40LofbX38P6o3v0Fkcs81kLShFmISXqUl7BSToyezau4qJhon9ni+KIpUVlb2urvJ1X+fxttHnaN8kj4KKeMFMH0fhK7nVzRVsOCVBWTNzOJ4w3HeLnsbk8HEny/7M6MjRvf63bqjreYoU/6wB4Brp8Xyw9njGBcbTlyknqiQILSu0UZbEzSehogRSNYj2KMnYBNt2EW7s5vk6jJ16k49v/55bs28tcN7kiQhIjq7v7Tvoyc5I7IO3a7O3TAkHA4HNdYaogxRCBqhQ7ttjjbaHG1YW6387vPfcZ3pOr6t+Zb9NfuZO3ou/3fB/zEifERPpujZRnaRtH/Pxl4/hfPDH2C0IYTU8dG8d/o5quwHuC/5XvKP5JO3P49zjOewLn0dUrNEbGys/yMpV/dusOfITXp6OuvXr+9yPDU1tdvz/bZbzOQrYFkBvJ2NkHsrxEyE4DCoPeZ0Tr0QIti4RviEayL2I+hCQKMBQduep2m/sdxDxR1fi5LQ0XmJGhyCBock8NM3S3hxzCFEBF49FUs4LaQYGxmbOIFIYyyflLewpfJashbP46GPH+K2d2/j+Sue59zoc3vUta/dTY7qtHwbHMT30CPcvA0hMa3HtlyJ2+SEZH4x+xfcOu1W7nnvHpblL+PfV/+b6JDoHj/brR1jEoE9TBcO8esFKSQkJHSvpz7C+QeQMBktoKfvnNVnH3zGr+//9YB06g1RFKnQVPSsJ1BWWwbAjyb9iN+N+B3vlb/HY58/xs3v3My69HVMip40IJkhwU45usjveOHWOe7jn+9qprFZT+qoVFJHpXL9pOtZvn05OR/msDpN/hI1Xjkpz2UxgzlHbjo7RovFQmpqamDOkxo1E25/B3b8Dk59A5EjYep1YEiEqDEQ1r7biCQ6/17/FQSHI17+GyqCEkkYORqhhx+rzSHSYnPQYnM9Op+3ORzYHRKO9gS3XZRwOJyP9f+9nc8v2YhDlJh1cieTz5nIKydGUvBdBWWljVTWtzJjjIHpcdN58coXuf2d27l7593k/jDX+7lGgsCto0bwxY8/gtDefy+u+k/a9qT55JjJPLfwOX78xo956OOH+Ou8vw5sHo8g8LX+drQC1JLhnf69oNMps9ymN1w20ml0CILAvHHzmBE3gxUFK7gj/w7+efU/GRk+ctByRElE4xHtTomZwppL15CVn8XbZW8Puv3OeGVJ17KY3nqKpaWlXis1GHJzc9271hQWFgb+HKn5D/XvvMz3ALDZ7HxWXMrBPfs5dLqJ0w2t1DbbqGu2Ud9ip9nmwO7NkHTaXfxqc0n7i1jYZSVIW8vlkxNYkprIGGMocyfFARAVHMWf5/2Z61+9nr+Y/8JvLvjNwOW106zR9OmgwMNJeczVGR0xmocveph73ruHXUd38f3E7w9IdsQvdiFq9aBA+tEfa1ddpVU81yPGh8WzbsE6bnrzJu5//35evPLFQa9XdEiOLnOmLhp9EQvGL+Dve/4+qLa7wytt16xZ0+uMctfs1FWrVnmtmLeYTCb3bjEZGfL/h/QHLTYHrXaRU3Ut3PlyMQcrG4mP1HNOfAQjDSFMHhmJITSIqJAgQoK1hOg0hAZrCdFpnY9BGvQ6LcE6DTqNgE6jQasV0GkEtBrnY9bPb+OFF19Co4HJ//sOAO/ccykT47tfKDsmYgx3zbqLJ4uf5Japt5AYlaioDRzimSjBk3mJ8zh/1Pk8UfwEc8fMdUda/SJ+MogiKLDN+80338zLL78se7u9YZecTqqzA4kLjWPNpWu49Z1beW7Pc2SdN7iJ1p0jKRdZM7O4/rvrB9V2d3i9LKa3baMkSeLBBx/0WqmzlS/LreTvPcV3J+spr26ipqkNa7ONNvuZ4e5zR0Tw3I+ncNmMCWi18s2Yam5sIDTY2d5bd1/CGGMohrDeR7CWTl7K818/z3NfP8cjFz0imy7d0dMNKAgCv5z9S25+62Y+PPYhlyVepqge/cUftdVcjrw7Rz0rYRa3T7+d9V+t52rT1YyNHOu9nG4iKXB2wWfHz+ZbvvW67e7wKjuclZWFwWDo8c9oNPptWcxQpLHVzh0vFXPdMx/zry+OYBdFzjfF8JPzx/HrK6fwxOLz3Of+/dZUpo0Ml30d1SWXXOJ+PnV0VJ8OCiBEF8Kt027l1dJXqW7pPeE/WHq7Ac+LP4+ZcTN5ea9vI5fe8LSnr3DnpITuY4/lM5YTrY/myeInByWnp0gK4C+X/2VQbXfHsFoWMxRxiBLL/1HERwdP8+cfz6LwN+m88LM5/Pa66dyTfi63XZzEopSxxIQHc8PsMYw2dp17IwdXX321V5+7/pzrERB40/KmzBp1pLuclCc3fu9GPj/5OeX15Yrq0V+8tedgcOWkeuryhgWFcXfy3Ww/vJ1vTn/jtRyH2H0k1ZvswaDgOLtKX3xy8DQTf/0Wn5RWseGWFK6bNebM/JxOfPHr+Tyx5Lxu35MDb7vnxhAjlydezrYD2xStttldUtiTeYnzCNWF8vYh+UeXvMEf6Q7P0b2euMZ0DeOjxrPhq4GXUnJdA4fk6DGSUgLVSfmJT0ur+MmmzwEYFxPGRRPjej1fp9X4rVRGX1x3znUctB7koFW5Rcl9RVJhQWHMGzePNy1vyu4sXRMuLbUW9/NAxN0l7qVagVajZdmMZews38n+mv09nteZm9+6mdkvzWb+1vl8VfmVTysi+H4yhwqtdgf3by3hQlMsN10wrk8H5Quys7O9/uwFoy4gPCicHUd2DHjCYE9IkkSzvZkgTRBB2qBec1Iurkq6ijctb7K/Zv+AF8JWNlXy/tH3sdRaaLQ1IkoikcGRNNmb+O/B/7rPmxk3k0XnLiI+NJ4QXQhBmiCCtcEEa4IJ0ga5H++85063/kqVKO5MfyIpgKtNV/NsybM8//XzrLqkfyPwe07vISctB2urlcN1h1k4wXeb//rUSZWUlDBr1ixfigxI/rv7GCfqWnhp2fk9DvH7mn379jF37lyvPhusDebSMZey88hO7jjvjgF/vvBkIZHBkUyOnowgOPNbTxQ9QWVzJQBGvZFzjOcAPSeFAS4cdSHhQeG8X/7+gJxU4elCflvwW+ySnfGR44kMjkQjaKhrq3MPCFw85mK+OPEFNtHGw5883Geb1R9UE1PurMihETRO59XucF2Oy/OxwzGtjiAhiInGidyTcg/gXBbUbG+mvL6cD499yEfHP6LUWsoPxv+AgsMFGPQGqluq0QgaQrS91+YK0gTxk+/9hKfMT3F/6v3Ehfb9T3JW/Cxunnpzn+cpgSJOqqSkpNvjW7ZsUZ0U8GrJceaeExcwDgrg1Vdf5ec//7nXn583bh4P7HqA4w3HB7yW7vZ3bwcgPjQeu2inprWGi0dfzBVJV/DS3peYO2Yuh+sOc270uRhDjD22E6QN4qLRF7Hr2K5+zwUSJZGnvnmKWfGzeOLyJ4gK7nu9WZujjeqWalodrdgcNtpE59o5m2jD5rBhE208+PKD/O8l/4tNtHV4r01swy7a3a/tkr3Do2td4GcnPuP9o+8TrA3mk+Of8GXll2e+pybIXaP97UNvU9lcyfHG4yyatIilk5cSEdz37+pH5/yIZ0qeIW9/Xr/+sUyJmdLnOUqhiJPavHkztbW1XSok7N69WwlxsrPhw0Pcf/WsHpPYntgconu2d12L87G+xUZd85nXrsfGVjsV9a0UH67ht9dN88E38R1zx8xFJ+jYdXQXP57y4wF9NsmQxP+e/798dOwjdh3dRU1rDQ9d+BBjIsaQnTawbuilYy/l/z7+P6qaq4gNje3z/H01+6hoqeDxGY/3y0GBM3Lsa3lJfGg8V5u8H+E7XHeYn73zMzbu2cjFo88U0Hvy+09y0ZiLqG2tZfvh7dwy9Ra27NvClJgpzEqY1e/2DXoDV5uuJndfLj+f8fM+N6QwGXy/FteFIk5q5cqVFBUVMX/+/A7Hd+zYoYQ42fnbewd5bW8NF02MJTZCjyhKtNgc1DTZsDbbsDa1OSdaNtqob+15l9ewYC1RIUFEhuiIDNERERJE8eEaANImdF8f3l/85z//GdTnI4IjmBk/k0+PfzpgJzU9djpzRs1hzqg53Jd6X6/zcPpi7pi5SEh8dOwjrjvnuj7PP1R7CICpsVO9ktcTg7Xn+KjxFCwuwC7aCdYGY3fYOXnqJKNHjkaj0RAWFMat024FGLC9Xdw45Uby9uex4/AOrki6otdz48PivZIhB4o4KYPB0MVBAd0eC0Re/vkc3txXx97jtVQ3VaHTaAjWajCGBREdFsyY0VEYw4KJDgvCGBbsXpISGaLDEOp8jNDr0Gm73mgTHnTOJwqkrh44J+hu2rRpUG1cOPpCXvzmReyiHc0ABo5HRXSs+DmY4e240DhmxM1g19Fd/XJS75Q5lwCFB4V7LbM75LCnRtC4d7PRCBrZE/DnRp9L2sg0/v3dv/t0Uv2JSpVC8cT5zp07mTdvnvtxKDB9jIG508YrKiNYF1izPypkWL924egLeabkGb4+/TUz42b2+3MJofJugnDh6AvZum9rvyKyD44qs9OwHPb0BUsmL+GBDx5gf83+XsvuxIb4z0kpfqeYzeYOj77AbDaTktJzzXB/8sqKC9l4S/f1rfzJnDlz+j6pD6bFTiMyKJJPT3w6oM+FB8sbxZw/8nysrVYO1ByQtd2BIIc9fcH8xPnEhsSydV/vm2H4M5Ly2b9zJWcje5KXlwf41ikOhJTxMSyYOvAqiUpz4403DroNnUZH2sg0Pjv+2YA+F66T10mdl3Aeeq2ez070rsfhusMA3DvtXlnlgzz29AVB2iBumHQDb1jeoMnW1OE9z3s2VKfMcqz+EFh9DhnIyMgInJ1hhhD33ivPjTpn1Bz2nN5Di73/ta7lzgfptXpmJ8zmi5Nf9HreNf9xlkuO08s/mVYue/qCxecuptnezBuWNzocd00O9Tdn9Yzz7mqcg7NUqygG5vIHUWyvjS2zfnK1mRyfjE208VXlV4zXjO9Xm6G6UNm/z5wRc9j09SZa7a19Dq/H6GMC1p4ulLruACPCRnDJmEvYum8ri85Z5F5+1WZ3VgN87OLH+i1XCf185qQCcd2ZP3aLGSyiKFJbW4skSbLWYb/llltkSfZGSVFE6CL48NCHGGINPerp2ZVoqWuhwiFvonmSfhJN9iY+PvgxU429Ty8QmgUqKioC0p4ulLruLn6Q8AN+Y/4NHxz4wG2vJruz+9dU39Tv71JbWyu7boo7KdeP0Vc5qYGwcuVK7rvvPvdr124x8fHxgVkXHeePVRCEXndh8Ybm5mYSEuQZZZs9Yjb7Gvdx88Sbe9TTc6Fu4ohEEsLkHeGLiYshwhzB/pb9XJZwWa/njooZ1esGB94gpz1Buevu4qr4q/jb/r+RX5nPZedeBkBtq9PhxETH9Pu7BAcHy65bv77tYOo1Z2ZmdngMJPR6PVFRUR3+4MxuMYH657kLi1x/eXl5srWVOjKVLyu/dJb06OEcSTjzTysiOEL27xOsCyZ1RCpFp4p6PMdFqC40oO2p5HV3/em0Ohafu5jtZdupa6tDo9HgwJmTCtYGD6gtuelXi8uWLWPhwoX88Y9/7LAurz8lUl1LY6qr5a3cuGDBAlJSUkhJSWHx4sWytq0yOFJGpNDiaOFgXc+lWzwja71u8Nuad0fayDRKKktoc/TedQ/EVIQ/uH7S9UhI7qoP7iJ6PizL0h396u4VFxe7h/TXrVtHUVERALGxsbz77rs9fq6kpISioiJSU1MxmUxs2rSJZcuWyaA2HbZS7wmr1Rqw3bZAY/PmzbK1NTVmKiHaEPbU7OFSLu32HM/uXm+VDQZD2sg0Wh2tfFX5FakjfTs3TU57+oqYkBgWjF/A1v1buWXaLf0u/aI0/YqkkpKSWLRoEUajkZycHIqKiigqKuqzRHB+fj7R0dFs3ryZjIyMDjsLK0VBQQE5OTmAMzHumjel0jsPPPCAbG0FaYM4L/48vqr5qsdzPJ2UUpHM5JjJRAVHUXiyUJH2e0NOe/qSpZOXUl5fzmfHP8PmcFZa8LeTGpD0+fPnU1tb617isnLlyl7PN5lMLFq0iEWLFg1KyYGQnp5Oenp6r7vZqHSlvFze2uDJCcm8tPcl59KUbv4XupzU/HHKrefUCBpSR6TyxckvWMEKxeR0h9z29BWzE2ZzjvEctuzb4i7hEhYU5ledBpzlMhgMzJs3j02bNvUrMlqxYgU7d+70yxY/Kv3nvPPkrZ+ePCKZBntDjyWFRZxO6qqkq2SV25m0kWl8VfkVrY7Wvk+WEbnt6SsEQWDp5KW8f/R9yurKAP/ONocBjO6tXLmSJUuWkJqaysKFCykqKsJisfT6OYvF4u7mZWRksHTpUlmUVpEfubcgmxE3A52go/hU9//IXIlzpQv6p41Mo01s48uKL/s+WUaG8pZu15iuQa/Vu7cIC9P5N5LqV3cvOzubBQsWsHLlygFtVWUymZg/fz7z588fsn30s4U777yT1157Tbb2QnWhTDZMxlxh5qapN3V535WUVXpkbVL0JIx6I1+c/II5o3y36Fdue/qSiOAIrjFdQ+7+XGCIdPdyc3N59tlnqa6uZtu2bWzbto1XXnmlz5xUdXU1S5cuVbt7ZykzomdQfKq424m8rpyU0sPbrryUP5LnQ5mlk8/0euReAD5Q+hVJuaKnzkXr+poGYLVayczMpLi4mHXr1iEIAlu2bPFSVRUlUaJ7MjN6JpsPbeZw3WEmGCZ0eM9X3T1wdvn+UPQHmu3NHfIrMSEx/GTKTxSROZS7e+AcGU0ZkYJO0Cmy4edAGNTYYl8jaBkZGRw6dEjt6g0Bmpqa+j5pgEyNnopG0FB8qriLk3J391B+IuWckXOwi3ZKKkq4cPSFHXRQykkqYU9f8/eFf/e3CsAgSrWUlZWxcePGXrtxFosFi8WidvWGAC+99JLsbYbrwpkSPYWiU0Vd3nNFUr6YzTzROJGYkJguXT5RFBWTr4Q9fY1G0Ph0p+Ie9fDmQ6mpqSxYsICMjAz3erfumD9/PtHR0URHR3PnnXd6raTK0CV5RHK3I3yuKQi+WJIiCEK3eSlfbxeu4h1eXSGz2cz69euZMGFCn+cuWrSIG264gcJCNXEZyLzwwguKtJuSkMKJxhMcbzje4bir7pCvnMSckXP4+vTXHapPipJykZRS9jwb8eoXYjQaB7Spwh13DHxXWxXf8vvf/16RdpNHOKukdo6m7JJvF6+mjUzDLtnZXXFm70e7aFdsyYdS9jwb8bq7p+T5Kr7n4MGeKxYMBtcW6Z2dlEP07eLVJEMScaFx7i6fJEnYJXufVTu9RSl7no149QsxmQa2m2nnnYyVxGw2U1BQAEBhYSEbN25UKyH0g8mTJyvWdsqIlC6bIvh6hb0gCKSNSHM7KVcZEqXkK2nPs41hlzUsKCggOzub7Oxs0tLShsyGpP7GVTlCCVJHpHK47jCVTZXuY77u7gGkjkzlm6pvaLQ1YhOdK/yViqSUtOfZhtc5qe5YsWLFoHdtHQxms5lVq1a5X2dkZGA2m/tcY6gCt99+u2Jtu/NSFWe6fL7u7oEzee6QHJhPmd1OSin5StrzbMOrK9R52LisrIz09HSMRiPJycmsXLmyg7PwFcnJyWzcuNH92mq1AhATE9Pt+epuMWdQcneTuJA4xkWOo/BEIT8Y9wMAd7VMDRqf2ToxIpH40Hi+OPEFU6KnAM5IbqjZM5AJmN1iPNdibdq0iaysLLKzs92O6dChQ6xYsYI1a9b0Oo9KCTIyMtzPt2zZ4nae3aHuFnOGH/3oR4rubjLTOJOPjn5ERZJTRlV1FQDWaisVrb7bknyGcQafHP2EH8Q7nWVjXSPWIOuQs2egEjC7xQiCQF1dHcuWLWPHjh1s3769Q+4nKSmJ1atXk52dzYMPPtiv+VRyY7VaycvL67XmlbpbzBni4uIU3d1kXss83ih/g7bQNsZGjiXSEQlAQnwCCRHy7hTTG5eMv4Tfff47tBHOXFhsdCxGnXHI2TNQUWK3GK+cVHFxMUlJSaSmpmKxWLodvTMYDKxbt44HH3yQOXN8VyLDRU5ODvn5+b06G71ej17fdRMApXa9kAvPXUPk4rnnnuO6666TrT3oqOf5o89HK2j57ORnLDEscc84d+1E4ivmjJqDKIkUnnKO8ul1+iFpz0DFb7vFdKagoICVK1fy7rvv9jm9YPXq1UiSRHR0tFcK9kRvu8WsXbuWnJwcTCYTVqvVnZtS8R9RwVHMiJvBp8c/Bc4kzn29wj4xMpERYSP4+NjHgHKjeyry4VUkVVNTM6C5T0rUOe+pTExeXh7JycluB7V169aA3PMv0Fi3bp3iMi4afREvffsSdtF+Zp6SQjvF9IQgCMwZOYfXLa8DEB4UDgqkH31hz7MFryIpX07OHAgWi4XFixezYMECBEEgOjpana/ST55++mnFZVw4+kLq2+r5puqbM/Ok/FCryLNCZ0RwhCIyfGHPs4XA7dx6gclkQpKkDn81NTX+VmtI8PXXXysuY3rcdCKDIvnk+CeKz/jujblj5rqfRwZFKiLDF/Y8WxhWTkrFe8aPH6+4DJ1Gx/mjzuejox/RbG8GIEQborjczsSFxrkrdCq1E4ov7Hm2oDopFQAef/xxn8i5LPEyvjr9FeX15YTqQv22xfnrP3qdbdduU0y+r+x5NqA6KRUAbrqp644uSnDp2EvRCBreLXvXr/u5jQgfwaToSYq17yt7ng34d//kAMM1k76uri5g56KIokh9fT0hISGy6miz2WQt89yTnlq0TA+fzu7K3YwKG+X30tJD3Z6Bhus7d7dDkLcIkpytDXEsFgsTJ070txoqKkOe0tLSAZd06gk1kvLAtRD5yJEjATvNwrV0p7y83OfrIgeCqqe8DBU9a2trGTduXI+L+r1BdVIeuMJog8EQ0D8EgKioqIDXEVQ95Wao6ClnlzRwO7cqKioqqE5KRUUlwFGdlAd6vZ6HH36428oIgcJQ0BFUPeXmbNZTHd1TUVEJaNRIqhMnT54M6BKtoigqouO///1vWdtTSk+5Ue0pL0ropzopFUD+m+psR7WnfKhOSgWAzZs3+1uFYYVqT/lQnZQKAA888IC/VRhWqPaUD9VJqQBQXl7ubxWGFao95UN1Up34rqKJ5jaHcgLamuB4ifOxu9c90Nzm4OtjtYrpdt5553Uvq12/5qZq9lbtddeBkoVuvrun7A7P7c2yy29uc1BcVs1Xxxt6tqtLx8bT/bpOLjzt6a1unte7uc3R4bfZnZ1qmhoUsVHn350S16I3VCfVidv+9S2llQ3KCTi9HzZ83/nY3eseKK1s4Jq/fqSYbllZWd3Latfv0JFdLH1jKYdqD8kntJvv7inb8/mh2kOyyy+tbGDxhs/J3LqvZ7u6dCzd2a/r5MLTnt7q5nm9SysbOvw2u7PTR4f3KmKjzr87Ja5Fb6hOSgWAO++8098qDCtUe8qHYk6qrKzM/XzHjh1KiVFRURnmyF4F4Y477kAQBIxGI1lZWUyYMIH58+ezbds2brjhBrnFqcjEYLsnKh1R7SkfskdS69atIzMzk9LSUrKzs0lNTWXhwoU97pOnEhg0NfUvIazSP1R7yoci9aRmz57NmjVrSEpKUqJ5FQV46aWXuuwEreI9qj3lQ7GclOqgVFRU5MBrJ3XHHXewbdu2Ps/xd6F9lf7xwgsv+FuFYYVqT/nw2kllZWWxfft2YmJiWLhwIX/84x8pKSnpcM6aNWtYtWrVYHVU8QG///3v/a3CsEK1p3x4nZOaPXs269atY926dezYsYPc3FxycnIASE5Odu8UYbVaZVFURVkOHjzobxWGFao95UOWxPn8+fOZP38+RUVF7Nixg6KiIsxmM6WlpSxZskQOESoKM3nyZH+rMKxQ7Skfso7uCYKAwWBwOy2VoYMrClaRB9We8uF1TqqsrIydO3eqifFhwu233+5vFYYVqj3lw+tIymQyYTQasVqtREdHk5qaitVq5fDhw4wfP15OHVVUVM5ivI6kMjIyqK6uRhRFioqKWL58OaWlpaSnpzNp0iRWrlzZZbRPJXC57bbb/K3CsEK1p3x47aTS0tLcz5OSksjIyCA7O5sDBw6wfft2TCYT2dnZbNq0SRZFVZQlKCjI3yoMK1R7yofXTiozM5OFCxd2qHawevVqwOm0li9fzvbt21m2bNmglVRRno0bN/pbhWGFak/58NpJGQwGtm7dqi4cVlFRUZRBrd0zGAwsX75cLl1U/Mi6dev8rcKwQrWnfKiVOVUAePrpp/2twrBCtaeMSCodeO/LUqmhuU05Aa2NknRst/Oxu9c90NRql/YctUoNzW3SiRMnJIfDIataP/zhD7vIamq1u/VraqySvjn9jdRka+pXew6Ho289u/nunrI7PLc1DUh+f2hqtUtflFZK7xYf6Pmau3RsqOzXdXLhaU9vdXNfA0mSGprbOvw2u7NTdWO9Ijby1EOSpF6vhdy/S0mSJEGSJMnfjjKQOHnyJAkJCWg0gRlkiqJIRUWF7Dr+8pe/5K9//ats7Smlp9yo9pQXURRl1y9wv62KT3n88cf9rcKwQrWnfKhOSgWAm266yd8qDCtUe8qHIuWDhyqSJFFfX09ISEjAhtSiKCqio81mk3UdplJ6yo1qT3lxdfciIyMRBEGWNtWclAeVlZUkJCT4Ww0VlSFPRUUF8fHxsrSlRlIeBAcHA1BeXk5UVJSftemeuro6EhMTA1pHUPWUm6Gmp+tekgPVSXngCk+joqIC+ocAQ0NHUPWUm6Gip1xdPVAT5yoqKgGO6qRUVFQCGtVJeaDX63n44YfR6/X+VqVHhoKOoOopN2eznuronoqKSkCjRlIqKioBjeqkVFRUAhrVSamoqAQ06jwpwGKxkJeXh8lkwmKxkJmZidFo9LdaAJjNZgoKCgAoLCxk48aNbt0CUe+cnBxWrlwZsDoWFBRgsVjcO2ynp6cHnJ4Wi4WCggJiYmKwWCxkZGS49fWnnmazmeXLl1NcXNxF3550kkVf2Yu/DEGSk5Pdz0tLS6WMjAw/atORNWvWdHjuqWug6V1cXCwBUk1NjftYIOmYn58vZWZmunUxmUzu9wJJT89rLkmSW2dJ8p+eubm57uvbmd50kkPfs95JlZaWdjCkJEmS0Wj0kzYdKS4u7qBLaWmpBEilpaUBqXdubq5kMpncTirQdPTUTZKc+rkeA0nPzrp4OlZ/69nZSfWmk1z6nvU5KVdY7UlMTAxms9lPGp0hOTm5w64jVqsVcOoXaHrn5eWRkZHR4Vgg6WixWKiursZoNGI2m7Fare4uVCDp6ZKdkpLi7vYtWLAACDw9oXed5NL3rHdSrhu/M9XV1b5VpAc8b/wtW7aQnp7u3jm6O/yht9Vq7TbPEEg6ms1mYmJi3PmRDRs2kJeXBwSWngC5ubkATJw4kdzcXPdvIND0hN51kktfNXHeAz0Z2F9YrVby8vK6JC27O8/XbN26lczMzH6f7w8dq6ursVgsbiefmZlJdHQ0Ui9zmf31GygoKGDNmjVYLBaysrIAWL9+fY/nB9pvFXrXaaD6nvWRlNFo7OLZXd2CQCInJ4f8/Hy3XoGid0FBAUuWLOn2vUDREcBkMmE0GjvYD5wRViDpabFYKCwsJD09nczMTEpLS9m6dSsWiyWg9HTRm05y6XvWOynXEHRnUlNTfaxJz6xdu5acnBxMJhNWqxWr1RpQem/dupUNGzawYcMGLBYLq1atwmw2B5SOrvxTdwSSnmazmbS0NPdrk8nEypUrA+6au+hNJ7n0Peu7e51/vBaLhdTU1ICJpPLy8khOTnY7KFfXqrN+/tK78w8xKyuLrKysbp2CP21rMplITU11589cc6WSk5MDSs/k5GTWr1/fIRdZVVUVUHp65iB7u3/k+o2qC4xxGm/9+vWkpaVRWFjYYTKiv/WaOHFih2NGo5Gamhr3+4Git9VqZcOGDeTk5JCZmUlWVhbJyckBp2NOTg4pKSkUFxe7o1MILFsWFBS4u6Hg/Efgbz0LCgrIz89n7dq1ZGdnk5aW5nakvekkh76qk1JRUQlozvqclIqKSmCjOikVFZWARnVSKioqAY3qpFRUVAIa1UmpqKgENKqTUlFRCWhUJ6WiohLQqE5KRVEKCgqYOHEia9euZcOGDaSkpJCSkuKe+Dlx4kR36Y6UlBR3ZQIVFRdn/bIYFWWxWq3k5+e7Z0zn5+cTExPjrpqwdOlSLBYLycnJrFmzxmfr0PLy8qiurh5Q9QYV/6BGUiqKUl1d3evi3uTkZPdKeVcZFV+wZcuWXvVSCRxUJ6WiKD2VcRnoOXJjNpsDqtKFSs+oTkpFUfoTGblK+rpyVeDMZbleFxQUsGHDBhYvXozFYsFsNrN27Vp3QTgXBQUFrF27lry8PHJycrqVZTab3e9t3bo1IMpEq/SOmpNSCQiSk5NZunSp+3V6ejrp6enk5+e7y+nm5uaSl5dHdnY2ycnJTJw4sUPplZycHHfl0urqaveK/c5yLBYLVqtVzUcNEVQnpRKwxMbGEhsb635tNBo75JFclR+NRiPr1693b1DhorCwsNt2t2zZ0iUKUwlcVCelMqTorfuYnJzcoQhfT5GSmo8aWqg5KZWAoq8i/T29v3Tp0g5RFNDltefnjUYjBQUFAbmJgUpH1EhKxSe4tjd3Jao3bNhAamqquyyu2Wxmy5YtxMTEkJGRgdVqZcuWLYAzP+X52eTkZHd7a9asYc2aNe55Vjk5Oe4a4d3V2DYajaSnp7u3tgqECqwqvaNW5lRRUQlo1O6eiopKQKM6KRUVlYBGdVIqKioBjeqkVFRUAhrVSamoqAQ0qpNSUVEJaFQnpaKiEtCoTkpFRSWgUZ2UiopKQKM6KRUVlYBGdVIqKioBzf8DQHFt4XeE898AAAAASUVORK5CYII=\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#\n",
        "# Compute the DF\\lambda function.\n",
        "#\n",
        "df_lambdas = df(\n",
        "    particles,\n",
        "    mu,\n",
        "    sample_times,\n",
        "    absolute=False,\n",
        "    cumulative=False\n",
        ")\n",
        "\n",
        "#\n",
        "# Select options for plots here.\n",
        "#\n",
        "event_ids = [5, 6, 9, 10]\n",
        "\n",
        "#\n",
        "# Make the figure.\n",
        "#\n",
        "fig, axes = plt.subplots(\n",
        "    nrows=len(event_ids),\n",
        "    ncols=1,\n",
        "    sharex=True,\n",
        "    sharey=True,\n",
        "    figsize=(HALF_WIDTH, 3),\n",
        ")\n",
        "\n",
        "#\n",
        "# Plot the selected event IDs.\n",
        "#\n",
        "for i, (idx, ax) in enumerate(zip(event_ids, axes)):\n",
        "    # Plot the sequence of DF\\lambda, once the particle is spawned.\n",
        "    for mi in range(num_marks):\n",
        "        mask = sample_times >= times[idx]\n",
        "        ax.plot(\n",
        "            sample_times[mask],\n",
        "            df_lambdas[idx, mask, mi],\n",
        "            color=COLORS[mi],\n",
        "            linewidth=LW,\n",
        "        )\n",
        "\n",
        "    # Plot vertical lines at the selected events for ease of visual inspection.\n",
        "    id = sample_times[mask][0].item()\n",
        "    ax.axvline(id, color=COLORS[marks[idx].item()], alpha=0.5, linestyle='--')\n",
        "\n",
        "    # Clean up the axis.\n",
        "    ax.grid(True)\n",
        "    axes[-1].set_ylim(-2.3, 2.3)\n",
        "    axes[-1].set_yticks(*[[-2, 0, 2] for _ in range(2)])\n",
        "    ax.set_ylabel(r\"$\\mathrm{DF}\\lambda_t^{(\" + str(idx+1) + \")}$\")\n",
        "    y_label_2dp_formatter(ax)\n",
        "\n",
        "\n",
        "#\n",
        "# Handle the zoom.\n",
        "#\n",
        "plt.xlim(X_ZOOM[0]-1, X_ZOOM[1]+1)\n",
        "for ax in axes:\n",
        "    ax.axvline(X_ZOOM[0], c='k', linestyle='--', lw=0.75)\n",
        "    ax.axvline(X_ZOOM[1], c='k', linestyle='--', lw=0.75)\n",
        "\n",
        "#\n",
        "# Clean up the figure.\n",
        "#\n",
        "axes[-1].set_xlabel(\"Time $t$\")\n",
        "axes[-1].set_xticks(np.arange(X_ZOOM[0], X_ZOOM[1]+1, 10))\n",
        "fig.align_ylabels(axes)\n",
        "\n",
        "#\n",
        "# Save out.\n",
        "#\n",
        "fig.align_ylabels()\n",
        "# fig.tight_layout()\n",
        "fig.subplots_adjust(hspace=0.15)\n",
        "savename = f'./DFlambda.pdf'\n",
        "plt.savefig(savename, bbox_inches='tight', pad_inches=0.01)\n",
        "print(savename)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 326
        },
        "id": "5UdBZTgfZxb6",
        "outputId": "62555b9f-a592-46d9-ef6e-2c89f8b1a1d8"
      },
      "execution_count": 24,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "./DFlambda.pdf\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 270x300 with 4 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Thanks! :)"
      ],
      "metadata": {
        "id": "_GcuAb_gktuA"
      }
    }
  ]
}