{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import torch\n",
    "from sklearn.decomposition import PCA\n",
    "import torch.nn as nn\n",
    "from os.path import join\n",
    "import matplotlib as mpl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(20, 5)"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def generate_synthetic_pca_data(n_samples=200, n_features=5, n_components=2, noise_std=0.1, random_seed=0):\n",
    "    \"\"\"\n",
    "    Generate a synthetic dataset for PCA testing.\n",
    "    \n",
    "    Parameters\n",
    "    ----------\n",
    "    n_samples : int\n",
    "        Number of data points to generate.\n",
    "    n_features : int\n",
    "        Dimensionality of the feature space.\n",
    "    n_components : int\n",
    "        Intrinsic rank (number of principal components) to use in constructing the data.\n",
    "    noise_std : float\n",
    "        Standard deviation of Gaussian noise added to each sample.\n",
    "    random_seed : int\n",
    "        Seed for reproducibility.\n",
    "        \n",
    "    Returns\n",
    "    -------\n",
    "    X : np.ndarray, shape (n_samples, n_features)\n",
    "        The generated data matrix.\n",
    "    \"\"\"\n",
    "    rng = np.random.RandomState(random_seed)\n",
    "    \n",
    "    # 1) Generate random principal axes (each column is a \"principal direction\")\n",
    "    #    shape: (n_features, n_components)\n",
    "    principal_axes = rng.randn(n_features, n_components)\n",
    "    \n",
    "    # 2) Generate random scores (coordinates in the principal-component space)\n",
    "    #    shape: (n_samples, n_components)\n",
    "    scores = rng.randn(n_samples, n_components)\n",
    "    \n",
    "    # 3) Construct data by projecting scores onto principal axes\n",
    "    #    shape: (n_samples, n_features)\n",
    "    X_clean = scores @ principal_axes.T\n",
    "    \n",
    "    # 4) Add noise\n",
    "    noise = rng.normal(loc=0.0, scale=noise_std, size=(n_samples, n_features))\n",
    "    X_noisy = X_clean + noise\n",
    "    \n",
    "    return X_noisy\n",
    "\n",
    "X = generate_synthetic_pca_data(\n",
    "        n_samples=20, \n",
    "        n_features=5, \n",
    "        n_components=3, \n",
    "        noise_std=0.1, \n",
    "        random_seed=42\n",
    "    )\n",
    "\n",
    "X.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<style>#sk-container-id-3 {\n",
       "  /* Definition of color scheme common for light and dark mode */\n",
       "  --sklearn-color-text: black;\n",
       "  --sklearn-color-line: gray;\n",
       "  /* Definition of color scheme for unfitted estimators */\n",
       "  --sklearn-color-unfitted-level-0: #fff5e6;\n",
       "  --sklearn-color-unfitted-level-1: #f6e4d2;\n",
       "  --sklearn-color-unfitted-level-2: #ffe0b3;\n",
       "  --sklearn-color-unfitted-level-3: chocolate;\n",
       "  /* Definition of color scheme for fitted estimators */\n",
       "  --sklearn-color-fitted-level-0: #f0f8ff;\n",
       "  --sklearn-color-fitted-level-1: #d4ebff;\n",
       "  --sklearn-color-fitted-level-2: #b3dbfd;\n",
       "  --sklearn-color-fitted-level-3: cornflowerblue;\n",
       "\n",
       "  /* Specific color for light theme */\n",
       "  --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
       "  --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, white)));\n",
       "  --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
       "  --sklearn-color-icon: #696969;\n",
       "\n",
       "  @media (prefers-color-scheme: dark) {\n",
       "    /* Redefinition of color scheme for dark theme */\n",
       "    --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
       "    --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, #111)));\n",
       "    --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
       "    --sklearn-color-icon: #878787;\n",
       "  }\n",
       "}\n",
       "\n",
       "#sk-container-id-3 {\n",
       "  color: var(--sklearn-color-text);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 pre {\n",
       "  padding: 0;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 input.sk-hidden--visually {\n",
       "  border: 0;\n",
       "  clip: rect(1px 1px 1px 1px);\n",
       "  clip: rect(1px, 1px, 1px, 1px);\n",
       "  height: 1px;\n",
       "  margin: -1px;\n",
       "  overflow: hidden;\n",
       "  padding: 0;\n",
       "  position: absolute;\n",
       "  width: 1px;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-dashed-wrapped {\n",
       "  border: 1px dashed var(--sklearn-color-line);\n",
       "  margin: 0 0.4em 0.5em 0.4em;\n",
       "  box-sizing: border-box;\n",
       "  padding-bottom: 0.4em;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-container {\n",
       "  /* jupyter's `normalize.less` sets `[hidden] { display: none; }`\n",
       "     but bootstrap.min.css set `[hidden] { display: none !important; }`\n",
       "     so we also need the `!important` here to be able to override the\n",
       "     default hidden behavior on the sphinx rendered scikit-learn.org.\n",
       "     See: https://github.com/scikit-learn/scikit-learn/issues/21755 */\n",
       "  display: inline-block !important;\n",
       "  position: relative;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-text-repr-fallback {\n",
       "  display: none;\n",
       "}\n",
       "\n",
       "div.sk-parallel-item,\n",
       "div.sk-serial,\n",
       "div.sk-item {\n",
       "  /* draw centered vertical line to link estimators */\n",
       "  background-image: linear-gradient(var(--sklearn-color-text-on-default-background), var(--sklearn-color-text-on-default-background));\n",
       "  background-size: 2px 100%;\n",
       "  background-repeat: no-repeat;\n",
       "  background-position: center center;\n",
       "}\n",
       "\n",
       "/* Parallel-specific style estimator block */\n",
       "\n",
       "#sk-container-id-3 div.sk-parallel-item::after {\n",
       "  content: \"\";\n",
       "  width: 100%;\n",
       "  border-bottom: 2px solid var(--sklearn-color-text-on-default-background);\n",
       "  flex-grow: 1;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-parallel {\n",
       "  display: flex;\n",
       "  align-items: stretch;\n",
       "  justify-content: center;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "  position: relative;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-parallel-item {\n",
       "  display: flex;\n",
       "  flex-direction: column;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-parallel-item:first-child::after {\n",
       "  align-self: flex-end;\n",
       "  width: 50%;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-parallel-item:last-child::after {\n",
       "  align-self: flex-start;\n",
       "  width: 50%;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-parallel-item:only-child::after {\n",
       "  width: 0;\n",
       "}\n",
       "\n",
       "/* Serial-specific style estimator block */\n",
       "\n",
       "#sk-container-id-3 div.sk-serial {\n",
       "  display: flex;\n",
       "  flex-direction: column;\n",
       "  align-items: center;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "  padding-right: 1em;\n",
       "  padding-left: 1em;\n",
       "}\n",
       "\n",
       "\n",
       "/* Toggleable style: style used for estimator/Pipeline/ColumnTransformer box that is\n",
       "clickable and can be expanded/collapsed.\n",
       "- Pipeline and ColumnTransformer use this feature and define the default style\n",
       "- Estimators will overwrite some part of the style using the `sk-estimator` class\n",
       "*/\n",
       "\n",
       "/* Pipeline and ColumnTransformer style (default) */\n",
       "\n",
       "#sk-container-id-3 div.sk-toggleable {\n",
       "  /* Default theme specific background. It is overwritten whether we have a\n",
       "  specific estimator or a Pipeline/ColumnTransformer */\n",
       "  background-color: var(--sklearn-color-background);\n",
       "}\n",
       "\n",
       "/* Toggleable label */\n",
       "#sk-container-id-3 label.sk-toggleable__label {\n",
       "  cursor: pointer;\n",
       "  display: block;\n",
       "  width: 100%;\n",
       "  margin-bottom: 0;\n",
       "  padding: 0.5em;\n",
       "  box-sizing: border-box;\n",
       "  text-align: center;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 label.sk-toggleable__label-arrow:before {\n",
       "  /* Arrow on the left of the label */\n",
       "  content: \"▸\";\n",
       "  float: left;\n",
       "  margin-right: 0.25em;\n",
       "  color: var(--sklearn-color-icon);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 label.sk-toggleable__label-arrow:hover:before {\n",
       "  color: var(--sklearn-color-text);\n",
       "}\n",
       "\n",
       "/* Toggleable content - dropdown */\n",
       "\n",
       "#sk-container-id-3 div.sk-toggleable__content {\n",
       "  max-height: 0;\n",
       "  max-width: 0;\n",
       "  overflow: hidden;\n",
       "  text-align: left;\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-toggleable__content.fitted {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-toggleable__content pre {\n",
       "  margin: 0.2em;\n",
       "  border-radius: 0.25em;\n",
       "  color: var(--sklearn-color-text);\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-toggleable__content.fitted pre {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 input.sk-toggleable__control:checked~div.sk-toggleable__content {\n",
       "  /* Expand drop-down */\n",
       "  max-height: 200px;\n",
       "  max-width: 100%;\n",
       "  overflow: auto;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {\n",
       "  content: \"▾\";\n",
       "}\n",
       "\n",
       "/* Pipeline/ColumnTransformer-specific style */\n",
       "\n",
       "#sk-container-id-3 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
       "  color: var(--sklearn-color-text);\n",
       "  background-color: var(--sklearn-color-unfitted-level-2);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-label.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
       "  background-color: var(--sklearn-color-fitted-level-2);\n",
       "}\n",
       "\n",
       "/* Estimator-specific style */\n",
       "\n",
       "/* Colorize estimator box */\n",
       "#sk-container-id-3 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-2);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-estimator.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-2);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-label label.sk-toggleable__label,\n",
       "#sk-container-id-3 div.sk-label label {\n",
       "  /* The background is the default theme color */\n",
       "  color: var(--sklearn-color-text-on-default-background);\n",
       "}\n",
       "\n",
       "/* On hover, darken the color of the background */\n",
       "#sk-container-id-3 div.sk-label:hover label.sk-toggleable__label {\n",
       "  color: var(--sklearn-color-text);\n",
       "  background-color: var(--sklearn-color-unfitted-level-2);\n",
       "}\n",
       "\n",
       "/* Label box, darken color on hover, fitted */\n",
       "#sk-container-id-3 div.sk-label.fitted:hover label.sk-toggleable__label.fitted {\n",
       "  color: var(--sklearn-color-text);\n",
       "  background-color: var(--sklearn-color-fitted-level-2);\n",
       "}\n",
       "\n",
       "/* Estimator label */\n",
       "\n",
       "#sk-container-id-3 div.sk-label label {\n",
       "  font-family: monospace;\n",
       "  font-weight: bold;\n",
       "  display: inline-block;\n",
       "  line-height: 1.2em;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-label-container {\n",
       "  text-align: center;\n",
       "}\n",
       "\n",
       "/* Estimator-specific */\n",
       "#sk-container-id-3 div.sk-estimator {\n",
       "  font-family: monospace;\n",
       "  border: 1px dotted var(--sklearn-color-border-box);\n",
       "  border-radius: 0.25em;\n",
       "  box-sizing: border-box;\n",
       "  margin-bottom: 0.5em;\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-estimator.fitted {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-0);\n",
       "}\n",
       "\n",
       "/* on hover */\n",
       "#sk-container-id-3 div.sk-estimator:hover {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-2);\n",
       "}\n",
       "\n",
       "#sk-container-id-3 div.sk-estimator.fitted:hover {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-2);\n",
       "}\n",
       "\n",
       "/* Specification for estimator info (e.g. \"i\" and \"?\") */\n",
       "\n",
       "/* Common style for \"i\" and \"?\" */\n",
       "\n",
       ".sk-estimator-doc-link,\n",
       "a:link.sk-estimator-doc-link,\n",
       "a:visited.sk-estimator-doc-link {\n",
       "  float: right;\n",
       "  font-size: smaller;\n",
       "  line-height: 1em;\n",
       "  font-family: monospace;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "  border-radius: 1em;\n",
       "  height: 1em;\n",
       "  width: 1em;\n",
       "  text-decoration: none !important;\n",
       "  margin-left: 1ex;\n",
       "  /* unfitted */\n",
       "  border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
       "  color: var(--sklearn-color-unfitted-level-1);\n",
       "}\n",
       "\n",
       ".sk-estimator-doc-link.fitted,\n",
       "a:link.sk-estimator-doc-link.fitted,\n",
       "a:visited.sk-estimator-doc-link.fitted {\n",
       "  /* fitted */\n",
       "  border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
       "  color: var(--sklearn-color-fitted-level-1);\n",
       "}\n",
       "\n",
       "/* On hover */\n",
       "div.sk-estimator:hover .sk-estimator-doc-link:hover,\n",
       ".sk-estimator-doc-link:hover,\n",
       "div.sk-label-container:hover .sk-estimator-doc-link:hover,\n",
       ".sk-estimator-doc-link:hover {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-3);\n",
       "  color: var(--sklearn-color-background);\n",
       "  text-decoration: none;\n",
       "}\n",
       "\n",
       "div.sk-estimator.fitted:hover .sk-estimator-doc-link.fitted:hover,\n",
       ".sk-estimator-doc-link.fitted:hover,\n",
       "div.sk-label-container:hover .sk-estimator-doc-link.fitted:hover,\n",
       ".sk-estimator-doc-link.fitted:hover {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-3);\n",
       "  color: var(--sklearn-color-background);\n",
       "  text-decoration: none;\n",
       "}\n",
       "\n",
       "/* Span, style for the box shown on hovering the info icon */\n",
       ".sk-estimator-doc-link span {\n",
       "  display: none;\n",
       "  z-index: 9999;\n",
       "  position: relative;\n",
       "  font-weight: normal;\n",
       "  right: .2ex;\n",
       "  padding: .5ex;\n",
       "  margin: .5ex;\n",
       "  width: min-content;\n",
       "  min-width: 20ex;\n",
       "  max-width: 50ex;\n",
       "  color: var(--sklearn-color-text);\n",
       "  box-shadow: 2pt 2pt 4pt #999;\n",
       "  /* unfitted */\n",
       "  background: var(--sklearn-color-unfitted-level-0);\n",
       "  border: .5pt solid var(--sklearn-color-unfitted-level-3);\n",
       "}\n",
       "\n",
       ".sk-estimator-doc-link.fitted span {\n",
       "  /* fitted */\n",
       "  background: var(--sklearn-color-fitted-level-0);\n",
       "  border: var(--sklearn-color-fitted-level-3);\n",
       "}\n",
       "\n",
       ".sk-estimator-doc-link:hover span {\n",
       "  display: block;\n",
       "}\n",
       "\n",
       "/* \"?\"-specific style due to the `<a>` HTML tag */\n",
       "\n",
       "#sk-container-id-3 a.estimator_doc_link {\n",
       "  float: right;\n",
       "  font-size: 1rem;\n",
       "  line-height: 1em;\n",
       "  font-family: monospace;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "  border-radius: 1rem;\n",
       "  height: 1rem;\n",
       "  width: 1rem;\n",
       "  text-decoration: none;\n",
       "  /* unfitted */\n",
       "  color: var(--sklearn-color-unfitted-level-1);\n",
       "  border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 a.estimator_doc_link.fitted {\n",
       "  /* fitted */\n",
       "  border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
       "  color: var(--sklearn-color-fitted-level-1);\n",
       "}\n",
       "\n",
       "/* On hover */\n",
       "#sk-container-id-3 a.estimator_doc_link:hover {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-3);\n",
       "  color: var(--sklearn-color-background);\n",
       "  text-decoration: none;\n",
       "}\n",
       "\n",
       "#sk-container-id-3 a.estimator_doc_link.fitted:hover {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-3);\n",
       "}\n",
       "</style><div id=\"sk-container-id-3\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>PCA(n_components=3)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator fitted sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-3\" type=\"checkbox\" checked><label for=\"sk-estimator-id-3\" class=\"sk-toggleable__label fitted sk-toggleable__label-arrow fitted\">&nbsp;&nbsp;PCA<a class=\"sk-estimator-doc-link fitted\" rel=\"noreferrer\" target=\"_blank\" href=\"https://scikit-learn.org/1.5/modules/generated/sklearn.decomposition.PCA.html\">?<span>Documentation for PCA</span></a><span class=\"sk-estimator-doc-link fitted\">i<span>Fitted</span></span></label><div class=\"sk-toggleable__content fitted\"><pre>PCA(n_components=3)</pre></div> </div></div></div></div>"
      ],
      "text/plain": [
       "PCA(n_components=3)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "pca = PCA(n_components=3)\n",
    "pca.fit(X)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Shape of data: (20, 5)\n",
      "Number of components found: 3\n",
      "\n",
      "Eigenvalues (Explained Variance):\n",
      "[8.38039202 2.27980048 0.59756047]\n",
      "\n",
      "Explained Variance Ratio (Scree Plot values):\n",
      "[0.74341963 0.20223976 0.05300924]\n",
      "\n",
      "Principal Components (Loadings):\n",
      "[[-0.12811828  0.26004447  0.14492492  0.29344522  0.89936047]\n",
      " [-0.24284499  0.27544842  0.88934033  0.03765262 -0.26983427]\n",
      " [ 0.74391845  0.62579178 -0.03849175  0.19062273 -0.13096312]]\n",
      "\n",
      "Singular Values (related to sqrt(eigenvalues)):\n",
      "[12.61853591  6.58150508  3.36951762]\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAk0AAAGGCAYAAABmPbWyAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABWtklEQVR4nO3dd1gUx/8H8PeB9A5KUxSwF0AiRsGC3cQeY2yoWKOxYsOWRDT2JJbEiDFRMQmoiYpJLFFs2Guwt68IVgix0A0IzO+P+3F4UtzTO+6E9+t57gk7Ozv7uc0qH2dmZ2VCCAEiIiIiKpGetgMgIiIiehswaSIiIiKSgEkTERERkQRMmoiIiIgkYNJEREREJAGTJiIiIiIJmDQRERERScCkiYiIiEgCJk1EREREEjBpIiKNOnXqFD744ANUrVoVRkZGcHBwgK+vLyZPnqzt0FQWFhYGmUym+FSoUAFVqlTBkCFD8ODBA0W9Q4cOQSaT4dChQyqf4/jx4wgJCUFycrL6AicitWDSREQas3PnTvj5+SE1NRVLlizB3r17sWLFCjRr1gybN2/Wdnivbf369Thx4gSioqIwYsQIbNy4ES1atEBGRsYbt338+HHMmTOHSRORDqqg7QCIqOxasmQJ3NzcsGfPHlSoUPDXTd++fbFkyRK1nCMzMxOmpqZqaUuqBg0awMfHBwDQunVr5Obm4osvvsD27dsREBBQqrEQUelhTxMRaczjx49RsWJFpYQpn55e4b9+IiIi4OvrC3Nzc5ibm6Nhw4ZYu3atYn+rVq3QoEEDHD58GH5+fjA1NcXQoUMBAKmpqZgyZQrc3NxgaGiIypUrIygoqFDvjxACq1atQsOGDWFiYgIbGxv06tULt2/ffu3v2bRpUwDAnTt3Sqz3xx9/wNfXF6amprCwsED79u1x4sQJxf6QkBBMnToVAODm5qYYBnydYT4iUj8mTUSkMb6+vjh16hTGjx+PU6dO4fnz58XW/fzzzxEQEABnZ2eEhYUhMjISgYGBhRKRhIQEDBgwAP3798euXbswevRoZGZmwt/fHxs2bMD48eOxe/duTJs2DWFhYejWrRuEEIrjR44ciaCgILRr1w7bt2/HqlWrcOXKFfj5+eGff/55re9569YtAEClSpWKrRMREYHu3bvD0tISGzduxNq1a/H06VO0atUKR48eBQAMHz4c48aNAwBs27YNJ06cwIkTJ/DOO++8VlxEpGaCiEhDHj16JJo3by4ACADCwMBA+Pn5iYULF4q0tDRFvdu3bwt9fX0REBBQYnv+/v4CgNi/f79S+cKFC4Wenp44c+aMUvmWLVsEALFr1y4hhBAnTpwQAMTXX3+tVO/evXvCxMREBAcHl3j+9evXCwDi5MmT4vnz5yItLU3s2LFDVKpUSVhYWIjExEQhhBAHDx4UAMTBgweFEELk5uYKZ2dn4eHhIXJzcxXtpaWlCXt7e+Hn56co+/LLLwUAERcXV2IsRFT62NNERBpjZ2eHI0eO4MyZM1i0aBG6d++OmzdvYsaMGfDw8MCjR48AAFFRUcjNzcWYMWNe2aaNjQ3atGmjVLZjxw40aNAADRs2RE5OjuLTsWNHpeGtHTt2QCaTYcCAAUr1HB0d4eXlJXkYrGnTpjAwMICFhQW6dOkCR0dH7N69Gw4ODkXWv3HjBh4+fIiBAwcqDUuam5vjww8/xMmTJ5GZmSnp3ESkPZwITkQa5+Pjo5g4/fz5c0ybNg3Lli3DkiVLsGTJEvz7778AgCpVqryyLScnp0Jl//zzD27dugUDA4Mij8lPzv755x8IIYpNbtzd3SV9n59++gl169ZFhQoV4ODgUGRML3r8+HGxsTs7OyMvLw9Pnz4t9QntRKQaJk1EVKoMDAwwe/ZsLFu2DJcvXwZQMBfo/v37cHFxKfF4mUxWqKxixYowMTHBunXrijymYsWKiv/KZDIcOXIERkZGheoVVVaUunXrKpJAKezs7ADI52O97OHDh9DT04ONjY3k9ohIO5g0EZHGJCQkFNm7cu3aNQDyXhYA6NChA/T19REaGgpfX1+Vz9OlSxcsWLAAdnZ2cHNzK7HeokWL8ODBA/Tu3Vvl87yu2rVro3LlyoiIiMCUKVMUiV9GRga2bt2qeKIOKEjcnj17VmrxEZE0TJqISGM6duyIKlWqoGvXrqhTpw7y8vJw/vx5fP311zA3N8eECRMAAK6urpg5cya++OILPHv2DP369YOVlRWuXr2KR48eYc6cOSWeJygoCFu3bkXLli0xceJEeHp6Ii8vD3fv3sXevXsxefJkNGnSBM2aNcPHH3+MIUOG4OzZs2jZsiXMzMyQkJCAo0ePwsPDA5988onar4Oenh6WLFmCgIAAdOnSBSNHjkRWVha+/PJLJCcnY9GiRYq6Hh4eAIAVK1YgMDAQBgYGqF27NiwsLNQeFxGpSNsz0Ymo7Nq8ebPo37+/qFmzpjA3NxcGBgaiatWqYuDAgeLq1auF6v/000+icePGwtjYWJibmwtvb2+xfv16xX5/f39Rv379Is+Vnp4uPv30U1G7dm1haGgorKyshIeHh5g4caLiqbZ869atE02aNBFmZmbCxMREVK9eXQwaNEicPXu2xO+T//Tcy0/pvezlp+fybd++XTRp0kQYGxsLMzMz0bZtW3Hs2LFCx8+YMUM4OzsLPT29ItshIu2QCfHCAiZEREREVCQuOUBEREQkAZMmIiIiIgmYNBERERFJwKSJiIiISAImTUREREQSMGkiIiIikoCLWwLIy8vDw4cPYWFhUeQrGoiIiKhsEEIgLS0Nzs7OSi/QloJJE+TvfnrV+66IiIio7Lh3756kl4S/iEkToHg9wb1792BpaanlaIiIiEhTUlNT4eLi8lqvJmLShIK3pltaWjJpIiIiKgdeZzoOJ4ITERERScCkiYiIiEgCJk1EREREEjBpIiIiIpKASRMRERGRBEyaiIiIiCRg0kREREQkgVaTpsOHD6Nr165wdnaGTCbD9u3blfYLIRASEgJnZ2eYmJigVatWuHLlilKdrKwsjBs3DhUrVoSZmRm6deuG+/fvl+K3ICIiUoPcXODQIWDjRvl/c3O1HRG9RKtJU0ZGBry8vLBy5coi9y9ZsgRLly7FypUrcebMGTg6OqJ9+/ZIS0tT1AkKCkJkZCQ2bdqEo0ePIj09HV26dEEubzYiInpbbNsGuLoCrVsD/fvL/+vqKi8nnSETQghtBwHIV+aMjIxEjx49AMh7mZydnREUFIRp06YBkPcqOTg4YPHixRg5ciRSUlJQqVIl/Pzzz+jTpw+AgvfI7dq1Cx07dpR07tTUVFhZWSElJYUrghMRUenatg3o1Qt4+ddx/orVW7YAPXuWflxl1Jv8ztfZOU1xcXFITExEhw4dFGVGRkbw9/fH8ePHAQDnzp3D8+fPleo4OzujQYMGijpEREQ6KzcXmDChcMIEFJQFBXGoTkfo7LvnEhMTAQAODg5K5Q4ODrhz546ijqGhIWxsbArVyT++KFlZWcjKylJsp6amqitsIiKiAkIAT54AiYlFf65eBUqahysEcO8ecOQI0KpVqYVNRdPZpCnfyy/UE0K88iV7r6qzcOFCzJkzRy3xERFROZSRUXwi9OLnn3+A58/f/HwJCW/eBr0xnU2aHB0dAch7k5ycnBTlSUlJit4nR0dHZGdn4+nTp0q9TUlJSfDz8yu27RkzZmDSpEmK7dTUVLi4uKj7KxAR0dvk+XMgKUlaMpSerlrbtraAo2Phz9OnwMKFrz7+hd+DpD06mzS5ubnB0dERUVFR8Pb2BgBkZ2cjOjoaixcvBgA0atQIBgYGiIqKQu/evQEACQkJuHz5MpYsWVJs20ZGRjAyMtL8lyAiIu161fDYi59Hj1Rr28REnswUlQy9+LG3B4r7nZObC/z8M/DgQdHzmmQyoEoVoEUL1b87qZ1Wk6b09HTcunVLsR0XF4fz58/D1tYWVatWRVBQEBYsWICaNWuiZs2aWLBgAUxNTdG/f38AgJWVFYYNG4bJkyfDzs4Otra2mDJlCjw8PNCuXTttfS0iItI0TQ2P6esDDg6vToQcHQFz84In3F6Xvj6wYoX86TmZTDlxym97+XJ5PdI6rSZNZ8+eRevWrRXb+UNmgYGBCAsLQ3BwMJ49e4bRo0fj6dOnaNKkCfbu3QsLCwvFMcuWLUOFChXQu3dvPHv2DG3btkVYWBj0eYMREb1dtDE89vLHzg7QK+UHy3v2lC8rMGGC8qTwKlXkCROXG9AZOrNOkzZxnSYiIg3R5PCYqam0RKik4TFdkpsrf0ouIUE+7NeiBXuYNOBNfufr7JwmIiLSYenp8qEvdQ+PVahQ8vDYi/vUMTymS/T1uayAjmPSREREctnZrx4ey0+UVB0es7OT1itka1v6w2NEEjFpIiIqy/LypA+PPX6sWtumptKfHjM01Mz3IypFTJqIiN5G6enSnx7LyZHe7quGx15+eoyoHGHSRETlj65OuJUyPJb/ychQrW0OjxG9MSZNRFS+bNtW9KPdK1Zo5tFuDo8RlRlMmoio/Ni2Tb6I4MsrrTx4IC/fskV64sThMaJyh0kTEZUPubnyHqailqYTQv7o+oQJQKNGwL//cniMiAph0kRE5cORI8pDci8TQr7f1VV6mxweIypXmDQRUflw7560enp60hIhDo8RlTtMmoio7BICOHUKCA8HfvpJ2jFRUUCbNpqNi4jeSkyaiKjsuXlTniiFhwOxsQXlenryp9mKIpPJn6Lz9y+dGInorcOkiYjKhn/+ATZvBn75BThzpqDc1BT44AMgIABISwP69pWXvzghPP/9ZcuX68Z6TUSkk5g0EdHbKz0d2L5d3qMUFSV/Qg6QJz7t2wMDBgDduyvPPapQoeh1mpYv18w6TURUZjBpIqK3S06OPEEKDwciI4HMzIJ9774r71Hq00e+1lFRevaUJ1K6uCI4Eek0Jk1EpPuEkA+5/fKLfAguKalgX/Xq8h6l/v2BWrWktaevD7RqpZFQiajsYtJERLrr1i15j9Ivv8h/zlepkrw3acAAee9S/pwkIiINYtJERLolKUnemxQeLl8uIJ+JScGE7vbtAQMD7cVIROUSkyYi0r6MDOD33+U9Snv3Fkzo1tMrmNDdowcXkyQirWLSRETakZMD7NtXMKH7xXe5NW5cMKHb0VF7MRIRvYBJExGVHiGAs2flidLGjcoTut3d5YlSQABQu7b2YiQiKgaTJiLSvNjYghW6b94sKLezky82GRAANG3KCd1EpNOYNBGRZvz7L/Drr/J5SidPFpSbmMjXSRowAOjQgRO6ieitwaSJiNQnM1M+oTs8HNizRz5vCZBP6G7XTt6j9MEHgIWFduMkInoNTJqI6M3k5AAHDsh7lCIj5a82ydeokbxHqU8f+crbRERvMSZNRKQ6IYBz5womdP/zT8E+N7eCCd116mgvRiIiNWPSRETS3b4NRETIe5Vu3Cgot7MDeveW9yr5+nJCNxGVSUyaiKhkjx7JJ3SHhwPHjxeUGxvLJ3QHBAAdOwKGhtqLkYioFDBpIqLCMjOBP/+U9yj99ZfyhO42beQ9Sh98AFhaajdOIqJSxKSJiORyc+UTusPDga1blSd0v/OOvEepb1/A2Vl7MRIRaRGTJqLyTAggJkbeo7RpE5CQULDP1bVgQnfduloLkYhIVzBpIiqP4uIKJnRfv15QbmtbMKHbz48TuomIXsCkiai8ePwY+O03eaJ07FhBubEx0LWrPFF67z1O6CYiKobKSVNWVhZOnz6N+Ph4ZGZmolKlSvD29oabm5sm4iOiN/HsmXxCd3g4sHs38Py5vFwmk0/oDggAevYErKy0GycR0VtActJ0/PhxfPvtt9i+fTuys7NhbW0NExMTPHnyBFlZWXB3d8fHH3+MUaNGwYKvSCDSntxc4NAheY/S1q1AWlrBvoYN5T1KffsClStrK0IioreSpKSpe/fuOHPmDPr37489e/bAx8cHpqamiv23b9/GkSNHsHHjRixduhQ//fQT2rdvr7GgieglQgDnzxes0P3wYcG+atWA/v3lvUr162stRCKit52kpKlDhw747bffYFjMXAd3d3e4u7sjMDAQV65cwcMX/8ImIs2Jj5dP6A4PB65eLSi3sZFP6A4IAJo1k6+vREREb0QmhBDaDkLbUlNTYWVlhZSUFFhysT7SdU+eFEzoPnq0oNzISHlCt5GR9mIkItJRb/I7/42enrt8+TKio6ORm5sLPz8/+Pj4vElzRFSc//4DduyQJ0q7dilP6G7dWt6j9OGHnNBNRKRBr91n/91336Ft27aIjo7GwYMH0bZtW8yfP1+dsRGVb/krdA8bBjg4AB99BPz+uzxh8vICvvwSuHsX2L8fGDqUCRMRkYZJHp67f/8+qlSpotiuW7cujhw5gooVKwIATpw4gW7duuHff//VTKQaxOE50hlCABcvynuUNm4EHjwo2Fe1asGE7gYNtBcjEdFb7E1+50vuaWrbti1WrFiB/BzLzs4Oe/bsQVZWFtLS0rBv3z5UqlRJtciJSO7uXWDRIsDDQ74swFdfyRMma2vg44+B6Gj5Kt4LFzJhIiLSEsk9TampqZg2bRrOnTuH77//HkZGRhg4cCBiYmIgk8lQt25drF+/Ho0bN9Z0zGrHnibSiqdP5RO6w8OBw4cLyg0N5RO6AwKATp04oZuISI1KZSK4paUlQkNDcezYMQwePBjt2rXDkSNHkJubi9zcXFhbW6saN1H5899/wM6dBRO6s7Pl5TIZ4O8vf/Ltww/lPUxERKRTVJ4I3qxZM5w9exZWVlbw9vbG4cOHmTARlSQvDzh4EBg+HHB0BHr1ArZvlydMnp7A4sXAnTvyOsOGMWEiItJRkofncnJy8MMPP+Dq1avw8vLCkCFDEBsbi5EjR6JixYr49ttv4ejoqOl4NYLDc6QRL07ovn+/oLxKFfnQW0CAfA4TERGVmlIZnhsxYgROnTqFbt26Yf369bh48SK++eYbHDx4ED/++CN8fX0RHByMTz75ROUvQFRm3LsnX6H7l1+Ay5cLyq2s5EsGDBgAtGjBFbqJiN5Ckv/m3r59O7Zu3YpFixZh37592Llzp2Lf8OHDcerUKRw5ckStweXk5ODTTz+Fm5sbTExM4O7ujrlz5yIvL09RRwiBkJAQODs7w8TEBK1atcKVK1fUGgdRiZKTgR9/BFq1ki8LMH26PGEyNAQ++ED+0tzEROCHH+TzlpgwERG9lST3NNnb22Pv3r2oXr069u/fDzs7u0L7IyIi1Brc4sWLsXr1amzYsAH169fH2bNnMWTIEFhZWWHChAkAgCVLlmDp0qUICwtDrVq1MG/ePLRv3x43btyAhYWFWuMhUsjKkk/oDg+Xr9SdP6EbkCdGAQHyuUs2NtqLkYiI1ErynKaoqCgMGDAAjx49gpOTE3799Vf4+flpNLguXbrAwcEBa9euVZR9+OGHMDU1xc8//wwhBJydnREUFIRp06YBALKysuDg4IDFixdj5MiRks7DOU0kSV4ecOSIfOhtyxZ5D1O+Bg3kQ2/9+sl7m4iISCeVypym9u3bIzExEY8ePSq1RSybN2+O1atX4+bNm6hVqxYuXLiAo0ePYvny5QCAuLg4JCYmokOHDopjjIyM4O/vj+PHj0tOmohKdOmSvEcpIkI+Zylf5cryFboHDJA/BUdERGWaSi/slclkpbrq97Rp05CSkoI6depAX18fubm5mD9/Pvr16wcASExMBAA4ODgoHefg4IA7d+4U225WVhaysrIU26mpqRqInt5q9+/Lk6TwcPlTcPksLeUTugMCgJYtAX197cVIRESlSlLS9N577+Hzzz9/5XBcWloaVq1aBXNzc4wZM+aNg9u8eTN++eUXREREoH79+jh//jyCgoLg7OyMwMBART2ZTKZ0nBCiUNmLFi5ciDlz5rxxfFTGJCfLJ23/8ov8tSX5I9cGBkDnzvIepc6dAWNjrYZJRETaISlp+uijj9C7d29YWFigW7du8PHxgbOzM4yNjfH06VNcvXoVR48exa5du9ClSxd8+eWXaglu6tSpmD59Ovr27QsA8PDwwJ07d7Bw4UIEBgYq1oVKTEyEk5OT4rikpKRCvU8vmjFjBiZNmqTYTk1NhYuLi1piprdMVhawe7c8UdqxQ76dr0ULeaLUqxdga6u9GImISCdISpqGDRuGgQMHYsuWLdi8eTN++OEHJP//JFiZTIZ69eqhY8eOOHfuHGrXrq224DIzM6H30uPZ+vr6iiUH3Nzc4OjoiKioKHh7ewMAsrOzER0djcWLFxfbrpGREYz4Pq/yKy8POHpUPvT266/KE7rr1ZMnSv37A9WqaS1EIiLSPZLnNBkaGqJ///7o378/ACAlJQXPnj2DnZ0dDAwMNBJc165dMX/+fFStWhX169dHTEwMli5diqFDhwKQJ2xBQUFYsGABatasiZo1a2LBggUwNTVVxEmkcOWKvEcpIgK4e7eg3NlZniQFBABeXvL3wBEREb1EpYngL7KysoKVlZU6Yynk22+/xWeffYbRo0cjKSkJzs7OGDlyJD7//HNFneDgYDx79gyjR4/G06dP0aRJE+zdu5drNJHcgwfy15j88gtw4UJBuaWl/MW4AwbI11XihG4iInoFyes0lWVcp6mMSUmRT+gOD5e/BPfFCd2dOsl7lLp0AUxMtBsnERGVulJZp4lIp2VnF0zo/vNP5QndzZsXTOh+aSV7IiIiqZg00dsrLw84flyeKP36K/D0acG+unULJnS7umotRCIiKjuYNNHb5+pV+dBbeDjw4iKmTk4FE7obNuSEbiIiUqvXTprOnTuHa9euQSaToW7dunjnnXfUGReRsocP5RO6w8OBmJiCcguLggndrVpxQjcREWmMyklTUlIS+vbti0OHDsHa2hpCCKSkpKB169bYtGlTqb5mhcq41FRg2zb58NuBAwUTuitUKJjQ3bUrJ3QTEVGp0Ht1FWXjxo1Damoqrly5gidPnuDp06e4fPkyUlNTMX78eE3ESOVJdjbwxx9Anz6AgwMwZAiwf788YWrWDAgNBRITgd9/B3r3ZsJERESlRuUlB6ysrLBv3z40btxYqfz06dPo0KGDYqXwtwmXHNCw3FzgyBEgIUE+76hFC+VhNCGUJ3Q/eVKwr06dggndbm6lHzsREZUppbrkQF5eXpErgBsYGCheb0KksG0bMGECcP9+QVmVKsCKFfIn3MLD5St0x8UV7Hd0BPr1kydL3t6c0E1ERDpB5Z6m7t27Izk5GRs3boSzszMA4MGDBwgICICNjQ0iIyM1EqgmsadJQ7Ztk6+NJOUWMzeXT+gOCADatOGEbiIi0ohS7WlauXIlunfvDldXV7i4uEAmk+Hu3bvw8PDAL7/8ompzVFbl5sp7mF6VMHXuDAwcKJ/QbWpaOrERERG9BpWTJhcXF/z999+IiorC9evXIYRAvXr10K5dO03ER2+rI0eUh+SKM2WKfKkAIiIiHffa6zS1b98e7du3V2csZdawsDPaDqHUvXvyKEZKqPf9pqM4HW+m8Xh0ydrBjV9diYiIdI6kpOmbb77Bxx9/DGNjY3zzzTcl1uWyAwQAKdYV1VqPiIhI2yQlTcuWLUNAQACMjY2xbNmyYuvJZDImTQQAuFmrIZ7Y2MP6aVKRi4HlAXhq64CbtRqWcmRERESvR1LSFPfC4+Av/kxUHKGnj439J2P0d9OQB+VVVPMAyABs6jcJQo9PyRER0dtB5RXB586di8zMzELlz549w9y5c9USFJUNf/u0xqoxi5FsY69U/tTWAavGLMbfPq21FBkREZHqVF6nSV9fHwkJCbC3V/5F+PjxY9jb2yM3N1etAZYGTa/TVB4ngr9IlpeLWjfPwyr5EVKsK+JmrYbluoeJE8GJiLSnVNdpEkJAVsQKzRcuXICtra2qzVE5IPT0caNOI22HQURE9EYkJ002NjaQyWSQyWSoVauWUuKUm5uL9PR0jBo1SiNBEhEREWmb5KRp+fLlEEJg6NChmDNnDqysrBT7DA0N4erqCl9fX40ESURERKRtkpOmwMBAAICbmxv8/PyKfGkvERERUVml8pwmf39/xc/Pnj3D8+fPlfbzhbdERERUFqm85EBmZibGjh0Le3t7mJubw8bGRulDREREVBapnDRNnToVBw4cwKpVq2BkZIQff/wRc+bMgbOzM3766SdNxEhERESkdSoPz/3555/46aef0KpVKwwdOhQtWrRAjRo1UK1aNYSHhyMgIEATcRIRERFplco9TU+ePIGbmxsA+fylJ0+eAACaN2+Ow4cPqzc6IiIiIh2hctLk7u6O+Ph4AEC9evXw66+/ApD3QFlbW6szNiIiIiKdoXLSNGTIEFy4cAEAMGPGDMXcpokTJ2Lq1KlqD5CIiIhIF6g8p2nixImKn1u3bo3r16/j7NmzqF69Ory8vNQaHBEREZGuUDlpelnVqlVRtWpVAMCWLVvQq1evNw6KiIiISNeoNDyXk5ODK1eu4ObNm0rlv//+O7y8vPjkHBEREZVZkpOmq1evolatWvD09ETdunXRs2dP/PPPP/D390dgYCDat2+PW7duaTJWIiIiIq2RPDw3ffp0uLm54ZtvvkF4eDg2b96My5cvY8CAAdixYwcsLCw0GScRERGRVklOmk6fPo1du3bhnXfeQfPmzbF582ZMnToVI0aM0GR8RERERDpB8vBcUlISKleuDACwtraGqamp0st7iYiIiMoyyUmTTCaDnl5BdT09PRgYGGgkKCIiIiJdI3l4TgiBWrVqQSaTAQDS09Ph7e2tlEgBULxWhYiIiKgskZw0rV+/XpNxEBEREek0yUlTYGCgJuMgIiIi0mkqv3uOiIiIqDxi0kREREQkAZMmIiIiIgmYNBERERFJ8NpJU3Z2Nm7cuIGcnBx1xkNERESkk1ROmjIzMzFs2DCYmpqifv36uHv3LgBg/PjxWLRokdoDJCIiItIFKidNM2bMwIULF3Do0CEYGxsrytu1a4fNmzerNTgiIiIiXSF5naZ827dvx+bNm9G0aVPF6uAAUK9ePcTGxqo1OCIiIiJdoXJP07///gt7e/tC5RkZGUpJFBEREVFZonLS1LhxY+zcuVOxnZ8o/fDDD/D19VVfZP/vwYMHGDBgAOzs7GBqaoqGDRvi3Llziv1CCISEhMDZ2RkmJiZo1aoVrly5ovY4iIiIqHxTeXhu4cKFeO+993D16lXk5ORgxYoVuHLlCk6cOIHo6Gi1Bvf06VM0a9YMrVu3xu7du2Fvb4/Y2FhYW1sr6ixZsgRLly5FWFgYatWqhXnz5qF9+/a4ceMGLCws1BoPERERlV8q9zT5+fnh2LFjyMzMRPXq1bF37144ODjgxIkTaNSokVqDW7x4MVxcXLB+/Xq8++67cHV1Rdu2bVG9enUA8l6m5cuXY9asWejZsycaNGiADRs2IDMzExEREWqNhYiIiMo3lXuaAMDDwwMbNmxQdyyF/PHHH+jYsSM++ugjREdHo3Llyhg9ejRGjBgBAIiLi0NiYiI6dOigOMbIyAj+/v44fvw4Ro4cWWS7WVlZyMrKUmynpqZq9osQEWmAEAI5OTnIzc3VdihEOkNfXx8VKlTQyDxrlZOmXbt2QV9fHx07dlQq37NnD/Ly8vD++++rLbjbt28jNDQUkyZNwsyZM3H69GmMHz8eRkZGGDRoEBITEwEADg4OSsc5ODjgzp07xba7cOFCzJkzR21xEhGVtuzsbCQkJCAzM1PboRDpHFNTUzg5OcHQ0FCt7aqcNE2fPr3IRSyFEJg+fbpak6a8vDz4+PhgwYIFAABvb29cuXIFoaGhGDRokKLey9mkEKLEDHPGjBmYNGmSYjs1NRUuLi5qi5uISJPy8vIQFxcHfX19ODs7w9DQkE8vE0H++z87Oxv//vsv4uLiULNmTejpqe+NcSonTf/73/9Qr169QuV16tTBrVu31BJUPicnp0Lnqlu3LrZu3QoAcHR0BAAkJibCyclJUScpKalQ79OLjIyMYGRkpNZYiYhKS3Z2NvLy8uDi4gJTU1Nth0OkU0xMTGBgYIA7d+4gOztbaSHuN6Vy+mVlZYXbt28XKr916xbMzMzUElS+Zs2a4caNG0plN2/eRLVq1QAAbm5ucHR0RFRUlGJ/dnY2oqOj4efnp9ZYiIh0jTr/BU1Ulmjqz4bKrXbr1g1BQUFKq3/funULkydPRrdu3dQa3MSJE3Hy5EksWLAAt27dQkREBNasWYMxY8YAkA/LBQUFYcGCBYiMjMTly5cxePBgmJqaon///mqNhYiIiMo3lZOmL7/8EmZmZqhTpw7c3Nzg5uaGunXrws7ODl999ZVag2vcuDEiIyOxceNGNGjQAF988QWWL1+OgIAARZ3g4GAEBQVh9OjR8PHxwYMHD7B3716u0URERK9FJpNh+/btOtMO6Q6V5zRZWVnh+PHjiIqKwoULF2BiYgJPT0+0bNlSE/GhS5cu6NKlS7H7ZTIZQkJCEBISopHzExGVabm5wJEjQEIC4OQEtGgB6Otr/LSJiYmYP38+du7ciQcPHsDe3h4NGzZEUFAQ2rZtq/Hzq1NISAi2b9+O8+fPK5UnJCTAxsZGO0GRRrzWOk0ymQwdOnRQWh+JiIjeMtu2ARMmAPfvF5RVqQKsWAH07Kmx08bHx6NZs2awtrbGkiVL4OnpiefPn2PPnj0YM2YMrl+/rrFzl6b8h5Wo7HitmVL79+/HzJkzMXz4cAwdOlTpQ0REb4Ft24BevZQTJgB48EBevm2bxk49evRoyGQynD59Gr169UKtWrVQv359TJo0CSdPnkR8fDxkMplSz01ycjJkMhkOHToEADh06BBkMhn27NkDb29vmJiYoE2bNkhKSsLu3btRt25dWFpaol+/fkprWbm6umL58uVK8TRs2LDE0Ypp06ahVq1aMDU1hbu7Oz777DM8f/4cABAWFoY5c+bgwoULkMlkkMlkCAsLA6A8POfr64vp06crtfvvv//CwMAABw8eBCB/kCk4OBiVK1eGmZkZmjRpovi+pBtU7mmaM2cO5s6dCx8fHzg5OXFtECIiXSAEIHWhy9xcYPx4+TFFtSOTyXug2rWTNlRnaio/RoInT57gr7/+wvz584t84tra2hrJycmS2gLkQ2MrV66Eqakpevfujd69e8PIyAgRERFIT0/HBx98gG+//RbTpk2T3ObLLCwsEBYWBmdnZ1y6dAkjRoyAhYUFgoOD0adPH1y+fBl//fUX9u3bB0A+jeVlAQEB+PLLL7Fw4ULF783NmzfDwcEB/v7+AIAhQ4YgPj4emzZtgrOzMyIjI/Hee+/h0qVLqFmz5mvHT+qjctK0evVqhIWFYeDAgZqIh4iIXkdmJmBurp62hJD3QBXxy79I6emAxCVnbt26BSEE6tSp8wYBFpg3bx6aNWsGABg2bBhmzJiB2NhYuLu7AwB69eqFgwcPvlHS9Omnnyp+dnV1xeTJk7F582YEBwfDxMQE5ubmqFChQonDcX369MHEiRNx9OhRtGjRAgAQERGB/v37Q09PD7Gxsdi4cSPu378PZ2dnAMCUKVPw119/Yf369YpFnkm7VE6asrOzuQYSERG9FvH/vVvqGqXw9PRU/Ozg4KAYQnux7PTp0290ji1btmD58uW4desW0tPTkZOTA0tLS5XaqFSpEtq3b4/w8HC0aNECcXFxOHHiBEJDQwEAf//9N4QQqFWrltJxWVlZsLOze6P4SX1UntM0fPhwREREaCIWIiJ6Xaam8h4fKZ9du6S1uWuXtPZUWJW8Zs2akMlkuHbtWrF18hcmFC8MH+bPIXqZgYGB4meZTKa0nV+Wl5en1LZ4aViyuLYB4OTJk+jbty/ef/997NixAzExMZg1axays7OLPaY4AQEB2LJlC54/f46IiAjUr18fXl5eAOSvxtHX18e5c+dw/vx5xefatWtYsWKFyucizVC5p+m///7DmjVrsG/fPnh6eha6QZcuXaq24IiISCKZTPIQGTp0kD8l9+BB0fOaZDL5/g4d1L78gK2tLTp27IjvvvsO48ePLzSvKTk5GZUqVQIgf2Tf29sbAAo9zv+6KlWqhISEBMV2amoq4uLiiq1/7NgxVKtWDbNmzVKUvfxCeENDQ+Tm5r7y3D169MDIkSPx119/ISIiQmmai7e3N3Jzc5GUlKQYviPdo3LSdPHiRTRs2BAAcPnyZaV9nBRORPQW0NeXLyvQq5c8QXoxccr/e3z5co2t17Rq1Sr4+fnh3Xffxdy5c+Hp6YmcnBxERUUhNDQU165dQ9OmTbFo0SK4urri0aNHSvOK3kSbNm0QFhaGrl27wsbGBp999hn0S/ieNWrUwN27d7Fp0yY0btwYO3fuRGRkpFIdV1dXxMXF4fz586hSpQosLCyKfL+pmZkZunfvjs8++wzXrl1TenNFrVq1EBAQgEGDBuHrr7+Gt7c3Hj16hAMHDsDDwwOdOnVSy/enN6Ny0pT/aCQREb3FevYEtmwpep2m5cs1uk6Tm5sb/v77b8yfPx+TJ09GQkICKlWqhEaNGinm+Kxbtw5Dhw6Fj48PateujSVLlqhlbcAZM2bg9u3b6NKlC6ysrPDFF1+U2NPUvXt3TJw4EWPHjkVWVhY6d+6Mzz77TGmJgg8//BDbtm1D69atkZycjPXr12Pw4MFFthcQEIDOnTujZcuWqFq1qtK+9evXY968eZg8eTIePHgAOzs7+Pr6MmHSITLx8uBuOZSamgorKyukpKSoPLlPimFhZ9TeJr291g5urO0Q6C3333//IS4uDm5ubm/+BnctrQhOpEkl/Rl5k9/5r7Ui+JkzZ/Dbb7/h7t27hSbDbdPggmhERKRm+vpAq1bajoLoraDy03ObNm1Cs2bNcPXqVURGRuL58+e4evUqDhw4UOSCXkRERERlgcpJ04IFC7Bs2TLs2LEDhoaGWLFiBa5du4bevXsXGp8lIiIiKitUTppiY2PRuXNnAICRkREyMjIgk8kwceJErFmzRu0BEhEREekClZMmW1tbpKWlAQAqV66sWHYgOTlZ6aWIRERERGWJyhPBW7RogaioKHh4eKB3796YMGECDhw4gKioKLRt21YTMRIRERFpncpJ08qVK/Hff/8BkK93YWBggKNHj6Jnz5747LPP1B4gERERkS5QOWmytbVV/Kynp4fg4GAEBwerNSgiIiIiXSMpaUpNTVUsAJWamlpiXU0sDklERESkbZImgtvY2CApKQkAYG1tDRsbm0Kf/HIiIiJNk8lk2L59OwAgPj4eMplMpZf6vnh8UV6nTSlcXV2xfPlytbZJpUdST9OBAwcUw3J89xwRke4q7dc2qfpaoMGDByM5ObnEhEVVLi4uSEhIQMWKFSUfk5CQwH/ov6U0cQ9JJSlp8vf3BwDk5OTg0KFDGDp0KFxcXDQaGBERkRT6+vpwdHRU6RhV6xMBKq7TVKFCBXz11VfIzc3VVDxERFSOtGrVCuPHj0dwcDBsbW3h6OiIkJAQpTr/+9//0LJlSxgbG6NevXqIiopS2v/iUFpeXh6qVKmC1atXK9X5+++/IZPJcPv2bQCFh+dOnz4Nb29vGBsbw8fHBzExMUrHh4WFwdraWqls+/btkMlkiu3Y2Fh0794dDg4OMDc3R+PGjbFv3z6Vr8m6detQv359GBkZwcnJCWPHjlXsu3v3Lrp37w5zc3NYWlqid+/e+OeffxT7Q0JC0LBhQ6xbtw5Vq1aFubk5PvnkE+Tm5mLJkiVwdHSEvb095s+fr3ROmUyG0NBQvP/++zAxMYGbmxt+++03pTqXLl1CmzZtYGJiAjs7O3z88cdIT09X7B88eDB69OiBr776Ck5OTrCzs8OYMWPw/PlzRZ3s7GwEBwejcuXKMDMzQ5MmTXDo0KFC13nPnj2oW7cuzM3N8d577yEhIUHx/TZs2IDff/8dMpkMMplM6XhNU3lxy7Zt25ZqgEREVLZt2LABZmZmOHXqFJYsWYK5c+cqEqO8vDz07NkT+vr6OHnyJFavXo1p06YV25aenh769u2L8PBwpfKIiAj4+vrC3d290DEZGRno0qULateujXPnziEkJARTpkxR+Xukp6ejU6dO2LdvH2JiYtCxY0d07doVd+/eldxGaGgoxowZg48//hiXLl3CH3/8gRo1agAAhBDo0aMHnjx5gujoaERFRSE2NhZ9+vRRaiM2Nha7d+/GX3/9hY0bN2LdunXo3Lkz7t+/j+joaCxevBiffvopTp48qXTcZ599hg8//BAXLlzAgAED0K9fP1y7dg0AkJmZiffeew82NjY4c+YMfvvtN+zbt08poQPkU3hiY2Nx8OBBbNiwAWFhYQgLC1PsHzJkCI4dO4ZNmzbh4sWL+Oijj/Dee+/hf//7n6JOZmYmvvrqK/z88884fPgw7t69q/j/MWXKFPTu3VuRSCUkJMDPz0/y9X1TKi858P7772PGjBm4fPkyGjVqBDMzM6X93bp1U1twRERU9nl6emL27NkAgJo1a2LlypXYv38/2rdvj3379uHatWuIj49HlSpVAMjfgfr+++8X215AQACWLl2KO3fuoFq1asjLy8OmTZswc+bMIuuHh4cjNzcX69atg6mpKerXr4/79+/jk08+Uel7eHl5wcvLS7E9b948REZG4o8//iiUXBRn3rx5mDx5MiZMmKAoa9xYPm9s3759uHjxIuLi4hRTZH7++WfUr18fZ86cUdTLy8vDunXrYGFhgXr16qF169a4ceMGdu3aBT09PdSuXRuLFy/GoUOH0LRpU8V5PvroIwwfPhwA8MUXXyAqKgrffvstVq1ahfDwcDx79gw//fST4vf+ypUr0bVrVyxevBgODg4A5A+OrVy5Evr6+qhTpw46d+6M/fv3Y8SIEYiNjcXGjRtx//59ODs7A5AnQX/99RfWr1+PBQsWAACeP3+O1atXo3r16gCAsWPHYu7cuQAAc3NzmJiYICsrSytDrConTfk30dKlSwvtk8lkHLojIiKVeHp6Km07OTkpnti+du0aqlatqkiYAMDX17fE9ry9vVGnTh1s3LgR06dPR3R0NJKSktC7d+8i61+7dg1eXl4wNTWVfI6iZGRkYM6cOdixYwcePnyInJwcPHv2THJPU1JSEh4+fFjs2zWuXbsGFxcXpTnF9erVg7W1Na5du6ZImlxdXWFhYaGo4+DgAH19fejp6SmV5V/jfC9/Z19fX8XTg/nX6MWOkmbNmiEvLw83btxQJE3169eHvr6+oo6TkxMuXboEQD5EKoRArVq1lM6TlZUFOzs7xbapqakiYcpv4+VYtUXlpCkvL08TcRARUTllYGCgtC2TyRS/a4QQheq/OI+oOAEBAYiIiMD06dMRERGBjh07Fvt0XVHneJmenl6hei/O1QGAqVOnYs+ePfjqq69Qo0YNmJiYoFevXsjOzn5l+wBgYmJS4n4hRJHf/eXyoq5nSde4JPntFnfuF+sUd+788+Tl5UFfXx/nzp1TSqwAeQ9SSW1I+X9UGlSe00RERFRa6tWrh7t37+Lhw4eKshMnTrzyuP79++PSpUs4d+4ctmzZgoCAgBLPceHCBTx79kxR9vJ8n0qVKiEtLQ0ZGRmKspfXcDpy5AgGDx6MDz74AB4eHnB0dER8fPwrY81nYWEBV1dX7N+/v9g47969i3v37inKrl69ipSUFNStW1fyeYrz8nc+efIk6tSpozj3+fPnlb7/sWPHoKenV6jnqDje3t7Izc1FUlISatSoofRRZajN0NBQa6NaKvc0AfIuyOjoaNy9e7dQBj1+/Hi1BEZERNSuXTvUrl0bgwYNwtdff43U1FTMmjXrlce5ubnBz88Pw4YNQ05ODrp3715s3f79+2PWrFkYNmwYPv30U8THx+Orr75SqtOkSROYmppi5syZGDduHE6fPq00wRkAatSogW3btqFr166QyWT47LPPVB6dCQkJwahRo2Bvb4/3338faWlpOHbsGMaNG4d27drB09MTAQEBWL58OXJycjB69Gj4+/vDx8dHpfMU5bfffoOPjw+aN2+O8PBwnD59GmvXrgUg77mbPXs2AgMDERISgn///Rfjxo3DwIEDFUNzr1KrVi0EBAQo/l96e3vj0aNHOHDgADw8PNCpUydJ7bi6umLPnj24ceMG7OzsYGVlVah3SlNU7mmKiYlBjRo10K9fP4wdOxbz5s1DUFAQZs6cyVVOiYhIrfT09BAZGYmsrCy8++67GD58eKHH5YsTEBCACxcuoGfPniUOfZmbm+PPP//E1atX4e3tjVmzZmHx4sVKdWxtbfHLL79g165d8PDwwMaNGwstjbBs2TLY2NjAz88PXbt2RceOHfHOO++o9H0DAwOxfPlyrFq1CvXr10eXLl0UT5blL5NgY2ODli1bol27dnB3d8fmzZtVOkdx5syZg02bNsHT0xMbNmxAeHg46tWrB0A+z2jPnj148uQJGjdujF69eqFt27ZYuXKlSudYv349Bg0ahMmTJ6N27dro1q0bTp06pdLajyNGjEDt2rXh4+ODSpUq4dixYyrF8CZkQsWBwlatWqFWrVoIDQ2FtbU1Lly4AAMDAwwYMAATJkxAz549NRWrxqSmpsLKygopKSkaeXdeaa/QS7pN1RWUiV7233//IS4uDm5ubjA2NtZ2OFQGyGQyREZGokePHtoORS1K+jPyJr/zVe5pOn/+PCZPngx9fX3o6+sjKysLLi4uWLJkSbGPcxIRERG97VROmgwMDBQz5R0cHBSPUlpZWam0gBcRERHR20TlieDe3t44e/YsatWqhdatW+Pzzz/Ho0eP8PPPP8PDw0MTMRIREZEG6coj/bpOck9TTk4OAPlKrE5OTgDkK4ba2dnhk08+QVJSEtasWaOZKImIiIi0THJPk5OTEwIDAzF06FDFo42VKlXCrl27NBYcERERka6Q3NM0adIk/Pnnn/Dw8ICvry/Wrl2r9HZjIiIqXRxSISqapv5sSE6aZsyYgRs3buDQoUOoU6cOgoKC4OTkpHhjMRERlY78hfwyMzO1HAmRbsr/s6HuRS9VngjeokULtGjRAitXrsSmTZsQFhaGFi1aoGbNmhg2bBiCg4PVGiARESnT19eHtbW14iWmpqamkt7HRlTWCSGQmZmJpKQkWFtbF3rH3ZtSeXHLouzcuRODBg1CcnKy1t4H8ya4uCWVJi5uSeoghEBiYiKSk5O1HQqRzrG2toajo2OR/5h4k9/5r/XuOUDe9bV582asX78ex44dQ/Xq1TF16tTXbY6IiFQgk8ng5OQEe3t7PH/+XNvhEOkMAwMDtfcw5VM5aTpy5AjWr1+PLVu2IDc3F7169cK8efPQsmVLTcRHREQlyH87AxFpnuSkacGCBQgLC0NsbCx8fHzw5Zdfol+/fhoZziIiIiLSNZKTpmXLlmHAgAEYNmwYGjRooMmYiIiIiHSO5KTp4cOHan90j4iIiOhtIXmdJiZMREREVJ5JTpqIiIiIyrO3KmlauHAhZDIZgoKCFGVCCISEhMDZ2RkmJiZo1aoVrly5or0giYiIqEx6a5KmM2fOYM2aNfD09FQqX7JkCZYuXYqVK1fizJkzcHR0RPv27ZGWlqalSImIiKgskpQ0paamSv5oQnp6OgICAvDDDz/AxsZGUS6EwPLlyzFr1iz07NkTDRo0wIYNG5CZmYmIiAiNxEJERETlk6SkydraGjY2NpI+mjBmzBh07twZ7dq1UyqPi4tDYmIiOnTooCgzMjKCv78/jh8/rpFYiIiIqHyStOTAwYMHFT/Hx8dj+vTpGDx4MHx9fQEAJ06cwIYNG7Bw4UK1B7hp0yb8/fffOHOm8PvbEhMTAQAODg5K5Q4ODrhz506xbWZlZSErK0uxrakeMiIiIio7JCVN/v7+ip/nzp2LpUuXol+/foqybt26wcPDA2vWrEFgYKDagrt37x4mTJiAvXv3wtjYuNh6L7+QTwhR4hu/Fy5ciDlz5qgtTiIiIir7VJ4IfuLECfj4+BQq9/HxwenTp9USVL5z584hKSkJjRo1QoUKFVChQgVER0fjm2++QYUKFRQ9TPk9TvmSkpIK9T69aMaMGUhJSVF87t27p9a4iYiIqOxROWlycXHB6tWrC5V///33cHFxUUtQ+dq2bYtLly7h/Pnzio+Pjw8CAgJw/vx5uLu7w9HREVFRUYpjsrOzER0dDT8/v2LbNTIygqWlpdKHiIiIqCSSX6OSb9myZfjwww+xZ88eNG3aFABw8uRJxMbGYuvWrWoNzsLCotB77szMzGBnZ6coDwoKwoIFC1CzZk3UrFkTCxYsgKmpKfr376/WWIiIiKh8Uzlp6tSpE27evInQ0FBcv34dQgh0794do0aNUntPkxTBwcF49uwZRo8ejadPn6JJkybYu3cvLCwsSj0WIiIiKrtkQgih7SC0LTU1FVZWVkhJSdHIUN2wsMJP/lH5tXZwY22HQERUbr3J7/zXWhH8yJEjGDBgAPz8/PDgwQMAwM8//4yjR4++TnNEREREOk/lpGnr1q3o2LEjTExM8PfffyvWO0pLS8OCBQvUHiARERGRLlA5aZo3bx5Wr16NH374AQYGBopyPz8//P3332oNjoiIiEhXqJw03bhxAy1btixUbmlpieTkZHXERERERKRzVE6anJyccOvWrULlR48ehbu7u1qCIiIiItI1KidNI0eOxIQJE3Dq1CnIZDI8fPgQ4eHhmDJlCkaPHq2JGImIiIi0TuV1moKDg5GSkoLWrVvjv//+Q8uWLWFkZIQpU6Zg7NixmoiRiIiISOtUTpoAYP78+Zg1axauXr2KvLw81KtXD+bm5uqOjYiIiEhnvFbSBACmpqZFvriXiIiIqCxSOWnKyMjAokWLsH//fiQlJSEvL09p/+3bt9UWHBEREZGuUDlpGj58OKKjozFw4EA4OTlBJpNpIi4iIiIinaJy0rR7927s3LkTzZo100Q8RERERDpJ5SUHbGxsYGtrq4lYiIiIiHSWyknTF198gc8//xyZmZmaiIeIiIhIJ6k8PPf1118jNjYWDg4OcHV1VXr/HAC+f46IiIjKJJWTph49emggDCIiIiLdpnLSNHv2bE3EQURERKTTVJ7TRERERFQeSeppsrW1xc2bN1GxYkXY2NiUuDbTkydP1BYcERERka6QlDQtW7YMFhYWAIDly5drMh4iIiIinSQpaQoMDCzyZyIiIqLy4rVf2AsAz549w/Pnz5XKLC0t3yggIiIiIl2k8kTwjIwMjB07Fvb29jA3N4eNjY3Sh4iIiKgsUjlpCg4OxoEDB7Bq1SoYGRnhxx9/xJw5c+Ds7IyffvpJEzESERERaZ3Kw3N//vknfvrpJ7Rq1QpDhw5FixYtUKNGDVSrVg3h4eEICAjQRJxEREREWqVyT9OTJ0/g5uYGQD5/KX+JgebNm+Pw4cPqjY6IiIhIR6icNLm7uyM+Ph4AUK9ePfz6668A5D1Q1tbW6oyNiIiISGeonDQNGTIEFy5cAADMmDFDMbdp4sSJmDp1qtoDJCIiItIFKs9pmjhxouLn1q1b4/r16zh79iyqV68OLy8vtQZHREREpCveaJ0mAKhatSqqVq2qjliIiIiIdJakpOmbb76R3OD48eNfOxgiIiIiXSX53XNSyGQyJk1ERERUJklKmuLi4jQdBxEREZFOU/npuRcJISCEUFcsRERERDrrtZKmtWvXokGDBjA2NoaxsTEaNGiAH3/8Ud2xEREREekMlZ+e++yzz7Bs2TKMGzcOvr6+AIATJ05g4sSJiI+Px7x589QeJBEREZG2qZw0hYaG4ocffkC/fv0UZd26dYOnpyfGjRvHpImIiIjKJJWH53Jzc+Hj41OovFGjRsjJyVFLUERERES6RuWkacCAAQgNDS1UvmbNGgQEBKglKCIiIiJd81orgq9duxZ79+5F06ZNAQAnT57EvXv3MGjQIEyaNElRb+nSpeqJkoiIiEjLVE6aLl++jHfeeQcAEBsbCwCoVKkSKlWqhMuXLyvqyWQyNYVIREREpH0qJ00HDx7URBxEREREOk3lOU3//PNPsfsuXrz4RsEQERER6SqVkyYPDw/88ccfhcq/+uorNGnSRC1BEREREekalZOmadOmoU+fPhg1ahSePXuGBw8eoE2bNvjyyy+xefNmTcRIREREpHUqJ02TJ0/GyZMncezYMXh6esLT0xMmJia4ePEiunXrpokYiYiIiLTutd495+7ujvr16yM+Ph6pqano3bs3HBwc1B0bERERkc5QOWnK72G6desWLl68iNDQUIwbNw69e/fG06dPNREjERERkdapnDS1adMGffr0wYkTJ1C3bl0MHz4cMTExuH//Pjw8PNQa3MKFC9G4cWNYWFjA3t4ePXr0wI0bN5TqCCEQEhICZ2dnmJiYoFWrVrhy5Ypa4yAiIiJSOWnau3cvFi1aBAMDA0VZ9erVcfToUYwcOVKtwUVHR2PMmDE4efIkoqKikJOTgw4dOiAjI0NRZ8mSJVi6dClWrlyJM2fOwNHREe3bt0daWppaYyEiIqLyTSaEENoOQqp///0X9vb2iI6ORsuWLSGEgLOzM4KCgjBt2jQAQFZWFhwcHLB48WLJSVxqaiqsrKyQkpICS0tLtcc9LOyM2tukt9fawY21HQIRUbn1Jr/zJfc0derUCSkpKYrt+fPnIzk5WbH9+PFj1KtXT6WTqyr//La2tgCAuLg4JCYmokOHDoo6RkZG8Pf3x/Hjx4ttJysrC6mpqUofIiIiopJIfo3Knj17kJWVpdhevHgx+vXrB2trawBATk5OoflG6iSEwKRJk9C8eXM0aNAAAJCYmAgAhZ7cc3BwwJ07d4pta+HChZgzZ47GYiXSdez9pJexB5To1ST3NL08ilfao3pjx47FxYsXsXHjxkL7Xn45sBCixBcGz5gxAykpKYrPvXv31B4vERERlS0qv7BXG8aNG4c//vgDhw8fRpUqVRTljo6OAOQ9Tk5OTorypKSkEteNMjIygpGRkeYCJiIiojJHck+TTCYr1HtTUm+OOgghMHbsWGzbtg0HDhyAm5ub0n43Nzc4OjoiKipKUZadnY3o6Gj4+flpNDYiIiIqXyT3NAkhMHjwYEUPzX///YdRo0bBzMwMAJTmO6nLmDFjEBERgd9//x0WFhaKOUxWVlYwMTGBTCZDUFAQFixYgJo1a6JmzZpYsGABTE1N0b9/f7XHQ0REROWX5KQpMDBQaXvAgAGF6gwaNOjNI3pBaGgoAKBVq1ZK5evXr8fgwYMBAMHBwXj27BlGjx6Np0+fokmTJti7dy8sLCzUGgsRERGVb5KTpvXr12syjiJJmWwuk8kQEhKCkJAQzQdERERE5dZrvbCXiIiIqLxh0kREREQkAZMmIiIiIgmYNBERERFJwKSJiIiISAImTUREREQSMGkiIiIikoBJExEREZEETJqIiIiIJGDSRERERCQBkyYiIiIiCZg0EREREUnApImIiIhIAiZNRERERBIwaSIiIiKSgEkTERERkQRMmoiIiIgkYNJEREREJAGTJiIiIiIJmDQRERERScCkiYiIiEgCJk1EREREEjBpIiIiIpKASRMRERGRBEyaiIiIiCRg0kREREQkAZMmIiIiIgmYNBERERFJwKSJiIiISAImTUREREQSMGkiIiIikoBJExEREZEETJqIiIiIJGDSRERERCQBkyYiIiIiCZg0EREREUlQQdsBEBERAcCwsDPaDoF0yNrBjbUdQiHsaSIiIiKSgEkTERERkQRMmoiIiIgkYNJEREREJAGTJiIiIiIJmDQRERERScCkiYiIiEgCJk1EREREEjBpIiIiIpKASRMRERGRBGUmaVq1ahXc3NxgbGyMRo0a4ciRI9oOiYiIiMqQMpE0bd68GUFBQZg1axZiYmLQokULvP/++7h79662QyMiIqIyokwkTUuXLsWwYcMwfPhw1K1bF8uXL4eLiwtCQ0O1HRoRERGVEW990pSdnY1z586hQ4cOSuUdOnTA8ePHtRQVERERlTUVtB3Am3r06BFyc3Ph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",
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x400 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Extract essential info\n",
    "explained_variance = pca.explained_variance_           # eigenvalues\n",
    "explained_variance_ratio = pca.explained_variance_ratio_\n",
    "components = pca.components_                           # loadings\n",
    "singular_values = pca.singular_values_\n",
    "\n",
    "print(\"Shape of data:\", X.shape)\n",
    "print(\"Number of components found:\", pca.n_components_)\n",
    "\n",
    "print(\"\\nEigenvalues (Explained Variance):\")\n",
    "print(explained_variance)\n",
    "\n",
    "print(\"\\nExplained Variance Ratio (Scree Plot values):\")\n",
    "print(explained_variance_ratio)\n",
    "\n",
    "print(\"\\nPrincipal Components (Loadings):\")\n",
    "print(components)\n",
    "# Note: each row in `components` is a principal axis (length = n_features).\n",
    "# pca.components_.shape => (n_components, n_features)\n",
    "\n",
    "print(\"\\nSingular Values (related to sqrt(eigenvalues)):\")\n",
    "print(singular_values)\n",
    "\n",
    "# -----------------------\n",
    "# Scree Plot\n",
    "# -----------------------\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.bar(\n",
    "    range(1, pca.n_components_ + 1),\n",
    "    explained_variance_ratio * 100,\n",
    "    alpha=0.7,\n",
    "    label='Individual component'\n",
    ")\n",
    "plt.plot(\n",
    "    range(1, pca.n_components_ + 1),\n",
    "    np.cumsum(explained_variance_ratio) * 100,\n",
    "    marker='o', color='red', label='Cumulative'\n",
    ")\n",
    "plt.xlabel('Principal Component')\n",
    "plt.ylabel('Explained Variance Ratio (%)')\n",
    "plt.title('Scree Plot')\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "# -----------------------\n",
    "# Loadings Heatmap (optional)\n",
    "# -----------------------\n",
    "# A quick way to visualize how each original feature contributes\n",
    "# to each principal component.\n",
    "plt.figure(figsize=(6, 4))\n",
    "plt.imshow(components, aspect='auto', cmap='viridis')\n",
    "plt.colorbar(label=\"Loading\")\n",
    "plt.xlabel(\"Original Feature Index\")\n",
    "plt.ylabel(\"Principal Component\")\n",
    "plt.title(\"Heatmap of PCA Loadings\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "dl_env",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
