{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b9e2d729",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "True\n",
      "11.7\n",
      "NVIDIA RTX 6000 Ada Generation\n",
      "2\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "48"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "print(torch.cuda.is_available())   # should be True\n",
    "print(torch.version.cuda)          # CUDA version PyTorch is built with\n",
    "print(torch.cuda.get_device_name(0)) if torch.cuda.is_available() else None\n",
    "print(torch.cuda.device_count())\n",
    "import os\n",
    "os.cpu_count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fe4f5248",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "from typing import Dict, Tuple, List, Optional\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import logging\n",
    "logger = logging.getLogger(__name__)\n",
    "\n",
    "def load_ap1_data_from_csv(csv_filepath: str, replicate: Optional[int] = None) -> Dict[str, np.ndarray]:\n",
    "    \"\"\"\n",
    "    Loads AP1 single-cell data from CSV or Excel file.\n",
    "\n",
    "    Args:\n",
    "        csv_filepath: Path to the CSV or Excel file\n",
    "\n",
    "    Returns:\n",
    "        Dictionary with condition identifiers as keys and feature matrices as values\n",
    "    \"\"\"\n",
    "    logger.info(f\"Loading data from: {csv_filepath}\")\n",
    "\n",
    "    # Load the data based on file extension\n",
    "    if csv_filepath.endswith('.csv'):\n",
    "        df = pd.read_csv(csv_filepath)\n",
    "    elif csv_filepath.endswith('.xlsx'):\n",
    "        df = pd.read_excel(csv_filepath)\n",
    "    else:\n",
    "        raise ValueError(\"Unsupported file format. Please provide a .csv or .xlsx file.\")\n",
    "    \n",
    "    replacement_map = {\n",
    "                        '0.316 uM Vemurafenib': 'Vem',\n",
    "                        '0.316 uM Vem + 0.0316 uM Tram': 'Vem+Tram'\n",
    "                        }\n",
    "    df['condition'] = df['condition'].replace(replacement_map)\n",
    "\n",
    "    print(df['condition'].unique())\n",
    "\n",
    "    # Define AP1 protein features (these are in log space already)\n",
    "    ap1_features = [\n",
    "        'cFOS (log a.u.)', 'p-cFOS (log a.u.)', 'FRA1 (log a.u.)', 'p-FRA1 (log a.u.)', 'FRA2 (log a.u.)',\n",
    "        'cJUN (log a.u.)', 'p-cJUN (log a.u.)', 'JUNB (log a.u.)', 'JUND (log a.u.)', 'p-ATF1 (log a.u.)',\n",
    "        'ATF2 (log a.u.)',\t 'p-ATF2 (log a.u.)', 'ATF3 (log a.u.)', 'ATF4 (log a.u.)', 'p-ATF4 (log a.u.)',\n",
    "        'ATF5 (log a.u.)', 'ATF6 (log a.u.)', 'MITF (log a.u.)', 'NGFR (log a.u.)', 'p-ERK (log a.u.)',\n",
    "    ]\n",
    "\n",
    "    # Check if all features exist\n",
    "    missing_features = [f for f in ap1_features if f not in df.columns]\n",
    "    if missing_features:\n",
    "        logger.warning(f\"Missing features: {missing_features}\")\n",
    "        ap1_features = [f for f in ap1_features if f in df.columns]\n",
    "\n",
    "    logger.info(f\"Using {len(ap1_features)} AP1 features\")\n",
    "\n",
    "    # Create condition-based data dictionary\n",
    "    data_dict = {}\n",
    "\n",
    "    if replicate is not None:\n",
    "        # Group by condition, time, and cell line\n",
    "        for (condition, time, cell_line, replicate_id), group in df.groupby(['condition', 'time', 'cell_line', 'replicate_id']):\n",
    "            # Create condition identifier\n",
    "            condition_id = f\"{cell_line}_{condition}_{time.replace(' ', '')}_rep{replicate_id}\"\n",
    "\n",
    "            # Extract feature matrix\n",
    "            feature_matrix = group[ap1_features].values\n",
    "\n",
    "            # Remove rows with any NaN values\n",
    "            valid_rows = ~np.isnan(feature_matrix).any(axis=1)\n",
    "            feature_matrix = feature_matrix[valid_rows]\n",
    "\n",
    "            if len(feature_matrix) > 0:\n",
    "                data_dict[condition_id] = feature_matrix\n",
    "                logger.info(f\"Loaded {condition_id}: {feature_matrix.shape}\")\n",
    "            else:\n",
    "                logger.warning(f\"No valid data for {condition_id}\")\n",
    "    else:\n",
    "        # Group by condition, time, and cell line\n",
    "        for (condition, time, cell_line), group in df.groupby(['condition', 'time', 'cell_line']):\n",
    "            # Create condition identifier\n",
    "            condition_id = f\"{cell_line}_{condition}_{time.replace(' ', '')}\"\n",
    "\n",
    "            # Extract feature matrix\n",
    "            feature_matrix = group[ap1_features].values\n",
    "\n",
    "            # Remove rows with any NaN values\n",
    "            valid_rows = ~np.isnan(feature_matrix).any(axis=1)\n",
    "            feature_matrix = feature_matrix[valid_rows]\n",
    "\n",
    "            if len(feature_matrix) > 0:\n",
    "                data_dict[condition_id] = feature_matrix\n",
    "                logger.info(f\"Loaded {condition_id}: {feature_matrix.shape}\")\n",
    "            else:\n",
    "                logger.warning(f\"No valid data for {condition_id}\")\n",
    "\n",
    "    return data_dict\n",
    "\n",
    "def prepare_pair_from_mat(cell_line: str,\n",
    "                          baseline_condition: str, baseline_time: str,\n",
    "                          target_condition: str, target_time: str,\n",
    "                          replicate: Optional[int] = None) -> Tuple[np.ndarray, np.ndarray]:\n",
    "    print(\"Cell line: \", cell_line)\n",
    "    raw_data_dict = load_ap1_data_from_csv('mmc5.xlsx', replicate)\n",
    "\n",
    "    if replicate is not None:\n",
    "        pre_key = f\"{cell_line}_{baseline_condition}_{baseline_time}_rep{replicate}\"\n",
    "        post_key = f\"{cell_line}_{target_condition}_{target_time}_rep{replicate}\"\n",
    "    else:\n",
    "        pre_key = f\"{cell_line}_{baseline_condition}_{baseline_time}\"\n",
    "        post_key = f\"{cell_line}_{target_condition}_{target_time}\"\n",
    "\n",
    "    if pre_key not in raw_data_dict or post_key not in raw_data_dict:\n",
    "        raise ValueError(f\"Pair not found: {pre_key}, {post_key}\")\n",
    "\n",
    "    # Equalize N\n",
    "    n = min(len(raw_data_dict[pre_key]), len(raw_data_dict[post_key]))\n",
    "    X_pre_raw = raw_data_dict[pre_key][:n]\n",
    "    X_post_raw = raw_data_dict[post_key][:n]\n",
    "    return X_pre_raw, X_post_raw\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "75d3cecc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import json\n",
    "import logging\n",
    "import argparse\n",
    "import geomloss\n",
    "import random\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import TensorDataset, DataLoader\n",
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "from typing import Dict, Tuple, List, Optional\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "from sklearn.preprocessing import StandardScaler, MinMaxScaler\n",
    "from sklearn.metrics.pairwise import rbf_kernel\n",
    "from typing import Dict, Tuple, List\n",
    "from scipy.stats import ks_2samp\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.metrics import r2_score\n",
    "\n",
    "import gc\n",
    "gc.collect()\n",
    "\n",
    "def median_heuristic_gamma(X: np.ndarray, Y: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    Median heuristic for RBF bandwidth: gamma = 1 / median(||x - y||^2).\n",
    "    Uses the median of pairwise distances in the pooled set.\n",
    "    \"\"\"\n",
    "    Z = np.vstack([X, Y])\n",
    "    # Sample if too large for efficiency\n",
    "    max_samples = 5000\n",
    "    if Z.shape[0] > max_samples:\n",
    "        idx = np.random.choice(Z.shape[0], size=max_samples, replace=False)\n",
    "        Z = Z[idx]\n",
    "    D2 = cdist(Z, Z, metric='sqeuclidean')\n",
    "    # Use upper triangular without diagonal\n",
    "    triu = D2[np.triu_indices_from(D2, k=1)]\n",
    "    med = np.median(triu[triu > 0]) if np.any(triu > 0) else 1.0\n",
    "    return 1.0 / max(med, 1e-12)\n",
    "\n",
    "def mmd_distance(X: np.ndarray, Y: np.ndarray, gamma: float) -> float:\n",
    "    \"\"\"\n",
    "    Unbiased MMD^2 estimator using Gaussian (RBF) kernel, sklearn backend.\n",
    "\n",
    "    Args:\n",
    "        X: (n_samples, n_features) first sample\n",
    "        Y: (m_samples, n_features) second sample\n",
    "        gamma: RBF kernel bandwidth; if None, uses median heuristic\n",
    "\n",
    "    Returns:\n",
    "        Unbiased MMD^2 value\n",
    "    \"\"\"\n",
    "    n = X.shape[0]\n",
    "    m = Y.shape[0]\n",
    "\n",
    "    # Kernel matrices\n",
    "    Kxx = rbf_kernel(X, X, gamma=gamma)\n",
    "    Kyy = rbf_kernel(Y, Y, gamma=gamma)\n",
    "    Kxy = rbf_kernel(X, Y, gamma=gamma)\n",
    "\n",
    "    # Unbiased: exclude diagonal entries\n",
    "    np.fill_diagonal(Kxx, 0.0)\n",
    "    np.fill_diagonal(Kyy, 0.0)\n",
    "\n",
    "    term_xx = Kxx.sum() / (n * (n - 1)) if n > 1 else 0.0\n",
    "    term_yy = Kyy.sum() / (m * (m - 1)) if m > 1 else 0.0\n",
    "    term_xy = 2.0 * Kxy.mean()\n",
    "\n",
    "    mmd2 = term_xx + term_yy - term_xy\n",
    "    mmd2 = max(mmd2, 0.0)  # Numerical stability\n",
    "    return float(mmd2)\n",
    "\n",
    "def r2_feature_means(y_true: np.ndarray, y_pred: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    R^2 computed across features between mean vectors of y_true and y_pred.\n",
    "    \"\"\"\n",
    "    mu_true = y_true.mean(axis=0)\n",
    "    mu_pred = y_pred.mean(axis=0)\n",
    "    ss_res = float(np.sum((mu_true - mu_pred) ** 2))\n",
    "    ss_tot = float(np.sum((mu_true - mu_true.mean()) ** 2))\n",
    "    if ss_tot <= 1e-12:\n",
    "        return 1.0 if ss_res <= 1e-12 else 0.0\n",
    "    return 1.0 - ss_res / ss_tot\n",
    "\n",
    "def wasserstein_pointcloud(\n",
    "    X,\n",
    "    Y,\n",
    "    p: int = 2,\n",
    "    a=None,\n",
    "    b=None,\n",
    "    method: str = \"emd\",          # \"emd\" (exact) or \"sinkhorn\" (approx)\n",
    "    reg: float = 1e-1,            # Sinkhorn regularization (only used if method=\"sinkhorn\")\n",
    "    return_plan: bool = False,\n",
    "):\n",
    "    \"\"\"\n",
    "    Compute Wasserstein distance W_p between two empirical distributions supported on point sets X and Y.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    X : (n, d) array-like\n",
    "        Source points.\n",
    "    Y : (m, d) array-like\n",
    "        Target points.\n",
    "    p : int\n",
    "        Order of the Wasserstein distance (commonly 1 or 2).\n",
    "    a : (n,) array-like or None\n",
    "        Weights for X; if None, uniform weights.\n",
    "    b : (m,) array-like or None\n",
    "        Weights for Y; if None, uniform weights.\n",
    "    method : str\n",
    "        \"emd\" for exact optimal transport (requires POT),\n",
    "        \"sinkhorn\" for entropic approximation (requires POT).\n",
    "    reg : float\n",
    "        Entropic regularization strength for Sinkhorn.\n",
    "    return_plan : bool\n",
    "        If True, also return the optimal transport plan.\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    Wp : float\n",
    "        Wasserstein distance of order p.\n",
    "    plan : (n, m) ndarray, optional\n",
    "        Optimal transport plan (only if return_plan=True).\n",
    "    \"\"\"\n",
    "    X = np.asarray(X, dtype=np.float64)\n",
    "    Y = np.asarray(Y, dtype=np.float64)\n",
    "    if X.ndim != 2 or Y.ndim != 2:\n",
    "        raise ValueError(\"X and Y must be 2D arrays with shape (n, d) and (m, d).\")\n",
    "    if X.shape[1] != Y.shape[1]:\n",
    "        raise ValueError(f\"Dimension mismatch: X has d={X.shape[1]}, Y has d={Y.shape[1]}.\")\n",
    "\n",
    "    n, d = X.shape\n",
    "    m, _ = Y.shape\n",
    "\n",
    "    if a is None:\n",
    "        a = np.full(n, 1.0 / n, dtype=np.float64)\n",
    "    else:\n",
    "        a = np.asarray(a, dtype=np.float64)\n",
    "        a = a / a.sum()\n",
    "\n",
    "    if b is None:\n",
    "        b = np.full(m, 1.0 / m, dtype=np.float64)\n",
    "    else:\n",
    "        b = np.asarray(b, dtype=np.float64)\n",
    "        b = b / b.sum()\n",
    "\n",
    "    # Cost matrix: C_ij = ||x_i - y_j||^p\n",
    "    # Compute squared Euclidean via (x-y)^2 = x^2 + y^2 - 2xy for speed\n",
    "    X2 = np.sum(X * X, axis=1, keepdims=True)          # (n, 1)\n",
    "    Y2 = np.sum(Y * Y, axis=1, keepdims=True).T        # (1, m)\n",
    "    sq = np.maximum(X2 + Y2 - 2.0 * (X @ Y.T), 0.0)     # (n, m)\n",
    "    if p == 2:\n",
    "        C = sq\n",
    "    else:\n",
    "        C = sq ** (p / 2.0)\n",
    "\n",
    "    try:\n",
    "        import ot  # POT: Python Optimal Transport\n",
    "    except ImportError as e:\n",
    "        raise ImportError(\n",
    "            \"This function requires the POT library. Install with: pip install pot\"\n",
    "        ) from e\n",
    "\n",
    "    method = method.lower()\n",
    "    if method == \"emd\":\n",
    "        # exact OT: minimizes <P, C>\n",
    "        P = ot.emd(a, b, C)\n",
    "        cost = float(np.sum(P * C))\n",
    "    elif method == \"sinkhorn\":\n",
    "        # entropic OT approximation\n",
    "        P = ot.sinkhorn(a, b, C, reg=reg)\n",
    "        cost = float(np.sum(P * C))\n",
    "    else:\n",
    "        raise ValueError('method must be either \"emd\" or \"sinkhorn\".')\n",
    "\n",
    "    Wp = cost ** (1.0 / p)\n",
    "\n",
    "    if return_plan:\n",
    "        return Wp, P\n",
    "    return Wp\n",
    "\n",
    "def summarize_metrics(y_true: np.ndarray, y_pred: np.ndarray, median_gamma: float) -> dict:\n",
    "    \"\"\"\n",
    "    Compute a standard set of metrics: MMD^2 (RBF), R^2 of feature means, median KS across features, and Wasserstein distance.\n",
    "    \"\"\"\n",
    "    # Drop any samples that contain NaNs in either true or pred\n",
    "    mask = (~np.isnan(y_true).any(axis=1)) & (~np.isnan(y_pred).any(axis=1))\n",
    "    if mask.sum() < len(y_true):\n",
    "        print(f\"[summarize_metrics] Dropping {len(y_true) - mask.sum()} samples with NaNs.\")\n",
    "    \n",
    "    y_true = y_true[mask]\n",
    "    y_pred = y_pred[mask]\n",
    "\n",
    "    out = {}\n",
    "\n",
    "    out['mmd2_gamma_median'] = mmd_distance(y_true, y_pred, gamma=median_gamma)\n",
    "    out['mmd2_gamma_0.5'] = mmd_distance(y_true, y_pred, gamma=0.5)\n",
    "    out['mmd2_gamma_1.0'] = mmd_distance(y_true, y_pred, gamma=1.0)\n",
    "    out['wasserstein_distance'] = wasserstein_pointcloud(y_true, y_pred, p=2, method=\"emd\")\n",
    "    out['R2_feature_means'] = r2_feature_means(y_true, y_pred)\n",
    "    return out\n",
    "\n",
    "def split_train_test(X: np.ndarray, Y: np.ndarray, train_fraction: float, seed: int = 42) -> Tuple[np.ndarray, np.ndarray, np.ndarray, np.ndarray]:\n",
    "    if X.shape[0] != Y.shape[0]:\n",
    "        min_len = min(len(X), len(Y))\n",
    "        X = X[:min_len]\n",
    "        Y = Y[:min_len]\n",
    "\n",
    "    n = X.shape[0]\n",
    "    n_train = max(1, int(n * train_fraction))\n",
    "    rng = np.random.default_rng(seed)\n",
    "    idx = rng.permutation(n)\n",
    "    tr_idx, te_idx = idx[:n_train], idx[n_train:]\n",
    "    return X[tr_idx], X[te_idx], Y[tr_idx], Y[te_idx]\n",
    "\n",
    "def topk_markers(adata, drug: str, k: int = 50, rank_key: str = \"marker_genes-drug-rank\"):\n",
    "    R = adata.varm[rank_key]\n",
    "\n",
    "    # --- get the rank vector for this drug ---\n",
    "    if hasattr(R, \"columns\") and hasattr(R, \"iloc\"):  # pandas DataFrame\n",
    "        if drug in R.columns:\n",
    "            r = R[drug].to_numpy()\n",
    "        else:\n",
    "            # fallback: interpret columns as ordered groups; try to map via rank_genes_groups names\n",
    "            names = adata.uns[\"rank_genes_groups\"][\"names\"]\n",
    "            groups = list(names.dtype.names) if (hasattr(names, \"dtype\") and names.dtype.names is not None) else list(names.columns)\n",
    "            r = R.iloc[:, groups.index(drug)].to_numpy()\n",
    "    else:  # numpy array (or array-like)\n",
    "        names = adata.uns[\"rank_genes_groups\"][\"names\"]\n",
    "        groups = list(names.dtype.names) if (hasattr(names, \"dtype\") and names.dtype.names is not None) else list(names.columns)\n",
    "        r = np.asarray(R)[:, groups.index(drug)]\n",
    "\n",
    "    # smaller rank => stronger marker\n",
    "    idx = np.argsort(r)[:k]\n",
    "    gene_ids = adata.var_names[idx].to_list()\n",
    "    gene_short = (adata.var.iloc[idx][\"gene_short_name\"].to_list()\n",
    "                  if \"gene_short_name\" in adata.var.columns else None)\n",
    "    return gene_ids, gene_short, idx\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "c533daf9",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/pytorch_lightning/utilities/imports.py:22: UserWarning: pkg_resources is deprecated as an API. See https://setuptools.pypa.io/en/latest/pkg_resources.html. The pkg_resources package is slated for removal as early as 2025-11-30. Refrain from using this package or pin to Setuptools<81.\n",
      "  import pkg_resources\n",
      "Global seed set to 0\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/pytorch_lightning/utilities/warnings.py:53: LightningDeprecationWarning: pytorch_lightning.utilities.warnings.rank_zero_deprecation has been deprecated in v1.6 and will be removed in v1.8. Use the equivalent function from the pytorch_lightning.utilities.rank_zero module instead.\n",
      "  new_rank_zero_deprecation(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/pytorch_lightning/utilities/warnings.py:58: LightningDeprecationWarning: The `pytorch_lightning.loggers.base.rank_zero_experiment` is deprecated in v1.7 and will be removed in v1.9. Please use `pytorch_lightning.loggers.logger.rank_zero_experiment` instead.\n",
      "  return new_rank_zero_deprecation(*args, **kwargs)\n"
     ]
    }
   ],
   "source": [
    "import scgen"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c1a97a5a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def SCGEN(\n",
    "    X_tr_pre, Y_tr_post, X_te_pre, Y_te_post,\n",
    "    max_epochs=1000,\n",
    "    batch_size=64,\n",
    "    early_stopping=True,\n",
    "    early_stopping_patience=50,\n",
    "    condition_key=\"condition\",\n",
    "    ctrl_label=\"control\",\n",
    "    stim_label=\"treated\",\n",
    "    cell_type_key=\"cell_type\",\n",
    "    cell_type_label=\"cell\",\n",
    "    n_hidden=256,\n",
    "    n_latent=50,\n",
    "    n_layers=2,\n",
    "    dropout_rate=0.2,\n",
    "    accelerator=\"auto\",   # \"auto\" | \"cpu\" | \"gpu\" | \"mps\"\n",
    "    learning_rate=5e-4,\n",
    "    seed=12345,\n",
    "    verbose=True,\n",
    "    metrics_fn=None,      # e.g., summarize_metrics(y_true, y_pred)\n",
    "):\n",
    "    import numpy as np\n",
    "    import pandas as pd\n",
    "    import random\n",
    "\n",
    "    try:\n",
    "        import anndata as ad\n",
    "        import torch\n",
    "        import scgen\n",
    "        try:\n",
    "            import scvi\n",
    "        except Exception:\n",
    "            scvi = None\n",
    "    except Exception as e:\n",
    "        msg = str(e)\n",
    "        hint = None\n",
    "        if \"scvi._compat\" in msg:\n",
    "            hint = (\n",
    "                \"Likely scGen (PyPI) vs scvi-tools mismatch. \"\n",
    "                \"Try: pip uninstall -y scgen && pip install git+https://github.com/theislab/scgen.git\"\n",
    "            )\n",
    "        return {\"error\": f\"Import failed: {e}\", \"hint\": hint}\n",
    "\n",
    "    # ----------- Validate shapes -----------\n",
    "    X_tr_pre = np.asarray(X_tr_pre); Y_tr_post = np.asarray(Y_tr_post)\n",
    "    X_te_pre = np.asarray(X_te_pre); Y_te_post = np.asarray(Y_te_post)\n",
    "\n",
    "    if any(a.ndim != 2 for a in [X_tr_pre, Y_tr_post, X_te_pre, Y_te_post]):\n",
    "        return {\"error\": \"All inputs must be 2D arrays (n_cells, n_features).\"}\n",
    "    d = X_tr_pre.shape[1]\n",
    "    if any(a.shape[1] != d for a in [Y_tr_post, X_te_pre, Y_te_post]):\n",
    "        return {\"error\": \"Feature dimension mismatch across inputs.\"}\n",
    "\n",
    "    # ----------- Seeds -----------\n",
    "    random.seed(seed); np.random.seed(seed)\n",
    "    try:\n",
    "        torch.manual_seed(seed)\n",
    "        if torch.cuda.is_available():\n",
    "            torch.cuda.manual_seed_all(seed)\n",
    "    except Exception:\n",
    "        pass\n",
    "    if scvi is not None:\n",
    "        try:\n",
    "            scvi.settings.seed = seed\n",
    "        except Exception:\n",
    "            pass\n",
    "\n",
    "    # ----------- Accelerator selection -----------\n",
    "    def _auto_accel():\n",
    "        if torch.cuda.is_available():\n",
    "            return \"gpu\"\n",
    "        if hasattr(torch.backends, \"mps\") and torch.backends.mps.is_available():\n",
    "            return \"mps\"\n",
    "        return \"cpu\"\n",
    "    accelerator_used = _auto_accel() if accelerator == \"auto\" else accelerator\n",
    "\n",
    "    # ----------- Build training AnnData -----------\n",
    "    try:\n",
    "        X_tr_all = np.vstack([X_tr_pre, Y_tr_post]).astype(np.float32, copy=False)\n",
    "        cond_tr = np.array([ctrl_label] * len(X_tr_pre) + [stim_label] * len(Y_tr_post), dtype=object)\n",
    "        ctype_tr = np.array([cell_type_label] * len(X_tr_all), dtype=object)\n",
    "\n",
    "        ad_tr = ad.AnnData(\n",
    "            X_tr_all,\n",
    "            obs=pd.DataFrame({condition_key: cond_tr, cell_type_key: ctype_tr})\n",
    "        )\n",
    "        # avoid \"Observation names are not unique\"\n",
    "        ad_tr.obs_names = [f\"tr_{i}\" for i in range(ad_tr.n_obs)]\n",
    "        ad_tr.var_names = [f\"g_{j}\" for j in range(ad_tr.n_vars)]\n",
    "\n",
    "        scgen.SCGEN.setup_anndata(ad_tr, batch_key=condition_key, labels_key=cell_type_key)\n",
    "\n",
    "        model = scgen.SCGEN(\n",
    "            ad_tr,\n",
    "            n_hidden=n_hidden,\n",
    "            n_latent=n_latent,\n",
    "            n_layers=n_layers,\n",
    "            dropout_rate=dropout_rate,\n",
    "        )\n",
    "\n",
    "        train_kwargs = dict(\n",
    "            max_epochs=int(max_epochs),\n",
    "            batch_size=int(batch_size),\n",
    "            early_stopping=bool(early_stopping),\n",
    "            early_stopping_patience=int(early_stopping_patience),\n",
    "            enable_progress_bar=bool(verbose),\n",
    "            plan_kwargs={\"lr\": float(learning_rate)},\n",
    "        )\n",
    "\n",
    "\n",
    "        model.train(**train_kwargs)\n",
    "\n",
    "    except Exception as e:\n",
    "        return {\"error\": f\"scGen training failed: {e}\"}\n",
    "\n",
    "    # ----------- Predict treated for test controls -----------\n",
    "    try:\n",
    "        ad_te = ad.AnnData(\n",
    "            X_te_pre.astype(np.float32, copy=False),\n",
    "            obs=pd.DataFrame({\n",
    "                condition_key: np.array([ctrl_label] * len(X_te_pre), dtype=object),\n",
    "                cell_type_key: np.array([cell_type_label] * len(X_te_pre), dtype=object),\n",
    "            })\n",
    "        )\n",
    "        ad_te.obs_names = [f\"te_{i}\" for i in range(ad_te.n_obs)]\n",
    "        ad_te.var_names = ad_tr.var_names.copy()  # ensure exact match\n",
    "\n",
    "        # IMPORTANT: pass ONLY adata_to_predict OR celltype_to_predict (not both). :contentReference[oaicite:3]{index=3}\n",
    "        pred_adata, delta = model.predict(\n",
    "            ctrl_key=ctrl_label,\n",
    "            stim_key=stim_label,\n",
    "            adata_to_predict=ad_te,\n",
    "        )\n",
    "\n",
    "        y_pred = np.asarray(pred_adata.X)\n",
    "\n",
    "        if metrics_fn is None:\n",
    "            metrics_fn = globals().get(\"summarize_metrics\", None)\n",
    "\n",
    "        metrics = None\n",
    "        if callable(metrics_fn):\n",
    "            n = min(len(Y_te_post), y_pred.shape[0])\n",
    "            metrics = metrics_fn(Y_te_post[:n], y_pred[:n], median_gamma)\n",
    "\n",
    "        return {\n",
    "            \"y_pred\": y_pred,\n",
    "            \"metrics\": metrics,\n",
    "            \"delta\": delta,\n",
    "            \"model\": model,\n",
    "            \"adata_train\": ad_tr,\n",
    "            \"accelerator_used\": accelerator_used,\n",
    "        }\n",
    "\n",
    "    except Exception as e:\n",
    "        return {\"error\": f\"scGen prediction failed: {e}\"}\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b2a6a182",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cell line:  COLO858\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n",
      "X_pre cells: (3026, 20)\n",
      "X_post cells: (3026, 20)\n",
      "(2420, 20)\n",
      "(606, 20)\n",
      "(2420, 20)\n",
      "(606, 20)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 1234\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.05162262759745905\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55/1000:   6%|███████████▍                                                                                                                                                                                                     | 55/1000 [00:12<03:39,  4.30it/s, loss=0.753, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 63.060. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1235\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.023786174627426826, 'mmd2_gamma_0.5': 0.14842408760197867, 'mmd2_gamma_1.0': 0.17105366188724563, 'wasserstein_distance': 1.1725070762851098, 'R2_feature_means': 0.9540075221651654}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:15<04:15,  3.69it/s, loss=0.784, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 59.753. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1236\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.011263021511409121, 'mmd2_gamma_0.5': 0.10692444164902215, 'mmd2_gamma_1.0': 0.12905775662538288, 'wasserstein_distance': 1.20638436956788, 'R2_feature_means': 0.9864186213140927}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55/1000:   6%|███████████▍                                                                                                                                                                                                     | 55/1000 [00:15<04:23,  3.58it/s, loss=0.768, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 63.424. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1237\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.011737653935130377, 'mmd2_gamma_0.5': 0.08452215626032655, 'mmd2_gamma_1.0': 0.09682969474650172, 'wasserstein_distance': 1.2190680598623767, 'R2_feature_means': 0.9908260589138994}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54/1000:   5%|███████████▎                                                                                                                                                                                                     | 54/1000 [00:16<04:45,  3.31it/s, loss=0.708, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 57.848. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1238\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.024036644152102937, 'mmd2_gamma_0.5': 0.0973414417067413, 'mmd2_gamma_1.0': 0.10001753823906756, 'wasserstein_distance': 1.3649660016101306, 'R2_feature_means': 0.9886349771756325}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 54/1000:   5%|███████████▎                                                                                                                                                                                                     | 54/1000 [00:16<04:49,  3.26it/s, loss=0.733, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 66.811. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1239\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.022173207013221674, 'mmd2_gamma_0.5': 0.11861878362430056, 'mmd2_gamma_1.0': 0.12934920736850675, 'wasserstein_distance': 1.2386023887938116, 'R2_feature_means': 0.9674456723550396}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55/1000:   6%|███████████▍                                                                                                                                                                                                     | 55/1000 [00:16<04:45,  3.30it/s, loss=0.726, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 61.107. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1240\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.005018512514085138, 'mmd2_gamma_0.5': 0.09075475623925933, 'mmd2_gamma_1.0': 0.11576820085760758, 'wasserstein_distance': 1.1179800131983217, 'R2_feature_means': 0.9978700726842221}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55/1000:   6%|███████████▍                                                                                                                                                                                                     | 55/1000 [00:16<04:47,  3.29it/s, loss=0.746, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 61.107. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1241\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.01666047369911161, 'mmd2_gamma_0.5': 0.10468167447770493, 'mmd2_gamma_1.0': 0.11486890412491274, 'wasserstein_distance': 1.141402100330362, 'R2_feature_means': 0.9710727551278339}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:17<04:55,  3.20it/s, loss=0.754, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 59.468. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1242\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.03003040109657995, 'mmd2_gamma_0.5': 0.13591577211978167, 'mmd2_gamma_1.0': 0.13857398130977489, 'wasserstein_distance': 1.2192886756464505, 'R2_feature_means': 0.9325012670459427}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:18<05:04,  3.10it/s, loss=0.748, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 64.645. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1243\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.008437094743591, 'mmd2_gamma_0.5': 0.09901099906258914, 'mmd2_gamma_1.0': 0.11978145088790798, 'wasserstein_distance': 1.1295748044803051, 'R2_feature_means': 0.9924187972884}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55/1000:   6%|███████████▍                                                                                                                                                                                                     | 55/1000 [00:21<06:06,  2.58it/s, loss=0.746, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 65.105. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 metrics: {'mmd2_gamma_median': 0.01871928119211219, 'mmd2_gamma_0.5': 0.11016709665157065, 'mmd2_gamma_1.0': 0.1234378472018896, 'wasserstein_distance': 1.2294736903701005, 'R2_feature_means': 0.9740434308289944}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0172  0.0080\n",
      "mmd2_gamma_0.5        0.1096  0.0199\n",
      "mmd2_gamma_1.0        0.1239  0.0210\n",
      "wasserstein_distance  1.2039  0.0715\n",
      "R2_feature_means      0.9755  0.0203\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/umap/umap_.py:1952: UserWarning: n_jobs value 1 overridden to 1 by setting random_state. Use no seed for parallelism.\n",
      "  warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "image/png": "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yQqSjOZpi4vPJhZbfk/0x9wTbmeveueP+Nrq0FU/7rod+Nvr8TTuoW7DaxHf6cvc07xjTUAoCJCt6QgBTV++TfOONXE1FXX1EdRtXNHjWOiaH/f+7fja6vA07aFt9/oIf4bQfCBJSCZLxHj/7MQiHr/tbO677lT+dNMZCa/LEHfBcNRRR/Hqq6/y/PPPc/jhh3PXXXfx5z//mQULFsT7UoMilh8znvzqV7/i5Zdf5umnn+aLL75g3LhxzJ07l6ampojjbr75Zh544AHWrVtHQUEB8+bNC+3fWLhwIV6vl1WrVrFlyxbuu+8+MjICzqeWlhZOOukkZsyYwfr163nrrbfYv38/559/fsT5n376aSwWC2vWrOGRRx5hwYIFvP7663R0dISOefvtt3G5XPzoRz8CAgECy5Yt45FHHuHLL7/kxhtv5Kc//SkfffQRAHv27OHHP/4x8+bNY+PGjVxxxRXceuutvY5HUCg+8cjf+HbLp6x66yUkQLbY2VlRwcsvv8wrr7zCxo0bATjvvPOoq6tj5cqVfP755xxxxBGcfPLJofHr6OjgBz/4Ae+//z4bNmzg9NNPZ968eVRVVQHwyiuvUFpayu9//3tqa2upra0FAgLl9NNP55xzzmHz5s3885//ZPXq1RGT+KWXXsqePXv48MMPeemll/j73/9OXV1dr/17+OGHWbhwIVdddRVbtmxhxYoVjBs3LvR5X/3pjf0NTVzy80VccuF5fPGft1j5yj8468zToA/H80AYjC0/3GQjdL1Hk01X4YOsoHra8DbvQQiBkGQkSaZ15+puAilYMMfXXt/tM3dDJULTkM22QA1zsw2habgbKkPfHagjPriobN6xJibBaXEUIEkKvqZqdBGo8oYc6JOjdGpISI2YdTESEkhyqP57cLzLS3M5dmrZ8E27/cMf/pAf/vCHiTh1XBjq7J9Op5OHH36Yp556ijPOOAOAxx9/nHfffZf//d//5eabbw4du3jxYk499VQgMImXlpby6quvcv7551NVVcU555zDlM4Sf4ccckjoe3/961+ZMWMG9957b+i9J598klGjRrF9+3YOPfRQAMaPH8/9998fOqa8vJz09HReffVVLrroIgCee+45zjrrLBwOB16vl3vvvZf33nuPWbNmha67evVqHn30UebMmcPDDz9MeXk5DzzwAAATJkwICa6eKCgITA55RSWMnjA9tClLMdvw+XwsW7YsdMzq1av57LPPqKurC/mj/vjHP7J8+XJeeuklrrrqKqZNm8a0adNC57/rrrt49dVXWbFiBddeey25ubkoioLD4aC4+LtEfkuWLGHBggUhv8P48eP5y1/+EupXVVUVK1eu5LPPPuPI6VPRdZXHH3mYyVO/u1Y07r77bv77v/+bG264IfTeUUcdFXN/eqO2thZVVTnvwosZNWokCMGUyZNChWLj6XgezGaxgVZls2aOwNfegPC5EEjIiglzbilCV7vtXu49xfdYJEVB93uQzbZAfQVFwZ4/uH1V4ddECFRPB+nFE/vcZW0rKMfduBtJ6KCYsGZ/16eggKpe/SR+ZyO+9nokxZy0+u/JD1lIAvFO2NUXFRUV+P1+Zs+eHXrPbDbzve99j6+//jri2ODkC5Cbm8uECRNCx1x//fX84he/4J133uGUU07hnHPOYerUQK3bTZs28eGHH4Y0iK7XDwqGI488MuIzk8nE+eefz7PPPstFF12E0+nktdde44UXXgBg586duFyukLAK4vP5mDFjBgBff/01Rx99dI/96Iuum7ZGjx4dEgrBvnV0dHRLg+J2u6moCGSr7Ojo4M477+SNN94ITZxutzukMfTEpk2b2Lx5c4R5SAiBrutUVlayfft2TCYTUyeV422pQQidscUZZGdn9XjOuro69u7dy8knn9zjNfvqT29MmzaNk08+mWlHzGTu3LmcdtppnP2DU3FYdITmC21ui4cDf7CpKgZalc2aWYCuBjRlc0ag7rjUWa8kSF8LvJzxs8mdPJemL99G9zpDPoac8bO7tSFWuvoKfK21aN4OvG21WDNHRBWcQUHiad4LuoqQZJAVNJ8TS+ek727YRXv1Fpq2rERJy0HztCFUf1Lqv8NBKhiGS23erlxxxRXMnTuXN954g3feeYclS5bwwAMPcN1119HR0cG8efOirtJHjBgR+v/p6endPl+wYAFz5syhrq6Od999F7vdzumnnw4QMjG98cYbjBwZmd45UdFkXdvY0dHBiBEj+Pe//93t2OzsbAB++ctf8u677/LHP/6RcePGYbfbOffcc/H5fL1eq729jcsvvoBfXBFQ4ZW07FCyv7KyMrZv3w6A6mxCkuVQFBBCILTopppgfqKeiKU/vaEoCu+++y4ff/wx77zzDg899BC33XYbn6xe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hKJpGrfffjtjx47FbrdTXl7OXXfdFVMit+HEqlWrmDdvHiUlJUiSxPLlyyM+F0Jwxx13MGLECOx2O6eccgo7duxITmNjwBAMSeKjjz5i4cKFfPrpp7z77rv4/X5OO+00nE5nsps2ZKxbt45HH32UqVOnJrspCae5uZnZs2djNptZuXIlX331FQ888AA5OTnJblpCue+++3j44Yf561//ytdff819993H/fffz0MPPZTspsUVp9PJtGnT+Nvf/hb18/vvv5+//OUvPPLII6xdu5b09HTmzp2Lx+MZ4pbGiDBICerq6gQgPvroo2Q3ZUhob28X48ePF++++66YM2eOuOGGG5LdpIRyyy23iOOOOy7ZzRhyzjzzTHHZZZdFvPfjH/9YLFiwIEktSjyAePXVV0OvdV0XxcXF4n/+539C77W0tAir1Sqef/75JLSwbwyNIUVobW0FIDc3N8ktGRoWLlzImWeeySmnnJLspgwJK1asYObMmZx33nkUFhYyY8YMHn/88WQ3K+Ece+yxvP/++2zfvh2ATZs2sXr1as4444wkt2zoqKysZN++fRH3elZWFkcffTSffPJJElvWMymXXfVgRNd1Fi1axOzZszn88MOT3ZyE88ILL/DFF1+wbt26ZDdlyPj22295+OGHuemmm/jNb37DunXruP7667FYLFxyySXJbl7CuPXWW2lra2PixIkoioKmadxzzz0sWLAg2U0bMvbt2wdAUVFRxPtFRUWhz1INQzCkAAsXLmTr1q2sXr062U1JOHv27OGGG27g3XffxWazJbs5Q4au68ycOZN7770XgBkzZrB161YeeeSRA1owvPjiizz77LM899xzTJ48mY0bN7Jo0SJKSkoO6H4PdwxTUpK59tpr+de//sWHH354UNSh+Pzzz6mrq+OII47AZDJhMpn46KOP+Mtf/oLJZELTtGQ3MSGMGDGCww47LOK9SZMmUVVVlaQWDQ0333wzt956KxdccAFTpkzhoosu4sYbb2TJkiXJbtqQUVxcDMD+/fsj3t+/f3/os1TDEAxJQgjBtddey6uvvsoHH3zA2LFjk92kIeHkk09my5YtbNy4MfQ3c+ZMFixYwMaNG1EUJdlNTAizZ8/uFo68fft2Ro8enaQWDQ0ul6tbtTBFUdB1PUktGnrGjh1LcXEx77//fui9trY21q5dy6xZs5LYsp4xTElJYuHChTz33HO89tprOByOkK0xKysLu92e5NYlDofD0c2Pkp6eTl5e3gHtX7nxxhs59thjuffeezn//PP57LPPeOyxx3jssceS3bSEMm/ePO655x7KysqYPHkyGzZs4MEHH+Syyy5LdtPiSkdHBzt37gy9rqysZOPGjeTm5lJWVsaiRYu4++67GT9+PGPHjuX222+npKSE+fPnJ6/RvZHssKiDFSDq39KlS5PdtCHnYAhXFUKI119/XRx++OHCarWKiRMnisceeyzZTUo4bW1t4oYbbhBlZWXCZrOJQw45RNx2223C6/Umu2lx5cMPP4z6PF9yySVCiEDI6u233y6KioqE1WoVJ598sti2bVtyG90LRj0GAwMDA4MIDB+DgYGBgUEEhmAwMDAwMIjAEAwGBgYGBhEYgsHAwMDAIAJDMBgYGBgYRGAIBgMDAwODCAzBYGBgYGAQgSEYDAwMDAwiMASDgYGBgUEEhmAwMDAwMIjAEAwGBgYGBhH8f/UIMPmCceTsAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"Vem\"\n",
    "X_pre, X_post = prepare_pair_from_mat('COLO858', 'DMSO','24h', drug, '72h')\n",
    "jfe_indices = [1, 6, 0, 5, 4, 7, 8, 2, 3, 19]  \n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "X_tr_pre, X_te_pre, Y_tr_post, Y_te_post = split_train_test(X_pre, X_post, 0.8)\n",
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "# Compute median heuristic gamma on training data\n",
    "median_gamma = median_heuristic_gamma(X_tr_pre, Y_tr_post)\n",
    "print(\"Median heuristic gamma:\", median_gamma)\n",
    "\n",
    "\n",
    "all_metrics = []\n",
    "for run in range(10):\n",
    "    print(f\"**************** Run: {run} ****************\")\n",
    "    seed = 1234 + run\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "\n",
    "    out = SCGEN(X_tr_pre[:, jfe_indices], Y_tr_post[:, jfe_indices], X_te_pre[:, jfe_indices], Y_te_post[:, jfe_indices], seed=seed)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post[:, jfe_indices], median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post[:, jfe_indices]\n",
    "target = Y_te_post[:, jfe_indices]\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#C88131\")\n",
    "ax.scatter(y_pred_umap[:, 0], y_pred_umap[:, 1], s=10, alpha=0.7, label='predicted cells', color=\"#1F4D8D\")\n",
    "\n",
    "ax.set_title(f'{drug}')\n",
    "# ax.set_xlabel('UMAP 1')\n",
    "# ax.set_ylabel('UMAP 2')\n",
    "ax.set_aspect('equal', 'box')\n",
    "# Add a legend to distinguish the points\n",
    "ax.legend()\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "# Display the plot\n",
    "plt.savefig(f\"./plots/scgen_on_4i_drug_{drug}.png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "5056be31",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cell line:  WM902B\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n",
      "X_pre cells: (5690, 20)\n",
      "X_post cells: (5690, 20)\n",
      "(4552, 20)\n",
      "(1138, 20)\n",
      "(4552, 20)\n",
      "(1138, 20)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 1234\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.06485749121371297\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:32<09:49,  1.61it/s, loss=0.597, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 61.090. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1235\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.10883506875127225, 'mmd2_gamma_0.5': 0.23275748265251217, 'mmd2_gamma_1.0': 0.2031924863696455, 'wasserstein_distance': 1.4686054519364318, 'R2_feature_means': 0.8335194773242958}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:31<09:20,  1.69it/s, loss=0.577, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 60.910. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1236\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.1308606882088923, 'mmd2_gamma_0.5': 0.2526519316431175, 'mmd2_gamma_1.0': 0.2168343535447418, 'wasserstein_distance': 1.550675533814606, 'R2_feature_means': 0.780755256801148}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:30<08:56,  1.77it/s, loss=0.588, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 57.674. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1237\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.1952477659721823, 'mmd2_gamma_0.5': 0.3571030468309488, 'mmd2_gamma_1.0': 0.289445866700143, 'wasserstein_distance': 1.7874107468635314, 'R2_feature_means': 0.6978173218497687}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:29<08:53,  1.78it/s, loss=0.629, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 60.086. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1238\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.1447567234412932, 'mmd2_gamma_0.5': 0.2600636985856191, 'mmd2_gamma_1.0': 0.22035493320623242, 'wasserstein_distance': 1.6304492460066016, 'R2_feature_means': 0.7405089410473291}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:30<09:03,  1.74it/s, loss=0.575, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 67.216. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1239\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.15704256095816227, 'mmd2_gamma_0.5': 0.34332499536167893, 'mmd2_gamma_1.0': 0.3052216972060351, 'wasserstein_distance': 1.6446458541218612, 'R2_feature_means': 0.7401543122837826}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52/1000:   5%|██████████▊                                                                                                                                                                                                      | 52/1000 [00:30<09:11,  1.72it/s, loss=0.595, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 57.461. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1240\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.15283395404318645, 'mmd2_gamma_0.5': 0.2809305823123218, 'mmd2_gamma_1.0': 0.23039908135936982, 'wasserstein_distance': 1.6582876570526761, 'R2_feature_means': 0.7333782445992303}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:31<09:17,  1.70it/s, loss=0.579, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 61.368. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1241\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.10067608891435609, 'mmd2_gamma_0.5': 0.17649902492279873, 'mmd2_gamma_1.0': 0.1465647516094931, 'wasserstein_distance': 1.5767872947104096, 'R2_feature_means': 0.8242962889140435}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52/1000:   5%|██████████▉                                                                                                                                                                                                       | 52/1000 [00:31<09:32,  1.66it/s, loss=0.59, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 60.284. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1242\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.1441905220238926, 'mmd2_gamma_0.5': 0.28826187184777186, 'mmd2_gamma_1.0': 0.2523138259275306, 'wasserstein_distance': 1.5975613498839367, 'R2_feature_means': 0.7652472655573783}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 52/1000:   5%|██████████▊                                                                                                                                                                                                      | 52/1000 [00:31<09:27,  1.67it/s, loss=0.627, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 65.916. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1243\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.17286970176514416, 'mmd2_gamma_0.5': 0.24263645778944842, 'mmd2_gamma_1.0': 0.19240008110624485, 'wasserstein_distance': 1.8776583621293907, 'R2_feature_means': 0.6287508096873076}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 53/1000:   5%|███████████▏                                                                                                                                                                                                      | 53/1000 [00:31<09:29,  1.66it/s, loss=0.62, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 68.898. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 metrics: {'mmd2_gamma_median': 0.11596557467541535, 'mmd2_gamma_0.5': 0.22977594216125885, 'mmd2_gamma_1.0': 0.20131663625248453, 'wasserstein_distance': 1.4977093708782119, 'R2_feature_means': 0.7985653635532123}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.1423  0.0293\n",
      "mmd2_gamma_0.5        0.2664  0.0539\n",
      "mmd2_gamma_1.0        0.2258  0.0468\n",
      "wasserstein_distance  1.6290  0.1251\n",
      "R2_feature_means      0.7543  0.0612\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/umap/umap_.py:1952: UserWarning: n_jobs value 1 overridden to 1 by setting random_state. Use no seed for parallelism.\n",
      "  warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYYAAADOCAYAAAA6/KVQAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAADki0lEQVR4nOz9d7hkZ3Xni3/enSpXnZw7qaNCKyAJlJBEo4AQCgZbFsZgzNwxY8/YMNyxDf4Ze/yzPVx7bF+ufcfMAINBMhKIICShjCSUs9RSS93qfLpPrlOnTuVdO73v/WNXVZ/qPt1qgQiW6vs8etSnatdOtWutd631Xd8llFKKDjrooIMOOmhA+0WfQAcddNBBB79c6DiGDjrooIMO2tBxDB100EEHHbSh4xg66KCDDjpoQ8cxdNBBBx100IaOY+iggw466KANHcfQQQcddNBBGzqOoYMOOuiggzZ0HEMHHXTQQQdt6DiGDjrooIMO2tBxDB28LXH11VcTj8cpl8tH3eYjH/kIlmWxsLDwczyzDjr4xaPjGDp4W+IjH/kItm1z6623Lvt+rVbjtttu433vex+9vb0/57ProINfLDqOoYO3Ja6++mpSqRQ33XTTsu/fdtttVKtVPvKRj/ycz6yDDn7x6DiGDt6WiMVifPCDH+SBBx4gm80e8f5NN91EKpXi6quvplAo8OlPf5oVK1YQiURYt24df/M3f4OUsrX9+Pg4Qgj+7u/+jv/xP/4HJ5xwAvF4nMsuu4yJiQmUUvzlX/4lY2NjxGIxrrnmGvL5/M/zkjvo4Lhh/KJPoIMOflH4yEc+wje+8Q1uueUW/tN/+k+t1/P5PPfeey8f/vCHUUpx0UUXMTU1xSc/+UlWrlzJE088wec+9zlmZmb44he/2LbPb37zm7iuy+///u+Tz+f527/9W6677jq2bNnCj3/8Y/74j/+YPXv28E//9E/8l//yX/ja1772c77qDjo4DqgOOnibwvd9NTw8rM4999y21//n//yfClD33nuv+su//EuVSCTUrl272rb57Gc/q3RdVwcPHlRKKbV//34FqP7+flUoFFrbfe5zn1OAOu2005Tnea3XP/zhDyvLslS9Xv8ZXmEHHfxk6KSSOnjbQtd1rr/+ep588knGx8dbr990000MDg7y3ve+l+985zu8+93vpru7m1wu1/rvkksuIQgCHnnkkbZ9/tqv/RqZTKb197ve9S4AfvM3fxPDMNped12Xqampn+1FdtDBT4COY+jgbY1mcblZhJ6cnOTRRx/l+uuvR9d1du/ezT333EN/f3/bf5dccgnAEfWJlStXtv3ddBIrVqxY9vXFxcU3/6I66OCnRKfG0MHbGmeeeSabNm3i5ptv5k/+5E+4+eabUUq1HIaUkksvvZQ/+qM/WvbzGzZsaPtb1/Vltzva66ozWbeDX0J0HEMHb3t85CMf4fOf/zwvv/wyN910E+vXr+fss88GYO3atVQqlVaE0EEHbwd0UkkdvO3RjA7+7M/+jK1bt7b1Llx33XU8+eST3HvvvUd8rlAo4Pv+z+08O+jg54VOxNDB2x5r1qzhvPPO47bbbgNocwx/+Id/yO23384HPvABPv7xj3PmmWdSrVbZtm0b3/3udxkfH6evr+8XdeoddPAzQccxdNABoTN44okneOc738m6detar8fjcR5++GH+23/7b3znO9/hhhtuIJ1Os2HDBv7iL/6ijYHUQQdvFQjVqX510EEHHXSwBJ0aQwcddNBBB23oOIYOOuiggw7a0HEMHXTQQQcdtKHjGDrooIMOOmhDxzF00EEHHXTQho5j6KCDDjrooA2/dH0MUkqmp6dJpVIIIX7Rp9NBBx108JaAUopyuczIyAiaduyY4JfOMUxPTx+hRNlBBx100MGbg4mJCcbGxo65zS+dY0ilUkB48ul0+hd8Nh100EEHbw2USiVWrFjRsrHHwi+dY2imj9LpdMcxdNBBBx28yTieFP0vnWPo4OcPOzeOW57HSvUT61v9iz6dDjro4BeMjmN4myO79Xayz91C4NbQrTgDZ13HwOlX/6JPq4MOOvgFokNXfRvDzo2Tfe4WlFJEMqMopcg+dwt2brxtm+L+Z9teW24/r7dNBx108G8HnYjhbQy3PE/g1ohkRhGahhnvwSlO4ZbnifWtPq5oohNxdNDBWw+diOEXgF/kCnvpsa1UP7oVx6vlUVLi1fLoVhwr1X/c0cTrbfNmnm8HHXTw80EnYvg54xe5wl722GddR/a5W3CKU63XYn2rKe5/9pjRBLx+xPFmnq8QOpl1F5BefRaaYS1bKO8U0Tvo4M1BxzH8jLHUWAFtK2yvlif73C2kxk590wyZnRunPLkNISA5urm138NX981jr732r0iNnXqEQV0aTZjxnrZooonj2eYnvYbK1DZmn7oRoVsoqXCKE9hP/Stzz96MZsYx4xl6T7uKsQs+ARzb4XYcRgcdvDF0HMNPgOUMzeGv2blxsi/eRnHPYygVoFtxUqvOxqsVMeNdSL/+M1lhTz38v/AqCwCYqT5GL/wdBk6/+pir++UMeaxv9VGjiTeyzU9yDdnnbsGr5PGqebRIksAugJIAKD8gCHykW2Xm0a8iFPScuOWoDrc8+XKnBtJBB28QHcfwBrHcyhRoey02sJ7q9CvUFyYQQsPqGUMpxcIrd+PbBbzyPMIw0aNprET3666wj2fFa+fGmX3qRrzaIkI3UYBfyTP75I2kxk496uq+PLWNwmsP4tWKaLrRtgofOP3qZaOJpTiebY4XS6Maq2sEr5YnqC0CirAcFjoHlAojicAj9/IdmKn+ZZ1eeXLbzzRCO97vpROtdPBvDR3H8AawXDpm9qkbQYEwLCKZUZzSLPlX70WLhG3nSgjcwjRmsh+/togeTSE9B+V7BLVFus780DENRnbr7cw+dSN+vYIRTTJ0zkeXNcRueR6/XkEgEIaFBgSuTeBUccvzZNacfcTqvnvjFhZfexC3ukhQL6F8r7UKH3136BxifatfN5e/dJufxhAeEdUk+3ELU+GbQoX+oQUVOsDARwiWdXpCcITDqC+Ms7j7sda1/aToMLY6eCuj4xjeAJZLx9Tm9yAQxNJDCE1DM6NI30XKIgQeBC4KcBYnQUk0K0kkM4LvVJBujdTo5qMez86Nh6mh2iICgW8XOXj//42V6kPJoM3YWKl+NMPClz54daTQEIAeSbQiksNX9255nuyLtxLUS4BAs+JIt0bu5TvoOXHLsoazrSCshQXhgdOvOW5667GwNKrRzBgoidBNhBVH+S7Kd8KUkhCAwIilMeIZkqObW4yopSmt5OjmNodh5/bhVfPMPnEDua23MXTuR38iQ320es3SSOR4tumgg19WdBzDccLOjeOWZhGa3rYyNaJJULReC+wSqMbSVrcgcAAQuoEKAtziDF5lHmSA0DQqk9vIrDl72WOWJ7fhVRZC42hYTJUMFmo6Ax6sX3VkLl3JACUlKqiDpmGmBxk696NH1AWW/q3pBsr30Kw4SvqtVfhydY+lxg5hUF+cpP70zRR3P0bvKVewuPPBN2wImxGG9F00w6Jr0xbmX/g+XnZveH5WHN2KQySJphuY6WG80gwq8DHimVZNI9a3etlIqhkl1RfG8So5lFT4ToXAqTD1yJd/IkN9PGysnzVj6ydBJ63VwfGi4xgaWK543Py7PPlyK52DUqjAwy3OokeSjLz73wG0VqtC0xCNNIbyvTD7ITSiPauQvoOTP4hqpEE0K878S7djpvoxEz1H0DC9Sg6lJEpJHp0d5e6pldiBTnxW5yqvxJZRDb9WaOXSjVgGKz2Ek59AKcnI+Z845oo41rea3tOuYubRryLdGkI3W6vw5eoeTWNnxLpx8hMIoaMEyEauXwY+sd7VyxrC5YxSM8JwinNIt4oeSaJZcQKnipHsJZIeQvp1lO8ydO7HWveo6UQON3DLpb2aUdL81tuZeeqbCDOCblgEvotXzlGZ2vaGjeQvkrF1NBzL6C9HhOiktTo4FjqOgSNzwbGB9ZQPvkhQL6OZUQKnhgwcBALp1QmLChqBW6N88EVGzvstvMoCfr1MtHuM+Re/T+DVEUKjnj+IQEOPJpGVOmg6eiSJ8uv4dhG/mmf8ri+EefJIEis90CpoL2y7C1BMl03unlyBBAYiFcpBkttfi7LKm2U0UWVx9yO4lQUimRECp0Lg1lC+26B7Gsc0AGMXfAKhIPfyHUeswg9Hy9hVF8LoRGjhKj7Zh1eaQ9ONZQ3hcimm1Nip4WtePTT+Cjy7BLUCSB/puxiRJHokiVPNU554EXtuV9s+jhZpHY5Y32qifWsQQiAAKQOEDFCoVnD3RvCLYmzB8g7g8PvbtWkLqdHNbYuaw4kQnbRWB8fC294xNNMjgeegWQk8u0T1pR+CCtq2E0YEqSStCqiSKBmQe/lOCrsfJahXADCTvaTXvBM7u5vArWEmekEI/Fo+dCpKhfTLcK+ACnPnhkng2vh2malHvozQDIRuYqWHWCyBLQ2GEj5mtBdRzTNXT7IYJBnVfYq7HwMl8WsFlJQIAUI3QdPD1E/gE7g1Yn1r6F5//hH3YPTdn6DnxC2vS8FtGrvZp25EyQAhFGbPGNKzMeIZujZtofDag22GEJbv3RBCNAxZAmRYS1BOBXQTEKjAp96MrpRiYdvdGIke4n0n/ET5+tTYZsxkL245B9IPX9R0vPL8cT8rS/GzZGwdbfV/LAfbvL+13D5mHv0quURvuKhpRIIIgULhFqaJD23Cr+V/oWmtDn658bZ3DG55HqcwTeCGkYCS8pBTENoS/rxz5IcbBsa3SwgjggC82iLV6VdY8d5Pt9Id9cUpygeeJ//aA+ixTIOCCaBAM8P9aCYqcHHL86jAa7xnoGk6PdEkMUNSi4zQl46TK7nELY2BrjgE86AUZmoAtzQLMkDRLHNo1HIHOHDP3zYonjo9J1/O2qv//JjMIjg6o6Zp7FqpCekjDKv1fu+mdgdztA5qpUImUeDZoGkoP7z/mqajhAivwXcQmomZHsArzxPUSz9x/0esbzVdm7aQffaWsHitGZixDIs7Hzxqof149vl6nzuebQD2TuZ5cecM5YMvMlx8iGFrsW31L313WQcLonV/pV8P2WVSose7COplvMoCRqI3fKaUQqGoLxwgkhn8maW1Ovi3jzfsGB555BH++3//7zz//PPMzMxw6623cu2117beV0rx53/+53zlK1+hUChw/vnn86UvfYn169e/mef9pmFx1yP4tWL4xxJHALT/+3WgGxZSBuB5+NViyyk0DWjgVPGqeczMEMqrI6UPgUuYlhIheynwEYYA3QDfDVlNRoSRaJnLB/fwY3eM6YKHhuKy/h30+/uRgQuaERZo1ZIBHCqgPr8PUAjDRLMSSK9O/tV70SNJKhMvHpU9dCiKqqNbCQLPbluhx/pWs+rST2Gfcc0RK9vDDeHRcu2psc1AmNLQjChB4IOmo1BEulcg3SpeeZ7Y4Hp0Kx5GQ76H9Oqt834jhi279XZKex4Lnb6SIAN8pwIldUwH8/Mo2P7zd5/ma7e9SLFio6RP0lzPe1bVOD25j8zBb7G671aEbuDXKySGNrU52AM5l92lATLVRcbiNaQX1l90M4ZmRHAK0xyYr5P3hukxKoxESwROhe6NH37d6+kUq9++eMOOoVqtctppp/GJT3yCD37wg0e8/7d/+7f84z/+I9/4xjdYs2YNn//857n88svZvn070Wj0TTnpNwt2bpzinsdA08Il9tJU0WEI2Trecu8ghIbvVCHwAYXvlJh99ts4+QOt3K6ZHkQIDa+cxUwN4JeySKEjNB2hRcJ9C4HQTcxYF24pC9JHBS5CN3jvWI7Lz9/Eohen8tiPGFSTyKAR2Ug/FJlT/qHTUqpxLQLNjLeotIFTIb/jR5iJnqOyh9zyfFgQ9usgJWgamhE9woAebTV8uEHp2rSFhZfuwLZLmEdhEknfpXTguVYUoltxSPUDCs2IYMTS+LVFvFqhbR/H+z1nn7sFKeUhxpgKUJ6NF3hUpl5Z1vgdHjV1b9xCcmzzGzaU27dtY2pmFmWkSPaNMNiTZO1YD3sn83z51mf5/kM78H2JajTyFVyNW3dnuFNsJqG7nNxXY8voPJutOZzSDJH0ME5phgcm+vnRqznKpbXgljk9M82WvjwrugSaEcHO7ePH2dXcl12HLU1ius8Vq+Z478gcybGj06QPv/bDackdvPXxhh3DFVdcwRVXXLHse0opvvjFL/Knf/qnXHPNNQDccMMNDA4O8oMf/IDrr7/+pzvbNxlh2sZHM6KAQimF8myauf8m9EQPZrwLr5IncCoNLn1YUNbNGNJ38KuN9JAedjSX9j6BHu9BaDpKaPjVBcz0IG5xBuU7RLpH20Th6vkJZp+6ESkDdDOK0AQIk0jPSlDha6O9Bv25ncwlbIzYCdRz+5GBH6ai5BKnILTGNYDQNKRXD/srGgVxlMKM9xyVRil9F+lWUYrW56SsIn237f4drgPlluepTG5j4ZW7CZwqeiRBYvQU7OxuVOAzXU8R9L6bWN8FDDT2sdS5RLtHifefgFJhTaApZ+EUpzAT3Qy840Nv2DDbubChza8V0a0YRzh+6TP3zM0svvbAEfpKbbn7uV1MPfJljHgXVqqvte3eyTxz+UrL2B+Or/3Ljdz80Di5mkEtMEhGTUaH+zlxTR8v7pxl/9QiXrD8gsRVBq5v8NhsnKfnerhwIMEfnH6QXfsm2JmP8v3pUYTIgQrIOSnuyW5ka3kFVw29xiXmbg4uSu5bOBElJAORCkU/zj2TK+lLmbz2cg1z36ucsXH4iPM+Fi35J+396ODfFt7UGsP+/fuZnZ3lkksuab2WyWR417vexZNPPrmsY3AcB8c5lL8vlUpv5im14fCVrJXqx4hnUEri2yVU4AICq2cFZjSNU5zBt4toaCADUqvOpDq1Db+aByHQzRijF30SEEw88E+YiS6MWAbp1anOFNAFQMiECXwPzatjZYYYueDfkRrb3GbcMmvOpjK1jfyr9+IFIWNGjyRBei2m1NTDX8KvFfGrCwSuHRaaNR2lCZAKZCOiaUQLZqqfxOhmSnsfJ6hXEJogufJMpFM6Jo1SMyz0SDI8hu8gNB3NMLFz+4l2j7aa2Q5ReMPiMQi8chalFEILGUr1hYNEelfwSOkU7tgZx96ao+vpH/Dxa97Jr773lNb3cjidEtRPLbfR0l1q3DPhRBrvLJ15q9DjXUcwdZb2IdgL42HvCeDXS62i/o/G03zrkSmqdZdE1OJ9567j9I3DLSexfds2bn5oHMcXONJASqjYHvP5ErsnFkgnIsjjpEV5SvBwdoyuyUFemvCYrkapBQaiERXqQqFpYAdRfjh7Iu88y6RU3I5LjIF4FXyNjFFj3O7jH1/ZSPWFrQAM9CT41PXntL4LODYtucNmenvgTXUMs7OzAAwODra9Pjg42HrvcHzhC1/gL/7iL97M01gWy0lLDJx+dYtSKIQW0hd9DyOSwIhlUCoIUz26QeDaFPc8hh5JEhvcQOBU0HST1NipAEQyAyil0Iwo9sIBUAFeaS7cbyPF5FUXGgZYLcs1t7O7sbpGl6zuYfjcj2HEe5h6+EsopYj2rkYpiVueb0QJAjQdUKBbaJqGlBKBonfzFay65FOM3/v35Hf8CAC/Mo+ZHsIrzR6VRmml+rHSA3h2GaHp+HYR6dlkn/02+VfvoXvjFuae/Ta+XQjXuY36QKRrtHGtYWOa9B2UdJmsxPnhnjRoMGhWsQOfG+58iZMGFIm5B0NZjuJci04ZeA4zj/8LZqKX7vXnH1e6alkRw0adJBQtdMMOb6E3UoYCkKCFqTvNiLRFTs3aSG1uV8spAKgg4GBesm8myl3PvEYskWLlYBe7JnL80y1P09cVpzsV42NXnkYmmMX2BImIhlsVSAS+hFzRxg/A83yC4y5jCXwleHCXQAiTWhD+dFXDyflKQAAlqVEUMX6cHeWcrj1ENY+SHyetKxZci5qMIlyBqQukDJhfKPO/vvsUZ2wcaUUOx6Ild9hMbw/8wllJn/vc5/jMZz7T+rtUKrFixYo39RiLux9n4oF/JHCqAPjVPJMP/g9SY6cycPrVmIle7Nx+Yn1r8KoLh5rVGjUAI5bBqxVRvoPvO0i3itU9hpI+laltWOmhFlXTXhgnqBXDgrIMUBxiOGm6hYLWqgtok6dYyt5RUuIUp7DSQ0C75o+VGcar5BDRFCrwQ2MsfTQrhpnsRQYuhhVn4PRrQgnriRcxEz3IwMPJT1LPT2BlBunetGXZvHGsbzWxgfXYr97bSFUF6NE00d7VeLU8M09+g6Be5tDKWzV6D+qtfSglG85WkKtIbE8wEKmgCUVPQmcyl+eF277IBvFqSEkFlKbj5CfCVFjgc/C+v8OrLryuBpGZHqI+vxcZ+K36QyQzfGSdxIyRWH0ylYmXkG4trPsDXq2AZpioIKCw90mk79K9/ny6N25h6pEvtx37x9lV3De/nmKQoOTbrBKQkw4LhRqBVPRm4gSB4oY7X+I/fWAtMVNRqisCJVrX6QcShYYvl0Yu7enLo8GRAl8aR9laoZQEYfDwzjpX/uoVXJl/hB/u62XOi6FF08SFTt1x0Pw6Gop6oLOYm2PnM/exduz61vd/NFryz7JJr4NfHrypjmFoKDRic3NzDA8Pt16fm5vj9NNPX/YzkUiESCSy7HtvBrJbb2fyoX8O0z9A05h5lXnG7/t7UivPoPDag20MnbXX/hWVqW3U5vezuP1+NCOKV97d2qf06tRz45iJHmaevIHAraPpBpl1FyB0k7mnv4kwYuGa1A2dkTAioGkE9RKe0MhuvY3y+LNtTUnH6pRte6+SAwTx/nUITcMpzOAWp5FuBSdfQWgmmVPf30YXNeI91BcOhAXOhtZQefxZBk6/5oh7tjR6UVLiLk6iVGj4A6fWcApwhGkSemNFHrSK6XosTb8QWKrGog1dkYCZ6UkMFN1mDQINIUSYshJB+H/dRJhWK2VzLA2i6txOqtM7ELqBaHRFzzz+L/Se8v4j6iTKc7Hn9x1Kj0W6UG4NJ38QYURQXp25p75J9tlv0XPy5fRtfj9GvCtMM6qA6Wqc+7LrkMBgwqe06LNvpoKuKVypowlBqVpn1VA3B+cKJPtG+PB7VvPVe/Y3Uj6goQhagxMV7WmtJY72aBAaUuiHiujtb+JjYCjF1HyJ7+4Y5YpLP8r6Up6SH6XgxfjWPS9i13w8wmcAATHNgb13YufOOSQlcgxacidaeOvjTXUMa9asYWhoiAceeKDlCEqlEk8//TS/+7u/+2Ye6rjQjBR8u7jk1UM/qNKeJyjtfwYz2dfWOOVWci0par+6gFtZaC/uAkifwLVB01vKpPMvfI/02vNp1hWaBhhCxpPQIo2VqqK45zGEbrWYQYXXHgzVTnc+uGyKZ2kXraabYWTg1wGBW5xpnFRoWJSSVKdeaRvfWV84EB67YQykW8eTwRFpgWax1qsVifWuRvoObmkW6Tm45dySYx0JvzKPHk2i6WaYVjMt+t/xQdYObuTKhRu4a2KUeS9JRNS5rHcHK3tMnLwR5tmFjmrcY6GZRDIjWKmBY2oQhbz9Ms2eD+l7SHcBv7ZI9sXvg2YgVKOBUAgUIU2VRiRI4BLtPwG3OB1Gk5reciL5V+8lkhlB6AaaGUH6Lot+EluaDMZsRODQa0pmnFQj8lBommB+sYYMQNMFldw0HzijC8b389Udq5FKIqUg66WWPItimTt5dAQYaLqOQhJI1fjWVeupNoREKfA9yfcf2sETLydxvQDXDzB1ncBzEQS4UgcBScPjjK5ZpGu33eewqK4xeOJHWX/GNezac4CcFyfWt7ZFHGji9QrwHfzbwxt2DJVKhT179rT+3r9/P1u3bqWnp4eVK1fy6U9/mr/6q79i/fr1LbrqyMhIW6/DzwNHRgrLQUHg4VUWkF0joVpqdjfZ576DHkkQ611N1XfxK8t3x0q32qCTmi1l0trsDoxYBt8phwVhCFMjQgv1iDSN9Jp3UpncipVqZwYlxzYv24EMR3bRlidfZuqRL+MW52hbYTZ6MfxasSW33b1xC1OPfoVDTgq8ShZhWG0ifs0UTbPAXVMSPZIIV/8yCBViIRQHhAY9N0ySm5lhQuoupFaeSXXqZVTgh9GYXea9K+bZvDJB3jHo0sp0lw8QOEOYmSHc/CTT9TRFfYBuo8qqLgMrNfC6GkSeXWw1Hi5lkwndQugWyCJmsh89lsav5vEqC5jJPqRbY7KWYNGJMEDAcCSCqlfQreghWm+9xMzT3wwjPhkquvYmFDETcm4Kizq+0jCEZCzp4klFwU9SrXvY9SKWrviT//kQ5/ZO89Gx7VwzXOO+uXUsyNiSJ+hoTuHwRNGh7RwfYpYgFrcIAonrBQjp4kkNicBTh8a4e75kbqGM6x8eXZiAxFBQ8w0emV/F9uoYz/1wmtEVzzG7UObRFw9SqTkk4xHO2DjEjv05qnUXQ9/OxWeu4bpLTmHtWA/ffeAVbrjzpVYB/mNXntZWyD4cHSfybwNv2DE899xzvOc972n93awP/NZv/RZf//rX+aM/+iOq1Sq/8zu/Q6FQ4IILLuCee+75ufUwNEdbTjzwj/i1wuts3fjBBV6oW+RMh41UShLYZaTnYMYzDefS7HNoh/LdxvjJUJlUIOg59f0U9zzWxtgRCIRu0HfqVcSHNlKZeBGnNEskPdRmAI/VKXv4e7oVQ4smka2I6NA5ikaDHUBybHNYOLRLSKfc+rzQzFbnLxySrmgWuL1qHq+cQ+gGZmYEJX38ag4jmiFwa2H9ATCSAxjRFM7iFNJzyL96L2ayl1gjCivueQwVBPSLfYx09SE9G1/1hpGF9Hmsejr3zq2jquJo0uOi8n4+tHq8FTVN19PMvXyQwZ4kkOZgzwdg7530OvO0iu8yLPBDKEuSM9YyVY3Sh2I0WGDaybDgdtNfsdhROoU79/VgBwbxiMaHzkxwlv49JksGBZmhSyswbCqkZyOMKEJJlPRZkfBZnazyWHaQQEYRKGK6h45Pb0JStw2qjotE4ktBzbP44dRqslWdz6x7hA3pPM/kBvnW1OmNasOxooWjv2e7Po7nM9wb59xT1/PQ069RrHrI1mcOffZIp9B8X8MHUIq6NJiyY3z9/r3A3tYWhqExv1hj72SescEM0YjOgeki//u2F/j+g9s5bU2al/ctEChBbyZJuebyv777JOsTC5iJHh7eaVOs1jnnlBWsGMzwnR+9woPP7cd2Qvbceaeu5Hd+5awjHETHefziIZT6SWTEfnYolUpkMhmKxSLpdPoNfba54rVzB1q5/XYszeEKNCsWGrfAQ49lUH4dPZLCsxuzFCDsQlYKI5rCb0lZhEZVqYZ8hma0mrDMRDdrr/0rgCM4/s2V/uGKok3hvDfCDy/uf5Y93/8TpGsjvVr7VeomIxd9sjWJbXH344zf/YVW0xxoIBTCiGIlelhz1Z8BMH73F9qK37W5nUgZEOtdjRFNtl7TIwl8u7TE8ekoRdgjIQglxXWLxPCJaEaE6sx2pPRRXpj6ao4cTY2dyq49B/j/3bSXxVrAYtHG9SVCKD5w1gD//qpT2Z4VrRWp4/gITWCZOrhVNkd3cslYjiExReDUgLC/5OH8xrCpKzCIGQGr4iUO2F04xNCkg+0JUpZPX3eKCl14SmdddIZtEzUCJYjpAZcN7ObigXF0MxZ2ZHt1pt0e/nHXO3ClTsxQ1JwARxqYho6rJSnaEj8IWkyhJkwh+S/rfsxAtM6PF07gjumNjThL4ydD+JMdiDlgJshXJJp2NCdw/Ps7hOWd0pEF7/aoRgC6CDi1p8CeUpqSZ7beNXSxZB8Cv0HH6kpF+NNPXNSKMt5oBNLB8eON2NZfOCvpzcJSeqJqqwccepzNVD89J13Kwiv3EDhllJRoQkNP9dO7+f0sbr8fMz2IP11qPfJCgRZJolkxsEvhilzTUDIgTKMIdCuGEU0foUx6eJfw0sJpYmgTTmkGZMDoRb+7rLjdsbC0CU2YsUYqBYxED0Pv/A1GG06hRdOtFg7VSQQII9ow4MbyBe5aHiOWCesRfh0lw/es9AD9Z3yQ2aduxEh0Axr7p/Is1E1644rVAzG8ao6pcpTqjE7KPcggiyCMhjRHDN2KtQrK1WmNor2H3GIVL1DIRvrttmeybD34LJ4XEI9amIbO5FwJIQQjfUmmCz4H/ZW8sNDPhUO9rDH202NWEbrJvbOrkcpnMOqQc5M8Nj/CQLTGQKxAVg5SsAMGhjK4kRi1ks3k/CL7VRRdizLaBbp0uS+7jg2JOUaiZYRhglTsXIxRdEzSZg2kRjoqmKnHseJJvHpAEDgc4h41b7VCInikcCIHqwly9SgSgU7Y6dzsTz/0rL4eDm29aJvIukegtNbU0zcHy9c+ju4Uwr8V4CuNFxd6Gu8e2o8fqGU/Wyg7/Mk//4jp+TKGoXPDnS/i+pJE1CTwHW6486U2Km0HPx+8ZRxDsyipWwkOb2AC0KIp1nzg83SvP5/44Hpmn7yx1Z07dG44LrM8/kyL8SOMCChJpGcFqIC+U68i99LteHaJwC7S+iUKgfQdUqvPZuS8jx2VU99kOfm1ItHGzIJIejgsJhvWMa9tOc2apU1oKAlmDE03WXnJp+g/7arW55oT4EIWS+O+6GZrUFDfqVctW+DWrTiD534UoO21JhUUIYikh7l/PMXtB2JUHZ+YCddYLm45y90Hh6lLk6jo5rIBk4v7D4SceN/h4KJg7oXdnHBSupEeUrheu2WTUlEo1ylWHSKGjlQK1w/QhGA2X8XQdZABRUfnO/tWkDH7SRkOJ6dmsQODAauM40dQwsALIAgCbMcnrc8zLbvZNVVGUG7t0zR0DF2QrShWRMpUAoO8G2MkWkL5Lj/OrePO+VPIu1EW3Bi6kM1OCHSjju/rDSPfblAFCg14tTJCpR6ERhyWMJOWovkdta/El0y7boOHtkT6BI7PsSx3zNd7/Y3t9+hxy/L7dD3JP9z0ZNuW+WK40IlaOi/unOmkm37OeMs4hlZR0i41UqhGQ7VUR2gGw+f9VmtVfrSO2oGzrmP2yRsbSpRhWsJdnMJI9tCz6T0oFNnnvkO4+BFtRefKxIvAx5ad7VDc+yTekiK4UrKVf389XvjR9Hqk72KlB0K5cDNK0KBUOuUcdm6cWN/q9glwphWuUX0P3YxhxjP0nnZVK7I41n1Z+hpAZWobQtPZn61yx64RJD5DCZeiF+W72+MIsYZIPMZgkGOxrnFfdiMbkguA4PbZTbxaGcV8bQfdmQk+fs07Oe/UFdxy/6tHmI1yzUFKhe36RC0dCB2G5wdEDA2hJHVlINFIGXUkgheLo+hIJu0M1SASdhwjmKmnKHgxIroM0180ZENUWKLQNQFC4Lkei1Inbvj0JTXQLaarMe7LbULoFoYGrlStwrNSULFddN1AIzjM4Cs0FCuTVQ7WMq1ehkNXuBwO3QVDyPAYaGhIbLn8z9UUslF0fuMsp+PDm7HfIyOM5ffZ/hTU3YC//MoDTE1M8KmPv4+9k3lu+dEr/Pj5/fiB7KSbfkZ4yziGpU1ZygtVS7WG0e079ZABXLr6PnzQy8DpV1Od242d20+zkKtkAEqR3/EghZ0PhhtqIfNHGJGQMqrpqCBsdlvKsXdKM+Re+uGhorUIDZFXXUAI7ZhDcZrnunR/dm4f0499FSPRixnPhNeb3Y1bmsO3iygpmX74fzH//HfxT/5tcuUAx04xkqyH5kozEbqi/4xrGTj96mWPe3iB+/BJdk0nJX2X+UKEmhswmPCJda0iGUmxa7KAEIIVfTHq8wtE9YBsPcHNk5vZUR6kHIQkBNNx8OpV/vd3HuaP//37eejZveSLdZoZBwUI0cxIg+MFGLpANmSF/ECSNl0WXQtTC4joEkt4ZN0UGxNzPLF4AoEUDVk6iULgSh1PGcT0gMHuCBKDuaKLL6E7HWN+sYovoS50Lu49yGiyjvJNFv0kdWmSMFw0oRPXfDylMxAPmKuZeIFAx0Vi0G7wBAEaWTtGII+MJo5lcDUUUgl8pZEwfc4edfjxgQS+0hCN66HVi6AQ6ugr9a5UhGrNI1DhbAuNAE+9XvF7ObzRGsbr7f/19he+X6x5/OOtr/DAU9sp+glmF+sIIVg5EMN3PL5+2zOddNObjLeMYzjUlDWCbsbw7CKaprPysv/SihSONuhk6Wq4tOexcEiOEUFJDxCNgTx3oFlx4v3rqEmJV5lvMHwEQjMaIzjbO5RDwbpm53PTaIQyDN0nXXpU49xEO2ffwasVQtE/M4ZSCju7m/4zPsjUI18Oaw2GhRAa94+nue+57fhmN3r9XC4f2MnFAxMh0yTV33bcpYZ/up5uC8/bFDaF3miU68KIdeNVF+iN+aQy3dTNGOlUN7lCjUw6iVKwWAuoOHFmqxau1FgorGq7tkBplBwDrVCi9Np9/Prw8/zAGSXvxhqrfB3LCJvGNKEIpKIvEyWVjHPGhmGe336A8qKNBsR1D0sLKHpRYprHial5Xq2MYOCTc5NENA9HmQwmJHlb4AQaB3N1DKEwNIXEomq7BDJcz5f9KD+aXU23aXPxwAEGuqKkCmmq5SJCBa1oQSpJ3Aio+Rp2oNPsKmiHwA701r+PJ0UjUPTHA2xPoeMRMU0OFE1WxIqM17pQaI0UVUCAjieP1jAXImHp9CV0Nq+M8/BL05Q9HVOALnycQMcSPoaQuMrAVxoR4VNXxmH7Oh6nEG6vaSHD981EoAQvTysEJYTQ0QSMTxcYidvUpdnWud3BT4+3jGM4XFLCiHW15e8PX317tTxTj3wZ3YqhZCjcllp1NjLww2Ijoe6RdGthc1TgtxRJIz0rwtSQEKFshgidh1fJITS9VcD1naXMKNVyEsqvU9z96OsOcVnK2fftUour7xamsbpGQPkU9z8T0mmlj0Iy7fZy7+xaFB695iyLGNw7t56NXRXWDMYZOvejy46EfGh2jHuzG3GUScyA687r50z7e637VV+cwKssgGYS1CZQMqBfBlxz4ru460AXB+cKJKIW//7aMwH48q3PM1OLh6J4QoVaPksgCfV9NHy0gw/w7q5J1m6aJu9Gma3F+OHcycS7UqigzuR8HQWY7gIXr5ScNrrIOUMpNFfy3Es7eXwyybyTJKr7XNb/GuuTeVK6gyN1dCFxlIkhJJ7v4csoSdPDkUbI/Q8U5w9n2emsolYXRA0TFQhKfow7ZjdxyqjBOy/5NT42nuZr33uEiKGwfR0hAvJ1k5gR0BXVcVyXamAuoYy2vnWU0DF1DdeXbQ3LhlBIpZDoS7aGiBaQ1CrkgzT9EZfhZI2CY6IJxYU9+3ilPEyAjh3oRHDxlNFIJTWrHmE0IAiNtOEu8P7hCTZaJZ7XNxAzo3THAvK2zmwFpDDDJJgQ9Ec9/vOFPq8dzPLN14bxW/s9HscQbmPpGo5Ubzi+OB4oNJRSjRYhjfFKAg3FvQ+/wHsuPOeYv6cOjh9vGcfwesPXK1Pb8Cp5rK6RRhNTDC+7F5EZItq9osW3160oSqXDaWGNhrSeEy+hMvFimySF0HRiA+saInMl3OIMc8/dEnbUqlo47jISR8a6QqnuJUwpq2sUYVivq1TZ0qx58ka8chYQYeFYCJzCJFaqn9rMjgaPX4KULNjh6nUgUkUTUXpTJtNFg4LKMPjOX11WVjorVnPn/m6knKc76lOomtx49wzdGytsOGFF2ISX7MMpzOCVZsK+DaEhhOI86wku/O0/C/e/ZM7AlrPyfL9UpyuhcyBbRvrNH/Mhc6EJxZbRLMNWAekKxlIuY9Lm5OQ0lmnwo0KMSrXGUALeOeJiefP86AWbO57NEtMD3r9qlk9edR4fMtcyt1hlsDtBpthNfsePuKy6m/uyG4iaUPM1dCGRRoqYUJwQL+JpMRxfUHQ0ViXLbK8FaJogYhmgDGqOi2fFiL/r/QycfjZXZp4ls2sn+9yVjBdMHpuIYwmbFSODFD2Lcm6SNdoCL5dHDvsWBYGEQEo0TaALkFKiCYUuFMmoQdkBJSUSgSEkA1aFkmui0Mh0d6MFOTKGzaxjclJmns19ZSaqcZ6cH2UsaaNi/Uwv2GTrEaCptypJxQwuHZnmkpU51gwkeHZ/mNIaildY9BIU7DDSUELDipoMpCw+8f5NvPOsU+H5bVyVmeSBl/JU6l6rV/PY9QaJBriewjIMHH9p2HC8zuWNQyK4bf8Aq773PJ/55OqfyTHebnjLOIZjDV9vUjbdykLY/do13Hq0zUQoLSGEhu/V6TnpEsrjz+KJsJiXXvNOBs/8EPHB9UdIUoRdtiZeaQ40jUhmJKR2+i5D536sNVNg+rGvhd3VXh2re5R476qWSN7rKVWGhlww+eN/RhgRgmo+7L1Qkvjwidhzu4h0r8BZnED5Lj1mjZgeUAri9Gg6ixWfqPDJ+Flmn7oRoRsMnH51W4SVnzewA4M+vYhQEXoSOjMlWKiq1mAY6dkYsXRjdGQQqm32jBG4Nn2Vl1iz/gJifYc6YRfLdcq2gxARLNMkkB4qaMnlkTI8fmVdlk9edQYLr85Sdysot4ryw7Gm706/wtrYLItOhMH+bsxYir95vBepJAORKkU/xl0HhjjxqYd4z29v4bTWPbyIzAnn8L77/o5Txg5Q0Yd44oDguWwG37CoOx4T1QQrUja2ipEyPFZ1BaQqEQrVGo7rt6RM0qkUK9asBcKFx+5KL7fuTVB0LSquxmjSx0qkGTBiVMol1kQm2FYeXqaWAIauhQVuwoZ4XykCpcAJOH+1zunR13hlPsbuag9lL0bFD6VC9s8HjPUNYpg+ge7ww9kTCZSGrimU0CgGcQZjcVwZ9oiElYwwWqi7kphms2YggdA0hnozRE1J1o6Qq+thz0ZEp787g6YL/vT/uJhcocrH/+L7ZPNhtNuVjHLFuzdg5w7w1I4FFupGS6dJNpyQjiRAJ+zLCOm57U7hjeKNprDCz9zw42lWrlt+xkQHbwxvGccAy7Nq7Nw4s0/eiFtdDGu/gYebP4gezWAme3FKs2F04LmN933WXvtXLfGwysRW9s7tomvTFgbO+nWEgOTooSEybmEapSSR7pWNJrA4TnGKSGaowQx6Gc0ww7qA9CDwUFIeFyOpidTYZqxkL0oprGRfqFckBJnV72wI3CkSwydRm9/HqF7jitFJ7p4aZbooiGkelw3sYjheAa27FaUsjbB6IoNENYeiF6U3alKo68QtQlaODFqOtueU95HfdjdSepipAQKnSlBbbMlx26uv5Ya7HJSCdWM9SCXJF22iloGhQUS4mEJxUneJ371skLO2/AGxvtWYqT4mH/ofeOUcSw3BiLnAiKkQTpadtU3YQR8DVg1dM+gyHebqceZLXsu5NuslM/U0U8O/DrtvI2bv5NWFd5BKZxgeGWbXwRwLBclUBZKGywdOWOD9V15BcuEE/p9vPdUyiP1dcX7nV85sGZjpeppbxtexUHWQKsx5T1XjDPk6tUqNZCKOIn7UdbFlakgJmbjBfMGl26zTY9VxpcHUPFx3SokLUq+wtbKSr+89ibge1k/m3BQH5jz6og4onWgsTlorU3BMXKWjIkkmilDxzdBMCxEOnCJ0EQ9ND3H+2F7WDCQYMnJctdbn1qlN+HWHSERnxWAXQ70pDs4VyBVqfOUHzzO/WMM0NBCCUs3hxddm+dJnf5Vzn9/G33/nZWK6x2zBR6pDTWtNHJ5Ka8fRaizHYiwtd0eXv8uFqsff3PAYw71Jrr9wlCtPS3TGkv6EeEs5BjiSVZPdehv2wsEjRPCkVyM+vInq5EvIxipVIZh/4XsAVCZeDGUl4j3UcvuYefSrmInexmAf1ZLrLh14nsUdD4SyzYcZ/Ga6RugWiaGN1HL78GuL1BfGMeIZujaFukj1xanWjOijMYWa4zHd4kw4kc1KMP/i9w8xk8pZCBzMZB9XjBqsjTxF3rHoseywSUtYoYZTQ08/s+bsVoQ1oMa5ctUQd473M1s1MDTBO/oXMJM9rLzsE2gNTaWZJ28kqIfyG/WG7LaVGWrJce9+7kdUqu9g1Ug/mibYsKKP1+Q8F53ST3bXU7xWSBIojTk7wnMv7eKsUImDgdOv5kDO47Uff4euSJ0hdZCWYRA6SnoknYPEtFGKfpSMcCh6EWKaS4YFylPbcIozZJ+7hXv3xLh7cox6YBBhLSclZ6i5MJauhee0so89muA3Lj6F89ZabFi3iljfan4VOGPjCC/uDEUCD191vrhzhoWqwrAsLEOjVvdxfcW+6UWGe1NsWtXDcy8NHHV9W6v7CCDn+Ug0IlpAV8QnkC7ZeoJqYj2iOokR2ICiP1JD0zQShkvOSXL+WI2nppOkDZdE31piSjBd8Pi9685nsWzzle88TrHq4spm34OGYehgpVh0LEYaMvK/8u61nKS/g//rlh0YusZQb4pcoUYiauFVchRLFQSSiBUBBbZUVGoOL+6cYevBOpW6pKx0hK6hWlHBcld9tJTTG2FCvfHUU7lax1AO/++3x3nuwXlOHXR4/5VXdKbOvUG85RzDUti5cRZfe5BD7UGHHjSlJHZ2D5oRDSehCQ1hhsXm5lCbUF+o2EifSGbkIPl5ne77v8PGia1Up7aFTVvSbw2zWZrCakpeNwvi8b4TsBfGGTj711G+y+JrD5J95lvh0B8rQSQzuKw0Rnbr7aEYnVfHr1fRrBjRnpVIv46d3c3oRb+LndtP9tlvE+1djV8vMZqwGY03JL+1KEopvEoOI5psRSlLI6z/kOrngq3P8a07n+HZuRTPzHWxw17Nv9uc4crTksy/dFs46IYmXz78z4h1tYQAM4t5YgbkCjX6uuLsmshRKNd54Nn9lOwe0kad0egiRT/KD/d1c9aDP+Dd132a7z7wCl+/vchi9mSios5l/QYX9+1rfFFhwX5lr8H71QJ37e8j6yTRkbyjexY91kX+lbtBwYFFuOvAaqRy6TOKFP0YW8sr0IUkt1jCN7MsOia6ptE/NEJybJhY3yHjv3as56gpCK+SC2dMoKNpBqYlkPh8aMtJnHPKCv7uGw8RicbocR0WnGbDYoOlg2ylXQwNCALyXpxu38UJLGK6x4pVaxjpWcvsI3cS031KfpyuaICrdDKWwyndZV6eT1Ooa8SUIFvRQDNJizLrhxxu602BZpMrOQQqFDNMJyL09iQ5/cr/SGLuQYp7HqOw+2FGrGf5zXddzg+2aRyYnidmwLUnB3TvvwHLW430o9i2RDOsRqFX8f/e8jQzuXKohNtg4OkapGIGnuPi+8dq2PtJcCyncPT3BDBXcJFEua22gjsPSh6ffpJ//IvO1Lk3gre0Y8i+eFuoPqqWCT1lcGhOM7JFARS6SeDUwqE81UUQGkp6PLywgft3rcF2IUKNyyZe4eLBg1jpYYx4FypwGT73YyRHwyHrxf3PIn33iIK4Gc8Q61vD1MNfIvCccHymCmUnAq9+zPkDiFAsTtbL1OZ2YmVCZpJmWHSvv4D8q/fg1fJoZjgLQmkaZnIAr5IFJdF084i+iaURVs+mNDtvL5Hs9unrSrBYgxvufIn1ibFQFwlANOYnyENT6cxEeG2regQf2bCBbz0yxZ7JPPmiTXfCJOEvUFAJKl4EN2KQMepk3RTjr71I77Zt3HDny0jfZSBSoeAY3JfdwIZkjpHooTGvVnqQD4xE2dQ7wT07TbaWV/B8aRXbd6zk8sHdvGdoklw5Qz0w6I+U0YCMUWfeszire44ncqNMHqwgEQgh+JtvPMpwX+q4mqOyW2+ne/9tZIwTKLkWfhBO9hvsTvBr7z2Fnc/cRyE3Q0R4VLwEli7CSasSDBGmjRbcGAKNkbiNDCTTdoKsHaXLrHPZwB6S07swV32UC677DLsrN3DXxAhZJ06EKu/snsSy0pwzOM8T0128NlGi4kLCVPz3r9/PFWNTXNJlca+7EU9GqdY9kjGLwZ4kH7vyNNYMJ9n79LMI3cJKhd/VO4N72XTRRYzveIG0yjNQOIgeSfKhDRlu2tFP3hEI5dOdimFoGn4jOlAylPvWRPh7On0Edk8HKAW1wDzKHXw9iu5yKaafrFDtukErnRXRJYGCR6Z6ePDpnVx55eqfaJ9vR7xlHYOdGw9nHggNZejg+ctsJUNjq0Kan/IdtGgUFTjosQzSqSJ9h2k7wb3ZdQgd+o1FCl4k1NJJZhmRk9A1hqZrWOmhVu3BrxURukG0fx1eaaatIK4ZFoFbQ7MSocE2oyjfQTdjBG512fkDRqybwD5Ai5IoJU5hkmj3aCsFNXDWdbzw49uYLwd0G2OMxqtouka0e5TMuguWnda2FBP791K1HVYMpDGjCfosxcG5AotenLQRIWhQblWTeqqFswqWXttvnH4x7zorz4PP7eOGO7eyqkenMBOEdFGl4QQ6NgYxzadbrzI1M0upkKeXWZTyyZg+WSfZkqNowqstYsa7kfUy28snYuCS0UsUvSh3T65gbWSSLrFIVHMpehEyRp2cG0cqyaCZJ6oNoFmKsh/OXq67PnXH5+u3PcP6xEIrpbTcc5R97hZGE4qPnlrhe9sTVH2f7t4+Pvmr5zISLbH74P24/jrm3CSeFAgUhi4wNR+pdCKGRPPD7y2me/jRboZFhSsHXmFjapE1Y90IPWSprb32r/jNX7+Sk358G/Nlyc6FKE/lVvPoCwZR3efE9ALP5zX6TUl/1G5c/yif3ryTTT0vED3zP0C8D8vUWyyxwyNXM95DfWGcxORdbO6N49dquEUP31/kvOgzrDvrBHYtxug77SpifWv4m288Sq3u4XgBTYMdqLDA/ez+OtFIDA3niHsX4ng7nt9oZLF8vSJY8ooThB3jgdK4+bF5pr3nWL+il4vPXPMGj/X2w1vWMbjleZQKsHrGcBcnj64xJjS0SBxZrwCKwK2imVGMeAbXqYLQyLtx6r7OoFkBqciY9YbxijMSLeOVZoj2rkT6bkgtrRUI3BrIALc0R987PkTPhgvbCuK6FSfw6iC0cL6zrhMsMzpx6fzdMH4PpT6kDBAoEiObWwbtkYUT+Pq+86lUqsQsjevfPcK1540dVwEuu/V26s/fhm6vZOpgjsH+PsoqTSJqkXAONLqQmz/GMLLq3fx+Rs77rSMkNJrpmDse2clizSFqQkJ3KfsRyn6UlOFw+dAeVvYIgoTA9AsUpEVacyl6FjHNo8eyQWgNXScfgaC+MM58WWBLkwGrjCZoRR95J8op6VkuG9jFfdkNjNs92L5JVPe4Y/YkbGkxEK1SctNYusDxfKRbolAp8tLdDyCGXIbO/egRaTy3PM8zkxazwTAru3z+9N15ZnOLnHrpeZx2zikNo1tH6FqbadMExHWfmm9QDwwyhgMoSl6Erq4urr9ggDOKT2F1rcKIJNpYagOnX81FDeXZb9+0l0g3DFguc3NzPL84QIBgKFIB3yMlPObrSbL5Kpt7phkxdtK9qp9Y38ojn6ElkavQDWTgYxhRfPtAoytfoqSkX+1hxcpR1r/3FJ4+oKjYbjgJT7CEthqi6utUfYBj632143h0mI4VNRwpL77cZwPV1KQSPPZqlsdfzRKNGFx94Ub+5vcvfwPn+/bDW9YxNH8MSimsrlHq83uX31D6SN8FPZyjq1kJAqdKfeEAQrfQDIveuE/MlNTMIeLeLMW6RkwP6LFqNB/ezLoLKB14jnr+YGOspdbong4o7XmMoTM/1Ka62iz86lYsrDEYUXQzumyqZ+n8XU1oiFg30imjlKI0/gxTj36N+pprueHOl/CdGr1ajkJF41/vzXPSYMDZl4TSH8uJ8UEoyz3z+L8wHNG5elOdO3bGOTibp6svwoe3nEBs/KuoeBdWeoj64iQoydjFv8vgmR9snePhWDvWw8euPI0b7nyJBTVIVzTHJelXWZ/I0ROps3owztC5v0Mkk+GKsSnumVrFvNtFRNhc1r8zjBaEgYbASA+y+orPYef201/8XoOOmyCtVyn6YbdzTyRcsV7ct48u0+YbB88iEXHot6rkvBS2b1Gq2/ieh+2GRvxA1qXLlKTlPM5ihcmH/hkhBMnRQ872D2/Yw0NbT0QqgaHBhcMLfOodHmvXrWo9Z0WZwhQ+G3p8clVYdEykNIhHFO8fG2ddbIZuvQKaQNv4IU6+6FpGoiX2/uAefLuA8p0jFgWxvtUs7phvRXBIjYxhU3biGCJgsa6RMRRFP0JU9+kSobjj7NPfJP/qPW21quWo3H2nXsXizgcPLTia2mKNGoKZGqIytQ1qQ6TiEUrV+hFO4fWTPceTEjreOsRPElEceSTPD/j+QzsQCN533vpO9HAUvGUdw9Ifg1defgIbmhHqGPlug+ZHWGBtKFaG84IjrBnu4v3+LPfOJpizo0SFc8h4aTpGrIv0qrOYeOCLjR2HmkjKd8Lu6cA/ol9haeFX+u4xWUnNbaefuIHi3ifCuRAKEBpeOcf0Y19l5qBHpSroDubRhAp7EcqC3c/9iFNOP6tN56iZ9hk4/WqyW29n5vF/wVmcRpgWF/fpnNg72lgVX8DqwTjjdx9KQ0S7x3CK0wj9aPnkQ/jV957CGRtHmMtX6BJF+oJxvEoOK9XXMr52bpzLTqhwYv9uSqqXZDDDkFZAM4ZBqZb6bff684l2j7Jq621cPriXe+fWknVTLTruSKzS4hgYQoKAfquKJqDPrFANojiBIFCHCsKtOcxmFKlKyPI8Ew/8E0YsQ2bdBXzttdXc/8IMSumIxijNR2Z6uDJzKqcscfLrz7qE2PYd2HWf4UgVU6SQwuA/XSDZHCnh1Xw0PUnvaVe1ZmRAD7GB9Sy8ck845Ekz6D3lfW1d6UsjuL6uOAXHIGW4nN11gGcXVxy6/v7XGIkWQNPQoyn8eoXZp24Mn5mmzEnfBay9tp3Kbab62hYcZvcKAqeCbxcp7X+G8vizVLSVKPccXK/5rR6frEf7+z9JveB4U1BvDKH8t+Jb97/CLQ+8wlknjvKF/3hpp+/hMLxlHQPQopTu/cGfstwDakTTaGYEt9yYBIZsCN6FKyghINK9AgRc3D/OCfpeFpwoPUa5lf8Wmo4wTLxqHiUDzPQwbmGysfICYUYx45ll+xVeTxJjKcqTL2Nnd4GU4YAgNDTDQmgG0q2hTz1MRJxPoa7Rk9DDXgQTMlr5CHG/5mxrM9FL9rlbQDOYdrvIlyx6qkXWDAcMD0dbq+JmGkL6Hk5hEqRk9skbOJBz8AbeeUzp43amz+Zl78HAWdfBc7cQuHsbTusPllV5jfWtZujcj3Kp92U2JJ9mwbXoMWxGYmWE0FGNsaY9lk1M80Jqq1Gn6IcS6q40UQhMoUiaPl16CVdFWKibDMbCYrqUinp+gn0P38EPX3sPSkXRGs+NVBqgMW+ub7uGsy/5VX5z7lZuvPtl5r0u4hGd940d5CRm6T/jo0R7Vhzh9O3cOKXxZxvfZciSK40/i50bB+CFH9/Ggm1wwSqPxw9GmMrZRITG5YO7uah7F+/qniTvRumN+gxHi4TDl3TcwjQohZIB3/jmrdx1YOCwoTeHhCObC45mz4706gROhWk7RUGm6bbqPJ2NslgLGtcOLeG+Nixn+MVR/n18wnk/D0gJz7w6xa/84U38hw+eze/92rt+bsf+Zcdb2jEAeNU80rXD3HzgLXlHIL0aXRsubI3hVL5PKKdtYKYG8Mrz4cCaSBIlfUaiFUYT9VA/qbFdpGdlmAMXoQHVlIKuMdzSDCiwEt3HVFBt4mhpnuZ7LcPeuxJ/qhSmq4iGq03DZCRa5tfeleHmh/LMlAVxE65YOc2qHtEm7tfs8vZqBezcfgK3xgNTQ9y5byN2oBPTPK6oTfOx3/xguxz5Uzfi5CcQQsPqXckDU4Pc9eQOglieZCLxUzUUHU3u+1jR09jUNpQCM9FDafw5insew6sV8GuLjERLrVpD1k1hByZFPxZSLQFPCRZdi4ropsus0601o0SNibxP3u1mwQ11nppC2c2BOzqK9St6W+ezfds2pmZmOWlQ8p9P3UXFGCEls/QH+3AWXWafupHh83+7Tcl372SeXc8+TX22xkisUS6VPm5xlsrUNu7eATc8txJHRYiZivNXVllrHqAnHjASq+GVI4wk7FD9FRVWXAWhpdMFSgim6wm+u6NMpDtDXyZBdrHGl299vqVCemieQZq1l36K7UNb2Pvqszy152memu+nLk00ISm7oW5YwgiwfdEQvXg9Q/+TNLkdbV+8zvs/fRRRqrr83zc9zt7xSX7vw+/pRA+8DRyDaDVXtj9UWjSFEU2RXnUGdnYXwozhVebDiEHoYZ412UvPyZejR1PkXvg+0nMatNGGaqrQw3SHFSc5ujnUHXruFjRdI9a78riYQMARKqaZdRcwcMahzx0uEGhlhnHyB0MtJ8NEj6Qw4xk+fNUFbF4RZfdzPyKjlVnVI+jatAUhwsimOrcrnFwXBGi6jluaY6qa4M59PUgEg9EaBdfintnVvF9fw0Dj/AZOvxohBJMPfQmra4QZJ8NdB3qQvstQQpKvLvK17+4l/erLrOwR9J5yBcmxzcd0Eoc7wjcSPR2+bbR7lKwYY77k05cA87UbuTRZ5pSVk+xcTPDN3auQXigrt1TaTQkdTTfQIgmEVuKh7Crum1uHLU10JLpQJHSHahBBEtYlzurJ8q5V4UP1tX+5kZsfGqfmKqKazxUjOpeu3Y9bmkMFAcKwQDPaKMhNyZBifh6jfg6XDexa0rOheOmZx7ll2waU0BiI1ih5MR4/GOGcMy1OOet8Cq89iPLsVu/LdD3JgmPRpZcZ1ueQnoNuRSlHV1IPNITrsn1/jUAqgkByy49eYf2KnrbxmeuHIrx2IE+h6pErrCOm10kbLgUnSjWwWjMhogbUliP3vWH89Mb8EN6MFJPCC+AHj+1n685pfvfD73nbz3d4yzuG5OhmjHhXQ4TuEGS9hDKjbQZdurVGM1s4hQwECy//ECOWQSmJEUuHKqcAhCM9dTPSighifauXleQo7n/2qEayrU9BM3Dyk8w9czPFvY8xdE7IkjmcVaJH4miRJMqvowIf6ZSJDZxHrG81Z1+ymlNOPwu3PE9lchuLrz1I4NZwywsNmXDCwrgepzLxIuXIqiWiexo9cY052whXwZsPpX6So5sxkz1Iz2ZmHqr1FAORKm5hgljgM+fGmCs69MtZJh/+EmaiFyvVd9SGvWPJnx+Pg2iueM3sMzz+yCP8cF8vdWmQSnfxa+/6dd4Z3MuYW6HoxxFGDEEQEm+WqLyuHO4C6RN713+kNvsUP3zZxZMaXYaNowwIDLrNOpYWIBCc0zfF/3FyyBzaP1Pm5ofGCTyXfqNG0Y9w9+QY6+LPMWK5CMMi0j2KlexvsY2m62m+ftszyMBnpEtjdlYc0bMxPTlJzTmBof4+vPIsab3KlJNgh3kh61dfxdpGt7z0XW59bD83PbCPutSJGXBpz8tc3D9OpGclfRWJrsHEgoOhCYSSCAH3PbWHh57TiZgGKwe7GD84yQ/31xmI1kmYihmZwJFxCl6MlsFV4PuC4LgNcHtEsByb6WgQjZ6i9n29mY7kcBw6sUBBuVTin256hL6uxNu6MP2WdwyxvtX0nnIFs09/8zBZjGaT1qH0RGVqG1OPfhUZ+Pi1AihF4NrosQyI0BFI30EYFqmx0xl61/VHGLKlq9nlDODA6Ve3rZZbfQrxHpz8BErTEUogfa9tpbmUVSI0HSOWQjMHwsKpF3ZAN/PTTcOxuPNBlFIYsW6cxanwqs1Y2KCmfOqL0yR8l5i+nqIXoTtGSBc1FaPDQ0fcx2ZKKVXPEtOHKKs0GVWn4OjENJceoxxGUgr8WhE0/ZgNe0eTP1/OmSxFc9VdqVYJKvPY3jCZGAxGbQrVPN9/McY5//6PWZGsY1ai9E69QL6Wb82ThpB6aWg60ViEE046k5v21Jl1XkNDUfJi9FoVTF3ygaHtoVnSTU7sD1r1oqndu6m5in6j1qDNOmTdJAt1i5Xd3WhGBKGbOKVZhNBxirO8+uoLFHI5BqM2vgNdlstcPd7o2SgjDIse0yVmQFml6R5Is3uyQMH3+f5Wj4f23t2qE+ydzPO9515FoRhOKQp1nfsWTmZDMs/K6gIrUr1ceNow336yiOcH6JpkMOJQKXpoZpST1o6hfBvTWySQceIRnYLdrN8vrSOo1lQ6gWK0S6Ps6hRrQcPgv15xWaLUIUMfOucjtzok/9f4DIdqGoaQDfnvo+GNFMOPBUG2bkG9xqf+9lY+/zuXvW0jh7e8YwAYOOMa8jvuxy1lEXqEZlJWN2MttlCsbzVueR6h6VjRNEGtgGg0nmlmFFSAFkkTLEyEhcL9T2LE06y9+s/bjtU0+tJ3ly34upVcKG/RcBZdm7aE0UAlF86C0HSEpmMmevHtxdb5NZ1XeXIb9dx+FrbfTyQ9hNC0Fgc+u/U2yuNhMxNKEThV4oMb8eulMP0Fje7uCNKtonBZ0dPL+1fnuGu8j9lqSLH88HvWtEULrfvYSCkFD32Jqw2bO8cTZOuCCHbIDFrSkKaQBPUSntCWbdhrpsWWkz8/lhz53sk8N9z5EkrBSJfJvqJi0TUZSDkYhkWXrJO3HQoqw0lrNpMBrrmwxt9/84nD9iTwgoAtp65hYq7IYzvy6JqBUB5KKeacFIPxOiXRx1PZPurS4r6c4DeG13BK32pGh8tE9YCiHyFjOA3arE+PaWMmR6jn9uIUZwCFZsSYfuTLyJxDRJwbUm01m5IfJ6b7+Jhsr62gL22ypt/iIyeG3eP7s3UKtYDeTJx1Y73kCjVuuPOlFtPL9qE7KkEGdEUtZso6lehKxi6+ltTYZq54/H5+/HwBX2pkTBtH6kSlB7LE3t0VUsk0JUega1B2dQqOftg9OtzgCoygSrdQVIghhH7USODQyl9gGhCxTKp2KN8tAKGJNkcNEDEFvi+IaT52oKEa+mXakhkTR6K5j6WCfD+Ncwh/J0Vb8bn/97637WS4t4VjiPWtpv8dH2Tm0a+ipIfQTYxYGuMwtlAzZRN4NmiNxjNNR3p1lAyozWwHoYXbuDUWtt1FcnRzi8+/NEJYapiXdpsuvBROgms6i8JrD9K9cQsLr9zd0qCxMmNIv35Es9vSrmq/ukBNSeKN2dFC6GGnt26FEUJpFr9epp4/iDAj4Q40I9S+cSoIIdAjCUBwUdcO1q6LkHcinHDKu7j4Yx896r1sppS2JGY5aVAxM5sl5U0yEi23bSc0A+V7aLqxfMPektkWEMqfN+/TUjnyw2sRE/v3Ui6XWDGQRtMidEcD5uuKfA0isToFL0IiGWGwJ9k65kBPEk0TGLqGoWsEUuF6Prbjc/8ze7nv6b2UKlXG+mNM5SSeJ0DA+tgcT80PgNAYjNUp+lG+83SJiy7Nc9Lmzfzq2ffx3acWyLpJYprPZYO7GU2E6UgtkkLZJVTgIN0qQSTGSKTE5YN7uH/hJLJ2nIjmsH4oxXdmz8T2NeIWfHh4NZ+4tr17fN1YL5om6OuKc3Cu0KL/xgyoym4SapFCNSBmaGw85wrKfeezfcdeqjsf4qqhgHuz6yk1+j0+MLSD18r9PJFfzXTZRogow3EbR1n4bXb6SLqoAqaqUUCEHcby6EZ4aTrI88O4Q9cF0g+7woMlTsHQBb2ZOBecvpI7H30NL1CYIsBtRAm+0hvMMNUofjcGmwrtMMcUsvWO3zkcO7/lBfDP332Gv//0+45jX28tvC0cA8DYBZ9AKMi9fAcq8NvmLS81Ps10CUIHPHQriW5GsAbW4hZm0SIJZOCCDFAqYOrRryB0I6T9HTbvOXAqOKVZIukhvFoehSKoV4k2JsE1jWBybDM9J24huzWkDSrpI4TVxmZamoKJ9q5GKYlXzVPzPYx4hsToZor7ngQ0AnsxlF723bDngHD1pekmMvBASYSVQmgmzuIEIBiJB4zGqkSqL2Pnxo85PKh74xZyL99Bf7CbwaEoblkQeIexvgIfoYeFdLfRR9KMzJamxZqzLfx6CRm4SO+QQzw8FRcbWE9938G27mxPxOkybXTpMVsxSMRNrjuvvxG9HFrpaUJgGhoRy8Cue2ETua6xcrCLAwcnKVfqBLaH9EPaqy4EwoxiV3SGkz6GlaDLd5krLrLzmfsZib6L3/30/8n6r3yWg7tfoNusMZa0Sa48i/rCONKrITSBChpSDXbY83Jx715OXRljwQ5Hcn537mwi3ZAxJLmK5NsvSC66NN/WPd4UJWyqoJrZZ5DjP+C9mSR3T46S07pJZuJ85NINHBB9/OU/3E25XEK3N3BZ/25+f+3TLNSNsJscuC+7kf5IBVdFWPQizNSidJkOaVOBGWWxevRZCr4UGAKOpKMuNbKhYQ5L/VqjsUw2ekcApTB1vTXZritpIlTAzn0znLp+mJf3zOH7PgY+Q5EyM04GU/goJXCUoDnTQxONWRAqdBUZw6bgJ9rO4eg4vqLHA88cpTH2LY63jWMAGH33J+g5cUvbCnQ544MCw4oj4l10b3wPA2dcQ31xiuKuR1pSF2G/g0BraNyAaEuRRNLDYZ5d+jjFqZDRJAOCeonq7A4iXWNohtkygrG+1ay65FPYp1+zbBH2iBRMJAGVHFIF+PUSxb1PhKM3mzOmmz9WoRHpXY306riFKRACoekor4bn1kA2jLnQ0JN9KBUcc3hQduvtLO58kMC1QQi6TjgHI9HN/Avfx2tcr27FMWJpov3rqEy8SHHv4221g8PpqdNPfIP8q/eiggA0QWrVWdQXp1qOsBkB1V65h+HusUPd2TMLRHXJhzfMcFK/x+xClS6xwOrs4+z9QaZ1vDM2DjPQk2B+sUZQ9/ADia5rjPalUL5Nt8iR0+NUfBPZkH6IGQG7S93owqPgWvSYUKgbRKgT7LiF3dnvkll3Aef/yn/gzMUp7Nx+Yn1riHaPsuvb/xnlewgjAsJtJdV1K4Z0awxqc4z1ZzjY8wHsKRvD0Ng1U8MPJFLafOdHr/DZj1/Y1j3eHJ16/YWjYSe6Urz/ZJMT+/ez6FisO+M9BN44f/n9nehWku6EzmzZ4IezG/jMuiynpOcAeKU0iC0N0obNRD2FgURpJtFEBikMksk4trtI3QuW/f71pcoowOEGtlkrAEibLraK4flhUkjXFDEjnIPhSo1EugfPdYi6c2G/ST5K4PbxJ9efyvgz32dQTVB0dL584Bw8qRO0OkqaNSLFkFVGx2O81kPZjx6XHTg+hNdQrDj883eeftv1OLytHAO0F4cPL4Q6pRnyr96L1TVKrH8tXi1P+cCzDJxxDd3rz6fn5MtZ2HYXSoU1CjM9QLRnZVgQFnC4Hk0kM8joRb+LV80z++QNCMNCj6Vx85M4+YNEe1cweM5Hj1q8XoqlKRjNjOHmJ0HTiaSHsBf2h45KHb5qA9DQzWjopJQMO7LbpMYEmhFBCYG0S4ho6qjDg5r3y6suEjhVVOAx9+y3MRM9aLpJJNVHZt0FdG+4EOm7TD38pSNqLM3aQfM/OzeOnd2N1TWCdOt41Ryl/c9Sm90ZNgwm+3DyE0jfRTUiisvX1jix12F6dpZey2Xd6mGk79PrTKJ8Dz2+HqVk63hrx1bzqevP4Ss/eJ5y1SVi6fiBxHZ8LOVSqGukIwrbg4CwO7rkani+4r3942yvDDNTihLB5fKhvYylA+qLM9Sfvpni7scYOvejjJz7m6371HvaVcw8+lWmyhYLbpoes8aoXsVMdNP7zt84ROWtpzEeuoMD00UMPRz7qVA88PROfu2SU1g71tPWPT7Yk6TP29vWib5mIEHfxFbUc1vZUeynOH8mpmkyb5v4gYVE8OOF9fzGWIWpSoScG0dHUvQT+EFTIsknElTwzW4+fslqZuZS/PNd4/hteZolEuKq+bdqxAXNLQQ6QUvMWEOipI8uNBSS/liArsN1myp0qVn8sUv46r1ZUlYZoQQprcx8QaNfz3La6imkH/DtHclQqZZD9Q8NhamDH0jcACRWSMlWCoVspJuav4E3Um9YXkbjK7c9z+Xnrn9b1Rredo5hKQ5fhetmLOT4m9Fl891rr/5zkqObmXr0K2i6RbRnZWswz1La61K10e7151Pc/2wo6NdIIRnRNG5hmuFzP0b/aVcdcV7LNbstTcEsnRondAOBCMd9LpUKFAY0G7RkEMpoLAsVzhkQOkpJMusuOGq0UJ7chlvM4rvVRsd3BOVU8GsFEqOnID2bysSLDJ75oSPu7eH3snmd2a234xTnsFIDePVs6Nukj28XQEqCejlUn9V0CAReZR4/PciQYTM47IESjRqLFq7SdRPdjKEZkbbjHW5gX9w5zQ13vsR0wUPXNJLUmVSppXcFW5qMZiTvHX6GfN2ix6qzajBJ0KjpKAEy8Fpd5E1Zk7ELPsHdLzt8+9Usti+I6ZIPnmHx27/6G233diQ3zrnrouyfXsT3FZryGIzUsYtVdj5zH2vHrj/iOzi8RmMv6WfpTYAmJNMVA12ArguQ8MLiEMnomTyV7cP2NFwJgdLwlUAqHV0oJsox0maRzK6vclKiyo8yp7J9Md127Kil43pN6mmz7S+EjkTTDRShrPqgVWFPJYPXYhNpzFQ1klbAusQcK1IepR6bqHAoeTEylkvJs4gKh4xWRrfiTFYFj+fXNI5yyMjrmoamXAJlMOekQo0zETAaL2IImKvHKQXx1je55Edx2L+Pj820WKrz5VuffVsJ772tHcPhP7LAsxF6s9i8/PjNwTM/iNCNZWdLL9fHsNxxpGdjJntasxuW4mgUV2in1c48eQNKSaRnI5viZ0sfduWD0MMejupC+JrQl6SaDkEBRiSJMEzSq89a9l5lt97O7JM3hqJvMgAz2jqWQqACr834L6foufReZrfeztQjX8Yrz6MCP3RcDUkLhEAYUZRrgwpCLSndQMS7kU4FtzCNmexh8JywSJ597ha8WiF0urE0mhFZ9rtbKs+xdqyn5SiyOx/nL2/Zd9gVhxlymRhl/Wot7Po2o40VdoASWjj3OtmHkz/Iwfv+rkFpjmOvvpY79qQxYg5DwTwFx+TWlwNOf/x+Tj71dKxUf4tIcLajeNDahC8V3TGJqyIgfbSD92PnzuHOlyptzWgfu/I0LlxSo1FBqPOlmXHGIjbv6J7jrpm1SMJawHDKx3Y0HpwaIBE1GY65LNqCquMT1wV1GQoVSgReIJitGJjJ1VR9A1MEKBGu1H0JdTcgamr4gWpFE1pjMWJosH5FhmKpil/zqPg6aaPOgpdo3VEF2J5grhbhzPdcy6AQXD5wP/dm15Otx4lqHpcP7Gb96nehVl3Hy/fchS0jGJoiiosrdTwMAqWQUiciPCzNpxZEcJXJpN3NUKSEpcmwKeGY0h1HYzktjx8+tovf+ZWz3zZRw9vaMSynOtlz8uXY2d1HGP2lWE4Ar1mwPVoqKLXqbIp7Hjvmfpfj+B9O3Wzuv3TghUN5edXICTQNK+Ewmt5TP8DIeR+jPLmN2SdvwLNL+JWlc5UbP4zGBDo9mmLq4S/hVRfa+ghaI0oNC6trFCd/EOXVodHZqwmB0M02Y7zcvV1a7J998kb8Sh50K+yr8N3GuQOaifJsWhGQDJBCQ3Nr6NEkvae8j9SqM+lef354bxvfRWVyG4s7H1z2Hi+NwlrCcj1Jzjt1JfdNvQKtpEjoXJuaSiuSLtKvY2UG6Nq0hfwrd6NkgBAKs2csnPDnVNBjaSLp4daI01LpVHpZRNN1epIG00XFzid/SOzA7ehWlMC1MWIZ1o72cM3iJHeN91N0E8Qt+MDGGoFb57s/eoUbH1toNaO16KqfuaIliFfPT3Dwvr8Lx72aUd7Tv48X8gMEIkJPUmC7EkPX8KVOSiuhXJ+UkBRkBkuTjMUL5N0YBdeiHFj8713rOKdUouTo4XOoOWhIalgEaAS+T6AOUZ91AZ4KU0X1aoloUCQXGGhARPfBa6SUEEQMQaAM7NUfZOD0S7Fz41y6tsqG9DPk3Rg9ls2qfqslsNiXH8Dc/gzSc2h2IBmEI1JDB2FRD6ywSx0ZsqbqGUSDEyVbLKXlcDjN9dio2t7bKmp40x1DEAT81//6X/nXf/1XZmdnGRkZ4eMf/zh/+qd/2tD0/+XCcjo927dtY2ZmltHhIQaW4fNDaKCPpli6FM0IwKsVAUV6zTsZOfdjyzqP40m/AEvy8qNoZhTfLuGVs5iJHox4dyiXoJuMnPexJY4qTHMp32mM6ISwOB2uCM30ALGeVcs6o6XnZSX7wtcKU+iRFJphghD4Daew1BgfTQPJLc+Ho1BVgCaMVrGyhWZBvCkFTdi1K6WPssvkt99PafyZlgNrXmNmzdlHkAuWfgeBW+Oh2THuzW7E1eIkohbXbpYMzt9Nl7EGJxBUfavVaHVW/wKnJvYgxKHvtnfTlpbonGpEapqVwIhm8OslNCNKRisT030K1VDQcNEWREWdbqOGGR/Cr5fxyjmsRh/K+zYGrNWfpmyNQGyQF6cV38uehLt9gnzZZc1I9xF01bWnHrrmytQ28q/ei3SqjMZ1PnRSlTv3WRRqEDPhmnNHefCVIoWyTdrwKHox4roHQlDxLUpeeM2WFoB0ePBgkrKv46PhBxqmCB2hrgKieoDtG4S94AJDk3hBOLhnYsFFEqZw4pqD9I2WxpQAAhkW/dcOp1q/odELfwf9yRtZ5VTRIxmGzv3oEumQvXhS4EuBapiqsMaxNA0kCNCICJ+BSJnJetehZ/uoTmEpDkUWGqAEjWftyC0ff2mCvZP5t0XU8KY7hr/5m7/hS1/6Et/4xjc4+eSTee655/jt3/5tMpkMf/AHf/BmH+5NwdJVfvhAvtwI3bN87EqxbPfj8azum9u41cVQasP3yL9yD9GuMUbf/Ykj9vl66ZcmjnAgsS6kW0MzLKRXw4gmj1gtRzLDjF70u/i1PAfv/yKBUwFEqO4pJVay/6jOaDlJjmjvKobO/Ripsc2tc1pOzmK5CKo8tQ2/XobAC+mzTegmICBww79lWOQXhoWZ7Mev5sNiZryrrbh8rOL90u8pK1Zz5/5uJHlGV3axUHK4+aEpPr1Z57KBPdw3t5aCiAFw3mCO//9/vu4IOfRY32pWXfop7DOuaUWM43f9N6qzO1oEzZF4N9dfuIJ/vbfITFkQMySXDexmNBWu6k3dwi3O4lVy6GYM6dmsGojw47kEt+5IMmPH0DWDkXQEUfE4MFsgk4xQq/skolZbjwYA7/h9Fs2zSQVZNm1cz9nrz+eyhrjf6PAQJ23eTN+//CvfvH+BeS9NVLh8YGgHALfNnYqndCxNMhCtExMO2XqKhOZQkxae0vGUgYbEEj71QG80nYGuhR3Juggl6mWjmU1HUfEiYdoNaKU4leL83glG9j1Ptie7LEMt1re6rYlx9VCaYiWLlIqMYeMqnUoQRSM4rCAtWfRiYVqTdpegE9bafIxlJDcAFDHNoz8T5foPnMtCyeZrt71wyPUIMI1wpO1cvtJxDD8JnnjiCa655hquvPJKAFavXs3NN9/MM88882Yf6k3H0geyLXRfpvvxWKv75vtOcRavVmys0AWaFUe6NXIv30HPiVuWNaJHS78sxXIOpMmAOtyQHV6zSK06GyOeQZhR/MoCzR+tvXCA5PCJOKUZUCocXnSM8xo896MMnH5V2zbHAzs3TuG1B9Gj6cPSWjTYtQ1KomaG//bdkOpoRfHK/lGLy4cf43DJkUhmlPy8QV2aDEQqID2644LxnKBIN+8ZfJYNiTnybpyeiMPKntB4LFVFPfy7aqbFEAKhmgkoQAiuu/wMThoMQkFDlWeASfRoN5oRDb+3ZC+abrbup3/Sx3lgTwkRr2P4HijFzHyJ3lSEXMllYq5IX1eCj115Wtuz2JQHadUgYhmu7B6nLxinfxCMaIkD9/8/DGaf4vL+MO24Pl1iNF5G+W441GjiLAJ0TC1gwe8GAX0RG1/VqfoGeS9Br1ljNFZk3k1QDeIkElF810aXPptSWV4pDZA26gjNYMJOhfswK9gqQsUziWo+Md2jKxVhomzBMgy1JubyFap1l5WDXRQqdULTrigHUUSDeSfR24y8q4zWXM9DLXCNvzUDTShkoEg3qLI1aSFQRLSAmO4R030+Mvg0Ihfh2d1pUgmLUtVFExC1DFKJCKah4R6FxvtWw5vuGM477zy+/OUvs2vXLjZs2MBLL73EY489xj/8wz8su73jODjOoXmxpVJp2e1+Hlj6QDZD9wPT8+zb/jwj0fVtD+/RVvflqW3kX7kbv15B0y2kZ4cdwFY8bFzTTVTgU5natuwq+2jpl6U4mgNp5tybwn3LyXIU9zyGb5fwq0tYSkIg3SqV6VdRfh09kjyi1nA853U8aBpqKz0QRlEI8Oughas/JX3QrZDhIiVoGkYkSeDareKyUpL64gSabh4RTR3uCLs3bml9Tz2RQaKaF3ZHayaLFYeYqcjIcB7HWMpjVC6ghEZgSw7e93fsOTDTNnPicMaYW55HMyziIyehgpAV5dfyuOV5zr7kV1uChuWpbRReO1T/GL3ok23388VpDdt/gKGBXmYXp3H9AIVgbrFCd9LiMx85nzM2Drc5haULmd50nPlClS/d/BDRpx9hQE2EtGoFP55fzX3zG6lLk6hwUOxiNFEFzeT07nmerdV5dKaPBSeMlgRw0E4jCLWQBNAbqaIJwUDUJq/18vsfvZS0ewBv27+C0Jl8ZZTADyg6GnU/VKJd9BMEjZRMRPMoBTFu3xvn+bkMV68c598dpV9msCdJImqRK9RQvoMfzl3C0mQ4U1vJRuOchkCR0F1Ug4XnBmEKjNaVhJBSkrE8fm/DNqbsNHdMrKLLrBDRJBFdkXUSlFyLex/PEumOcOamUbbvy7JYqWOaOqWqg5SKf/jmE+QK1be8htKb7hg++9nPUiqV2LRpE7quEwQBf/3Xf81HPvKRZbf/whe+wF/8xV+82afxE6H5QB6cnCGie9RsH1PVcLc+zN6Dgu6NW9rkpA83zt0bt5B9/nt4tUUEAh+F0IyG4a21pDgUKmQVLRGNK/dd0CqIrh17fQnqoxnqpmH0a0Wk9JGeQ3Lk5DZZjjB9s2SlLnQ0M4ZmRtCTva1O7aMVvpfDchTb5V47JDtSb8hmOIBopI0C0AysZC9WZhivkkPTTVZc8mk0w6IyuY3si9+nOvUKAGayl/Lky8cU6Fvc+SBdm7ZQeO1BBtQ4V67xuWd2LRPZEolYhA+/ZzUr6i9Tz8tGGiLMnQvT4oHpIe5++tDMiWs3S94Z3Nsmj55efRa6FQ+ZZksWCNJ3W6q6mTVnY6X6iaT6UQpSY5vb7qmdGydR20/MUCwslpC+Bw2jJ5QCp8xJA/KIqLUpD6LQ2DNhEwQSpQLuN7r5zVXTKM9lup7mvux6JJJ+q8y0neSWqVMh2s17MtuYdns4UEszmHCp1MNRoX5jIJGGRG88JxU/QlS3qWp9ZHr6OWPjMH1ejfH9dSKZUa5yy3xvR5pFT0cABgG+hKCR7ln04xhCoWvgBgF3T47yvkqUzDLPUrOx739/52Fy+RICE0NTBJqJqQuE5+I3qQJKYQdhClIAUd1Dkzqe0lGNaxAq9CymphjpNhjtsXmqmsSrelhaqMAb1XzQdGxfYygu0DTB6pEu3Ik8uiYY7E4yOpA+ZhbhrYQ33THccsstfPOb3+Smm27i5JNPZuvWrXz6059mZGSE3/qt3zpi+8997nN85jOfaf1dKpVYsWLFm31ax4W1Yz2MahM8OB9yvA0k5/VlWTvag53bx/RjX8VI9GLGD3XVLjXO5clteJUFhG6GWvy+i/JdMuvfTX1+Dyrw0cxoaFh0Cz0aw6vk+OZ37uGBcg7bF0smbb3+iuRo+XSvuhjKg/suSvpU53aRGNzQGgLPkgYlAKRP0NBPivQPHbPwvRyWo9gCyxbmlzpUzbDCoUdCC9VIzSiapoeplVq+VStpRkJWqp+FV+9GZIYwE71Iv97mvI6W3kuNbqa3IVf9a5Pb2PT848yXJf0pjXeccQ2psf9Odutt5Lffj1eaRxg68/oJ3DO5EildRrpMFmthPWL4DIuRmNsmj54YOaWNyRYbWM/Uw19q66a3s7tbf4M6wpHj1rika4zv7V+BFIKI8EnoPgnDoR6YjO/e3iZsOPXo16g++SOKi6ew6Da0sBrr6BcWB7m4dx8jEZtdlV4KXpR+q8LBappFP45C8NWdG3itL8LFYwVqjkT6Poteqi0FoxBkzBqe0pFahJwfIapcrt2s2LtrF/fNlIktDnKmmefS1RA4Zf71tREs4ZN3TDwZjn9tspJ8JdCRdEd8qloP2UKd0cMk6ZuLifeudElueoHtM3Dr+ChSQUz3sfVecoFORveoBQb1QGscIyyH1wOLtGkjAFfqjMaKBEpHFwElP8bsfJHT+qv8xpbruOnBfcwXIKr7XD68n019HvEczORt6nNVcmW/pcXUl4kfSQDoOIbjxx/+4R/y2c9+luuvD5tzNm/ezIEDB/jCF76wrGOIRCJEIpEjXv9F4MXHf8SuqQr9lkZE83CkwcFqit3jrzGkl1BSYi5T+Gw+1JWpbcAhPkST2NCz8UKSW/5jq+4w88S/IAMPJz/BZCXKD/f1oMcLrFy55qdakbjl+VBgzy6F3PZIgsApE9gF7IVxzHg4y3j+he81zvBQvlS3EkjPbtN2Wq7wfTiWW6XPPnkjCBC6tWxhvulQF3c/xuxT/4qV6kczo2hGFKc4xdC5HyOSGTrCYCzufgzfLmOl+lGB25pE13RexyreN/ezuPNBRhOK1f09bee16pJPkV51VtiPoOmU7QFqnmQwLjGsCN04jOcEi36S/uKeNnl0O7u7Vd9Z2vHdlPKobrsLM9lPJD3Y5syAtnv3XnOBlCrwv3euoRaY2NKkVI+gCcUrkzbvb9zzyce+xsxjX8WrJpAqlJtoQgBOYJB3THaVT+CHsydS8qMU/WhLuloQTh98cvEENnVvQ5Mus267U2jureDFGI6WuWZdmaorGZIHefzJAo/dNoOPjibWc3Z/nj8+fTuberrpS0eoVj0yhovnhqwkXZM4MmzE7M3EINVHzLOpP/8/Gd+2uOxiAqXodfNckPHwR2zumNlAzomDcIlZEdakKsxWDaaqoaONagFSCXx0LugZ5+T0HLdMnYYjjcZ411BEsMcoE9gl3t29i/P/7Ld56d5/wZx9gtF4FSOWYk13wEPjVTwVpsO6Exo1T+fAbAHT0KjYLpapH0kAeIvhePhcbwi1Wg1Na9+truvI5fhfv2SYnDiIHej0WVUypkufVcWWJtmii/RdhGGGrJJ4T2P4zXzb55tDgQg8fKeGkAHmksH3TSOrpMTNTyKVYtFPYAcGKfIo36avK0617jKXr7zh87dS/QjdCHPdmoGSYYRixLsZPPvXWXvtX9G94UL0RjNbCIHQDCI9Y2hWoqXtJIQ4rpGkzVW6uUQYMHCq+PVK+2uH3a9Y32q611+AlepDKdkqyupWnNTYZjJrzm5bVe/9wZ8y9chX8MrzVKe3U53ZQXX2NfzqApXJba19Dpx1HUKIZa9h2XNdcl7d68+n79SrQAYknQPEDElFdOO7DvnyoXqEDEIufVMePWgwwjJrzkYzLAK31nIYXjkLgYdXmsPO7kb6HoFbY9eeAzz2wm4O5FXb+byjf5H3DM1iBxZuELaeJQyf+3d4fPeBV9m+bRsLL92BkpKC6sLSAvSGOF2YvtRxAh1fadyX3YChBQxHSo0BRQKBRixqErFMfCWwVYReq9ZK+SxF0930WjXuOdDDfeM9/MuB03l4bphAhnl7L1A8OdvDd+vXcdFvfp6TN6wkW4+Rc2NIIKq7rIkv0BWVWKaOZoZspct6X2XIWMCI96CUYvbJG5l96saWkwycGrJeaQyjcql4OuUgQtkzqLqC2WCIeKa/8QQ35ORFmAwcjRU5PTPDZQO70ICsm0KDNmn4V194mlcf/g7x8nZWpFyUDNifddib9ckYNqYmsTSJ43gMdUfwfMlr4zmm58tUay4v7px+A7/Mf3t40yOGq666ir/+679m5cqVnHzyybz44ov8wz/8A5/4xJH0zF82jK1YSUzfe5jGvkePUQ21kKJplFJHLXyWJ19GaDqgQAaIaIr+d3zwCLG+wKkgpYcmBD2WQ9zSKDgmMdehWFHLUxKPA7G+1fSdehXTj3310NjPaBor0U33+kNSF1Z6oG2UqdBMpFc/KrPpWFh2lR5JgOB1abdwqPHPXhhH0w16T7tq2fSYW5pHulUOdXYrUAI9nmJx54MtltexiuSH6001axhLu7EXdz6IDHzG0nD1iR637ygzfrBC1JBcvdFmNGHjFo8ujy79cBHhVaYRQm/UTgAlkTLAKUzyeOV0HnhtLzXHR6tu5IrFKd63MWjUKTK8613v4I6pRepKA6FRCUxKs1X+4ZtP0B1TbEn1cWF3ji6jSkQLwv4gdYiRrxsaFX2AuorQb5XRRKhyOlHvQmiCunNoLsKBcoIFLxHWBA6b5yxQdEdcFrwElh7QH6kyYffgq0b9o7GNBO57Kc9Jz5d4eleBVFQnLvOUvAi2jLDop+mP1vnAls2c/Y6TcLd+g/jB5xifzVAINPp7k4wYVRSKeP86pO+EUQOK6XqaH86eSNW3sEQAmoarFNmiQyZuYgiFUgofHakEcc2ly6wDcHHfPjYkc63muVAaXvDj3Bruy23CeXmemLGaD6zt4jzrSRYqUezAoC9ao1azQOj4UuC6Prom6OtOMNafolb33/J1hjfdMfzTP/0Tn//85/m93/s9stksIyMjfPKTn+TP/uzP3uxDvek44/xLuPaRh/nBS0FDY9/j8pEDnDDaRXrdByjsfOh1C59GvAulwKtkCepl5p//Pl51kfK+p5CBh5nsA6GH3bLxLtYNDXGlnOeuAwNMFzySCesISuIbwei7P4ESsPDSHUyUTEp2D+tPvmRZzSXp1pButW1EaTOff7w4GpUVOCbtdvKxr7Hw0h3IwEcFLkpKBFEKrz2IlexrsaFa6bF6uSH7sSRJpxuY6QECt9pWCzlakbx5rlOPfBkvuweUwoh3U558uXW+SilivatxSjOcw484YfNa8k6ElHuQEVECNUhq9Vl45bkj5NFbzr9eQfkeSoR9GM1GPRX4zNRT3D29CjMJQ4mAuXLAXeN9rNWfZtVAlNELf4dcsBlX3I5mKCxTo2z7oCQZy0Epg3umV7IhXWA0Pss7MtPcVV+PIUATir6oixlP03Pie4nP7qccJOmKeCQyPaR1k1I1ZABqQpCKGbxa7MX1IWU6FLxYIy0VDsfRhWJ9IseEP8zgYAavOEmXdFhwI40ivWwwg6BW9/i/vv4IxaqLAEpahuGEQ1RKrl5nM6TPsGLkHNh/L/HJO3kou5L7shuxpUFsPOD9K00uXVPCq+VBaCFdWmjk/SRlP0KgtFDTSzeQEpSS6EJydv8CU9U4C3UDV2kIDW6ZOo2CF+Pivn2MxCqMJpxQOgTFdD3DffMbQdMYiNQoyxQ/3NfNqlVJeiJ1YrqPK016zSpZNx025+k66YTOhhXhXIx41HrL1xnedMeQSqX44he/yBe/+MU3e9c/F/z+5/6S07719+zf8Tw9lsOawRgDZ/12OD1t/1NHFD6b4mluaTZMIQQSrzzXkndwS7Nkn/0WKIXQLfxqHjMzhBFNoxsWvr3IpascLrjoojZa5E+DsQs+wSO5E/jm9l3YPiSzDh8Tr7QK2stJevw0FNSjrdKPtnKfejTMkSsZgNDCorxuEu1dhfTstnpEKz3W2LZN6ynwcUtZIun+162FNJEaOxUV+OEKW2gE9TJTj3yZ0Qs/uayg4li3w6A8gDIUSmogBIFdYPDsDxO4NWJ9a+hef35brSXWv5bqzPZQOkO3ANEiJOTLcaq2y5DYhxO4pAxJtp5kwY2x0ndJjZ2KNa2Rikeouz51J5Tt1pDYhTkMXaNKkrLWy1iszmXrqmzzLQI9Tl8ypIrqZoQLL72CSPfLfPP+XSz6kEwk+PD5K7jt4R0kYhbJmIXjBuyd9BpOOTyGEAKhfLosl6ju895Vi3xrfy9F1yKTHoV6lrjmUpMWsuEUIlqA44c6XFpjdKcnNaYqUQbjPnXH5ubZNXiTuzHq85yd2sgzhRVIJANWmaIf5a6JUc48eRV97i78WqHRHCfYaw9T9KOoRodzsyxm6BpK6EzbSa5aO8sP9o2gyToJrUYpSHFn7jROHhKs7IaezVeQffYW/GqeRT9JXUVZ0Z8mqOZJK5u5WoxFN8bJXfO8f9U8dx3oJ8BgMFbnojNGeO97tzRoqu1zMd7KdYa3tVbS0XDh9f8nZx9GtSzufxYlA6LdKxrjNOPU5na2xNOEphM4tVAMTi2ppzSkroGQtqoUbn6SSPdoi4b50xjl5bB3Ms+3HplCsxKsGoj/XCh2y63Sl2NNlRuUUxk0ZTrDzmcZcIQQX/PzrfSY57ftH6EhnTJdm379de/f4u7HsXP7cUvZcJ63YWEYFoHv4pVzYRfyMoKKgVM7QjSvvnCgMcxJIIROafw54gMntM/j6F6Bk///2jvveLmqcv1/d50+c86cXnJSTiokIXRCCyUkRAjgRcBywQJXQIqIIpdrARTFxsWr8kNFBcWCKF1KEroEAgFCCpBKkpPT68yc6bus3x97ZnLmlCRAAkHn+XwCyZ6196y19571rvWW52lx6lbMLCgawkxTFarA51KJZEwCkknM8uFRbSo8Dl/VYOtaaiqPoa4yQDKZxIz205Z0JsaOlB8Lh567I3Qip506iemBKlI5or3IEKK95sYw9e4JHFgrMWB4qS5zYyT6Wf66hhACxUqxrSOBoqhUlGl0R1IIy0ZG4NMsgprBwtrNHDlOJWq08VS0hq60G094HFceHmXJqn7W9AedCVtSUWWnMlhTJVIZ0wkEC4hmYMn2KsrLAtSUeejYYfNc30QylkqZliArVEJall7TS2vLVqaccDKav5JE10ZWL1/C0vbGUYLijvBPdySNInlY0xtCEhayorA9VY1pO66+Z3omcu3Hji1QmcTb1iL1ZCl/OEpCchEI6HT19OKWs1SVudC85cwP9TCjMkmm4lAmTJ3JpPoQekAaoYvxfnb1HwWUDMMYGD6pDfelZ2KdI8jThG06K9vRICtO5rWwC/TW79Zts6cYrVBv6NY37/LIRLscV5LLjx6sHpXraW8h/53ZeJ8jKJTfAZAj/hMWwraclFpZIRvrLBATNhz3BeIdbxPZ+FyOOwkUTxmu8gasZITAKCy1Q7Hl4RvpW/eEUzyXq5mQFW0IZR5o/spRCRUT7esw471DSPMiTqzDWwaSVEhb1UM1hf5r3jCyqqF6Qo5hsE1nUWBkmFJfy2IxyENvu+jOBvAoJovqd1DviUOOC7G5Mcwnj2/g7sfXkLLBr2YYNN3YOLxFftXk6XVRzlrcTHNlmE+cTBGl+NBnTDZJyMySEQJZc3GiN8zjOxroMlxYpk65TyWWspBlCduGQ8raWFC1gbCeosGfwTIaWDBJcOqRc4mIUGGV/OCbd1Pvi+GSTRKWTl/W0YBWFLkgC+LWVYI+F71xk/HlVYhMF0E1QXc6TNpSiZoOAZ5HFQRdJv50C12v3ks39dhNp/DE4HH0G7sW37EFbEk3oHoF7f0ZLFtgC6eW4oW+CXyp8liq2fl7rgI+JznV4l1pN57yBs49uoqT5zsZk9nBHqYW2G/vYttqJ8X4+MPO5eCrFxXd439llAzDHmK4Lz1PnuYK1hUySox4H0MIYoogSTLuiolY2QSyqlF98Jn7rK9DK0eHb33zLg/LSGObaYQAK5vCTA3SsfxONF/FXjdYqd5tvP7sQ/SlfFT6ApRL/c4tKhIWkjAT/TmWWIn25XcWYhOBxtkYsY5c0ZsTMLeMFNloB4ru26UbaWDTcvrWPJYzCpB/OLaVRRY2AoHmrygUnQ13f6V6t40gzVNcflRPiFTXRkcnwhbYRgYKcqptOb0KxzgUFhKpKJlYB5P0KIcHIWmoHBDsYk6oB8lWUXMZbN1vPMzs3nu5fEKWrkianpTGfe2zCahpXLKFW5eJmNVFPu6hlOJD3VqqN0yy/S2EBJ7KSRwffIvm5ha2yzP564YK+hICVZfQFAUsg/Z0kLArS71rEGFJhcyuoWSSz/5zJfF4nBpPBllRCFkp0paCrPuJJU3H0Koy9VUBqsp89G3spKsvSqXoozcbIGur+JQMCctFRmhkDJAweXmgkX+manm100d8+TsMZDx5MdAxoSgyyAqTmirZ0bMNASiyhKpIRBIGS1ZsZs7U2qLJfLg2x9BJvvDMR+FBaz5rNs2zJ+zBG//RR8kwvAsM9823PXf7sMwbD1bW66woh7qTZEcXwTZTIwju9gVGk4TMb32jW7fkCq18YNvImhs7F7zFtmhZ+pMRtNvvF397ci1/eLWJjHDh0QQL62yO9byaM6KO/KikaHjrDyTTt80hzfPurDOQJEc21RNuQpIUMgMtIGxMM4OZirFtyS1MWPjVUe9pbPtrCNupJEbOZwnZKLoPWXOhuv3UDlHRG75THI00r+252zHivU7gXNgF2nKEIDT5GOLV82jr6MTe9DDNFeGc1GstVirK3zZW88j2BhKWjgS8ODCBc8x1LJicof64C4GdQfDmphoq7ZW0K24CagYbCV02iRpBvEF1TB/30EI/Mx0jr8BsGykE0OBJMLm6j9aEnwc36di2U5Fc60ljojFgegtpnb76WSPehXItiYsMAymnAC5quAlrSa7+9MH8Y22WJ3M6yd39CTKGRVWZF1Vk6IwrIGt4VJtaPc62hIaUJ+CzJf7eegBCkpz1ghC7NQqS5BgBv9fFEQc2snx1C6oio2sKli1IpQ3+smQN9z395ojC0Xp3jIC9FqkP3hqYUNgNNTeG95jl+F8ZJcPwLjF04jASfUWuh4qDFjt8OLEerMwgwjSRZGfFlVc129vxhLEw1qpoJyVFCmQZ20giLBNJdWggkJVRWUvfK7a09nPviz0ISabanSRmeHiitZEpUzupkTpzhXAqiu4l2fE2kiThDhZXXwvhyKamet8hm+jfaXRz6aCxLS+y4S8t1B934YhJTHUHKKRgFnYoEpWzT6d86nF7/DyGP/fOl+523Ia26dSEyCqSbfHwy508Neikoiqp6XxssJtF0x3Rpwc7Z3LvtkaylpNvr0qCmOnhH90HcuLimVTPOYPo1pUYySiat4zsYBdYBvXuLAuqN7K0e6rjftIE5x5dNaY7Y3habl5hYujfJVnlpPpWXmmfhOQNUhlyM9AZQTUzlCvxwj2ObllecOnl0VShsrBmE0s6m+nO+B2BnZrN1JcdT1t3jKqgi1gyS9aw6I+m+PxxQWZmn6ezO4IhVP7WcRCRjAchSSgIhARpW8MSuZwzIY0aVxgOWZII+FycNW86C4+azJ8fX01fLIVh2liWjSxLeHRtBJVFoPcF2p77FUa8j2e7x7O0bwamXkGwzFlQnXbQnrEcg/N+/yu6l0qG4X1gtGwc3V+Z01/QC3n5jcc6NRwf9GpjqHshj2JKCjeW6fDyS4qGK1SPHqjeq6ujrv44KVOipqoSY7CTgDxId9ZLtvoIXJkVCMBMOhrSZiqG6gmSiXU6OxkjXSh4MwZ7aH/hNzCUpjunvQ1gm5lRDVo0dBhvZyYSEr25PHZQPEFqDv2P952FteO5XxJZ/wwgI0sSXfpkHn2rBtWXor7MS48d4MF3ZITVQtgX5LmeidjCRMql21pCAmGTNFUSriYA4q1rMRN9GIViQMeYnVC1jan+fvqzLqrLvcyf//kx+zf0GZvJflR/2FmBG8nC383UAOMCXj47fzwPrpUZSGZRdS8nhdc6uwXJqY42k05AfOi9klWd+eP6mBqMMJBxUe7K0BSy6E0IYpF+6tRewh5BVqjERYDG5ArGVdg0+DxkIq1Es2/zSOdULFvCkiQUYZPJTUU7ZabzhqHY3ahrMmUBD+m0gdejoakKT7y0meqwj6s+PZdfP/Aa8WQGWXaYUBuqg0WEmBtXLqOu7c8YyQHas+Us6Z6CLQzCWiexpJv/9/eVVJadwAF7wHL896fWFb5PkiQOmV7H2ScdyAmHTnzX79T+hpJheJ8Y7nrYWyyk+xJD+5ju3+Fk2MiKo7u8h1QYe4p8vGNQ6Ph9Wfp7I7gVE29sC7aSxUoPOvQSsuLEhc0smYFWsG0kRSF84EI8lRPwN85C9VWApJAd2JG7em7SkCQ0f2VRFXN2sIdHVye45/k2YpF5qNk+Tq19h/njo1Tm3EJ5vJdn5amcwLh5l5Du3lKoT4l05EjYjA4yvZBJu+lIerm3bRYel04sa6IqFpbt1ADYyMgSeFWL6jK3Q/ux4WlUbzlmKoZt5lmHnbhVvTtCvVui+rBP77avw9/DoeMc+veZlROYl1v1at0rES//HSQdWXVh2xZYBsP1tfRAFXqwmomeDM2aG9vQUDQXlT4JzYwQESphr0QqKfCKGCHRj+atyemdB5jvaSfpFzz4tkHEdGEWVV2PbhDyKA94CHkVtkYTlAd0JjVWFHYDt169iNv/29klb++IcMeDr9HWHaOhOkhHextKagDrraVkRAeSJNGfcZGyFKr1QfqSPnpigxhC5jt3PMuXzjmc0866adR3Y0trP6s2dPDjPywnEk87TLgC2noGeeKlzUwfX8ExB43nqFnjPrJGomQY9gF2xUK6vyDfx9DEw8fUsH6vGMqq2tw4gQtOO4i7HnqFHb1xPIrM4mlJxpXZZGNONbCcS/dV/dUY0U5UfwWKy4+ViZNoW0eqdxt6oArNG0IIge2vzGk5OFD9FYAo0J5H1j/N9n7Bneumo3jKmTi+ke5eH8+k6jm6SSKy/mn61vzDKaLKZesoupey6ScRaJj1rtxLtXPPL6zMs4ZD79Cd0gm6JToSLiQsGqsCxFIQTyWxbUeCMq8jENItzhy/gwZ/muxgOlcbMQnbzLB9wKazq5dyJU6dO4YkqYSmHMfEhV/do+cwWrxkKPLGsblxQo5S3Gb9W1WY8X6HAgYKAfHhz7Z82kkMbHgaK5sovDOuUIhFjW080TaezoSERxEsrHuHxqCxU+/cTNNNPS/31WLiiEWNxPDsjVyURILoYILeARtLSBiDPRiDNpVlNYWsu6NnN7FqQzt/WbKWwUSGeCrLQCxOmTTAx8Z3M7GhjERbK8LKUi5H8MgmvVkffVkfFhYul4qqyDm30yKaJxbfs7z+RWdfnO6BxIieG6bN2i09rN3Swx0PvsaCo5q5/b/3TabfvkTJMJSwV3c5Q2m/JUWlcvZiPnHyF5ji62PNsn9SW1lOgzeOZchIiooerEKSVTRfBUaiD8DRj452YJsGpuih/cU/0HzGtwvuEdXtQ9HdKO4gViqGpChIkkOLPrD+aYQQxNV6UqZMjdWDMMNUV5azvb2HbW+/xqyK4mwdX+0MMrFOOv75G3p9FahD2HN3B4cMT+Ifq6L8dVsHSTNLytLoT1vYQL0nhVcTyKoH0S6QZRkFA8sGXbY4u24Nx4e2M7Dxebw1UxG2ozXxXG8z/9hSRsqaSCAY4j8OdvGJkw4o0tx4N88r3942s8S2v5rLstpJ+55nvm04/ot0vnQ3ViaB4vIVpDaHPts8S+xwQ5rq3caCSXFmVG0iJioISn2MC2Qpn7a4SIs77p5IW0+cuKkN6+Wu4wpCQNawUHPy5n1pnfLeLsjo+NwuasL+Io2Kmc01tHXHSCdjfLJhA0c1u1FdPlwVTaS736HeHWNB9QYe6pyJIVR02aa+XKehOjhqZfPQa/u9Gt0Du+gsYNmCJ17czHd/+yzfuvCE3T6j/Qklw1ACsHd2OSNovy2D9hd+g5Bg6vSTkFbFyca3MdifytUxSPjqDsTOxslGO5BUHdUTwox1YwsbLBMQ9K17DFe4kcZjvzBqOulQtbbetf/AFWqgwrbxajKRtFzgoPKoEJIH0bzhomwdK5NwRINse5eyocORnyi39wv+vGYawraY4EvQl/GRsRUCZFAVCduy6OrrQ5Ylpo+vpLenm/7BLFmh8I/O6Wiaygmv3+fod6fjtKf8PPyOB2SLptpKBkWQRzbASafNoJzRac6HG7Gh9yWvTZ6JdmFl4g6Vh6yiuENYRpbOFXePYL4dTVtjeApnZP3TVEzfqUSYj23w6r1Y2S1FfQvPOImNm7fTPpBg2/IniBtNw+7mbtJSZQnLFsgSKAoEVZtoVqYrqVHjM7ngtCNobgzz4pqWohqesBZhRyoG2SjJ9nfQw43IioarvAHbzLAglKK2foBfr9aQJUFtRWDMyuah9UFm/56Rggrg70++yYwJVSOElvZnlAxDCXsNQ2m/hRBIioZtZulb/QiSIFdQN4Q1VkCibTWS7kV1B1BUDVf5OAa3veIYBUlCUt1gW/StfqQwCQ13jwz9dz6bpNEfZlFTexEH1WdOmcr43udHZOsIYSNMoyAbKoRNNtJOvG3tmIZh6EQZV+tJWxKVagJVdVFJiu60l8PK2ng7M4ltrZ3I2JSpKoPRAWIZBRsZlyxQVZUn2sczxdNBvTeJJKsMWEHSwkWtO4PuC1GpemjpirBj6xaCfctzLKQg6z4sIz3CiA01HJKkOIR0soKVTeQyqZxiQjPeTXs6SL8h6HnoDo4+878K93M0t9OepHCOpeF875MtPPvaNrLpJIloDWNPqyPdSDVBjWga7KxDuSEhGDRkqjwZzpvaySmfWMwBs5w01KE1PH7RS3dXD24JKlxpbNsk09eCOzyuKDV4jraDc6YIlnRPo20gO2pl85bWftp7BlEVmd5IkoBHR1NlTNMerWypCNFEhm/98immjKvYY62VDxslw1DCXkOe18g2HHZLIWyQJLLxfocGw0iOep7IJpH9lQ7HTqwT1VuOkXAmbxBOWq1l7jZTangR4injvSM4qLrfiI2SrbNTNtRIRcj2tyKE7ajsCUH1nDNGlfTMT5QVto1Hk4lm3ZSrgkFCeHSDBc2DLJTfYsD0Ul3mY21rir9vaSCT9aJKUO1JU+Ex6BhU6Td91JNA1hwmUK9OEeOubidJv/ZLWukgG+9xVPdkBSQZRfcU7s3wlX16YAfZWLfDN2VmGRpJfrZ3Eku7p5KyNTytJqe/8yM+c86po7rQdqV1MTxlc6hh+ftT67jtb6+woyuGJEFDhYeUpbJnsQVQZJmycDkDbQO4dAVZSFiWiY1gbm2UT338lKLiu3wNz10PvcKOnkFcwKn1LTT4M2DryLqH2rkXFPTK80bss2aWE/tMBgwv4yY2F4zCltZ+/vbkOp56eQOmaZI1QVY1EkmbqqCGYdoMpizSxq53EKmMSd9HSP2tZBhK2GvwVE4gNPlY0i//GXAK15BkhJnBSjGs0rkYmUgHsqqj6B5Ck4+l/80nEGamQB2ueUN7lCm1u3jJWNk68da19K17nHRfC8gyWqAW2zToXHE3xmAvfeseL/K7a74KEIJMrJPGYC0fG9/Jo1sr6E6ruBWT0yf1M/PQuUQ2Psd4r4tsbBPH+QfwNbbz+x2HomBTpsTpT7jwKDYVXqe2wDbSNPgMFo1r5/Ed9bRHDNxqlvllq6iROh3NjFgXYIPqQliGQ+NuZgtjKSIDdPkdGpac6y5fn+BIfk7FhhyRnZdHt1cz49mHmDeKC609HaQlfDpyyzLqjJ1JCo+ujvOHR5eTGMLTlF8Rb2nt5//uWUF7zyBWLg91e1cCRdYYK+toOCwb2rsiKLJEOOihoSpIV18UTba58AunFhmF/HfWVwW5dGED/SufISB6afAmnHtrJlHdfgKNO8/xVE6g/+2n6V3zCMIyqfSGCATOhcYz+PtT67jjwdfY2tqHJCxqPSncqoRtuTlzYguTtFasbIKV0Qn8ZetU7N3I27T3DpI1rY8EK2vJMJSwV1E+9Xj61j6GlU0BjpiNrOqOkcjs4kRZRtgGVsYiPONkXOHGAi13Xkp1T2Mgu4uX5D8fugtoOO4LaIEqWp/9f0iKCyvZ75Dn2SZty+9Esq1czUWElmU/RQ9UYKbj2NkEVirKKeOrOXbePBKu8ZRrSaZOHg9A/1vLSLStQ+TqL+aUdRI132RJ1xR6jBBuKc2Cqo3UKV0IoSJJIKtuFkwc5LgTZ9ATMzHW/olaqY1s1AnM5xme8oZTVt3OPWbkyt7KxEF2KsuFZRQMQ3/WQ8rWqNYHkSWJMj1Dj+mheyA9woWWz8RJpLN41GP4j4N1Fh8SokeeUAjGNtWUjSBrXLWhg86+eMEogGMOTBs0Rca2BdZu/DCqZOElw0mHVPFmj4e+WJJQwMcFpx1UcB+N3k/B/LJyZlb0Y6aEo08iyyP0PvJqeMK2nXuUiy/1KhO566GVpOIJJGGhyILerIc6OcFgOo2VzVDr6UXIFpONHkKuScQyyqiCR0PH3h9L8epbbRw9e3iMZf9CyTCUsFehB6pwldVhGZmdRWqaC9+4g+lZeW+OnmIUmFmEJCFpHmRVp/HYLxR0mt9PptRY2TujBXADjbNR3X7SA21IkoKQZIQQkE0gNA+q5nY4plJRTN2Lr3Y6mVgH2BYN8y4dwTE1sGk5tpF2rpGDJMEJVS1MDfQzYHgp15LUaX0IoSDZJv6mQ6mYtaiwqn377kswpO7C+XkDg6yiBWuRVRVFcxd2P57KCZRNP4m+1Y+QSsVyLjInoG4XREAFFV6BRzGJmm5CWoaY6cUlUgStbjpe+gPbejIY1UfQv20Nv330HSRFp6mmho72Nv7yTBs1PeuJ2gFikQOZOL4RYaYI6VnaI0bxiljs9F4N3TB65TSV3jTbBv05tWZRSOHNnyghUemxUWWbA+2X+I+PfYyEa2qRqyePLa393PXQK9iWSUO5j4EkLOmexvRwglqvXMiQazh2p2BYqncbq198kq6BCip8UK868TFJktn66lNEehME5SS9UgBhyxhIbI/7AMGD2xowa2Kc1NBNuZak0mOgYtGb8ewy5mDZgp/99SXaemL88IqFu2j54aJkGErYqxjq5x+a41495wx0bzndq+4v0FDrwVoS7esACVnRHCpuYRXcIu8mU2o0A9D9xsN0rrgbMx0vcCLl4wWjkaRpvgrcVc2kelty1Eoqki+MOdiNZJnYioWU01hWXN4cB1IdmWhbYcWeR/cbD9Ox/E5HfxsJZMUZY077oN4do84VzbHFOmI+IpdKasR7YO75SFKOWBDYyQObg21hxDrR/BXUzb2gaMyR9U8jLDMXO1Ed0sFkBCTZkXr1BJmke/lEuIIHVmXoybhxS1kW1m5hYkM5T7XV8NiLb5O2t2BlUyRMlYm+CHGzC59l0GV6iKv1lEt9aGaEbdssNCtGypBwa6B1vwI0cfC0OsIhTyHfX8r98atJgmqW3pQj86mIvLkS+NQMhq1iCglVknCpNhoW/lQL6rrfUukPF1w9Q5/7my++TqS3lxp3ilRWIRCopUv24j70EiY2Muri4m9PruUPa6aSMsAtW5xav5155RuwjDR61wokMYOBrE5ISdJr+DCEhCbZ1LliKEKwpLOZKd4eGkNJFo1r56FtjbiETDq763iDacG9y95kztQ6PrVw9h693x80PrKGwbIsDGOM1WcJHyqC0xeg1xyIkehH84VxlzeQTqepOPzT+CbPKxw3Ev20LLvVqfC1bWRZRlZdmJJOOp3e4+/re/tp+tY9jm2kkTU3FTMX4audRusr92FmTCTJjZkxaX3lvkK/TNmDHqhx+Hr0EMnuTbzz9C8BkAJ1yJoHV3kD2Ugn2HKuKE0CzQ9ICFc5lhrATEWQAg2kMwbZzSvRfM5KtnPtMkzZB54qCoyusoIkySjuAGY6Dla2eCBux0BYWpDOtcsITpoL/toh8qC5/0gKnsoJjta0oqLXHEg6nSY90Ebn2mWgl6F4a8h2bUAk+9D8FUhyHBQFT+VEVE+IZNcGjnb9k6YDvfQlJYIMMGV8LR3ZMh5vqcQ201QoUfokH2lbpyfjoUpEiZoe3KpFhc+m0e+jyRPlhS43lvCiyHB8eR+ebQ+S6j2M5sYJXHP+Mfzkj8vpi6RAEpSpSc6pW0uZV3DnlgMIqGn8aoao4SFja/jUDDHDjbBU3IqBhsGCqg00eBPoZQcUCTnl03DNZBS7N4NLmkvM8hGUU3T19OIpb2DcxGZCo/jzd3J4KdR4k0TSKk+0j2Oyq4UGNc26DkHakIgYHgBcchZd2DT5ong1G9sWdKW99GddjJMFsqKheIKEXS4kScI2EnRExqDgdwj4+dEfXkBT5f0yS+kjZxiEEHR2dhKJRD7srpSwW/ghkoXI1lGPC8uNeuil7FQrdv7fk3bTu3X4OaNDWCaGEYBp5yLLMsK26TWgv7MfefZn0ZF2srgiaO2OICtupJkXYIAjumQZqI0n5WKgUsFLbEsSihAohb45E7ysuh3thXwlhKLSGTMBE/rbkVUdMfUTKMJCGeZXkHXHVaakoqPSsyM5uydhWwzqblxzr3ayu4a0lRQFZBUFELZFW+8gcmQrtplBTDvHEY0yDfSJH8NKRTFW3uZoe9vOOIZqiTQ3hGmMdZKNDGCmPfSlwiQNm2o9C7ag0pVi0NQRQnYI/GSTBZVvUqf72dot2J6opNqTwutSSZsy2xNBtvcLxuWypPJkjqs2dJDq3Ur5O3+gRu5g7UAFEoJKPYEsgVsepDsbYHHNW1S4s5hCQZMsyrUkDd44eng8qsuH0Dxkom2O4FNu16d4y6h3bWJhzWaW9R1Ad8qLS8rskmhwx9YtJFIZqsu82Mk0IT1LV8pNVKnD6y1jaXcYv5qm0pUiktOEUGWbrHDhd2lEUxI+t011uQdjxrk8udTGF3AxvsxLd+8A7Z1pYHgBX+GtBSRSaYP/97eVVJb59jvqjI+cYcgbherqarxeryOEXsJHFkYqhpWKOnq+koziCaF5gnt8vplNYgzqSLK2c/q2DRSXDzPphWGGQQtUoXmCO783l9Mvhs3SkqSgunxOLYCiIYSVvzhasBpZUrGFo89gJhx9CUlScu0EIic8VAwJPVDl1BAk3DmpUoEoZPU7RiGfRSTJChDaGaPIveqSrBa+SwL0QA2ypmMbWbKDXQjbwrZNhICeAT+JaWdirfk9IGMkI8iKWqQlkqcEx7bwm+141CBxpRKf3UEkq1GhJTm34Q1UySasZ6h3R0h2eumzpmGoIardA8iSSdCl0zEoEbUDRRlkeTLHVK+PLYM62USQsJ7EIxtOjENNEzXdeGSDKf4+GkMWrlA9kqKRGRhE1spzxtIupMlKEoXsK9vMICkaJ1RsYXaTh76UQoXHZF5OfGc4ut94mPRrDyEnGuiJ24R0k5jhxqMKGurr6M+opIWbKnUAWZJwuU16skEOr4mxpi9Ex6CEV5NZ1NTJxBoPvaEDSZnraKrwIssS5V6JbWNtFoYgbVi0dEX5zm+epTeS2K92Dh8pw2BZVsEoVFRUfNjdKWEvwO12Y3q82GYGWXX0EfKwjQy2bSLLKrLmGvV8W5HIZCLOxCyrTlUvGpq/jKyVGiLQIyHJGm5/CFlz4Xa7sf0hjFQEMxkZMYlLEui+AIbIIOxc/r/kpJS6Pb5Cf8xMgmxGQlL0nGFSEVYWSXE7GUFDLigBuksHIchmc4FWSQEhIYTjjgAQtgDNIbLLiwNp/goUzYNlpBxDJGzHePnCaN5g/maiKTbZwW6E5Vw/HPKSrpqOpfvw1k4lPO0EFN1Lz6r7i2oS9GA1DfMuZYKqE53qkA/29tjoUpQFVeuZE+oASUFSFIQpYZsZyvUEXrdGQlThs3qIxE3cssSEGYcCEN26ckSFetn0k4isf5pxZqdDJd4zzcnOkrMsqNrEuHIZxe0Yw3TvOwXNEDMZwTZShZiVv2FWUfaV6gliJgeoFq3UBT1Uzl48anwqH1+qc6VZWJtmScdEulMePDosqNpINQa4mnArJlHTQ0hLE83qeBSTTy2ey6eATa8+SUgeZHxYymXLNeNzbywIY3VGTUyh4FUsktbYWUoAlm2jyvJ+V9/wkTIM+ZiC1+v9kHtSwt6CkYwMmehkhG2iectGHHcmwLIR58uaC9UXdtpa2UJb1e1H2FWOqp6wQZLR/BVFBsYyUljpOMIeLVgoDTMWo+eayLJa6Dd5wyTJaL5wLiPJKmTpS7KKsEystBOQFjlJU0mSUL1l6L4KzEwcM9GPpLpyni0Z284WxiprLhTNM6bBVDQPqtuZJAE0RXEC0HoQM95Dz6r7UXQvnuoppLo3FREn5rOqPj0Rjjysnx1btyC3/ZNAn012QMn13wBFQ5YVGnxpFlZv4MnIHHpj5WhSlEWNrXi2vcL67Q/l6lJ2flc+A6x82klIqs7J9u+YVv66Q92tJajTIwjhw8jtemRZQ69ocnYLZpbauRcUlPaAomJGzVeOt+4A0j2bsS2TgQ1PowUqRxTr5es8FN3HiVXvMC0Uoz+lUFtbSY3dB7aPiuxbLKwMsaR3Or1WJW41w2nju5k55zA8lROYOeewokSHaigSxhKSit+tUeuKsr7fizWivmGnl0MIyFoWVtrer+obPlKGIY+S++hfA2Y6jhHvxfHT6wjbdCZFWd3pnhlyXNE8o+4cNG/ZqJPlWMfB2Y3kpUSdjKihgWBn7W8mBxzDpOg5j5SCsE3nejjX2qVhClZjxPsc4yApqJ6Qw8kEyLoXYWYQCHR/FZqvHHB+kGYygrCyjucql55qxPsKY5I1V+H7h8JIRgrfx9C4iCSh6F4Ul1bYIaS6N9Ew71JkVR81YyfQ+wKhVb/GGOwlKwQICUl1FXY2kiSh+SqYV7mVQ2c1s33jWiq8gqYyiUTnAJIAb/0BmKko/W8uQS+rxxVqIBPrpHfNI9QedT7u8nom+tNMlBQyfZ0ga3irmsnEOjEHe3BXTUL3VyBsm0y0DVeodkz6jbyynqx7cQ1R/xvOdzVcqKpO66PepaC7NBStGldlM9HNLzCv8h2mlsWI643UhANUi85Cdflo2XJDhbGyhsX//ulFYoMeZCWJtZtijW3tEYK+kdxMHyY+koahhI8+nEmsF5ETCgJyRVhZJ4iam5AlcFbiVrZoQh6OsSbLsY47Pvjcd+QWdHnjIEl5g5SLP9i2sxiRbadgTy7+2eypYbJt08liyo9LdYGVRRqS6moZKRA2do5AEKRcgaC0S+NoGxmMwZ6c6yxnFCQZ1RtAcSXBG0JzuYt4jmRVJzTx8BHXSvVuo/OluzHj/c7uAEcISRgp58rCQg81OkHs5AC+HY8ylRgudxPC9hSqEoRlIGtuhGWhaB6y8R6y0U6E6RD3DQQOpr23naDVSzXgKmtEdfuxjTKMwR7M5ACat5xMrNOhLjGzI/qan6SjW1fusRxnYMLhRDe/gKy6se0Eiu5B0VxowToiby/DtixAUKf1IStxdGr3SKNkqDBWbyTBrx94DaQUY+02hyKWyPLnJ1bzrYtO3G3bDwK7ruEu4QPDs88+iyRJ/zLZVrsaT2G1ng8M5yYRR5hGQlZdBfeME+913DPDJ+T3g6EuIOEccFbCsuoQ7MlKoUrYsVsCYZso7iCy5mLChAn89Kc/3Xk9zYXq8o2YtIceL/pOYSOsrDPe3Lh27mJkvv+//4+jT/mPQvL/xVd8nXMvuBi7EDMphmWkdhoFKXdSzvApmhtZc2Mk+4sCuPmJLtW7jejWlaR6twE5d0smgQAUVUdSdScd0x2kbNqJuMsbsI0UVnIA1VuOK9yEJMlkIq0Iy3SkQyEXZO8HCTIxRxRK2BaSpvNUey3fe1Li15tnc9uOE1mePARZ1UhHOkj1bnHqNOK9DLauJhtpw0zHaXvudrrfeJiBTctpf+mPDGxaXhj/0Irv0cYITtB5y4PfJLLxORBQOft0Jn/ixzR//Hs0zLuUdM9mh2HX5YNc/YeTSm2+a42ST5w8k9v/ezEXzG+mKqShyLv3cvx12Tq2tPbvtt0HgZJhKGGvwTYymJkEtpHZ9bHcxOirmcw/lj7rTP7CRlhmLiPHRPWFncnFygnG+MJjBqD3FEMn87wLqOg7vOXIiur0RdiAcAyS6nKMlawi657c1QSWmXUC5KOMcTTkvxPbwjZSBYoKy0gV7ottmUXUFQiBMLM595B4T8ZRUlQqZi5CkiQy0TYkSSpMdPnJctvjN7PlwW/S/cbDziTr8iEBlpl1vh+B5itj3AmXMOUTPyY96WzWZ5rp1aehunzo4UawbYzBHidrSNVIdW92AuG2hZnoRRgphLDpUSbxRGsTtm3TWOFB9ZSxtO9AdkRl0n1bnV2krCAA20ih+ivx1U5HCEHL0lvZ9Lev0frUz9n892vY8vCNRYHt0cYIQ3ZB6TiqN4yk6gxuX4m7vIHQxMOdFGPLdHattomie0FS0PwVNC342h5pcwxHoPcFPq7/lRtmreDKg96hsXx4IFoM+QPxlMGSFZvf9ffsC5RcSf/GyGaz6Lq++4Z7gOHBYjPtZORkoh1khb8ogJxfOQMgybkgqxNnAIER78Nd3ohS1kA6ncTl9r4ro7An2UwwugvIUHLxjXzgWVZ2BpVzbiQjl8VkpaKk+1ty45BGDZIP74uieTAkh7tIkh0jlHcRIUROxxqKA5RiBP/gaNfNZ2XlG0uyioVGJmuSKD+E5rMOGKFlMVoFeKBxNrVzz6fteSfGIIBuaRxy9dn40kFWbWjnrqU2kd7peLbYLJ6W5MQaDdVbhqSoYJlYmTiy5nHcc7lUYWFbSBJE7CDJrEWNJ4ssCSrLvLRksph1xyFt3QCaG0VzY2WTOXeUB0mWQYCVjiEpKrLLh22k6V3zKIMtqxzCwFxg2984UoWv+42HSPfvAEnGTPSjhWrB3snYqweqUL0h53mkYtjZJLKiUH3YOe9JHCnVu43OFXdjmwYTqipoKu/n5HErOf3hQ/JPddgZjtvw1w+8SnW590NPXS3tGD4gZDIZrrzySqqrq3G73Rx77LGsXLlyRLvly5cze/Zs3G43Rx11FOvWrSt8tn37dhYvXkx5eTk+n48DDzyQxx57rPD5unXrWLRoEX6/n5qaGs4//3x6e3dKYJ5wwglcfvnlXHXVVVRWVrJw4UI+/elPc9555xX1wTAMKisr+cMf/gCAbdvcfPPNTJw4EY/Hw0EHHcTf//73QnvbyPCPh+5j9lEnUzF+Jqd+/NNs2fgWwM4AMmAm+rGNDLLmYsZhJwDwyc9ejL/+AA444hSEZXDTD3/KUSeexq9+eRvNU6fjDzmZRJFIhIsuuoiqqiqCwSAnnXQSq1evLvRhy5YtnHnmmdRUVxMsC3PkUXN5/KF7MZKRwti3b9/OV77yFSRJKiQwyJqLFStXMe+k+Xg8HiZNm8XXb7wFQwuh+auQZYWuzg4+8Z//RbjpQJqnTOXuu34H7AxG54Vvho4R4I7bf8HMWbPwBcupbxzHly75r5wrSBCNp/jSVf/N+BmHUzNpNiefsoDVa9c56avD6S9yd1IIgZGKYCQj3HP3bzhoziH4giEqKsKcsvBUomlI2S4MdCRFJ6mE6YykiQymufmuf/Lo6ji9WjOr2mW2tPazcfN2VnVodJo1Bb98Xje7es4ZTP/0L5h4+jdYV385v+xcxC1PpvjSDx/hp39+CUlx0VQbxgYeXu9mR0R25Fk9ORZc4cQlHOlUN5IkowdrQIAv+Q4u0gykVRK92+lob8Pn1qmrqXAWCpKcqwuRASknLmTnFP4EkurESiRFA9vENjK4Qg0IIRjY8PSIiTvVu43o5hccMkFJwrYMMv0tSJJSxDFVfdi5aL5yNG8ZrrI66o+9iMYct9JoO6tdoXvVQ6T7dmAM9pDs3ICRjLKtJ4uu7tqlFBlM84t7X/nQXUr/1juGdyuP+H7w9a9/nfvuu4/f//73jB8/nh/96EcsXLiQzZs3Ew7vTFG75ppr+L//+z9qa2v5n//5HxYvXszGjRvRNI3LLruMbDbL888/j8/n46233sLvdzIZIpEIJ510EhdddBG33norqVSKa6+9lnPPPZenn366cP3f//73XHrppSxf7vhnN2/ezDnnnEM8Hi9ca8mSJSSTST7+8Y8DcPPNN/PHP/6RX/7yl0yZMoXnn3+e//zP/6Sqqop58+axffs2PvX5L3HxFy7gwgs+zWtvrOG/v30T4LCrjhZAXvnqa1RXV/ObX97GicccjDxEuuWdbS088OBD/P2v96C5HdfNOeecg8fj4dFHHiIQ8PGb397FySefzMaNGwmHw8TjcU5deArf+uol6C6dP//tIT5x/n+x+sUnmTzzcO6//34OOmg2F33h8/zXRRcVdhJbtmzh1FNP5aabbuJ3v/sdPT09jvH86rXceeed2O4Al55/Ke0dXTxx/x9RFIlrvnETPb3OJOXAKaCThozx9l/8mq9dcw3f+eY1LJx/MtFohBWvvOa0k2Q+8/lL8Xg8PPCX3xIKBrjrr/9g4aLTWf3iUsrLQrnitpEwUzE6u3v57MVX8b3rr2PxovnEYhGeWb6KjpjA43WjyBKhgJdYyolHKIqz2v6/e1bgcWlYtk0mYzrZUunJeJT8qr+lyC/vqZxAezrIPa89gmFKVJd76R5I0DWQwO9zYfsraGgKsqM7Bs3TkTv/WtB1llQN28giKQq2kXbeA0lG9ZYxDovTJvXxRGsTXUkbjzrAJxfNZOacCax/swIjOQBG2uGkcgdRda8TLNdcBZZYISsF3Q9Zc2ObmTEDztnBHkfG1B3AjPcVdlRacOwsp6G7qsHWtXS+dDeSqo/YWQ2fN1K924i3rWVg/dNIkoxtW47xinbQnWjApQiyo4eJCtjeGeHeJ9dx3eeO33XDfYh/W8OwJ/KIewuJRILbb7+du+66i0WLFgFwxx13sGzZMn77299yzTXXFNpef/31nHLKKYAziTc2NvLAAw9w7rnn0tLSwtlnn82sHAf9pEmTCuf94he/4OCDD+b73/9+4djvfvc7xo0bx8aNG5k6dSoAU6ZM4Uc/+lGhTXNzMz6fjwceeIDzzz8fgD//+c+cccYZBAIBMpkM3//+93nyySeZO3du4XtfeOEFfvWrXzFv3jx+fcdvmTRhPDffeB2SrDK5eTzr3nyL//3Fr3NVxSMDyFVVzuRTUVNPQ9OkXDDa+cFmDZM7fv4jGppnorp8vPDCC7zyyiu0bduIYiYQwuam667goYce4u9//ztf/OIXOeiggzhw+mRHIlTRueG6r/HIo0v4xxPLuPKAgwm4ZWQJPKpNmctAcbkwMwm+/72b+MxnPsNVV11VuD8/+9nPmDdvHrfffjstLS08sWQpzy95gEMPno0kydx2y3c5dN7pQ9b0Tkro0DF+/+abufKSL3D5Jf9VWP8fOmcmSBIvr97Aa6tWs23dClxuF6qnjFv+92QeevgRHl76PJ8774yxtSuETWdnJ6ZpcubHFjCusY5Mtoay8U5RmYKFJWQG4k4gX1UcV51LV+juT1BfFaS63MuazV0IATPqyohF+nl4vZupfjeHnHAmsLM47d4nW9jeEUGWoac/hktTME2bLTv6cbtUgj4XFaGgs9rvEGRiHbiCdSjuINgDSKobYaZBkjDiPUiKjm2kmVaWQPfGQAgm6js49qBTHc3peRePID4cOlm3v/h7+t9cgp1J5OpTJLKRdox4L6oniOYrH5E9pAeqkCQFOzUIqitHhGhjDHaS6t02piJgfo7IxvswEwO4Kpp2mfGUb2/E+x2hKbcPktGCK63SL1PrSTCY8Y3+bPOPWMDSFZs5d/7MD62u4d/SMOzKt7ovdg5btmzBMAyOOWYnLbOmaRxxxBG8/fbbRW3zky9AOBxm2rRphTZXXnkll156KUuXLmX+/PmcffbZzJ7tsDOuXr2aZ555prDqH/79ecNw6KGHFn2mqirnnnsuf/rTnzj//PNJJBI89NBD3HPPPYCzo0gmkwVjlUc2m+Xggw8GYP3GTRxxxBE7A7mSzNHHzeN/f/HromNjBZA1TxlWOg4IJEWlqbGe6qqqghFZvXo18Xic2sacIczNtKl0ms0bNwIQj8e5/tvf4tF/PEJnVzemZZFKpdnR1o6ZimJnkwVKC9vMYpv9mKkob6x6jXVvbeBPf/pToT9CCGzbZsvGDWzYuB5VVTl49gEOFQUwffp0ykJBJ+sn18e8UVB9YXoHorS3d3Di8ceMKHyTZZU3N7xDPJFk3Iwjdt4ESSKVSrFtRweusgZkly+XNyvtjMHg7MBmHTidE449isPnncrJ847huOOO45hT/oOK8iAgoQgbQwhkWca07IIOgC0ELl0hlsjkXGkC3GEamsrY0R3DfejHyMbXsvGvX8G2TLrsap5cNwdJ2GAamEKQSKsosoSmymQMi/5YijMPUtHevotsJoGViWMmo7hCNZQdejaBhlmk+3fQueJukBVUTxmPvpFgSVcTGcmHRzE5bWIFJ+Um87GElvL/bz7jesIz5tO58h5iW18B20mfFWYaM2lRfcjZI37DeQGprlf+giwpSIpDWW5nUwxseqHo+nkUzxH1mKko2f5WVHewUIE91AANba+X1WMmI1jpuPN+SBKSrNBcW8mpiRYiqfH0ZDzsCr2R5Ida8LZPDENbWxvXXnstjz/+OMlkksmTJ3PnnXdy2GGH7Yuve9fYU/3a/Q0XXXQRCxcu5NFHH2Xp0qXcfPPN3HLLLVxxxRXE43EWL17MD3/4wxHn1dXVFf7u841crXzmM59h3rx5dHd3s2zZMjweD6eeeirgTLgAjz76KA0NDUXnuVw7J3lZ1XGVNRQCoqrL+R5XqA496N9lIFjWXGj+CmfXIGy8Xm+REYnH49TV1fL4fX8YwYlUWTcBM5Pgq1d/hSefepoffO9GJtRV4HbrfObCy8lmMpi5OMNwv72wLeLxBF/4z3O44oor0f07f4RGKkZ92MWbiYFcY1GY5PN1F4rLjzvsCK4MDQR7rEHnc3dwVMM4GI1QW1PNEw/8aQiNB+jBWsrKQoVrSbKKPORzJAnVUwbJAR75629ZsfINnnruBX57191870c/5d77H2H8uEYsZFRZJhRw0x81sCybTNYJSm9tG0BVZAzTQpFlNEVmIGkTCATR+9/g1df+Rn/aRdhjEiVDJhGl1i3oTrswcyyzFa4045saydgq/ZEYjcmXER6Bt2YamVgntpGibPrJVEw/cefvSZJwBetojess7WvCFlmqXTGilpcl3dNYnA7SnLv3u6Nbd5c3kB1oRUJCdgec+gZho7iD+BtnjXpO9cFnEt3yArZpoPkqyMY6MZMDdK38K/1vPjHCYzB0jrDNtFMYGO8hG2lH84dHpK8On1P0cCPp3u0IbGRJRS+rd2jQJT9uxXR2drsQ9UllTLLGHhAu7SPsdcMwMDDAMcccw4knnsjjjz9OVVUVmzZtory8fG9/1XvGrvRr9wWam5vRdZ3ly5czfryj7GUYBitXriy4MPJYsWIFTU3OZDMwMMDGjRuZMWNG4fNx48ZxySWXcMkll3Dddddxxx13cMUVV3DIIYdw3333MWHCBFT13T3Wo48+mnHjxvHXv/6Vxx9/nHPOOQdNc3h7DjjgAFwuFy0tLcybN2/U82fMmMHDDz9cVEy2YsUKYGce/2jQNA3Lcl7+fIaQ4vIjK1pRZs8hhxxCZ2cXmqrR1NS4M/vGtkCCbLSD5S88z/mf+STnfPI/sY0Mkd4OWna0wdzDnWCmsNE0DdMq/rHNmXUA6zduYXxdGa5Qba7AKkMm0oYApk2bhmmarFq9jkMPmYOwsmzaso1INIai7yw2G1pEFwgEmDBhAs8tf5mT5y8YkSE156DZdHX3oOkuJjSNy1U4Z1HcAexMgmy0AzPtGBd3uAnLSCFrHmTNctJlUxEU3csxR8/lmGOO5rqrL2P64SezbMkTfPbCi1EUmYpyP+GgB5cKiYgLv1enusJPdDBN1rRBCMoCLvpiSXxunU8e38CKFX/h0W1HkLY13LLJERVtuKQsQgjqXBn6sm4SpgtdMtBli5SpEHTLhORBNG/YyRySJIzBXrpfvZfI+qcKAkj531tfop60KVPtsXEFqqjRvHTG5T1aHee1pX3J7diWiaQ6qaWyqmNnkyi6B9vMFnE05eGpnEDtUec7rp7BbszkAIq3HE/FhILHoFeZSESEqAn7CZtONlWiayO2kSwUYgYnHUX90ReMMFzD5xRZ0fBUNOFrmEWiba2jBJgOsLTvAHQ1wqyybtZGqsc0Dm6Xiq7tmmdpX2KvG4Yf/vCHjBs3jjvvvLNwbOLE/YtSdrhofD7GsK92Cz6fj0svvZRrrrmGcDhMU1MTP/rRj0gmk1x44YVFbb/zne9QUVFBTU0N3/jGN6isrOSss84C4KqrrmLRokVMnTqVgYEBnnnmmYLRuOyyy7jjjjv41Kc+xde//nXC4TCbN2/mnnvu4Te/+Q2KsuuX7NOf/jS//OUv2bhxI88880zheCAQ4Gtf+xpf+cpXsG2bY489lmg0yvLlywkGg3z2s5/lkksu4ZZbbuGaa67hoosu4rXXXuOuu+7a7X2ZMGECTz31FMcccwwul4vy8vJCle9QzJ8/n7lz53Le5y/jpm9+jcmTxtPR1cMTy57mjNMWcughh9A8cQIPPPAgZyw+E0V38Y3rrsW27RzTqRPYHj+ugeUrXuUTZyxCd+lUhsv5ype+wEmLP83V/30jnzv/PEKVDazfuJmlj/+DW3/0PaZNaeaUk+dxxde/zW0//z9U3c3Xrrkej2fXroAbbriBSy65hOrqahYtWsTg4CDLly/niiuu4JRTTuHIww7m3PP/i+/d8D9MnthER2cXTyx7hjNOW8ChhzgpjfmUWc1bhqzqSLLjilr5+hqe/eeLnHziCVRVlLHy1dfp6+/n0APGUe3J4PaH8AVzOgK64/qxbMHUcZWkMgapjEl/LMWXP3kU9VUBasJ+4q1r+d2OOgQW1a4EUdPNK331HFXdzdK2+iG6BAZpS6K1L0UwqPOZU6Yyvvd5jGQ/suYh298KsowrVI9tpulccTfS3Ason3YSAxuexpPYhIuZRNIKIaudqOlDUdWCuA+MnhQyUrZzIsdXbMFKxwqyne6qybQ9d/uYccO8m2pg0wt0rfwrnooJBY/BY28aPLXqJdJCQ7eTLKzewHHBmLPbHCJwlGhfS7xtLcAIwzN8TqmZu1MYKjvYw0ArGBvXUVOtk42kmRXq5u1YJRmhMjRBVFUk6isDHypFxl43DA8//DALFy7knHPO4bnnnqOhoYEvfelL/Nd//deo7TOZDJnMzsKgWCy2t7s0KnYnGr+38YMf/ADbtjn//PMZHBzksMMOY8mSJSN2Uj/4wQ/48pe/zKZNm5gzZw6PPPJIodbAsiwuu+wyWltbCQaDnHrqqdx6660A1NfXs3z5cq699loWLFhAJpNh/PjxnHrqqcjy7rOSP/OZz/C9732P8ePHF8VCAL773e9SVVXFzTffzDvvvENZWRmHHHII//M//wNAU1MT9913H1/5ylf4+c9/zhFHHMH3v/99vvCFL4z2VQXccsstXH311dxxxx00NDSwbdu2UdtJksRjjz3GN77xDS75yv/Q09NDbU01Rx95KDU1tUjAD2/6Nhdf8TWOnXcClZWVfO2qK4hGilP+vvG1y/nytTcw+5hTyWSyDLa9ycwDpvH4fXfxnR/+jAVnfBohBJOaJ3H24oUF19Evf/pDLrv6Ok5eeDo1NTXcdNNNfOtb39rl2D772c+STqe59dZb+drXvkZlZSVn/8fHMTMJZFnlkYfu55vf/CYXX/E1evv6qamp5pgh43F4OsQIGhBZc1Fe3cALL73CL351J4PxOE2NDdx84/9w+qIFTp/TAxiq7NRGALIs43FptHXH8Lg1UmmD8oCbg6fVFVbpz271krY1qt0ZJFsQVJL0ZPw0jGvC3ZWlUk5SpqXI2BqGULhwfhNHH3s04dTb9KxuZNOW7fQlUwQtHxMbyh2J1Mggmf4dvPyP3xNTKqmtm0JjYAUfG9fBYzvq6Er78Sgmi8Z149m2gVTvYQXxnaGTe68ykTvvfwlklaaacnojyYJsZ41HRlZUfA2zSbStAVkZETcERvzO+998orC639qd4PHWieghlYagTltLK49urWLaoROpkNcWBI4sI026r4XWZ24vuJNGMzyjxUc8lRMYp/Xjc29kUOiU182kuzfCJB8cMbORh1e0MZiL/dSU+/jixw/9UAn1JCHGSn94b3C7HVGLq6++mnPOOYeVK1fy5S9/mV/+8pd89rMj+dFvuOEGbrzxxhHHo9EowWAxL386nWbr1q1MnDix8D0l/HtiqLtnaGGX6gkhKQ6LaXawe/STJYmCGhqO4ZFU3clcsbLogWqAPWJ33VOMxhY7tLgOGDEeCZxA9BjcSLbtVEkb8d4C/5JtGdhm1snzl1UsLUBrZx/3LW/jT0vewrRsVEXmjOOnFWkOb2nt5/Kb/kI20U9ITRE1XGjeMj572hxuu+efVLniKLKMLaA74+OmSxcwbuAx+t9cwjOd41jSPYWM5MOtGJw2oYcFk5IkOt/m2a7xLOufSTJr45bSLKjexIk1rbQnvUREOWVKjMlN1VjZBPXHfJ6ulX9FCFFw8ZqpKG8O1vDLdROp8Rl4yurQAjW0dEX41qdmcnAjxFvX0rvmETID7UiajitUjx6oJhNto2zKPAa3rxyxixialfhmrJpfb3S0q610lETXZrozfr40p5PJ1msIy8AVbiITaS2QAzrxAonms256V4vKoTsfn1vngtMO4hMnz2RLaz+rNnQAFBnsvYlYLEYoFBp1bh2Ovb5jsG2bww47rJA2efDBB7Nu3boxDcN1113H1VdfXfh3LBZj3Lhxe7tbJXzEsLvq5eGspnmXkRHvcRoUKqulHPEb5KtLJaShhcVIskbWkjFNE0UCKe7IYQ4Npg9nZs3TWOSzTgp8R7tgch3BFlvWUIi/2EYG2eVzaMB3k8WVH7+My7l2nvZbknNEc8KhFrGymNl+jGyWLa0DjKsO4fVoJFMGb2/tZUtrf2ECam4Mc+E587jroVcYSGXwBVx87swjGC/W45KyRNJyTlDHg8+rE5Id1tS2pJ8lPdOwhU2V1kdCq+Ox7RKT3W9gpXws7ZsBElTrMSJZnaXdU5kWHKBO76dejSMpGlYuy0cIR3xH9YYxc9TkxmAvIcmLRxNE0jJEOhjI6PjcLsZNbEZ3xxxZVzMLioqwLDLRdqdGQ1aIbn5h1PqDoat7Le4m2L2G3kiScq9GJKvhktKE3VlU26EwN+K9YJlouWeWV5LbVcLKaC6xoSysNWF/0f1vbgwX4ij5Yx8W9rphqKur44ADDig6NmPGDO67775R27tcrqLslhJK2FMthnzA2jJSzg/XtinM+ML5e7FRyEMU2sm6j1haEMmoCCEhSVCGiXswguzV0Fwu3NrOn4mRjBRYTIUQTtqnpOykgh+FGsMyUo7BGMoWa2YwM3HU3Of58YKE4g6gecr2iAZE1lzYrjLSiUEUYaCS71NOHc62ME2DVMagoTroKIwFBC1dkREB3+GTVr07xqa//ZWF1SpLuprpzgbxKCan1m2lIuWi07KI2CHSlkq1O4EkBBVBnY5BD2b9ccRbVpG2FGq8WURWUKZn6TFCDJh+6vQBEI5MqqK5c0HqWbSZWZLtb+U2dA5vVo3axikVCks6m+mM65S5TC447QiaG8Nsf/LuAtVFvjocwwLbIjTtBCIbn0PPBcaHZx/mJ+sGevjk8Q3c83wb29t6UG2LBVUbKI9th0AlweZjSHa+jZ1NYMS6kFTNIRXcRcLKruqkhrKwDmxazvoNmxhUqnm5zcMzr23DMG3KA+7CbgJ2Bt6HGpN9ib1uGI455hg2bNhQdGzjxo2FbJwSStgVxlxdj0E3LWsuh2aiIH+ZNwwgybk6AMtyCtDImwMJcpW4eCqJxuOAgaaAJST6MxpSRiClEshKmoqQl3DQ41Bbx/uKqK2FEEhY2CJHhKq6CtQYO41Wn0OcZ6ccPqjchGcm+p3gprCd/uTGa2cS4Cnbo/vVH0vRFxXYthdJWATkBEGtmJ5aliU8Lq2gMNYbcTKRRgtuDp20olu3YGUSnFAdYXo4QX/WTZkcpSksI7sPR1IUyuQobsUkktEo0y36Ylk0I4nes55y3cAtZYmkJIIKxCwvXl2hOuzD7R3naDKExxVVGSMENjaSyAXfc+SKJ9V3McXXy0DWzcyT/5MjTp45jOrCId2TbAMtUEXTgq/hLm9gcNvKMbMPh07es3Uv1TMa2LFlPeVKgjqvw/UkhCDZ+Tay5sEVHk8m0kqmrwV3eBw1c8/fpUrc7uqktjx8I/c9s54lnZPoybQzaLpy8SAVW9gFVbeXX13Dn5ZtJGWC3+crMhj7CnudK+krX/kKK1as4Pvf/z6bN2/mz3/+M7/+9a+57LLL9vZXlfAviIJOQq6YLE80NxbdNDgU2gXXkRCFSlNJVtG8YVAUJ91T1SnQV0gSmr8CCwWBhCLjnCOBaUsIpEK6YF80STpr5vqWF8HZCZH7TiEEIscPJHKsqXkxIIcg0ElLzQe1JdVFns5bypEJ7sl480hnTfqiSQB0TQUkYqabrCU7FedCIMkKuqZz1rxpSBJs3dGBmezj7EO9BQMwnHY7j6Esq7X6AAf6O6j3DKK6/VRMP5HwgQtp8MZZWLUBWYJeuwphJPnY+G6aG8KMr9Q4bUIPmq+cXlGDJCksrHuHRm+CioMWU3PofxCaeHhhsswL7siSmjMKudRi28RKxah3DXBgoAPX5nvofuPhAtWFq6zRiRMJGwSEZ5xC+ZRjCplCozGuDp+8LSNNsPtZDvC1U+caACuLlY5ixLrIRrvIRjuRZBlf7QxUXzm1cy8YkykhX9OgDdmp5Dmo8ve667X7WfvqcpZ0NpMVGmlLye2SHMLE6GCagcE0zy97jDvv/yfpaAflRgvpaBd3PbTvuZT2+o7h8MMP54EHHuC6667jO9/5DhMnTuSnP/0pn/nMZ/b2V5XwL4ixpDJ3RTedL5DbKVTjTLAFneR0LGdsNJy0cYEedGoWrKyJLMvYtoYsDEzL2Vdoao7bR4GsYWGaFrqm5lamI43DTkg5zeecIRgiOCRkpVhzAnIcUobT79yOYeh4dxVrMU0L2xaOARM2MiamkLBQ0LCRJFA8IaTBCPOm63jXv8aObZsJq0kaWpJseXgNgaaDef3Zh+gZtKkKyBxywplFqmihycfSt+5xR1UO0PwVhGcuIjvYQ/3RnyU8Yz4NvVs5xa6lNyHIvnEXzQ1hWuM6fYl6Jns2M3VyhP6MizI5Qr07jrDc9K97HCs9SPWcM3dyErWtcwjzhNhJO+7cReePrCErOsgq3a/eS8O8S3OxCYGnegpGog9Z1ag++MzCmWNlCg0vSFM0jyPxKoYVlQkbSXVjWwbpvha0QBW6v4LAGIV0MHad1GDbWiLrn8bKJrGyKfpSKmlLxaM4O1AJge0UtZA1BbKdIbbtDVJmLTWeLBhpvKKd3mSSDa8spbnxk2P24f1in1Q+n3766Zx++un74tIl/ItD1lwo7iBmKoIwMw5j5x5oMQyNNwBFrqeR0psVqG7HjeLWVSpCXvqiSSxbQlYFmg0i55owLRtZllBVBVlTRxigPHbKzTouLcXtR9E8OwPDuZ3AUAqN4mPSiKDz7mItqqogyxKmZaNIwum/LKHpGork7BpkzYWVTbL10R8T7FnNgT6QNDdCQN+6J3jwpTaeaJ2QK2ozWNj+ACc3/ho7m8I2Usi6D8XlJTDhcALjD0ESgoH1T9O35h8F33n93P+kHmfnsaVF4vH18HhLJcmshYsDOW1SHwsnZ0l0dmFnQHb5SA+0kX75L0Q3vYCvYSap7k1k8266ETGhwl3GVd6A7q8i3beNVO/WQn2EmRpAdftHrUcaagzy/x4+eTvKeaMnaAoJMB2pVSPWRXD8IbvNRMqrxDk7FQVvwyz61z6ek3X1kY33E9bALWdJWwoKNhYSNpDJZFFkOC64iUlaBx61loEkBDVnR+hWTOSWZaR6j9pnafb/llxJJey/MJIRrLRDroYkobiDe5wmKmsuskLBNC1UoZBPaN6V9jNAOOjB69ac81SFZNqgL5oka1jIskTI58I0LdKAe5gBQogcHbTDh5OPP+SDxyOMkr8CoPhYoGpE//Yk1jLUqBmW4wYL6Qa6Ijn8crKCMA2sTBw739+cAZI1L60xhce21yJrKrVek/64zeMtdTRr26l3RUFWsNODWJlBstEuMgM7EJaB6i0b1XfuqZxAasJZPPb829h2lhpPloG0yhOtTRxQtZUKJGxhYQ72ODsvyclC6n9zCaq/EtUdcHS2h1WnI6tgm2ieELq/ilTvOwU6C0V342uYRbDpYPwNs0adKMcKBA8tSJNkJXffUyPOJ8fimu9LqnvTCPI9yMUWVj1EdPMLBZ1vPdSAMdhJ9J2XnASJXKKCsAzq3TYLqjeytHsqLtXENiV02SSgZjm+cguLw+uRUDi17h0ea6mjJ+3DrVgsnhyjTh/YpxQ+JcNQwn6DoslQdSFs06lsdQecz3cjvuMEYpPYtkCWpULQGMbWfs7Draugq4W/5w1FMm0QTWQYGEwXXbOoDzk95qFEemPpPuePj3ZsaP+KNKlhTN3roUZNMhPImQjCcnYYkubGTOREhbJpCtlYto0w0wyYNWSERo2WQhIKATlGt+Gn3/A5hsG2AMt5FlLu+SQH0IO1Y3KMGdVHYHn6qS/TkCUBvdvpStr0Z12EEQ6zqWO1kPOCO7EujHgvJlIuPDTUjQTYJkgStpkl2bUBMz2Yu8ce0gOtpPt2kGhdS+1chx14T8WIhrqZsrFOtj72gzHfj9yDRphpsoO9ozKrdq64m3TfDkd7ItyIEIJ4y2t0q5OIGGG8yRT17kHQ3IUxnlD5DlP9vfRnPZhCRpVswnqKencMhIQQFifWttGstdBveqmpCNFUZiFJ+47CB0qGoYT9CGNNhkYqgp1J7DJ9tTgQq2BaNn3RJF635kz67xJuXSUNRBPx3V5zdzuS0YzS7gzVu4m17DRqLmzDV8jSMga7KYhGQ2HlDYAkM+nAw/APBIkkBggqCaKGC49sEFYHGao1YSOQJRnF7Xdy+hN9BTfM8JTNmrAfv89HNAuVZV4SShK30k/AaEf1BgAJMzkAloEaqkMYuWC9bSPrXsg6zxBFB2tIdpUQziJBdSFsJ15kxDoByalfSQ7Q+sz/Q/UEHO2F3M7AFarbJWFmoRJ64z8RQ3cGRRiqo+1kuA0d88Cm5XQsvxPLNJxdmiRjRDvRQ7U80zmOZQPTSJkKLlHJgqoNnFC1vejq9e6YYwhGfxGoOfw8KtIxZydix5GkfUvhAyUFt39ZDBerlySJBx988APvxw033MCcOXP2qO3QyTCv4QCSU/TFSCU4gG3btiFJEq+/9jq2LXj15ReZ1BAmGR/EtgWm+d4ZKvPB3bymgarIY14zTxb4fnWpi673HnSvC6SFkrQzuyuXmishoQWqKD9wAVPO+QkHzJ7DKeVrwDboSnuQgQXVG6n3JIbdiCy2mXVUz1QNhBhVVxmcdNcLTjuIjGGyYXsPWUtwWlMnjb4UqjuIu3JiLsZhk412YGWTyLoXWdGcmJIk5yrTdyYX74QoZJQZsQ6sbMqZzHNuNmOwm3Skq6Dm1v3qvdhmtmDEhG2PmrK65cFv0rf2UXbWt4z+veQy0sIz5hdpNrQs/QmZgXbHDWZbSLaFZRq09AuWdE/Btm1qfQY2Ekt7ptGeDu3xe6D5woSnn8j4+V9myid+zIRF19F81k37TDsmj9KO4d8EHR0de8xwe8MNN/Dggw/yxhtv7NtODcNoPnnZ7cdKDxbotsdyqSiqjCxLWLazRR8aNH6vGBrcVRV5r1zz3WB3O5FdoWBkcxXAWqASSbFpWvA1yqccQ6p3Gzue+inHlbXR7G6nP61RrsQcV4esIkkakqw4CmRmBoSFsCyEZYIvTNnUeYWMotEgSU4dgpWJgazgqWom0bWRVM87SIpDKS4pGpKq4fKWOUFZzY2ZimHEupwMoYKByF9UBglUfyVGrHtkBhEgsnHiHW/jr5vhqL6p+piEmUVupmAtyWSEkUHvAsk7kqIRmnI8ExZ+FdhZr4CsIGk6djYDwswTrdBnqmTVENWuOJJtUe626Ey46M9o1I/5KGXAqWvRvGEaT/zSCM6lDwIlw7AfI5vNFgj03i9qa2v3ynX2NYZPhoDjRtqNS8WlOYHYoagIed+TGymPocHdfCD6/V7z3WJ3Lqddnaf6wkgRJ9dfVnVqj/l8Qdg+O9iDmY4jIdEYyNLoSzlBf1nBVdbgGAUjRTbWA6oOpgE5+VXbMhnctpLqOTvTQgc2LSfVu5Uuu5Y/PNqFisWEcpPWTov73mmgwt/JdNtxUQkksLIIM4NtpPFMbMZKDWBlE2ieAN6aqY7bZMTOTEJSVBTNjRSoxkwOjBostpIDJLo2onmC6IEqQhMP32XKquopR9gmirccKzmkPkDWUN1+zHQcWXNRf8znaTj284WPh6a8Cssik93hfKDoqG4/VUIlVF5BWlRQ7pXojSTwZHsIu7LFbr0h0MrqwMhQcdDpVM8540PThym5kj4gnHDCCVx++eVcfvnlhEIhKisr+da3vsVQDsMJEybw3e9+lwsuuIBgMMgXv/hFAF544QWOO+44PB4P48aN48orrySR2Lnd7+7uZvHixXg8HiZOnFikRpbHcFdSa2srn/rUpwiHw/h8Pg477DBefvll7rrrLm688UZWr17tFA1JUoFCOxKJcNFFF1FVVUUwGOSkk05i9erVRd/zgx/8gJqaGgKBABdeeCHp9Fh+25148803Of300wkGgwQCAeadNJ/trZ3OpKi5+MPf/sEhxyygvGEKBx99Cr/50/2jrp7DQQ/V5U4aakN1kHDQw/bt21m8eDHl5eX4fD4OPPBAHnvssd32aeg1x9WEaKgKMK4mVAhmfxSgecvQAzWoniBN868qUEBHt67ENrOobj8CgTCzzs4gt8uw03EkIDjhCOcdyK+ac0WEqstXKNgCp4J389+vofWpn/PGIz+nv3M77tR2Orr66U3pdMZVfvVGFc90Njods4zCwlwCjFgnDfMuLbhJyqceh6RoFK3eFQ1Z1QoUGlWH/geusvqdhY1FEJiJPqxsksHWNUBOxW1IMR049Qa2kSHR+Tap7s3YRhJJ9yFrPpBVZFXHMrPIsoIrWEN4+olF36IHqpBkhfTADmf3IytIqhtfzVR8tTNo8CY49+gqFM1Fa08cM9HHwsr11HsTQ9Kbh0JClmT0UPWHahTg33zH8EHzj/z+97/nwgsv5JVXXuHVV1/li1/8Ik1NTUWU5D/5yU/49re/zfXXX+/0cQyx+ssvv7ygefG5z32O9vZ2nnnmGTRN48orr6S7ewxmURxFtHnz5tHQ0MDDDz9MbW0tr7/+OrZtc95557Fu3TqeeOIJnnzySQBCIccnes455+DxeHj88ccJhUL86le/4uSTT2bjxo2Ew2HuvfdebrjhBm677TaOPfZY7r77bn72s58VaVMPR1tbG8cffzwnnHACTz/9NMFgkOXLl2OazmrqT3/6Ezfe9AN+9tNbOWj2TFavWcfFl36JYHnVqKSM+Wrl/Kr+sssuI5vN8vzzz+Pz+XjrrbdGlT/dFYZmLH3UIGs6surCXd4wIm3TVz8TK5N0KDtwFOlkVSu4bFzhRqduI5FbRQsBioYQdsFPP7BpOf1vLkEIpz6hPJPEZcfpTrjpS3uwEGiSiWRnWdo1mam+7lyg1TE0WlkdQjg7mtDEw0n1bqNzxd3OzjAXaAaB7q+i/tgvFFFo6P5Kdjz1s5xeeDHcFROQNdfuJXslyaHfKFSgW0iaByyBnU0hKSpqoJLaUegvBlvXYGVTGIO9OWoU0PzlqJ5QIZZxzvxZHHbgIG88ehshJU613Y6w5ALxoj0k4C27fKiewD4PLO8JPppv+17AWPS3+xLjxo3j1ltvRZIkpk2bxtq1a7n11luLDMNJJ53EV7/61cK/L7root2K1T/++OO88sorHH744QD89re/LVJ9G44///nP9PT0sHLlSsJhxyBOnjy58Lnf70dV1SL30wsvvMArr7xCd3d3gfTwJz/5CQ8++CB///vf+eIXv8hPf/pTLrzwwoL40E033cSTTz65y13DbbfdRigU4p577imoxuX1qQGuv/56brnlFj5x7nnO+KcfyPqNm/jVr341qmEYjpaWFs4++2xmzXIqVXdlpP6VkR5oo/Olu7EtA81fiW2kSHVvYsLH/gcj0Y8R76Vv3WNIil6o1o2sf5rqQ86m783HycZ6sM00iitQIL0DGNj4HLZporj9SLJMvS/NguqNPNQ1m6wNumxTqSeocGXozvqJ2GXU4zCnasEaVJcPaUiWT97FJSwrl9LpBH6tTBx3eByhiYcXxpRPN93yyHdJtK7emeYqKU5cZTeSvdnBHmRVx1t/AFYmTrp/hxO/MrNIyKBAaMpxNJ102Zia0LLmxlUxHisTB8tE0b0jYhkNgysxgt24Qg1kBw2H/dXIopfXE5p8LHqwBkX3Fhm9Dxv/loZhS2s/f3h0NUJAU00ZvZFkgbBqX+4cjjrqqKIt5Ny5c7nllluwLKugsDZcF3v16tWsWbNmVLH6rVu3snHjRlRV5dBDDy18Pn36dMrKysbsxxtvvMHBBx9cMAp7gtWrVxOPx6moqCg6nkql2LJlCwBvv/02l1xySdHnc+fOLVKEG60vxx13XMEoDEUikWDLli1ceOGFRcbTNM3CLmZ3uPLKK7n00ktZunQp8+fP5+yzz2b27Nl7dO6/EvrefqrAQmom+tFCtZCTxayes5jo1pX0rnkEPVDMROpvnEV4xkk7eYxUHT1QxWDrGrY8+E2y8T4QFlY6juL2g21wQuU7lOkGv285GEkShPUUkawLr67Q0NiAZpkYgz1IuQyjoStkPVDlcFoV+d8FtpnJUYoXw1M5gebF32LDX76MlU1gZhJISAXq7V0xoOqBKtoSPvp6DSq8OpVWjoxRkpFdblqjMm+/2UY09DLTpo6MT6QH2rHNtJMppajIqpvauRfgCtUWtR1aZa0Hqh2+LdsqJALsj/i3NAxd/XES6SxNNWXIskRlmXdUGuIPAz5fsT5yPB7n4osv5sorrxzRtqmpiY0bN77r79idLOVoiMfj1NXV8eyzz474bFdG6P30JR53agjuuOMOjjzyyKLPdidVmsdFF13EwoULefTRR1m6dCk333wzt9xyC1dcccV77vNHDcIyibe8VmAhtYUg29/q0EvkJs1d6aAPz4YZms3jrZpM3EhjpWJY6TiyquKqauZgZQdRcwNLuibTa5bhktKc2tBCU7mOkQyhujzUzb0Af8Ms2tNBNq9pybl0J1A+/SQ6X7q7qNBNUrQcCWIxUr3bGNj0AggbX+0MMpE2MtFOJ53Ztka4ZYZqJPzlkX/y5zcmkTQkPIrBguo0J1RuRVZ1nm6rZklnMylbRVm/jkPCz7CwOcFh88+hes4ZDGx8HisVzXVOdnY4toXmCxftamBsKeH91SjAv6lhqAn78bn1PaIh3pt4+eWXi/69YsUKpkyZsstJ7pBDDuGtt94qcvUMxfTp0zFNk9dee63gStqwYQORSGTMa86ePZvf/OY39Pf3j7pr0HUdaxgtwSGHHEJnZyeqqjJhwoRRrztjxgxefvllLrjggqIx7gqzZ8/m97//PYZhjNg11NTUUF9fzzvvvPO+SBjHjRvHJZdcwiWXXMJ1113HHXfc8e9lGISFsG1cZY1OUZhtIYRNaPKxRamQu0rrHJrRM5yAzl8/k2TPZsqmHEf51Hm4yxvY9LdrWBBKcVBzH71xixADNJULMlEnfTY0+Vj8DbN4dHWcPzy6vMile/L4w+h65R6nJkDRQZhgmyN2DPmYiZGMYsR7MZIRp6ratpAkmdDkY4vy/YfGWNqSPv78RjNCVqkP2QwkdZb2TGdacAAygiWdzdgIFCy60gEeaw/wen+cMzvv43zLLNB9Y9sFAyZr/lGNF3zwUsLvF/+WhiFfhPOHR1fT0hUpvJD7erfQ0tLC1VdfzcUXX8zrr7/Oz3/+c2655ZZdnnPttddy1FFHcfnll3PRRRcVAqjLli3jF7/4BdOmTePUU0/l4osv5vbbb0dVVa666qpdrsQ/9alP8f3vf5+zzjqLm2++mbq6OlatWkV9fT1z585lwoQJbN26lTfeeIPGxkYCgQDz589n7ty5nHXWWfzoRz9i6tSptLe38+ijj/Lxj3+cww47jC9/+ct87nOf47DDDuOYY47hT3/6E2+++eYu/fqXX345P//5z/nkJz/JddddRygUYsWKFRxxxBFMmzaNG2+8kSuvvJJQKMSpp55KJpPh1VdfZWBgoEj5byxcddVVLFq0iKlTpzIwMMAzzzyzy/jLvyIkSUHW3EhWckwWUhh98hqNZyjQOHvE7kL3V1B35KcLE17t3PPpfvVearOdNFR5qT7sPwk0zi5wCUU2Psebb7zKb9YfjOIpo6HcRW8kwV0PvcKUTzcja56cm8bO7RbcRZPu0F2LrHsQlulQnuPQqai+MPEdqwqcRvn2lpFB1n30dAmSWagP2SiKQtgP7VGZHa5D6e3pYdDUCWsJurJhFMnGEjKmLfF4awNT/nEn9e4ohZqDQoqVskuaig+yDuH94t/SMMDYEnv7EhdccAGpVIojjjgCRVH48pe/XEhJHQuzZ8/mueee4xvf+AbHHXccQgiam5s577zzCm3uvPNOLrroIubNm7dHYvW6rrN06VK++tWv8rGPfQzTNDnggAO47bbbADj77LO5//77OfHEE4lEItx555187nOf47HHHuMb3/gGn//85+np6aG2tpbjjz+empoaAM477zy2bNnC17/+ddLpNGeffTaXXnopS5YsGbMvFRUVPP3001xzzTXMmzcPRVGYM2cOxxzjbLMvuugivF4vP/7xj7nmmmvw+XzMmjWrEIzfHSzL4rLLLqO1tZVgMMipp57Krbfeukfn/qtAUlQqZi5i4LU/75KFFIonrzzVA7JS4BnqXHE30twLKJt+EpH1T4/YXeQxmpFJ9W5jcPtKJFVHmAadvTH6o3GCqQj9MYFHEXSlPax/ZQuTzDTCcnYXiuZFD1YVTbqFGgRvmEz/Dkfn27RA1hzyRZcPMxktBJ4dPqRurGwKhE1I+PEo4xlI6oT90B83yJoKf1vnJm01ETXcpC0FCydrSZUEIS1FzPTQG7epleIj7l2+Gv9fAZIQY3DNfkjYlWB1Op1m69atTJw4EbfbPcYV9k+ccMIJzJkzp4imooQS9jWG/mZEvHOPXRndbzxMx/I7yQy0I2k6rlA9Qggy/S1ovjCaP0z5tJPwN87aY9dIdOtKtj7yHSTdQzbSzv07pnJ/23QsAZpkE3AJgprB5ZNeYFyZxI6oTH9KJezOcPgpn6ThuC8UrpXq3caWB7+JmY6TjXUjSZKjdSErTp2ErCIrKnXHXUTjsV+g67X72f7EDx1RJt2LbaR5pquRZX0HEMuqCNvGQqFMSxNUk7SlgkQMj5OGKwlqXYMoso0MXDH1Neq0viExEClXAyIx4bRvUD1n8Xt+XvsSu5pbh+PfdsdQQgn/bthTV8ZOqgfVWd1bFumBVhCO714vq8c2UgxseJrwjJMK19xdXdBg21qyg90Iy6I97eeV/noCapqEqWMKhWgWFozrpE4f4Lm+w3m8tYGUAW7Z4IK2Ki4Ycq18TCQfpBaSjOIpw0oOABKyoqN4Q0TWP40koHfNI44qHGBlEsiazvymAaTmCfzj9SiD8SRxU8WvZJBlmQZ3FAlo9vXSmirDzIkfLajemHMjaQXXlax5EJIElsGodWsfQZQMQwkllFCE4uCyQmagDdtIO/UGlU2oLh9C8xTVCIxVF5QPXNtmls4X70ZYBgD9WQ8pS6EpkCZtJMhaCoO2j0nKO7QnfTy6tRxkkxqvRSSjce+LPRxzbH+Rwcm7q7rfcOIWVjqBJatogSrcZXXIqptU3zZ61zzi7CA0D8I2kCQZxeWnI1vOs+9kCAQCBIiwKaLSmfHjVTJkbJ2AmuHchrWF/ubpsIUpoYVqMQd7HY1u20KWJNRAJf6GsZXdPkooGYYPCKOleZZQwv6Iorx7fxXCtrCNFJKsOiyow1hKx6oLGi/W49n2IFY2iZmKYaWjOCQYMmE9hUc2iKQVQrpF2lbxyynCaoq+rI+UpVKtRJEsFzVVdXSlJbr6Hb/+0F2Jp3IC4+d/mdScM4m3raXjpT8gKTqy6sZI9iMrKsIycZc1DjFyKUSin950iNhAL021YeTKGuqNXtriLnozfkIug0X122kImAgjQ2PIQvNVYlv+Qg2GFqh0MqckGcXlG7U6+qOKkmEooYQSijBa6mpdTgRntHTWrjUtRXVB5V5o6ehnw4o3OKhGgKRi5nP+c0yl9e64o17WO4PujB+ParGgegv1/hSkdTyKTdT0UK4JooYLn1vnjY0dPPHi5lHZCvJusjzddr6PFQctJrL+6YKRs7MpsrEutGAN9eF6PNtsunp6aWiahC+sM96f5YJ5kzloUpipk8eTHmijZelPnAB8sA4j2V9UgwF8ZFJQ3w1KhqGEEkoYgbHy7kc7NrQuKCDF6OrpRbFN/OkWjKSOlYzkZE/ztTE71ctm1qvE9XH4rQ6qslsQlqDRn2Zh3Tss6ZhIV8pNmdfk1LkH8sSLm3fLVjBav3V/5RAJTxnFHcATbqJJtlg8LcnD693s6I4RCAS55KwjiqhxPJUTMBJ9Rcam5qjzqTpocVGbfzV8JA2Dbdu7b1RCCSXwfpIORwtWj3YsXxd010Ov0NLbj0eB06cMUqdGMaJ5agvJIecbwmck6x6aG6uQ5CzCLife7sXOJrGzSU6saWFGZZZBuYI5p51FRIS475m39oitYHgfhxoL28zS9tzthRqME2tamOp34z70Y1SXuWnwp0boOX/UitP2Bj5ShkHXdWRZpr29naqqKnRdH4O+toQSShBC0NPTgyRJo3JR7U184uSZTPH1sWbZP6mtLKfBO0i8TSmo8AEgq+i+CgQ21Qf/B5FNzxUVybnL6/GNO5jY5hewLZOJXhfVh32M6lmz2NLa/77YCoYai+E7gENOOBPooPvle9k2pJBvaNX0R6k4bW/gI2UYZFlm4sSJdHR00N7e/mF3p4QS9ntIkkRjY+Mec0u9H0ydPB5lnYEQXdiG7JDLaR5UdxArPYiwDGRNp+6Yz1M95wz0UM2ImEX1nDNIHXr2iNX53mQrGL4DANjy4DcdJbdcId9u6br/xfGRKnDLQwiBaZoj+HxKKKGEYmia9oEYhTyG8heZiT5UbzmeyklkYh2jMooO52HaHfaFhkp060q2PX5zgftJ2DaZaBsTFl03ghDvo4x/+QK3/NZ4X2+PSyihhHeHoavxeOtaBjY8vUtG0XfromluDO91+ppdMcv+u+IjaRhKKKGE/Rf5yT408fCClsP+HLTdFbPsvytKhqGEEkrYZ/ioBG3/HTOPdoWSYSihhBJK4KNjxD4I7HeGIR8Lj8ViH3JPSiihhBL+dZCfU/ck32i/MwyDg4OAo7pVQgkllFDC3sXg4OBuNdP3u3RV27Zpb28nEAh85IvXYrEY48aNY8eOHbtND9vfURrL/od/lXFAaSwfBIQQDA4OUl9fjyzLu2y73+0YZFmmsbHxw+7GXkUwGNyvXpD3g9JY9j/8q4wDSmPZ19jdTiGPXZuNEkoooYQS/u1QMgwllFBCCSUUoWQY9iFcLhfXX389Lpfrw+7K+0ZpLPsf/lXGAaWx7G/Y74LPJZRQQgklfLgo7RhKKKGEEkooQskwlFBCCSWUUISSYSihhBJKKKEIJcNQQgkllFBCEUqG4X3itttuY8KECbjdbo488kheeeWVXbb/29/+xvTp03G73cyaNYvHHnvsA+rp2Lj55ps5/PDDCQQCVFdXc9ZZZ7Fhw4ZdnnPXXXchSVLRH7fb/QH1eGzccMMNI/o1ffr0XZ6zPz4TgAkTJowYiyRJXHbZZaO235+eyfPPP8/ixYupr69HkiQefPDBos+FEHz729+mrq4Oj8fD/Pnz2bRp026v+25/b+8XuxqHYRhce+21zJo1C5/PR319PRdccMFu1SXfyzv6QaNkGN4H/vrXv3L11Vdz/fXX8/rrr3PQQQexcOFCuru7R23/4osv8qlPfYoLL7yQVatWcdZZZ3HWWWexbt26D7jnxXjuuee47LLLWLFiBcuWLcMwDBYsWEAikdjlecFgkI6OjsKf7du3f0A93jUOPPDAon698MILY7bdX58JwMqVK4vGsWzZMgDOOeecMc/ZX55JIpHgoIMO4rbbbhv18x/96Ef87Gc/45e//CUvv/wyPp+PhQsXkk6nx7zmu/297Q3sahzJZJLXX3+db33rW7z++uvcf//9bNiwgTPOOGOUKxXj3byjHwpECe8ZRxxxhLjssssK/7YsS9TX14ubb7551PbnnnuuOO2004qOHXnkkeLiiy/ep/18t+ju7haAeO6558Zsc+edd4pQKPTBdWoPcf3114uDDjpoj9t/VJ6JEEJ8+ctfFs3NzcK27VE/31+fCSAeeOCBwr9t2xa1tbXixz/+ceFYJBIRLpdL/OUvfxnzOu/297a3MXwco+GVV14RgNi+ffuYbd7tO/phoLRjeI/IZrO89tprzJ8/v3BMlmXmz5/PSy+9NOo5L730UlF7gIULF47Z/sNCNBoFIBzetYRiPB5n/PjxjBs3jjPPPJM333zzg+jebrFp0ybq6+uZNGkSn/nMZ2hpaRmz7UflmWSzWf74xz/yhS98YZfkkvvrMxmKrVu30tnZWXTfQ6EQRx555Jj3/b383j4MRKNRJEmirKxsl+3ezTv6YaBkGN4jent7sSyLmpqaouM1NTV0dnaOek5nZ+e7av9hwLZtrrrqKo455hhmzpw5Zrtp06bxu9/9joceeog//vGP2LbN0UcfTWtr6wfY25E48sgjueuuu3jiiSe4/fbb2bp1K8cdd1yBzn04PgrPBODBBx8kEonwuc99bsw2++szGY78vX039/29/N4+aKTTaa699lo+9alP7ZI8792+ox8G9jt21RI+XFx22WWsW7dutz7PuXPnMnfu3MK/jz76aGbMmMGvfvUrvvvd7+7rbo6JRYsWFf4+e/ZsjjzySMaPH8+9997LhRde+KH16/3it7/9LYsWLaK+vn7MNvvrM/l3gGEYnHvuuQghuP3223fZ9qPwjpZ2DO8RlZWVKIpCV1dX0fGuri5qa2tHPae2tvZdtf+gcfnll/OPf/yDZ5555l1Tn2uaxsEHH8zmzZv3Ue/eG8rKypg6deqY/drfnwnA9u3befLJJ7nooove1Xn76zPJ39t3c9/fy+/tg0LeKGzfvp1ly5a9a6rt3b2jHwZKhuE9Qtd1Dj30UJ566qnCMdu2eeqpp4pWbUMxd+7covYAy5YtG7P9BwUhBJdffjkPPPAATz/9NBMnTnzX17Asi7Vr11JXV7cPevjeEY/H2bJly5j92l+fyVDceeedVFdXc9ppp72r8/bXZzJx4kRqa2uL7nssFuPll18e876/l9/bB4G8Udi0aRNPPvkkFRUV7/oau3tHPxR82NHvjzLuuece4XK5xF133SXeeust8cUvflGUlZWJzs5OIYQQ559/vvjv//7vQvvly5cLVVXFT37yE/H222+L66+/XmiaJtauXfthDUEIIcSll14qQqGQePbZZ0VHR0fhTzKZLLQZPpYbb7xRLFmyRGzZskW89tpr4pOf/KRwu93izTff/DCGUMBXv/pV8eyzz4qtW7eK5cuXi/nz54vKykrR3d0thPjoPJM8LMsSTU1N4tprrx3x2f78TAYHB8WqVavEqlWrBCD+93//V6xataqQrfODH/xAlJWViYceekisWbNGnHnmmWLixIkilUoVrnHSSSeJn//854V/7+739kGPI5vNijPOOEM0NjaKN954o+i3k8lkxhzH7t7R/QElw/A+8fOf/1w0NTUJXdfFEUccIVasWFH4bN68eeKzn/1sUft7771XTJ06Vei6Lg488EDx6KOPfsA9Hglg1D933nlnoc3wsVx11VWFcdfU1IiPfexj4vXXX//gOz8M5513nqirqxO6rouGhgZx3nnnic2bNxc+/6g8kzyWLFkiALFhw4YRn+3Pz+SZZ54Z9Z3K99e2bfGtb31L1NTUCJfLJU4++eQRYxw/fry4/vrri47t6vf2QY9j69atY/52nnnmmTHHsbt3dH9AiXa7hBJKKKGEIpRiDCWUUEIJJRShZBhKKKGEEkooQskwlFBCCSWUUISSYSihhBJKKKEIJcNQQgkllFBCEUqGoYQSSiihhCKUDEMJJZRQQglFKBmGEkoooYQSilAyDCWUUEIJJRShZBhKKKGEEkooQskwlFBCCSWUUISSYSihhBJKKKEI/x/YTUDTUUvPQgAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"Vem\"\n",
    "X_pre, X_post = prepare_pair_from_mat('WM902B', 'DMSO','24h', drug, '72h')\n",
    "jfe_indices = [1, 6, 0, 5, 4, 7, 8, 2, 3, 19]  \n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "X_tr_pre, X_te_pre, Y_tr_post, Y_te_post = split_train_test(X_pre, X_post, 0.8)\n",
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "# Compute median heuristic gamma on training data\n",
    "median_gamma = median_heuristic_gamma(X_tr_pre, Y_tr_post)\n",
    "print(\"Median heuristic gamma:\", median_gamma)\n",
    "\n",
    "\n",
    "all_metrics = []\n",
    "for run in range(10):\n",
    "    print(f\"**************** Run: {run} ****************\")\n",
    "    seed = 1234 + run\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "\n",
    "    out = SCGEN(X_tr_pre[:, jfe_indices], Y_tr_post[:, jfe_indices], X_te_pre[:, jfe_indices], Y_te_post[:, jfe_indices], seed=seed)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post[:, jfe_indices], median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post[:, jfe_indices]\n",
    "target = Y_te_post[:, jfe_indices]\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#C88131\")\n",
    "ax.scatter(y_pred_umap[:, 0], y_pred_umap[:, 1], s=10, alpha=0.7, label='predicted cells', color=\"#1F4D8D\")\n",
    "\n",
    "ax.set_title(f'{drug}')\n",
    "# ax.set_xlabel('UMAP 1')\n",
    "# ax.set_ylabel('UMAP 2')\n",
    "ax.set_aspect('equal', 'box')\n",
    "# Add a legend to distinguish the points\n",
    "ax.legend()\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "# Display the plot\n",
    "plt.savefig(f\"./plots/scgen_on_4i_drug_{drug}.png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "610e4869",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "3cc05c34",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cell line:  SKMEL19\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n",
      "X_pre cells: (2677, 20)\n",
      "X_post cells: (2677, 20)\n",
      "(2141, 20)\n",
      "(536, 20)\n",
      "(2141, 20)\n",
      "(536, 20)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 1234\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.10487158680337198\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:15<04:21,  3.61it/s, loss=0.672, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 44.418. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1235\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.011807994513391762, 'mmd2_gamma_0.5': 0.05297324023556105, 'mmd2_gamma_1.0': 0.06250089501413936, 'wasserstein_distance': 0.8182968900347497, 'R2_feature_means': 0.9962337219807589}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▊                                                                                                                                                                                                      | 56/1000 [00:16<04:34,  3.43it/s, loss=0.74, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 41.440. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1236\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.017140347192364125, 'mmd2_gamma_0.5': 0.054300002052135254, 'mmd2_gamma_1.0': 0.05677862788658622, 'wasserstein_distance': 0.8665040979342262, 'R2_feature_means': 0.9890205383972126}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:15<04:19,  3.63it/s, loss=0.706, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 41.012. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1237\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.031657994550237545, 'mmd2_gamma_0.5': 0.07445974042276071, 'mmd2_gamma_1.0': 0.0768445176466715, 'wasserstein_distance': 0.8826671994684921, 'R2_feature_means': 0.9583413496776466}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 57/1000:   6%|███████████▉                                                                                                                                                                                                      | 57/1000 [00:15<04:20,  3.62it/s, loss=0.67, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 46.193. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1238\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.07603471065654177, 'mmd2_gamma_0.5': 0.11522331030243471, 'mmd2_gamma_1.0': 0.09522199008623006, 'wasserstein_distance': 1.1321061493230766, 'R2_feature_means': 0.8654436819539899}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 55/1000:   6%|███████████▍                                                                                                                                                                                                     | 55/1000 [00:13<03:59,  3.94it/s, loss=0.712, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 44.430. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1239\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.04404492040828489, 'mmd2_gamma_0.5': 0.08718358426859396, 'mmd2_gamma_1.0': 0.08095838036323871, 'wasserstein_distance': 1.0102072288800743, 'R2_feature_means': 0.9332991081168809}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:16<04:36,  3.42it/s, loss=0.642, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 42.633. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1240\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.01570182660665953, 'mmd2_gamma_0.5': 0.04481376288354877, 'mmd2_gamma_1.0': 0.05095447820256915, 'wasserstein_distance': 0.8277387470280311, 'R2_feature_means': 0.979662690967244}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:15<04:29,  3.51it/s, loss=0.639, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 42.453. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1241\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.006185463353893805, 'mmd2_gamma_0.5': 0.032032719118964215, 'mmd2_gamma_1.0': 0.0413441369360919, 'wasserstein_distance': 0.7552801687683472, 'R2_feature_means': 0.9989330853844587}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:15<04:24,  3.57it/s, loss=0.652, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 43.932. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.0237896728437883, 'mmd2_gamma_0.5': 0.06306034438209218, 'mmd2_gamma_1.0': 0.06542516454995045, 'wasserstein_distance': 0.9088447770214891, 'R2_feature_means': 0.974147011209691}\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 1242\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:15<04:13,  3.72it/s, loss=0.636, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 41.046. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n",
      "Global seed set to 1243\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.0516964730242897, 'mmd2_gamma_0.5': 0.09179243897988609, 'mmd2_gamma_1.0': 0.08284902566435914, 'wasserstein_distance': 0.9985110289509332, 'R2_feature_means': 0.9189833664354172}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 56/1000:   6%|███████████▋                                                                                                                                                                                                     | 56/1000 [00:15<04:12,  3.73it/s, loss=0.672, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 40.745. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Received view of anndata, making copy.                                                                    \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:1828: UserWarning: Observation names are not unique. To make them unique, call `.obs_names_make_unique`.\n",
      "  utils.warn_names_duplicates(\"obs\")\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 metrics: {'mmd2_gamma_median': 0.0453084929820311, 'mmd2_gamma_0.5': 0.0814177561042343, 'mmd2_gamma_1.0': 0.07488947969506654, 'wasserstein_distance': 0.9688127516731535, 'R2_feature_means': 0.9277572846352986}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0323  0.0218\n",
      "mmd2_gamma_0.5        0.0697  0.0250\n",
      "mmd2_gamma_1.0        0.0688  0.0164\n",
      "wasserstein_distance  0.9169  0.1115\n",
      "R2_feature_means      0.9542  0.0426\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/umap/umap_.py:1952: UserWarning: n_jobs value 1 overridden to 1 by setting random_state. Use no seed for parallelism.\n",
      "  warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "image/png": "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ccPxG7sQgng8TnNzM7I8dZp31kNAfr9/gpH3+XzU1NRMa/wBZFme1mudaAKBwEl3c8HJO24oj32uOFnHfrKOG47P2IPBYEnHlfsBlClTpswpygmRgnj99ddPxNeUKVOmTJkZUF4BTIHL5eKv//qvcblccz2UGXGyjhvKY58rTtaxn6zjhk/G2Gc9CVymTJkyZU4OyiuAMmXKlDlFKTuAMmXKlDlFKTuAMmXKlDlFKTuAMmXKlDlFKTuAMmXKlDlFKTuASfjxj39Me3s7breb888/n02bNs31kKblnnvu4bzzzsPv91NfX88NN9zArl275npYR8U//MM/IEkSd95551wPZVq6u7v5wz/8Q2pqavB4PCxfvpx33313roc1LbZt853vfIeOjg48Hg8LFizgf/yP/1GSiNiJ5o033uDaa6+lubkZSZJ44oknxvy7EIK/+qu/oqmpCY/Hw1VXXUVnZ+fcDHYcU43dNE3uvvtuli9fjs/no7m5mVtvvZWenp4TMrayAyjCww8/zF133cVf//Vfs3XrVs4++2zWrVvHwMDAXA9tStavX8/tt9/Oxo0beemllzBNk7Vr15JMJud6aDPiZOokNzw8zMUXX4ymaTz33HN89NFH/Mu//MtJ0QTpe9/7Hvfeey8/+tGP+Pjjj/ne977HP/7jP/LDH/5wroc2gWQyydlnn82Pf/zjov/+j//4j/zgBz/gJz/5Ce+88w4+n49169aRyWRO8EgnMtXYU6kUW7du5Tvf+Q5bt27lscceY9euXVx33XUnZnCizARWr14tbr/99sLftm2L5uZmcc8998zhqGbOwMCAAMT69evneiglE4/HxaJFi8RLL70kLrvsMnHHHXfM9ZCm5O677xaXXHLJXA/jqLjmmmvEbbfdNua13//93xe33HLLHI2oNADx+OOPF/52HEc0NjaKf/qnfyq8FolEhMvlEr/61a/mYISTM37sxdi0aZMAxMGDB4/7eMorgHEYhsGWLVvGdDKTZZmrrrqKt99+ew5HNnOi0SgA1dXVczyS0im1k9wnhaeeeopVq1Zx0003UV9fz8qVK/npT38618MqiYsuuohXXnmF3bt3A7B9+3Y2bNjA1VdfPccjmxn79++nr69vzD0TDAY5//zzT7pnFnLPrSRJVFZWHvfvOiFaQCcToVAI27ZpaGgY83pDQwM7d+6co1HNHMdxuPPOO7n44otLUmH9JDCTTnKfFPbt28e9997LXXfdxV/8xV+wefNm/uzP/gxd1/nqV78618Obkm9961vEYjGWLl2KoijYts3f//3fc8stt8z10GZEX18fQNFnNv9vJwuZTIa7776bP/iDPzgh6qZlB/Ap5fbbb+eDDz5gw4YNcz2UkphpJ7lPCo7jsGrVKr773e8CsHLlSj744AN+8pOffOIdwCOPPMIvfvELfvnLX3LGGWewbds27rzzTpqbmz/xY/80YpomN998M0II7r333hPyneUQ0Dhqa2tRFIX+/v4xr/f399PY2DhHo5oZf/qnf8ozzzzDa6+99onrrTAZW7ZsYWBggHPOOQdVVVFVlfXr1/ODH/wAVVWxbXuuh1iUpqYmli1bNua1008/nUOHDs3RiErnz//8z/nWt77Fl770JZYvX85XvvIVvvnNb3LPPffM9dBmRP65PJmf2bzxP3jwIC+99NIJ621QdgDj0HWdc889l1deeaXwmuM4vPLKK1x44YVzOLLpEULwp3/6pzz++OO8+uqrdHR0zPWQSubKK69kx44dbNu2rfDfqlWruOWWW9i2bduUbUTnkosvvnhCqe3u3buZP3/+HI2odFKp1ISOUYqi4DjOHI3o6Ojo6KCxsXHMMxuLxXjnnXc+8c8sHDH+nZ2dvPzyy9TU1Jyw7y6HgIpw11138dWvfpVVq1axevVqvv/975NMJvna174210Obkttvv51f/vKXPPnkk/j9/kL8MxgM4vF45nh0U3OsneTmim9+85tcdNFFfPe73+Xmm29m06ZN3Hfffdx3331zPbRpufbaa/n7v/972traOOOMM3jvvff413/9V2677ba5HtoEEokEe/bsKfy9f/9+tm3bRnV1NW1tbdx555383d/9HYsWLaKjo4PvfOc7NDc3c8MNN8zdoEeYauxNTU3ceOONbN26lWeeeQbbtgvPbXV1NbquH9/BHfc6o5OUH/7wh6KtrU3oui5Wr14tNm7cONdDmhag6H/333//XA/tqDgZykCFEOLpp58WZ555pnC5XGLp0qXivvvum+shlUQsFhN33HGHaGtrE263W5x22mniv//3/y6y2excD20Cr732WtF7+6tf/aoQIlcK+p3vfEc0NDQIl8slrrzySrFr1665HfQIU419//79kz63r7322nEfW7kfQJkyZcqcopRzAGXKlClzilJ2AGXKlClzilJ2AGXKlClzilJ2AGXKlClzilJ2AGXKlClzilJ2AGXKlClzilJ2AGXKlClzilJ2AGXKlClzilJ2AGXKlClzilJ2AGXKlClzilJ2AGXKlClzivL/A+BiX6QO8a7aAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"Vem\"\n",
    "X_pre, X_post = prepare_pair_from_mat('SKMEL19', 'DMSO','24h', drug, '72h')\n",
    "jfe_indices = [1, 6, 0, 5, 4, 7, 8, 2, 3, 19]  \n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "X_tr_pre, X_te_pre, Y_tr_post, Y_te_post = split_train_test(X_pre, X_post, 0.8)\n",
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "# Compute median heuristic gamma on training data\n",
    "median_gamma = median_heuristic_gamma(X_tr_pre, Y_tr_post)\n",
    "print(\"Median heuristic gamma:\", median_gamma)\n",
    "\n",
    "\n",
    "all_metrics = []\n",
    "for run in range(10):\n",
    "    print(f\"**************** Run: {run} ****************\")\n",
    "    seed = 1234 + run\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "\n",
    "    out = SCGEN(X_tr_pre[:, jfe_indices], Y_tr_post[:, jfe_indices], X_te_pre[:, jfe_indices], Y_te_post[:, jfe_indices], seed=seed)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post[:, jfe_indices], median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post[:, jfe_indices]\n",
    "target = Y_te_post[:, jfe_indices]\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#C88131\")\n",
    "ax.scatter(y_pred_umap[:, 0], y_pred_umap[:, 1], s=10, alpha=0.7, label='predicted cells', color=\"#1F4D8D\")\n",
    "\n",
    "ax.set_title(f'{drug}')\n",
    "# ax.set_xlabel('UMAP 1')\n",
    "# ax.set_ylabel('UMAP 2')\n",
    "ax.set_aspect('equal', 'box')\n",
    "# Add a legend to distinguish the points\n",
    "ax.legend()\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "# Display the plot\n",
    "plt.savefig(f\"./plots/scgen_on_4i_drug_{drug}.png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6856ea1b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2061ee67",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "711c8633",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3847dd9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "258f2758",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d698f206",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
