{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "5de5ac4c-2a63-4af8-8789-24f8e95f15e2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "import torch.nn.functional as F\n",
    "from sklearn.manifold import TSNE\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import scipy.stats as stats\n",
    "from scipy.stats import kurtosis, skew\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.decomposition import PCA\n",
    "import matplotlib.pyplot as plt\n",
    "from mpl_toolkits.mplot3d import Axes3D\n",
    "from scipy.spatial.distance import cdist"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "6051ac33-fb7f-41da-b81c-a2bf26fdfaff",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['participant_id', 'session_no', 'task_type', 'trial_no', 'day', 'block',\n",
       "       'start_point_x', 'start_point_y', 'target_point_x', 'target_point_y',\n",
       "       'start_time', 'end_time', 'quadrant', 'is_success', 'actual_dist',\n",
       "       'movement_dist', 'completion_time', 'path', 'time_string',\n",
       "       'time_diff_ms', 'Age', 'Cohort', 'Gestational_Age',\n",
       "       'mabc_total_test_score', 'mabc_standard_score', 'mabc_percentile',\n",
       "       'distances', 'rmsd', 'normalized_trajectory',\n",
       "       'trajectory_embedding_completion_time',\n",
       "       'trajectory_embedding_sequential', 'trajectory_embedding_rmsd',\n",
       "       'trajectory_embedding_success', 'trajectory_embedding_multi',\n",
       "       'trajectory_embedding_weighted_multi'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data_path = \"../saved_models/STCRL/embeddings/embedded_trajectories.csv\"\n",
    "#data_path = \"../saved_models/STCRL_transfer_learning/embeddings/embedded_trajectories.csv\"\n",
    "df = pd.read_csv(data_path)\n",
    "df.columns"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e25adf38-1d05-408a-8137-e948e27f7e13",
   "metadata": {},
   "source": [
    "### Trajectory normalization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "68d210d5-2ea3-4b97-a3b2-5bcc7c4bc95f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import ast\n",
    "\n",
    "def normalize_trajectory_3d(trajectory, time_sequence, target_position=np.array([1.0, 0.0])):\n",
    "    \"\"\"\n",
    "    Normalize trajectory spatially while preserving original time.\n",
    "    \n",
    "    Args:\n",
    "        trajectory: numpy array of shape (num_points, 2) containing x,y coordinates\n",
    "        time_sequence: numpy array of timestamps in milliseconds for each point\n",
    "        target_position: desired end position for all trajectories (default: [1,0])\n",
    "    \n",
    "    Returns:\n",
    "        Normalized 3D trajectory (x, y, time_in_seconds)\n",
    "    \"\"\"\n",
    "    # Convert time from milliseconds to seconds\n",
    "    time_sequence_seconds = time_sequence / 1000.0\n",
    "    \n",
    "    # Spatial normalization\n",
    "    start_pos = trajectory[0]\n",
    "    centered = trajectory - start_pos\n",
    "    \n",
    "    # Get current target position after centering\n",
    "    current_target = centered[-1]\n",
    "    \n",
    "    # Calculate rotation angle to align with desired target\n",
    "    current_angle = np.arctan2(current_target[1], current_target[0])\n",
    "    desired_angle = np.arctan2(target_position[1], target_position[0])\n",
    "    rotation_angle = desired_angle - current_angle\n",
    "    \n",
    "    # Create rotation matrix\n",
    "    cos_theta = np.cos(rotation_angle)\n",
    "    sin_theta = np.sin(rotation_angle)\n",
    "    rotation_matrix = np.array([[cos_theta, -sin_theta],\n",
    "                              [sin_theta, cos_theta]])\n",
    "    \n",
    "    # Rotate trajectory\n",
    "    rotated = np.dot(centered, rotation_matrix.T)\n",
    "    \n",
    "    # Scale to match target length\n",
    "    current_length = np.linalg.norm(rotated[-1])\n",
    "    target_length = np.linalg.norm(target_position)\n",
    "    scale_factor = target_length / current_length if current_length > 0 else 1\n",
    "    \n",
    "    normalized_spatial = rotated * scale_factor\n",
    "    \n",
    "    # Create 3D trajectory with time in seconds\n",
    "    trajectory_3d = np.column_stack((normalized_spatial, time_sequence_seconds))\n",
    "    \n",
    "    return trajectory_3d\n",
    "\n",
    "def normalize_trajectory_sequence_3d(path, time_diff_ms, target_position=np.array([1.0, 0.0]), target_length=512):\n",
    "    \"\"\"\n",
    "    Normalize a trajectory into 3D (x, y, time_in_seconds).\n",
    "    \n",
    "    Args:\n",
    "        path: trajectory coordinates as string or numpy array\n",
    "        time_diff_ms: time differences in milliseconds\n",
    "        target_position: desired end position (default: [1,0])\n",
    "        target_length: desired number of points after resampling (default: 100)\n",
    "    \n",
    "    Returns:\n",
    "        Normalized 3D trajectory with time in seconds\n",
    "    \"\"\"\n",
    "    # Parse input trajectory\n",
    "    trajectory = np.array(eval(path) if isinstance(path, str) else path)\n",
    "    \n",
    "    # Parse time sequence\n",
    "    time_sequence = np.array(eval(time_diff_ms) if isinstance(time_diff_ms, str) else time_diff_ms)\n",
    "    \n",
    "    norm_traj_3d = np.array([])\n",
    "    \n",
    "    if isinstance(trajectory, np.ndarray) and trajectory.size > 0 and not np.all(trajectory == 0):\n",
    "        # Normalize to 3D with time in seconds\n",
    "        norm_traj_3d = normalize_trajectory_3d(trajectory, time_sequence, target_position)\n",
    "        \n",
    "        # Optional resampling (only for spatial coordinates)\n",
    "        if target_length is not None and target_length > 2:\n",
    "            t = np.linspace(0, 1, target_length)\n",
    "            t_original = np.linspace(0, 1, len(norm_traj_3d))\n",
    "            \n",
    "            # Resample spatial coordinates\n",
    "            resampled_spatial = np.vstack([\n",
    "                np.interp(t, t_original, norm_traj_3d[:, 0]),\n",
    "                np.interp(t, t_original, norm_traj_3d[:, 1])\n",
    "            ]).T\n",
    "            \n",
    "            # Resample time to maintain correspondence\n",
    "            resampled_time = np.interp(t, t_original, norm_traj_3d[:, 2])\n",
    "            \n",
    "            norm_traj_3d = np.column_stack((resampled_spatial, resampled_time))\n",
    "    \n",
    "    return norm_traj_3d\n",
    "\n",
    "# Example usage:\n",
    "# normalized_traj = normalize_trajectory_sequence_3d(\n",
    "#     path=path_data,\n",
    "#     time_diff_ms=time_diff_ms_data\n",
    "# )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "65fc0469-ac22-4dcb-9f66-48d966e3a9e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "df[\"normalized_trajectory\"] = df.apply(lambda x: normalize_trajectory_sequence_3d(x['path'], x['time_diff_ms']), axis=1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1aeb1c0d-ab18-4110-98c1-609e31ad6458",
   "metadata": {},
   "source": [
    "### Calculate E-E matrix from Embedded space"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "337cfabc-544e-4606-8b2d-2d7a4e915f15",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "\n",
    "def calculate_exploration_exploitation_scores(df, embedding_column='trajectory_embedding_weighted_multi',\n",
    "                                             distance_metric='euclidean', window_size=6):\n",
    "    \"\"\"\n",
    "    Calculate exploration and exploitation scores for sequential trials.\n",
    "    Uses a rolling window approach to determine how much a participant is exploring vs exploiting.\n",
    "    \n",
    "    Parameters:\n",
    "    -----------\n",
    "    df : pandas.DataFrame\n",
    "        Dataframe containing trajectory data with columns:\n",
    "        - participant_id: to group trials by participant\n",
    "        - task_type: to separate unimanual (0) and bimanual (1) tasks\n",
    "        - day, block, trial_no: to order trials chronologically\n",
    "        - embedding_column: trajectory embeddings\n",
    "    \n",
    "    embedding_column : str, default='trajectory_embedding_weighted_multi'\n",
    "        Column name for the trajectory embeddings to use\n",
    "    \n",
    "    distance_metric : str, default='euclidean'\n",
    "        Distance metric to use for measuring embedding similarities\n",
    "    \n",
    "    window_size : int, default=5\n",
    "        Size of the rolling window to use for calculations\n",
    "        \n",
    "    Returns:\n",
    "    --------\n",
    "    pandas.DataFrame\n",
    "        Original dataframe with additional columns:\n",
    "        - exploration_score: higher values indicate more exploration\n",
    "        - exploitation_score: higher values indicate more exploitation\n",
    "    \"\"\"\n",
    "    \n",
    "    # Create a copy to avoid modifying the original dataframe\n",
    "    result_df = df.copy()\n",
    "    \n",
    "    # Initialize new columns for scores\n",
    "    result_df['exploration_score'] = np.nan\n",
    "    result_df['exploitation_score'] = np.nan\n",
    "    result_df['novelty'] = np.nan\n",
    "    result_df['avg_similarity_to_window'] = np.nan\n",
    "    result_df['max_similarity_to_window'] = np.nan\n",
    "    result_df['trial_seq'] = np.nan\n",
    "    \n",
    "    # Ensure embedding column is in numpy array format\n",
    "    if isinstance(result_df[embedding_column].iloc[0], str):\n",
    "        # Parse string embeddings properly\n",
    "        result_df[embedding_column] = result_df[embedding_column].apply(\n",
    "            lambda x: np.array([float(val) for val in x.strip('[]').split()]) if isinstance(x, str) else x\n",
    "        )\n",
    "    \n",
    "    # Group by participant and task_type\n",
    "    for (participant_id, task_type), group_df in result_df.groupby(['participant_id', 'task_type']):\n",
    "        # Sort trials chronologically for this participant and task\n",
    "        group_df = group_df.sort_values(by=['session_no', 'trial_no'])\n",
    "        # group_df = group_df.reset_index(drop=True)\n",
    "        \n",
    "        # Create a sequence number for trials\n",
    "        group_df['trial_seq'] = range(1, len(group_df) + 1)\n",
    "        \n",
    "        # Store sequence number in the result dataframe\n",
    "        result_df.loc[group_df.index, 'trial_seq'] = group_df['trial_seq'].values\n",
    "        \n",
    "        # Handle missing embeddings by creating placeholder embeddings\n",
    "        valid_embedding_indices = []\n",
    "        valid_embeddings = []\n",
    "        embedding_dim = None\n",
    "        \n",
    "        # First pass to identify valid embeddings and determine dimension\n",
    "        for i, idx in enumerate(group_df.index):\n",
    "            embedding = group_df.loc[idx, embedding_column]\n",
    "            if embedding is not None and not (isinstance(embedding, float) and np.isnan(embedding)):\n",
    "                if embedding_dim is None and hasattr(embedding, 'shape'):\n",
    "                    embedding_dim = embedding.shape[0]\n",
    "                valid_embedding_indices.append(i)\n",
    "                valid_embeddings.append(embedding)\n",
    "        \n",
    "        # If we have no valid embeddings or couldn't determine dimension, skip this group\n",
    "        if not valid_embeddings or embedding_dim is None:\n",
    "            print(f\"Warning: No valid embeddings for participant {participant_id}, task {task_type}\")\n",
    "            continue\n",
    "        \n",
    "        # Second pass to process distances only for valid embeddings\n",
    "        if valid_embeddings:\n",
    "            # Create array of valid embeddings\n",
    "            valid_embeddings_array = np.vstack(valid_embeddings)\n",
    "            \n",
    "            # Calculate distances between valid embeddings\n",
    "            valid_distances = cdist(valid_embeddings_array, valid_embeddings_array, metric=distance_metric)\n",
    "            \n",
    "            # Create a full distance matrix with NaNs for missing embeddings\n",
    "            n_trials = len(group_df)\n",
    "            all_distances = np.full((n_trials, n_trials), np.nan)\n",
    "            \n",
    "            # Fill in distances for valid embeddings\n",
    "            for i, valid_i in enumerate(valid_embedding_indices):\n",
    "                for j, valid_j in enumerate(valid_embedding_indices):\n",
    "                    all_distances[valid_i, valid_j] = valid_distances[i, j]\n",
    "            \n",
    "            # Calculate scores for each trial in sequence\n",
    "            for i, idx in enumerate(group_df.index):\n",
    "                # For the first trial, set default values\n",
    "                if i == 0:\n",
    "                    result_df.loc[idx, 'exploration_score'] = 1.0\n",
    "                    result_df.loc[idx, 'exploitation_score'] = 0.0\n",
    "                    result_df.loc[idx, 'novelty'] = 1.0\n",
    "                    result_df.loc[idx, 'avg_similarity_to_window'] = 0.0\n",
    "                    result_df.loc[idx, 'max_similarity_to_window'] = 0.0\n",
    "                    continue\n",
    "                \n",
    "                # Skip calculation if current trial has missing embedding\n",
    "                if i not in valid_embedding_indices:\n",
    "                    # Assign the mean or a default value for missing embeddings\n",
    "                    if i > 0:\n",
    "                        # Use the mean of previous valid scores as a fallback\n",
    "                        valid_exploration_scores = result_df.loc[group_df.index[:i], 'exploration_score'].dropna()\n",
    "                        valid_exploitation_scores = result_df.loc[group_df.index[:i], 'exploitation_score'].dropna()\n",
    "                        \n",
    "                        if len(valid_exploration_scores) > 0:\n",
    "                            result_df.loc[idx, 'exploration_score'] = valid_exploration_scores.mean()\n",
    "                        else:\n",
    "                            result_df.loc[idx, 'exploration_score'] = 0.5  # Default\n",
    "                            \n",
    "                        if len(valid_exploitation_scores) > 0:\n",
    "                            result_df.loc[idx, 'exploitation_score'] = valid_exploitation_scores.mean()\n",
    "                        else:\n",
    "                            result_df.loc[idx, 'exploitation_score'] = 0.5  # Default\n",
    "                    \n",
    "                    # Set other metrics to NaN or default values\n",
    "                    result_df.loc[idx, 'novelty'] = np.nan\n",
    "                    result_df.loc[idx, 'avg_similarity_to_window'] = np.nan\n",
    "                    result_df.loc[idx, 'max_similarity_to_window'] = np.nan\n",
    "                    continue\n",
    "                \n",
    "                # Filter out NaN values from distances to previous trials\n",
    "                distances_to_previous = all_distances[i, :i]\n",
    "                valid_previous_distances = distances_to_previous[~np.isnan(distances_to_previous)]\n",
    "                \n",
    "                if len(valid_previous_distances) > 0:\n",
    "                    # Novelty: minimum distance to any previous trial\n",
    "                    # Higher value means more different (more novel)\n",
    "                    novelty = np.min(valid_previous_distances)\n",
    "                    result_df.loc[idx, 'novelty'] = novelty\n",
    "                    \n",
    "                    # For window calculations, get start index\n",
    "                    window_start = max(0, i - window_size)\n",
    "                    \n",
    "                    # Calculate distances to the window of previous trials\n",
    "                    distances_to_window = all_distances[i, window_start:i]\n",
    "                    valid_window_distances = distances_to_window[~np.isnan(distances_to_window)]\n",
    "                    \n",
    "                    if len(valid_window_distances) > 0:\n",
    "                        # Convert distances to similarities (higher = more similar)\n",
    "                        similarities_to_window = 1 / (1 + valid_window_distances)\n",
    "                        \n",
    "                        # Average similarity to window (measure of exploitation)\n",
    "                        avg_similarity = np.mean(similarities_to_window)\n",
    "                        result_df.loc[idx, 'avg_similarity_to_window'] = avg_similarity\n",
    "                        \n",
    "                        # Maximum similarity to any trial in window (measure of exploitation)\n",
    "                        max_similarity = np.max(similarities_to_window)\n",
    "                        result_df.loc[idx, 'max_similarity_to_window'] = max_similarity\n",
    "                        \n",
    "                        # Alternative exploration score: based on novelty (difference from previous trials)\n",
    "                        # Normalize to keep early trials' scores high\n",
    "                        trial_position_factor = np.exp(-0.01 * i)  # Decreases slowly with trial number\n",
    "                        exploration_score = novelty * (0.7 + 0.3 * trial_position_factor)\n",
    "                        \n",
    "                        # Alternative exploitation score: based on similarity to window\n",
    "                        # We use max similarity as the primary factor\n",
    "                        exploitation_score = max_similarity\n",
    "                        # print(participant_id, idx, exploration_score, exploitation_score)\n",
    "                        result_df.loc[idx, 'exploration_score'] = exploration_score\n",
    "                        result_df.loc[idx, 'exploitation_score'] = exploitation_score\n",
    "                    else:\n",
    "                        # No valid window distances\n",
    "                        result_df.loc[idx, 'avg_similarity_to_window'] = np.nan\n",
    "                        result_df.loc[idx, 'max_similarity_to_window'] = np.nan\n",
    "                        \n",
    "                        # Use default values or interpolate from other trials\n",
    "                        if i > 1:\n",
    "                            # Use mean of previous scores\n",
    "                            valid_exploration_scores = result_df.loc[group_df.index[:i], 'exploration_score'].dropna()\n",
    "                            valid_exploitation_scores = result_df.loc[group_df.index[:i], 'exploitation_score'].dropna()\n",
    "                            \n",
    "                            if len(valid_exploration_scores) > 0:\n",
    "                                result_df.loc[idx, 'exploration_score'] = valid_exploration_scores.mean()\n",
    "                            else:\n",
    "                                result_df.loc[idx, 'exploration_score'] = 0.5\n",
    "                                \n",
    "                            if len(valid_exploitation_scores) > 0:\n",
    "                                result_df.loc[idx, 'exploitation_score'] = valid_exploitation_scores.mean()\n",
    "                            else:\n",
    "                                result_df.loc[idx, 'exploitation_score'] = 0.5\n",
    "                else:\n",
    "                    # No valid previous distances, set defaults\n",
    "                    result_df.loc[idx, 'novelty'] = np.nan\n",
    "                    result_df.loc[idx, 'avg_similarity_to_window'] = np.nan\n",
    "                    result_df.loc[idx, 'max_similarity_to_window'] = np.nan\n",
    "                    result_df.loc[idx, 'exploration_score'] = 0.5  # Default mid-point\n",
    "                    result_df.loc[idx, 'exploitation_score'] = 0.5  # Default mid-point\n",
    "    \n",
    "    # Normalize scores to [0,1] range\n",
    "    for score_col in ['exploration_score', 'exploitation_score']:\n",
    "        min_val = result_df[score_col].min()\n",
    "        max_val = result_df[score_col].max()\n",
    "        \n",
    "        if max_val > min_val:  # Avoid division by zero\n",
    "            result_df[score_col] = (result_df[score_col] - min_val) / (max_val - min_val)\n",
    "    \n",
    "    # Add task labels\n",
    "    result_df['task_label'] = result_df['task_type'].map({0: 'Unimanual', 1: 'Bimanual'})\n",
    "    \n",
    "    return result_df\n",
    "\n",
    "def calculate_exploration_exploitation_ratio(df, smoothing=0.01):\n",
    "    \"\"\"\n",
    "    Calculate exploration/exploitation ratio for each trial.\n",
    "    \n",
    "    Parameters:\n",
    "    -----------\n",
    "    df : pandas.DataFrame\n",
    "        Dataframe with exploration_score and exploitation_score columns\n",
    "    \n",
    "    smoothing : float, default=0.01\n",
    "        Small value to avoid division by zero\n",
    "    \n",
    "    Returns:\n",
    "    --------\n",
    "    pandas.DataFrame\n",
    "        Dataframe with additional column:\n",
    "        - exploration_exploitation_ratio: ratio of exploration to exploitation\n",
    "    \"\"\"\n",
    "    result_df = df.copy()\n",
    "    \n",
    "    # Calculate ratio (with smoothing to avoid division by zero)\n",
    "    result_df['exploration_exploitation_ratio'] = (\n",
    "        result_df['exploration_score'] / (result_df['exploitation_score'] + smoothing)\n",
    "    )\n",
    "    \n",
    "    return result_df\n",
    "\n",
    "def calculate_progression_metrics(df):\n",
    "    \"\"\"\n",
    "    Calculate progression metrics based on sequential trial analysis.\n",
    "    \n",
    "    Parameters:\n",
    "    -----------\n",
    "    df : pandas.DataFrame\n",
    "        Dataframe with exploration and exploitation scores\n",
    "        \n",
    "    Returns:\n",
    "    --------\n",
    "    pandas.DataFrame\n",
    "        Dataframe with additional progression metrics\n",
    "    \"\"\"\n",
    "    result_df = df.copy()\n",
    "    \n",
    "    # Initialize columns\n",
    "    result_df['learning_rate'] = np.nan\n",
    "    result_df['strategy_stability'] = np.nan\n",
    "    \n",
    "    # Process each participant and task type\n",
    "    for (participant_id, task_type), group_df in result_df.groupby(['participant_id', 'task_type']):\n",
    "        # Sort trials chronologically \n",
    "        group_df = group_df.sort_values(by=['trial_seq'])\n",
    "        \n",
    "        # Get indices for this group\n",
    "        indices = group_df.index\n",
    "        \n",
    "        # Skip if too few trials\n",
    "        if len(indices) < 10:  # Need enough trials for meaningful metrics\n",
    "            continue\n",
    "            \n",
    "        # Calculate rolling metrics\n",
    "        window_size = min(5, len(indices) // 4)  # Adaptive window size\n",
    "        \n",
    "        for i in range(window_size, len(indices)):\n",
    "            current_idx = indices[i]\n",
    "            \n",
    "            # Get window of previous trials\n",
    "            window_indices = indices[i-window_size:i]\n",
    "            window_df = group_df.loc[window_indices]\n",
    "            \n",
    "            # Calculate learning rate: change in performance over trials\n",
    "            # Use whichever performance metrics are available\n",
    "            if 'rmsd' in group_df.columns:\n",
    "                # Negative learning rate because lower rmsd is better\n",
    "                learning_rate = -1 * np.polyfit(window_df['trial_seq'], window_df['rmsd'], 1)[0]\n",
    "            elif 'completion_time' in group_df.columns:\n",
    "                # Negative learning rate because lower time is better\n",
    "                learning_rate = -1 * np.polyfit(window_df['trial_seq'], window_df['completion_time'], 1)[0]\n",
    "            else:\n",
    "                # Default to exploitation trend if no performance metrics\n",
    "                learning_rate = np.polyfit(window_df['trial_seq'], window_df['exploitation_score'], 1)[0]\n",
    "            \n",
    "            result_df.loc[current_idx, 'learning_rate'] = learning_rate\n",
    "            \n",
    "            # Strategy stability: consistency of exploration/exploitation ratio\n",
    "            if 'exploration_exploitation_ratio' in window_df.columns:\n",
    "                strategy_stability = 1 / (1 + window_df['exploration_exploitation_ratio'].std())\n",
    "                result_df.loc[current_idx, 'strategy_stability'] = strategy_stability\n",
    "    \n",
    "    return result_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "9ad5301d-387e-4e2d-b6c0-1498ba634bd3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>participant_id</th>\n",
       "      <th>session_no</th>\n",
       "      <th>task_type</th>\n",
       "      <th>trial_no</th>\n",
       "      <th>day</th>\n",
       "      <th>block</th>\n",
       "      <th>start_point_x</th>\n",
       "      <th>start_point_y</th>\n",
       "      <th>target_point_x</th>\n",
       "      <th>target_point_y</th>\n",
       "      <th>...</th>\n",
       "      <th>exploration_score</th>\n",
       "      <th>exploitation_score</th>\n",
       "      <th>novelty</th>\n",
       "      <th>avg_similarity_to_window</th>\n",
       "      <th>max_similarity_to_window</th>\n",
       "      <th>trial_seq</th>\n",
       "      <th>task_label</th>\n",
       "      <th>exploration_exploitation_ratio</th>\n",
       "      <th>learning_rate</th>\n",
       "      <th>strategy_stability</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>451.220748</td>\n",
       "      <td>-453.255370</td>\n",
       "      <td>...</td>\n",
       "      <td>0.082055</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>8.205542</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>-523.109406</td>\n",
       "      <td>-447.873534</td>\n",
       "      <td>...</td>\n",
       "      <td>0.112268</td>\n",
       "      <td>0.421532</td>\n",
       "      <td>1.372298</td>\n",
       "      <td>0.421532</td>\n",
       "      <td>0.421532</td>\n",
       "      <td>2.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>0.260162</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>557.574475</td>\n",
       "      <td>325.309867</td>\n",
       "      <td>...</td>\n",
       "      <td>0.059388</td>\n",
       "      <td>0.578677</td>\n",
       "      <td>0.728079</td>\n",
       "      <td>0.516601</td>\n",
       "      <td>0.578677</td>\n",
       "      <td>3.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>0.100884</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>476.961663</td>\n",
       "      <td>216.321327</td>\n",
       "      <td>...</td>\n",
       "      <td>0.059665</td>\n",
       "      <td>0.576824</td>\n",
       "      <td>0.733632</td>\n",
       "      <td>0.501828</td>\n",
       "      <td>0.576824</td>\n",
       "      <td>4.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>0.101674</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>-497.485877</td>\n",
       "      <td>-249.059722</td>\n",
       "      <td>...</td>\n",
       "      <td>0.015491</td>\n",
       "      <td>0.839610</td>\n",
       "      <td>0.191029</td>\n",
       "      <td>0.585121</td>\n",
       "      <td>0.839610</td>\n",
       "      <td>5.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>0.018233</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16315</th>\n",
       "      <td>MTRLRN079</td>\n",
       "      <td>5</td>\n",
       "      <td>1</td>\n",
       "      <td>20</td>\n",
       "      <td>Day-3</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>332.677025</td>\n",
       "      <td>-235.033037</td>\n",
       "      <td>...</td>\n",
       "      <td>0.017954</td>\n",
       "      <td>0.721609</td>\n",
       "      <td>0.275226</td>\n",
       "      <td>0.617692</td>\n",
       "      <td>0.721609</td>\n",
       "      <td>116.0</td>\n",
       "      <td>Bimanual</td>\n",
       "      <td>0.024540</td>\n",
       "      <td>-101.055825</td>\n",
       "      <td>0.987909</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16316</th>\n",
       "      <td>MTRLRN079</td>\n",
       "      <td>5</td>\n",
       "      <td>1</td>\n",
       "      <td>21</td>\n",
       "      <td>Day-3</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>-541.816202</td>\n",
       "      <td>-203.887310</td>\n",
       "      <td>...</td>\n",
       "      <td>0.006610</td>\n",
       "      <td>0.838702</td>\n",
       "      <td>0.101455</td>\n",
       "      <td>0.705284</td>\n",
       "      <td>0.838701</td>\n",
       "      <td>117.0</td>\n",
       "      <td>Bimanual</td>\n",
       "      <td>0.007789</td>\n",
       "      <td>-73.719668</td>\n",
       "      <td>0.989142</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16317</th>\n",
       "      <td>MTRLRN079</td>\n",
       "      <td>5</td>\n",
       "      <td>1</td>\n",
       "      <td>22</td>\n",
       "      <td>Day-3</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>-534.191589</td>\n",
       "      <td>326.568198</td>\n",
       "      <td>...</td>\n",
       "      <td>0.016737</td>\n",
       "      <td>0.777017</td>\n",
       "      <td>0.257179</td>\n",
       "      <td>0.674807</td>\n",
       "      <td>0.777016</td>\n",
       "      <td>118.0</td>\n",
       "      <td>Bimanual</td>\n",
       "      <td>0.021266</td>\n",
       "      <td>2.003748</td>\n",
       "      <td>0.989531</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16318</th>\n",
       "      <td>MTRLRN079</td>\n",
       "      <td>5</td>\n",
       "      <td>1</td>\n",
       "      <td>23</td>\n",
       "      <td>Day-3</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>559.127069</td>\n",
       "      <td>355.643316</td>\n",
       "      <td>...</td>\n",
       "      <td>0.017366</td>\n",
       "      <td>0.586678</td>\n",
       "      <td>0.267157</td>\n",
       "      <td>0.501319</td>\n",
       "      <td>0.586678</td>\n",
       "      <td>119.0</td>\n",
       "      <td>Bimanual</td>\n",
       "      <td>0.029104</td>\n",
       "      <td>34.007860</td>\n",
       "      <td>0.989642</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16319</th>\n",
       "      <td>MTRLRN079</td>\n",
       "      <td>5</td>\n",
       "      <td>1</td>\n",
       "      <td>24</td>\n",
       "      <td>Day-3</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>319.515281</td>\n",
       "      <td>326.462988</td>\n",
       "      <td>...</td>\n",
       "      <td>0.035949</td>\n",
       "      <td>0.544132</td>\n",
       "      <td>0.553675</td>\n",
       "      <td>0.459748</td>\n",
       "      <td>0.544131</td>\n",
       "      <td>120.0</td>\n",
       "      <td>Bimanual</td>\n",
       "      <td>0.064874</td>\n",
       "      <td>32.414128</td>\n",
       "      <td>0.990291</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>16320 rows × 45 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      participant_id  session_no  task_type  trial_no    day    block  \\\n",
       "0          MTRLRN002           1          0         1  Day-1  Block-1   \n",
       "1          MTRLRN002           1          0         2  Day-1  Block-1   \n",
       "2          MTRLRN002           1          0         3  Day-1  Block-1   \n",
       "3          MTRLRN002           1          0         4  Day-1  Block-1   \n",
       "4          MTRLRN002           1          0         5  Day-1  Block-1   \n",
       "...              ...         ...        ...       ...    ...      ...   \n",
       "16315      MTRLRN079           5          1        20  Day-3  Block-1   \n",
       "16316      MTRLRN079           5          1        21  Day-3  Block-1   \n",
       "16317      MTRLRN079           5          1        22  Day-3  Block-1   \n",
       "16318      MTRLRN079           5          1        23  Day-3  Block-1   \n",
       "16319      MTRLRN079           5          1        24  Day-3  Block-1   \n",
       "\n",
       "       start_point_x  start_point_y  target_point_x  target_point_y  ...  \\\n",
       "0                  0              0      451.220748     -453.255370  ...   \n",
       "1                  0              0     -523.109406     -447.873534  ...   \n",
       "2                  0              0      557.574475      325.309867  ...   \n",
       "3                  0              0      476.961663      216.321327  ...   \n",
       "4                  0              0     -497.485877     -249.059722  ...   \n",
       "...              ...            ...             ...             ...  ...   \n",
       "16315              0              0      332.677025     -235.033037  ...   \n",
       "16316              0              0     -541.816202     -203.887310  ...   \n",
       "16317              0              0     -534.191589      326.568198  ...   \n",
       "16318              0              0      559.127069      355.643316  ...   \n",
       "16319              0              0      319.515281      326.462988  ...   \n",
       "\n",
       "      exploration_score exploitation_score   novelty  \\\n",
       "0              0.082055           0.000000  1.000000   \n",
       "1              0.112268           0.421532  1.372298   \n",
       "2              0.059388           0.578677  0.728079   \n",
       "3              0.059665           0.576824  0.733632   \n",
       "4              0.015491           0.839610  0.191029   \n",
       "...                 ...                ...       ...   \n",
       "16315          0.017954           0.721609  0.275226   \n",
       "16316          0.006610           0.838702  0.101455   \n",
       "16317          0.016737           0.777017  0.257179   \n",
       "16318          0.017366           0.586678  0.267157   \n",
       "16319          0.035949           0.544132  0.553675   \n",
       "\n",
       "       avg_similarity_to_window  max_similarity_to_window  trial_seq  \\\n",
       "0                      0.000000                  0.000000        1.0   \n",
       "1                      0.421532                  0.421532        2.0   \n",
       "2                      0.516601                  0.578677        3.0   \n",
       "3                      0.501828                  0.576824        4.0   \n",
       "4                      0.585121                  0.839610        5.0   \n",
       "...                         ...                       ...        ...   \n",
       "16315                  0.617692                  0.721609      116.0   \n",
       "16316                  0.705284                  0.838701      117.0   \n",
       "16317                  0.674807                  0.777016      118.0   \n",
       "16318                  0.501319                  0.586678      119.0   \n",
       "16319                  0.459748                  0.544131      120.0   \n",
       "\n",
       "       task_label exploration_exploitation_ratio learning_rate  \\\n",
       "0       Unimanual                       8.205542           NaN   \n",
       "1       Unimanual                       0.260162           NaN   \n",
       "2       Unimanual                       0.100884           NaN   \n",
       "3       Unimanual                       0.101674           NaN   \n",
       "4       Unimanual                       0.018233           NaN   \n",
       "...           ...                            ...           ...   \n",
       "16315    Bimanual                       0.024540   -101.055825   \n",
       "16316    Bimanual                       0.007789    -73.719668   \n",
       "16317    Bimanual                       0.021266      2.003748   \n",
       "16318    Bimanual                       0.029104     34.007860   \n",
       "16319    Bimanual                       0.064874     32.414128   \n",
       "\n",
       "      strategy_stability  \n",
       "0                    NaN  \n",
       "1                    NaN  \n",
       "2                    NaN  \n",
       "3                    NaN  \n",
       "4                    NaN  \n",
       "...                  ...  \n",
       "16315           0.987909  \n",
       "16316           0.989142  \n",
       "16317           0.989531  \n",
       "16318           0.989642  \n",
       "16319           0.990291  \n",
       "\n",
       "[16320 rows x 45 columns]"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#df_with_scores = calculate_exploration_exploitation_scores(df, embedding_column='trajectory_embedding_multi_loss')\n",
    "df_with_scores = calculate_exploration_exploitation_scores(df, embedding_column='trajectory_embedding_weighted_multi')\n",
    "df_with_ratio = calculate_exploration_exploitation_ratio(df_with_scores)\n",
    "df_with_ratio_progress =calculate_progression_metrics(df_with_ratio)\n",
    "df_with_ratio_progress"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c3f764b4-ce5f-401b-883c-c2efa77131f2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "6e3ac87a",
   "metadata": {},
   "source": [
    "### Comparison of Exploration-Exploitation (E-E) Ratios: Normalized Trajectories vs Embedding Space\n",
    "We compute E-E ratios from two representations: (1) learned trajectory embeddings and (2) purely geometric normalized trajectories. This allows assessing whether embeddings capture higher-order control strategies beyond geometric variability."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "925302a5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Trajectory-based E-E ratio available for 16320 trials.\n",
      "Merged shape: (16320, 44)\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>participant_id</th>\n",
       "      <th>session_no</th>\n",
       "      <th>task_type</th>\n",
       "      <th>trial_no</th>\n",
       "      <th>day</th>\n",
       "      <th>block</th>\n",
       "      <th>start_point_x</th>\n",
       "      <th>start_point_y</th>\n",
       "      <th>target_point_x</th>\n",
       "      <th>target_point_y</th>\n",
       "      <th>...</th>\n",
       "      <th>trajectory_embedding_weighted_multi</th>\n",
       "      <th>exploration_score</th>\n",
       "      <th>exploitation_score</th>\n",
       "      <th>novelty</th>\n",
       "      <th>avg_similarity_to_window</th>\n",
       "      <th>max_similarity_to_window</th>\n",
       "      <th>trial_seq</th>\n",
       "      <th>task_label</th>\n",
       "      <th>exploration_exploitation_ratio</th>\n",
       "      <th>exploration_exploitation_ratio_traj</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>1</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>451.220748</td>\n",
       "      <td>-453.255370</td>\n",
       "      <td>...</td>\n",
       "      <td>[0.19598372, -0.0443047, -0.39139536, -0.03888...</td>\n",
       "      <td>0.082055</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>8.205542</td>\n",
       "      <td>1.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>2</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>-523.109406</td>\n",
       "      <td>-447.873534</td>\n",
       "      <td>...</td>\n",
       "      <td>[0.16557111, 0.21644062, -0.37040448, 0.631607...</td>\n",
       "      <td>0.112268</td>\n",
       "      <td>0.421532</td>\n",
       "      <td>1.372298</td>\n",
       "      <td>0.421532</td>\n",
       "      <td>0.421532</td>\n",
       "      <td>2.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>0.260162</td>\n",
       "      <td>628.181745</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>3</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>557.574475</td>\n",
       "      <td>325.309867</td>\n",
       "      <td>...</td>\n",
       "      <td>[0.26427168, 0.016123265, -0.27471226, 0.03697...</td>\n",
       "      <td>0.059388</td>\n",
       "      <td>0.578677</td>\n",
       "      <td>0.728079</td>\n",
       "      <td>0.516601</td>\n",
       "      <td>0.578677</td>\n",
       "      <td>3.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>0.100884</td>\n",
       "      <td>172.860092</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>4</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>476.961663</td>\n",
       "      <td>216.321327</td>\n",
       "      <td>...</td>\n",
       "      <td>[0.238517419, -0.000704005361, -0.214667365, 0...</td>\n",
       "      <td>0.059665</td>\n",
       "      <td>0.576824</td>\n",
       "      <td>0.733632</td>\n",
       "      <td>0.501828</td>\n",
       "      <td>0.576824</td>\n",
       "      <td>4.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>0.101674</td>\n",
       "      <td>75.758626</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>MTRLRN002</td>\n",
       "      <td>1</td>\n",
       "      <td>0</td>\n",
       "      <td>5</td>\n",
       "      <td>Day-1</td>\n",
       "      <td>Block-1</td>\n",
       "      <td>0</td>\n",
       "      <td>0</td>\n",
       "      <td>-497.485877</td>\n",
       "      <td>-249.059722</td>\n",
       "      <td>...</td>\n",
       "      <td>[0.2107846, -0.07058901, -0.39435142, -0.05100...</td>\n",
       "      <td>0.015491</td>\n",
       "      <td>0.839610</td>\n",
       "      <td>0.191029</td>\n",
       "      <td>0.585121</td>\n",
       "      <td>0.839610</td>\n",
       "      <td>5.0</td>\n",
       "      <td>Unimanual</td>\n",
       "      <td>0.018233</td>\n",
       "      <td>7.127018</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 44 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "  participant_id  session_no  task_type  trial_no    day    block  \\\n",
       "0      MTRLRN002           1          0         1  Day-1  Block-1   \n",
       "1      MTRLRN002           1          0         2  Day-1  Block-1   \n",
       "2      MTRLRN002           1          0         3  Day-1  Block-1   \n",
       "3      MTRLRN002           1          0         4  Day-1  Block-1   \n",
       "4      MTRLRN002           1          0         5  Day-1  Block-1   \n",
       "\n",
       "   start_point_x  start_point_y  target_point_x  target_point_y  ...  \\\n",
       "0              0              0      451.220748     -453.255370  ...   \n",
       "1              0              0     -523.109406     -447.873534  ...   \n",
       "2              0              0      557.574475      325.309867  ...   \n",
       "3              0              0      476.961663      216.321327  ...   \n",
       "4              0              0     -497.485877     -249.059722  ...   \n",
       "\n",
       "                 trajectory_embedding_weighted_multi exploration_score  \\\n",
       "0  [0.19598372, -0.0443047, -0.39139536, -0.03888...          0.082055   \n",
       "1  [0.16557111, 0.21644062, -0.37040448, 0.631607...          0.112268   \n",
       "2  [0.26427168, 0.016123265, -0.27471226, 0.03697...          0.059388   \n",
       "3  [0.238517419, -0.000704005361, -0.214667365, 0...          0.059665   \n",
       "4  [0.2107846, -0.07058901, -0.39435142, -0.05100...          0.015491   \n",
       "\n",
       "  exploitation_score   novelty  avg_similarity_to_window  \\\n",
       "0           0.000000  1.000000                  0.000000   \n",
       "1           0.421532  1.372298                  0.421532   \n",
       "2           0.578677  0.728079                  0.516601   \n",
       "3           0.576824  0.733632                  0.501828   \n",
       "4           0.839610  0.191029                  0.585121   \n",
       "\n",
       "   max_similarity_to_window  trial_seq task_label  \\\n",
       "0                  0.000000        1.0  Unimanual   \n",
       "1                  0.421532        2.0  Unimanual   \n",
       "2                  0.578677        3.0  Unimanual   \n",
       "3                  0.576824        4.0  Unimanual   \n",
       "4                  0.839610        5.0  Unimanual   \n",
       "\n",
       "  exploration_exploitation_ratio exploration_exploitation_ratio_traj  \n",
       "0                       8.205542                            1.000000  \n",
       "1                       0.260162                          628.181745  \n",
       "2                       0.100884                          172.860092  \n",
       "3                       0.101674                           75.758626  \n",
       "4                       0.018233                            7.127018  \n",
       "\n",
       "[5 rows x 44 columns]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.metrics import r2_score\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from scipy import stats\n",
    "\n",
    "def _flatten_normalized_spatial(traj_3d):\n",
    "    \"\"\"Flatten spatial (x,y) coordinates of a normalized trajectory into 1D vector.\n",
    "    Accepts array shape (N,3) with columns (x,y,time_seconds). Returns None if invalid.\"\"\"\n",
    "    if traj_3d is None or isinstance(traj_3d, float) and np.isnan(traj_3d):\n",
    "        return None\n",
    "    arr = np.array(traj_3d)\n",
    "    if arr.ndim != 2 or arr.shape[1] < 2 or arr.size == 0:\n",
    "        return None\n",
    "    spatial = arr[:, :2]  # take x,y\n",
    "    return spatial.flatten()\n",
    "\n",
    "def calculate_exploration_exploitation_scores_normalized(df, normalized_column='normalized_trajectory',\n",
    "                                                         window_size=6, distance_metric='euclidean'):\n",
    "    \"\"\"Compute exploration & exploitation scores using normalized spatial trajectories.\n",
    "    For each participant/task, trajectories are flattened (x,y) and pairwise distances computed.\n",
    "\n",
    "    exploration_score: novelty (min distance to any previous) adjusted for trial position\n",
    "    exploitation_score: max similarity (1/(1+distance)) to window of recent trials\n",
    "    Returns original df with new columns:\n",
    "        exploration_score_traj, exploitation_score_traj, exploration_exploitation_ratio_traj\n",
    "    \"\"\"\n",
    "    result_df = df.copy()\n",
    "    result_df['exploration_score_traj'] = np.nan\n",
    "    result_df['exploitation_score_traj'] = np.nan\n",
    "    result_df['exploration_exploitation_ratio_traj'] = np.nan\n",
    "    result_df['traj_valid'] = False\n",
    "    \n",
    "    # Pre-flatten trajectories\n",
    "    flattened = df[normalized_column].apply(_flatten_normalized_spatial)\n",
    "    result_df['flattened_traj_vec'] = flattened\n",
    "    \n",
    "    # Group by participant/task (infer columns if present)\n",
    "    group_cols = [c for c in ['participant_id','task_type'] if c in result_df.columns]\n",
    "    if not group_cols:\n",
    "        group_cols = []  # treat whole set as one group if metadata absent\n",
    "    \n",
    "    def process_group(g):\n",
    "        g = g.sort_values(by=[col for col in ['session_no','trial_no','trial_seq'] if col in g.columns])\n",
    "        # Build list of valid vectors\n",
    "        vecs = []\n",
    "        valid_idx_map = {}\n",
    "        for i, idx in enumerate(g.index):\n",
    "            v = g.at[idx,'flattened_traj_vec']\n",
    "            if v is not None and len(v)>0 and not np.all(np.isnan(v)):\n",
    "                vecs.append(v)\n",
    "                valid_idx_map[i] = len(vecs)-1\n",
    "                result_df.at[idx,'traj_valid'] = True\n",
    "        if not vecs:\n",
    "            return\n",
    "        # Pad shorter vectors to max length (ensures same dimension)\n",
    "        max_len = max(len(v) for v in vecs)\n",
    "        vecs_padded = np.vstack([np.pad(v,(0,max_len-len(v)),'constant') for v in vecs])\n",
    "        dist_mat_valid = cdist(vecs_padded, vecs_padded, metric=distance_metric)\n",
    "        # Iterate trials\n",
    "        for i, idx in enumerate(g.index):\n",
    "            if i == 0:\n",
    "                result_df.at[idx,'exploration_score_traj'] = 1.0\n",
    "                result_df.at[idx,'exploitation_score_traj'] = 0.0\n",
    "                result_df.at[idx,'exploration_exploitation_ratio_traj'] = 1.0\n",
    "                continue\n",
    "            if i not in valid_idx_map:\n",
    "                # fallback: use mean of previous valid scores\n",
    "                prev = result_df.loc[g.index[:i], 'exploration_score_traj'].dropna()\n",
    "                result_df.at[idx,'exploration_score_traj'] = prev.mean() if len(prev)>0 else 0.5\n",
    "                prev2 = result_df.loc[g.index[:i], 'exploitation_score_traj'].dropna()\n",
    "                result_df.at[idx,'exploitation_score_traj'] = prev2.mean() if len(prev2)>0 else 0.5\n",
    "                result_df.at[idx,'exploration_exploitation_ratio_traj'] = result_df.at[idx,'exploration_score_traj'] / (result_df.at[idx,'exploitation_score_traj'] + 1e-3)\n",
    "                continue\n",
    "            valid_i = valid_idx_map[i]\n",
    "            prev_valid_indices = [valid_idx_map[j] for j in range(i) if j in valid_idx_map]\n",
    "            if not prev_valid_indices:\n",
    "                continue\n",
    "            distances_to_prev = dist_mat_valid[valid_i, prev_valid_indices]\n",
    "            novelty = np.min(distances_to_prev)\n",
    "            window_start = max(0, i - window_size)\n",
    "            window_range = list(range(window_start, i))\n",
    "            window_valid = [valid_idx_map[j] for j in window_range if j in valid_idx_map]\n",
    "            if window_valid:\n",
    "                distances_window = dist_mat_valid[valid_i, window_valid]\n",
    "                similarities = 1/(1+distances_window)\n",
    "                max_similarity = np.max(similarities)\n",
    "                # Trial position modulation (slight decay)\n",
    "                trial_position_factor = np.exp(-0.01 * i)\n",
    "                exploration_score = novelty * (0.7 + 0.3 * trial_position_factor)\n",
    "                exploitation_score = max_similarity\n",
    "            else:\n",
    "                exploration_score = novelty\n",
    "                exploitation_score = 0.5\n",
    "            result_df.at[idx,'exploration_score_traj'] = exploration_score\n",
    "            result_df.at[idx,'exploitation_score_traj'] = exploitation_score\n",
    "            result_df.at[idx,'exploration_exploitation_ratio_traj'] = exploration_score / (exploitation_score + 1e-3)\n",
    "    \n",
    "    if group_cols:\n",
    "        for _, g in result_df.groupby(group_cols):\n",
    "            process_group(g)\n",
    "    else:\n",
    "        process_group(result_df)\n",
    "    \n",
    "    # Normalize scores to [0,1] if possible\n",
    "    for c in ['exploration_score_traj','exploitation_score_traj']:\n",
    "        mn = result_df[c].min()\n",
    "        mx = result_df[c].max()\n",
    "        if pd.notna(mn) and pd.notna(mx) and mx > mn:\n",
    "            result_df[c] = (result_df[c]-mn)/(mx-mn)\n",
    "    return result_df\n",
    "\n",
    "# Generate trajectory-based E-E scores\n",
    "df_traj_scores = calculate_exploration_exploitation_scores_normalized(df)\n",
    "traj_ratio_available = df_traj_scores['exploration_exploitation_ratio_traj'].notna().sum()\n",
    "print(f'Trajectory-based E-E ratio available for {traj_ratio_available} trials.')\n",
    "\n",
    "# Merge embedding-based ratio (already computed earlier as df_with_ratio) with trajectory-based\n",
    "comparison_cols = ['participant_id','task_type','session_no','trial_no']\n",
    "merge_keys = [c for c in comparison_cols if c in df_with_ratio.columns and c in df_traj_scores.columns]\n",
    "if not merge_keys:\n",
    "    df_compare = pd.DataFrame()\n",
    "    print('No common keys for merge; cannot compare.')\n",
    "else:\n",
    "    df_compare = pd.merge(df_with_ratio,\n",
    "                       df_traj_scores[['exploration_exploitation_ratio_traj'] + merge_keys],\n",
    "                       on=merge_keys, how='inner')\n",
    "    print('Merged shape:', df_compare.shape)\n",
    "    display(df_compare.head())"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "dad601da-219e-4e49-91f9-a7b2fd7a1896",
   "metadata": {},
   "source": [
    "### Bootstrap Comparison: Hypotheses 1a & 1b (Embedding vs Trajectory E-E Ratios)\n",
    "We perform participant-level bootstrapping (sampling 10 Term and 10 Preterm participants per iteration) to estimate:\n",
    "1. Early (sessions 1–3) vs Late (session 5) shift in E-E ratio (Hypothesis 1a)\n",
    "2. Preterm vs Term difference in bimanual task E-E ratio (Hypothesis 1b)\n",
    "\n",
    "Representations:\n",
    "- Embedding-based E-E ratio: `exploration_exploitation_ratio`\n",
    "- Trajectory-based E-E ratio: `exploration_exploitation_ratio_traj`\n",
    "\n",
    "Outputs (per representation):\n",
    "- Mean Early, Mean Late, Mean Difference (Early - Late) with 95% CI\n",
    "- Mean Preterm, Mean Term (bimanual), Difference (Preterm - Term) with 95% CI\n",
    "\n",
    "Method:\n",
    "- For each bootstrap iteration:\n",
    "  - Sample (with replacement if necessary) up to 10 unique Term and 10 unique Preterm participants.\n",
    "  - Compute per-participant phase means; aggregate Early vs Late.\n",
    "  - Compute per-participant bimanual overall mean ratios; aggregate cohort difference.\n",
    "- 95% CI = 2.5th and 97.5th percentiles of bootstrap distribution.\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "68379202-6282-464d-bbcf-48eed52af122",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Available Term participants: 50; Preterm participants: 18\n",
      "=== Bootstrap Results (Mean Difference ±95% CI) ===\n",
      "Hypothesis 1a: Early - Late (Embedding): 0.1503 [0.1329, 0.1680] (n=1000)\n",
      "Hypothesis 1a: Early - Late (Trajectory): 162.7077 [1.7914, 441.7271] (n=1000)\n",
      "Hypothesis 1b: Preterm - Term Bimanual (Embedding): 0.0075 [-0.0229, 0.0337] (n=1000)\n",
      "Hypothesis 1b: Preterm - Term Bimanual (Trajectory): -274.7518 [-1169.2366, 112.5961] (n=1000)\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAMWCAYAAADs4eXxAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdd3gU5drA4d/M1iSQHpIAAUKvShURFEUEFOwNK+hR7B71sx9FURTFhu3o0WMX67E3EFAsdKnSW0IPIZBCSLbO+/2xyUJIAklIsu25r2svNrMzs89MwrzzzNs0pZRCCCGEEEIIIYQQ9U4PdABCCCGEEEIIIUS4kqRbCCGEEEIIIYRoIJJ0CyGEEEIIIYQQDUSSbiGEEEIIIYQQooFI0i2EEEIIIYQQQjQQSbqFEEIIIYQQQogGIkm3EEIIIYQQQgjRQCTpFkIIIYQQQgghGogk3UIIIYQQQgghRAORpFuIamiaxqOPPhroMALi5ptv5owzzgjId48dO5YmTZo0yne1adOGsWPHHnW9d999F03TyM7O9i879dRTOfXUUxssNoDVq1djNptZuXJlg36PEEKEIynHG7ccr6qsDDd79+4lJiaGH3/8MdChiBAjSbcIGeUX8+pe8+fPD3SIR9SmTRtGjRpVL/v68ccfG+xGIisri//+9788+OCD/mXZ2dlHPPdPPfVUg8QS6bp27crIkSMZP358oEMRQohjJuX4QY1Zjp966qlHPO/lr2B/QDF37lweffRRCgoKAhZDUlIS1113HQ8//HDAYhChyRzoAISorccee4zMzMxKy9u3bx+AaALjxx9/5NVXX22QAvLFF18kMzOT0047rdJnl112GWeddVal5b169ar3OILdzz//3Cjfc+ONN3LWWWexadMm2rVr1yjfKYQQDUnK8cYtx//1r39x3XXX+T9ftGgRL730Eg8++CBdunTxLz/uuOOO6XuvuuoqRo8ejc1mO6b9VGfu3LlMmDCBsWPHEh8f3yDfURM33ngjL730Er/88gtDhgwJWBwitEjSLULOmWeeSd++fRtk34Zh4HK5sNvtDbL/YOd2u5k6dSo33nhjlZ/37t2bK6+8spGjCk5Wq7VRvmfo0KEkJCTw3nvv8dhjjzXKdwohREOScrzhVFWOH97M3G6389JLL3HGGWccsZvUgQMHiImJqfF3m0wmTCZTrWMOJKUUDoeDqKioGm/TpUsXunfvzrvvvitJt6gxaV4uwtKzzz7LSSedRFJSElFRUfTp04f//e9/ldbTNI1bb72VqVOn0q1bN2w2G9OmTau03q+//oqmaXz11VeVPvvoo4/QNI158+Ydc9x//PEHF198Ma1atcJms5GRkcGdd95JaWmpf52xY8fy6quv+uMvf5UzDIMpU6bQrVs37HY7qamp3HDDDeTn5x/1+//880/y8vIYOnRonY+hvPnd7Nmz6du3L1FRUfTo0YPZs2cD8OWXX9KjRw/sdjt9+vRh6dKlVe5n8+bNDB8+nJiYGJo3b85jjz2GUqrCOjU9VqUUEydOpGXLlkRHR3PaaaexatWqKr931apVDBkyhKioKFq2bMnEiRMxDKPSeof36Z49ezaapvHZZ5/xxBNP0LJlS+x2O6effjobN26stP2rr75K27ZtiYqK4oQTTuCPP/6osp+4xWLh1FNP5ZtvvqkyXiGECEdSjjduOf7oo4+iaRqrV6/m8ssvJyEhgUGDBgGwYsUKxo4dS9u2bbHb7aSlpXHttdeyd+/eCvuork/3Tz/9xMknn0xMTAxNmzZl5MiRVZbBa9eu5ZJLLiElJYWoqCg6derEv/71L39899xzDwCZmZn+c1b+XR6Ph8cff5x27dphs9lo06YNDz74IE6ns8J3lN+jTJ8+3X+P8p///IfBgwdz/PHHV3luOnXqxPDhwyssO+OMM/juu+8q3ZcIUR2p6RYhp7CwkLy8vArLNE0jKSnJ//OLL77IOeecwxVXXIHL5eKTTz7h4osv5vvvv2fkyJEVtv3ll1/47LPPuPXWW0lOTqZNmzaVvvPUU08lIyODqVOncv7551f4bOrUqbRr144BAwYc87F9/vnnlJSUcNNNN5GUlMTChQt5+eWX2b59O59//jkAN9xwAzt37mTGjBl88MEHlfZxww038O6773LNNddw++23k5WVxSuvvMLSpUuZM2cOFoul2u+fO3cumqZV21y8pKSk0rkHiI+Px2w+eDnZuHEjl19+OTfccANXXnklzz77LGeffTavv/46Dz74IDfffDMAkyZN4pJLLmHdunXo+sFngF6vlxEjRnDiiScyefJkpk2bxiOPPILH46lQ21vTYx0/fjwTJ07krLPO4qyzzmLJkiUMGzYMl8tV4ThycnI47bTT8Hg83H///cTExPDGG2/U6gn4U089ha7r3H333RQWFjJ58mSuuOIKFixY4F/ntdde49Zbb+Xkk0/mzjvvJDs7m/POO4+EhARatmxZaZ99+vThm2++oaioiNjY2BrHIoQQwUjK8cCV40dz8cUX06FDB5588kl/Qjljxgw2b97MNddcQ1paGqtWreKNN95g1apVzJ8/v8IDg8N98MEHjBkzhuHDh/P0009TUlLCa6+9xqBBg1i6dKn/d7VixQpOPvlkLBYL48aNo02bNmzatInvvvuOJ554ggsuuID169fz8ccf88ILL5CcnAxASkoKANdddx3vvfceF110Ef/3f//HggULmDRpEmvWrKn0oGXdunVcdtll3HDDDVx//fV06tSJJk2acP3117Ny5Uq6d+/uX3fRokWsX7+ehx56qMI++vTpwwsvvMCqVasqrC9EtZQQIeKdd95RQJUvm81WYd2SkpIKP7tcLtW9e3c1ZMiQCssBpeu6WrVqVaXvA9Qjjzzi//mBBx5QNptNFRQU+Jfl5uYqs9lcYb3qtG7dWo0cOfKI6xwet1JKTZo0SWmaprZs2eJfdsstt6iq/vv+8ccfClBTp06tsHzatGlVLj/clVdeqZKSkiotz8rKqvbcA2revHkVjhNQc+fO9S+bPn26AlRUVFSF4/jPf/6jAPXrr7/6l40ZM0YB6rbbbvMvMwxDjRw5UlmtVrVnz55aHWtubq6yWq1q5MiRyjAM/3oPPvigAtSYMWP8y+644w4FqAULFviX5ebmqri4OAWorKws//LBgwerwYMH+3/+9ddfFaC6dOminE6nf/mLL76oAPX3338rpZRyOp0qKSlJ9evXT7ndbv967777rgIq7LPcRx99VCkuIYQINVKOB64cP9Tnn39eqex95JFHFKAuu+yyGh3Txx9/rAD1+++/+5eV/37Ly8r9+/er+Ph4df3111fYNicnR8XFxVVYfsopp6imTZtWOEdKqQrl9jPPPFOpLFZKqWXLlilAXXfddRWW33333QpQv/zyi39Z+T3KtGnTKqxbUFCg7Ha7uu+++yosv/3221VMTIwqLi6usHzu3LkKUJ9++mmlcyNEVaR5uQg5r776KjNmzKjw+umnnyqsc2jNZH5+PoWFhZx88sksWbKk0v4GDx5M165dj/q9V199NU6ns0Lztk8//RSPx1Nv/ZwPjfvAgQPk5eVx0kknoZSqthn2oT7//HPi4uI444wzyMvL87/69OlDkyZN+PXXX4+4/d69e0lISKj283HjxlU69zNmzKh0/rp27VqhxqB///4ADBkyhFatWlVavnnz5krfdeutt/rflzcfdLlczJw5s1bHOnPmTFwuF7fddluFp/F33HFHpe/88ccfOfHEEznhhBP8y1JSUrjiiiuqPSeHu+aaayr09z755JMrHONff/3F3r17uf766yu0DrjiiiuqPffly6tqZSCEEKFGyvHqNXQ5fjRVjely6DE5HA7y8vI48cQTAar8fZSbMWMGBQUFXHbZZRWOxWQy0b9/f/+x7Nmzh99//51rr722wj0CcMRa9HLl03fdddddFZb/3//9HwA//PBDheWZmZmVmovHxcVx7rnn8vHHH/tr+L1eL59++innnXdepb7tUi6L2pLm5SLknHDCCUcdgOX7779n4sSJLFu2rEJ/nqou3lWNoFqVzp07069fP6ZOnco//vEPwNck7cQTT/SPuFpYWFih35bVaiUxMbFG+wfYunUr48eP59tvv63Ud6uwsPCo22/YsIHCwkKaNWtW5ee5ublH3Yc6Qv+kDh061Kif2OGFZlxcHAAZGRlVLj/8WHVdp23bthWWdezYEcDff6umx7plyxZ/7IdKSUmpdGOyZcsW/4OAQ3Xq1KnK76jK4cde/h3lx1gez+Gj9JrN5iqbRMLB30lNbj6EECLYSTlevYYux4+mqnO5b98+JkyYwCeffFLp+490TBs2bACodrCx8u5S5Q+l69pMe8uWLei6XqlcTUtLIz4+3l/ulqvu7+Xqq6/m008/5Y8//uCUU05h5syZ7N69m6uuuqrSulIui9qSpFuEnT/++INzzjmHU045hX//+9+kp6djsVh45513+OijjyqtX5v+uldffTX//Oc/2b59O06nk/nz5/PKK6/4P//nP//Je++95/958ODB/gHEjsbr9XLGGWewb98+7rvvPjp37kxMTAw7duxg7NixVQ7mdTjDMGjWrBlTp06t8vPyvk/VSUpKqtFALUdT3eil1S2vyw3CsR5rQ6nPYyxX/jsp78MmhBDhTMrxwJXjVZ3LSy65hLlz53LPPffQs2dPmjRpgmEYjBgx4ojHVP7ZBx98QFpaWqXPD23tVR9qmgBX9/cyfPhwUlNT+fDDDznllFP48MMPSUtLq7KyQcplUVuSdIuw88UXX2C325k+fXqFuSLfeeedY9736NGjueuuu/j4448pLS3FYrFw6aWX+j+/9957KzRRq00Tr7///pv169fz3nvvcfXVV/uXz5gxo9K61RUs7dq1Y+bMmQwcOLBWNyHlOnfuzNSpUyksLPTXQgeCYRhs3rzZX7sNsH79egB/bXBNj7V169aA74n7obXne/bsqXRj0rp1a/+T+UOtW7euzsdSXTwbN26sMBe6x+MhOzu7ynlSs7Ky0HW9wvkQQohwJeV48JTj+fn5zJo1iwkTJjB+/Hj/8qrKysO1a9cOgGbNmh2xlVx52bxy5coj7q+6c9a6dWsMw2DDhg0V5h3fvXs3BQUF/nL3aEwmE5dffjnvvvsuTz/9NF9//TXXX399lQ/Ts7KyACp8nxBHIn26RdgxmUxomobX6/Uvy87O5uuvvz7mfScnJ3PmmWfy4YcfMnXqVEaMGFHhKWfXrl0ZOnSo/9WnT59axQ0Va0SVUrz44ouV1i3vW1RQUFBh+SWXXILX6+Xxxx+vtI3H46m0/uEGDBiAUorFixfXOO6GcmjNg1KKV155BYvFwumnnw7U/FiHDh2KxWLh5ZdfrnBup0yZUmm7s846i/nz57Nw4UL/sj179lRb41AXffv2JSkpiTfffBOPx+NfPnXq1GprJxYvXky3bt0C+iBECCEai5TjwVOOV3VMUHUZerjhw4cTGxvLk08+idvtrvT5nj17AF/t/SmnnMLbb7/N1q1bK6xz6PdWd87OOuusKmN6/vnnASqNdn8kV111Ffn5+dxwww0UFxdX29d/8eLFxMXF0a1btxrvW0Q2qekWIeenn35i7dq1lZafdNJJtG3blpEjR/L8888zYsQILr/8cnJzc3n11Vdp3749K1asOObvv/rqq7nooosAqiwUj2Tjxo1MnDix0vJevXoxbNgw2rVrx913382OHTuIjY3liy++qDIRK78JuP322xk+fDgmk4nRo0czePBgbrjhBiZNmsSyZcsYNmwYFouFDRs28Pnnn/Piiy/6Y6/KoEGDSEpKYubMmVX2wVqyZAkffvhhpeX1NdVKObvdzrRp0xgzZgz9+/fnp59+4ocffuDBBx/0N62r6bGmpKRw9913M2nSJEaNGsVZZ53F0qVL+emnnyo1C7v33nv54IMPGDFiBP/85z/9U4a1bt26Xv52wNc/8NFHH+W2225jyJAhXHLJJWRnZ/Puu+/Srl27Sk/y3W43v/32m3+aNSGECHVSjgeuHK+t2NhYTjnlFCZPnozb7aZFixb8/PPP/preo2372muvcdVVV9G7d29Gjx5NSkoKW7du5YcffmDgwIH+B+wvvfQSgwYNonfv3owbN47MzEyys7P54YcfWLZsWYVz9q9//YvRo0djsVg4++yzOf744xkzZgxvvPEGBQUFDB48mIULF/Lee+9x3nnnVWhVdjS9evWie/fufP7553Tp0oXevXtXud6MGTM4++yzpU+3qLlGHi1diDo70lQjgHrnnXf867711luqQ4cOymazqc6dO6t33nnHPx3GoQB1yy23VPl9HDbVSDmn06kSEhJUXFycKi0trXH85dNUVPX6xz/+oZRSavXq1Wro0KGqSZMmKjk5WV1//fVq+fLllY7P4/Go2267TaWkpChN0yod1xtvvKH69OmjoqKiVNOmTVWPHj3Uvffeq3bu3HnUOG+//XbVvn37CsuONmXYodNuVTelSlXnuny/zzzzjH/ZmDFjVExMjNq0aZMaNmyYio6OVqmpqeqRRx5RXq+30n5rcqxer1dNmDBBpaenq6ioKHXqqaeqlStXqtatW1eIXSmlVqxYoQYPHqzsdrtq0aKFevzxx9Vbb71V4ynDPv/88yqP8dDfn1JKvfTSS6p169bKZrOpE044Qc2ZM0f16dNHjRgxosJ6P/30kwLUhg0bKh27EEKEEinHDx5fY5fjhzrSlGHl03Ieavv27er8889X8fHxKi4uTl188cVq586dlc7v4VOGlfv111/V8OHDVVxcnLLb7apdu3Zq7Nix6q+//qqw3sqVK/3fY7fbVadOndTDDz9cYZ3HH39ctWjRQum6XuG73G63mjBhgsrMzFQWi0VlZGSoBx54QDkcjgrb12Tat8mTJytAPfnkk1V+vmbNGgWomTNnHnE/QhxKU+oYRvcRIgJ5PB6aN2/O2WefzVtvvRXocOrd5s2b6dy5Mz/99JO/KbdoeIZhkJKSwgUXXMCbb77pX37eeeehaRpfffVVAKMTQojwIeV4w3jrrbe47rrr2LZtGy1btmy0761vL774InfeeSfZ2dmVZiQB35Sjv//+O4sXL5aablFj0qdbiFr6+uuv2bNnT4VBUsJJ27Zt+cc//sFTTz0V6FDClsPhqNQ/7v3332ffvn2ceuqp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fV9trqM33MLKVav54N03aZ6ezocffcLQEWezesVftGjR3L/eiOFn8M5/X/f/bLMd3P8bb77N4qVLmffHLH6aPoPLr7qG3Tuy0DSNrKxs3nzrXf6a//tRYykoKOCU086gqKiIiRPG069vb9919Pc/ufeBhxly2mC5joqIE+yXSCGEEPXBZAMsjVPTbbhqvGppaSlffPEF33zzDaeccgoAjz76KN999x2vvfYaEydO9K9rs9lIS0urcj9r1qzhnHPOoVu3brRt25Z77rmHvLw8kpOTue2223jqqaeIjY09ajwPPvgg2dnZrF+/nubND96oduzYkcsuuwy7vY41ZUIEuboOyvnsfeMwImVQTt0KpqNdA+qppru219Evv+GbLz/llJMHAfDo+H/x3fc/8dp/3mTiY4/41/VdR1Or3M+ates4Z9RIunXrStu2mdxz37/Iy8sjJSWFm269g6effKxm19GHHmXLlq2sW72MFs3T/cs7duzAZaMvluuoiEj1cFUQQggh6sbj8eD1eivdhEVFRfHnnxVrpWbPnk2zZs3o1KkTN910E3v37vV/dvzxx/Pnn39SWlrK9OnTSU9PJzk5malTp2Kz2Tj//POPGothGHzyySdcccUVFRLuck2aNMEsgzKJMFfehLsmL7MMyhkUDl5HKz4siYqK4s858yosm/3bHzRr3oZO3Xpx0y3/rHgdPa4Hf86Z57uO/jyT9PQ033X0o0+x2+2cf945R43FMAw+/ewLLht9Cc0PSbjLyXVURCr5qxciQhgK9MMqOHWXi35PPosGLB5/D4bcQIlG1rRpUwYMGMDjjz9Oly5dSE1N5eOPP2bevHm0b9/ev96IESO44IILyMzMZNOmTTz44IOceeaZzJs3D5PJxLXXXsuKFSvo2rUrycnJfPbZZ+Tn5/PII48wY8YMHnroIT799FPatWvH22+/XaHZerm8vDzy8/Pp3LlzY54CIURjcDhh7L2+9+9OBnv4jGfStGlTBpzYn8efeJounTuTmtqMjz/5nHnzF9C+fTv/eiOGD+WC888hs01rNm3O4sGHH+XMURcw789ffNfRa65mxd8r6XpcX5KTkvjso/fJz89n/ISJzJ75Ew+Nn8Ann31Bu7aZvP3maxWarZcrv4526tihMU+BEEFPkm4hwpTTA2v2mNi0T2efQ6PUrRFlVsTbFa2b2tGsTdAMg9SFSwDQvEaAIxaR6oMPPuDaa6+lRYsWmEwmevfuzWWXXcbixYv964wePdr/vkePHhx33HG0a9eO2bNnc/rpp2OxWHj11Vcr7Peaa67htttuY9myZXzzzTcsX76cyZMnc/vtt/PFF19UikPmrRcijHkNmDHn4Psw88G7b3Lt9TfRonUH33W0V08uu/RiFi9d6l9n9KUX+9/36NGd43p0p12nHsz+7XdOH3Ka7zr68gsV9nvNP27k9ltuZOmy5Xz97fcsXzyPyc++wO133s0Xn31UKQ65jgpRNWleLkSY8RqwcLuJt5ZY+X2LmR37dUrdviruUo/GrmKd+buakHDx26zMk5ptEXjt2rXjt99+o7i4mG3btrFw4ULcbjdt27atdpu2bduSnJzMxo0bq/z8119/ZdWqVdx66638/vvvnHnmmcTExHDJJZcwe/bsKrdJSUkhPj6etWvX1sdhCSFEo2nXri2//TKd4oLdbMtax8J5v+H2uGmbmVntNm3bZpKcnMTGjZur/PzX2b+xavUabr3lRmb/9gdnjRjuu45edAGzf6t6ULry6+i69Rvq5biECBeSdAsRRvaWaHz8t4X52814DI2kaIPBbdyM7uHiH72dXNbDxeA2bhLtHjSLnYU5MpiJCB4xMTGkp6eTn5/P9OnTOffcc6tdd/v27ezdu5f09Mp9Bh0OB7fccgv/+c9/MJlMeL1e3G43AG63G6/XW+U+dV1n9OjRTJ06lZ07d1b6vLi4GE8tplMSQojG5ruOpvmuoz/P4tyzR1a77vbtO9i7dx/p6ZUHqHQ4HNxy+138598vVXEd9RzxOnrpJRfy8SefsXPnrkqfy3VURCpJuoUIE1sKTXy2ysK+Up0os2J4ezeX93BzfJpBsxhFjBVSYhTHpxmc376A4jmvYNEPNgPLd8i8YSIwpk+fzrRp08jKymLGjBmcdtppdO7cmWuuuQbw3aTdc889zJ8/n+zsbGbNmsW5555L+/btGT58eKX9Pf7445x11ln06tULgAEDBvDVV1+xYsUKXnnlFQYOHFhtLE888QQZGRn079+f999/n9WrV7NhwwbefvttevXqRXFxccOcBCGEOAbTf57JtOkzyMrKZsbMXzht6Fl07tSRa8ZeBZRdR+/7F/PnLyQ7ewuzfvmVcy+4lPbt2zF82NBK+3v8iac4a8RwevU6HoCBJ53Il19/y4oVK3nl3/9h4EknVhvLE48/QsuWLThx4Km8/8FHrF69hg0bNvL2O+/Tq99AuY6KiCR9uoUIA7Z2p/HTxigUGi1iDc7q4CbKUv36mgbODT9z3uWX+pd9tcbCqJ4aSdHSHysseZ2AF2iEebprqbCwkAceeIDt27eTmJjIhRdeyBNPPIHF4vsjNplMrFixgvfee4+CggKaN2/OsGHDePzxxyvM1Q2wcuVKPvvsM5YtW+ZfduGFF/LHH39w8skn06lTJz76qHI/xHKJiYnMnz+fp556iokTJ7JlyxYSEhLo0aMHzzzzDHFxcbU+PiEigcsDG/fqbMg3UeDQKHGDzQRJ0YrW8QZdU7zYQv2usybTeHkNjrlOqxbThZUrLCzkgYceZfv2HSQmJnDh+efyxOOPVLyO/r2S9z6YSkFBIc2bpzNs6BAen/BwFdfRVXz2v69Y9tdc/7KLLjyf2b/9wcmnDaNTxw589MHb1caSmJjIn7/N4tnnpzBx0mS2bNlKQkI8Pbp345mnJsp1VESkUL/8CRHxftvkosnJd6DQ6Jri5bRMT42nCG1qO5hgOzwa36y1cHE3F03DZ1BXoZnB3ATc+8FbCkYjzNNtbuL73hq65JJLuOSSS6r9PCoqiunTp9doX927d2fDhop9CXVd59///jevvfZajfYRFxfHpEmTmDRpUrXrVNcvXIjIo7F2r5WFu6w4vRWvLR4DDhRqbC3Umb/NRK90Lz2rniI6uGlmMMeA58DRE2KvAaoeGpKaY2p3Hb34Qi65+MJqP4+KimL6j9/UaF/du3djw5rlFZbpus6/X5nCv1+ZUqN9xMXFMemJCTz1xIRq15k9a1qN9iVEOJCkW4gQNj/LwZTfStB0E12TXZzeVtU5n0qIMshxaXy9xsIl3d2hXyMhfExWSDoBDDd4PGA2N3zSrZl93yuECGsOj0bsiIn8sT0GgDibQZcUg4w4gyiLotStsbtYZ2Wuzr5SnYU7zGzOj8YUW3nKvqBmskJiX1A16IvsMcBcD0m3XEeFCCtyWy1EiNqQ6+bJnwsxFDjWz+CU3ieiabUroL12O99P/wJNgzOd8NkqRb5DZ/pGM2d38jR4biYaickKugVopKRbCBH2ihzw3eY4rM2TMOuKE1t6OS7Fi+mQS0y8XZHe1MvxaV427NWZnW0mr8RE3KjJrNlZSpfK0zxXyemsfbeVSmKiYO9fdd/eZAVqUsbWU9IthAgrknQLEYLyir2M/yEfp0fRs4WZme+8gnZZ9YOa1ERTG4zq6OZ/qyxkF5hYsF1xYkbVo5MKIYSIXMUu+N9qK8UuDW/xHi7sbaV5gh1VTZGhadAx2aBFrItv15jYQxz3fpNP0c+34cmt+RR9htcLRxivRAghgpUk3UI0MLfHg7cW02OYzGYs5ur/a7q9iiemF7CvxKB1opl7h8Qw8/H6SY5TmyiGtPUwY5OFhTtMpDc1aB0vA6sJIYTwcXrg27UWil0acVYPWd/fTeLAKTXaNsYKZ2YW8t+Z27E2P560cydzQecS4uxHLmdKi/fz7H3jMJSUR0KI0CRJtxANyO3xMGrkKPLy8mq8TXJyMt//8H21ifebc/azOsdNjFXjkTPjibHWfb5L3eWi93MvowHL7rsdw2qlS4pBzn4vf+ea+HmThct7uIiRbmVCCBHxlILpG83klehEWxQjMot4tWRvrfZhNSmKZjxGlxs/ZU+pmZ82RXNxdzf2I9yRuq31UAg5nHDTeN/71x4Du4wYKoRoPJJ0C9GAvB4PeXl53P/Cu1isRy/g3S4nT905Fq/HU2XSPXezg2/+LgHg3qFxtIg343DUPenWDIPmf8wDYPndt/qXn9zGw65ijbwSnekbLZzXxV3n7xCNzzCMQIcQ8eR3IMLR8hwT2QUmTJri7E5ummp1/Dv3OhmWWcw3G+PId+jM2mTmrI4NPI6I14BvZ/nev/Jo9etpgFJSqx4EDKV8T3pkGBIRBiTpFqIRWKw2LJZje1KfX+JlyuwiAC7qGc2Jmfb6CK1KZh1GdPDw6d8Wthfp/LXDRK9QnOYlwlitVnRdZ+fOnaSkpGC1WtHK7mKVUng8Hsxms39ZJGjs41ZK4XK52LNnD7quY62PGjohgkDeAY0/t5oAGNTaQ2oTRcmBuu8v2qIY1cnNZystbMo3sXqPQbdmgX9YZTWDrhns3JVLSnIiVqulxjmfAjxehdmjRXSeeKznQQEul5s9efvQNQOrZCsiDMifsRAhQCnFlF+LKCw1yEwyM+bEpg3+nYlRilMzff27F2w3kRptavDvFMdG13UyMzPZtWsXO3furPCZUgrDMNB1PeKS7kAcd3R0NK1atULXZRRjEfoMBT9vMmMojTbxXo5LrZ/kuFmMYkCGlzlbzfyebaZFrIv4hnueXCO6Bpkpil0FJezcWTZqeg2vHb7rjULXtYi6zh7umM9DWSuDaKuXVim+34kQoU6SbiFCwPQ1pczPdmLRfc3KrabGKYG6pBhsL/KyZo+JmVl2NHtso3yvqDur1UqrVq3weDx4vQcH2DMMg71795KUlBRRiWAgjttkMkVciwIR3lbkmMgr0bGZFEPb1W8z8F7pXrILdHYU6fyaZeG8zu6Az2poNUOrJPAYXrwGvqrXGjCUYm+hk6Q4G3qgDyKAjvk8aGDSfa3uIvg0ijAjSbcQQW5XoYfX/9wPwNX9m9A2uXHnSzm1jYec/Rr5Dp2mJ98l/dxCgKZpWCwWLJaDfyuGYWCxWLDb7RGXdEficQtR25kzqpsL+4AL5m33tXQa2MpDdD0XQboGp7d1M3W5lW2FOhv26XRMCnwzc00Di8n3qilDgcWksFsju3ZWzoMQlUnSLUQQM5TimVmFlLoV3dMtXNgzptFjsJjgzA4ePl1pwZrRl29WOrmsX1SjxyGEEKJm6jJzRrnD58Kes9WM26uRGtNwfa7j7dCnuZeFO8z8kW2mTbwLq/RoEkKEEUm6hQhi09eUsmqXmyiLxj1D4zAF6JFxcoxiUIaT37ba+WCRg54ZLrqkyQBRQggRjGo7cwZUPRd2XonG2jxfC5FTMxt2dPG+LbysyzNR6NRYvNPEgAzv0TcSQogQEdC2dl6vl4cffpjMzEyioqJo164djz/+OOqQC75SivHjx5Oenk5UVBRDhw5lw4YNAYxaiMZRWGrw1lxfs/KrTmhCWmz9PyPz2mz89M1Upn0zFe9R5iztkuzGufl3vAom/VzAfkfgm/8JIYSoXvnMGTV5masYaX/eNhOg0T7RS2qThu1aZNZ9o6IDLN1l4oCrnr8g2g5b//C9ogM8WpsQIuIENOl++umnee2113jllVdYs2YNTz/9NJMnT+bll1/2rzN58mReeuklXn/9dRYsWEBMTAzDhw/H4XAEMHIhGt7b8/ez36lok2jm3B7RDfMlmobXbscbZT/qaCWaBsVzXiatqc7u/QYv/FpY4QGZEEKI8LFrv0ZWvgkN1Wi1zm0TDNKaGHgMjYU76vlBs6ZBTJTvJaNzCSEaWUCT7rlz53LuuecycuRI2rRpw0UXXcSwYcNYuHAhUDZN0pQpPPTQQ5x77rkcd9xxvP/+++zcuZOvv/46kKEL0aDW5XqYtroUgNsGx2JupNHKj0a5S7lnSDRmHeZsdvLdypJAhySEEKIBLNjuS3q7pBgkRDXOA1ZN8w3WBrByt06B1K8IIcJEQPt0n3TSSbzxxhusX7+ejh07snz5cv7880+ef/55ALKyssjJyWHo0KH+beLi4ujfvz/z5s1j9OjRlfbpdDorjMBZVFQE+EawNYyaNYc1DMM/t2skqZfjNgzf/IrlrxBgKOU77gaI11AKTdehpqdDgWYy89ocXzI7tJOdrumWI8ZW6+8oo+k6utvN8a+8ARr8ffuNGNYjDEurfNu0TTJx3UlNef3P/fznz/10TrXQPqVxR1Q/Fg35+2405f+/DMP3qgG5rgXPcQdTLEJUJbdYY2uhjobihBY1HwG9PrSIVbSO97KlwMRfO8wMbVdP3+90wV1P+t4//yDYZFwSIUTjCWjSff/991NUVETnzp0xmUx4vV6eeOIJrrjiCgBycnIASE1NrbBdamqq/7PDTZo0iQkTJlRavmfPnho3STcMg8JCX9PZSJpipl6O2+uEQgNMrgC3o6g5QykKi90oqPd5NV1uFx269AGlo2rSOk/pZAy+gax9BtEWOLeLhdx9R/67rfV3ABpm2nfuje6FjJmzAfj7putRpiMl3ToduvQhr9DFiS0sLGxhZskOD+O/z2f8GU1IjA6NX3hD/r4bjeHCN3nsXjAV12wTua4FzXHv378/0CEIcUR/7fQNHd4x2SA2AN2fT2jhS7rX5umc0LKeblY9Xvjke9/7yfdBzcaXE0KIehHQpPuzzz5j6tSpfPTRR3Tr1o1ly5Zxxx130Lx5c8aMGVOnfT7wwAPcdddd/p+LiorIyMggJSWF2NjYGu3DMAw0TSMlJSVobtIaQ70ct6cE0MFiBVNoDFRiKIUGpCTa6z0Jczhgw5rFoBloNZj+xOkyKE4/GR24ZkBT2jc/el/u2n4HgMLDxrVLUBzM0jUTR97eMNiwZjHJcVbsdjsPjLBx15f72Jbv5eW5pTxzXgLR1uD//9KQv+9G4wXcTkhJAnPN+vvLdS14jttuD41ro4hMBQ6djft8/1f6Ng/MCOLpTRUZsQbbinQW7zTTv1lAwhBCiHoT0KT7nnvu4f777/c3E+/Rowdbtmxh0qRJjBkzhrS0NAB2795Nenq6f7vdu3fTs2fPKvdps9mw2So/vtR1vVY3XJqm1XqbcHDMx63rvk5Z5a8QoWkaetmrPumahjIMqOHpWLrbim6z0SpeZ2S36BrFU9vvKKcOa+KqcZTtNd825ecp1m5i4qgE/vm/fWzO8zBxWiGPjUzAaj62c+j2ePB6atec0GQ2YzHX/HLWUL/vRlP+/0vXfa8abybXtWAQLHEIUZW/8+yARmaCl6TowHXD6dfCw7YiK6tzdXokhOi1WgghygQ06S4pKal082Eymfz93TIzM0lLS2PWrFn+JLuoqIgFCxZw0003NXa4QjSoYhesyPX1Mbuyb1TA5uSujbRYMxNGxnPf1/ks3e7iyZ8LeGh4fJ0HfnN7PIwaOYq8vLxabZecnMz3P3xfq8RbCCFERZo1ho35vnKoV3pg58luEatIb2Kwq1hn9d6ogMYihBDHKqB3qGeffTZPPPEErVq1olu3bixdupTnn3+ea6+9FvDVTtxxxx1MnDiRDh06kJmZycMPP0zz5s0577zzAhm6EPVu4XYzXqXh3r2KE1qdFOhwaqxzqpUJI+N56Pt85mU5efLnAu4fFo+1Dom31+MhLy+P+194F4u1Zh3u3C4nT905Fq/HI0m3EEIcA3vHYXgMjaRogxZNAzvYpKb5Ev9dG3TW7LODSQY+E0KEroDeob788ss8/PDD3HzzzeTm5tK8eXNuuOEGxo8f71/n3nvv5cCBA4wbN46CggIGDRrEtGnTpE+cCCv5pRqrcn2tPg789R6aNjDAEdVOz5Y2Hh4Rz+M/FTBns5NHf8hn/Jnx2C16rZqLl888YLHasFjkBksIIRqLocDeZSQAx6d6g6KHWNtEg1ibosipY2t/WqDDEUKIOgto0t20aVOmTJnClClTql1H0zQee+wxHnvsscYLTIhGNm+bCYVG6zgPebtXBzqcOunfxs5joxJ49McCFm9z8eB3+Ywf3pRLLzin1s3FDa8XQmcWMiGECHnb9lsxNU3GZjLolBwc09rpGhyf5uWPLWaiup4bKjORCiFEJdIWU4gA212ssXGfCVD0b+FkcSN+t9dm4+dP30bTwGs/9vlTemfYmHROAg9/n8+qXW4e/K6QvcWuGjcXLy3ez7P3jQvtObSFECIErd3na0HYMdGFpY7jcjSErile5m/TIaEVO4v3075mEzZUFm2HdTMOvhdCiEYkQ6gKEWDzt/mefXVONkiKauTaBU3DFR+HKz6u3kab75ZuZfJ5icTZNTbt9RI/8hlKlR2LxXrUl9kqTcqFEKKxFbtg+35f86LOic4AR1ORzQwdEnwxrd57DA+HNQ2SE3yvYGg7L4SIKJJ0CxFAu4s1thTqaCj6t6zdNFnBrH2KhecuSCIlRsMU14Kv1kWTd0BucoQQIhit2ePr4uTOWUm8PTialh+qS6IDgC2FFopdAQ5GCCHqQJJuIQJo0Q4TAJ2SDeIC0NpNd7vp/sqbdHv5TXSXu173nZFg5umzm+LZl02JW+d/qy3sKJLEW4hQ5PV6efjhh8nMzCQqKop27drx+OOPow7pCqKUYvz48aSnpxMVFcXQoUPZsGFDAKMWNaEUrMr1lUWOddMDHE3VEuxe3DkrUWj+WGvN6YJ7nva9nJK5CyEalyTdQgRIXonG5nxfX+6+LQIzH6rm9dLmu2m0+W4amrf+Y0iK0Sn88T7SYjy4vBpfr7GwtUASbyFCzdNPP81rr73GK6+8wpo1a3j66aeZPHkyL7/8sn+dyZMn89JLL/H666+zYMECYmJiGD58OA6HI4CRi6PZVqRR5NSw6gbO7LmBDqdapWt/BGDlbhNGXYb98Hjh7c99L09g5yAXQkQeSbqFCJDFZbXcHRINEqPCd+Aw5TrA2R1LaRPvxas0vltnYYsk3kKElLlz53LuuecycuRI2rRpw0UXXcSwYcNYuHAh4KvlnjJlCg899BDnnnsuxx13HO+//z47d+7k66+/Dmzw4ojW7vGVRW3jneANrv7ch3Jlz8VuMjjg1thaILevQojQIlctIQJgvxPW7/X99+sToFruxmTWYWRHD5kJvsT7+3UWdu6XxFuIUHHSSScxa9Ys1q9fD8Dy5cv5888/OfPMMwHIysoiJyeHoUOH+reJi4ujf//+zJs3LyAxi6Nze2HTPl9Z1CE+eBNuAAwP7RN8zcJX75HbVyFEaJEpw4QIgKW7fIPWZMQaNIsJ31ruQ5l0OKuDhx/WQ3aBie/WWri4uzusa/mFCBf3338/RUVFdO7cGZPJhNfr5YknnuCKK64AICcnB4DU1NQK26Wmpvo/O5zT6cTpPJjoFRUVAWAYBoYRfIN5HYlhGCilMFC+TtIBnvbQUApN1+EooWzcp+M2NOJsBs2iPTXa5nCHbqMUUINt6/o9HRJcrMyzszlfp9QN9uruYpVvfUOpg1NQKuWvaTIa6HdkKOX7O4jwaS/lPDTyOSj/ezYM3ytI+K+LQRRTbdVn7JJ0C9HInJ6Dg9b0al71iOWH3ogedX+1WDfQTDqc2cHDl2s0dhfrfLPGwugeLqIsgY5MCHEkn332GVOnTuWjjz6iW7duLFu2jDvuuIPmzZszZsyYOu1z0qRJTJgwodLyPXv2hFw/cMMwKCwsQqHQza6AtyN0uV106NIHlI46QmOq8qblnZIMdM1Mhy590DAdcZtDaRzcBgNfwm0cOe8+dJvafk+yHZKiDPaW6qzfo9OjWTU3xEqnQ5c+5BW6sJaU7aPEQfkjoT35DpSz/ltbGUpRWOxGAXoET0sm56GRz4HhAq8B7AVTccN+Vy34rouFKKXQ9dBsnbJ///5625ck3UI0spW5JtyGRlKUQeu4ircmXo8HNI0hQ06v9X4NrxdCIHm1mOCcTm4+W2ml0KkxfaOFczq70SOzXBYiJNxzzz3cf//9jB49GoAePXqwZcsWJk2axJgxY0hLSwNg9+7dpKen+7fbvXs3PXv2rHKfDzzwAHfddZf/56KiIjIyMkhJSSE2NrbhDqYBGIaBZrhIQUO3WsEUgOkoDuFwwIY1i0Ez0KoZ7PuAC7aXzSjRKcWLMjxsWLMYhbfabQ6nOLgNOr5sWz/yNNiHblPb70Hz0iXF4M+tOmv3mjguvZqk2zDYsGYxyXFW7Pay34XtYHmbkmCHmPr/HRlKoQEpifaITTZBzgM08jnwAm4npCSBObphv6sWDMNA0zRSUlJCNun2Xz/qgSTdQjQiQ8Hfu313GT3TvZVuTAzDC0px9zNvERVdswtnafF+nr1vXEg144qywMhObj5baWFroc6C7SYGZIR/33YhQlVJSUmlmyaTyeRvepeZmUlaWhqzZs3yJ9lFRUUsWLCAm266qcp92mw2bDZbpeW6rofkDZqmaehovhvsACcauqahDAOOEMrGfb5uTmlNDBKioOQAR92mKhW2Kfv3aNsfy/d0TvYyZ6uJ3Qd08h1a1V2UNN/6uqYdTHgO+bKG/B1pZd8ZqclmOTkPjXgOyv+edd33CiKapoXsNR2o17gl6RaiEW0t0ClyathMio5J1fcTsVitWCzWGu3Tba3ZelXxWq3Meu81NA28trrvpy6SoxVD2nr4eaOFRTtMtI43iA/Na7IQYe/ss8/miSeeoFWrVnTr1o2lS5fy/PPPc+211wK+G6s77riDiRMn0qFDBzIzM3n44Ydp3rw55513XmCDF1XaWD6A2hHKomAUbYU2CQZZ+SbW7NEZ2KqGD2yjbLD024PvhRCiEUnSLUQjWrHbd5PTJcWLpYbN6hqUrlOa1ixglTKdkw22FXhZk2dixiYz57cLTBxCiCN7+eWXefjhh7n55pvJzc2lefPm3HDDDYwfP96/zr333suBAwcYN24cBQUFDBo0iGnTptVr8zxRP4pd+GeQaJ8Yeq2MuiT7ku61e3ytpGrUPUnXoVXzBo9NCCGqIkm3EI2kyAHZZXOL9kgNrZqFhnRKGw9bi3QKHTqLcmICHY4QogpNmzZlypQpTJkypdp1NE3jscce47HHHmu8wESd+KYJ8zUtbxqClb5tEgzsZsUBt8a2Qo3W8aHTvUoIEZmkMacQjWRlrgnQyIgzSAiSabI0t4cub75H5zfeQ3O7AxKDzQxD2/q+e/VeO6bEzIDEIYQQkWLDXl9Tq/Yh1rS8nFnH30VrzZ4aNhtzueGRF30vV2DKOyFE5JKkW4hG4DUOThN2XGrwNOXTvR7a/e9b2v3vW3RP4OJqHa/okORFodGk/7hAT3ErhBBh68AhTcs7hGDT8nJdUnyxb9qn46rJYbg98MoHvpe76uk6hRCioUjSLUQj2FxgptSjEWNVZCaEZs1CQxvUyoNJU1jSe7C5IATmPhNCiBC0saxpeWqINi0v1yxGEWc38CqNrHy5nRVCBDe5SgnRCFbu8SWR3ZvVcMCXCNTUBj1TSgBYuCsKrzybEEKIerdxn6/VVYfE0L7IatrBJubr98rtrBAiuMlVSogGZkpoTU6xGQ1Ft2ah25SvMfRIKcVbspdit4lVuXJ5EkKI+lTigp1FoTtq+eHKk+4tBTpOaTEuhAhiclcrRAOzdxwGQNtEgyaNOxV2yDHrULr8MwAW7TDjCe2KGCGECCob9+koNFJjDGLDYCa3pGhFYpSBobSyEdmFECI4yRVKiAbkMRS2toMB6JYiGWRNONZNJ8ZicMCt8ffuYJjMXAghwkN50/JQHbW8KuW13eUjsgshRDCSpFuIBrRkuwc9Kp4os0Gr+PC5yWlQhofeqaUALNlpkr7dQghRD0rcsCOMmpaX61CWdG8r0iiVmcCEEEHKHOgAhAhnv2xwAdAx0ROUA6h5rVZm/+cFNA28tuBp+94hwcWS3dEccGusy9Pp2kwybyGEOBbZ+b6m5SnRBnFh0LS8XEKUIjnaIK9EZ9M+ne6p1ZQXUTaY8+nB90II0Ygk6RaigRQ5DBZt9T1275TkJij/u+k6xW1aodXigYDT6WyQdQ9l0uH4NC9zt5lZsstElxSjVjEKIYSoqHxarXCctrJjki/p3rDXVH3SrevQuV3jBiaEEGWCMAsQIjz8tsGBxwDP3k0kRTcLdDjHzOvxgKYxZMjptd7W8HqhllNv90j1smiHiX2lOlsKdNqE4Y2iEEI0Bo8BWwvDN+nukOR7SLu9SKPEBRZ5SCuECDKSdAvRQGas9fVLdmz8BYaNDnA0VdPcHjr+72sANl52AcpSfWZsGF5QirufeYuo6Oga7b+0eD/P3jcOQ6lax2YzQ/dUL0t3mVmaY5KkWwgh6mh7kYbb0IixKJrF1P56HOzi7JAaY7D7gM6GfTpdk6pYyeWGF972vb/zWrDW8kmwEEIcAxlITYgGsDXfw7pcN7oGzk2/BTqcauleDx0//IyOH36G7qnZwDoWqxWLpWYvs/XY+okfn+oFFNsKdfJLpepCCCHqIivfN7J3m4Tw7arTIfkoo5i7PTD5Td/LLZN6CyEalyTdQjSAmWW13H1amlGOgsAGE8Ji7dCmbNT3v3fL5UoIIWpLqYP9uduGcYuhDmUjsu/cr1HiDtMnC0KIkCV3sULUM6+hmLXel3Sf1iF4RgQPVceVDYqzZo8Jd/jMciOEEI0ir0Sj2KVh1hUZceGbdDe1QbMYA9DILpDek0KI4CJJtxD17O+dLvKKDZrYNPplSJ+xY9Uq3iDWpnB6NdbvlUuWEELURnktd0acgTnML6HtE30PFTZL0i2ECDJhfvkVovHN3uAAYFA7O1azNHE7VroG3Zv5qrhX5VbTV08IIUSV/FOFxYdvLXe5dmVJ9479JjRrTICjEUKIgyTpFqIeebyKPzf5ku5T29sDHE346JLiRUORU6yzTwZUE0KIGilxa+w+EL5ThR0uIUqRGGVgKA1ry36BDkcIIfwk6RaiHi3d7mK/UxEfpXNcC+nPXV9irNC6rJZmTa5ctoQQoia2FPqaWTeLMYiJkCKpvIm5tc2AAEcihBAHSacXIerRbxt9A6id3M6OSddwBzieo/FarPzx0tNoGniDfM7Sbs0MsgtMrMkzMaCVF10qvIUQ4oiyC3xdciKhlrtcu0SDhTvA2rIPDrfCXt7ozG6FGe8dfC+EEI1Ikm4h6onLq5i72QnA4A4h0rTcpFPYqX1IzNvaJt7AblaUuDW2FOgRdRMphBC1ZrKwfb/vNi+SrpfJ0YqmVoP92Fm6w81pnaN8H5hM0LtbYIMTQkQsaacpRD1ZvNXJAZciKUanW3pw1xqHIpMOnZN9A6qty5NLlxBCHIkltSseQyPGokiJVoEOp9FoGrRN8AAwLzvY25sJISKF1HQLUQtujwevx1PlZ7+sOwDASW0suJy+Gm9n2b/BSnN7aPv9T2hA1vkjUZbgfljQKdlgWQ5sztdxe8Eig5kLIUSVLC36AL7xMEKhNVN9ahvvZvluK4u2unF7FRaTBi43/Odj3wo3XAZB3qVKCBFeJOkWoobcHg+jRo4iLy+v8ocmG4mXf4BuieaDp27lnT3rKnxseL0QhOW77vXQ9b8fALDl7BF4gzzpbhajiLMpCp0aWfk6HZMjp8mkEELUhrWlL+luFQFThR0uNcbAKNlHSXQiy7a76NfaBm4PPPqSb4VrL5akWwjRqCTpFqKGvB4PeXl53P/Cu1istgqfbco38/PmKJpaDW585FF/rUJp8X6evW8choqcpn0NSdOgY7KXRTvMrN8rSbcQQlRlT7GBOaE1GopWcZF3ndQ0cG6ZR1SXkczZ7PAl3UIIEUDSMVKIWrJYbVgs1gqvzQW+kVA7JBlYrQeXm60yQmp965jku4HMLtBxVt3SXwghItrSHb6+zM1iDOwRWr3i2jIPgHlZTryGPPgWQgSWJN1CHCOX15cAwsGEUDScpGhFUpSBoTQ27pNLmBBCHG7Jdt8TyVaxkftk0p2zkhgrFJQarN0tA6oJIQJL7liFOEZbCnQ8hkasTZESI0/TG0N5s/L1e2UkNSGEOJTHq1heVtOdERe5STeGhz4Zvn7b87KCe1BTIUT4k6RbiGO0qay2tX2iN+JGiA2UDkm+qcO2F2qUuOWkCyFEubW73ZS4wXAUkhId2a2vTmztS7rnbHagZGwVIUQASdItxDHwGJBV1rS8XWJk39w0pni7b3Rahcbm/AjtsCiEEFX4a6uvVte1Yyl6hD+T7NXCgkWHnYVethV4Ax2OECKCyd2qEMdge6GO26sRY1GkNQm9p+hei5V5kyeABt4Qmz6lQ7LB7gM6G/bJZUwIIcqVJ93uHUuAPoENJsCirRq9Mmws3OJk7g6DVt+87vvALoOcCiEal9R0C3EMNuX7/gu1TTRCs2m5SWfv8d3Zd3x3MIVW/+iOSV5AkXPAjB6TEuhwhBAi4ApKvGzY4+vH7dqxJMDRBIeT2vqmC5uz1QOD+vpeIVbeCSFCnyTdQtSRoWDzvvKm5dJsrbE1sULzpr7WBdY2AwMcjRBCBN7ibS4A2iaZUKUFgQ0mSJzYxoYGrM91s6dYymohRGBI0i1EHe3ar1Hq0bCZFC2ahl7TcgDN46H1tz/R+tuf0DyhN8pt+7J+9LbWAwIciRBCBF550/LeLaXbTbmEaBNd0y2YvB5ynv8Y/vsZuEOvvBNChDZJuoWoo/JRy9smGJhC9H+S7vHQ49X/0v2V/6KH4E1IeQsDc2oXCkplIDshROQylPLXdPdqEVpjdDS0AZl2zF4PPV6cAvdNBpfM2y2EaFwhmioIEVhKwaZ9vj5hbWXU8oBpaoOUaC+aprNgi9xECSEiV/ZeD4WlBnazRqdm0mf5UCdl2gIdghAiwknSLUQd7Dmgsd+lYdYVreMl6Q6ktvG+Gvr5knQLISLY0u2+Wu7jWlixmEJxZM+G0yLeTKsEaXIvhAicgCfdO3bs4MorryQpKYmoqCh69OjBX3/95f9cKcX48eNJT08nKiqKoUOHsmHDhgBGLARsLGta3ibewBzw/0WRLTPBl3Sv2OnhgFMegAghItPSbb7+3L1aynRYVTmxjZwXIUTgBDRdyM/PZ+DAgVgsFn766SdWr17Nc889R0JCgn+dyZMn89JLL/H666+zYMECYmJiGD58OA6HI4CRi0i3yT9quSR5gZZgN/Dkb8VjwIItzkCHI4QQjc7tVazY6Wvt0ytDksuq9G9j9793eUJz8FMhROgKaFubp59+moyMDN555x3/sszMTP97pRRTpkzhoYce4txzzwXg/fffJzU1la+//prRo0c3esxC5Jfq5Dt0dE3RRpqWBwXX1nmYE1oxZ7ODIR2jAh2OEEI0qrW73Tg9ivgonTaJZpxOmRrrcO2TD97yrtjpom9cdACjEUJEmoDWdH/77bf07duXiy++mGbNmtGrVy/efPNN/+dZWVnk5OQwdOhQ/7K4uDj69+/PvHnzAhGyEGwu8BXcGXEGNukiFhRc2b7rwaItLpxSgyGEiDBLypqW92xpRdOkP3dVDj0v87OltaQQonEFNGXYvHkzr732GnfddRcPPvggixYt4vbbb8dqtTJmzBhycnIASE1NrbBdamqq/7PDOZ1OnM6DTUyLiooAMAwDw6hZraRhGCilarx+uKiX4zYM39De5a8QYCjlO+6jxGsohabrZJUl3W0TjBodoqbrUIvTUdv1j2Ubw2JhwYQH0TTwWixH3b4xYqv1dyjw5m8mOUYj74Bi8VYHJ2baq129pr/voFb+/8swfK8akOta8Bx3MMUiwsOyskHUekt/7urZLGx86RneW1DMxu2KmwyFSZcHFEKIxhHQpNswDPr27cuTTz4JQK9evVi5ciWvv/46Y8aMqdM+J02axIQJEyot37NnT437gRuGQWFhIUopdD1yRsmql+P2OqHQAJMrCIbpqxlDKQqL3ShAP0INgcvtou3xp7GnxAQoMmMN1FFa8GmY6dClDxqmo65bl/WPZZv2nXuDyUpuvz4HPzjC9o0RW12+A6XToUsfjk/TmbXJy6w1JbSNq371mv6+g5rhAq8B7AVTcc02keta0Bz3/v37Ax2CCCMHXAZrd5f355apsaplNtNm9KmsKsnlgEuxdrebbunykEII0TgCmnSnp6fTtWvXCsu6dOnCF198AUBaWhoAu3fvJj093b/O7t276dmzZ5X7fOCBB7jrrrv8PxcVFZGRkUFKSgqxsbE1isswDDRNIyUlJWhu0hpDvRy3pwTQwWIFU/W1jcHEUAoNSEm0HzEJczhgp6sJMUDzpoqYGhyewsOGNYtReNFqMG1qbdc/lm02rl2Cwgu6mZrkno0RW12+A8Ngw5rF3NnRzqxNB1i+y0NinA1zNVPm1PT3HdS8gNsJKUlgrlm/RLmuBc9x2+2hcW0UoeHvHS4MBS3iTDRrKvNzH4nZpNG/jY1f1juYu9khSbcQotEENOkeOHAg69atq7Bs/fr1tG7dGvANqpaWlsasWbP8SXZRURELFizgpptuqnKfNpsNm63yk15d12t1w6VpWq23CQfHfNy6Dpp28BUiNE1DL3tVR9c0rK1OBKB9olHjw1OGAbU4HbVd/1i20TweMmbMQdNgx5BTUOYjXxIaI7Zaf4fm26Zbmpk4u0ahQ7Fql/uINT41+X0HtfL/X7rue9V4M7muBYNgiUOEh/L5uXtK0/Ijc3vg8584L9fNb/oJzNns5LqTlPSBF0I0ioCW/HfeeSfz58/nySefZOPGjXz00Ue88cYb3HLLLYDvRumOO+5g4sSJfPvtt/z9999cffXVNG/enPPOOy+QoYsIVFBqYE71tcxomxgeI8PqHg89n3uV4599Fd3tCXQ4x8Skawwo68s9J0umDhNCRIYl23xJtzQtPwqXG26bQKfHnyQKD7uKvGzZF9rlnhAidAQ06e7Xrx9fffUVH3/8Md27d+fxxx9nypQpXHHFFf517r33Xm677TbGjRtHv379KC4uZtq0adI8TzS6hVvdaLqJlGgvsXJvE5ROauv7xczd7AjtgdKEEKIG9h7wsjXfgwYc30Jqumuq/FzNlQe0QohGEvAJj0aNGsWoUaOq/VzTNB577DEee+yxRoxKiMrmZ/sGqsmMlyfjwapXSxvRFo29BwzW73bTOU1uQoUQ4au8aXmHZmZi7dJtoaZObGNjTo6beVkOLu/bJNDhCCEigFyhhaiBA06D5Tt9yXZbSbqDltWs0a+1r7ZbmpgLUb927NjBlVdeSVJSElFRUfTo0YO//vrL/7lSivHjx5Oenk5UVBRDhw5lw4YNAYw4/C3b7rvO9Wopza9qo19rGxqwPtdD7v7w6C4mhAhuknQLUQMLtzjxGOAp2EZClMyxG8wGljUxn7PJgZIm5kLUi/z8fAYOHIjFYuGnn35i9erVPPfccyQkJPjXmTx5Mi+99BKvv/46CxYsICYmhuHDh9d4uk5RO0oplpb355ZB1GolIcpE13QLAPOz5e9TCNHwAt68XIhQMGezr1B2bZkLnBXYYMQR9Wttw2KCHYW+QXLaJFkCHZIQIe/pp58mIyODd955x78sMzPT/14pxZQpU3jooYc499xzAXj//fdJTU3l66+/ZvTo0Y0ec7jbVuAl74CBxQRdZeqrWhuQaWfVLjdzNzs5p0dMoMMRQoQ5qekW4iicHsWiLb7aBFf2vABHI44m2qrTu2wU3zmbpYm5EPXh22+/pW/fvlx88cU0a9aMXr168eabb/o/z8rKIicnh6FDh/qXxcXF0b9/f+bNk+tmQ1i6zXd965ZuxWaWaa9q66RMXzmxYqeL/Q5pwSaEaFhS0y3EUSze6sThUaTEaOTt3RjocOqVYbGw+F//BxoY1vCpER6YaWNBtpO5mx1c0U8GyRHiWG3evJnXXnuNu+66iwcffJBFixZx++23Y7VaGTNmDDk5OQCkpqZW2C41NdX/2eGcTidO58EHY0VFRQAYhoFhhFYSZBgGSikMFKiyVwMrH0StV0trpdkaDKXQdB1qGcqxbqMUUINtGzw25VvfUOrgubGa4a1J/vfp0SbaJJrJ3udhwRYHQzpG1TyYahhK+f4OIrxrk5yHRj4H5f/5DMP3ChL+62IQxVRb9Rm7JN1CHEV50/IT21hZE+BY6psymdh1ykloYVZJ0j/Tjj67iI15HnKKPKTFyqVOiGNhGAZ9+/blySefBKBXr16sXLmS119/nTFjxtRpn5MmTWLChAmVlu/Zsyfk+oEbhkFhYREKhW52NXg7Qq+h/IOotY5V5O6reL5cbhcduvQBpaNqOE6YhpkOXfqgYarTNhj4Em7jyHn3sX5PjbZROh269CGv0IW15JDlJw/y/VvkATwcl2Yie5+H2etK6J587AWhoRSFxW4UoIdbwVoLch4a+RwYLvAawF4wFTfsd9WC77pYiFIKXQ/NxtX79++vt33JnagQR+DxKuZn+25sBrSx8M5R1hfBIT5Kp3tzKyt2uJi72ckFPeVSJ8SxSE9Pp2vXrhWWdenShS+++AKAtLQ0AHbv3k16erp/nd27d9OzZ88q9/nAAw9w1113+X8uKioiIyODlJQUYmNj6/kIGpZhGGiGixQ0dKsVTPYG/b41OS5K3dDEptG3bQwmveJNvcMBG9YsBs1AM9VsnwoPG9YsRuGt0zbo+LJtnSM+yD3W76nRNobBhjWLSY6zYrdX/7sY2tXEt6ud/L3LS3ysDesxNtM3lEIDUhLtEZtsgpwHaORz4AXcTkhJAnN0w35XLRiGgaZppKSkhGzSfaTrR23V6U60bdu2LFq0iKSkpArLCwoK6N27N5s3b66X4IQItOU7XRQ7FfFROp2b1fDuIIRoXi/pv88FDXYP7I8yhc8xDsy0sWKHizmbHVzQUwbJEeGnMcvigQMHsm7dugrL1q9fT+vWrQHfoGppaWnMmjXLn2QXFRWxYMECbrrppir3abPZsNkqT3Wl63pI3qBpmoaO5rvBbuCb7OU73AD0bGnFYqp8rnRNQxkG1DKUY96m7N+jbd/gsWm+9XVNO5jweDzww2zf+5GngtlMx2YWkpvo5BUbLN/hon+bY7/B1sq+M1KTzXJyHhrxHJT/p9N13yuIaJoWstd0oF7jrtOesrOz8Xort+9xOp3s2LHjmIMSIljM2eRrsndSpq1STUI40N1u+jzxHH0mPofucgc6nHp1UlvfzdOqXW7yS2QeVhF+GrMsvvPOO5k/fz5PPvkkGzdu5KOPPuKNN97glltuAXw3VnfccQcTJ07k22+/5e+//+bqq6+mefPmnHfeefUaizjYn7unzM9dc043XHu/7+X0lXeapnFSpq+smJslA28KIRpOrWq6v/32W//76dOnExcX5//Z6/Uya9Ys2rRpU2/BCRFIXkMxt2z064Ht7NRodBgRNJo1NdGxmZn1uR7mZTk5q1vwNLkS4lgEoizu168fX331FQ888ACPPfYYmZmZTJkyhSuuuMK/zr333suBAwcYN24cBQUFDBo0iGnTptVr8zwBDrfBml2+pLu3zM99zE7KtPHt3yXMz3LiHazC8gG7ECLwapV0lz+t1jSt0sApFouFNm3a8Nxzz9VbcEIE0pocN/mlBk1sGse3sOJ1y1PwUHNSpp31ucXM2eyQpFuEjUCVxaNGjWLUqFHVfq5pGo899hiPPfZYvX+3OGjlLjduA5o10WkeFz5dggKlR3MrTWwaBaUGa3e76SZzngshGkCtku7yYdMzMzNZtGgRycnJDRKUEMGgfNTy/m1sWEwa3vBqfR0RBraz8+6CYpZtd3HAaRBjC80+RUIcSsriyFY+P3evDBtaBPeXrS9mk0b/1jZmrXcwd7NDkm4hRIOo0x1oVlaWFPIirCml/En3oLbSNDJUtUowk5FgwmPAwi3SUkGEFymLI9Oh83OL+jGgrJyfs9mJiuC5pYUQDafO8+jMmjWLWbNmkZubW2ni8LfffvuYAxMikDbmedi938Bm1uidIQPVhLKBbe18svgAczY7OK1jVKDDEaJeSVkcWQpLDTbleQDfyOWifvTNsGIxwa4iL1v2eWiTZAl0SEKIMFOnmu4JEyYwbNgwZs2aRV5eHvn5+RVeQoS68lHL+7W2YrdI871QNrCsBmPRFhdOj9RgiPAhZXHkWbbd12InM8lMQrT0564vUVbd/4BdRjEXQjSEOtV0v/7667z77rtcddVV9R2PEEGhvGn5wDBvWm6YzSz7v1vQNDAsdW74EtQ6pJhJaaKzp9hgyTYn/dtIywURHqQsjjzStPwYWC3w8iMH3x/mpEwbC7KdzN3s4PK+TRo5OCFEuKvTXbbL5eKkk06q71iECApb93nYmu/FohP2CZoym9k+bAjhPBaPpmkMbGvn6xUlzNksSbcIH1IWR56DSbdcx2rNYobLz6724xPb2NCADXs85O730qyptCQQQtSfOjUvv+666/joo4/qOxYhgsKfZbXcvTJsxFhltOtwcFJb3w3q/CwHXkOamIvwIGVxZNlV6CGnyItJhx7Npc9xfYuPNtE13Xde52U5AhyNECLc1Kmm2+Fw8MYbbzBz5kyOO+44LJaKF//nn3++XoIToiG5PR68Hg+GUrjcLhwO0DWNPzeWAnBCho7DcbDgdTrDr5+X5vXSbMFiNA329O2JMoXuk/0j/X7aJyia2jT2OxWLsw/QPMbA7TFjs8iNqwhdUhZHlr+2+MqjTikmNMNXZlUnHMurY+bxwC/zfe+HnAjmyrfA/VtbWLXLzZ+bShnesWbloclsxlLFvoQQ4lB1ukqsWLGCnj17ArBy5coKn8mckSIUuD0eRo0cRV5eHpqu06FLHzasWYwWnUziJW+jDC8Tbj6fRx1FlbY1vF4Ik1xNd7s5YfyTAEz7ZireqNBLur0eD2gaQ4acfsT1mgy6HXvHYdz7wqe0KFpMfu4Wvvv+W7lZEiFLyuLI4fZ4eOWTX6DFCSz66X0GTvq4RtuFU3l1zJxuuOwO3/utf1RKut0eD28/cSucPpnl250MOu1ClOvAUXebnJzM9z98L2WJEOKI6nSF+PXXX+s7DiEaldfjIS8vj/tfeBeLxQZKB81gea6FuduhRazi5uf+U2Gb0uL9PHvfOAyZwzOoGIYXlOLuZ94iKjq62vWyC0z8tAmSjzuLCzoN4um7r8br8ciNkghZUhZHDrfbjZHUCR244rLzSb/+nCOuL+VV7Xk9HvK2rKaDzUO+08wlD71LxyTPEbdxu5w8dedYKUuEEEclVwgR0SxWG2azFeUFzQSbC3xVAh2SFRZLxdFh3VYZLTaYWazWSr+zQ2UmgTVbccCtk+eUQYiEEKEje68X3R6HRVe0iDNh0o/cKknKq7prm+BlcY6Z7CIr3dJkXBchRP2oU9J92mmnHbHp2i+//FLngIQIlCIn5BTrgKJ9ohHocEQ9M+vQNsFgbZ6JTQXyvFGEPimLI8eynb4a1+ZNfQOpiYaTGe9hcY6NrQU6HsNXdgghxLGq051neR+ycm63m2XLlrFy5UrGjBlTH3EJ0eg27vXVHLSIVcRIJUFY6pBUlnTnm0CTOykR2qQsjhzLy5Lulk09gPTXb0jJ0QZNrIpil8a2Qp3MBHkIL4Q4dnVKul944YUqlz/66KMUFxcfU0BCBMqGfb4krGOSN8CRiIbSKs7AalKUeHTMzboEOhwhjomUxZHB5VGszilLumO9SM/AhqVp0C7Ry/IcM5v2SdIthKgf9VrVc+WVV/L222/X5y6FaBQFDsg9oKOhaCdNy8OWSYd2ZTdQtjaDAhyNEA1DyuLwsjrHhcsLRsk+EuxSPjWGtmXlRFa+jiFj0Qkh6kG9Pi6dN28edru9PncpRKPYmO9rWt4yThEdQdOrGGYzf99yHZoGhiUyak86JHlZk2fC2mYgXrmbEmFIyuLwsnS7CwDXzuVoWt8ARxPCrBZ4+t6D74+geVOFzaQo9Wjk7NdoHitlhRDi2NTpLvuCCy6o8LNSil27dvHXX3/x8MMP10tgQjSmSG1arsxmtpxzJpE0pW/LWN/NlDMqnlU5Hk5oG+iIhKgbKYsjw7KypNu9cxkgSXedWcxw3SU1WtWkQ2b5wJv5Os1jI+veQAhR/+qUdMfFxVX4Wdd1OnXqxGOPPcawYcPqJTAhGsu+Uo29pTq6Jk3LI4FJ941Ou3avhT+z3JJ0i5AlZXH4K3YarM91A+DetTzA0USWtom+pHvzPhODWnkj6uG0EKL+1Snpfuedd+o7DiECZsNeXy13RpyBPTJaWB/kNUhavhI02Ne9C5iOPPdruGhflnTPy3bjNRQmXe6mROiRsjj8rdjhwlDQIk4n70BeoMMJbV4vzFvqez+g11HLu9ZxBiZNUejU2FeqkRQtTcyFEHV3TCnG4sWLWbNmDQDdunWjV69e9RKUEI1FqYNJd4cIrOU2uV0MuPcRAKZ9MxVvVGQk3S2aGhiOIoqIZdkOF30ybIEOSYg6k7I4fC3Z5mtaflxzM1LPfYwcLjj3Rt/7rX9ATNQRV7eYoFW8QVa+iU37dJKipYm5EKLu6pR05+bmMnr0aGbPnk18fDwABQUFnHbaaXzyySekpKTUZ4xCNJh9Dp18h69peVuZFiRi6Bq4tszF3mkEv29wSNItQpKUxeFv6XYnAD2bm/kgwLFEorYJB5PuE1pK0i2EqLs6TRl22223sX//flatWsW+ffvYt28fK1eupKioiNtvv72+YxSiwWzY53vu1DrOwBZpTcsjnDPrTwD+3OzA5ZFmgyL0SFkc3nL3e9le4EXXoHu6FFCBkJlgoKHYU6JT6Ah0NEKIUFanq/i0adOYOXMmXbp08S/r2rUrr776qgzeIkKIxoa9vmlDOkVg0/JI59m9kqRojb0lioVbnAxqJ1MsidAiZXF4W7rNV8vdqZmFJrY61ZFEPKfTecgPDsqv8g6nA0xa9euWibb4ZrzYVqSxYa+Jvi2ktlsIUTd1SroNw8BiqTzHocViwTAkeRGhwZLWnWK3jtWkaBMvf7cRRxkMbmfly7+dzFpXKkm3CDlSFoe3JWVThfXKsAY4ktDj9XhA0xgy5HT/MrsBc8ren376GTiqeY5heL1wyH+rDklethXprN+rS9IthKizOiXdQ4YM4Z///Ccff/wxzZs3B2DHjh3ceeednH766UfZWojgYGs/BPANoGaWSoSINLi9L+leuMVJkcMg1i5/CCJ0SFkcvgylWFqWdPfOsAHyEKU2DMMLSnH3M28RFR0NgMnhgAuvAeD+F97Ba6/4oLW0eD/P3jcOQ1XsbtQu0eDXLEVeiU5+qUZClHRHEkLUXp3uMF955RWKiopo06YN7dq1o127dmRmZlJUVMTLL79c3zEKUe+cHoU1cyAAnVPkyXWkapNoom2SGY8Bf2yUDnsitEhZHL6y8jwUlhrYzRqdUyu3ZhA1Y7FasVjKXuaDLQYs5kOWl73M1qpbFERZICPOl2iXz3YihBC1Vaea7oyMDJYsWcLMmTNZu3YtAF26dGHo0KH1GpwQDWXBFje6JZqmVoP0JipiKxEMk5nV112FBhjmyJgu7HBDOkWxee5+Zq0vZWT36ECHI0SNSVkcvsqblh/XworFpOF1BzigMGCYTay57ir/+9romORla6HOhr0yirkQom5q9cjul19+oWvXrhQVFaFpGmeccQa33XYbt912G/369aNbt2788ccfDRWrEPXm142+G5qOSW407SgrhzFlMbP54vPYfMl5qCr6hkaC0zrY0YBVu9zsKvQEOhwhjkrK4vBXPoia9OeuP8piYfMldSvv2iYa6Jpib6nO3pIIvmkQQtRZrZLuKVOmcP311xMbG1vps7i4OG644Qaef/75egtOiIaw74CXZTt8yVXHRKk+iHTJTUz0bOm7sf1lvTQxF8FPyuLw5vIoVu4q68/dUpLuYGA3Q6s4X5M4aWIuhKiLWl05li9fzogRI6r9fNiwYSxevPiYgxKiIf26wYGhwJ27lnh7hA+I4jWIW7eRuHUbwRu5TeZO7xQFwC/rS1Eqwv8mRNCTsji8rc5x4fRAYrRO60SZn7veeL3HVN51SDqYdEsxIYSorVol3bt3765yepJyZrOZPXv2HHNQQjSkWetKAXBu/CXAkQSeye3i5NvvY9Bt92FyRW6t/8C2Nmxm2F7gZX2uNDEXwU3K4vC2ZFvZVGEtrWiR3P+pnplcbgbdVvfyrm2CgUlT5DukibkQovZqlXS3aNGClStXVvv5ihUrSE9PP+aghGgoWXvdbMrzYNbBmSV9HoVPtFVnQKZv+piZZQ9lhAhWUhaHt6Xby/tz2wIciTiUzQyt43213eulibkQopZqddU466yzePjhh3E4Kvd7LC0t5ZFHHmHUqFH1FpwQ9W3aal9C1TfDgnLuD3A0Ipic0flgE3OXR9oOiuAlZXH4KnIYbChrbdNL+nMHnY5J5Um3SZqYCyFqpVadhR566CG+/PJLOnbsyK233kqnTp0AWLt2La+++iper5d//etfDRKoEMfK5VH+puXDOln5PsDxiODSq6WVlCY6e4oN5mx2cFrHqECHJESVpCwOX8u3u1BAqwQzyU0icxrHYJaZYGDRFUVOjZxijWR7oCMSQoSKWiXdqampzJ07l5tuuokHHnjAP+CQpmkMHz6cV199ldTU1AYJVIhj9edmB/udimZNdHq2kMFpREUmXWNY5yim/nWAaWtKJekWQUvK4tDn9njweiqPH7FoSwkAx6XrFVoyOJ3ORotNVM9i8k0fti7PxLo8E8ktAx2RECJU1DrzaN26NT/++CP5+fls3LgRpRQdOnQgISGhIeITot78VNa0fHiXaEy6DIIiKhvWJYqP/jrAsu0ucoo8pMXKwxkRnKQsDl1uj4dRI0eRl5dX6bOEi97EFJvO1Bf/xbt3L6r0ueH1Qu2mmBb1rHOyl3V5Jtbv1TmxRaCjEUKEijrfUSYkJNCvX7/6jEWIBrOjwMOKHS50zZdYQeSO1C2qlxZrpmdLK0u3u5i+ppQx/ZsGOiQhjkjK4tDj9XjIy8vj/hfexWI9OFhakVNj6som6CjuuucurIe0Li8t3s+z943DkI7EAZcRp4iyKErdGtuLpAuAEKJmpBpHRITyWu6+rWw0a2rC4ZCkG8AwmVl/5SW+92a5eQAY0TWKpdtd/Ly2lCv7NZFWEUKIBmGx2rBYDg6Wtmufb2zbtKaKGHvFQdTcVhlU7VgZZlO9lHe6Bp2SvCzLMbN+rzQ7EELUjCTdIuy5vYoZa31J95ldpZ/uoZTFzPqrLkWmgj3opLZ2mtqKyCs2WLLNRb/WMm2PEKLhbS30Jd0ZcUaAIwlPymJhw9WX1su+OiUbLMuB7AIzmlnuK4QQRycTDYqwNz/bSUGpQWK0zgmSQImjsJo0Tu/ku4mavqYkwNEIISKBoWB7ke+WrJUk3UGvWYwi3m7gURrWNgMCHY4QIgRI0i3C3k+rfYnTsC5RmE1SpVuBYdAkeytNsreCITd65YZ38SXd87J8D2yEEKIh7Tmg4fBoWEyKZjHSb7tB1GN5p2nQOdm3D1u7U+shOCFEuAuapPupp55C0zTuuOMO/zKHw8Ett9xCUlISTZo04cILL2T37t2BC1KEnJwiD0u2ugAY0UWagB3O5HJx6g13MnjcnZicrkCHEzTaJlvo2MyMx4CZZV0ThBCiofiblscamILmziy8mJwuBo+rv/KuU7IXAEv68ewrkYezQogjC4pL+6JFi/jPf/7DcccdV2H5nXfeyXfffcfnn3/Ob7/9xs6dO7ngggsCFKUIRd/9XYIC+mRYSY+TIQxEzZ3ZNRqAH1eVyIjBQogGtaXAdzvWOl6St1ARZ4fUGC+abuKPTfLQWghxZAFPuouLi7niiit48803K8wvWlhYyFtvvcXzzz/PkCFD6NOnD++88w5z585l/vz5AYxYhAqHWzFtja+W8pzjogMcjQg1QzraibZq7Cj0snS73FAJIRqG0wO79vu6Pkl/7tDSMdE3E8qvG6WMEEIcWcCr/m655RZGjhzJ0KFDmThxon/54sWLcbvdDB061L+sc+fOtGrVinnz5nHiiSdWuT+n04nT6fT/XFRUBIBhGBg17MNjGAZKqRqvHy7q5bgNA5Q6+AqgWetLKHYq0mJN9MmwVqitNJRC03U4NNQahHvoNjVV220a4zv82xxCcfTtw+H4y3/Xmq5T6nAcsRb71HYWflzj4pvl++mSbGAym7GYA37ZPPhHaxg17pso17XgOe5gikUE3vYiHYVGvN0gzh7oaERttE9083u2iax9FjbucdM2OQjKByFEUAro1eGTTz5hyZIlLFq0qNJnOTk5WK1W4uPjKyxPTU0lJyen2n1OmjSJCRMmVFq+Z88eHA5HjeIyDIPCwkKUUuh6wBsDNJp6OW6vEwoNMLkC2o5CKcWXSw8AcFpbC3sLnBU+d7lddOjSB5QOBr6M0zhy3q1hpkOXPmiYUN6axVHbbRrjO8q3ad+5NxoH5ypVXo64fTgdv2FA+y59uPn2B464nicqBY67mQXZLq65dTJxURrjxz+M2RTgOc0NF3gNYC+Yimu2iVzXgua49+/fH+gQRBCRpuWhy24G15Z52NqewvQ1pdx0ctNAhySECFIBS7q3bdvGP//5T2bMmIHdXn+Pdh944AHuuusu/89FRUVkZGSQkpJCbGxsjfZhGAaappGSkhI0N2mNoV6O21MC6GCxgilwj+xX7HCxvdDAZoYL+jSlia3i8TgcsGHNYtAM38MBBegccb5qhYcNaxaj8KLVMOeq7TaN8R3l22xcuwTFwSxVM3HE7cPl+JUCQ7nZuGYxd036D1FRR+568M16DzuLzWSOuJGZk0eT2PTRer1m1YkXcDshJQnMNes6Ide14DnugP/9iKCh1MGku1WcjB0RihzrZ2Brewq/rC/lHwOaBDocIUSQCljSvXjxYnJzc+ndu7d/mdfr5ffff+eVV15h+vTpuFwuCgoKKtR27969m7S0tGr3a7PZsNkqz8Ws63qtbrg0Tav1NuHgmI9bL8tcy18B8t1K3zRhp3eKItZeORPTNQ1lGFAeZg1DrrBNDdV2m8b4Dv82h9CIvOO3WK1YrNYjrndcmmLnRliXb0cpDV3zvQKq/I9V132vGm8m17VgECxxiMDLd2jsd2nomqJlrNR0hyL3ruUkxWjsPaCYn+2kc2KgIxJCBKOAlfynn346f//9N8uWLfO/+vbtyxVXXOF/b7FYmDVrln+bdevWsXXrVgYMGBCosEUIyN3vZe5mX3Pyc3vIAGpHYpjMbLroHDZddA6GOcBNpoNUu0SDaIuixK1jbdU/0OEIERRkms/6sbWslrtFU4VFLsENyjCbGqa8Uwand/A9vP15jUwxKYSoWsBqups2bUr37t0rLIuJiSEpKcm//B//+Ad33XUXiYmJxMbGcttttzFgwIBqB1ETAuD7lSUYCo5vYaVNkiXQ4QQ1ZTGz5voxgWyUEPRMOnRN8fLXTjP2LmcFOhwhAu5I03z+8MMPfP7558TFxXHrrbdywQUXMGfOnABFGvy2FPouvtKfu+Epi4W148Y0yL6HdLDy2TInS7a52HvARjOp7RZCHCao27i98MILjBo1igsvvJBTTjmFtLQ0vvzyy0CHJYKY06OYttrXtPxcmSZM1JPuqV5AYW3ek+0FNRytTYgwJNN81h+PATuKyvpzS9Id0tJjTRzX3IIC5mTL9GFCiMqCam6D2bNnV/jZbrfz6quv8uqrrwYmIBFyZq4tpdChSG1q4sQ2lfv2i8MYBlE5uWgalDZLrlX/4EgSa4PWcV62FJr5cY2T29NiAh2SEAFRn9N81scUn8HCPzVdhXkoq1m3bMrKXftNeAyNGIsi0a7qfcrGRp1+MhSm3zQMonLzgOrLu1rHVTb9pKEUQztHsWKnmz+yXFwz0Ijo8tRQyvf/IcBTxwZSo56DOkwj2hiCccrO2qrP2IMq6RbiWBhK8eVy3zRh5x8fjUmXNtNHY3K5OH3MTQBM+2Yq3igZVbk6xzVzsaXQzKwNLv5xkkGMLXJvqERkqu9pPutjis9g4ZuargiFQjcfecrM8ikrtxX6uj+1ijXqfcrKxpx+snybYJ9+0+Q4WN79+OVUvIfNIlCXuFA6Hbr0Ia/QRedEC3Yz5BYr/lx3gC6pkdu9zVCKwmK3b2KYCO2/1qjnoA7TiDaGYJyys7bqc4pPSbpF2FiQ7WR7gZcmNo3hXaICHY4IMy2aevHkb8GR0Jof/i7inO5Hf0BhMpuxmOUyK0JfQ0zzWR9TfAYLwzDQDBcpaOjWI0+ZWT5lpRpcNj93gnHU6Q6DcfrFw7cJ9uk3D92uqiky6xIXhsGGNYtJjrNit9sZ3MHF9DUOFuzwMrhL5M7ZbSiFBqQk2iM66W60c1CHaUQbQzBO2Vlb9TnFp9wNirDxv6W+Wu6zukUTbQ3N/9wieBleD44139PkpFt4Y0YWT994A6gjNztKTk7m+x++l8RbhLyGmOazvqb4DBaapqFTNqXgEW6ydU1Di0ok32FCQ9Eq3qjRYJbBPP1iKEy/eehm1U2RWeu4NN825VNJntk1mulrHPy5ycnNJyti7aH3d1xfNC1IptgMoEY7B3WcRrQxBNuUnbVVn3HLnaAIC2t3u1i5y41Zl2nCRMMwDC+Ojb+QOOgmXLHpXDXxE9rEV98G0e1y8tSdY/F6PJJ0i5BXPs3noa655ho6d+7MfffdR0ZGhn+azwsvvBCQaT6PxNqyHwBpTRR2uTyEjY7NzLRO0NmSbzB9TSkX95LxP4QQPnKpF2Hhi2W+EctP7WAnuYlMdioaiMdJ5yQXK/bYWZlnp0OKO9ARCdEoZJrP+mXN8CXdbRJCd4AhUZmmaQxpb+OdRaX8uKqEC3tGR3RNrxDioNCs6xfiEDlFHv7c5Bt058Ke8lRZNKyuyU40FNsKdfaWyM2UEOVkms+acXoUlua+Oc7byFRhYWdAawvRVo2dhV6Wbpfpw4QQPlLTLULeV8tLMBT0zrDSNjlyRwsVjaOp1aBtosGmfSaW55gY0tYT6JCECAiZ5rNuVu7yoJntxFgMkqMjd0qlcGUza5zeyc53f5fyw8oS+mTI9KVCCEm6RYgrchhMW10KSC13XSiTieyzR/jfi5o5Ps3Lpn0m1ubpnNQK6ZMphKixv7b5uqW0jvPUaiAxcWwas7wb2S2a7/4uZV6Wk7xir3R7E0JI0i1C2zcrDuDwKNonm+mTYQ10OCHHsFhYeev1cuNXSy2aKpKjDfJKdP7ebaJfi5pO6iqEiGRKKf7a5msd0zrOA0gy1lgMq4VVt13fKN/VOtFM93QLK3e5mbamlCv7NWmU7xVCBC/p0y1CVqnL4OsVvgHULukdgyaZo2gkmga90n2J9vIcEx7plimEqIGt+V5yiw2Ux0WLpvKwLpyN7O6bSeWnVSV4DelGIESkk6RbhKwfV5dS7FS0iDMxqF39TV4fUZTCWlCItaAQlNwU1EbHJIMYq6LErbE+Ty6lQoijW5jtBMCdswKLVHI3rkYu7wa1sxNn18g7YDC/7PcuhIhccqcoQpLLq/hi2QHAV8tt0qWWuy5MTifDLr2WMy65FpNDbgpqw6RDzzRfTdXSXSZ5ZiGEOKqFW3wzbbi2/RXgSCKPyeHkjEsar7yzmjRGdPXVdn+9/ECDf58QIrhJ0i1C0sy1pew9YJAco3N6p6hAhyMiVPdmXiy6Ym+pztZCefAjhKjefofByl2+QdRc2xYFOBrRGM7uEY1JhxU73Wzc4w50OEKIAJKkW4Qcr6H4bInvqfGFvWKwmCTZEYFhM0O3Zr7a7iW7ZFxKIUT1Fm9zYihoGa9jFO8OdDiiEaQ0MXFyWfe3r6S2W4iIJkm3CDl/bHKwq8hLrF3jrK5Syy0Cq2eaFw3FtkKdPQfkAZAQomoLt/iaNPfLsAQ4EtGYzj/e18R89gYH+w7I4HlCRCpJukVIUUrxyWLf0+Jzj4vBbpE/YRFYsXZon+QbvnzpLhkZSQhRmddQ/FWWdPeVpDuidE610jXNgseA71aWBDocIUSASMYiQsrCLU6y9nqIsmic0yM60OEIAUDvsunD1u/V2S/j0QkhDrM6x02hQ9HEptElVR7ORZrzj48B4IeVJbg8MuqmEJFIkm4RUj4t68s9slsUsfaDf75ujweHw1Hjl9MpmZGoP6lNFC1iDQylSW23EKKSuZt9o5af2MYms21EoIFtbTRrolPoUPyyvjTQ4QghAkBG/hEh4++dLlbtcmPR4YKeMf7lbo+HUSNHkZeXV+t9Gl5vRP8vUCYT28441f9e1F2/5h52FFlZmWuibwsv0oBUCAG+blHzsnwPek9qaw9wNJErkOWdSdc457gY/jt3P18tL2F4lyg0TR6+CBFJIjjdEKHmk8XFAJzRJYqkmIMFptfjIS8vj/tfeBeL1VajfZUW7+fZ+8ZhRPjkyobFwvK7b0PK/mOXEadoFmOQe0BneY6JvmmBjkgIEQyy93nYVeTFaoI+GVbwugIdUkQyrBZW3HNbwL7/zK5RfLiwmOx9HhZvc9G3Vc3uV4QQ4UGal4ugdHhz8dXbi/lrqwtdg3O6mqtsKm6x2rBYrDV6ma3WAB+hCDeaBn2b+/p2r8gx4ZJBaoUQwNzNvjKqd4ZNBv+MYE1sOmd288248mlZJYIQInJITbcIOlU1F2966r3Y2p5CycbZXHTms1VuZ3i9SJveWlIKk8OBBnjtNqTK+9i0SzRIsBvkO3RW7ZEHO0IImJvl6899Ulup2QwopTA5fA9AAlXeXdgzhu/+LmHFTjerdrnoli7lhBCRQpJuEXQOby5e4ND4eJWvD/fVZ/cj6ZKPK6wvTcXrzuR0cuboawGY9s1UvFHS3/BYaBr0ae5l5mad5bstYJKnQEJEstz9Xjbu8aBr0L+NXF8DyeRwMuLcK4DAlXcpTUwM7RzFtNWlfLL4AI+PkqRbiEghSbcIWuXNxZdvNQMabeK9pMVW/pN1S1NxEUQ6JRss2K7Y79Kxdxga6HCEEAE0r6yWu2uahfgoaVoersq7uRlK4XK7cDhAr6Ym/dyuZn5e45sCddMeN+1S5OGsEJFAkm4R1PY7YW2e70alXwvpJCuCn0mH3s09/JZtIarHRbi9CqnfEiIylffnllHLw5PX4wFNY8iQ0wHQdJ0OXfqwYc1ilGFUu13ysIeg5Yl8uuQADw6Pb6RohRCBJEm3CGpLd5kwlEaLpgbpTaX5uAgNXVMMFm03KGmayi8bXJzbMyrQIQkhGtl+h8GKnb6RygdkSn/ucGQYXlCKu595i6joaFCA0kEzoJou426Xk2cee5SElify+0YHV/f30DJebseFCHfS1kkErVKPxspc39RgfVt4AhyNEDVnMUGvNN/N9ufLHLi88sBIiEizcIsTQ0FmkpnmcZJUhTOLtWxmFIsVk8mM+UgzqFhtePOz6ZdhRgGfLzkQ6PCFEI1Akm4RtP7OteAxNFJiDFrFSdIiQkvXFDfeA3vZc0AxfU1poMMRQjSyOZt9/bmllltU5aLjfV0OZq4rJadIKhaECHeSdIugpFmi+TvXN0Ba3+ZemclKhByzDqUrPgPgk7+KcXnkwZEQkaLUZfDXVl9/7oHSn1tUoXOqmZ4trXgMmLpIaruFCHeSdIugZO8yEpdXIyHKoH1i9YORiGOjdJ2dJw9g18kDUCa5HNQ3x7rpJMVo5B0w+Gl1SaDDEUI0kgVbnDg90DzORLtkaVoeDJRJZ1eQlXfX9G8C+Gq7t+VLbbcQ4UxKAhF0HG5FVPfzAN+I5VLL3XAMq5UlD90t57ihGB4uPt7O63N9c7KO6BqNzSwnW4hw9/tGX9PyU9rb0eQCGxQMq5UlD98d6DAq6Jxm5cQ2NuZnO3l/YTH/kpHMhQhbwfGoT4hDTF/rRLfHEWcz6JgktdwitA3taKVZE519JQY/rJLabiHCXYlLsWiLr2n5Ke2labk4sqvLart/3+hg0x53gKMRQjQUSbpFUHF5FF/97btZ6ZXmRJcKAhHiLCaNy/v5bqo++auYAy55kCREOFuwxY3LCy3jTbRNkgaF4sjaJVsYXPZw5r2FxQGORgjRUCTpFg3O7fHgcDhq9Pp+RRH5pQpvcS4dE6V/U0MzORyMGn4hI4ddiKnUEehwwtYZnaJoGW+i0KH4TKaHESKs/b7JV1spTcuDi6nUwchhwVneXXVCE3QNFmQ7WZPjCnQ4QogGII9gRYNyezyMGjmKvLy8o6+sm0m46A1MTZpRuuJ/aIMub/gAxf+zd9/hURT/A8ffezU9IT300DsoNYiCgCCgiGBHBUFRKYKICnYUpdgLYvkpoKAoXwELTUA6CEjvvUMCAdJIuzK/P2JOjrRLvZTP63nugezO7n5mb29nZ3dmVpQAg15jcJQv4xfHMW/HVe5o4kWIj97dYQkhitjVdMWW0/9VuoVwRbVKBrrW9+TPAylM/zuJyXdVkhs2QpQzUukWxcpmtRIbG8vYD2dgNOX+rtL9sUZWnfTAU28j9vAy7OrBEopSiOIXFWmmcYSRvectfLcpiee6+Ls7JCFEEdt0Giw2qFZJT81AucQSrnu4tQ8rD6Ww82w6f59IIypSbtoIUZ5I83JRIowmM0ajKceP3mBie3RGpbxZSArYZDARUb5omsaQ9r4ALDuQwvFLcowLUd6sPa4AuKW2NC0X+RPmp+fuFt4AfLU+kXSbcnNEQoiiJJVuUSocuqQjPk3Dw6BoEFS6+loJUVQahJu4ubYHCvi/DYnuDkcIUYSS0238cybj/9K0XBTEgy29qeSp41y8jd92ydsuhChPpNIt3E4p2HI2o3/rDRE2jHJUinJsUJQPBh38cyqdbafT3B2OEKKIbD+VgNUO1SvpqBlkdHc4ogzyMul4rF3G2y5m/5NEXLLNzREJIYqKVG+E2x29rONKig6TXtEsTAoYUb5V9jdwRxMvAL5cl4hVmhAKUS78fSwegFtqSYVbFNxtDT2pE2IgOV0xc5O8QkyI8kIq3cKtlILN/z7lbhFuwyzjzpQopdMR0+ZGLrS5EaWX00FJ6d/aBz8PjROXrfy2R5oQClHWXU5KY/fZjApS57omN0cjsqP0Oi6UgfJOp2k81cEPgCX7UzgaK+N/CFEeSBVHuNWJOB2xyTqMOkXzcHnKXdLsJhNb3noZGe+nZPl56HisnS8fr0rg+81JdKrjQaC3vEJMiLJq9d5zKAUNQqBKgPyWSyO7ycSWCS+7OwyXNK2cMf7H2qOpTFubwJQ+geikoBaiTCu9t/pEuXftU+5mYTY8pUWeqEBub+RJvVAjyemKb//+b1A1i9VKampq3p+0NFJSUkhJScFikSchQrjTit3nAOhSRypGomg80d4Xs0Fj9zkLS/aluDscIUQhyZNu4TanEzRiknToNcUNEfKUW1QsOk1j2C2+jPzfZZYdSKVHo3Tqhei4o9cdxMbG5rqshxF8PGDtQUhJh/CICE6dPInRKHeuhChpJy4kcjQmAb1O45ZId0cjyoswPz0D2/rw5fpE/m9DIm1rmgmSFlFClFlS6RZus+VMxuHXJMyGl3SBcwt9aiq33/8YAMt//habp7zmpiQ1CDNxe0NPluxP4fM1CUy505vY2FjGfjgDo8mc43J6lYbRfpUHTS1JSdcY2rstVqtVKt1CuMHyXRnvCWte1Qc/j6tujkbkRJ+SStf7BgGlo7xLS8v77RXd6+n466Cew7E2pq5J4LUelUogMpEfFqsVm9WaZbpdKdIt6aSm4tQ1QG8wYDRI9asikm9duMXZBI2ziTp0muJGecrtVgYXCn5RfB6L8mXdsVSOxFpZciAdAKPJjNGY850onVIYlAWTyQOb9PMTwm1sdsVfe84CcFOdSoBUukuz0lDe2axW0DQ6d+7iUnp9YCSVen/I+mOw7mgqHWrLzfHSwmK15tg6TdPpqNuwJYf3b0XZ7Y7pwcHB/LHwD6l4V0DyjQu32HI249BrFGLHN+cHekKUewGeOga29eWzNQl8908KOu9gd4ckhHDRzhOXuJSYho+HkebVfNwdjigD7HYbKMWYd7/B08srz/SW9DQ+mfULXs3vZ+qaBFpUNeFjliGZSgOb1Zpz6zQFKB1odvj33rglPY1Jzw7EZrVKpbsCkm9clLjoRI1T8To0FC0rZ22SI0RF06uJJysOpbA/2oJ31NMoeXW3EGVCZtPym+qHYLdZSLWmo7OnQi5db11pVizKP6PJlGuLpmsl75hDnVse5Fy8nS/WJTKmi38xR1cx5dRUPCeZv+XsWqcpBcoGmh55Q4wApNIt3ODvf/tyNwix4y+tpIRAp2mM6uTHsJ8vQfW2HItLoUGou6MSQuQmNd3K+gPRAEwY0Z95VXzwSd5KYrKdVBdeKGC32UCGYRCusFkY0cGLlxYmsexACq2qm+hU19PdUZUruTUVz4v8loUrpNItStT5f59y6zRFmyrylFuITDWDjPRtZubnHWmsPWWmZqAFDzlDC1FqrTsQTarFxtVL55jwybf4G9MItO7FqvfGpuXcbyolKZH3XhyCXZq0iHxoFG7gwVbe/PDPVT5emUD9UCMR/lJI5KQgT61dGcj0WvJbFvkhv1ZRojKfcjeUp9xCZHFvcw9+WHWElIBqrD9loEstuTElRGm1ePtpAM7tWIG5RxsMmsKgM4HOhE7LudmwxSSv6xAF83BrH3aeTWfveQsT/4zng76BGPTSdvl6hXlqrdcbXG72L79lkR9urXRPnDiRefPmceDAATw9PWnfvj2TJ0+mfv36jjSpqak899xzzJkzh7S0NLp3787nn39OWFiYGyMXBXE2QeP0v0+5W0tf7lJBaTouNWuc8X+dFNzuZjJoJK3/jIBek9l7QU/9YBtV/eQOuhClzamLiew5dRmdpnFu23JgnLtDEnlQOq3Ml3d6ncaLXQMY+nMsBy9YmLk5icFRvu4Oq9TJdYCzHMhTa1Hc3Dr84erVqxk2bBh///03y5Ytw2Kx0K1bN65e/e+VG88++yy///47c+fOZfXq1Zw7d46+ffu6MWpRUJvO/DdiuZ885S4V7GYTG999k7/fexO7WYaRLw2sMXtpFJzx6rC/jhmw2vNYQAhR4jKfcreqHURa4iU3RyNcYTeb+fu9sl/ehfnpGXVrxkBqP2+7yj+nZGC+nGQOcObKxyBPrUUxc+uT7iVLljj9PWPGDEJDQ9m6dSu33HIL8fHxfPPNN/zwww907twZgOnTp9OwYUP+/vtv2rVr546wRQGcTdRzJuHfp9zSl1uIXLWrksbJeCNxqTq2nNUTVU3eZS9EaZFutbHs31HLuzWrzAQ3xyMqnptre9CzsSeL9qYw8c84PrkniCoB0mO0OCgFielwKVnHlRSNpHRIsWhY7WC1+eLTcQzrz3hSyVtPgIcizMeOj9TfRTZK1S80Pj4egMDAQAC2bt2KxWKha9eujjQNGjSgevXqbNy4USrdZciWcxlnoCah8l5uIfJiNkDHmlYWHTay9ZyeukF2gr2kyZsQpcG6/dEkplgI9ffkhppB7g5HVFBPd/DjWKyVAzEW3lgUx8f3BOJlkvd3F4UUC5yI03H8io5ziTqSLTl1R9DjUbsT+y4B1zR48TMravjbqRVgo2qAQrrdCyhFlW673c6oUaO46aabaNKkCQDR0dGYTCYCAgKc0oaFhREdHZ3tetLS0pzegZmQkOBYv93uWjtNu92OUsrl9OVFkeTbbv/35YQZH7tSGKu04HySAb2W8V5uV7rLaDod/LsaV+Q3/fXLKAUUQ1wFWaYktpG5jD41ldsGPAXAX99Nw+aRe7v/8pD/zDTFnheVkd7+7+/AFXalHNuoVclOZCUbx6/oWXHUwD2NLWR2Q/zvmFWgQKfT5XmOk/Na6cl3aYrFVTIGy38WbjsFwO0tqqEvo32DKyJ9Siq3Pvo0ACu/m4bNs2z3czMZNF7rEcCIuZc4dcXKhKVxvNmzkgysVkApVg2PRr357bAvMcl64L/9qNMUgZ4ZH1+TwtMIRr3Ckp7Kknlz6HDnwyTbTFxO0biUrJGQprH7gp7dF/T4mBSNQ200DbM53ip2bT3FFXqDAaOh1FTZRAGVmm9w2LBh7Nmzh3Xr1hVqPRMnTmT8+PFZpl+8eJHU1FSX1mG324mPj0cphU5Xce4aFkm+bWkQbwd9OuggLT2NoPZDsAKNQ2x460Hl0VJWw0Ddhi3R0OeZtiDpr18GOxkVbnvu9e7Cbqck8pKfZeo0uBENPeb4jBtTypb7d1O+8q935L/YtqN01G3Yktj4dEzJrm0j3ZJO3YYtQenADh2rWTmboCPmqo5d53U0D8uorCn02JQJvTUFk12jZcuWxMbGYs6ln6Kc10pPvhMTE90dQr5ljsHSunVrrFYrL730Et26dWPfvn14e3sDGWOwLFy4kLlz5+Lv78/w4cPp27cv69evd3P0Ree/AdSge4tquHS3VpQameVdeRHkreeNnpUYM/8yW0+l88nqBJ691Q9Nk4q3K+wKTsbp2HdRx/Ergfi0G0LMv+V1sJedyEp2avjbCfVRGLIpPpKvprFg76+0HnIPnp4ZCdJtcDZBx7HLOo5e0ZGUrrHpjIGt5/Q0CFRongF07twlX3EGBwfzx8I/pOJdxpWKb2/48OH88ccfrFmzhqpVqzqmh4eHk56eTlxcnNPT7piYGMLDw7Nd17hx4xg9erTj74SEBKpVq0ZISAh+fn4uxWO329E0jZCQkFJzkVYSiiTf1mRAB0YT6D3YeMSC1bc6ek3RqooNTZ/3KhRWDu/fiqJ40l+/DDoyrpt0kFs5VdjtlERe8rPMkQPbMvL/L01PrsuXl/xnPBy2OfJfbPvZbufw/q0E+5vwyKMFQabUVDi8fytodjQ9+HpC+2pWVp0w8vdZA7WD0vE1g6Zs6FU6NoMn6Upj69atBAcH4+npmUs4cl4rLfl29XgoTWQMlgyZA6i1qRtGsJ8HKSkpbo5IVHT1Qo281N2f8YviWLo/BT8PHYOjfKTinYs0K+y7qGdntJ6EtP/2kyX2MLc0q0KDMH2Bu0Ka9BBZyU7NADu3WOBYvI4d0XpirurYE+tBpX5f0bqKjZZVQe9CkWRJT2PSswOxWa1S6S7j3PrtKaUYMWIE8+fPZ9WqVURGRjrNb9myJUajkRUrVtCvXz8ADh48yKlTp4iKisp2nWazOdunPTqdLl8XXJqm5XuZ8qDQ+db9W3PVNBTw4/aMJjSNQyz45OMEpux20HKvBBcmfZZlNEfYxbudYkhfqGWuoVEB81+cy2gZ6XWahs7Fjeg0Lcs2mobZOXjJzvlEHatOGLizvjXjWAXHQWu321363cp5rXTku7TEURhFMQZLUXQHK0nXDqDW44aqjjh1Op2jj5Kjd1Ue6yoPXXWyW6Y0d9W6drHM3jlFHZer+6Couyq1qWFmREdfPl6VyNztVzHp4eE2Pq5noojZlcro1pNDvBarFZvV9UF189u8+tquWteGEJ8KO2P07Lugx2LPKGQ9DIoGwTYifRL5vxnP0aTzTDxMXoX+nSkFOg3qBtmpG2TndLzG+lMasXix9SIcT7Jza6SVyr55bMiVrmqZB57dnvEpJUpj9678KsrY3VrpHjZsGD/88AO//vorvr6+jn7a/v7+eHp64u/vz+DBgxk9ejSBgYH4+fkxYsQIoqKiys1d8/Js/bE0Dl+0oSyp3BBuBUdvFiGEqzQNutSy8sMuIyfi9By+ZKeBjN0k3KioxmApiu5gJWndoUskplgI9DZS3Udx4cIF0tLSaNmyJSZ7CjotHZvdhEJfoboqlZWuWtcul113qiKLK499UFxdlW4M1/HQDR78sD2V2f9cJTHZSt+mZrc88bYrRXySJaMR4XXbt9psvPnmWyQmuN7U39fPj9deexWD3rWmadd21bJbITpJY3uMnmNxOjL7agd62GkeZqN+kB2DDtLStKI/Lv89FgCq+Sr61E7mx19XYq9/F5dTdPyyz0irCBttKtvIcXgIV75/ezrY7MAl0Ce5FnwJKI3du/KrKLuDubXSPW3aNAA6derkNH369OkMHDgQgA8//BCdTke/fv2cBmYRpZvVppj+d8YPP2XPfLza3eHmiIQouwI9Fa2r2Nh0xsDqEwZq+GkYpZWZcJOiGoOlKLqDlRSlFCt+OwRA79aRhIdnDA6XkpLC1q1bSdd5YtIUetJROiOalvMPtLx01bl+mdLeVeva5bLrTlUUcTmecueyD4qzq9IjUR54eBj4dmMSv+1LQzPoGXKTj8utrYqKXSk0ICTQI8u2U1NT2bZpJS++/y1GY95NIC2WNCY/N4hA3zfy11XrwHaOxunYecFIzNX/KnzV/e20CLdS3V85fUdFfVxmeyxoVk6tnc6oO2/lnwu+7I/V8895A2cTdXSvY8m+Sbsr378NsKRBSBAYvFwLvgSUxu5d+VWU3cHc3rw8Lx4eHkydOpWpU6eWQESiqCw9mM6ZOBv+HhqX9swDpNItKqb8jFKaW9pWlW0cvqTjcoqOtafM9KpVeu5mi4qjKMdgKaruYCVh54lLHItJxGzQ0atVDUd8mW8OyOzqkdlNqcJ21SnF+b92sZy6UxVJXC7sg+LsqnT/jT54GjWmrknk113JXL5q4/muAZgNJVvx1v6N9/qYM7tRGU1mjEYXXmidz/ynWuws3p9OwN3T+PO457/bVDQMsdMi3EZQLq/fLPLjMptjQdnteBgVt9WxUiPAzl/HDZxP0vHjbhNda1upHWjPso4885+5EZ0u41OKlLbuXflVlHHLsxJR5FItiln/ZDQNvK+FBxMtMtBMaaU0HXH1amf8X159U6RsVitoWr5HKQWw22xZemPodRnNzOfuNbIv1kTjIBNeIUUUrBB5KI4xWMqSeZuOA9C1eVX8PF2oKIhSR+m0ClPe9W7qjY9Jx/t/xbP2aBoxiZd59fYAQn1dfIRbBl2+auO33cn8vieZpDSF3i8Cs17RPNxGszAbXqXwZ1sv2E6YTzpLDmc8jV94yEi7qlZaV7Hlq+IvygapdIsiN2+P4nKyIsJPT/cGJia6OyCRI7vZxLpPp8jJvRjY7TZQijHvfoOnl2vNvVKSEnnvxSE5DpYS4atoFmZnV4yeP0/4c0egwvn5jRDFoyKPwXL20lU2HYoB4O42kXmkFqWV3Wxm/WdT3B1Gielc35MQXz3jF13h0AULw36O5YWuAbSuUcBhuUshpRQ7z6azaG8K64+lYv33IXG4r44jSz/j8aGP4OVRCmvb1/D3gHsaW1h/Ss+OaAN/nzFwJVWjSy1rtq8pE2WXVLpFkYpLTmfu7owKw8B2Phj1UiEQFZvRZHKtCR1gMeWdLqqalWOXNeLTDOw5k0D9ygGFjFCIvFXkMVjmbz6OAtrUDaVasPtGhBYVW366KkHGiN9NK5v49N4gJiyN48hFK6/8cYU7m3gxOMoHT1PWGl1+RxXP3E5Jv8oqIdXO8gMpLNybzJm4/0Ywaxhu5J4W3twQobjl40UY9Y+UaFwFpdfBLTVtBHoqVp0wcDA241VmvepZZAjickQq3aJI/bDuBMkWqBui55Y6HqTns5AQQuTObICONVJZeMSL3WcSqRzo7e6QRAVQUcdgSUyx8OfOjNeE9W0rT7lFyStoV6Xg4GD+WPgHEf4GPuwbxFcbEvn93+bXm0+m8VQHX6Ii/xvd3GK1ckevO4iNjS3Qdoq74m21KzadSGXloVTWHUvF8m9d29OocWs9D3o19qJOSEYVtTS+/cAVTcLs+HtYWHTIyPlEHT/vMXFnXYu7wxJFRCrdosicvJjI79vOATC4bdYRK0Xpo09Lo/OTIwFY/fXH2D3KT7Oz8qxOoJWa/qmciPdg24k4d4cjRLm1ePsp0iw2IkN9aVFT3tVXlulS0+j4RNkr7wrSVcmSnsakZwdis1oxGgyYDBrDb/GjfaSZD/+KJybRxvjFcbSoamJgWx8ahpuwWa3ExsYy9sMZGE2u7Zvrt1PUbHY4k6DHO2ooA39IIDHtv5t/tYMN9Grsxa31PPDK5ql9WVXNX3FvEwu/HTCSkKYx/6AX+oAa7g5LFAGpdIsioZTi86V7sStF+xpwQ1VpEFMmKIVXzEUANBeeZInSQdOga40Evt3tQUx8KmGNb3J3SEKUO1abnV+3nADg7raRbnnfsSg6Whkv7/LTVSknN1Yz8/VDwczZepX/bb/KjjPpjDpzmZbVTNzRyAhoro8qXkyS0+FUvI7jV3ScjNeRbtPwbNiTxDRFJU8dHet60LmeJ/VCDeX2Nxnoqbi3cToLDhi5lKzDv9ckDl6w0ry6uyMThSGVblEkNhyMYcfxSxj1Ooa0cXc0QpR/lTxsNK3qy87TidTvMYSUdCuenu6OSojyY+Wec8QmpBLgbeLWJpXdHY4QRcLDqGNgO19ub+TJD/9cZdmBFLaeTmfr6XQq3fs1m8+ZaBCiEeipin2QVaUgKR2ik3ScSdBxNkHjcorzU2sPg524fSuY/EwfWkf6oC/nI89n8jZBv0YWft1vIAZfXl2cxOs9jbSsVjZaaIisyk97DOE2aRYbXy7bB8A9basR4VcxTohCuFuTqn74mA14+AXx4/rj7g5HiHLDZlf8uO4IAPe0q4XJUH5ftSQqpnA/A6M7+zP94WD6NvfCywh633C2njcze5eJmTtMLDtiYFe0jgtXNWz2vNeZm6tpdg7EpLPycDpeLR/hj8Oe/N9WE9O3m1l82MjuGL2jwh3sZadVZSv3Nk5nQLOrJK37mBZVjBWmwp3JwwB31k0m/cw20qzw+sIrbDkpYyWVVfKkWxTaL38fIyYuhWBfDx6IqgFxZ9wdkhAVgkGvcUPNANYejOWPbWfo0bImtcL83B2WEGXe6r3nOHv5Kn6eRu5oJf0pRfkV7mfgyQ5+PNDCyO2PvUzTu0ZzJiFj9OyEND37YzNuOOk0ha8JfMwKX5PC26jQMOHZ7B5+25OK0WgjzapIsypSLIoL8RaSrSlcSbZzOdlGQup/Tfq9mt/P6QQc6w30VFTxs1PFT1HF147nNT0ULRV8HDGjHhKWv0mv1xey6aSF8Yuu8EqPANrV9HB3aCKfpNItCuVCfApz/n0a8HjXBniY5GmAECUpIsCTmL3rCWt8E58u2sP7A6NkEEMhCuHap9x929XC0ySXSqL8Mxs00o+toWedp0Fn4myCjugkjegkHTFJGmk2jfg0iE+7tnwx4N1qIN9sSgXyHjE80EtHZX8dW1b+TrdutxLhpyPYS8n7qPNit/JCZy8+XJPKuqNpvLU4jlduDyAqUireZYmUJKJQvvhzH2lWO42rVaJT48pgS3F3SEJUOAcWf02NFrew78wVlu08Q/cW1dwdkhBl1rr95zkVm4SPh4HereUpt6h4jHqoWclOzUoANpSCxDRITNdITNdIStNItoDFZmfr+tV0u70nOr0es0HDbNAwGQCbjerBZoK99QR66wjz1eNl0pGamspNb0+lSf8Obh2wrawx6DTG3RbAZC2eNUdSeWtJHC93D+CmWlLxLiuk0i0KbN3+86w/EI1epzHs9ibldhTJck3TSKxeFTRQ8v2VWWkJsTzQPpIZq4/wzYoDRNUPw89TLmaEyK+09HRmrzkEwB03VkNnt5KSYs0xfUqK3GguK5SmkVijquP/wnWaBn4e4OehgP+aiVss6aye/DHPTb4XD4//Kn92pbhwOZXQQHl9bFEy6DXG3uaPToNVh1N5e2kc424L4OZId0cmXCGVblEgiSkWpi7ZC8C9UbWoHS79SMsim9nM6q8/LvYRSkXxu+PGqqzcF83Ji0nMWHmQZ3o2dXdIQpQpFouFZrfeTc3bh2JJvcqQO9owKPWqS8vabDa5oirl7B5m1nz9sbvDEKJQ9DqNF7r6o9dgxaFU3vkzjhe7eNFJGuWUelJEiAL5v+X7uZyURtUgb/rfUtfd4QhR4Rn0Oob3aMLz3/3Noq2n6N6iGvUrB7g7LCHKjHSLhcBm3QBoViuC/r9uyHOZpIQ4Rt3bEbu9kEM7CyGEi/Q6jee6+KPTwbIDqUxekYzqqHFrqLsjE7mRSrfIt+3HY1my4zQAz97RTF6lIkQp0axGEF2aVmHF7rN8tmgPHw26qcK9YkWIglp3IAa/ynUw6DSa1AjGZMy7bDOZpT+lEGlpzq+xsitFuiWd1FSyNC+/Pq1wTXb7bWh7M8puZ/mhdKastpPmcZqOTaoDYDAYMBqNWZYR7iOVbpEvqRYbHy/cDcCdrWrQpHqgmyMShaFPS6PjMy+ABus+nYLdw+zukEQhPd61ARsPxXDofDyLt5/ijpbS5kyIvKRbbcxaewyABpV9MbtQ4RZliy41jQ4jXgCkvCsqNqsVNI3Onbs4Tdd0Ouo2bMnh/VtRObQCsdtsIHXCPOW0j/+j4X/zcIx1u/PBooMMeuJpzu9cSXhEBKdOnpSKdykilW6RL/+3fD/nryQT4ufBY53ruzscUVhK4Xsq473qmlJ5JBZlQaCPBwM61WPa0n1M/+sgHRqEE+AtF5dC5Ob3f05yISGV1IRL1Auv4u5wRDHQlML3pJR3Rclut4FSjHn3Gzy9vP6boQClA80O1zW2SklK5L0Xh2CX78AlOe7ja+jsaaw5lcjuS7407fccA559g0kDO2K1WqXSXYrIm/GEyzYejOH3f04CMOqOZnib5YcsRGl0Z6sa1A7zIynVwrd/HXB3OEKUaokpFn5Ym/Fe7iMrZmHQy6WREPlhNJkwGv/7GIwm9HoDBqPzdKPRhMEkb9YoiOv3sdPHZKJ7rSTqh3sDsO1UIpVvuM3NEYvrSckiXBKbkMoHv+8EoG+7SFrVDnFzREKIa6WkpDg+6WlpPNElY4DDpTvOsP1INCkpKaSlpTnSWCwWN0csROnw47rDJKVaqBHszbkdK9wdjhBC5JumQdvaAdSr7A9Ak7tHsmzXOTdHJa4llW6RJ5tdMeXXHSSkWKgT7sdjt0qzciFKC6vVApqOoKAgvLy8HJ8b60RwZuufAAz9YC7+AQHce++9+Pn54eXlRfUaNaTiLSq86CvJ/LYlowXXgI51QMko5EKIsknTNFrXDqFOmA8AU/88wKJtp9wclcgkfbpFnuZuOMrOE5cwG/WMvfsGGa1ciFLEbrOBsvPxL+vx9vFxmpdqsbFkZzR+EbV47v9W0iTUQLrOk/T0NIb2biv9vUSFN33lQSw2Oy0ig7ihpgwMKsqX/IwULqOKlw+apnFDjQBWLJhNjai7+HjhbuxKyaCqpYBUuiswi8WC1Wp1/G232x3NT3W6jEYQ+8/GMXPVIQCGdK5LuL8MyCREaWQym7O8vshkhhtqBbPp8AV2n0mgdlAQnp4eGe3QhKjgth+PZdXec2jAE10aosnvQpQTeY94nTMZVbzs0zSNg4u/ZsTw4fy29TSfLtqD3a7o3bqmu0Or0KTSXUFZLBaq16hB9Pnzjmk6nY6WLVuydetW7HY7Hv4htH3yA8w+lTi/azV3vnaHvIKgvNE0ksMy+ucrueAsl+qE+3H8QiIX4lPYeCyBW5v6uzskIdwu3Wrj00V7ALijVQ3qRPiTkpLi5qhEcVIVqLxzZcTr68mo4uXPY53qYDIZ+d/GY0xdspdUi4372td2d1gVllS6Kyir1Ur0+fN8/tum/56OKYXJnkK6zhOrXfHXvgvEJVsI8DLSd9BD2B+9R5qkljM2s5m/vvtCHnyWY5qm0a5eKAu3nuJcfDrHYhKpFigtVkTF9tP6o5y9fJVAH7OMU1JB2D3MrPz+C3eHUaIyR7x2haWUjyouTeXzT9M0Hu/SAL1O46f1R/lmxQHik9N5vEsDadnjBlLpruBMZg+nSrfBakXpzWw6GENcsgWzUU+nJlXw8jCSnibj7glRFvl5mmhWI5Dtxy+x9XgswT7h7g5JCLc5HZvET+uPAvBUt0Z4e8hNZCFKK2kqXziapjGocwP8PE18vXw//9t4jPjkdJ69oyl6nVzXlySpdIss9p6J4+TFJDQNbmkYgY9ckAhR5jWsEsCpC/Fcumpl24kr7g5HCLdQSvHZ4j1YbHZa1Q7hlkYR7g5JCJELaSpfNO6JqoWfl5EPf9/Nsp1nSEyx8FLfGzAbZXDkkiK3OISTY7Ep7DhxCYDWtUMIC/B0c0SiOOnS0ukw4gVuGv4COmmOVa7pNI2bavujaXD2SgphTW52d0hClLgVu8+y48QlTAYdw3s0kSaWFYguLY2bhkt5V1ZlNpV35WMo5U3l3aVb82q8eu+NGPU6/j4Uwys/buZqqrw6tKRIpVs4nLt8lbVH4gGoX9mfepUDsk2XkpKS6yc1LY3U1FRSU1OlX00ppyk7AYeOEnDoKJpd7giXd4HeRppUqwRAozuHcTEh1c0RCVFyLsSnMG3pXgD631yXiEquPTUT5YNmV1LeiQqvff1w3unfBi+TgV0nLzPmu7+5mCCDSJYEaV4uALgYn8Lq/dEoBTVDfGhVOyRLGqvVApqOoKCgHNfjaYKb60NSKlx780z61QhROjStFsjZS1e5jA+fLN7HlAHt0cnTPlHO2eyKd3/dQVKqlfqVA7gnqpa7QxJCCLdoViOIdx9tx8s/buZYTAIjv13P+PtbUzdC3m5SnKTSLbhyNY2Ve89hsyuqBJiIqheWbZM7u80Gys7Hv6zH28cn23XpVQrh6Vux6LyxaWbpVyNEKaPTabStE8jvm4+z+zTMWXeEh26u6+6whCgWFosFq9XKvM0n2XXyMh5GPSN7NMCSnsb1jSrllWFCiPIkt3NalQATkx9qydvzdnHq0lWem7GBMb2bcUvjKiUYYcUile4KLj7ZwuqDF0m32gnx8+DWev6gy/2pl8ls/m/E8+vo7QoDJpRmQqeZSv0rKISoiHw9jBxYOI0mfUfz/epDNKxaiRsig90dlhBFymKxUL1GDa7iRdsn3kNnMLJ17gfUGbcs1+VsNlsJRSiEEEXPlZapmQxmL5rdP5bgOjcy4ZdtPHb5Kg90qCvjXRQDqXRXYL7hkazaf4E0q50AbxOdGkVg0FKwujswIUSxO7fjL0a9/i7Ld59n4rztfPZ4B0L9ZeBEUX5YrVYuxF6mz4RvSUqzUaWSJ/e+826OF5NJCXGMurcjdru9hCMVQoii40rLVKf0SvHP0VhOXEplxqrDHI1J4rnezfA0STWxKMlAahXUofPxtHpsImlWO4E+Zm5rVlVeGyBEBfNE53rUDvMjPjmd13/6h5R0ueUmypcGPYeQlGbD06SnfYMIzB6emMweOX6EEKK8yGyZmtfHw8OT1rWD2f/75+h1Gmv3n+eZb9Zz5lKSu7NQrkiluwLaffISr/28A6OnD8E+Jro2qyIV7goszd+PNH8/d4ch3MBs1PP6fS0J8DZxLCaByfN3YJNRfUU58eeus1Rt2R2NjBF7pZwTUt4JkT1N0zi9ZRFv338jgT5mTsUmMeKb9azbf97doZUbUumuYFbtOce42ZtJtdi4dGwnNzcIwWSQC5GKyubhwbKfp7N87nRsnvKUpyIKC/Di9ftaYdTr2Hgohs8W70HJwIeijDtw9gpfrTgEQJNq/vJ6MIHN04Plc6W8EyI3Dar489njHWhcrRLJaVbe+t82Pl64m1SLjHVRWFLpriCUUvyw9jAT52/HYrPTpk4w22eNx6iXQ0CIiq5R1Uq80KcFGrBo2ym+WXFAKt6iTPvfxuNYbYqYfRtoEOHr7nCEEKJMSElJwcugGH9Pc+5uXR3IuC4Y/vVa9p+6SEpKitPHYrn+PRAiJ1LjqgAsNjvv/7aLmasy7vr3axfJi72bYremuzkyIURpcUujCEbe0RSAuRuP8fXy/VLxFmXWi3e34IH2keyZ/6GMwiuEEHm4dsRzLy8v/Hx9eLpHM/6Z8TJpiZc5fekqI/5vHQ1v64+Xtw9eXl54eXlRvUYNqXi7SIalK+diE1J5Z9429p6+gk7TGHp7Y+5sVUPeRyoA0KWlE/Xa2wBsfvtl7GazmyMS7tTjhuqkW2x8vnQfv/x9nOQ0KyN6NkGvk/uzomwx6nU80D6SQWlS1okMurQ02rws5Z0Q2cltxPNUi40txy5zPg7qdx9MVN+naV0rEE+9jaG922K1WjEaje4JvAyRSnc5tu1YLJPmbyc+OR0vs4GX+t5A6zqh7g5LlCKashO0a2/G/2UALQHc1SYSD5OBD3/fxeLtp4mJT+Hlfjfi4yEFqhCi7NLsSso7IfKQOeK58zTo3NSLozEJbD0ay+Wr6SzbE03DKn5oeqlKukoeX5RDdqWYteYwL83eRHxyOrXD/Pjs8Q5S4RZCuKR7i2q8dm9LzEY9247FMuKbdRw+H+/usIQQQgjhBpqmUSfcnztb1aBKoDd2BXvPJNB+2GdsO37J3eGVCVLpLmeiryTz4vd/8/3qQyjg9huq8eFj7akS6O3u0IQQZUj7BuF8MCCKED8Pzl1OZtS365m74Sg2u93doQkhhBDCDbzMBjo1juCmBuF4GHV4B1flzV928vpP/3D+SrK7wyvVpNJdTiilWLTtFE99tYZdJy/jYdQzpndznr2jmbybVAhRIHUi/Pl8yM3cVD8Mq13xfysO8Mw36zl4Ls7doQkhhBDCDTRNIzLUlx7NIjixfj56ncbfh2J4Ytpqpi3dS9zVNHeHWCpJpbscuBCfwqtztvDxwt2kpNtoUj2QL568hduaV3V3aEKIMs7P08Sr97Zk9J3N8PEwciQ6gWe+Wc+k+ds5d/mqu8MTQgghhBsYDToOLf2Gjwa04YbIYCw2Ows2n2DApyuZufIgV1NlVPNrSe/3MizdamPe38f5Ye1h0qx2jHodD99cizturIZep+U6QrmMXi6EcJWmaXRvUY0balbi2xUHWbUvmpV7zrF67zna1Q2lb5vq1An3y7KcwWCQEU2FEEKIcqxakDcT+7dh2/FYZvx1kEPn4/lh3RF+++cEtzYI5qFO/gT6ero7TLeTSncZtfXYRT5fvJcz/z5pSjp3kJ3/+5CFL5/J13psNltxhCfKEKu8NkW4wGKx0LxRPaLPn8c3vBZ1uj5CSL3WbDh0gQ2HLnD52E5ObV7IxYObUTYrAOEREZw6eVIq3kKIUkHKOyGKh6ZptKwVwo2Rwaw/EM3MVYc4FZvE7zuiWbrnAt1bVKNv20gqV+AxpqTSXcYcPh/P9L8OsPVYLACVvM0M6Fibnq3u4PPfNmUZ5j8nSQlxjLq3I3YZFKlCs3l4sOS3H9A0d0ciSjur1Ur0+fNO55m45HQOnk/k1KVkAms1J7BWc0wGHTWCvajqb2Tc/TfJ+zuFEKWCzdODpb//4O4whCjXNE2jQ8MIouqHs+HAeWavOcjxi8n8/s9J/vjnJC1rh3BHyxq0qRuKXlexLj6l0l1KWSwWrFar4+8zl67yw/pjbDh0EQC9TqNHiyo8eFMtdPaMPhMms4fLlW5X0wkhyq/8dDPJTHvteSbU7EFoJT+uplo4dD6eYzEJpKTbOBydxOFoaD98Kj9tOE7n5tWpHuxTLHkQQgghhPvkdC1xYw1/qt0eSXSKgV//Oc22E5f55+hF/jl6kVB/T7o1r0rnplUqzBuWpNJdClksFqrXqEH0+fMEVG9EjfZ3E9qgLZpOh7LbOb9rFUdXzmbxlRieuWY5aSouhHCF1WoBTUdQUFC+l83uPOPtYeSGyGCa1wzi/JVkjkYncOZSEj6hNfhxw3F+3HCcyFBfOjauzC2NIipMASuEEEKUV3ldS+h0Olq2bMnWrVux2+14BkbQoNM91Gp3BxfiU5i15jCz1hymYZUAujSrQocGEVTyKb9dQKTSXQolp6ZBcF3uf246V5L/e9pduZInTar6ERA1AJ4c4JguTcVFQenS02n9zntowNbXnsduMrk7JFEC7DYbKDsf/7Iebx/XnkC7cp7RaRpVAr2pEuhN0tVkJrz8HI8+9zY7T17m+IVEjl84yIyVB6kT7sctjSpzU4MwqgbJE3AhRPHTpafT8s13ASnvhCgKeV5LKIXJnkK6zhM0jfS0VIb2bsvKGe+w9UQ8y3efZfuxi+w/G8f+s3FMXbyXRtUqEVU/jPb1w8vdDXqpdJcSSikOnovjz51nWLXnHM3ufYEryVZ0mkatMF8aVq2Ev1f2BYQ0FRcFpdnthG3elvF/m9y0qWhMZnOxdUkxGXSc2/EXz/eshxUDfx+5yLoDMew+FceR6ASORCfw7V8HqBroRbu6IbStE0KdcF+MRqP0ARdCFDnNZidUyjshilyO1xJKYbBaweDBtYMH2SzpRNUJJKpOIJeT0lh3IIY1+2M4EpPI3tNX2Hv6Cv+3/ABh/h40qxHIDZHBtKwdSoB32X4KLpVuN0q32th96jKbD1/g70MxRMf91yciJe4CLRvXoWG1IDxN8jUJIcqWnJqdGb38CGvUntBG7QmMbMaZy8n8b9NJ/rfpJKnxsSSd2sUXbz9Pi1qhGPU6N0UvhBBCiKKUV3N0s18woQ3aEtqwHZVqNiUmPpVlu86xbNc5ACJDfWkRGUyDygHUq+xPRCUvtDI0ErDU5kpQcpqVg+fi2Hf6CvvOXGHv6cukpP/XP9Js0NGhYQQdG4bQrmE1BizZgUkq3EKIMsiVJuzpVjvn41I4eyWF6LhUPPyD8WjamVfmbMXTpKdpjSBujAzmxlrBVA/2KVOFqxBCCCH+k5+ubRabnYsJaZy/cpUdu/fhGx75bze1REcaX08j9SoHUD/Cn7oR/tQI8SW8klepHRW9TNTopk6dyrvvvkt0dDTNmzfn008/pU2bNm6J5fpRxa+Xkm7lUmIasYlpXExM5eylZM5eSebM5WSirySjrksf6GOmTd1Q2tYN5cbIYDxMhoxRANX1KYUQouzJrQm7yQx1vb2oWwVsdjtnLsbz4+zZNL7lDuKTLWw+fIHNhy8A4OdppEHVSjSsEkD9KgHUCvUjwNtU4Ip4Xufy6xkMBmn27qLSVGYLIYQoXVzp2mYCvL28qFzJk2lPj+DY6WiOXExh35k4DkcncvxiIokpFrYevcjWoxf/W86go2qgFzVCfBlzVwsMpajFXKmvdP/000+MHj2aL774grZt2/LRRx/RvXt3Dh48SGhoaInFYbMrFv5znFfGTyDVCkYPH4yeGR+Dp8+/f/ti8PDKdT1h/p40rFqJRtUq0bhqJWqF+6GTpzdCiApOr9MREeDJvt8+ZfOPk4hOsLDtWCzbjsey59RlElKcK+GQcZe7erAP1YJ8CPbzIMjXgyBfM5W8zXiZDXiZDXgYdNiVQl1zI/PaN0Q4aDo0nQ7tmn/J/FvTERoezp4d2/D38SzJ3VLmlJYyWwghRNmX2SS9VrVwp+ma3oBvWE38qtTFv0o9fMMj8Q6pRjpmjl1I4uDxMzx3Z1OQSrfrPvjgA5544gkee+wxAL744gsWLlzIt99+y9ixY0ssDp0G0/48QES7fnmmNeo1PE16vEwGPI2waPoH/O/7r6lbJahcD4UvhBBFQadp1A73p3a4P/e2r43FZudodAIHzl5h/5k4Dp6LI/pKMokpFsegK67QyBjLRdM0mjzxOc0Nxiytj3KzaNspHrylfoHyVFGUljJbCCFE2ZefJul2pbiaZuVSfDL/9957WF/vW6paqJXqSnd6ejpbt25l3Lhxjmk6nY6uXbuycePGbJdJS0sjLS3N8Xd8fDwAcXFxLr9Sy263k5CQgMlkQqf77w5J6+pe/G/uz7TvfDseJhNGgw6zXodBr8NkAJNeh9mkx3jNMunpaXz1z2JCzemkJl7mfGJ2W8yaB03TiL8ci8mUdyX9alI8mqaRcOUS1rRUl/KY7TJKYVKppGspTqMM5mc7epWK2RKPTUvBrhlJvZqI0aCRdOUC1tTcWwFkyu8yhd2GxcMLlB40W3bZLrLtlERe8rvM1YQrJPw7LTHuIrbUnI+38pJ/pcCSainTedEpC3qVTrwxloSraa79/q/5fV+9mlA054wiTA8Z50tN04iJicFsdj4W/XXQtpoHbauFA+GkWWxEx6dy9vJVoq+kcCU5nbirFi5fTSMhJZ3UdBup6fZcK9V2q8WluADsdhtJSQnExcW5vExOEhIyfnWqnHUjym+ZXRTldW5SUlJKriyNu4TebEVvjceuyyj/clJezqXXL1Pay1J9alqu5V1RxKUUee6DsvBdFnaZ3PZDRcg/ZL8Piiuua68JbJpH0dULCrvMdfWKwmwjNTkJnQu3yQ1AJaOFmN2riYuLcypjCqJIy2tVip09e1YBasOGDU7Tn3/+edWmTZtsl3n99dcVIB/5yEc+8pFPqf6cPn26JIrSEpPfMlvKa/nIRz7ykU9Z+BRFeV2qn3QXxLhx4xg9erTjb7vdzuXLlwkKCnJ5wJ2EhASqVavG6dOn8fPzK65QSx3Jt+S7IpB8S77dTSlFYmIilStXdncoblUU5XVpURqPs5Im+0D2QSbZD7IPoHzsg6Isr0t1pTs4OBi9Xk9MTIzT9JiYGMLDw7Ndxmw2Z2mWGBAQUKDt+/n5ldmDpDAk3xWL5LtikXyXDv7+/u4Oocjlt8wuyvK6tChtx5k7yD6QfZBJ9oPsAyj7+6CoyuvSM6RbNkwmEy1btmTFihWOaXa7nRUrVhAVFeXGyIQQQghxLSmzhRBCiOyV6ifdAKNHj2bAgAG0atWKNm3a8NFHH3H16lXHyKhCCCGEKB2kzBZCCCGyKvWV7vvvv5+LFy/y2muvER0dTYsWLViyZAlhYWHFtk2z2czrr7+epdlbeSf5lnxXBJJvybcoPu4os0sDOc5kH4Dsg0yyH2QfgOyD62lKlbN3lgghhBBCCCGEEKVEqe7TLYQQQgghhBBClGVS6RZCCCGEEEIIIYqJVLqFEEIIIYQQQohiIpVuIYQQQgghhBCimFSISvfUqVOpWbMmHh4etG3bls2bN+eYdu/evfTr14+aNWuiaRofffRRljQTJ06kdevW+Pr6EhoaSp8+fTh48GAx5qBgijrf06ZNo1mzZo6X3EdFRbF48eJizEHBFHW+rzVp0iQ0TWPUqFFFG3QRKOp8v/HGG2ia5vRp0KBBMeagYIrj+z579iwPP/wwQUFBeHp60rRpU/75559iykHBFHW+M+dd/xk2bFgx5iL/ijrfNpuNV199lcjISDw9PalduzZvvfUWMsaoyI/8HJdlzZo1a7jzzjupXLkymqaxYMECp/lKKV577TUiIiLw9PSka9euHD582CnN5cuX6d+/P35+fgQEBDB48GCSkpJKMBcF58o1X2pqKsOGDSMoKAgfHx/69etHTEyMU5pTp07Rq1cvvLy8CA0N5fnnn8dqtZZkVgosr+u/8p7/7GR3PVgR9kNe14YVYR8UVLmvdP/000+MHj2a119/nW3bttG8eXO6d+/OhQsXsk2fnJxMrVq1mDRpEuHh4dmmWb16NcOGDePvv/9m2bJlWCwWunXrxtWrV4szK/lSHPmuWrUqkyZNYuvWrfzzzz907tyZu+66i7179xZnVvKlOPKdacuWLXz55Zc0a9asOEIvlOLKd+PGjTl//rzjs27duuLKQoEUR76vXLnCTTfdhNFoZPHixezbt4/333+fSpUqFWdW8qU48r1lyxan73rZsmUA3HvvvcWWj/wqjnxPnjyZadOm8dlnn7F//34mT57MlClT+PTTT4szK6Icye9xWdZcvXqV5s2bM3Xq1GznT5kyhU8++YQvvviCTZs24e3tTffu3UlNTXWk6d+/P3v37mXZsmX88ccfrFmzhiFDhpRUFgrFlWu+Z599lt9//525c+eyevVqzp07R9++fR3zbTYbvXr1Ij09nQ0bNjBz5kxmzJjBa6+95o4s5Vte13/lPf/Xy+l6sKLsh9yuDSvKPigQVc61adNGDRs2zPG3zWZTlStXVhMnTsxz2Ro1aqgPP/wwz3QXLlxQgFq9enVhQi1SJZFvpZSqVKmS+r//+7+ChlnkiivfiYmJqm7dumrZsmWqY8eOauTIkUUUcdEojny//vrrqnnz5kUYZdErjny/+OKLqkOHDkUZZpErid/3yJEjVe3atZXdbi9MqEWqOPLdq1cvNWjQIKdpffv2Vf379y90vKJiKMxxWdYAav78+Y6/7Xa7Cg8PV++++65jWlxcnDKbzerHH39USim1b98+BagtW7Y40ixevFhpmqbOnj1bYrEXleuv+eLi4pTRaFRz5851pNm/f78C1MaNG5VSSi1atEjpdDoVHR3tSDNt2jTl5+en0tLSSjYDRSTz+q+i5T+n68GKsh9yuzasKPugoMr1k+709HS2bt1K165dHdN0Oh1du3Zl48aNRbad+Ph4AAIDA4tsnYVREvm22WzMmTOHq1evEhUVVSTrLKzizPewYcPo1auX07pLi+LM9+HDh6lcuTK1atWif//+nDp1qrDhFpniyvdvv/1Gq1atuPfeewkNDeWGG27g66+/LoqQi0RJ/L7T09OZNWsWgwYNQtO0IllnYRVXvtu3b8+KFSs4dOgQADt37mTdunX06NGj0DGL8q+krjNKq+PHjxMdHe2Uf39/f9q2bevI/8aNGwkICKBVq1aONF27dkWn07Fp06YSj7mwrr/m27p1KxaLxWkfNGjQgOrVqzvtg6ZNmxIWFuZI0717dxISEkpVa0FXXH/9V9Hyn9P1YEXaDzldG1akfVAQBncHUJxiY2Ox2WxOXyxAWFgYBw4cKJJt2O12Ro0axU033USTJk2KZJ2FVZz53r17N1FRUaSmpuLj48P8+fNp1KhRodZZVIor33PmzGHbtm1s2bKlsCEWi+LKd9u2bZkxYwb169fn/PnzjB8/nptvvpk9e/bg6+tb2LALrbjyfezYMaZNm8bo0aN56aWX2LJlC8888wwmk4kBAwYUNuxCK4nz2oIFC4iLi2PgwIFFsr6iUFz5Hjt2LAkJCTRo0AC9Xo/NZuPtt9+mf//+hQ1ZVAAl8XsszaKjowGyzX/mvOjoaEJDQ53mGwwGAgMDHWnKiuyu+aKjozGZTAQEBDilvX4fZLePMueVBTld/+3YsaNC5B9yvx6sKMdBbteGFWUfFFS5rnSXhGHDhrFnz55S19e1uNSvX58dO3YQHx/P//73PwYMGMDq1atLTcW7qJ0+fZqRI0eybNkyPDw83B1Oibr2SV+zZs1o27YtNWrU4Oeff2bw4MFujKx42e12WrVqxTvvvAPADTfcwJ49e/jiiy9KRaW7JHzzzTf06NGDypUruzuUYvfzzz8ze/ZsfvjhBxo3bsyOHTsYNWoUlStXrjDftxDCNRXtmu9aOV3/VRQV+XrwWrldG3p6eroxstKvXDcvDw4ORq/XZxk1LyYmJs9Bs1wxfPhw/vjjD1auXEnVqlULvb6iUpz5NplM1KlTh5YtWzJx4kSaN2/Oxx9/XKh1FpXiyPfWrVu5cOECN954IwaDAYPBwOrVq/nkk08wGAzYbLaiCL1Qivs4zxQQEEC9evU4cuRIka2zMIor3xEREVluIjVs2LDUNK0v7u/75MmTLF++nMcff7zQ6ypKxZXv559/nrFjx/LAAw/QtGlTHnnkEZ599lkmTpxY2JBFBVBS59/SKjOPueU/PDw8y6ByVquVy5cvl6l9lNM1X3h4OOnp6cTFxTmlv34fZLePMueVBTld/1WU/Od1PRgWFlYh9sP1rr02rCjHQkGV60q3yWSiZcuWrFixwjHNbrezYsWKQvVDVkoxfPhw5s+fz19//UVkZGRRhFtkiivf2bHb7aSlpRXpOguqOPLdpUsXdu/ezY4dOxyfVq1a0b9/f3bs2IFery+q8AuspL7vpKQkjh49SkRERJGtszCKK9833XRTltfBHDp0iBo1ahR4nUWpuL/v6dOnExoaSq9evQq9rqJUXPlOTk5Gp3MuCvV6PXa7vcDrFBVHSZa3pVFkZCTh4eFO+U9ISGDTpk2O/EdFRREXF8fWrVsdaf766y/sdjtt27Yt8ZjzK69rvpYtW2I0Gp32wcGDBzl16pTTPti9e7fTzYdly5bh5+dXZlsKZl7/VZT853U92KpVqwqxH6537bVhRTkWCszdI7kVtzlz5iiz2axmzJih9u3bp4YMGaICAgIco+Y98sgjauzYsY70aWlpavv27Wr79u0qIiJCjRkzRm3fvl0dPnzYkebpp59W/v7+atWqVer8+fOOT3JyconnLyfFke+xY8eq1atXq+PHj6tdu3apsWPHKk3T1J9//lni+ctJceT7eqVx9PLiyPdzzz2nVq1apY4fP67Wr1+vunbtqoKDg9WFCxdKPH85KY58b968WRkMBvX222+rw4cPq9mzZysvLy81a9asEs9fTorrOLfZbKp69erqxRdfLNH8uKo48j1gwABVpUoV9ccff6jjx4+refPmqeDgYPXCCy+UeP5E2ZTXcVnWJSYmOn5HgPrggw/U9u3b1cmTJ5VSSk2aNEkFBASoX3/9Ve3atUvdddddKjIyUqWkpDjWcfvtt6sbbrhBbdq0Sa1bt07VrVtXPfjgg+7KUr64cs331FNPqerVq6u//vpL/fPPPyoqKkpFRUU55lutVtWkSRPVrVs3tWPHDrVkyRIVEhKixo0b544s5Vte13/lPf85uf56sCLsh7yuDSvCPiiocl/pVkqpTz/9VFWvXl2ZTCbVpk0b9ffffzvmdezYUQ0YMMDx9/HjxxWQ5dOxY0dHmuzmA2r69OkllykXFHW+Bw0apGrUqKFMJpMKCQlRXbp0KVUV7kxFne/rlcZKt1JFn+/7779fRUREKJPJpKpUqaLuv/9+deTIkRLMkWuK4/v+/fffVZMmTZTZbFYNGjRQX331VQnlxnXFke+lS5cqQB08eLCEcpF/RZ3vhIQENXLkSFW9enXl4eGhatWqpV5++eVy/+oSUbRyOy7LupUrV2b7O8r8rdntdvXqq6+qsLAwZTabVZcuXbKcQy5duqQefPBB5ePjo/z8/NRjjz2mEhMT3ZCb/HPlmi8lJUUNHTpUVapUSXl5eam7775bnT9/3mk9J06cUD169FCenp4qODhYPffcc8pisZRwbgomr+u/8p7/nFx/PVgR9kNe14YVYR8UlKaUUkX55FwIIYQQQgghhBAZynWfbiGEEEIIIYQQwp2k0i2EEEIIIYQQQhQTqXQLIYQQQgghhBDFRCrdQgghhBBCCCFEMZFKtxBCCCGEEEIIUUyk0i2EEEIIIYQQQhQTqXQLIYQQQgghhBDFRCrdQgghhBBCCCFEMZFKtxA56NSpE6NGjSry9c6YMYOAgIBc07zxxhu0aNHC8ffAgQPp06dPkcfiDqtWrULTNOLi4gq9rhMnTqBpGjt27Cj0uora9d/Z9cdTcnIy/fr1w8/Pz7E/spsmhBDCdcVVdpd3NWvW5KOPPiqSdZXW7+D664/srse++uorqlWrhk6nc+yP7KYJkV8GdwcghMjbxx9/jFLK3WGUCwMHDiQuLo4FCxaU6HbnzZuH0Wh0/D1z5kzWrl3Lhg0bCA4Oxt/fny+++CLLNCGEKO86depEixYtiqRCc/25trCKMjaRvVWrVnHrrbdy5cqVPB9KFKX777+fnj17Ov5OSEhg+PDhfPDBB/Tr1w9/f/9spwlREFLpFqIMKC8neYvF4u4Q3CYwMNDp76NHj9KwYUOaNGmS6zQhhKjolFLYbDYMhrwvW68/15YW6enpmEwmd4eRRWmNqyR4enri6enp+PvUqVNYLBZ69epFREQEAHv27MkyTYiCkOblolyw2+1MnDiRyMhIPD09ad68Of/73/+A/5oTLV26lBtuuAFPT086d+7MhQsXWLx4MQ0bNsTPz4+HHnqI5ORkp/VarVaGDx+Ov78/wcHBvPrqq05PnNPS0hgzZgxVqlTB29ubtm3bsmrVKqd1zJgxg+rVq+Pl5cXdd9/NpUuXssQ/adIkwsLC8PX1ZfDgwaSmpjrNz66p8jPPPMMLL7xAYGAg4eHhvPHGG07LHDhwgA4dOuDh4UGjRo1Yvnw5mqa5/IT39OnT3HfffQQEBBAYGMhdd93FiRMnHPO3bNnCbbfd5ngi27FjR7Zt2+a0Dk3TmDZtGr1798bb25u3337baf7Vq1fx8/NzfFeZFixYgLe3N4mJiS7FmslmszF48GDHcVC/fn0+/vhjx/w33niDmTNn8uuvv6JpGpqmOb6vvPKb13ZHjx5NQEAAQUFBvPDCC1laJlzb3K5Tp068//77rFmzBk3T6NSpU7bThBCivBs4cCCrV6/m448/dpyXZ8yYgaZpLF68mJYtW2I2m1m3bh1Hjx7lrrvuIiwsDB8fH1q3bs3y5cud1nd902ZXyun169fTqVMnvLy8qFSpEt27d+fKlSvZxpZZLqxevZo2bdpgNpuJiIhg7NixWK1WpziGDx/OqFGjCA4Opnv37gwaNIg77rjDadsWi4XQ0FC++eabPPdVbtc6kHcZmLm/+/Tpw9tvv03lypWpX79+lu0UNs7rff/997Rq1QpfX1/Cw8N56KGHuHDhApDRTezWW28FoFKlSmiaxsCBA13Kb14WLVpEvXr18PT05NZbb81Spl/bvHzGjBk0bdoUgFq1ajmOw+unuXpdIEQWSohyYMKECapBgwZqyZIl6ujRo2r69OnKbDarVatWqZUrVypAtWvXTq1bt05t27ZN1alTR3Xs2FF169ZNbdu2Ta1Zs0YFBQWpSZMmOdbZsWNH5ePjo0aOHKkOHDigZs2apby8vNRXX33lSPP444+r9u3bqzVr1qgjR46od999V5nNZnXo0CGllFJ///230ul0avLkyergwYPq448/VgEBAcrf39+xjp9++kmZzWb1f//3f+rAgQPq5ZdfVr6+vqp58+aONAMGDFB33XWXU2x+fn7qjTfeUIcOHVIzZ85UmqapP//8UymllNVqVfXr11e33Xab2rFjh1q7dq1q06aNAtT8+fPz3J/p6emqYcOGatCgQWrXrl1q37596qGHHlL169dXaWlpSimlVqxYob7//nu1f/9+tW/fPjV48GAVFhamEhISHOsBVGhoqPr222/V0aNH1cmTJx3fx5UrV5RSSj3xxBOqZ8+eTtvv3bu3evTRR/OM8/jx4wpQ27dvd8T92muvqS1btqhjx445vrOffvpJKaVUYmKiuu+++9Ttt9+uzp8/r86fP6/S0tJcym9uJk+erCpVqqR++eUXx77w9fXN8p2NHDlSKaXUpUuX1BNPPKGioqLU+fPn1aVLl7KdJoQQ5V1cXJyKiopSTzzxhOO8vHz5cgWoZs2aqT///FMdOXJEXbp0Se3YsUN98cUXavfu3erQoUPqlVdeUR4eHurkyZOO9V17rlUq73J6+/btymw2q6efflrt2LFD7dmzR3366afq4sWL2cZmtVrVmTNnlJeXlxo6dKjav3+/mj9/vgoODlavv/66Uxw+Pj7q+eefVwcOHFAHDhxQ69evV3q9Xp07d86Rbt68ecrb21slJibmua9yu9ZRKu8yUKmM6wkfHx/1yCOPqD179qg9e/YopZSqUaOG+vDDD5VSqtBxXv8dfPPNN2rRokXq6NGjauPGjSoqKkr16NFDKZVxvfLLL78oQB08eFCdP39excXFuZTf3Jw6dUqZzWY1evRoxzVcWFiY0/XH9OnTHddjycnJjuNu8+bN6vz58yopKSnLNKvVmue2hciOVLpFmZeamqq8vLzUhg0bnKYPHjxYPfjgg45K3vLlyx3zJk6cqAB19OhRx7Qnn3xSde/e3fF3x44dVcOGDZXdbndMe/HFF1XDhg2VUkqdPHlS6fV6dfbsWaftdunSRY0bN04ppdSDDz6YpUJ5//33O1W6o6Ki1NChQ53StG3bNs9Kd4cOHZyWad26tXrxxReVUkotXrxYGQwGdf78ecf8ZcuWuVzp/v7771X9+vWd8p6WlqY8PT3V0qVLs13GZrMpX19f9fvvvzumAWrUqFFO6a6vdG/atMmpcI+JiVEGg8GlQvX6Snd2hg0bpvr16+f4+/p9WdD8XisiIkJNmTLF8bfFYlFVq1bNsdKtlFIjR45UHTt2dFpPdtOEEKK8u/78mFlOLFiwIM9lGzdurD799NNs1+VqOX3TTTe5HJtSSr300ktZyoypU6cqHx8fZbPZHMvdcMMNWdbXqFEjNXnyZMffd955pxo4cGCe+czrWicn2ZWBYWFhWW4oX1vpLkycSmW/z661ZcsWBTgq8NdfFyhV8PxmGjdunGrUqJHTtBdffDHHSrdSGTdgAHX8+PFcpwlRENK8XJR5R44cITk5mdtuuw0fHx/H57vvvuPo0aOOdM2aNXP8PywsDC8vL2rVquU0LbO5U6Z27dqhaZrj76ioKA4fPozNZmP37t3YbDbq1avntN3Vq1c7trt//37atm3rtM6oqCinv11Jk51r8wMQERHhiP/gwYNUq1aN8PBwx/w2bdrkuc5MO3fu5MiRI/j6+jryFRgYSGpqqiNvMTExPPHEE9StWxd/f3/8/PxISkri1KlTTutq1apVrttq06YNjRs3ZubMmQDMmjWLGjVqcMstt7gc77WmTp1Ky5YtCQkJwcfHh6+++ipLTAXJb07i4+M5f/6803doMBjyzLcQQojcXX8eTUpKYsyYMTRs2JCAgAB8fHzYv39/jud4V8rpHTt20KVLl3zFtX//fqKiopyuD2666SaSkpI4c+aMY1rLli2zLPv4448zffp0IKMcXbx4MYMGDcpzm65e67hSBjZt2jTPftwFjTM7W7du5c4776R69er4+vrSsWNHgFzLZlfzm5OCXlsJUVxkIDVR5iUlJQGwcOFCqlSp4jTPbDY7Ts7XjmaqaVqW0U01TcNut+dru3q9nq1bt6LX653m+fj45CsPBVHY+HOTlJREy5YtmT17dpZ5ISEhAAwYMIBLly7x8ccfU6NGDcxmM1FRUaSnpzul9/b2znN7jz/+OFOnTmXs2LFMnz6dxx57zOlixlVz5sxhzJgxvP/++0RFReHr68u7777Lpk2bcl3OlfwKIYQoWdeXH2PGjGHZsmW899571KlTB09PT+65554s5U4mV8rpawfSKmrZlX+PPvooY8eOZePGjWzYsIHIyEhuvvnmPNeV17UOuF4GulIuFzTO6129epXu3bvTvXt3Zs+eTUhICKdOnaJ79+45fm/gWn6FKEuk0i3KvEaNGmE2mzl16pTj7um1XLkjmpPrC6q///6bunXrotfrueGGG7DZbFy4cCHHgqhhw4bZriO7NI8++miOafKrfv36nD59mpiYGMLCwoCMgc9cdeONN/LTTz8RGhqKn59ftmnWr1/P559/7njdxunTp4mNjS1QvA8//DAvvPACn3zyCfv27WPAgAEFWs/69etp3749Q4cOdUy7/vs3mUzYbDanaa7kNyf+/v5ERESwadMmx9N5q9XK1q1bufHGGwuUDyGEqEiyOy9nZ/369QwcOJC7774byKiY5TawlSvldLNmzVixYgXjx493ObaGDRvyyy+/oJRy3CBev349vr6+VK1aNdc8BAUF0adPH6ZPn87GjRt57LHHck2fKa9rncwY8ioDXVXQOK934MABLl26xKRJk6hWrRoA//zzj1OazKfu1+5nV/Kbm4YNG/Lbb785TSvstZUQhSHNy0WZ5+vry5gxY3j22WeZOXMmR48eZdu2bXz66aeOJssFderUKUaPHs3Bgwf58ccf+fTTTxk5ciQA9erVo3///jz66KPMmzeP48ePs3nzZiZOnMjChQsBeOaZZ1iyZAnvvfcehw8f5rPPPmPJkiVO2xg5ciTffvst06dP59ChQ7z++uvs3bu3UHHfdttt1K5dmwEDBrBr1y7Wr1/PK6+8AuDSE+T+/fsTHBzMXXfdxdq1azl+/DirVq3imWeecTSdq1u3Lt9//z379+9n06ZN9O/fv8BPDCpVqkTfvn15/vnn6datW54XLTmpW7cu//zzD0uXLuXQoUO8+uqrWW421KxZk127dnHw4EFiY2OxWCwu5Tc3I0eOZNKkSSxYsIADBw4wdOhQ4uLiCpQHIYSoaGrWrMmmTZs4ceIEsbGxObbaqlu3LvPmzWPHjh3s3LmThx56KNcWXq6U0+PGjWPLli0MHTqUXbt2ceDAAaZNm+a4iZxdbEOHDuX06dOMGDGCAwcO8Ouvv/L6668zevRodLq8L60ff/xxZs6cyf79+12+yezKtY4rZWB+FCTO61WvXh2TycSnn37KsWPH+O2333jrrbec0tSoUQNN0/jjjz+4ePEiSUlJhb62e+qppzh8+DDPP/88Bw8e5IcffmDGjBkFyoMQRUEq3aJceOutt3j11VeZOHEiDRs25Pbbb2fhwoVERkYWar2PPvooKSkptGnThmHDhjFy5EiGDBnimD99+nQeffRRnnvuOerXr0+fPn3YsmUL1atXBzL6hH/99dd8/PHHNG/enD///NNR+c10//338+qrr/LCCy/QsmVLTp48ydNPP12ouPV6PQsWLCApKYnWrVvz+OOP8/LLLwPg4eGR5/JeXl6sWbOG6tWr07dvXxo2bOh4lVnmk+BvvvmGK1eucOONN/LII4/wzDPPEBoaWuCYBw8eTHp6eoH7jAE8+eST9O3bl/vvv5+2bdty6dIlpzv+AE888QT169enVatWhISEsH79epfym5vnnnuORx55hAEDBjia9GU+iRFCCJG7MWPGoNfradSokaP5cXY++OADKlWqRPv27bnzzjvp3r17ni2K8iqn69Wrx59//snOnTtp06YNUVFR/Prrr453gmcXW5UqVVi0aBGbN2+mefPmPPXUUwwePDhL+Z6Trl27EhERQffu3alcubLL+ymvax1XysD8KGic1woJCWHGjBnMnTuXRo0aMWnSJN577z2nNFWqVGH8+PGMHTuWsLAwhg8f7lJ+c1O9enV++eUXFixYQPPmzfniiy945513CpQHIYqCptR1L5MVQpRL69evp0OHDhw5coTatWu7O5wsvv/+e5599lnOnTuX5wAvQgghRHaioqLo0qULEyZMcHcoOUpKSqJKlSpMnz6dvn37ujucHJWVOIUoC6RPtxDl1Pz58/Hx8aFu3bocOXKEkSNHctNNN5W6CndycjLnz59n0qRJPPnkk1LhFkIIkW9paWns3r2bvXv38swzz7g7nGzZ7XZiY2N5//33CQgIoHfv3u4OKVtlJU4hyhJpXi5EOZWYmMiwYcNo0KABAwcOpHXr1vz6668AvPPOO06v4Lj206NHjxKNc8qUKTRo0IDw8HDGjRvnNK+0xJlTDD4+Pqxdu7bE4hBCCJG9xYsX07lzZ3r37s0999zj7nCyderUKcLCwvjhhx/49ttvHU3YM+flVtbk9erLihbnU089lWMMTz31VInEIER+SPNyISqgy5cvc/ny5WzneXp6Znk9h7uUljiPHDmS47wq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PmP79u2sX78eo9HIRx99xIgRI/Dx8eHll18GICwsDIDk5GQ6duzI2bNnefLJJ6levTobNmxg3LhxnD9/no8++sgptunTp5OamsqQIUMwm80EBgY65t1///00bNiQSZMmsXDhQiZMmEBgYCBffvklnTt3ZvLkycyePZsxY8bQunVrbrnllgLtn5iYGNq1a+c4UYWEhLB48WIGDx5MQkICo0aNckr/1ltvYTKZGDNmDGlpaY67+TabjR49enDLLbcwZcoUZs+ezfDhw/H29ubll1+mf//+9O3bly+++IJHH32UqKgoIiMj84wvNTWV2NhYIOOku379embOnMlDDz3k0h3X2bNnk56ezogRI7h8+TJTpkzhvvvuo3PnzqxatYoXX3yRI0eO8OmnnzJmzBinC5QZM2bg4+PD6NGj8fHx4a+//uK1114jISGBd99912k7V65c4fbbb6dv377cd999/O9//+PFF1+kadOm9OjRI884rzd37lySk5N5+umnCQoKYvPmzXz66aecOXPGqSmeqzZs2EBQUBA1atTIdn5iYqJjP18rKCjIqeBbu3Ytv/32G8OGDQNg4sSJ3HHHHbzwwgt8/vnnDB06lCtXrjBlyhQGDRrEX3/95bS+K1eu0LNnT+677z4efPBBfv75Z55++mlMJpPjaa/dbqd3796sW7eOIUOG0LBhQ3bv3s2HH37IoUOHWLBggWN9jz/+OLNmzeKhhx6iffv2/PXXX/Tq1StLPnbv3k23bt0ICQnhjTfewGq18vrrrzt+u64YMWIElSpV4vXXX+fEiRN89NFHDB8+nJ9++smRZty4cUyZMoU777yT7t27s3PnTrp3705qamq262zZsqVTfoQQ2ZOyPHdSlktZnpecfi+FifHtt9/m1Vdf5b777uPxxx/n4sWLfPrpp9xyyy1s376dgIAAAJYtW8Ydd9xBREQEI0eOJDw8nP379/PHH38wcuRInnzySc6dO8eyZcuydKVQStG7d29WrlzJ4MGDadGiBUuXLuX555/n7NmzfPjhh07p//rrL37++WeGDx9OcHAwkZGRPPzww0yZMoXLly87/T5///13EhISsrQYadmyJb/++isJCQn4+fnle1+LbChRbkyfPl0Bavny5erixYvq9OnTas6cOSooKEh5enqqM2fOKKWUGjBggALU2LFjnZZfu3atAtTs2bOd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SilHJSCnbgh//vknSinq1avH0aNHGTt2LPXr1+eRRx7BarWSlJTEhAkTuPvuuwkLC+PYsWOMGzeO2rVr06VLF6xWq9P6xo8fz+23307Tpk2xWq20a9eOcePG8cgjjzB16lTat2+fZZlrl121ahXt2rVj/PjxtGzZEqPRyPr165kyZQobNmwgICDAUanOaT2ZFf1Lly5hNDp3m0hMTMznTnU/u93OI488wvPPP0/jxo2zzN+4cSMBAQGOCjdA165d0el0bNq0KduBvvJzkzzzpkmWGx3Z3OQpMtndLCrA9pYuXYpSivr163PkyBFeeOEFGjRowMCBA1FKkZSUxPjx4+nXrx/h4eEcPXqUF198kTp16tCtW7csN3befPNNevToQYsWLVBK0b59e1544QUGDhzIp59+yk033ZTjzaAJEyawatUqOnTowIQJE2jVqhVGo5G1a9cyadIkNm/e7HhlWE43lTJv7DludJaSm5Rl/aZpbspr3spFvpRyXAZf+3soF3nLxrX5yu8DHJcfkmTuR7s941NCsnvoWpQ3yd1a6X7++ecZO3YsDzzwAABNmzbl5MmTTJw4kQEDBjhenRETE+N0tzcmJoYWLVpku85x48YxevRox9//z959x1dV348ff51z7sreZECAICvs5UCciOLAUamjX9uq7U871FZpv7W22q9araNWraNaO7S22mG1zooiDhyAGFCZYW+SELLHHeecz++PEwKBJCQhyV3v5+NxHlxuzjn3/bnjnPM+n1VXV0dhYSE5OTldmk4DnDdY0zRycnIk6e6I2QTo4G4ZEfkIbKXQgJxMX1QmM5HoaN5Tvx82rC0Bze50tqi6ALyx0U3I1ihIDrLyrz/jR7/6HcmaDm9dDcDca27A6mBQw+bGen5zy3exlYl2hDltUxPgtEH1vLUtjVWVHkYPCJGf0oWjuG2zYW0J2Wmeox5cMdq/p/4g1O/TcBkaLtf+Y5cOhg6aCQQPWtvGqeHW6d2eRqYzzZLL5SwtDk08D9bQ0MDPfvYzdu7cSWZmJhdffDF33303CQnOyHper7d1nuOamhoKCgo488wz+eUvf0lSUlKbfa1atYoXX3yRFStWtNbYXXbZZXz44YfMnDmTUaNG8dxzz3VYmzdgwACWLFnCvffey7333su2bdvIyMhg/Pjx3H///WRlZaFpWuvS0X5cLhe6rpOV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RPHx8cI+VlFRQfv27SMAdPLkScrOzqaysrI6YVqttt71xsXFkYODAw0ZMoTOnj1Lhw4doqCgIHruueeEOHfvp4wx1pDi4mKKjIykl19+mbKzsyk7O1s4P919Pk1KSqINGzZQcnIypaen05tvvkn29vZ07do1YXnR0dE0e/Zs4XND7fTZs2dJLpfTK6+8QklJSXThwgVat24d3b5922jetFot3bhxg5RKJU2fPp1SUlJox44d5OnpSXFxcQb5cHR0pHnz5lFqaiqlpqZSQkICSSQSunXrlhBv+/bt5ODgQHfu3Gmwrsy5LunUqRM5OzvTqlWr6MqVK8Lk4OBAq1evpvT0dEpISKCwsDCaOHEiEREVFBRQhw4daOnSpUI5iajBdKbWFx8fT3Z2dvTII4/Q77//TocOHSIPDw8aPnw4jRkzhi5evEj/+9//SCaT0datWxsst63nj4hoxIgRFBoaSomJiXT69GmKiooihUJBq1evFuLUvgbLzs6mnj170ty5cyk7O5vu3LljNKw+llyr1VwfsLaLO93M6iorK0mpVNKxY8cMwidNmkTjxo0TTjj79u0T5i1fvpwAUEZGhhA2depUio2NFT5HR0dTSEgI6fV6IWzBggUUEhJCRETXrl0jiURCN2/eNFjv0KFDadGiRURENG7cOHrssccM5o8dO9ag0x0ZGUnTp083iBMREdFgp/vBBx80SDNw4EBasGABERHt2bOHpFKp0DAREf36668Wd7prfwmh0WioQ4cO9P777xPRXyfynTt3CnEa2ha109VuACxJV3t9xupCq9WSg4MDvfjii0JYdnY2AaDExMQGy27r+Vu0aBH16NHDIGzBggUmO91E1ReVAOjq1av1htUnLi6OJBIJ3bhxQwjbs2cPicViYT/jTjdjrDHu7iibOp8a07NnT1q3bp3RZZnbTg8aNMjsvBER/etf/6Lg4GCD64P169eTo6Mj6XQ6IV1YWFid5fXo0UNoR4mInnzySYNOYn0aui4hqu5kjh492iDdpEmTaMqUKQZhR44cIbFYTCqVSkhXu4NoSbq71xcfH08A6MqVK0LY1KlTSalUGnQkY2NjaerUqWaV3Zbzl5aWJnyJXSMlJYUAmOx0ExGFhoYafFFjKswUS67VuNPd9tnmw5asTbly5QoqKirwyCOPGISr1WqEhYUJn/v06SP87+3tDaVS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",
      "text/plain": [
       "<Figure size 1000x800 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from scipy import stats\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "# --- Bootstrap configuration ---\n",
    "N_BOOT = 1000  # adjust if needed\n",
    "SAMPLE_TERM = 10\n",
    "SAMPLE_PRETERM = 10\n",
    "EARLY_SESSIONS = {1,2,3}\n",
    "LATE_SESSION = {5}\n",
    "\n",
    "REQUIRED_COLS = [\n",
    "    'participant_id','Cohort','session_no','task_type',\n",
    "    'exploration_exploitation_ratio','exploration_exploitation_ratio_traj'\n",
    "]\n",
    "\n",
    "# Validate data availability\n",
    "if 'df_compare' not in globals() or df_compare is None or df_compare.empty:\n",
    "    raise RuntimeError('df_compare not available; run earlier cells to build comparison dataframe.')\n",
    "\n",
    "work_df = df_compare.copy()\n",
    "\n",
    "# Ensure cohort present (attempt attach if missing)\n",
    "if 'Cohort' not in work_df.columns:\n",
    "    print('Cohort column missing; attempting to attach.')\n",
    "    try:\n",
    "        # Reuse attach_cohort if defined earlier\n",
    "        work_df = attach_cohort(work_df) if 'attach_cohort' in globals() else work_df\n",
    "    except Exception as e:\n",
    "        print('Failed to attach cohort:', e)\n",
    "\n",
    "missing = [c for c in REQUIRED_COLS if c not in work_df.columns]\n",
    "if missing:\n",
    "    raise RuntimeError(f'Missing required columns for bootstrap: {missing}')\n",
    "\n",
    "# Filter to rows with valid ratios\n",
    "work_df = work_df.dropna(subset=['exploration_exploitation_ratio','exploration_exploitation_ratio_traj','session_no','Cohort'])\n",
    "\n",
    "# Map cohort labels to canonical Term / Preterm\n",
    "def cohort_label(c):\n",
    "    c_lower = str(c).lower()\n",
    "    if 'pre' in c_lower:\n",
    "        return 'Preterm'\n",
    "    if 'term' in c_lower:\n",
    "        return 'Term'\n",
    "    return None\n",
    "work_df['CohortCanonical'] = work_df['Cohort'].apply(cohort_label)\n",
    "work_df = work_df.dropna(subset=['CohortCanonical'])\n",
    "\n",
    "# Collect participant lists\n",
    "term_participants = work_df.loc[work_df['CohortCanonical']=='Term','participant_id'].unique().tolist()\n",
    "preterm_participants = work_df.loc[work_df['CohortCanonical']=='Preterm','participant_id'].unique().tolist()\n",
    "print(f'Available Term participants: {len(term_participants)}; Preterm participants: {len(preterm_participants)}')\n",
    "\n",
    "if len(term_participants) == 0 or len(preterm_participants) == 0:\n",
    "    raise RuntimeError('Insufficient participants for both cohorts; cannot bootstrap.')\n",
    "\n",
    "# Helper: compute per-participant phase means for given ratio column\n",
    "def participant_phase_means(df, ratio_col):\n",
    "    sub = df[['participant_id','session_no',ratio_col,'task_type','CohortCanonical']].copy()\n",
    "    # Early mean: sessions 1,2,3; Late mean: session 5; Mid (optional) session 4\n",
    "    early = sub[sub['session_no'].isin(EARLY_SESSIONS)].groupby('participant_id')[ratio_col].mean()\n",
    "    late = sub[sub['session_no'].isin(LATE_SESSION)].groupby('participant_id')[ratio_col].mean()\n",
    "    return early, late\n",
    "\n",
    "# Helper: bimanual (task_type==1) overall mean per participant\n",
    "def bimanual_means(df, ratio_col):\n",
    "    bi = df[df['task_type']==1]\n",
    "    return bi.groupby(['participant_id','CohortCanonical'])[ratio_col].mean()\n",
    "\n",
    "# Bootstrap containers\n",
    "boot_results = {\n",
    "    'embedding_early_late_diff': [],\n",
    "    'trajectory_early_late_diff': [],\n",
    "    'embedding_preterm_term_diff_bi': [],\n",
    "    'trajectory_preterm_term_diff_bi': []\n",
    "}\n",
    "\n",
    "rng = np.random.default_rng(42)\n",
    "\n",
    "for b in range(N_BOOT):\n",
    "    # Sample participants (with replacement if fewer than requested)\n",
    "    sampled_term = rng.choice(term_participants, size=min(SAMPLE_TERM, len(term_participants)), replace=len(term_participants)<SAMPLE_TERM)\n",
    "    sampled_preterm = rng.choice(preterm_participants, size=min(SAMPLE_PRETERM, len(preterm_participants)), replace=len(preterm_participants)<SAMPLE_PRETERM)\n",
    "    sampled_ids = np.concatenate([sampled_term, sampled_preterm])\n",
    "    sample_df = work_df[work_df['participant_id'].isin(sampled_ids)]\n",
    "\n",
    "    # Early vs Late embedding\n",
    "    emb_early, emb_late = participant_phase_means(sample_df, 'exploration_exploitation_ratio')\n",
    "    # Align idx intersection\n",
    "    common_emb = emb_early.index.intersection(emb_late.index)\n",
    "    if len(common_emb) >= 3:\n",
    "        boot_results['embedding_early_late_diff'].append((emb_early.loc[common_emb] - emb_late.loc[common_emb]).mean())\n",
    "    else:\n",
    "        boot_results['embedding_early_late_diff'].append(np.nan)\n",
    "\n",
    "    # Early vs Late trajectory\n",
    "    traj_early, traj_late = participant_phase_means(sample_df, 'exploration_exploitation_ratio_traj')\n",
    "    common_traj = traj_early.index.intersection(traj_late.index)\n",
    "    if len(common_traj) >= 3:\n",
    "        boot_results['trajectory_early_late_diff'].append((traj_early.loc[common_traj] - traj_late.loc[common_traj]).mean())\n",
    "    else:\n",
    "        boot_results['trajectory_early_late_diff'].append(np.nan)\n",
    "\n",
    "    # Bimanual cohort difference embedding\n",
    "    emb_bi = bimanual_means(sample_df, 'exploration_exploitation_ratio')\n",
    "    if not emb_bi.empty:\n",
    "        pre_mean = emb_bi.xs('Preterm', level='CohortCanonical', drop_level=False).mean() if 'Preterm' in emb_bi.index.get_level_values('CohortCanonical') else np.nan\n",
    "        term_mean = emb_bi.xs('Term', level='CohortCanonical', drop_level=False).mean() if 'Term' in emb_bi.index.get_level_values('CohortCanonical') else np.nan\n",
    "        boot_results['embedding_preterm_term_diff_bi'].append(pre_mean - term_mean if pd.notna(pre_mean) and pd.notna(term_mean) else np.nan)\n",
    "    else:\n",
    "        boot_results['embedding_preterm_term_diff_bi'].append(np.nan)\n",
    "\n",
    "    # Bimanual cohort difference trajectory\n",
    "    traj_bi = bimanual_means(sample_df, 'exploration_exploitation_ratio_traj')\n",
    "    if not traj_bi.empty:\n",
    "        pre_mean_t = traj_bi.xs('Preterm', level='CohortCanonical', drop_level=False).mean() if 'Preterm' in traj_bi.index.get_level_values('CohortCanonical') else np.nan\n",
    "        term_mean_t = traj_bi.xs('Term', level='CohortCanonical', drop_level=False).mean() if 'Term' in traj_bi.index.get_level_values('CohortCanonical') else np.nan\n",
    "        boot_results['trajectory_preterm_term_diff_bi'].append(pre_mean_t - term_mean_t if pd.notna(pre_mean_t) and pd.notna(term_mean_t) else np.nan)\n",
    "    else:\n",
    "        boot_results['trajectory_preterm_term_diff_bi'].append(np.nan)\n",
    "\n",
    "# Convert to DataFrame for summary\n",
    "boot_df = pd.DataFrame({k: pd.Series(v) for k,v in boot_results.items()})\n",
    "\n",
    "def summary_stats(series):\n",
    "    s = series.dropna()\n",
    "    if len(s)==0:\n",
    "        return {'mean':np.nan,'ci_low':np.nan,'ci_high':np.nan,'n':0}\n",
    "    return {\n",
    "        'mean': s.mean(),\n",
    "        'ci_low': np.percentile(s, 2.5),\n",
    "        'ci_high': np.percentile(s, 97.5),\n",
    "        'n': len(s)\n",
    "    }\n",
    "\n",
    "summary = {k: summary_stats(boot_df[k]) for k in boot_df.columns}\n",
    "\n",
    "print('=== Bootstrap Results (Mean Difference ±95% CI) ===')\n",
    "print('Hypothesis 1a: Early - Late (Embedding): {mean:.4f} [{ci_low:.4f}, {ci_high:.4f}] (n={n})'.format(**summary['embedding_early_late_diff']))\n",
    "print('Hypothesis 1a: Early - Late (Trajectory): {mean:.4f} [{ci_low:.4f}, {ci_high:.4f}] (n={n})'.format(**summary['trajectory_early_late_diff']))\n",
    "print('Hypothesis 1b: Preterm - Term Bimanual (Embedding): {mean:.4f} [{ci_low:.4f}, {ci_high:.4f}] (n={n})'.format(**summary['embedding_preterm_term_diff_bi']))\n",
    "print('Hypothesis 1b: Preterm - Term Bimanual (Trajectory): {mean:.4f} [{ci_low:.4f}, {ci_high:.4f}] (n={n})'.format(**summary['trajectory_preterm_term_diff_bi']))\n",
    "\n",
    "# Plot distributions\n",
    "fig, axes = plt.subplots(2,2, figsize=(10,8))\n",
    "plot_map = [\n",
    "    ('embedding_early_late_diff','Early-Late (Embedding)'),\n",
    "    ('trajectory_early_late_diff','Early-Late (Trajectory)'),\n",
    "    ('embedding_preterm_term_diff_bi','Preterm-Term Bimanual (Embedding)'),\n",
    "    ('trajectory_preterm_term_diff_bi','Preterm-Term Bimanual (Trajectory)')\n",
    "]\n",
    "for ax,(col,title) in zip(axes.flat, plot_map):\n",
    "    s = boot_df[col].dropna()\n",
    "    if len(s)>0:\n",
    "        sns.histplot(s, bins=30, kde=True, ax=ax, color='steelblue')\n",
    "        ax.axvline(summary[col]['mean'], color='red', linestyle='--', label='Mean')\n",
    "        ax.axvspan(summary[col]['ci_low'], summary[col]['ci_high'], color='orange', alpha=0.2, label='95% CI')\n",
    "        ax.set_title(title)\n",
    "        ax.legend()\n",
    "    else:\n",
    "        ax.set_title(title + ' (no data)')\n",
    "    ax.grid(alpha=0.3)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "# Store summary for potential downstream use\n",
    "bootstrap_summary_h1 = summary\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "id": "f233e983-71d3-4579-976d-b8567257452c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Saved bootstrap distribution figure to plots/bootstrap_EE_distributions_20251123_043642.png\n"
     ]
    }
   ],
   "source": [
    "# Save bootstrap distribution figure as PNG\n",
    "import os, datetime\n",
    "out_dir = 'plots'\n",
    "os.makedirs(out_dir, exist_ok=True)\n",
    "\n",
    "timestamp = datetime.datetime.now().strftime('%Y%m%d_%H%M%S')\n",
    "filename = f'bootstrap_EE_distributions_{timestamp}.png'\n",
    "\n",
    "if 'fig' in globals() and fig is not None:\n",
    "    try:\n",
    "        fig.savefig(os.path.join(out_dir, filename), dpi=300, bbox_inches='tight')\n",
    "        print(f'Saved bootstrap distribution figure to {out_dir}/{filename}')\n",
    "    except Exception as e:\n",
    "        print('Failed to save existing figure, regenerating:', e)\n",
    "        # Regenerate and save\n",
    "        fig, axes = plt.subplots(2,2, figsize=(10,8))\n",
    "        plot_map = [\n",
    "            ('embedding_early_late_diff','Early-Late (Embedding)'),\n",
    "            ('trajectory_early_late_diff','Early-Late (Trajectory)'),\n",
    "            ('embedding_preterm_term_diff_bi','Preterm-Term Bimanual (Embedding)'),\n",
    "            ('trajectory_preterm_term_diff_bi','Preterm-Term Bimanual (Trajectory)')\n",
    "        ]\n",
    "        for ax,(col,title) in zip(axes.flat, plot_map):\n",
    "            s = boot_df[col].dropna()\n",
    "            if len(s)>0:\n",
    "                sns.histplot(s, bins=30, kde=True, ax=ax, color='steelblue')\n",
    "                ax.axvline(bootstrap_summary_h1[col]['mean'], color='red', linestyle='--', label='Mean')\n",
    "                ax.axvspan(bootstrap_summary_h1[col]['ci_low'], bootstrap_summary_h1[col]['ci_high'], color='orange', alpha=0.2, label='95% CI')\n",
    "                ax.set_title(title)\n",
    "                ax.legend()\n",
    "            else:\n",
    "                ax.set_title(title + ' (no data)')\n",
    "            ax.grid(alpha=0.3)\n",
    "        plt.tight_layout()\n",
    "        fig.savefig(os.path.join(out_dir, filename), dpi=300, bbox_inches='tight')\n",
    "        print(f'Regenerated and saved bootstrap distribution figure to {out_dir}/{filename}')\n",
    "else:\n",
    "    print('Figure variable \"fig\" not found; regenerating before saving.')\n",
    "    fig, axes = plt.subplots(2,2, figsize=(10,8))\n",
    "    plot_map = [\n",
    "        ('embedding_early_late_diff','Early-Late (Embedding)'),\n",
    "        ('trajectory_early_late_diff','Early-Late (Trajectory)'),\n",
    "        ('embedding_preterm_term_diff_bi','Preterm-Term Bimanual (Embedding)'),\n",
    "        ('trajectory_preterm_term_diff_bi','Preterm-Term Bimanual (Trajectory)')\n",
    "    ]\n",
    "    for ax,(col,title) in zip(axes.flat, plot_map):\n",
    "        s = boot_df[col].dropna()\n",
    "        if len(s)>0:\n",
    "            sns.histplot(s, bins=30, kde=True, ax=ax, color='steelblue')\n",
    "            ax.axvline(bootstrap_summary_h1[col]['mean'], color='red', linestyle='--', label='Mean')\n",
    "            ax.axvspan(bootstrap_summary_h1[col]['ci_low'], bootstrap_summary_h1[col]['ci_high'], color='orange', alpha=0.2, label='95% CI')\n",
    "            ax.set_title(title)\n",
    "            ax.legend()\n",
    "        else:\n",
    "            ax.set_title(title + ' (no data)')\n",
    "        ax.grid(alpha=0.3)\n",
    "    plt.tight_layout()\n",
    "    fig.savefig(os.path.join(out_dir, filename), dpi=300, bbox_inches='tight')\n",
    "    print(f'Regenerated and saved bootstrap distribution figure to {out_dir}/{filename}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2379a3cc-f353-4cb4-8747-938550b2eb8a",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
