{
 "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": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AnnData object with n_obs × n_vars = 119479 × 78\n",
      "    obs: 'drug'\n",
      "    var: 'cell_part', 'measurement', 'stat', 'feature', 'original'\n",
      "    uns: 'source'\n",
      "Shape: (119479, 78)\n",
      "Observation columns: ['drug']\n",
      "Feature columns: ['morphology-nuclei-area', 'morphology-nuclei-circularity', 'morphology-nuclei-convexity', 'morphology-nuclei-eccentricity', 'morphology-nuclei-elongation', 'morphology-nuclei-equivalent_diameter', 'morphology-nuclei-extent', 'morphology-nuclei-major_axis_length', 'morphology-nuclei-mean_radius', 'morphology-nuclei-perimeter']\n",
      "Unique conditions: ['ixazomib', 'everolimus', 'olaparib', 'paclitaxel', 'vemurafenib_cobimetinib', ..., 'ixazomib_lenalidomide_dexamethasone', 'melphalan', 'ulixertinib', 'dasatinib', 'sec.abcl']\n",
      "Length: 38\n",
      "Categories (38, object): ['cisplatin', 'cisplatin_olaparib', 'cl', 'control', ..., 'trametinib_panobinostat', 'ulixertinib', 'vemurafenib_cobimetinib', 'vindesine']\n",
      "Number of cells per condition:\n",
      "cl                                        18332\n",
      "control                                   10995\n",
      "sec.abcl                                   3399\n",
      "trametinib_dabrafenib                      2958\n",
      "ulixertinib                                2858\n",
      "dexamethasone                              2796\n",
      "sorafenib                                  2763\n",
      "hydroxyurea                                2715\n",
      "vemurafenib_cobimetinib                    2695\n",
      "cisplatin                                  2693\n",
      "dabrafenib                                 2675\n",
      "decitabine                                 2648\n",
      "trametinib                                 2637\n",
      "paclitaxel                                 2636\n",
      "imatinib                                   2631\n",
      "everolimus                                 2592\n",
      "pomalidomide_carfilzomib_dexamethasone     2545\n",
      "olaparib                                   2540\n",
      "lenalidomide                               2524\n",
      "regorafenib                                2524\n",
      "ixazomib_lenalidomide_dexamethasone        2522\n",
      "ixazomib                                   2514\n",
      "temozolomide                               2513\n",
      "panobinostat                               2492\n",
      "dacarbazine                                2485\n",
      "trametinib_erlotinib                       2452\n",
      "midostaurin                                2425\n",
      "erlotinib                                  2406\n",
      "trametinib_panobinostat                    2377\n",
      "mln2480                                    2367\n",
      "melphalan                                  2352\n",
      "palbociclib                                2322\n",
      "dasatinib                                  2250\n",
      "cisplatin_olaparib                         2245\n",
      "trametinib_midostaurin                     2211\n",
      "vindesine                                  2102\n",
      "crizotinib                                 1978\n",
      "staurosporine                              1310\n",
      "Name: drug, dtype: int64\n"
     ]
    }
   ],
   "source": [
    "import scanpy as sc\n",
    "\n",
    "# Load your dataset\n",
    "adata_4i = sc.read_h5ad(\"4i/8h.h5ad\")\n",
    "\n",
    "# Basic overview\n",
    "print(adata_4i)\n",
    "print(\"Shape:\", adata_4i.shape)\n",
    "\n",
    "# View column names (metadata about each cell)\n",
    "print(\"Observation columns:\", adata_4i.obs.columns.tolist()[:10])\n",
    "print(\"Feature columns:\", adata_4i.var_names[:10].tolist())\n",
    "\n",
    "# How many drugs (conditions)?\n",
    "print(\"Unique conditions:\", adata_4i.obs['drug'].unique())\n",
    "print(\"Number of cells per condition:\")\n",
    "print(adata_4i.obs['drug'].value_counts())\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c25979ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "features_4i = [\n",
    "    \"intensity-cell-CD45-mean\",\n",
    "    \"intensity-cell-ClCasp3-mean\",\n",
    "    \"intensity-cell-DAPI-sum\",\n",
    "    \"intensity-cell-Ki67-mean\",\n",
    "    \"intensity-cell-MelA-mean\",\n",
    "    \"intensity-cell-PCNA-mean\",\n",
    "    \"intensity-cell-Sox9-mean\",\n",
    "    \"intensity-cell-aTUB-mean\",\n",
    "    \"intensity-cell-pAKT-mean\",\n",
    "    \"intensity-cell-pEGFR-mean\",\n",
    "    \"intensity-cell-pERK-mean\",\n",
    "    \"intensity-cell-pMET-mean\",\n",
    "    \"intensity-cell-pS6k1-mean\",\n",
    "    \"intensity-nuclei-CD45-mean\",\n",
    "    \"intensity-nuclei-ClCasp3-mean\",\n",
    "    \"intensity-nuclei-DAPI-sum\",\n",
    "    \"intensity-nuclei-Ki67-mean\",\n",
    "    \"intensity-nuclei-MelA-mean\",\n",
    "    \"intensity-nuclei-PCNA-mean\",\n",
    "    \"intensity-nuclei-Sox9-mean\",\n",
    "    \"intensity-nuclei-aTUB-mean\",\n",
    "    \"intensity-nuclei-pAKT-mean\",\n",
    "    \"intensity-nuclei-pEGFR-mean\",\n",
    "    \"intensity-nuclei-pERK-mean\",\n",
    "    \"intensity-nuclei-pMET-mean\",\n",
    "    \"intensity-nuclei-pS6k1-mean\",\n",
    "    \"morphology-cell-area\",\n",
    "    \"morphology-cell-circularity\",\n",
    "    \"morphology-cell-convexity\",\n",
    "    \"morphology-cell-eccentricity\",\n",
    "    \"morphology-cell-elongation\",\n",
    "    \"morphology-cell-equivalent_diameter\",\n",
    "    \"morphology-cell-extent\",\n",
    "    \"morphology-cell-major_axis_length\",\n",
    "    \"morphology-cell-mean_radius\",\n",
    "    \"morphology-cell-perimeter\",\n",
    "    \"morphology-cell-roundness\",\n",
    "    \"morphology-nuclei-area\",\n",
    "    \"morphology-nuclei-circularity\",\n",
    "    \"morphology-nuclei-convexity\",\n",
    "    \"morphology-nuclei-eccentricity\",\n",
    "    \"morphology-nuclei-elongation\",\n",
    "    \"morphology-nuclei-equivalent_diameter\",\n",
    "    \"morphology-nuclei-extent\",\n",
    "    \"morphology-nuclei-major_axis_length\",\n",
    "    \"morphology-nuclei-mean_radius\",\n",
    "    \"morphology-nuclei-perimeter\",\n",
    "    \"morphology-nuclei-roundness\"\n",
    "]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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": 5,
   "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": 6,
   "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": 7,
   "id": "b2a6a182",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (10995, 48)\n",
      "X_post cells: (2637, 48)\n",
      "(2109, 48)\n",
      "(528, 48)\n",
      "(2109, 48)\n",
      "(528, 48)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 1234\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.08064887236416649\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:14<04:22,  3.61it/s, loss=0.829, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 24.889. 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.010516278596688022, 'mmd2_gamma_0.5': 0.020815235175611735, 'mmd2_gamma_1.0': 0.013921331065742323, 'wasserstein_distance': 1.6761282278309235, 'R2_feature_means': 0.9242309980165291}\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:15<04:40,  3.37it/s, loss=0.81, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 22.469. 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.007575960814185545, 'mmd2_gamma_0.5': 0.015450905725473085, 'mmd2_gamma_1.0': 0.010571381946789533, 'wasserstein_distance': 1.7079557957222817, 'R2_feature_means': 0.9467230412985418}\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:15<04:33,  3.46it/s, loss=0.775, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 23.557. 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.008070531580616436, 'mmd2_gamma_0.5': 0.017573576354678516, 'mmd2_gamma_1.0': 0.01184074614917354, 'wasserstein_distance': 1.655885083024957, 'R2_feature_means': 0.9624522518895668}\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:16<04:57,  3.18it/s, loss=0.783, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 26.462. 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.00908941682360509, 'mmd2_gamma_0.5': 0.019330899365940818, 'mmd2_gamma_1.0': 0.013359029072307481, 'wasserstein_distance': 1.6618185898193978, 'R2_feature_means': 0.9418861029592718}\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:13<04:05,  3.86it/s, loss=0.835, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.980. 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.009903813585526722, 'mmd2_gamma_0.5': 0.01920301097494226, 'mmd2_gamma_1.0': 0.013007032244821692, 'wasserstein_distance': 1.6771431861940955, 'R2_feature_means': 0.9417304292967879}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:14<04:20,  3.63it/s, loss=0.793, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 23.381. 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.014080512788640753, 'mmd2_gamma_0.5': 0.023145920965531946, 'mmd2_gamma_1.0': 0.014664247661395298, 'wasserstein_distance': 1.6894329409912743, 'R2_feature_means': 0.9081194147680669}\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:14<04:22,  3.61it/s, loss=0.818, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.427. 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.010380415129866316, 'mmd2_gamma_0.5': 0.01772417990372485, 'mmd2_gamma_1.0': 0.01152550807853546, 'wasserstein_distance': 1.676638121682445, 'R2_feature_means': 0.9104227855784139}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:14<04:21,  3.62it/s, loss=0.795, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 28.897. 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.011388741791168666, 'mmd2_gamma_0.5': 0.018122468703399258, 'mmd2_gamma_1.0': 0.011747350755760562, 'wasserstein_distance': 1.745975505283426, 'R2_feature_means': 0.8721411009664389}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:14<04:22,  3.61it/s, loss=0.845, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 26.521. 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.00767588185184509, 'mmd2_gamma_0.5': 0.015945938809695748, 'mmd2_gamma_1.0': 0.010520111409774748, 'wasserstein_distance': 1.6685133629939397, 'R2_feature_means': 0.9607893732251461}\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:13<04:02,  3.91it/s, loss=0.815, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.332. 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.008970611724585797, 'mmd2_gamma_0.5': 0.016257080594608564, 'mmd2_gamma_1.0': 0.010044285116606572, 'wasserstein_distance': 1.6790582820493778, 'R2_feature_means': 0.9337603136474205}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0098  0.0020\n",
      "mmd2_gamma_0.5        0.0184  0.0024\n",
      "mmd2_gamma_1.0        0.0121  0.0016\n",
      "wasserstein_distance  1.6839  0.0261\n",
      "R2_feature_means      0.9302  0.0275\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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eC2JwszgtW9jS5S7nngbx4H6iiIcB+5Z9g7NqfioLq6RGEvc5KPIx9Yw7E1/4be+9S0efPBB/v73v/PWW28xadIkTjvtNKLR6KDjrr/+em6++WbeeOMNysrKOPPMMzEMA4Arr7wSTdN44YUXeOedd/jlL39JQUEBkJto5syZw6xZs3jzzTdZvHgxnZ2dXHjhhYO+/+9//zuqqvLyyy9z++23c8kll/DYY4+RTCbzxzz11FOk02nOOeccAG666Sbuuusubr/9dtauXcu1117L//t//4/nn38eyPXNOPfccznzzDNZtWoVl19+Of/zP/8z6vPoN4oLFy6kvb19kJHctGkTDz74IA899BCrVq0C4IILLiASifDkk0+yYsUKDj30UObOnZt/fslkkk984hM888wzrFy5kvnz53PmmWfS3NwMwEMPPURtbS0/+clPaG9vp729HcgZlPnz53PeeeexevVq7rvvPl566aVBk/hll13Gtm3bePbZZ3nggQf44x//mC8aG4nbbruNK6+8ki996Uu88847PProo0yaNCn/+c7uZzTa29u5+OKL+fznP8+7777Lc889x7nnnpsL7u5j/A0+DlkwjpNPncTE2vAOn3kqPTiWk59gEUBr1+h5dvB99/lMspJFeXkBoihQWuTHsCwUWaSxJ8YWIcFWJ0nM0thg9hEPWmiqTSEKVu5rEQRI2SaC5RC3dFRR5BPeOkRZpMPIoHfqnNxRhnFrlM5H3/89O6NJUlmd0iJ//toZ26TPYw4KYo81QD2WuMlHkY+lK2lvbu1SqRS33XYbf/vb31iwYAEAd955J08//TR/+ctfuP766/PH/uhHP+KUU04BcpN4bW0tDz/8MBdeeCHNzc2cd955zJgxA4AJEybkz/v973/PrFmzuPHGG/Pv/fWvf6Wuro4NGzYwZcoUACZPnsyvfvWr/DETJ04kEAjw8MMP85nPfAaAe+65h7POOotgMIimadx4440sXbqUY445Jn/dl156iTvuuIPZs2dz2223MXHiRG6++WYADjjggLzhGomysjLgfbmGgei6zl133ZU/5qWXXuL1118nEong8XgA+PWvf80jjzzCAw88wJe+9CUOPvhgDj744Px3/PSnP+Xhhx/m0Ucf5aqrriIcDiNJEsFgcND1brrpJi655JJ83GHy5Mn83//9X/6+mpubefLJJ3n99dc54ogjAPjLX/7C1KlTR7w3gJ/97Gd84xvf4Otf/3r+vf7zx3I/o9He3o5pmpx77rmMG5dL+ez/b2JfszM/+sAYgt6jY3SZ4EDzHa1kmrNM+dFEACrCBQS8Kt29aUqL/HT3pikO+jhieg33LF6NLTh4vBJBj8oqX5xJfYX4NJmEz0I1c2tZW4St7TFM3QYH3uns5pNGPQ0BP92ZDBWlASZUh/NuoVbS9GgZ7ICQv3ax6qG7N4Xfo3DACVUISzS0Vi0/Z4zFjTTwnkWviNFjICriRz7r6WNnGHYlD3pP0NjYiGEYHHfccfn3FEXhyCOP5N133x10bP/kCxAOhznggAPyx1x99dV85StfYcmSJcybN4/zzjuPmTNnAvD222/z7LPP5ncQQ6/fbxgOO+ywQZ/JssyFF17I3XffzWc+8xlSqRT/+c9/+Ne//gXkVu/pdDpvrPrRdZ1Zs2YB8O6773LUUUeNeB+7yrhx4/JGof/ekskkJSUlg47LZDI0NjYCuR3DDTfcwBNPPJGfODOZTH7HMBJvv/02q1evHuQechwH27bZsmULGzZsQJblQc/twAMPpKioaMTvjEQitLW1MXfu3BGvubP7GY2DDz6YuXPnMmPGDE477TROPfVUzj//fIqLi3d67ofJWBZb/TGEbX9tyxkFQPAJCA50PxWldF6Y8HHFTKwNc+npB3PXE2/T3NlLwKty6ekHU10WYslrmygp9ONVZXwehebOXipOLmHBMp1F2WYSokXQo9Jn6Jimg2wL+AWJN709HKGVUN3rxw7YJMMOrWaKmnCAJzZuYsmf28li4RNlpk4qY1M0xuZoEo8t8glvPeOKCgn+LLjLAeT+e956RytGT273r5YqJFYnPtJB6I+dYRip6GV/L2i5/PLLOe2003jiiSdYsmQJN910EzfffDNf+9rXSCaTnHnmmcOu0gdq5AQCgR0+v+SSS5g9ezaRSISnn34an8/H/PnzAfIupieeeIKamppB5/Wvdvc0Q8eYTCapqqriueee2+HY/gn6m9/8Jk8//TS//vWvmTRpEj6fj/PPP3+nCrzJZJIrrriCq6++eofP6uvr2bBhwy6Pv1+GYrRr7ux+RkOSJJ5++mleeeUVlixZwq233sr3vvc9li9fzvjx43d5vHuC4RZbb967JZcVNC08yK1UcVY56aYMrf/oQPSLSIqIbTvYKZv0lgzh43IG7vy5BzHrgOpBmUGNLVF8HoW+pIanWKK7N03Aq3LgGbWcPH8yc7dXXfdIGr/716sUSipOm4nXp9BppMnUi7zU18XjcguZTpOAonC8Vc6rQgTHgUrVT6+lsWpDB7PFSopElan+YioNX37xWHRE4S4/n+DMILJfQlSEfGbWR726+mNnGIamxH3YBS0TJ07M+/X7t/6GYfDGG2/skDr52muvUV9fD0AsFmPDhg2D3BZ1dXV8+ctf5stf/jLf+c53uPPOO/na177GoYceyoMPPkhDQwOyvGs/2bHHHktdXR333XcfTz75JBdccAGKogAwbdo0PB4Pzc3NzJ49e9jzp06dyqOPPrrDfewMRVHyEiejceihh9LR0YEsy/kg9VBefvllLrvssnxcJJlM7hAAV1V1h+sdeuihrFu3bpD/fyAHHnggpmmyYsWKvCto/fr1o9ZnBINBGhoaeOaZZzj55JN36352hiAIHHfccRx33HH88Ic/ZNy4cTz88MNcd911u/V9H5Shi63nlQ4eizah/RPUgMz5c6bx1Qve31UWHhai/V8RMBxsycHJ2giSgH/84ElyYu1go7JyfRsZzSASTdES6aOwwMvnz5yVPyYoB0lHk5QaEsVBH5Zm45EkevUsPlnGsC0ekLcSFw2wHeK6weNOM6ogUW34cUwbQ7HpcNI8abZQaCsYvSbFRiWST9rtxaPepeNYDt46L4Io4Picj8RidDQ+doZhYErcrvoLd4dAIMBXvvIVrr/+esLhMPX19fzqV78inU7zhS98YdCxP/nJTygpKaGiooLvfe97lJaW5vP8r7nmGhYsWMCUKVOIxWI8++yzeaNx5ZVXcuedd3LxxRfzrW99i3A4zKZNm/jXv/7Fn//8551q5Hz605/m9ttvZ8OGDTz77LP594PBIN/85je59tprsW2b448/nr6+Pl5++WVCoRCf/exn+fKXv8zNN9/M9ddfz+WXX86KFSv429/+ttPn0j95HnfccXg8nhFdIfPmzeOYY47hk5/8JL/61a+YMmUKbW1tPPHEE5xzzjkcfvjhTJ48mYceeogzzzwTQRD4wQ9+sIMse0NDAy+88AKf+tSn8Hg8lJaW8u1vf5ujjz6aq666issvv5xAIMC6det4+umn+f3vf88BBxzA/PnzueKKK7jtttuQZZlrrrlmp7uCG264gS9/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zy4uLi4udbiKwcXFxcWljmNeMXg8Hv7n//yfeDyelV7KsvNOvbZ36nWBe23HK+61LY6jHnx2cXFxcTm2OeZ3DC4uLi4uRxdXMbi4uLi41OEqBhcXFxeXOlzF4OLi4uJSxzGpGL7+9a9z1llnEQqFaGtr46Mf/Si7du1a6WUdEf72b/8WQRD44he/uNJLWRaGh4f59Kc/TXNzMz6fj1NOOYVXXnllpZd12FiWxVe/+lXWrFmDz+ejv7+f//2///eC+s4cazz33HNcddVVdHV1IQgCP/vZz+r+3XEc/vIv/5LOzk58Ph9btmzhrbfeWpnFLpK5rs0wDL785S9zyimnEAgE6Orq4jOf+QwjIyMrt+BFMN99q+X3f//3EQSBb33rW0s61zGpGJ599lluvPFGfvnLX/L4449jGAaXXnop+Xx+pZe2rLz88st8+9vfZvPmzSu9lGUhmUxy3nnnoSgKjzzyCG+++Sb/8A//QFNT00ov7bD5xje+wc0338y//uu/snPnTr7xjW/wd3/3d/zLv/zLSi9t0eTzed7znvfwf//v/23473/3d3/HP//zP/Pv//7vvPTSSwQCAS677DJKpdJRXunimevaCoUCr776Kl/96ld59dVXueeee9i1axdXX331Cqx08cx33yrce++9/PKXv6Srq2vpJ3OOA+LxuAM4zz777EovZdnIZrPOunXrnMcff9z5wAc+4Nx0000rvaTD5stf/rJz/vnnr/QyjghXXnml8/nPf77uZ7/1W7/lXH/99Su0ouUBcO69997q323bdjo6Opz/83/+T/VnqVTK8Xg8zh133LECK1w606+tEb/61a8cwDlw4MDRWdQyMdu1DQ0NOd3d3c6OHTuc1atXO//4j/+4pOMfkzuG6aTTaQBisdgKr2T5uPHGG7nyyivZsmXLSi9l2bj//vs588wzufbaa2lra+O0007jO9/5zkova1k499xzefLJJ9m9ezcAr732Gs8//zxXXHHFCq9sedm3bx9jY2N1z2UkEuHss8/mxRdfXMGVHRnS6TSCIBCNRld6KYeNbdvccMMN/Nmf/Rknn3zyYR3rqDfRWyy2bfPFL36R8847j02bNq30cpaFH//4x7z66qu8/PLLK72UZWXv3r3cfPPNfOlLX+Iv/uIvePnll/mTP/kTVFXld37nd1Z6eYfFn//5n5PJZDjxxBORJAnLsvjrv/5rrr/++pVe2rIyNjYGQHt7e93P29vbq//2TqFUKvHlL3+ZT37yk++Ixnrf+MY3kGWZP/mTPznsYx3ziuHGG29kx44dPP/88yu9lGXh4MGD3HTTTTz++ON4vd6VXs6yYts2Z555Jn/zN38DwGmnncaOHTv493//9+NeMdx111386Ec/4vbbb+fkk09m+/btfPGLX6Srq+u4v7Z3I4ZhcN111+E4DjfffPNKL+ew2bp1K//0T//Eq6++uqBxBvNxTLuS/uiP/ogHH3yQp59+ekmtuo9Ftm7dSjwe5/TTT0eWZWRZ5tlnn+Wf//mfkWUZy7JWeolLprOzk40bN9b97KSTTmJwcHCFVrR8/Nmf/Rl//ud/zm//9m9zyimncMMNN/Cnf/qnfP3rX1/ppS0rHR0dAIyPj9f9fHx8vPpvxzsVpXDgwAEef/zxd8Ru4Re/+AXxeJze3t6qXDlw4AD/7b/9N/r6+hZ9vGNyx+A4Dn/8x3/MvffeyzPPPMOaNWtWeknLxsUXX8wbb7xR97PPfe5znHjiiXz5y19GkqQVWtnhc955581IK969ezerV69eoRUtH4VCYcZwE0mSsG17hVZ0ZFizZg0dHR08+eSTnHrqqUB5EMxLL73EH/zBH6zs4paBilJ46623ePrpp2lubl7pJS0LN9xww4x45WWXXcYNN9zA5z73uUUf75hUDDfeeCO333479913H6FQqOrbjEQi+Hy+FV7d4REKhWbESgKBAM3Nzcd9DOVP//RPOffcc/mbv/kbrrvuOn71q19xyy23cMstt6z00g6bq666ir/+67+mt7eXk08+mW3btvHNb36Tz3/+8yu9tEWTy+XYs2dP9e/79u1j+/btxGIxent7+eIXv8jXvvY11q1bx5o1a/jqV79KV1cXH/3oR1du0Qtkrmvr7Ozkmmuu4dVXX+XBBx/EsqyqbInFYqiqulLLXhDz3bfpSk5RFDo6OtiwYcPiT3Y4KVNHCqDhn1tvvXWll3ZEeKekqzqO4zzwwAPOpk2bHI/H45x44onOLbfcstJLWhYymYxz0003Ob29vY7X63XWrl3r/Pf//t8dTdNWemmL5umnn274fv3O7/yO4zjllNWvfvWrTnt7u+PxeJyLL77Y2bVr18oueoHMdW379u2bVbY8/fTTK730eZnvvk3ncNJV3bbbLi4uLi51HNPBZxcXFxeXo4+rGFxcXFxc6nAVg4uLi4tLHa5icHFxcXGpw1UMLi4uLi51uIrBxcXFxaUOVzG4uLi4uNThKgYXFxcXlzpcxeDi4uLiUoerGFxcXFxc6nAVg4uLi4tLHa5icHFxcXGp4/8Hyyy9jtvkYQQAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"trametinib\"\n",
    "X_pre = adata_4i[adata_4i.obs[\"drug\"] == \"control\"].copy().to_df()[features_4i]\n",
    "X_post  = adata_4i[adata_4i.obs[\"drug\"] == drug].copy().to_df()[features_4i]\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.values, X_post.values, 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, Y_tr_post, X_te_pre, Y_te_post, max_epochs=1000, batch_size=64, seed=seed)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post, 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",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post\n",
    "target = Y_te_post\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=\"#C331C8\")\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": 8,
   "id": "5056be31",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (10995, 48)\n",
      "X_post cells: (2631, 48)\n",
      "(2104, 48)\n",
      "(527, 48)\n",
      "(2104, 48)\n",
      "(527, 48)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 1234\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.05748945574198288\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:16<04:55,  3.20it/s, loss=0.932, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.870. 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.031710555436549326, 'mmd2_gamma_0.5': 0.025159621137720398, 'mmd2_gamma_1.0': 0.010607972847554707, 'wasserstein_distance': 2.0765397124406553, 'R2_feature_means': 0.9196790648268033}\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:15<04:44,  3.33it/s, loss=0.947, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 26.823. 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.03571253822640863, 'mmd2_gamma_0.5': 0.029239491776305818, 'mmd2_gamma_1.0': 0.01205272455415552, 'wasserstein_distance': 2.0101308500124926, 'R2_feature_means': 0.9541792501694456}\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:15<04:37,  3.41it/s, loss=0.936, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 29.513. 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.03688468590228178, 'mmd2_gamma_0.5': 0.026518923935185387, 'mmd2_gamma_1.0': 0.011337654594576543, 'wasserstein_distance': 2.174962952458028, 'R2_feature_means': 0.8171778587793115}\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:14<04:11,  3.76it/s, loss=0.936, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 32.387. 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.034061971957124126, 'mmd2_gamma_0.5': 0.024602527418472353, 'mmd2_gamma_1.0': 0.010526767656417975, 'wasserstein_distance': 2.08207591088942, 'R2_feature_means': 0.8660642793796561}\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:15<04:40,  3.38it/s, loss=1.07, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 28.130. 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.03216196167625507, 'mmd2_gamma_0.5': 0.023890953873288268, 'mmd2_gamma_1.0': 0.00962552763795465, 'wasserstein_distance': 2.0689432810232624, 'R2_feature_means': 0.9457847169475505}\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 53/1000:   5%|███████████▏                                                                                                                                                                                                      | 53/1000 [00:15<04:36,  3.43it/s, loss=1.08, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 30.181. 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.03637700808291322, 'mmd2_gamma_0.5': 0.028050391180070022, 'mmd2_gamma_1.0': 0.011155432104377161, 'wasserstein_distance': 2.0838498448602216, 'R2_feature_means': 0.9409645790257095}\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:15<04:30,  3.49it/s, loss=0.934, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 34.742. 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.03163349660748449, 'mmd2_gamma_0.5': 0.023543816284609803, 'mmd2_gamma_1.0': 0.009819687675541047, 'wasserstein_distance': 2.0843556739739717, 'R2_feature_means': 0.8993949535764475}\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 53/1000:   5%|███████████▏                                                                                                                                                                                                      | 53/1000 [00:15<04:30,  3.50it/s, loss=0.95, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 27.735. 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.030168988566326216, 'mmd2_gamma_0.5': 0.023693484768601544, 'mmd2_gamma_1.0': 0.010588390051846919, 'wasserstein_distance': 2.08095115636596, 'R2_feature_means': 0.8715158880458758}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:14<04:21,  3.62it/s, loss=0.946, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 29.740. 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.03572309413606711, 'mmd2_gamma_0.5': 0.03092286870299421, 'mmd2_gamma_1.0': 0.012204772125987575, 'wasserstein_distance': 2.011113780993029, 'R2_feature_means': 0.9681051808240169}\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:16<04:52,  3.24it/s, loss=1.04, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 28.167. 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.025947770164266637, 'mmd2_gamma_0.5': 0.021814096921886433, 'mmd2_gamma_1.0': 0.009221653816619154, 'wasserstein_distance': 1.993892932046264, 'R2_feature_means': 0.9657142061284272}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0330  0.0034\n",
      "mmd2_gamma_0.5        0.0257  0.0029\n",
      "mmd2_gamma_1.0        0.0107  0.0010\n",
      "wasserstein_distance  2.0667  0.0521\n",
      "R2_feature_means      0.9149  0.0502\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": "iVBORw0KGgoAAAANSUhEUgAAAYYAAADeCAYAAAA5KqfLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAACwd0lEQVR4nOz9eZxc1Xnnj7/P3Wqv7qreF0mtBRACBBgwBgPGLAaM8ZLYeCe2M46/cRI78Ux+GfubZOJkMp7ML+OQySR2cBxiHJuAsbHZzWYZy2AQYgchoaWl3qu7a9/uds73j9td6pZaG0aA4L5fL5aurrp1uure+zznWT6PUEopQkJCQkJC5tBe6wWEhISEhLy+CA1DSEhISMgiQsMQEhISErKI0DCEhISEhCwiNAwhISEhIYsIDUNISEhIyCJCwxASEhISsojQMISEhISELCI0DCEhISEhiwgNQ8gxxb/9278hhGB4ePi1XkqLoaEhPvWpT72s11544YVceOGFrZ83bNiAEIJbbrnllVlcSMjLIDQMISGHwcMPP8xf/MVfUCwWX+ulhIQcdYzXegEhIUfCJz/5ST7ykY8QiURe1fd9+OGH+epXv8qnPvUp2tvbF/1u69ataNrL87HuvffeV2B1ISGvLKFhCDmm0HUdXddf62Us4tcxUpZlvYIrCQl5ZQhDSSHHFPvmGIaGhnjPe97Dhg0bOPPMM4nFYpxyyils2LABgB/96EeccsopRKNRzjjjDJ588slFx3vmmWf41Kc+xapVq4hGo/T29vKZz3yG2dnZ1nP+4i/+gj/+4z8GYOXKlQgh9lvDwhzD/Bp/+ctf8qUvfYmuri4SiQQf+MAHmJ6eXvT+++YY5vF9n6985Sv09vaSSCR473vfy8jIyK/34YWEHCbhjiHkmGf79u187GMf43Of+xyf+MQn+Nu//VuuuuoqvvnNb/KVr3yFz3/+8wB87Wtf4+qrr14U+rnvvvvYuXMnn/70p+nt7eX555/nuuuu4/nnn+dXv/oVQgh+4zd+g23btnHjjTfyd3/3d3R2dgLQ1dV10HX9wR/8AZlMhv/23/4bw8PDXHvttfz+7/8+N9100yH/pr/+679GCMGf/MmfkMvluPbaa7nkkkt46qmniMViv+YnFhJycELDEHLMs3XrVh5++GHOOeccANatW8dll13GZz/7WV588UWWL18OQCaT4XOf+xwPPfRQy0v//Oc/z3/+z/950fHe9ra38dGPfpSNGzdy/vnns379et7ylrdw44038v73v5+hoaHDWldHRwf33nsvQggApJT8n//zfyiVSrS1tR30tfl8ni1btpBKpQB4y1vewtVXX823vvUtvvCFLxzuRxMS8rIIQ0khxzzr1q1rGQWAs88+G4CLLrqoZRQWPr5z587WYwu972azyczMDG9729sAeOKJJ36tdf3O7/xOyygAnH/++fi+z+7duw/52muuuaZlFAA++MEP0tfXx1133fVrrSkk5HAIDUPIMc/Cmz/Q8saXLVu25OOFQqH1WD6f54tf/CI9PT3EYjG6urpYuXIlAKVS6RVdVyaT2e/9D8Rxxx236GchBGvWrHld9W+EvHEJQ0khxzwHqlI60OMLp9leffXVPPzww/zxH/8xp512GslkEikll19+OVLKo7KucJpuyOud0DCEvGkpFAo88MADfPWrX+XP//zPW4+/9NJL+z13YUjo1WDfNSil2L59O+vXr39V1xHy5iQMJYW8aZn36Pf14K+99tr9nptIJABetc7nG264gUql0vr5lltuYWJigiuuuOJVef+QNzfhjiHkTUs6neaCCy7gf/2v/4XrugwMDHDvvfeya9eu/Z57xhlnAPD//r//Lx/5yEcwTZOrrrqqZTBeabLZLOeddx6f/vSnmZqa4tprr2XNmjV89rOfPSrvFxKykNAwhLyp+f73v88f/MEf8I//+I8opXjXu97F3XffTX9//6LnnXXWWfzVX/0V3/zmN7nnnnuQUrJr166jZhi+8pWv8Mwzz/C1r32NSqXCxRdfzD/90z8Rj8ePyvuFhCxEqDATFhISEhKygDDHEBISEhKyiNAwhISEhIQsIjQMISEhISGLCA1DSEhISMgiQsMQEhISErKI0DCEhISEhCziVe9jkFIyPj5OKpV61WUGQkJCQt6sKKWoVCr09/cfchTtq24YxsfH91O9DAkJCQl5dRgZGWFwcPCgz3nVDcO8xvzIyAjpdPrVfvuQkJCQNyXlcplly5YtmvNxIF51wzAfPkqn06FhCAkJCXmVOZwQfph8DgkJCQlZRCii9wamPtzAmXawuiziQ+EA+ZCQkMMjNAzHOAtv/gCVZ6uAwp52yT9YwK/76HGdvqu76Xlv92u72JCQkGOC0DAcQ+xrBKZ+kqOw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+Lp+bOpvGAafffZZfAkjxieffELv3r0B2LVrF5s2bUpYtigoKODGG2/kxhtv5M477+Tpp5/m5ptvZvjw4bz++usUFhaiaQd3yU499VQKCgp45ZVX+Mc//sEll1yCrjsO8RNOOAGv10tJSQmjRo1qd/vjjz+et99+e59x7A9d1+MlTjpj+PDhVFRUoGla3Em9N8uXL2fSpElxv0hzc/M+DnCPx7PP8YYPH85XX32VsP6/J8cddxymabJy5cr4UtDGjRs7zc8IBoMUFhayePFizjrrrG80nv0hhOC0007jtNNO4+6776ZPnz7MmzePW2+99Rvtr6vZM8ktKy1ARLVRhKBRMRIikizhRBw1mQaPv/855VVNNNWFCeEUxtMQJEVUhC5YklnJCaEMcstADaisPLGJN+avojrcTANREMLREwFUW3BOaz5amkawXqGfmcIxeWmE7AhWo5VQy+inwwbzw/NOoOSrOlprwsz+eDWNIYPGpgiRsMnsdz6j+u/VTPQcgxWy0FK1dlciss7OIFwapuHTRswGg9pFu9pK1IDZYOLN8e43yqi92ciR4jvnfI6JZwgh4kkkhzPsKykpiZtuuonbb7+d9957j6+++orrrruO1tZWJk+enND23nvvZfHixaxfv55JkyaRlZUVT2yaPn06CxYsYOvWraxatYqlS5fGjcaUKVOoq6vj8ssv57PPPqO4uJgFCxbws5/97IBuvldccQVPPvkkixYt4sorr4y/HwwG+cUvfsHPf/5znnvuOYqLi1m1ahWPPfYYzz33HAA33ngjmzdv5vbbb2fjxo28/PLLzJ07d7/HjN08Kyoq2LVrV4ftxowZw8iRI5kwYQILFy5k27ZtfPzxx/z617/m888/BxzfQMxZvXbtWq644op9yrIXFhby4YcfUlZWFo/WuuOOO/j444+ZOnUqa9asYfPmzbz11ltx5/OAAQMYN24cN9xwAytWrGDlypVce+21+50V3HPPPcyaNYtHH32UzZs3x8/ZgY6nM1asWMH999/P559/TklJCW+88QbV1dX79Xt0J/ZMciuprCeQ7GF4jx7tZrTZQGM4yuf/3klZXRONGFht5kNFoUaG8aIQ9UkCP8uk6M5C9JszeGXbJlpMA79QURBoEnJMHxm2U47m/UA5n9jVSAF5lh+hKM7avyGxwnbCA2NRrwzOOqcf6YNSaIg4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O+5g8ODBJCUlkZ+fz9VXX83OnTs73ec3+W4eCo56w/Dvf/8b27Z56qmn+PLLL3nkkUd48skn+e///u/9bnvddddRXl4e/3vwwQe7oMcOr7zyCrfeeiszZsxg1apVDB06lLFjx1JV1b54+Mcff8zll1/O5MmTWb16NRMmTGDChAmsX7++y/q8Nx988AFTpkzhk08+YdGiRRiGwTnnnENLS0un26WkpCSc9+3bt3dRjztm4MCBCX366KOPOmzbHa8FwGeffZYwhkWLFgFwySWXdLhNd7gWLS0tDB06lMcff7zdzx988EEeffRRnnzySVasWEFSUhJjx44lHA53uM+D/X0dCjobR2trK6tWreKuu+5i1apVvPHGG2zcuJELLrhgv/s9mO/mIUN+B3nwwQdl3759O20zatQoOW3atK7pUDuccsopcsqUKfHXlmXJ/Px8OXPmzHbbX3rppfL8889PeG/EiBHyhhtuOKz9PBiqqqokID/44IMO28yZM0empqZ2XacOgBkzZsihQ4cecPuj4VpIKeW0adNkUVGRtG273c+747UA5Lx58+KvbduWubm58g9/+EP8vfr6eun1euVf/vKXDvdzsL+vQ83e42iPTz/9VAJy+/btHbY52O/moeKonzG0R0NDAxkZGftt99JLL5GVlcWgQYO48847aW1t7YLeQTQaZeXKlYwZMyb+nqIojBkzhn/961/tbvOvf/0roT3A2LFjO2x/JGhoaADY77lvbm6mT58+FBQUcOGFF/Lll192Rfc6ZfPmzeTn53PMMcdw5ZVXUlJS0mHbo+FaRKNRXnzxRa655ppOi1V2x2uxJ1u3bqWioiLhfKempjJixIgOz/c3+X0dCRoaGhBCkJaW1mm7g/luHiq+c4Zhy5YtPPbYY9xwww2dtrviiit48cUXWbp0KXfeeScvvPACP/nJT7qkjzU1NViWRU5OTsL7OTk5VFRUtLtNRUXFQbXvamzbZvr06Zx22mkMGjSow3YDBgzg2Wef5a233uLFF1/Etm1OPfVUSktLu7C3iYwYMYK5c+fy3nvvMXv2bLZu3crpp58eLxG/N939WgC8+eab1NfXM2nSpA7bdMdrsTexc3ow5/ub/L66mnA4zB133MHll1/eafG8g/1uHiq6rbTnr371K37/+9932mbDhg0JjpiysjLGjRvHJZdcwnXXXdfpttdff338/4MHDyYvL4/Ro0dTXFxMUVHRt+v8fyBTpkxh/fr1+13/HDlyJCNHjoy/PvXUUzn++ON56qmn+N3vfne4u9ku5557bvz/Q4YMYcSIEfTp04dXX32VyZMnH5E+fVv+/Oc/c+6555Kfn99hm+54Lf4TMAyDSy+9FCkls2fP7rTtkfpudlvDcNttt3X6tANwzDHHxP+/c+dOzjrrLE499VT+9Kc/HfTxRowYATgzjsNtGLKyslBVlcrKyoT3Kysryc3NbXeb3Nzcg2rflUydOpW///3vfPjhhwddUl3XdYYNG8aWLVsOU+8OnrS0NPr3799hn7rztQDYvn0777//Pm+88cZBbdcdr0XsnFZWVpKXlxd/v7KykhNPPLHdbb7J76uriBmF7du3s2TJkoMutb2/7+ahotsuJfXo0YPjjjuu0z+PxwM4M4UzzzyTk046iTlz5uxXhKI91qxZA5Dw5TtceDweTjrpJBYvXhx/z7ZtFi9enPAEtycjR45MaA+waNGiDtt3BVJKpk6dyrx581iyZAl9+/Y96H1YlsW6deu65LwfKM3NzRQXF3fYp+54LfZkzpw5ZGdnc/755x/Udt3xWvTt25fc3NyE893Y2MiKFSs6PN/f5PfVFcSMwubNm3n//ffJzMw86H3s77t5yOhyd/chprS0VPbr10+OHj1alpaWyvLy8vjfnm0GDBggV6xYIaWUcsuWLfLee++Vn3/+udy6dat866235DHHHCPPOOOMLuv3X//6V+n1euXcuXPlV199Ja+//nqZlpYmKyoqpJRSXnXVVfJXv/pVvP3y5culpmnyoYcekhs2bJAzZsyQuq7LdevWdVmf9+amm26SqampctmyZQnnvbW1Nd5m73H89re/lQsWLJDFxcVy5cqV8sc//rH0+Xzyyy+/PBJDkFJKedttt8lly5bJrVu3yuXLl8sxY8bIrKwsWVVVJaU8Oq5FDMuyZO/eveUdd9yxz2fd9Vo0NTXJ1atXy9WrV0tAPvzww3L16tXxaJ0HHnhApqWlybfeekt+8cUX8sILL5R9+/aVoVAovo+zzz5bPvbYY/HX+/t9dfU4otGovOCCC2SvXr3kmjVrEn4vkUikw3Hs77t5uDjqDcOcOXMk0O5fjK1bt0pALl26VEopZUlJiTzjjDNkRkaG9Hq9sl+/fvL222+XDQ0NXdr3xx57TPbu3Vt6PB55yimnyE8++ST+2ahRo+RPf/rThPavvvqq7N+/v/R4PHLgwIFy/vz5XdrfvenovM+ZMyfeZu9xTJ8+PT7mnJwced5558lVq1Z1fef34LLLLpN5eXnS4/HInj17yssuu0xu2bIl/vnRcC1iLFiwQAJy48aN+3zWXa/F0qVL2/0exfpq27a86667ZE5OjvR6vXL06NH7jK9Pnz5yxowZCe919vvq6nHE7kHt/cXuS+2NY3/fzcOFW3bbxcXFxSWBbutjcHFxcXE5MriGwcXFxcUlAdcwuLi4uLgk4BoGFxcXF5cEXMPg4uLi4pKAaxhcXFxcXBJwDYOLi4uLSwKuYXBxcXFxScA1DC4uLi4uCbiGwcXFxcUlAdcwuLi4uLgk4BoGFxcXF5cE/j+gLDh55hWkVQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"imatinib\"\n",
    "X_pre = adata_4i[adata_4i.obs[\"drug\"] == \"control\"].copy().to_df()[features_4i]\n",
    "X_post  = adata_4i[adata_4i.obs[\"drug\"] == drug].copy().to_df()[features_4i]\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.values, X_post.values, 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, Y_tr_post, X_te_pre, Y_te_post, max_epochs=1000, batch_size=64, seed=seed)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post, 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",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post\n",
    "target = Y_te_post\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=\"#C331C8\")\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": 9,
   "id": "b9c7dd83",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (10995, 48)\n",
      "X_post cells: (2693, 48)\n",
      "(2154, 48)\n",
      "(539, 48)\n",
      "(2154, 48)\n",
      "(539, 48)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 1234\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.07603466947967093\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:15<04:37,  3.41it/s, loss=0.782, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 26.773. 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.013031147223614425, 'mmd2_gamma_0.5': 0.013870630058121128, 'mmd2_gamma_1.0': 0.007545053495901281, 'wasserstein_distance': 1.7872224415461533, 'R2_feature_means': 0.5907341226373328}\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:15<04:43,  3.34it/s, loss=0.818, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 22.533. 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.008790604299436233, 'mmd2_gamma_0.5': 0.011232032562405514, 'mmd2_gamma_1.0': 0.006819672344451196, 'wasserstein_distance': 1.7679194330815677, 'R2_feature_means': 0.6749024580810057}\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:15<04:28,  3.53it/s, loss=0.832, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 28.011. 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.00706834487637098, 'mmd2_gamma_0.5': 0.009748834627328909, 'mmd2_gamma_1.0': 0.005836889230924097, 'wasserstein_distance': 1.7369183917006306, 'R2_feature_means': 0.7320418159311746}\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:13<04:05,  3.86it/s, loss=0.879, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.686. 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.008382446666750365, 'mmd2_gamma_0.5': 0.01044832104245004, 'mmd2_gamma_1.0': 0.006112060603045217, 'wasserstein_distance': 1.7510707112088757, 'R2_feature_means': 0.7791286685443591}\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:15<04:43,  3.34it/s, loss=0.917, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 24.920. 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.008970455633672825, 'mmd2_gamma_0.5': 0.011192176036149665, 'mmd2_gamma_1.0': 0.006503206191978254, 'wasserstein_distance': 1.7625350220267453, 'R2_feature_means': 0.72074910416779}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:14<04:18,  3.66it/s, loss=0.831, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 26.234. 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.009909973543066997, 'mmd2_gamma_0.5': 0.01119583917327295, 'mmd2_gamma_1.0': 0.006336689477785571, 'wasserstein_distance': 1.7808402628243694, 'R2_feature_means': 0.5903214873264016}\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:13<03:59,  3.95it/s, loss=0.907, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.057. 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.0093801868795641, 'mmd2_gamma_0.5': 0.01168333690332847, 'mmd2_gamma_1.0': 0.006706409506165342, 'wasserstein_distance': 1.75049402765922, 'R2_feature_means': 0.7028166471235928}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:14<04:26,  3.55it/s, loss=0.813, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 23.486. 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.01000610406282021, 'mmd2_gamma_0.5': 0.01333569544798549, 'mmd2_gamma_1.0': 0.007926037448113474, 'wasserstein_distance': 1.7800632419696247, 'R2_feature_means': 0.6018932730308189}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:14<04:23,  3.59it/s, loss=0.792, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 26.727. 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",
      "/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 8 metrics: {'mmd2_gamma_median': 0.008755715814723786, 'mmd2_gamma_0.5': 0.011031954703234675, 'mmd2_gamma_1.0': 0.0065762335650619945, 'wasserstein_distance': 1.7542328033212913, 'R2_feature_means': 0.6880856875504178}\n",
      "**************** Run: 9 ****************\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:15<04:35,  3.43it/s, loss=0.805, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.876. 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.011891730208393403, 'mmd2_gamma_0.5': 0.01355791787439807, 'mmd2_gamma_1.0': 0.007771959604269116, 'wasserstein_distance': 1.7776509756800218, 'R2_feature_means': 0.46591316936741944}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0096  0.0017\n",
      "mmd2_gamma_0.5        0.0117  0.0014\n",
      "mmd2_gamma_1.0        0.0068  0.0007\n",
      "wasserstein_distance  1.7649  0.0165\n",
      "R2_feature_means      0.6547  0.0921\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": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAELCAYAAADdriHjAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAADVsElEQVR4nOy9d5hd1Xnv/1m7nn5mzvSi0agjQAIsOhhMsenGxBjbcY1zY8dO4iTc3Ofe5Dq5175J/MuTxHGSe+3EsQ3GBgK40UUTxRhMFUU01dH0enrbdf3+OJqjGc2MCkhCEvvzPDxozuxzztp79l7vWm/5vkJKKQkICAgICNiF8m4PICAgICDgyCIwDAEBAQEBswgMQ0BAQEDALALDEBAQEBAwi8AwBAQEBATMIjAMAQEBAQGzCAxDQEBAQMAsAsMQEBAQEDCLwDAEBAQEBMwiMAwBxwyPPfYYQggee+yxQ/L5N954I0II+vr6Dtpn9vX1IYTgxhtvPGifGRDwTgkMQ0DAYeCWW27h29/+9rs9jICA/UJ7twcQEHCwOO+886hUKhiG8W4PZQ633HILmzZt4k/+5E9mvb548WIqlQq6rr87AwsImIfAMAQcMyiKQigUereHcUAIIY66MQcc+wSupICjiqGhIX73d3+Xzs5OTNNkyZIlfPnLX8a27XljDFu2bOGjH/0o7e3thEIhuru7+cQnPkEul6sfI4TgD//wD7n55ptZtWoVoVCIdevW8cQTT+xzPHfeeSdXXHFFfTzLli3j//yf/4PnefVjPvCBD3Dvvfeyc+dOhBAIIejt7QXmjzF8/vOfJxaLMTQ0xEc+8hFisRgtLS382Z/92azPDQg4VAQ7hoCjhuHhYU4//XSy2Sxf/OIXOe644xgaGuKnP/0p5XJ5zvG2bXPJJZdgWRZ/9Ed/RHt7O0NDQ9xzzz1ks1mSyWT92Mcff5zbbruNr371q5imyXe+8x0uvfRSnn32WU488cQFx3TjjTcSi8W4/vrricVibNiwgb/6q78in8/z93//9wD8z//5P8nlcgwODvJP//RPAMRisb2eq+d5XHLJJZxxxhn8wz/8Aw8//DD/+I//yLJly/jyl7/8di5fQMD+IwMCjhI++9nPSkVR5HPPPTfnd77vy0cffVQC8tFHH5VSSrlx40YJyDvuuGOvnwtIQD7//PP113bu3ClDoZC85ppr6q/dcMMNEpA7duyov1Yul+d83pe+9CUZiURktVqtv3bFFVfIxYsXzzl2x44dEpA33HBD/bXPfe5zEpDf+MY3Zh17yimnyHXr1u31XAICDgaBKyngqMD3fX75y19y1VVXceqpp875vRBizmvTO4IHHnhg3h3FTM466yzWrVtX/7mnp4err76aBx54YK/um3A4XP93oVBgcnKS97///ZTLZd588819ntfe+P3f//1ZP7///e9n+/bt7+gzAwL2h8AwBBwVTExMkM/n9+rW2ZMlS5Zw/fXX8/3vf5/m5mYuueQS/t//+3+z4gvTrFixYs5rK1eupFwuMzExseB3vPbaa1xzzTUkk0kSiQQtLS18+tOfBpj3e/aXUChES0vLrNcaGxvJZDJv+zMDAvaXwDAEHNP84z/+I6+88gp/8Rd/QaVS4atf/SonnHACg4OD7/izs9ks559/Pi+//DLf+MY3uPvuu3nooYf4u7/7O6C2y3m7qKr6jscXEPB2CYLPAUcFLS0tJBIJNm3adMDvXbNmDWvWrOFrX/saTz31FOeccw7/9m//xl//9V/Xj9myZcuc923evJlIJDJn5T7NY489xtTUFD//+c8577zz6q/v2LFjzrHzuboCAo5Ugh1DwFGBoih85CMf4e677+b555+f83sp5ZzX8vk8ruvOem3NmjUoioJlWbNef/rpp3nxxRfrPw8MDHDnnXfyoQ99aMHV+/TrM7/btm2+853vzDk2Go2+I9dSQMDhJNgxBBw1/O3f/i0PPvgg559/Pl/84hdZvXo1IyMj3HHHHTz55JNzjt+wYQN/+Id/yMc+9jFWrlyJ67r8+Mc/RlVVPvrRj8469sQTT+SSSy6Zla4K8PWvf33B8Zx99tk0Njbyuc99jq9+9asIIfjxj388r5Fat24dt912G9dffz2nnXYasViMq6666h1ekYCAQ0NgGAKOGrq6unjmmWf4y7/8S26++Wby+TxdXV1cdtllRCKROcefdNJJXHLJJdx9990MDQ0RiUQ46aSTuP/++znzzDNnHXv++edz1lln8fWvf53+/n6OP/54brzxRtauXbvgeJqamrjnnnv4r//1v/K1r32NxsZGPv3pT3PRRRdxySWXzDr2K1/5Ci+99BI33HAD//RP/8TixYsDwxBwxCLkfMubgID3EEII/uAP/oD/+3//77s9lICAI4IgxhAQEBAQMIvAMAQEBAQEzCIwDAEBAQEBswiCzwHveYIwW0DAbIIdQ0BAQEDALALDEBAQEBAwi8PuSvJ9n+HhYeLxeCATEBAQEHCYkFJSKBTo7OxEUfa+JzjshmF4eJhFixYd7q8NCAgICKAm99Ld3b3XYw67YYjH40BtcIlE4nB/fUBAQMB7knw+z6JFi+pz8N447IZh2n2USCQCwxAQEBBwmNkfF34QfA4ICAgImEVgGAICAgICZhEYhoCAgICAWRx1lc/bBtNsfGsEgFNWdbCsO0W5r4I9YWO0GER6w/v4hICAgICAvXFUGYafPrKJb9/yNBPZMgCtqSifX3UC616K45U91IhKx3WttH249V0e6bFNYIgDAo5tjhrDsG0wzfd+8QJT+Qq6roKUTKTL/OjJV2gLn0RvVwNO2mHk9nHia+MHPGEFk93+MXbXOCO3j+OVPYQqaDw3SdvVrcE1Cwg4hjhqDMNYukixbCGEwNRUEOA6NmXfJR/zEIpAT+lYQxb2hH1AE9XADwcZu3sK6froST3YdSxAua/CyO3jNdE5DSr9Fco3V5jakGHR73bOe80CgxsQcPRx1BiGtlSMWMQkU6hiuR6e4+P5Eh2FRFFFhiRO2kGNqBgtxn5/bv8Phxj8/gjSlyi6QPrybe86jnXsCRuv7KE1apS3VRiSZbKqTeOEif/vEr1JRzGUuhGYubsI3HwBAUcPR41hWNad4ovXrOPbtzzNyEQBD1ARuFLyeiFNhxWuTz77O6GX+yqM3z1ZMwoRBVyJl/dwFOeAdx3H8sp4+tx820eNqFijFo/rozwUHcESPiFULi60wzdBNRTUiErThQ1MbcgipcTsMt+Rmy8gIODwctQYBoBrLzqRuKXx5//2MB6SZjUEEh6Qw3zgmpWsfn/XAU069oSNdCVCF+BK0AR+2UdoygHtOo7llfGe5xZZEabvuRwPRUdAQgsh8sLmocgIq51Gehsb8SreLtecJNwbekduvoCAgMPPUVfH8Oh9WyhIh6rvMeKUcXyfqnTJhZwDnnCMFgM9qaEnNKSkZhQUQdtVTQe065j2u5tdJlLWXFHlvsrbOb0jivnOrbylgnZZDEvzSaCjAAlfxxI+k9UKle0V7DEbN+cgNIGTdpD+23PzBQQEvDscVTuG154Z5qn+YYQUSCQuMOKXaVcidPYkgdluj2l/N0Dh1SIgia/Z7cqI9IbpuK6VkdvHQREITdB6VTOLvtC132Oa9rubXeYxtzJe6Ny6lzaQbA1TnHKIezoF4WA6Co2+gTAFsuojPWi8IklhYxFryDpgN19AQMC7x1FlGIb7c3hIYopGRtpIai0ZG5IhTjijs+72sMZtvKKHGlUQhoJf8fDKPgB6k87iL3XVXT1tH24lvjb+tuMDRouBGlFx0g56Sj+mVsYLndvK1a387qdO5cZfbCRXsgkJgw8Mt4Ai2ORlaNQNFplxms5rpOOjbcds7CUg4FjlqDIMnT1JVCEoSRdVCNxdhmFzOcu3/+PXrNigMWGXiVkKnYTxyh4y79XiCCGBUARuxmHox6OzgqCR3vDbnrRm7jqOtZXx3s7t2t4TOWVVJ2PpIqE+n0d+8AbfNTZjKR6mVLnc7GFNy+p3dG0DAgLeHY4qw3DCGZ2cv2Yxt77yBi4SBTBVFR/48YaXiZZUfEViRBQ+5HXy/vyuALAERRUIXeBXwS26B9XV8053HUci0y65+Nr4gue2rDtF7EWX52/dwXp3AN+HZiVEQXd4ODbCR7QKywjP+rxj5foEBBzLHFWGAeDzv386G742wFi2RMTUkAJ8X5Kv2pgiRJsMk8XiQXWY5XqMDjsCAnxPIiQgJVpMO+iunmNpZby/WVbTwekpv4plSlrcEAqC9t4ko3aJsXSRZd2pYzprKyDgWOSoy0pa1p3iU1esRVMVqraL9CVhU0dRBK1tMVRVkFQMqsIjF3HRm3W0pAoeSEeiNep0fab9gCbxbYNpnnqln22D6UN4ZkcGB5JlNR2cbm2MElY08oaDjyRTqRANGbSlYsd01lZAwLHKUbdjKPdVOGFLlHPcVl6RaRRfEA3phFMaXlSQaIwwmS3RIKOsu2YFK1fXVqbzZSXtDz99ZBM33fsypapNNGTw2StO4tqLTqz/fttgmrF0kbZUjGXdqYN9uoedA8mymg5OtxUUroj18PPsdgaETSMRvnDFSSzrTpF9LnfMZm0FBByrHFWGYeyucX58w4vcV+2nKjxCmsr7ZBMXl7rIXxHitmdeZ6hQIBqtTeAnX7S4/t63MwltG0xz070vIyX0tDUwmS1z070vc8qqTpZ1p/ZpNI5GDiTLamZweiJdoooHIXCFz5aBNNsG03S0hI/ZrK2AgGOVo8YwlPsqPH/rDu73BpBIWjyTvO/wipji3Klmzh7t5MzrL2MsXSRZ0ehSopT7KnWD8HaCn2PpIqWqTU9bA4oiaG6I0D+WZSxdBNir0Tha2VeW1Z7Xse3Drfzn6GZ+9sBOfAl4kvRolR/e9SKPPr+DL16zjvcfo1lbAQHHKkeNYbAnbCYqZSzVp8k2UHxIoDOhW2Q1m8yTOY67upVYn8vI7eNsK0/UJyHgbQU/21IxoiGDyWyZ5oYIk9ly3Xe+N6PxTgzDkeCaWijLar4gcvF9Gndu3IIPKApU7Vq9iPR90rlKzVhefxkr1y4LspICAo4SjhrDYLQYtIQjhCoqBd0h7mnkFQcVQa7JY9At0vVqcVag00nXahYAhCEOWMxtWXeKz15xEjfd+zL9Y9m6u2h6wl7IaLxdjiTX1J5ZVnsGkaevYyYUwnF9NEVQsdxZn1Eu2WRClZqxXJsKDEJAwFHCUWMYIr1hTv3kEi77SZb7Kv1M6BaO4oMq+IW3k5BUufreCmdMNhJdEakHOstbyyAEkfbw2wp+XnvR7kKumav4fRmNA2Vf8Yx3m4WC0o2eTmM8RLlsUZ5hGHQEjuuhSvGOjGVAQMDh54AMg+d5/O///b/5yU9+wujoKJ2dnXz+85/na1/7GkKIQzXGOm0fbuXLa8/jojfGefY3/fzkpdfRpELC1chJm1/0baU9s5JFmzziJ8Zx0g5arHaK7yT4uaw7Ne/kvJDReDscKtfUwWJv8hifNU7i3255llzBQiIRgESgAFedsDzoyx0QcJRxQIbh7/7u7/jud7/Lj370I0444QSef/55fud3fodkMslXv/rVQzXGWUR6w5zcu5hyl0Ab3kIrIax+i4TQmVAtsrpNZ96ntKWM2WzQ+Zk2gP0Oph4oCxmNA2Vv8YwjgYWC0iNahc6WBP/to2ez/gev84I3gS18FF9wod7Jl685nbG7xhn68ShO1kExFdp/q4VFX+h+t08pICBgAQ7IMDz11FNcffXVXHHFFQD09vZy66238uyzzx6Swe2NtlSMWNwkPVYlLGFStQGJFxJgQ+q8Brp+u6M+2U+2uUz05+jsSdJ2Ri3w3P/DoVqjHleiJ7XDUpG7kCE62K6pQ8GeQen7tm3jpm/tjolcfdZSLn6hi4lKmZZIhFM/uQSAnf8+hD1hg1f7nP5/H0Yi6DkAFduAgIDDxwEZhrPPPpvvfe97bN68mZUrV/Lyyy/z5JNP8q1vfWvB91iWhWVZ9Z/z+fzbH+0MlnWnuLpzKbds3USfVqWieESkyh16H9loB186f2V94p0O6hYLFmFF47f71nBeqaXe0lPoAg5DS8+ZWT1CFTSem6Tt6t27l4PpmjpUTAel54uJ3Dm8nW/+yQWco0R3t/e8exx70qaWtgTIWgX62M/Hab4wCEgHBByJHJBh+B//43+Qz+c57rjjUFUVz/P4m7/5Gz71qU8t+J5vfvObfP3rX3/HA92Tcl+FdS/FIbyc75feJOZpNLsmec3h0bYJrlssSbE7qGtnHBqyKlnP4oe3vEC4vIo230SJKAz7JdJlmxYlQu8hqsidzurxLA/f8bGHHSq3Vsk8maPrM+31ncrBck0dahaKieTCLiesTc44UoCk9t8MARbflkH1c0DAEcoBaSXdfvvt3Hzzzdxyyy28+OKL/OhHP+If/uEf+NGPfrTge/78z/+cXC5X/29gYOAdDxp2Z8mEEwaqqdBmRlB1hbbuOF5K1IvQxtJFigWLSFagIGgMhahKl8lKBaHC42KE/xd9ixvCW/lX8Tr3bt9+wGPZHy0le8LGGrepDltYwzbSkSDBd/yjUjtoZkzE9+WCMZH4mhh6Sq/94AE+CA305MEXMgwICDg4HNCO4b/9t//G//gf/4NPfOITAKxZs4adO3fyzW9+k8997nPzvsc0TUzTfOcj3YPpLJlEUSUsNHLYJE2DguERNXdPUG2pGGFFI+tZNIZC5HyLsKbRKA1GI1Ue1GvupBYZopqE2555nTPPWVxfte+r4Gx/aw9828crenU/OwKkJ1GjKl7ZO+pWz/sbE4n0hun9SjdPfWczE8Uyjb5Bbyp5wEKGAQEBh48DMgzlchlFmb3JUFUV3/cP6qD2h+ksGW6HS8qdrBdDpGMOCTM8a4Ja1p3ity9cww23vsCoVSKi61yqdrE4nmCTlqWKT5sSJtxmkOoOsXMww/anx+g4LVwLru5DQG9/aw+ctIMwQNrAdLq/Cl7JOyQy4IeD/Y2J/Co6zo3Ld1DMWYR1nU9fspbTAtntgIAjlgMyDFdddRV/8zd/Q09PDyeccAIbN27kW9/6Fl/4whcO1fj2ynSWTO/EIi7zS+TC7rwT1Kc+fgorrBhv3TdC0tLocMJIFVLCJCxUykmfhu4QI305lIxP5ZYMj/48zw/Cb6Al9QUn/f2tPZhO1/SrtY5zakLBr9T+rejKEa8dtLeU3n3FRKaNp9AVlixvYjJbnrMrCwgIOLI4IMPwr//6r/zlX/4lX/nKVxgfH6ezs5MvfelL/NVf/dWhGt8+ifSGGdEq5NJu3X301Cv9cwzE6Z9dwYnndVN4tcjQTSMIQ7A81cTlo4u4vzDIjh1p/IzLOq0Zo8VgPFOikLZY2hJbcNLfn9qD154Z5sVbttKoGXT2hKkO2vgVidlm0HRh46yspCORd9pkZ6bxrFgOiiJI5ytzjOeRoBEVEBBQ44AMQzwe59vf/jbf/va3D9FwDpyZPn7b8ZC+xDS1uutnlqujN4U9YSM9iZEyEIrgkvZeVgwmeKYly6/SAzwnJ9k0meWscBtmRWEyW6Itkph30t+Xn/2nj2zi3255jmy5TFTX+a3kUj5wfAfWsM2i/9JF21Ut79Zl2y8W0kc6kJTeaeO5eWCSXK6K7XooisJLm0c4e20PcGRpRAUEBBxFWknzMdPH35SI8MrWMYSAtcvbKFdd/vk/f0PY1PF8vz7hXL5s2Vxph5DKxtwkuqKQ9A1yisNThVHOMtp4Sc/tNbg67Wff+NYIAKes6qiP7Z//8zdMZMtIfPKOwy2ZLSwLxehOxYivOTIqmvfGgTTtWYhl3SkuPWs5/3LLb/A8Hx2FqKdy931vcMmZK4BjU748IOBo5qg2DDPdFNliFSFACIHt+oRNjc39JTpbEvR2zJhwru+cI+0wts4n+7pFa2sYZdInYetMKFXOuriX37mye58ujo1vDc9Z8YJgPF1C1xR0VadadUh7VbZ4OU775NIj2n00zXz6SKNmlXxmgp7BWnrV/rh/ViebSPoGCaFjGhqGIxhPV+l/PY3Zbswbp9n41kjgWgoIeJc4qg3DTB9/2NSQEkBiaArjmRIArY2RuTGCD/fUpR3u3b6d//zVZqZyZdKiwqLWBEpZEvUNOjoT+x1c3XPFe+nZtdUwQqDoCioqnuPR9tG2Qy67cbDYUx/pMW2Uh2Mj2L+U2HfMddst5P5p9HRiUsM3ICRUMpqFaSs0ejrxeeI0tuPxvV88P2enF4jwBQQcHg6owO1IY9rHLwRM5cu0NEZoSoSZzJUxdJWWhgjlqjtvAdaIVuHh/CA/+tUrmLrGks5GhIC+kSzlSYvzB5qp/n8TbP76tr2OYXrX0tyw2wCVqjatjVFaGiJ4nk/FdvGkpDUV5Yxzeg7HpTlotH24lZV/vQz19xp4tHUcLanTlIgwkSkzla/QnIwgZc0dtFCB38rVrVwe6kG4MOqWES5cHuph5erWWX/D/rEstuvWDI6u0dPWgJTwg5uf59E/f4Vt3+xj89e2MXbX+GG+CgEB7y2O6h0DzM2lrw5VGd4llvdGsbaa3zo4ha6qXHvx8bN6NU9my0zlyizpbKSrNUHYU+nfmeGKShfnqx1Ix2fygTTNF6dIndM47/cvlJl0yqoO/uS3z+J7v3iBYtkiFjH54jXr9sstcjgkqg/kOyK9Ycp5QcV36WmY67bbl0R4pDfMpz99Csfd2lAT2AvXBPbm04ganijw3Z89Wze0jYbJ9nSRKbPK4q7k2wqABwQEHBhHvWGA3bn0Y3eNU7g9Tars4UTS9HzIpKs1wchkAVfzWf/UVpCw/umtSAndrQnS+Qo7R7MkYyblok3SN1ihJFGEYDBcZapaoXDzNk5j2bzGYW+ZScu6UwcsivdO00P3h7fzHXtz2+2PRHjbh1u5YJ52odNMX69tg+k9DG0J01dobYzSX8wz6VdJFNVDpmkVEBAAQsraI364yOfzJJNJcrkciUTioH1uua/C5q9tY9Arko95vJ6e5D5ngAw2AIau0NwYxdQ1HNdjeXcTiiIYnMjRN5SlKRmmQQvx/i2NnG+18URsnAeUISzhY0qFD1mdfPQDx7Pyfy2b9/sPRh7+9DlIKevBXiEEK/962UGbBN/Jd+wrNfhgpZjO/J6wonHBeCte2WW9P0QVj5BU+fjpx/Olr597UL4vIOC9wIHMvcfEjgFqqZUPFwZ4QB+mMGWTdi0calIdQoDjSTK5Csl4iLCh11ekhqrR29nA733kVE5Z1YH3gwyvPDzIA8oQSGjxTPKqw4PmMCseTizoVjoYqqgHIz30UH7Hnm472L+spAPl2otOZHUsVXcJZn+T5S/XP4mUkhZMCrrLHS+/ybnPLOWEMzoP2vcGBATUOGYMw5BfYr0YQrqShGowQbWm9LzLF+5LuSuNVefai45n/VNb666f3/vIOq696ITaB/2vFJubi1j3+bTYJooQJPxad7i0rFLeUVkw3vBOWah95sHUUXqn37GnATwUqaTP3rSlLl/iRD12hrJUhUeLb6IIhQbFZMyvMNyfCwxDQMAh4JgxDLmwixuHVNHAcjw0BD4SRRH4PiBBVQTXXng8X7n2DC45cwVj6SLJikaXEqXcV6mvmLuXNhAWGnnFIeHr5FUHUyo0+AbS8WcdezBZqH3mwfyuw/Ed+8t87rebb9vIDT9/gYp0ieg6l5Q6WbwjTCihkldcDAQ5x8HQVDp7kvv4hoCAgLfDMWMY2lIxEi1hrIRPoxGmKeMykS8DoKqQjIa4+gPHcfKqDl57ZpguJYr+qkp6Q5pt5YlZQdiVq1u5hC7uFwNMaBamVPhgsYNuLcb43VNMPZI96EHh6Syh+Nr4rPaZh2LC3rNF5zv9jgPJcJo2Bi9tHmH9U1tnFQWesqqTWza8iu9L2kNRcr7FejnEl+RyLlW7uUPuIKvUYkYpPcQbxTQnEOwYAgIONseMYZiZHTRcKNJohvj4pcfTtazm9hnaluHBZ7fz8CNb0cuCD3mdnDvVghZXMVp1vKpXT4MEuIAOlpaipGWVBteg04tgLjYwO+ZqBr3T9NLDkYm0J9MtOt8pBzL26aByplBlMlsilQizsqe5XhQItZTYBtVAOBJTVRnzy2wzixxvpgg5Gk2uIOnpOEi+/6PnAumMgIBDwDFjGKAWtOwZMuv+6Z4nEtghg03jk/zsydfQPEGDo5PXHR5Uh+n1w3RORnALHqightVa03pAMRRWrGoGR+JVPCo7LZSwOidgW3il8I4m9YMhVPduMd/Yh348CkIQXxObNf5tg2lu/MVGfMenIWQy5hfJlywqllOvgwCIxU3KrkM5XWXUqyCB9S0jjNpVPNenzQ1hKz7CkaSnKrx6cx/L/ntgGAICDibHlGEo91UwHrQ4UW1krM3iRxNv8fxPJ6ngksOhUwlj4+F6PhlhsVUr0GlHQJXggVf08G2fUFcINaLiV3z0lI5b9hCqwK94SF+rB2x923/Hk/rhyEQ6VOw5dt/xqQ5Y7PzuIEZKn2Uk37xnkOxgmRY/hKM66EJgOx5V26VUcepFgSD53i9eYDRXRZGCrkScUEzn1WIedUphSK9QEg6OkChS8Oyv+/lQ3+oj/loFBBxNHNWSGHsyPVE9ro/yzYkXuccZYExWwK91ox+QJbbqBQbUMlkcbk/s5InoGHggVIEaVVAMpR6gFULUArSmSvMlKdSQijVkIYSg47pWFEPBK3voKb0+qU+36dxfZmYJSV8ekkykPSn3Vcg+l3vHfaZnjt0tuliDFkIRTLQ6vOJM8fytOyj3VWrf83iFECp5w8GQChFPQyCYypURgnpR4LUXncgXrzmVRtNkqYzTkNUwh31cx2OlkiAvHFwh0aQgJBV+JcfY/EYgkREQcDA5pnYMRovBqFnlnuxOXMVHQeILwZSoTdQS8KnV8+lSUFY87k+OsDbRRodtooZ2T8jzBWj3jCWU+yrvOL30cGcJHcx4xsyxV/ur+K7k6fZJHiyOUPFdTFdh8iGFq09eSbsV4sqGxdxb7GdcqZJwdT5x7gmcddGSOXUQq2ONxCsaFh5hUydnW+hlwbqVnbz6ehofSVFxsRSfUVHh7s3bOPmyxQfrEgUEvOc5pgxDpDcM54eprvdIuDpTWLjU5KFVdrVaFhDVdAxDoWK5VHyPyXKZ7lh0zoS8Z4B2vp+nJ8ZKXwWhKbRd1XTAk/rBzhJaiEMRz2j7cCvWpMPYz8cZ0Src7wyCELSKEDnF5o6X3+TUtV2oEZXznXaOa25kPFOiyQxxwTVr53xvua9Ccgt8yOvkIXOEMa9MWNO4xOnk7It6uWNkC0OFIqoUCCERquDJrQNsG0wHQeiAgIPEMWUYAI67spuGTRF8x6fZjjA0VQABuqah+D625+MpEgeJ0ASNqTAnf2QpK1cf2Cp9ZnqpNekwfvck0pVMbchiNBsHvAo/WFlCe+NQxDPKfRXSGzJoSY2yKalWPFqqJkpY0NYZZ8yvkAu7LNtlQFvGddojTXRcV7s+2edydWM4dtc4z9+6g/FimaXZKH+QWEW5U5AoqnSHYrU04g+u5Id3bURS+5t2tsdxXX9BAb/9GX8g5x0QMJtjzjAs607x+WtOqTWg911MQyUWNljalWJoIs94poTn+0hH0tIQ4UvXnUZ8VZyX0hO0DR640J1QBV7FQ0tqKGEFZ7KWmbPnKnzbYJqNb43M6BMR5ZRVHYd1lXsoKqtnGpt2N0FkTCdvuzS0Goz4FXRNoS0Vo21tatauqPBKgc1f21Z3aaUubOSO9Zu43x6gqnuYDQoXF9tZPZpiyqgSX1eT4PjYxSfy6As7sB2PloYoFcvF1NirgN9CDPxwkLG7p5Cuj57UD0uacEDA0cAxZxhgtqbPdCHVVL5MYzjEb524ko7OBEZzLQvmgd9s4ff++k4czyMS0vnAuiVcd/GJLOtO1QTn3hgnozr0HJ+qvzbTHVMdqGJPOghdUB2w8F0ffBi7c5wlf1zze//0kU3883/+hpHJIq5X02/SVEFHc5w//sSZc8TnDtUq9u3EMxYSB5x+PelrdWPTlYpymdrNfyrbGZqcQghoTUXZ+NYwy7pT9V3RfC6tjXft5D6vH0xBuxIho1j8nH6ioVEcyyP0G5XLXxri058+havPO46fbnid/rEcEVOvy6nvD9PXduyeCSYfSIMExRBIXx41acIBAYeaY9IwwG5Nn7PX9nDJmSt4855BeLxC+3Bo14TYws+e3sK//Ocz+L6PUASe79M3nOXR53fw8d6VZJ/Nc1+1H0vxiadMfvdTp3JxYtFsd0yTjjViY43YCL2W3QSSzJM52q6uMKJV+I9fvsB4plQ3CgCuJxlPl/iPX74wq0jrYASH96b0eiDxjJkqpzMVVPd8/eqTl7LupTjWkMVxZiOJiEksHKqv6Pfs4TyfSyudt6gKjzY3jDAFpqOQFTaapdChRMhpDvfbA2RusnipPUcmX6FUdbDDHuuf2kprY3SWgZ1pXEe0CmPpItpLFsaDFtVhCzfr1g5UQLrg5T0cxTkq0oQDAg41x6xhmEmHG6bwpIJUIuhdNRfK87fu4FZewXN8DARlrxak1lSBXXH50a9eqcUmDJVWN0QubXPjLzay+jOpWe4Yv+qjxlW8gge+YESvUGj1SLkuSydsxswihZKN9CVCwLTIee3fkkLJrvvHD0ZweKHJfCb7E89YqGVpc0N0zut3Dm/nzD+6gF4lSj4zgX0HpKKhuS1VdxmG+VxarbEIMWGQLdokyzpZxQIhaJAGqqnSKBUGRZEN9hDhionr+ShCYDsu1T2Mz0zjOt2O1FJ9lAmfS0UXZ1Wbdp+oBN+RCB+EphzSNOGAgKOFY6qOYSGmV6gz6w3Gi2XskoOGwBO7W1IICalQiLJ0qQiPRsVENVUSvkGpZJMLu7NqHIQQdP52O+GeEL9umuC7qc38h/sW/yJf597t22lLxYhHDYQimNn5Qsqa6ms8urvBzXzjnK6L2DaY5qlX+hdsnwlzJ/O9tdzcVy3DQi1LtwxMzft6LuzScFqSN/JTTGZLvNE3waZtY2wemJzTxGfPOhEhBCuOa+ZDbhdCwrioYsZ0Whuj2IqPZ3lkfAvFE7hIQpqG50siIQ1fQjikU6rWDOxM4zrRWttl2GmHdiOC70vWyyGGlXItTW0aHxC8rYyygIBjkffEjmF6hdo3mSUf80gUVRqlUWtQr0HBt5HUjEJzOISFT0RoICHjWyRdnbywCQmDZEWb1x0zqpV54OfDWK5LRGi4CcFtz7zOmecs5vc+sm7eGENrKsrvfWTdXlfSakTl3u3bue3W1/e6C4Ddk3lPW8OCq3XYP3dVsqIR8lTGx4u0tsbqXdpWLGqat5VpWyrGtsE065/aSmMkRL5sYTs+6VyFS8+qKdnCbpnumdfQt336vzvEhXonJ6SaaumsfojsZQY/eeBlxtNVzIrg/dUWng+nyY9WEBqUqy6aKqhUnfoY7JHdbqq0laeqeLS4IRQhaFANxrwKWd2hww7XlkUKCEXQ/rFWFn2h+xDcfQEBRx/vCcMQ6Q3zwskFbn3yNSoll5BU+ZDfyUXlDh4OjyBUMKWHkODnfSqKzflrFiPftHnaHmNUVgijctFUK86/phkbqxmHmatL92STqfU2laoDwkKzFEpTLmPpItdedCLNDVF+8+oArueTSkbmzUqaLzhsf8jktmfmunTmE49bqP/0zNX6/rirxu4ax7k9zQWFFtaLIXbkLRItYT57xUl8YN0SJrOleVuZPvVKP1OjRaJllYgfqlVBK1UefX4Hj72wY45Rm3ZpZZ/L1SfzRYpBd2sMa8jinKW9nPmNxWx9YpTq7Vm6I1Ha9FHuLfajO+CpknDIIGRq9TGU3d1Fh6m4SchXySs28WiUcoMknNFoNsIoloISEmhJnbarmgKjEBAwg/eEYdg2mObO4e2YXSatxBgbLPCQOsIfR45nxUicjG/RqJiEOgw2yBFeyE/y67FhIu06H2pdRvvLCk1GiEWROM7U/Omojzy7jWypCrIWP/CkxPMtbMdbwO9/wrxj3XM38lJ+gtJv9r0LgL33n55m2l2lNWq4eRclpOBm3HrQdabhuLRnCcdNNpJxbN738eX1pjh7dnKb/vznftPPZLGCj0QXKqYvqNgeigeLuhY2antLo13WHaZphco2xQEBZw02YUrJkCgT0TUWmw2sOrmD0y9aAcw2ri3jOpcZi3g4NsJQoUC00eAzl57EBUuX4ts+iqEE9QsBAfPwnjAMM10sXt4lIQ0m1CqFlGSV2khle5XIkjATTQ6bJrJonqBVhClIlyeGBvmSv5wOL0x5SwXpSaQnZ6WjbhtM8+gLfShCgABfSjxPEgtr9clwf1b808wMDrcN1nYBQ+N5wiF9lttkPhaatKcxWgw8y8d6ozQdAUeNa1ijdj2TZ2bGUG9zAx1DFl1KtP4Z5b4KTRMqHS0tRLrD9Wvw4AvbSWBQxMGRPg6SMBrt0SiKIoiENAbGcmx8a2SfO6WZabRGi4FQBdXBKo+HxnjQGMYSPiGhcrmls+ZBi/J5u5snzTSuq1tW8pFdWUkHuwVpQMCxynvCMMx0sTQaJnnFJuSrpBQTPFB0BSklb1YzZKwqTY6JM2JjajAVtskoNs2DGqgCFImQop6OGukNM5Yu4rg+YVNDSlAUqNoejfEw45kSk9kSi9qS+1zxz8ey7hSrlzRz1xNv4Xo+mqrw4fNW7fW9++o/LQSAQEqJdCUy69L/vUH0pE7ThQ2zVu/WqIWU4Nu12MhC8YmxdJGK79IlI1iOiy18MopFSNHI2BbeeJWdo1l8X/Ifv3wekFx70Ym7U2vfF2Pl2mXzptFGesM0npvk+dvTPGgOgw8tmORxWS+HWFlK0rtHmulM47qMcGAQAgIOgPeEYZjpYhkqFDBSOhcXO2gZ11EjNeXUu1/byi8n+8hhk9cdOvQImi/Qy4Lu4xuQQzYgUTQFs1tHurLufmlLxWiMh/ClT65QxXJqE/iq3ibufPwNpnIVMoUqi9sb0DV1ryv+Pdk2mOaNHZMsak0SCeuUKw5v7Jh829pA9oSNYihEj4/gFz3KA1XwQGvQkX5N0iN1YSPpDRlKb5Xxih5qVKH/u0OU3ioxtSE7b3yiLRUjYurkqRBHp4pHg29yhmjheTdL/2QeIQQ9LUlUG278xUbG0yXWP7113qD6nkV+bVe3Un5iB7YtaXYMFARJqTPhW+QibpBmGrAgB7NgdG81QscS7wnDAHNdLB1ueFYB1KP/3ziRvEFHRjImqgy7ZTrUMFda3axc0czEljS+46M36/gVH8UQ9clo2vD8xy9fwHF8Gg2VD52xjOdeH8bQNHq7Gtg5nGPHcIbFHQ188Zp1+31T7Zlp1BiXB7Tj2JNpf75f8RG62LVjEqghBSWkYA1ZJNbEiK2KsP0f+tESar1rXU0+QhLuDc3RWlp2WoqPnXQcN/W/xFS4tiO7VOvifLud409z+e5TL9GqhdHGfTxXMiyK/OddrxJK6MQjJuWKU3exxV50592VrL66i/DPt5L3XRJerRd3WNFYdXlHECcImJd3WjA606jct23bPmuEjhXeM4YB5rpY6lk4r0zU3CAdccpFlZhvMO5XuDzbyTmVFibuSxM7MUp5SwU37c7ygU/fONakg5S1NNSwqaNr6qwJPRkJMTie54vXnLpg4Hk+9ifT6ECY6c93si5CEagJFSWkzAr62hM2QoDZsbs62c3XFGQX0lr62AdPpHmDz1i+SLKo0W6FcRSXJaUYqUiIwmCFJAZ5w0F1BJlcBWlVcHcV/4UMjf7X0zTeXp13V3L6Z1fwO2aRWza8Ss5yiJohfvvCNTSd08RTr/Qf86u4gAPjnRaMzjQqo2aVH4TfQEvq+x0rPJp5TxmGhZiefDO2RbzdIDNkkXB0lrsJwj0mQheUt1Twr4uRtip09iRpO6OVsbvGGfrxKP2lAj/U30BPaazqbWEyW+aB32ylYrlsHpiiqzlOxXJpbojs6lK2/+xPptEBn++M4Gzh1QJTG7LzBn3ViIo1Umtp6lc89KRedzPNPH5EqzD2ygRtqRhrP9jFwPdHapXeukBPaOjPeVxz8nJu6d/EuFYljMZp0VbWF/vxbPCljy+hars88tw2rim3L6gA+6mPn8KZ5yyu7/w2vjXMn37r/vfEKi7gwNhXBt7eKPdVGPrxaM1L0KQzVaxSSFssbYnVdu6GycB4jv7Xj02598AwMHvyHaOC0WRwwVgLK1Y1o0U1pC9Z37+DR++doKp6REMGH+87npU/BiftMq6VqMQc4hMast3H9lwGxnL4vkRKGJsq0tEc448/cebbuon2lWn0dpgOzjaclqTpwqY5PthIb5jIijCTD6SRXq3vQfMlKXq+0EXzham6uOBTuR2s/9buOMFHV6/k+CYdvUFFCasoZs09deWq5bS/oDDlV2ltjDKeKfEoQxR8ByFAEaAogid3DHKW2UBnWllQAXZ657eQbMexuooLODDmy8DTGvX9ikeN3TlOZaCKUAVO2qWhVcf0FSazJRoKJmPDBRQP8t8ZZ2AwdMzVwQSGYRfTk2//62miYxLtrgp+xUeGJX2TWdaLIUzNpKe1NgH95IFX+EJmMZ1+mAa7dtPkPAtvJ/RZOTxfEjZ1kBJnVzZRc0P0bbs89pVp9E6YNgbTLUmnXWTlLRXMLgM1pOBVfcpbam0679u2jZseeplMocJktkwqGWblomYms2XuePlNvhxbSacfqRmFXVlNekrj1E8uqW3Nxz08M0RDMkyl5BEyahIXqrJLnuT8MOJJsU8F2I1vjbyjjK+AY5+ZGXgCsevnGgsFpct9FTJP5hBKLQtRSmge1risbREb5Dj9wzlMT+GD5XaaS1pth4yg5wtdh/38DhWBYZiB8WCZ+N0lBt0iad8iVTFZVImRMWzKUZ9oSKViOTQ3RNgxOUVG2HS4YTqJ8MFSBw9FRxgulPA1iaYqhA0NBMiqQzpX4Rvffwwh2G+Xx+FqIjPtEnOLLlpMo+sz7Zgd5qx6Bs2XWEMWm98Y56aHaqv0pmSE8XSJXKFavy79Y9n6xL5l8yST1QrNZgjtu0N0XNfKyr9etqu+wGDnc/Cvtz+D7XgYukoiatIYD3Pcld10XBpe8NzLfRXueGgTP3n+tXeU8RVwYBxtGTkzM/BwJOgCN11zJRVeKcwblC73VUg/mcEpuIynLCaKFRo8nU4/wkc/sJqLV65m43e2kcirdMoIRAR+2Wf87kmaL0wdM0kQgWHYRf8Phxj8/giPGaM8HBmhqvqEFY3fPvsECkmVzINVJvsqGJpCMh6iMRmiORyGXRp055XaWG7F2Rou8MvWITKuRbnioCgCz5dYjoumKHS1JvbL5bFnM6DGc5O0XX3we0GX+yrs/Pch3IwDQuDmXHb++xDL/6J33mrkjOrUg+oVy8HQVSzHo2K5lCq14rvjruzmV2zlx/e9QdX0iBg6l1pdXHQ7xNfG68Htz5+2FgT89OHXcbxa3cfM+Ml85zrd5e2mUk39tisSZcgqsW0wTXdbgj/42OlHxaR1tLE/qr1HGjMz8Gbew77tzxuUtidtpjZkqQxXedQZ5qHoCFbUJ4TK5UYPX7l6DW2Aq2WxLAsiAtxaLG1m+vqxQGAYqE2O43dPMiRK3BcdwsWnwTGwdZ9b33gTJayQSoTJl2oSF+lchU9dspZT39dN/78PggMI6FQibFOKyKrEF5KK56IADaEQWlilqzWxXy6PmdkUQoPqoMXwrWNknszR9Zn2t9VlbKHdR+HVAs5UrdGQYgh8G5wpByftzFuNHD9eI7p+d5ZUImoylSkzPlAgGTL4zBUnA3DHxjeRQHsoSs63WC+HWFFKkLxznNxzhfpK7aPXLeGSr63Yr5Vo+tcZBm4YYUIpUxUezZZJxrZBr11vx/UXfG/A2+dojeWMaBWGzvVrfViGQvV7WDGUOf1AylvLDN8xjqILhr0SD0VHQEKLa5JXXB6Oj3DZWIYuJUrq3ASjP5vEL/u7EyyS2jFVS3PAhmFoaIj//t//O/fffz/lcpnly5dzww03cOqppx6K8R0W7Akbv+rxWHiMMaWCgiAvHJoxscoWVAUrWhuxkz624jOVK3Pyqg561nZRHawyfs8kQhW8Es5yd2wQwxGs1BNMqRb4cK1cwhPxyf1OOa1nU6Q0ygMWqBIhBL7jv60uY9Or7IlKmZZwhFM/uWSGcZl2ukpqcqN+/fW2D7fMUZFtg9lZUiWVc9JdLLfiNPgGPYMeb2YGqfguDaqBcCRJ3WTUKpHR7Jrv1hBojVpdd+q4tStYtnbvE8zYXeMM3DCCNWwRNQRmTGFSVEmrFhIwpUJIUY+KCetoY39Ve48kZu5wwk0aHzvpOD72wRPr8bOZu+HK9gpOxkX6EkUTTCkWlurT4plopkqDrzBlO7z4T1up2knUiErDOQnKW6tIV6IntX12QjzaOCDDkMlkOOecc7jgggu4//77aWlpYcuWLTQ2Nh6q8R0WCq8W6C8WeDmWQUiBoNZEZ1RUSeUNNF9hKJul0TCpNkgaG8P1Sb37s53kXyjwiDPEnfoA47KKqgpcRdKqhskKm1YnxMdOOo6fvbF5v1JO66Jykw6+6yNUgVBr3eL2N91umnJfhZ/8ZGOtl7LiEaqoXPaTLF9eex4AO7M53mwskCxqdFTCCARGs0Z8Te38ZkpLTO86Ll+2jFOu7+SNOwco35ym04rU7IsEN+fh3l8gskin3OARyUK2ahFWNHrXNSOf95COpLKz9lAhZ7dBXegcRm4fR6i1Npwd1TAXy3bujg9iC4mJQgsh2qNRRqqlI3rCOho52LU0h5r5djg/e2Mz5162jGWEZ9XyVPqqOBkXLanilX2k49Pg6TVVXuHSgEpecdArgsaIUXc92SMOS/+s55gVYjwgw/B3f/d3LFq0iBtuuKH+2pIlSw76oA4n5b4KUxuy5BMuPpI2L8SUauEqPhI4tZyi04nwUGyEUadMJKPzmUt3T+qbnhjkcW+Yu+UAwpYITWIJyZhfZcq2aMSkSQ9xensvp67tIhd265XX2edy895U0zfu0I9Hdy3gJUa3UesWt0fq5r7Y/MY491X7wdjVS9m3uK/az6m3bOP5l4a4r9pPVfMIJVUukV1cHOmm6zPtc8a0ZwVpZEWYlt947HThdSNLg2/UgnEutBd3G8JxymhS8OFzVnPaB5fx5sYtNaPgyXqDnIn7p/YaP5kp7Cd9ibfT4rxyGwlf5ycNO1CloMkIkbEtVEVheKLwtiVDAuayZy1NWNG49qTj6HCPzMlwjlrAPDUH07U86SczjNw2Rrg3jDNhUxmy6KxEuLjSwSOxUSZElWjU4IPFdnqbG2bV1jhpB7PdfJfP9tBwQIbhrrvu4pJLLuFjH/sYjz/+OF1dXXzlK1/h937v9xZ8j2VZtUDNLvL5/Nsf7SFgetLpXJQkMl7TC+pxYmSlheYrnFdqo9ONsNyOk1VtmiJhLlq6FICbb9vIDT9/gaxqk1NsmnwDf3rpLMFFUsXFs3wGbxhGjagsu64V+lw2375t3jL96VV5fG2c4/4+ztid42SezCFdiTDEnC3rvjKXMqqDpfi0uiGEKUi6OmNUeP75Qe73B8EQtLlhctLm0aZxrvjSybSdMTuGsWcFqTVqMflAml81jrM+NYglfEyp8MFiB+d5bYzGqvQsbuM0pYtHn9+B4/pseKOP7qVJ1q6JUt5eqXmu1Np/Ttal8GpxQcMwU5Zbi6r1u/YUmshXXB4OjTAZtvGrtaY73/3Zs7VakzOO54qlS4/JFd3hZjqdu947/X6DzY9ve1s9yd8u+5ulN3OHE7fUWs2BD+UbphirJurjnf6MyfXpmlupxcD3JNKF3/nM6VwerpJRHVqTEZx/Tc9KxPAsn6GbRpGefNu92Y9kDsgwbN++ne9+97tcf/31/MVf/AXPPfccX/3qVzEMg8997nPzvueb3/wmX//61w/KYA8F05NOW0HhysRi7snupKA6RByNiwvtdLoRADrdCJ1uBCEFvu2zbTDNLRtexfclbUaYvG0zQbW2wK+pb6NLQVV4bA8XWd7WhJOu+dQBhCHmlOnPl0K35I8X03b1/A/E/ujA9ByfIp4yyaVtEhWDvGITi5vIkqSqeLQrEYQpSFQMstIlF3Znvb+evpdz6xpJakhhiBIP6SMgBC2WSV5xeCg2Qj7q8nJTnuIdb8ypcbjp3pf52imnI7Saa0wYID2QjqRmKeZnTxkPRVXQGmsaTh+aXMQatZnCNWF+9OTLGJpGc0OEkb4cN9z6AnFRoSeaOOYe3HeDxp2CtgckQgu97Z7kbzcF+0A0j6Z3ODf+YiP9w0VCqFyZWkynE5kz3nkl3z9T++yZGgVjY1r9GKHW6iGEITBSxtu6Dkc6B2QYfN/n1FNP5W//9m8BOOWUU9i0aRP/9m//tqBh+PM//3Ouv/76+s/5fJ5Fixa9gyEfXGbeGO/Pt7IinMBaqcCvq7SW57pshALlHRX6S2UqvktIUXFcnyZpMEa13iLUFAoCgSt91Ki6O/thWwWkJLI8MmtbWni1sFddl/ly+fdHB2ZZd4qrLl/N7es3MW5bNCbCfPL9J5K4vYrpDJLBIunr5BWbaDQ0y288/TA6OQdnygVfEl4axs17ZFSbiu/SHomC4pP0BGNRi98kssTjJk2qMW+NQ6lNEG3WcTMO0qlVo040OdhmnuKgNsv9Mz2J+LaP2WHS8+UuFEOpy3i46VrdxenXLWNbbxX3cZ/O5giy6hPJCsakS7FFIsvymHtwDzczg//CECiqQG8xZsmV7M9nvB1Bu7ejeXTtRSey3I6z8TvbaY2HWWQkUOLKvOOdKREz5JfYFq5S3MMVOfMYa9Rm8IbhWb3ZD+Q6HA0ckGHo6Ojg+OOPn/Xa6tWr+dnPfrbge0zTxDSPbD/c7MYuNWPw5utbKGcru5N0duFbkqGfjFJudKgIh2FRRXo+UgpivoYvJJbiI33wFUkDJsuqMVzVxZl0UAyBou/OiOibzJIxbLxsFHWPFLq93Wx7NtRZ6PifPrKJ9U9txRNgRnUuP38lF5td7KwOcVGpnYfDI4xpFRItIT5/zSn1h2HmwxjuDSP9Mk7GxXu9hF/xSekmpqOQ9iq1oHyTIGyaOJ5Pc0NkwRqHnuNTxL6UqBfUPa6P8nB8DOeOt4jFzXp+/PQkYo1ZeCUfNaZithp0XFfrzbynjEdxMF13HyTRyXo2EUOnSQsdkw/u4WT6XhhWSoxHSjS4Op1D4O9yo+xPzKvcV+H5W3fUJFFao7QVlP021nu716d/P98OpGlEZdVUDDkhKeqlWlrpApIYkd7wLPXUsDI7kwlq6a9jZpFkq7Zgx8FjhQMyDOeccw5vvfXWrNc2b97M4sULZ5QcLey5Km88N1kLkvo1F8ewViar2jT4BitbmpGujVv0QBcIoSAdiampXFjp4NfaOBXFJREN8el1J9D2mElxRwkAvUkncUpNqXV9/w7WiyHcOMSe2ckFWisXpjv362bbWzvMaWZmZyzvTjGZLXPf45tZPAWdDRGuaF/KCZMpsprDqV9aWW/dCXMfxsjSCKUtZRBgNhoc1xHn8sEy97uDTIVt4tEQH/7ASu57bDMjO3OkwiFiqo7jeEyly6QaZxSvddcK3Z67ZRvrnxlGFiQNZYOMVeU7dzxH3NJou93Fq3r4VR+QeBUPz/IW3EXNDJAOF4ooiuBS0UWXFj0mH9zDiT1h83BhgAf0YcoJB9NRuLjUwYfcHjo+s39pmnc8tImbSq9gaT7hSY0rYj28P9+6X8Z6oXt9eue4UKxuakMWrVHFy3v4jsTJuLR9dPd4Z7q1RrRK/VlpI8zYYIGb+l+ieYPPqZ9cwq+i47MK/K4+eSnrXorvU7blcKkXHGwOyDD86Z/+KWeffTZ/+7d/y3XXXcezzz7L9773Pb73ve8dqvG9a7Rd3crUhgzWqM3j4VEeDo9SxSOEylXSoVkLoUuF1U0p/JDA6bfISZsT25s5O99Wm2z/ZCVL2hp585ktmO21dFN/l+aQf12MR++dwNRMFrXGmMyWeSg0zPJ8nM58BD2pkbqwcZZ+0Uz21Q4T5s8/7+tLM1Eps3hREqEIlkWasPZo3QkLPIxhFenKuhT3hXoni8fDFDyPNhljxWvNFPumWO8N0keFkFT4CD2coDex6oLdfZmn6X8lTRWX9lCUKavMeLaKU5B8844nubLQxUWJRUgfREhBWrKm2VTyFpxMZooNai9ZGA9a+3xwA/bNkF9ivRhCupJ2M0pGVnkkOcqlv7Nmv1xB2wbT3PHym6BAqx8ipzjck93JinCivkPfG/Pd66kLG5nakFnQvTS9sIksjeBXfbyqj5t1SOxKw97TrTV0rk+patMVj1PeUSbh60yoFlN+lWd/tI0fJN9CCav19Nc7h7dz5h9dQK8SXXDSf6e9IN5NDsgwnHbaafziF7/gz//8z/nGN77BkiVL+Pa3v82nPvWpQzW+d41Ib5hFv9vJ09/bwsPeKBJJi2dSMF3uKezko9lFhCIK+bEKbV1x0o0K4YxGsqjRE09w5nWttJ3RSva5HNKThBbVArcyUtMcSlsVqqpHT2tt0o5bKv15m81eloxq0ZlKwIYME/dMLnhTzXSBzXdzzpt/HjVoqUb2uQ2e72Fsu6qJqQ1ZnLSDElaoDtp0ESHaEcXNuUysn+Ic2cwSPULGs2jwDLq0KKG4ibpHX2Z7wiZpaUR0nQmvzCQWLhJDVdB0lfViiJXlJC2Kjqz6oAq8/UjXrYsNroXyeUfnau1IIxd2ceOQKhpgSRqEwWTYJhdy9/1mqLd9beuMYw/bxKsaE0oVzp8bO1uIPe91e8Jm4p7JBV2pey5svHJNNt5oMeaNWfB4hXCTxuhgnnAF8oqD4QriFYWRUoGcXaVdC+Ng09xai5flwi4nrE3OO9532gvi3eaAK5+vvPJKrrzyykMxliOOtg+3kgzl8W58nXYzipACNeMw6pTRUbk8vIj1/hA7B7MkmkN8+tK1nLdu1ayJaKFtcGdPclYf6rHhArb0uMcYxHV8zC0Kl4cWcWn3kr3eVPMFpqeZr5fD5645hVNLrbVK6IHdldDzfcZ8hsdoNmrGYthG+pJQj4kW0/DtWv9oFOgWMTqscC01SzDvSt9oMeiJJrjU6uLn/k5s6aGj0N2SpLM9wY7KFDnHpS1k1mIMYRXVPLCV/96uTcD+05aKkWgJYyV8YmWFyXQZvTw3/XNPpkX3bKcmVZ/OVIlIQQ6bECqxtEK5r7LfLpg9/557c6XubUedfS5Xd5P6VR8UQWve4Jp1y7ll4DUmVIeQVLm43E5LwcANeUR0jZxvwzBY2Pss8NvfGOCRSqCVtA+ioxK9LJgolmlQDQphl7Cv0bkkydnJJKuGkoyMFWl1IvQ+GcHqtGg4bfcqYqEbtO2MVj5brE3aA+M5PN8HFXSh0KSaZJwq6+UQa9xWulLRt31TzdfL4aePbOLGps2USjbRqMHno1GuZf6He8+HcdpYFF4tMnTTSE1AzJf4FQ+hCZDge369EhqVeVf609flotshUdS5QWzBTOp0ttdEBhMtYd738eV0KVF82z9mK0yPBmamfw5lioSEypWN86d/TrOn6N7y5kZe2T7MGC4hVeXifDvaXWXe3Lhljv7Xszdt4a37RkhaGj3RBKkLG0msic0xEjOfK6EKGs5NzBrDQjvq6cVaeXu5Hn8QiuD95VZaFMmEXyaeUel0aqnq3UaUqxp6uSe/kzG7QoMb4bO/tfdmWfsTAzySEVLKhRPIDwH5fJ5kMkkulyORSOz7De8i5b4Km7+2jUesQdbLIcqOQwiNy5RuLop0oYQVSq+XgVoap1f0UHSF4/5+BZHe8CyZ4pk9pmf+znY85JTHxu9v5z+rW2nQTXRHoNmCScPi9xuOZ3U+MetzF2J/ZJG3Dab502/dX9OY3+VeEgL+6frLDrhSeL5q6NxzeexJp1bZLEBv0OvZRPOtLKdXhvdu385tz7x+VKl3vtd46f6dvPTv22lvj7PIjOOWXKxhm8Vf7qbtqpb6cfPdY37Z4yNjXYTiOpEB6PDCSE9ithpoMY2Vf72MSG+4VjR66wtUpEtE1/lgtYNz0y3oTRp6Up9zH5X7KruLQA+g2OzX//w6r/98iAZXp0uJoie0uvKqPeEghQ+eQNq1wtLYiVEGSgUy0uZ9f7p8VqLG9Dnv+eztLcawt14Qh8r9eSBzb7Bj2AvT28FLuno50W1hyq0SmxSs+UAXuecKdXeKllSp9lv4rg9+TfvnhRMLC8oUzydh7J6oknversk6CIEZUkl4BqFtPpZnozfpFF4pLHiz7K8s8sEURCu+TyMTCtHo6axcvbsH9qZfDbFpfAI1qnHS4qb67+Z7eKZ3JJ86bXbLzkDO4shj5epWiBWQBYmVrlIdrN3/QzeNgJT1SW++e2xnMUMopLO6kMB2HFAkiqagN+v1HgkjWqVeNNoeipJ1Ldb7gywREZY3NCP93fUoQL3GJfdcYd5isxGtMud+mu7l8Z8vv04+USGs1jKkPtjYgzVkEVsdYWosi1CVWr1GUuDmPKxhm+5UjNN27fZnstCzt9COZSGDcSQFqwPDsBdmbge7UlFa8wYiKmi7upW2q1spvFpk4PtD2BNOTQFVrflPNj0xzI1btiJ0ZZZM8epYCiftcOO9G+u/GxrP8+1bf4OuKTSGQ0xVylSlpOr7qAj6msqsbGnBr85VVp2569ibLPLMCflgCaLNeRiMk7i290Tu27aNbz/2NBPZMgCtqSh//IkzYRv7NFyHsktdwDtnpoZXZcBCKBDa1RN95r053z0Wi5usen8Hyt2VWqtYKTC79doq3LAJ+SVyaXe2Ki86gxR5OZwhqkXoiSWwhizGZki3Swle0SV6XHSWL/+Ohzbxszc2z7rf3r8rtjbdy6OVEHkc7qsOsGIyQXckRutVLZS3Veu9nv2qj56QdH22g/ia2JyF2b4kyfd0xc6RlxmxGLhhBN+VjP184ogJVgeGYS/sKyU00humvL3M8K1jCFGTeTC6DabsNKWSTW9vqr5i2rF1ihf/aSte1WNCFmluirCzmmEiU6ZcdVCEoMUzUVFRhMRHYrgKD4SHWWu00RWZHWeYOTFLH4oVmxOWts7ZBWx8a3jOhLxnQHpvSq/z8dgLO/jOT59DU2YbvuaGKN/7xQtM5Svoulqras6U+X93PIuuqehSocOMkrGsQB77KKXtw60gYOd3BjE7a4kHcld3v+l7c76kh89ecRKnX7SC8nm7XT8brKF6Hc8dtw1w6VnLicVNyq5DJAv9boG84vJgeIRnCmkuLXZxgdpZl26f1u3ySj7WiIXZUZtQR80qtz33FghJV0OcjG1x4y82Ep5ayZRfxdJ8Wv0QAElpMGZXyGg2p13XSuqcRpyp2qTsZtxaoshn2ma5ymYy3+5o6+AUG57fDjDn/p4ZlLbHbewxG9+W9P/HEHgQXRU5IoLVgWHYB/tMCb26lcyTuVkrjBY1QjRaWzFFQhpj40X8vEdjxODZ+CTZnMXUZBVfSBRFYOoqnicZp0pNSAMUBBGpUnFdptwqrXmjHrzac5UyNJ6nULYYGs/XO8RFQ0Z9J1G1XOIRk3LF4aZ7X+afrr9sTkB6f/npI5v4zh3PMTCew9RVVE3QnorTP5Zly8AUxbKFEAJTU0GAV3XI5atojqDbjlChiqlI0jErkMc+SomviWM01dR+ZUTOG1idL+kBaoupJX+8mPKZwzz6w5dm1fGsf3orl569nPVPbWWcMsW8R0oLkbIMMrbFncpOTj29m9jzHkbKQCgCs93EzXlIj/rirdQlyW+t0OKHKE+UibcbjFSqTFTKtLfHCU9q5BSHhK9TaZI06BHe94XlxNviZJ/LEV8b3+szP5M9d0dvbZ8gXazwoztf4u4n3pqzM572QlgjFvaYXds9GTVxNTfvUu2vEuoJvevB6sAw7Ad7S3uM9Ibp+kz7rBXGmg928zFP4Xu/3sjmQgXpSxqkwbPaJE9XxogqGnnfxpeAL2lvjiFKkp2ZHK6Q9ZY5g3qFBgxikwIR3a2sOvbKxKxVSldrgkyhguv7s2SR5ZTHyGSBqu3i+RJVEYQMjbF0kbPX9hzQpFzuq7D5jXFuvHcjmqoQMjQc12dgNIfnSlRFoTJhoXkC35NYrgeylsJqWgLfkQyLEo1aCFt6aAVBshLcfkcj+5MRBHt3DebC7qw6nuld7skrO7jkzBVseH47N937MpGwxsBoAcf18IEnouNcFWmdle1jthp1HS3f9hn6v5sJoZI3nJqa8HCBcKtJSziCm3NZa6Z4rjTOhOLREInw+WtOofRWiZ/909Z6JtT++PfLfRWaJlQ+fsbx3PbM62x+a5ypYoUEBq1ZnTLOnJ3x9LUbuGEEf1dgW4upeAUP6UqsMRuv4tcTNt6tLLzgyTwIzNxV1Mr0MzSWHFQpaY1FaGuJkdlR5OH8IAUcPOkjUBC7hJi0cR+n7NFEiKJwsBUfRREITaAnNXo+3lUP4EJtlaIqCn0jWVobI5SrLh3Nca7/1NmUnivUZZFf1gco2BaogkhIo1x1cT0b2/EO6Pymg2IvFSfIUqanM4naKhgcz1O1XdKFCroruP3eTdi+hwbYnguKoMHXWU2SV5QMOcVmSlo0SJOPs2ROtXXA0cP0PT/tFko/niX3XGG/A6Z7i3VNT6I/feQ1dg7n0FSBZqh4ns8jr/fRdXKYtheUWe06U+fUmoWN3T1BS87g8sZF3G8NMi6qmK7CR1euYBSfW598jYrvogrBBWsW8/nfP53f/Honf/Hz39QzoWb2J19oYp4ZKD4hovPfTzuFhwe2c5/op9uMIxxZa1Klzd0ZF9+nMVXUqd5eolOGcdMu0pMoYQU9pSEUhZ4vd9XP6d0gMAwHiekbaGpDFiklOxrKlNMerUWd2CIDozPOW4NTVHEBga4q+L7El5LJcoWkNDjVbWKjkSbuanhtKl4EimWb1/MZeica6t+z8a1hKpbDeLrE0Hie5miIP7jydE5vamfzkyWkEkHv0tHGFcK+iqNJqraHpgoiIQNDV+eMf2/pc9PBsvb2OKHRmr5916pGvCZJ2XJQpUDL+yQxyBkOIVflfK2TJWe14P2qxG3qDuKuTpNrkBMOulBZHU0dNTndAQszX0bQZJtbb0i10I6hww3z0dUruePlN+eNdS3rTvGBdUu48e6N+FKgCkhGTUYmC3zf2USqKTRH5G7srnGGfjyKk3Y4M5tiSSLCZKWK7Xtkn8pxX3yIUJdJu5EgY1u8XJ5iYCw3KxNqZn/y3j38+zPVfvesajYfczjJbeRJc4ycb5HUzV2dC81ZiR0zY4N6Ai6YbOUcqxnFVAh3megtBtsH02SGR1k6KN81V2tgGA4i04GlXyXG+UV+Bzlpk5c29oQgHDeIt4YoT7lUPQ/XrXWIMxCcXWnhvEobCHgjlWNKschnHZxMrcTkH275Na/Rx3HhFPH3x7lp2+s0xMI0iRDjY0W0HDT80mZsdHxWtWVrY5TUsAkJlVhDiErVIWRqczKQ9pYmNzNYtkgxuLJhMXen+xgYzxFvDHHhaUt44PEtJHwDNazSKBVGlTLL3BiXrVzKg8+9SaXi0qaHkZYk5KtMavYBySEEvLsstGiYr7p3ff8OHv3hi1RVb97ss22D6XqznxOtEM3mSjg/zHFXdgPw1Cv9dYNy3cUn8ujzO7ArLmGpsiOTQyiC7tYEFcud1a6z3v7VEIR6TKoDFi0TBm/EszySGiXn2uQyNou1JGZ7nFZfr8fF5utPngu7sxYuM5+R+TKh3HyFbi3GpaKL9XKIUatEWNH47QvX1Cf3mbHBNsKM5Qs8qAyzVI+yOJJAbzF4YLSP++Ug/oMKsafNd62eJzAMBxGjxWDUrHJPdieaptBBmDEq9KfzLAk3cP7xPfznY6+hoYCQOFJiI3k2NEWnF+G8chunVpr4RbQfR9a6wKlAXtrcLnYQLg+gPgBEVdb0tFLeWaZdhBlXq0z51Vq2hirq/te2gsnloR4eDY+TzpfRVZVLz14+axXy2jPDvHjLVhqFQW9Xw5w0uT0rOM932lkRTRD5ZBM9x9c+58nnd5LPVDEtlZxio/qClnCE+Jo4qy7vIPzzzWR9mwbToBKDxsZofSIIOLLZ26Jhz3ujbzLLejGEqZn0tM5N3fzpI5u48RcbyQ6Wa81zGhZzvtOOeFLwm8ad8xY4frx3Jbc8volxv4Kn+HQQxihAtHV35l2HG97VTMoh3BtGKLUEjq39aR5JjgHQbJvkNYf+iTwx1cCLCqIhg1jYAE2Qibs0FrR6f/JVl3fMUmGd3iFojRrWmIVb8GZlQqkhldiaKBe82skKL0Eu7LLq8g5O//hu4cjpDKaueJx0Xx5FCvK6Q6HBw814bO2b4n51EK1Ro6M7Oef6HU4Cw3AQifSG4fww1fUeLXYIVTNoaooy5pX5vY+cSjKtcCdvUhU+lqw1AVUkKKrgoegIy604y504GgKHWuWwlODt6m7m4NS+qOTwxsAk3W6YvOEQRqO1MYocl6TOb6gV3+3K0Pj0p08hbO3gpxtex3F91j+1ldbGKNdedCI/fWQTN9z+ItlymYihc2VpMRelumelyc2XsnvqJ5fQ9qHdfuTPX3MK//iDX9NfLIFf60Exus4n0hvm9N4V/I5Z5JYNr5L1XfSQyjnrjn6Z9vcC+xKC2/PeyBg2bhwWtcbmpE1DrY7Fd3xa/BB5w+HeYj/HNTdij9ncsmErSkSdU/dzyjNRktmVbNXz3BsaQpWC8mC1rlc0/qspfvarPuIlldYpA+mXiSyNICXkTJeqdGmxTQQ1ZdcxpcLgWJ72RXGOX9XKrQ+8SqFkUazYFKMGrdEIHzvlOFaubq3rOE3vjNCgOmAhPYn0JE7Wxbf8ut5S4aUiQq0VwE73MH/tmWGG+3N09iRp66rFVbYMT5HzqjhIFB/6UhXWKCmUCzT8NxQ6upPvuPj0nRIYhoPMcVd207ApguXUGtZkbIuUE2a5HcM3Jc1KmJxn4eKh+gIVhaSrU1Bd8nGX0Mow7pCc1p+b1SdI7Pq/BLKVKoqQxF2dKxp6aCuYiMju4ruZOvPrv7WVaMioB/mmaw5uuvdl0ARtapica3NPfifLKjG6I7FZ2+h9peyesqqTeCqEGdZIhUJY+Nw5vJ0PDK5iWXeKM89ZjNls8Nwbg2x8c5SHn93G068M1FeF+yPlEXD42R8huJn3RsgvccdtA/MGlDe+NcJktkxnMgZaLVtoXKkynikhTEHFd1ncEJ81IQ7350iWPDq8MN1GDDzBg8owo36FRjfC8q5G/u9Du+QzTJ0PpmryGZW+CnpSZ+nZLYRe6yMnbBLSwNRVOrUoV3mLWH32Iv79+Zpb58RlbQyN53E9n99bs4beJ3W2PdhX3yHF18YRqqA6WAVV1Kq2dQWQSEfi5j2EClpSReiC3HMF2q5u5Qf/8HQ92B1WND557glcevZy/uXWZ/CQaAjiis5ThVHOiLWw7JxFxAZNxseLNBom/bk8jvTZOZLl7LU9h/VvHxiGg8yy7hSfv+YUbrr3ZYYKBYyq4OJiB95/ZFEjKle19PLToa0IVSCFIOUa2IpPxNBpT8aZGq8SQ6eIgzuzD7IERYDcpU4XCxl84sTVrNwUpj0fQkTEnOI7YE5q6/RDt2VgimLBojMWw2/2YZJZhT4HouI6li7i+T5LelJULAfPcknnK7MK7DKFKpPZEqlEmJU9u3tAj2dKrH9qa6CRdASyv0Jw0/dGA8m6MOTMgPLGt4ZrhY+5Mul8ha54DHIepqvQZIZouSxF7KW5BqWzJ4kVdXCzLr7tcZ7dxnJilFqh/ep2/uXOZ2cFjR8KjbCyKcmpH+8idW4jkd4wA/9m8+P7XmYSi4iu82HRxUXhbjLNoTkp3zsHMxR+VWBQGOSbPBJFFXZlJzWem2T41iogGTWqFFIu0UmFxYlEzd+rCvrGc5QXQbKoYf9qkFuffA3JLnkPu8qtT77GFxatoyUVJe5rKGkf3VPqEuQnnNHJ1b9ayq1PvsYL/hRVfIQQfOP7j/HS5hH+7o8uOWx/+8AwHAKmi3v6X09TvmGKTj2C3lZ7sM6ZbKHHD/FEeJznnQk8xUdIweWhRfQ2N+APpmmIhtDKCroUVIVHFhvJ9O5BokiIlVROj7VyyjeX7LUQZ6G0wJYhFWXCZ3gsR4NqUIrVcrrf94Xlc7RgFmJPWeXNA5PkClVs10dVBI88t43nXhtGSoiEdZxJn+yMHtBbB9P89OHXiYaNeeUEAt5d9qcZ1J7sWdgG8Kffuh9T11jS2cjO0SyDxQI9bUk+feoJXLArq+izXdYcg3LCGZ2MfUaj/3u7ZGekz6LGBOLqOC/bOXK2TeseQeNC1KsbBYDrLl3DknSEvhcmafSMeo1C/HiN6PrZz0VY0XizkuZZfYpK2iUsNC4pd9I7saheyPqINcgD2jAV18VMKFwR7+HsUjOP6SM8ZIxg5XzCisaZb3XXeqKHoqhC0GCEGK2W8AoujfEQUkJjs8lktkSDHuG4K7sp91VY91KcSb2L71tvoaEQkgqOD3c98RaXnb2SD6xbclj+9oFhOEQs607RNKKyzSqhd+kzsheqdGtRPuUt5aJoJyPDeRp9kxVdzThphy16Adv0yVkOSElLMsoH163g0Wd3MJWrgJTEfJ2zys2I20pMxtP0fKFrr+OYKU8QVjQ+0rucnsdULtO7ud8bZMytEMprfPbKNXXVyH25d/bUSmqPRti8cxJfgmmoJKImjz7Xh+P5RMIag2N5PM+n7PkMTeRpiIXRNQXH9WhuiLzrPtWA+Zl2FW1+Y5yM6hA/XqNt1+8WylaaWdj21Cv9s1bmyZjJwFiOL113GtdedEL9PQtVSrd9uBV70mb05xP4tuRXkXEeeewViqrLVLGMFzbpqITmDRpPB85jZY81aorG85J1338bzJHt+OCpy/j5vZtwHElKN6m6LuvFEJf5JU7oTeJeFeaBnw/ju5I2ESarWdxvD5Js0XmoPIKk9nq5UfLMxCiqEGTtKg1GiKxdJaxovG9NF+El4bpHIRrdnaY73SfCjkukJYkIDSEhpCmUHIctA1OBYTgWmG8rjpT4rsSddGhEoSmcQouruGmXUbPKw7ERGsJh2qJR0tUqRljji9ecxieXH8c///OTvKpkEcBz5iQNns6H7jZovjC1X6u46TTBlu0G23JpGuIaH7V70DxBg6Nz4sYo5TMq+2yKvqckx0hfjk3bxohIlSYlRDwRItkVZevgFEC9SMkwVGzHY3SqSNjUufbC41n/9NZ3LOgXcGi5b9s2bnpo1yJg/W5Buv1RAt1zx1quujQ3RDllVcecY+erlK73bk5qvBzO8POJPtS0YMmqJnxfks5XUBtUkobJb1+4hqZzmnjqlX6SFQ3n9nQ9cN43meW1p7O870ydE3bdx3saozse3sQoFYSEnG3RIkKIhEouXOtU555s4v9KoTMWQwuphHIm/cM5BtwSlu7T3RQn3B4iGVLoH8ty/prFPL1pkNFqqR5jOOGMTk6gc44RLPdVsEZthCrorIZRhaAqPUxqiydNVVixqOkQ/HXnJzAMh5D5pAOkBKNJZ7LdZSJTokkLcc71y1AMhXxmgsqPXVIZgfAlKUUjHXMYSxcJOZKdokTc00hInbzi8FBkhOOrKZbvh9BWhxum8KSCVCI82jjMPXJnrYe1qXJxpZ3VVoL0o1m2bpniB8m30JL6vE3R2z7cOks4TFZ9IllBBp+wpuP7EiY8xvUijfEwq5c088vH3sSXAkNT6WyKYzkeX7zmVK696ARaU9F3JOgXcGiZTz10WpCuU4nsUwl0IUG9Zd2pWRk7e/Y3mGZmbdAd6e2Mywq6FITTRVb2NLN1cIrPXnEyF566lI1vDfOn37qfUtUm5KlcUGjh0p4lPFIa5B5nJ2XboeGHffxO8X31ONb0vbbxrRHufvItUAWqVkt3HZMWixuStKVitQylIUnE1Mnh0BzSKVQ9GrojnH72Ul54KkdZB9OXTA7nCesan//90/nE0Np5z3GmEZyZEuyVPU5wE5wdbuUpMU5V8dEUhQ+ft+qw7RYgMAyHnJlZG9aoxeANIzyuj3JvsZ+K6mI6CpuftTnroiXYrotWgBw2DZpJ1rFQ8wrJisawlaOqeLR4JooUJHydYa3CRj3NCr9EA/P3np12CUWGJF7Z49VUjp+l+/A0j6itUlU8HgqNsMKJ00WMKbdKIW2xOBHBGq2SxGBcq9VJTD/806vAofE8hifIeRUShsnZkTaeKo/N6nJ1yqpONr41iuP6dfmOuKC+YlzIhRBwcHinGV/zqYf29aWZqJRZvCi5X0qg8/2N58vY+d0/O2vOe2fWBikqGCi4SIazBTAEjfEwF566FGCWARsfL7JeDOGNwl1eP4oHbWoYSxOz4ljf+ekz3LL+VSazJaq2hyLApWYcFAQfWLeE2Isum2/fhlf2uEBr5eHYCP3W7la5V1x0IpU2+MHNz7M9XcT0FS4P9RB70WXZhzsXNHoA6V9nGLhhBKGB0MDNe0hP8uXQai47awW54wUrFjUdVqMAgWE4LExnbZT7KoyaO7gnuxOp1fKqB0SJ/3jyZX75+hYSisFiP8pm8vQ5eTRf4TS7iclH0nRelCKi6+RxSXg6Q0qFvOLwYHiEjbc9ymeLJ3H5smWzfL4z4wBhRaMNnTcmsozKMlKAagh0BKavkjVcuj1BS0MUM6MwmS4RcZVZdRLeeK1v87LTUqxe0sxdT7yF6/oowLlOko/IXtbJFLmIy/u+UOtyVe6r8KmTjueOl99kMleed1ewkNjaoexm9V5gf5s3zWTPaz5v8kLUoKUa2Wu20p4Gaebf+LVnhndn7OgR0tUqNz/6Kic0NXPm76yYNZ5ZtUFOCFXAhGZjeR4V2+GC02oT5p4GrLU1xisTBe6wtpOVNgYKoYROd2uiHsd64Okt/NMtT+F4u7P/fAkhXcGTks7WOB9evZyRf91dy3FhupPjKg1EPlEr8Jw+p8uXLSNcKTFlVmltjNJWMPfZT2HsrnEGbhjBGrZAA+FT+78QKJpg5ethVv72skB2+1hnzwI4W/UpKy4SSVMyglPxeIUMqgtVxcPWHJ5UxnnjmQJfWLaOT557Arc++RojSoWCcGgMmRy3upXJbJnv/OgZBqpDLHPi9EQT2B8yueml2dLcv5ZjxKSGpFYL4QmJQOAJD8f3MNp1Ot3aaueR0BgTSoWQq86qk5iW/X5jxySLWpNEwjqZ/iI7CgW2bpukiyjHXdLGyjM661vkE8sGzeZK3JN1Fq9tYuWyfWc9HUndrI5G9tVAZj7mu+bLPtw6xxX0uWtO4dTSwtlK0xXO9Z7i15wyyyAN9+eo+C6tIoxf8EhIjQnN4pXvbyfVr7Dyfy2bNa6ZtUE9DU0YxRKZYgVVUeo1Maed0IWU1KXnh8bzlKVLS3OESs7DkzBqlXGGQFEEO0ey3PLAq7jedAL4bjwpUYTgQ2fWeo5vK0/MquVoHwqxrLGFhu7du3R7wqbdCrG4q7aLkvrsHhV7Gty6hIcKiiHwbYnvSBRFQagCvUnHzbhBP4b3CjNvctXQcYYlpq4SMjRMXWWzsElKDR8QUmCpHrZ0uWXDq/zLX17Jme9fzIZnt3Pbi2+worcZRRFYZYeBbIGbxTYadZNLrS5a74tQjFss7m5EUQThkI4nJKGUgZKxdxkHiaYrhKVK1AyBC8IQfPrTp/CR92n1YPWedRL9Dw5RyFRZ1Fqr0FQchzG9QnWxwHQNylsqpH+dmVU127Ldw73Tw3kyw+bk3lU491VxG7BvDrSF696u+ULuvvmKHrcNpvnBzc9jpx0afIN8psoPbn5+lkHq7EkSEhpZu1qPl5lSocE1mLh/iuaLU7OURfesDdJUBVNTiUdMmhsibB6Y5Jb1rxAyNKq2S7ZYJRY2iEdMlvU0EU0bDIzmKFcdLKeWEfcfv3iBbL4y77VLhAyaUlGuu/hEDHf/ajl820dKZstk7DpuPoNrdpg4OQetQUdv1mt9pp1dMvVdtV4XQT+G9xAzb/JMoYqqCBJRk7Cp0zeSRaiCqK5TxCWEgo1PSGhUfJcHfrMV8j5RXachGqo3AuqfzCGANj1M1fe43x/kY9VezIjK2HCe5oYolWpNTmMsX8JHIiXoqqAtFSMRMzn14yvpUqK7XQjAst9PUb509kpn7K5xyrdOoZR8hjIZmhsjZD2biKHT2hDD1EysIYvyjkq9atav+nh5D+lL9AZ1Vu/e+Sb6/am4Ddg7B9rCdV/XfD5333xFj/2vpymkLVoJoYZVkpbBeLpK/+vp+vtPOKOTa49bwe0vv8mEZmFKhQ+WOuj0Ikghyb2QRzGUWQZnpnEanijw3Z89S3NDhIrlkCtU8X3J4o4GyhWnVsF8zTpuvvtlxobztDREyccsKlaRkKHR1hTDslxs19slfr97v6AAjeEQX7xmXX28++o9UZ/4Sx5e0cPNuZhtJh3XtVIdqtZiCCqzDe4pMZwpF3vCQdEFalRBCSloUbW+QAv6MbzHmHmTv7R5hPVPbaV/LIuuKbQ1RVEsgZIVVKn1fXaTgmy5yrdvfgrfk6gIloo4NKkM5Er4EjpEmJCloDkwopTZWc5zspfgWW2S7WNVzKRGLGxQsVx8X+JJWas5MNV6MdF8zHz4p1eVnUqEq1K93JPdyeBUgZDQuFR0IaXkxfExmswQS5aE6ystlFqjHqELlLCKYip7nej3t+I2YGH2lg00H3tb8R4IjZ6O6SvkDIdGqZDTHExLwdzqUl5Zqf+9P/fl0+n4A43xdJEGz6DTjzCslslqNlOPuHQ/lp3jQpw2TtsG03WjpygC2/UxdRXDV4gZYYaLRRI74ILxVu6r9vPqaIGctPGBfMnm1a1jdDRFSYRNrIJDmVp/khgaF+pd/Jcvnjnredhb74n42nh9pxVdFcEatZAu9Hy5C2fKYfs/9GMNWyjGrta/rQaVvgqZJ3PojRpO3sV3JLLgs+i/dNB0YdMREVcLDMO7xPRNfvbaHi45c0V9mz4tIVHwbIpVm1jYhIigOGYjPAijYuGzXRb4QmYlLec2cuvmt1DKEnfCZ0gpkVddHoqMEJc650TbWeEnmaxY3JMcpCEGY5kSrucjfcnJKzv2W4Ji5qryg0oPx4UaGR0tsOT0Fp5/aYi/H96IpfjEUyaVapT371ppOVmntgpNaCimss9J5+1U3AbMZX8zvva24j3Qa75ydSuXh3q43x5gVCljOgoXF9vR76+y+alt9Yk+0hvmrC+tYMe3+3FzHk+Ex3goNoKl+kSEzpWJmvLqfDvLmUYvna+gKoKo0HB3WEx6NkIInHsKXJjspCkR5l/GX52lOQYwMlWiuSFCMh5CLdjoKFxidPNHnz2z3uJzz8l5vt4TCDFrp2W213bMTtqtxRC02upfehJruCbAJzQF6UrCS8OYlo9f8XCyHvE18Xl3Ye8GgWE4Api5TV/Wnao/zLbjYegqT7zYxw9++SImCoqiEJKCsnTJZatc8LDJpfEOHtSHGdErFIRLlFqtQxWPp6vjnNPWScOYjmt7jBZLaKqKoSm4nuSlzSNsG0wD7HMC2XMl31YwaY+F0C9K8ejwRkzHoKshSsauyRuccv1lrFxby5TKv1okvSGz3xP9voT7AvaPvbXXhNmxhT1XvG+ng1ikN8ynP30Kx93awHixRDyrsjiRwGjTcSYdhn48Wp/op//GG+/q4/FnX8dQDBqyCnltt/Jqy7g+785yptF79pkB7r7nDcZkhbCmcYnbScukjtKuYCgqniLBZ06Q2So7dCxKsbQ7xWS2xEt6jp3ZHMbX5iY9LORqA4kaUembzJKP1fSVuiMxQNaPV1RBZcjCtyXSg7armpjakK0/R17JQ09qR9SOODAMRyB7Psy243Hj3S9h+T6mDxY+ii/o9iOYnSYXVjtZWU3wgjbJz7wdWHgMqmUUBKbvMZ4pMaFXKbsutuPjOD66rrCkqxHX9bnj4U089crAPtMaZ67kK30VhKbQdlUTA2GXiu/S07kr0OmruwOda2tV2Q2nJWm+MHVAE/2Rsno6Vin3VXb1MXAJ94ZmrXgVQ3nbn9v24VYuWBsn/WSGkdvGUcOC8uYKvuuDD2N3jrPkj2vS65HeMOIDUdw3oSsep1wsz1JebY80LThhdrhhmiyVlhGHrkmHjGaTkiaLIjFc6eFMOqTaTSJSI7dLb2wmhq3QaJjYqo+mq0xOlnjt9gHWhprmBOAXcm/G18S5561ttZqM0u6ajE+uWYYaGcdJOyhRFS2pAoKlf9ZD6pxGjGaDoR+PUt5WQYuqdH6m7Yi61wPDcBTwgXVLuPoDq7hzw5tUPA9VCtbaDUSaTUaNKl2RKJ1DEUontmK/vA0JmELBwqciXUb9Mo/Gx3CtaRk+cFyfTL5KYzzEhud3YOrafqU1tn24FWvSYfzuSaQra3IFmrlfgc5goj9ymHYfOTkHZ8oFv+bamOnmeyd1JNPHj985SXXQAlUi1NqaPfNkjvKZw+TCLsmKRmZbHrfsMWTlaUmFmJgs1ZVXO65rZUSrMPbKxKzd7Nhd4zx/6w7Gi2ViaUGnG6bDC4MLTsllWC9TsAq0jIW5SO/kFnvbrCBzCBUdhS3DU+TLNrbtIqTgjXyalVOxejxgOhbWcFpyXvfmiFbhzuHtmDNaht45vJ0PaKvouK6Vnf8+hDNVS/wwmnWKb5VRDAVrcldvFbmnuToyCAzDUcLf/dElXHb2Sl5/eYzXXhth45Yxvuu+QXzM4BK3k4vMbtre30RiR4hy1cYDDKES0jViFzey8/4tlC23/nlSQrZQ4YJ1vTz/xvB+C9mV+yqkN2RQI0p95WQ8aPHxq47n1l9toq8vTTRay3UPqpiPLLYNpul/PU10TKLdVUEYgnBvGOmXcTIu9FXRkxod17VSeKXwjutIIr3hXXLVYwixK/jabbDBGuLRH75EqWxTytngS2zpU1U80kqZtmSUT77/RC744In84pk3ueX/vErFd4nFTT5+xvFcHOnixze8yHo5SFV1MRIKF5faOa9Uk/d7IjzGI8lRqqpPojHM2SctovOlGP6USxGXKi4uPiUcKnmvJmkvISo1notMcWqmie6hWlxgZixsPvfmthkigbLq04jJcKFYzyA0zDInt6dqKakjNoPfH0ZNqHh5D71RI7I8ckSmYweG4SjiA+uW8PqOcTb0D+ApPqoHniO5U/aDDyu2dNDRGqdquYRDOrlCFUURDKfzVGYYhWkiIZ3Tju/mjR2T8672Z1avQk1PprKjTLLksLQ7NcvXevZoioaplUxUyrRUI5xaCorRjiR++sgmfnDz8xTSFqarcFGxnUtbexCKILI0QqWvQsfHW0mdW4srbP7atndcR1LuqxBZGsZsM0CA3qQzUC6wXgyh+zqRgsIwNgBLvChF30Pqkt/K9XDV8cvZ9MQgN/z8BXxf0qAaFApVbrj1BYrWJPfRjzAEbXqEtFXhocgIy6txAB6OjyJMhVbXxNLhV1sGiMYMbE8hk7UBgS4FJiol6aJIAIWq4pJBklVsOi0f6TEnFrbnrnc6LXikL0ckK8h6NuNU+Oebn8KXoPhwXqSDP1LW4ORdpF8zNm7Wxcm7mJa/3+nYh7OhVWAYjiK27epf4PuSaFinUnLJqBYIwW3soOGhYdae3snWyQz9o1lKVYeIqnH/E1tmR912tYILGzqnrOpgPFPkpw+/TrZYoTEerjdXmZZTsCyXkuVQrjhICUlP5xOjS7mkvRcn7SBUQebJHJ1GhMWLkkfkCui9zLbBNDf+YiN22qGVEDnD4eHwCCtHEqxINONXfPSkXu9jMC3/vL91JPNNWDOLunxXIgS4Gbfe/rM9FmZ8LL8rICzxVWh2DSZcC3IuW/7PDl7XslTUWk8DbEkkqzBpWIw2WFRzHi1WCKFCwtOZUC2yas3IVIVHm2eiarUd8GA6z3lLF/FYZQBXlRiKSotjoAqFSWmhSIEpBRaSsuIxZlTRm0qc9Dtt+9wlLetO8fEzjueGW19gTLpIDaquh+IJomGdcsXhifIIZ9HKKie6q2ZBRdFrKdx+xcMrebN2JvNdz7cjb/JOCAzDUcRYuojj1TKVypaLLXd1g5YSzRN4wuetnZMct7qFN3dOIn1JxXFQEUhqxTvTaXsC+ODamiLl+qe24ng+uqZy6VnLOWVVJ3/6rfuREpqTEV7aPIrteoQNDUVVKEiHO+2drBhM0BNN0HBugvTjWYyUERSkHYGMpYsUcxYNro4aUmhUTEaMEmksrGEbI6XPWhkfSB3JfBPW5cuWzamilrak67MdhFpbuOO2ATKWhaYoSL+2Zin4DhnFwvRVGtxaOmhUEYQ7NXK+RULo5EVN8ytmGqAJJp0qLdUQedUhrGu0Nsdwcy4hqZKTNu3tccbHiygZn/dNRukxlnBjdCu6qZKYUBlXKyguKGJ3zRAS7k8MYzToJB4b4bPR4j4n4CuWLiUuKhRbJC9WJvhlfseuDEJBxNQoWg59pQLHKTHUhIreoOEkVGSmlqY67b7bU99s+nqesqrzgOVN3ilvP/Ug4LDTlorRGA8TMXUcz6tvAhQgo9jgSbLlKk+9MoAANKVWOT1dwAOgUhPOO4Nmfuu4FfUbbnl3imjIYP3TW9n41gilqk1zQwTb3RWwlqBpKqamougKTgOEf7uRlX+9jLarW+sTifRlUJB2hKG9ZKHmIedZ2EWHtFUlLDQ6WuMs/nJ37W84Y2U8nX0mhKhV+4r5q3Bfe2aYG25/Ec/yaz52WVM43fxGbaegp3Y3qJKexGw3OOGMTj57xUmopkIpUus34ArJqFZlUrPJqQ5bo0WEDp1OhA/ZnQgEY14FgWCxjLK+OEAZh0ndYiBaQTFULjcXsby3iSWtDVxmLCLUbjLqlHEzLpeKLhbFEpzkpbja7sFUNSaUKoojCPsqclcA2FUkriqJdIRYsrypfj7T6dwLYbTUOsOtLic4MZRCRWDh4/o+Zc9F1RXO+ORSFv2XDozGWkDbaDRY9F86WPFXS+rXf099q+nvn/k8TscBS1WbsXTx4N8suwh2DEcR04U93/npc0xly6iAKyVSgCV8BvUy4bKOaigoQmA57uwUPQknOg1cbi7ijEQ7GdWhVLXpiscpTFYASaZqAdRltRVV4MtdrgDXw5cSKSXxeIilZ7UR6a5NFkFB2pFJua+C8aDF5UY39zHAhGMRslUuDS3i9M8to+2qlnnfY3aY9Hy5a5Y0xcwspcIrBV68ZSvZcpk2NYyDTXNrLXEhozo07mXHce1FJ9IzZHLPXW9wt+xHFaK2WvcltvC5PzzESi9BuxLiAjpYaSXJqjZKr8ZNI2/h25KlaoJM3EVEFP5ozcn0Pq3X773PfnYdv/U+je1Pj1H8j0naKyEq4xWEAueGmrnod46j75Uphu+b4IexrTjCASFrz4qApqbaBBw2NQbH82x8a2Sf6r/T9/+adJJztXae8EfJV2wEkIyZVNpg0UXde61sXkjfCiCsaHV5m4xtHfKGVoFhOMq49qITaW6I8r+/u4HquM2UsHCp7cd9JCXbQTgga8/ZLHwBO9QCTRmdyLow8eMbMf5T8MbQOEVp4yJRhMK2X4+xvLmR+zduxfVqO4awqeF5Es/3aGmIzNKSgfduQdrhDAi+HaYLsy7p6uVEt4XxUon4pMpZX1g5r1GYT/Ct4bTkrNeFKvAqHklTI6xoZH0bhsGi5v7oOT6FcWGZsbuncPMV9ORsV1W5r8Kv7tnOw84wOVGrL9AQGGhUcSnjksGipzVB6oJGxJMKXa7Pm5kCdkTS05bEFj4JoZPOV2h9fxMrr2iZLRcONHYK3iwWkUhESEFWfbyST08iQe+FDfziySymqrFcCeMr4NgeA6LEeKbMeLbE4FgegO/94nlAznIpzXedVv51rZjzer+FbT9cT9V2aW2MIOWMHhC9C3dbXEjfqmfIqMt7bB+rEk+Z/O6nTj2k91tgGI5CPrBuCX/4yTP4lxueRuarGFIh5msUFRdfQAqDtLTxZuwXxK6Ac1nz2J4osnRTid6dKdblU9whs/hINF8h6qnc/fRmhCZob4ySaAlTqToIBa4+fzWtjbW2jPPdlO+1OoXDHRA8EKZXs77t19187eEQTXkVJaoQXzN3tbmQwqrepM96vTpQxRqzaTI0LjLbeCg0wqhSoXFXc6bYiy4jG7JItyb/kLqwcZaravMb49xX7UfTFAy3Vm9jSZ/aml0Q9jWawxE6PtrCxP1pkBKjzaCxZGCUBdszWfIVC8vxEAIeeW4bZ/9uz5x7TzEU1JiKV/HwK7XSZzWkoBgKQ36JbNhBtaCIi+HU3K5N4TC5fIVMsQrU+peXKjY33fsyzQ1RDF0lWdGwfjyJ7/jozTp+xa8nWzScluT1V3KoqmB1bwuKIvB9uV+9zOfTt/r4Gcdj3G1xod7JCakmxjMlmiohLli2bMHPORgEhuEoZffO4VFE1UfNSfLCRRcKLUaElGWyXStiubX4wrSJ8KXELXqUJyuM3z3BcjdOg2ISs2oiZIavMGiUwYfFuRCJLpNUIkz/WJaTV7Zz9tqed++kjyDeTr+Dw8Weq9nIijC55/LY22pFVXqTTuGVwpyJdCHZh2ml3IlWh7SVJxFWafAFuPABs4MVhTgZxWHdFSs4bllbPdU13BvCSTukN2Rm9SXPqA6W4tPqh1B1waBdwAFcASlf50q/m8WJBNVBi8pAFRRw0i6d7WHOkM38rLATx6uJ/ikK3LL+VZoSEb7ysTNmnY/RYmC2GlgTFl7BQ3rgV31uu+dV7i3sJG9WyFRtyq6DkDV31inFFNtFsaa/FDbwpSRfsihXHb7x/ccQArQcnD/RzPl2G/9/e+cdJlV59v/Pc9q0nZ3tjWVZXLp0xYaKCipoTOw1ahJLNNhiiimvMXmTiPEXY96YRA1JUBNr7F0pKlZERBFBkZW2vU8vpzy/P4YdWToqLJLzuS6ui+n3ObNz7ue5y/c2uyw8FTqORa7YYleUbTdvIjyhro4hxwbpVk1qRhVR3KxSn1iLZ4CHgYpBdVneHins+ELJ55tuugkhBNdcc82XZI7LrpDdORxEoMBDVLFQgICiYZiCDpHu0+kJgASBID+jgwk9iyMUq17yHA0HieEo2QoPNHSp0GTHiURSO5Rs/m+kNx68JxOCO8Pmq34pJbHlcYQq8FQY5O0fQC/QaPxXC61PtZNY+9lMgk2rkTYtIvAP9vGy1sLvW97jrx3LuTX+AQsDrQhdINOSAQQYaxSxX2Vhzrm0BtMsS3fSGkxjJ7KT/3qpGVVEsMiTHWGb0SmzfJRaBqenBvGT+GimJMoxoxbdb0cQChtnpTukGjIM0woIBbwYuorXo5Ef8GA7kvte+ICH53/YJ1Hsr/VRfEwBdtRBOlkxu7bCDP95/yPstEPZgCCmnh2OUyQ8FAiD9cSxpUR3FGxbomsKqYxFPJVBUxQGBINYMYt5vmaa9WTOLqGKXA6ld+UvBKxv7UEItqps2/pkG6v+p576WWtZ9T/1rPpVPav+px57dg+F96TIe9fa5neyuws7PveOYfHixdx5552MHTv2y7THZRfpFRP76OkG3py3ljczrTSKBFHFJBTwEI6lsJzs/AVNCjQJS33ZH8/4niLqJhYxY/VAnjXXZ7XxURhi5fGhFqZHMelq7qCs0M815x7a7yvhvYldnXewp9jaqj+xOoG0wSjPlhM7pkNqQ5p1tzfkSlV7FU+3VkTQPUgyL68Z2SUptbxERIb5oVZGGyUM9OfjJG1Ur0qjE6ctnGC+so63WtpIKTZeR2WGMZCRpcNyNtZVF/HN48fx7xfep70njcdUODE2gCNT5aCDbTsIr4KiCzzVHjItJtKGRhEnOURB71Rx4pKATyOTccBxaO2M8Yd736CkwJ8r8WztiuGvlOjFOnqBiuJTqU8liXRnKE3pRLUMtmNjOZJuJ42GguoIglJDKBpJxyaWtBFCkOczKMz30tOTxJAqESNDT9qkyvIjHUnh4aE+K/gJw6vobRjaWuh1cweebk7T8UIXngHGFk2F/VHY8bkcQywW47zzzmP27Nn85je/+bJtctlF6qqLqLusiKOnD2XVyjbeaG7m/jeXU1kcZOXadlIZE9OSWEJiCVgQaOVVfzuHJor53gf7c+aZY5jUUk39q60kYyaP5K0nT9EZUBEirGQwdHXjH3pf9vbE6+5kV+cd7Cm21oMgHbCiFlbEQmgCJ+OgaAqeKqNPfHxTxdPNZR8yXsmA4YVgSYJagPVNPYRNiwEbm7OWjI/yxIPv0x1N0m7HCUqdaitARMkwL6+Zk7UkdWQvZq1PtrH/UzrfDQ+lrSdO4cZ5DNKRkC2KQ0iQDii6gn+ojxfb1/G8aEJ2KVh2tjouFssgsrp8KECZ5sOW8H8PvIXPo2M7Dj5F42hfGcc4VVg9Jss72+nxZehuT6N2KZgbR3saUpARDpYC45MFNOpJDEPHG9I5+sDBvPDGJyxb3bqxyMMhXxpUDszHCOsoukL5Nz7LoWyeewK5xd9FrwPXCjWsiAUKWQkOr7JFL1B/FHZ8Lscwc+ZMTjzxRKZNm7ZDx5BOp0mn07nbkUjk83yky07gr/UxvnYQwYYgzy+vJ5m2KCn0s7axhy2jSpI3/Z0cRieeBQaTflPHpHPreOmF1TivNVBTVYCep1G4jcTZ3px43VPs7LyDPcnmq36hChRdYBTp2aEwaQdsMKo0tICG9MktYtbbkn3ozqRzu6P8Uh8Tz8rORG504jzxYDbfUhzy09YVJ6nZqBU6A/wBGqPR3N/PpivlQQUhStv1bNJZIaeLrZdpGMUGVthCZiTrEmFeUJrQCzUqq0N09CRwLAkRBxObGDaVwofW4YBUaG2PURHKo26/YhrbIjzh2UAorhNqVVic30meohHDxLSz+TcVSCsSi6yT+NAT5uBkCSccOIL9z8yqwL741mqkzBZxCFUgHLAjFlqev88KfmdzT0apgZ12SK+MgxBI2wEEdspBxC3MDhNFV3Ihoz1d2LHLjuGBBx7g3XffZfHixTv1/FmzZvGrX/1qlw1z+fxsuppNJbKdzx6hEJd2LqmkSUFGcVjq66YyHqB2o4LkiBMHkP+xL3sRcNSthkj25sTrnmZH8w76g01XmOmWDA1zmvAM8OBJO1g9Jsl1aUDsdMx6892RT9E4fdwIBpdnJTRWLAvn6u+TaRNDV0mbNqbBFjX3m4a6nJSzURoCjCKNTJsJusBX40PxKDhJhwEXVNKZ6sB5UaGyOpTL58R6UpxIFXqxzqORT9GEghmzaE2mkJrE1wrrUp20kSRt2tzjr2dCQQHdWoaUtAGR/S0IKPR7s7piZMu8o6rFgkArQ5xKvl5dxMPzP8S2JUNritFUBV1V6OiM4zuukGGTavtcsDfvRdheL0S2UlAgpUQoCsIjsKM2qQ3ZhXRvkUDveduTZeC75Bg2bNjA1Vdfzdy5c/F6vTv1mp/+9Kdce+21uduRSISBAwfumpUuu0zvavaN5+uZ/eS7mKokYSdwZHZhlhYOUsDiVBurlQjRT32cN2nCToVIdnXQvMuep3eF2fV6d5+RnUJXMEqz4Y+txawTa5NEP4gCguCYvKzkdVeMCcOrcrksXklS8ZzBqlc2TmSb2Dffkh/w0BVJ0hVJUhj09vn76Q119Q628edLyro9OBYITUEv6DvlLzgmj/00lbw3PX3zOQGDkakiqjJ+ZFDyVNda2kU2TxCSOjFh0hVPY+ugaQoYgkVKBzEnW4GkI0gLiVBA8SjY8c/ycF5UUqrDs/Vr8D/s4/GXP6IznKAznKC8KIDX0MkLevo0ePayae4pY1usawpjOw5/vP9N2rpiucqpTHsGxVAIjPKDKWkQCdo6YxRKg+qKAHqxjpNyWHdnI5pfzSm9fh6V28/DLjmGJUuW0NbWxsSJE3P32bbNwoUL+fOf/0w6nUZV1T6v8Xg8eDyeL8dal12irrqIymk+2l7s4rnMBnyoJEVWZlgqEEBjkBokUSB5cNEKDpk8iLrqoh2GSPbWxKtLX7Y1srPm0gFbjVm3PtnWZ37A6yUdvFTWRsYrczX1+7+mIxU/+gA9lyAdNrauz2KiOOTnvBljGT+scou/H3+tjyXjo58NttE1zjh2OGd9bew2p/xVroXTRg7jP+9/lFusXHjKBA6Ml/H23fXk96icaQ1CRCXFPh+rtQiPaxtICQdhAwp0xZJIHAy5USZGZBs3hRQMrylGEYKO7gR+TcNG4lFVkmmT+1/4AE1VCPoNOiNJ1rdG8BoqJ0wcSnGzSsJK9lnF9y6sZj++hLVNPTnVgLbuOLc9tAgEfO/0g3MO0kk6vKK38HTPOpLCwovKSQW1HJtXg4WF2Wmi6ALvQO8eFafcJccwdepUPvjggz73ffvb32bEiBFcd911WzgFl/5n01GL7ckEbXqKlsEWr7c0MbS4EM2rEvIqW6z4txci2VsTry6fsTMjOze9uCTWJmn8VwtWt4nQBU1KnOftBkSnYMCIQrozae5b8AHfjQ/ZQnI9057ps5gIJTUGKAGMfGOLFXV9QxePrV2NVqQxyJdHdybNky1rONypw3ucj+7qJIW2zrCRWafQ69xGJwxKPMNgio8RX6umrrqIf/z+Te6zPiSpWPgMlal6BaOThVR5/WQyNvfkfYpQsxVFiYSJLRwKFQ8ZJ42KwCIr7/LWBw0cPLaanliKpGNjaAqhoJdMxqajJ4EiBKbloGkKwoGQ8PD+oiYWLv6QmkD+Fqv4bK5N8Lt7XiOeSKOqCrqmEE+aPDxvBccfMpS62iIqzyzjnfvX8FTXWlBgYFmI9o4YT/esY4S3kKIWJSvTnaciFIHiU0g3ZYh+ENu7HEMwGGT06L4JxkAgQHFx8Rb3u+w99I5a7F0hNmtJVv/hOcLSpMSrf64V/96YeHX5jM3LVnc0sjPTnsGKWSAEiiEIKxYpYVNm+bB6LAoLPDTEIoQ91jY1kOqqi7Jdzw+1UZ9o32ro46OnG+hpSFDqeEnLNB4kTSLOjTcuoMmfQuQp5AU9XGCM4wT6qrRWdSmI1wSV0318uKiJ+1/7EISk0hegJ5NiXl4zQ8NBquJ+Krx+grpBRndIZWw0VcFnqwyR+bxNey7RbKDg2JINjWHOPX4MLy1Zi2k5+L0aPVYKTVWQZIs1LFPiQaUgqRJVTLp8aQZKSfNDbXSUW4R9Vu63MGF4JUG/QTiWwutRMC0HQ1cxbTu3ACv/ehl+bwTnfoWBZSH0PA3FEKxvCtO4podgJB8kJD/NNsFl+zEkjfc0g5S7NaTkdj7/l7BpVUMdvi9lxb83Jl5dsmxattoaTGelFDxeRm4jyWyUGmh5GlbYwslASNFQNEELCQqbbDKtDp4ineEnVCJeTG8zP7E1SY3e0MeHi5pYtaAZRUJEM8lLqDQqccKaxSKnHSUqqIj7yFgK9zzzPkOODW5zLkTT+jBJJzurQRWCAsNLixPH+Ho+g6oq8OWXUf1yG+F4Gk0VWLbEbyoc1VnJJ1aYTjWNLhSEyA7tMTM2Uw+q49zp42jtitHUHuX2R96mMOhjQ2sYyBb25aOREQ5eVIKdKkqdwtyO9bz0z3dJqXafCr3TjxnFbQ8tIp7MJuTzAx4Kg74+C7CaUUUEC725Yo+oxya/zEdJmx9vvgchILk+jdlhIXTw1ngRutjtIaUv7BhefvnlL8EMlz2Nu+Lfd+mVWQhOyOPRhSt5PtJAWnUIFnlI1gc4vXbL3b2/1seA8ytyOYZVnigpYRFWTTpFhkJpcFashtFHVsORW6+S2ZakRqY9w7P19cx56F16UgksVZK0baKKJKJY+GyVlGKhIuggRW23TkxLb1eltcoJZQX8MikKDC89mRQ+RWPIlAqKygvJa89QHvDz0boOHCfbwfz1I4dz+sSJzP9dIx2kSeMgZDbXVpjvy/0O6qqLqG/oIuA1kBJG15XxyZpOoolMtnpICI5NV1Jp+ljb0cPzohGP5qGmrG+F3vfOOBgEPDxvBaZt4/fqHDq2b+HNVvWRJo2k+jkDT0X2PAIk1qTw1njxVnqRzpYlxl827o7hvxh3xb/v0RuTT7em2ZCK8Vz+BlAF1SX5xIPOdsuKe8tcl7/awCsvfEh+2KDcE6Dbya6uh5rZcGTBpNBWL0hba64TqmDVR23ctWgpaIJy1UdYZjAVybh0iLc8HRTZBhv0BL0yet1OmiIlQM2oIvLOtLba9bt/rY9zDt+f+1/7kJZUHJ+icc7h+1PSqrHqtnr+E13NQrkOKSS6oRL0e1i5poMXhm2gOT9NMKKRxsHGwVIlJ0wZ1uecbHrB7ggnqCoJMr4lxBAnSIGiUxo3kEh6NBPLDwPL8rZaofe90w/m+EOG8p95y1nwzhrmvV3Pm8s29On72XyRVmn5WPVKfe48Splt9MNhj8liuI7BxWUfoTeUY6dsnJRDt5ImhU258GN1mRQW+/s0m20Nf60PK+LBXCgpiHtQbIFXD9CSjhP2Wdu9GG3eXOdkskJ3Kx5poIcENVUhlCoBTdBqJ6lWAuQ5PVlVU8ugVU8jkehC4dxjxmRtrGabXb8X/fBQDjliEKtfaSGvR2WwEqLxXy00aQleVluxLYkhlWycPm2yoTXMnx58i45EAo9XpdKfR36el+50ivHDK7c4ns0v2PY/uul4oQtpZxvyQgcGOfCb1TzyYOMOK/TeWLYBj67lnrO5g958kba5DEbJ8UUkPknuMVkM1zG4uOwj9IZylICKdKDI8OJ1VCIiQ75l0NETJxDoe9HaXN0TsuXIeUEPCcvE3wM9qTQ+RWP4CZU7HlZfmyJ0ZRGVbTqN9zQjDEFFMIi3RaW1KcqA4YWkqxTyk15GhYtRHZXnrAZs26HM8nKgp4RzTx3HQWcNzb3v9rp+9eeTFD9jgmXSRFaJtWNQkqiTlZ1PYiMygJmdaBj0Gnh0FcuWdKZSGAGdkMeDv1GSyM+Wnm4u9dLbsb3qkyY6Kk3ChkkooxPothlWXrhb+n62JoOxte9qd+E6BheXfYTeUI6dtBEKVCa9HEsl84wW2pUUBbo/d9Gqb+j6rFkt7e1TQbRpGKVHS+NTPJx7zJg+F+vNuffBpdy34AOSjkVe0MNpI4cx2jYwigwGKgZfKxjEU11r2dAWxsjTOHToAOTbkunVgxljldEWj5PXqjD+mBrKj9xygNDm1Dd0sXphC5EX26i0fZ8NNHcg3pYmXWijIrCR2TnnEgxboaRLxxNSaU7GSGUsYt0pDk6Xsv5vjRCIZjWfmj7dQuol055hXnQDL+hNJDMWPqFxfLSK2vaBO93309gWwSuy8x18Pn2bDho+y+EUTArljrc1EqO8Mo+66t3f/ew6BheXfYRNQzmKV8GK2RxtVzJaK0E5NkDthBIGKAHufXAp97+6nJ6GBF5UvlYwiClmRZ9Kl10pTnj7nk+Y8+gSHEdSoBokLJP/vP8RJZ5hVHUp6EU6U8wKhgbyeXd8nFc/2cDCTzfwmnSY0VLN8RW1FHUqmFGLjrmdhN+ObLfDt1enK9yaRAnaHKtUcmS6POscLNAdgVeqmMLBVgBHoiEIaR7CToZQ2ECW5tETTyGjDm+LNpbr3RycLOGt19rxDPBsIfWSclI8LxqRlqTc8NOTyd6e4cQpILTDvp+Rg0t4YsFHWLaTnfuglmQd89fIlfjaCTsXflM9Ss5Zvxpo2+O6ZK5jcHHZh+gNQbQ+0Ubngm6cjMMAJUBea4DEbV0sjK9ljlyBElAodbxEDJNnYusZUVJIaZvep9JlZ4oTEmuTfPxsM0mZLR0VpsyGnzQTpvgQr4lcXLx0RhGL31uNR9eoCARoSUR4NtZA3dogZd0GWqGKr9bXp8y1V5Kj1zltqtNVXZpPU1c3cwPNDMkEqbL8IKCsII+q0iCmJvHYCj2tSXyGxuS8Ct5ItNKaSeKzPRiKghcFn67R7aR5UTaBLalMeujqTOAPaHSEE9kZGz6wglAUMyAtCSkGXXkmYZ+1xTnZPBRV39DFhx+3USq9eIRKFymW2h2see51it8NMLWnnGP0KrQijfiKBCDxjAzgpBzeuX8NdxWvQujKHtUlcx2Di8s+SHhxFDVPpSNo0dLUSeDFLmpLQsTKJMk2i/KYD0URhCydNiVFW3ecCn/xLlW6JNYm6Xqtm2BcRTMUWqw4BaonG2pRPIz4WjWV0325sMh7kXbib2Uox0diXYKApdJGhnStQEfDV+vrU+b6n7nLeWTlqj4r5arS/D7x+rwCD02RGKv1KFWWHy2kcuh3B2MFQvzj3nfo6UjisRWmdpdzvDaQSXoJ3VoGZ5KXOa8vw8JmTSaCI8ByHDQp6GnvhI6sbExRwWd9B/mlPtL5DoWGh+5MmnyPb4sk8+aqw2cdPIoyxUssnKbE8WJ6JKmMgwMEpYadsnk2tZ79i4qpTHqz86mFQFoSvUinfUOCeDxDbW3RHtUlcx2Di8s+Rm8S+hVfC880rSdpWXiCCsdGqhjrKcGnajkJ7XAsicdSKPZ4d6nSpbcs1gybrIx1kcgz6REmbaQoFAYXHXMglZavT7K0vCEPn6LR2hAlhEHEMPFZGv4mgertW+ba4knxn/e3XClfe95hfUXqzAiO4TB3YBvFw4s4/1tjsyMy1wbxJeN0+lIUGDolYY3k+jRVA/0MG13KJ690YMdtWmUSleyEOCkhIxyEABvAga5wkhfe+oTvnX5wLu/SnIpvNcm8uepw89owc+5fwlkMRpXQI9NoGQVTOmgIvKpGqCjAukg3bd1xKoM+BAKkRGgCs8uk1OcnENjzumSuY3Bx2ccwSg02ZGI8nVyHdCSljoeIYjLP28SQxjyO0cuZ52umKRIjWODhnCNGc/Sxo3faKWza4dw5wGZeYwt5lk6J5iWsZPCGDIam87JjKhM2LZ5UTuPolNoh3Ld2OW16Ch8aJxbUUBXxU3h4iPDiaC7sxBQfyWUWNQV9K3kMXe0jUqcogv2qi9A1lWci65imjaIOH8tfbaA1HKO8NEhtQQgrZJFuSlN6QhGd83uoUvwcFCzjyeg6svVLWRyRTVV4hYIqBSYyp2+0rbxLb+J4fXdXbjcjUw7+HkGrtAiUeTmhp5pnUxsIywyKhDyhk1/pIyJMgkUeCsMG6aYMWr4KqsDqtlD9KgeeM5hvBQJ7XJfMdQwuLl9htjVFr0umSQmbUseDIgT5UqddpOlxMkxJlTOmpJhu1aTY9O6UU9i0ambVyjbei7VTURGky0mT1h1K8eCr8lJaEKKhK8LHzzYzWi3k1fw2nu5ZR+p5m7w3DKZFK7mseyg9Woby0jwGmkGEX5A4RKd7pDcnoBfUkgRWfbDVlfJhY2sAwR/ufZ2B5SHy/B4cR7K6oZMF73zKI/9cygtL1hAljdouOCZSxaHeCrpDGdDyUTd2Zx9n1fBmspU2K4muKmBLUmTDPKoUSNhC32jzvEtOwTZhk/CkkIrNp4lOCg0vETuD39Ap1ryMrShmv1V59OgZVskwb2udNEVj5Ht9nD5qOAMWBbCkhRbUKJlRTP6YPBqdOPW+FBOKqva4SoHrGFxcvqJsa4pepj1DieHFL3Ui0iJfakSEiVeoFOLBP8RHQbGx09IKm178XtZamOttIkYGb4vKYcGKbK+EahIsyKql+hSNUFqjtTzNMx3rkRqUpj2096R5VKzlOxVD2b+5ENkgkQMl7x4c44kHNzkOI3sc2+sPmDC8kpKCAImUhd9rsGp9B12RJH9/dEl2LjMKluZgOpIHzE95zm4kP+TB/+paxlv5DGsKUVEa5GBRytNsQKgCVVEImSphTFLYeHWdUNC7hb5RL5trQ324poGIkyKsmjSJGAXS4GyxHwO0AOmWNOVRDzVVQSZVVjG5o4duM8P+R9WgPBRDGhL/ED9ml0nXgm5eDbTx4KIV/TYh0XUMLi5fQbY3Ra+y1EdNIJ8Z6WqelRtoN9MoUnCAWoRerGfncWxDWmHzJqrE2iTv3L+GTieFUyR4rmMDMiOpLgnS3hHn9XAzhxrlLMnvojEaJeA1OPeYMdQ8pbOsu5OkY1HmeOkUKbpkigwOs51VHDawnCnRcqq+XsQTSz/Y6nFsr2R2016L1Q2ddEWSFIV8FGoeOnsSxLDwCBWPIohLm6hiUuML0dga4RHZRSipE2wwONRbzsCCIBldEvAb2GkbTzyNrisoukJhMCs4CfDGsvV97NhUG2p9LMLzTiNBqVOm+umRaVSpMMwJkW5MZ0tQA0p2WJIiqC0poLIxTVnEoHXjezRacTr9KeLtKR5f0IjiV/ttQqLrGFxcvoJst5t2bFbrf+pDMNTKZ4HRxPu+Hj7Ii7LK/oRpsUqOaqzI1ck3a0lal7WjvZfGeDGNnbBzjz3fuo574stIaw6yC+LSZLAMYoR0BhQXsqEtzNRzRjGtWOWTDZ0MHVjMUQcMptXXRuP9cTyWQrtI0aWlsays1HW3nebp5DqW6O0c25Xeblfw1kpme8NnvVPlFrzzaVaNtbqIePizWQuKJCuvLbJTC3taE8RkBkdAvubBQfJmfgclZQHe/6SV1s4YqqrwjaOGc+kpk3IOaenHTXz/D89tsXo3Sg1aPCk623poMxOksCmVHgxdxyd0WlJxlOMC1E0chJNxWH974xaCgP7BPlS/ygsta3leNpIwTSSQiUnGVFX024RE1zG4uHwF2dEUvd5+Bla2sfqZevJ0X+55L/nbmHriCIaNLOOxRR9x368/IJ420XokM/Rqjh9Qi9ll8s79a3gw+DEoUOZ46VDSJKVFh0gR1AJ0Z9IEC72sDHfy/POrcxfOjp44p399NEePDdIxV2HOomVkupJoqsC2QQUcBDKo8NrqDaiK0uc4fIrWR6Ji013MY4s+6tNhfcGJ4zjmwP14auHHufcI+gzSyRQpaaNJgbKxzChlmWQ0B10qeFSFmDRp6oqxriuMcKAID4ZUWba0GU6Bw8bWbHdntrS+iX/4VhJuTyEsSVJYtApJYVqSxsYrNGrHl+S6l81OcwtBwKLJhayu7+C5RxtwHEm56qM7aNGdjNPYFmFAWX6/TEjcKx2D4zhkMpn+NsPFZa9lQImfC08cy93PLNtmtYq/1kciIkg6W1b3JAYIli9syHUsF2LQY6d5XmukJBlA9ys0tUdIek0qq4JkWjIUWx6iIoPlh9XtXeT5PZx81Aief2M1dtqh0hOgO51m9uNLAMGE4ZVceMkkBk0s4X///jJp06arO44iFBQB/kIPiZTJiZOH8sayDdmqo5RgWqwS86/drNB68A/xkmk2sRM2GzIx/ilWIAW5Duvei/Sm+QiPTyOQ0UhZFo4i8aGBDR1aJluGikOHmaRbMwGB4mSdVUxYDBJeIl1p1q/ooq66aJs7s0Wvr+PeBR+AKqhQfGzQY0QwEdKi00kTcgzOVAZT0vrZJXZT/SMn46AYCom1SazxHpxXFary8nITFeOfWli2028TEvc6x5DJZFizZg2O4/S3KS4uezWjqjRmXXoo4bRKeXFw61Lam+0sGtsiSAnRhgRtz7blOpZJS/JtnXWZGHd2foiwQUHgSIWox6ZwqJ+Onjj+tIHh1UhnbISAcCxNpD1JUUwn6aSIkaRZJPnDva+T5/dwzIGDOWPaaL53+iRmP76Ejm6wnOxr1zR1oyqC/DwPt147g/UrukjM6cSMW8xPNiAth7qmIIMKQngHemj/JEEyYFHpCyAcNnZYp2ntiuXyEa888DFzXllGmenBcHyEVRP0bG9AnqWBgC4lQ4eaQQADQnm0dydACCzpEFYzeC2VQlvf6vnr6ElgpAQtj7TTk0pQho+UbRNXLRQUKiwPJhJdVxkVKOojM9K78+mdbd0bstOO85AX9PSZqFhRnMe15x2Goau5UamJtcndLp7Xy17lGKSUNDc3o6oqAwcORFG2PobQxeW/HSkliUSCtrY2BpcVUFm54/ncH37aRjSRJs9n8Kcn3mZ8Mh+/rhN20oQ8HjqsNElpE0hplDgeIoZFKm2TsSwa0xlUXUFxFPJ8HmorsxfJBW9+ihOxCQuJV9doziQREgyhsqE1zJynlvLSkjVccvIB/PW6k/jbY4t5/OWPAHJTzZ5/YzXHHzKUCYWl/C22iv+whp5ANmIQsnVOTQ5iRmwQBY6OV6r0OGkKdO9G1VdPLsRSafnofiNMwjEpwYMfDa+l0qAkQEC17UcPaBRaJi0k8RcZ5AW8yB6HVpnMlqk6ghO8NQwbWbbF+VvX0L2xi7qCYd58/IZOOJNBOBJTddBRyJM6HlQ61AyRPBu70ybTniG6LJprCDQ7LfRCDd9+WfkP48U0Z500igcXreizQzjqgMG5irBtjUrdXexVjsGyLBKJBFVVVfj9/v42x8Vlr8bny64e29raKCsrQ1XVrT7v9KmjKSkI8L+zX6Ygz8uAsnza2mIsEh2MlCHelV1EzSiqquBHo0z3oRkqBRmVtniSc6eMZOhhFblxlyUF/lxYZW1PFxNlMR/qYdrsJBIoxkNbOE62iVcSjmXDS3+9ropvTBnJG8s2UBzy4zU0fB6d9a09LP24mfgncR6T6wgLExWBkIKIYvGMt4ExVgkD7ADHpiqZ72ulJZ0dzpOb2wD8Z+5yHjfXEVFMoopFme1BtxW8tooQgohiEkorZHSH8vwAx47bj5fq16Pkq5RHfEyUxRzrG8iB5wzuszI/fepoaho9fPxsM8GwQmm3ga/Gw9fyB/F0ZB1hJ42CwC9VDFTCuolP1ciPqah+FSfj5MpatQKdTLuJGbHwpJ2c/MeJ++3HIZMHsX5FV7aXo65sh6NSdyd7lWOw7WwE0DB232QiF5d9id4FlGma23QMkF2dCwUGlOWjKIKysjyWdURZkurEktmw7ZDSQta29xDRLIJpCFtpDCkIPW1SV+WlfOJnYRWfR6O9J45mqBwbGMg0qqkPxni4s54wGZIZK9dN3NEdpzuS5D/zlnPGtNEUBn3YtsTnyYZN0mmLv/7zTSLRNN0iA1LidTSkAEdIUorNR+keSoo8jJRF7C+LCfsshp9QSfHkYt5Ytp51zT387fWlmMKi2PLQpWRoVVMUOgajMiFQod4To1lJYHg0Dk0Uc9SrBYzweGGKL6c8u7VZB4m1SYwX04yyQhCEVHeKVEOGo0ZVUqfn0a1laD3Q4aVP1tMTTaMnFI43q6j25lF5ZhmKoeTKWp2Ug6ILHFPiJG3suJ0rGc57N0rhQynsRJxV/iihScE+r0MRmD3mbh3p2cte5Rh6EUL0twkuLl8Jdva3srVcQ8KxKCwPImzJhp4Yb3W3EJAqatoi6Zh4pMKxsUpKbZ11dzYy+i8juODEcfzfA2+xan0cgNICPy0HOBzwXpDSBp0mu4RHA+uRm5hlOxKhSBa8s4ZDxgzksLEDWfDOGta39qAqCnbcQYYFxdIgrGUwBaSxUYQCAoRf4YX8FhxF4vfonDFuBGccO4Fn6+u5/ndP0dIRI5bMZD8H0FRBkW0QExYJ1eb1QDsAulTQHQWZhLeUNpSgwpBMkOJXYPD0wm1ebDPtGdKtaZyUg3QAIXBMh3RThuqiPCZtDO+csrGMtjcnsGkvyKYjT9V8FdltY/bY6CGNyjPLSDWm2DCnGaGR2x10vxZGqILEpwnsiI1jSoQiiHwQy1U67S72Ssfg4uLy5bL50HkpIc9nUFzsZ8WadjRdwTZtvKgoNpwYG5CVsrb9CK/A7DRZ/moDVGU7hKtK8ykr9JNIWTzR9CkTzpyMOsdmpFJEsdNGyrbowQTI7RwaWyP88s/zUTQF3aty4Mgq8hydp9d/RL7tRUFQbnlp1pNYAlRVUhD04vFq+PIMSgr8tLXFeODNDwmZOre+vZj2aALT/EzrCAG2kHQpGaQjEVLk5C2SwsbEoUr66SDNg+HVFCge8hyNjrkKF14yaavnzsk42HEHkAivAilJkyeJcZTOkClFlB/8WT5iawUAm488NQoNKk8rIDgmiFFqEF0W5dPfryfdlEYYAkUV6KUGybVJfLVekotT2UPTBXq+RteCbkqOKXJHe7q4uHxxNu0kzpg2f7j3Ddq6E9iORBFkJSEcnYhiUmJ7cvMNpCN5xdvKqy+tJEyGznCCwVWF5Pk9+L0G61t76EwnKRJQmhcgL6KDAsLJNmspArAlCcskldaoUv00+1I8ufBjgoZBWGawVYcBlh8dhQrTx+HpMkadNZDA0EAur2G2ZdDX27TZSeY9/DFtgRiKKhDZoqMsMuuIbLLznh1kVgxPOEhACgjLDDErgyMkeSkFR5U8uHglh8+o2+qFXTEU1LzsZDyZlrzia2WerwVnpUKwxcsFsR3LVWxtVCd8JqshVFAMQSNxult7KOnxUh7x4qSTIEEv1fBWeVE8yk7JmHxR3LKfPcDLL7+MEIKenp7+NuVLYV87ns2pra3lj3/84257/1/+8peMHz8+d/tb3/oWJ5988m77vE2pqy7isLE1HHXAYC44cRy6pmDbDpYtqcgPkHYcvFKhwNmY55PQJBLMD7ag+BSqy/IRQrCupYdYIp1rvqqqCWGnHQo/ganhckRGImS241hVFIQUCCBfN8jg0BNLYduSisI8glIjolo06Ukgu1s5RanlGwcMZ8LwSgJeg7a2GImGFGErjReVPLFxTetA9lOy6LqCrimU4KVAeHAExBWbzEZjLCTtpEjhoEkFw1HJNzXCLYnsRLWtYJQaeMoMPBUGnZUm8/wtoMLAshBSwj3PvE99Q9cOz72/1pcLAfUsDufKV+2EjafSw+tlnfw1uIo5vtXcJlbyWlE73hoPQhVYXRbS3rqMye7AdQwuuwUhBI8//vge+7zdfTHfV6hv6OKNZeupb+ji9Kmjuf0nJ/GtkyYwqDKU3TmogmMzVVSR3S2gQKzIwS7IJqyDAQ+DqkI4jmRDaxgh4IITxzG4vJBsukNwZKqc8+N1VOBjYGk+w8uLKMJAFwopbDKKg4WDoSpIIISHgKNybKySy7uGcWSmHKNIxyg1ciEwLEmLk0QgOM6u4iBRRsjWsxpEm+QzpISSgI8zxWCOKxiYPYbN0jCOkKCAx1EwFIWIauJFhVeSJNYmtzhnvaEgJ+nQ3BojaVsEHR0nZlNS4CeeyrD04+bced0erU+2sep/6qmftZZV/1NP5IMYql9lbUcPL4hG0ARlig+pwlxvMy16Cm+1gXTIhpqE2KW5GZ8XN5S0j5LJZPb66q6vgo37EttSY/3pt47kzGmjcw1mFT4vapWCGbEQisK4b5eT/3JzLnFtqBq1VQVccvKBTBheSV11ET2LwyiGQmCUH0zJZD1Aot3hJa2dhG2RpxjsLwpZLxKEzWx5p6oKPm3pIqPYKIrA1iUDzABIKDw8lNNwmjC8ipHfKeKdm1cR6IEqAjQpcQ6hlCX+LggpeLw6B48ZwKSR1YzMK8S8rYtlmU6KVS/Ykk6Rwu/TyViSEssgIk18qLSrabxS5cRgDRVJ7zZDNMGxQVSfSrkawK/qRB0TpUmQJkM6bTH78XewbCc3te3E/fbbosJpa+WnXQu6KT6mgA9e7CKRMSlXfXjLDZQOQauZpNNKUabn4xvoZcAFFQTH7P5SVdiHdwyJtcncdm13k06nueqqqygrK8Pr9XL44YezePHiLZ73+uuvM3bsWLxeL4cccgjLly/PPbZu3TpOOukkCgsLCQQC7L///jz77LO5x5cvX86MGTPIy8ujvLyc888/n46OjtzjRx11FFdccQXXXHMNJSUlHH/88Zx77rmcddZZfWwwTZOSkhLuueceICs/MmvWLAYPHozP52PcuHE8/PDDfV7z7LPPMmzYMHw+H0cffTRr167d7vmora0F4JRTTkEIkbvdG0L5+9//zuDBg/F6vQD09PRw8cUXU1paSn5+Pscccwzvv/9+7v3q6+v5xje+QXl5OXl5eUyaNIl58+b1OfZ169bx/e9/HyFEn0qd1157jSOOOAKfz8fAgQO56qqriMfjucfb2to46aST8Pl8DB48mHvvvXe7x9bLP//5T/bff388Hg+VlZVcccUVucd2dDw74uGHH2bMmDH4fD6Ki4uZNm1aH5t3lk13B5tr/mweAqmrLuLo44Zw4DmDUT0qdtxBD+oM/HYlE79eywUnjkMIWN/agxBwyckHcPrU/XMxeaPUyNbsJx3UfA0n6TAtOJCbvzON7519MOcevj+nevfjSnskV/hGc+rooWTsrCy2jkI+OktC3XSUmfgGenmjoovv/+E5rr9jPt//w3OsjHUx/cJR1OSHeFxfz+8Cy3nN14YaVPnG0SP5x/Un87srjuf0qfuz/8FVVJ5ZRrHiJc/WMISKR9fJ2BJNE+ghnVLh45vR/fh2bAjf94/maKq2G6LJtGeQtqSuppiTCmpRNIVWO0k6ZSIUgaFp1JQXkOk2mXP/Ehbe+CGr/qee1ifbct/DqpVZ6XK9SM+NMLUTNsExQSZ+fwgFlX7SVQqeai+JAolPaOR1ZP+eB5xfQflJu3+n0Ms+uWPYVD9+T3QL/vjHP+aRRx7h7rvvZtCgQdx8880cf/zxrF69mqKiz5JZP/rRj/i///s/Kioq+NnPfsZJJ53EqlWr0HWdmTNnkslkWLhwIYFAgBUrVpCXl+3o7Onp4ZhjjuHiiy/m1ltvJZlMct1113HmmWeyYMGC3PvffffdXH755bz++usArF69mjPOOINYLJZ7rxdeeIFEIsEpp5wCwKxZs/j3v//NHXfcwdChQ1m4cCHf/OY3KS0tZcqUKWzYsIFTTz2VmTNncumll/LOO+/wgx/8YLvnY/HixZSVlTFnzhymT5/ep75+9erVPPLIIzz66KO5+8844wx8Ph/PPfccoVCIO++8k6lTp7Jq1SqKioqIxWKccMIJ/Pa3v8Xj8XDPPfdw0kkn8fHHH1NTU8Ojjz7KuHHjuPTSS7nkkktyn1VfX8/06dP5zW9+wz//+U/a29u54ooruOKKK5gzZw6Qje83NTXx0ksvoes6V111FW1tbds9vttvv51rr72Wm266iRkzZhAOh3PnfGeOZ3s0NzdzzjnncPPNN3PKKacQjUZ59dVXkbns6s6x+e7gsLEDt6ti2su2kqTbk8CGbLil6JhC2p7qwIqkcmWYr8bacnb4irVcqWldpJ3XbmumOORHiTjQbtNqJYn4bdYfYTN77lJUCQNK8unOpPnbY0vglAP5YGoHj76yHltmcwbxpM1jL6+kxhfkI7sJf4mXmlFF1H29LCfi95/3PyIVkcSSGfxeg2Cxl7NOHMVhLUV0vxZG2nKHIZpex2d2mUwtqqYume1fUI8L8o9X3qOkwI/VY+HrFLRhESuXyITk3/9eyksvtpF0LHyKxtFaGcd0VfVRWDVKDfavDXHi+uE8vGAFK9e24/fofP3EkRw5fv+t9lbsbvY5x7CnuwXj8Ti33347d911FzNmzABg9uzZzJ07l3/84x/86Ec/yj33hhtu4NhjjwWyF/Hq6moee+wxzjzzTNavX89pp53GmDFjANhvv/1yr/vzn//MhAkTuPHGG3P3/fOf/2TgwIGsWrWKYcOGATB06FBuvvnm3HPq6uoIBAI89thjnH/++QDcd999fP3rXycYDJJOp7nxxhuZN28ehx56aO5zX3vtNe68806mTJnC7bffTl1dHbfccgsAw4cP54MPPuB3v/vdNs9JaWkpAAUFBVRUVPR5LJPJcM899+Se89prr/H222/T1taGx+MB4Pe//z2PP/44Dz/8MJdeeinjxo1j3Lhxuff49a9/zWOPPcaTTz7JFVdcQVFREaqqEgwG+3zerFmzOO+887jmmmty5+dPf/pT7rjWr1/Pc889x9tvv82kSdlSxX/84x+MHDlym8cG8Jvf/IYf/OAHXH311bn7el+/M8ezPZqbm7Esi1NPPZVBgwYB5P4mdpatKYIueGcNmqpsU421vqGLpR83A9khOHWTtnRg2yrHhOxirGtBN9JyEJpC8TEFxCZq3POHrB0DgkE6euL85/2POHxGHaGkRr5iYCZtygbk0abHKLD8dB6oMvuVd2iKxNAR2J0War5KQzzGzfe8Rnc0iSUlqiKQUmJZDq1dcX5970IcJB5UCkI+zv76GL53xsFceMkkDm+oy1ViGbrax7GVfyO5hRPcGpuXnFb7s/0LsYkaDyxaQfPaML4O6DHTeIRCXoegyRfn2eR6PKZBTVX2e5iX18yIZAEVjd7cotVf6+Ph+ct5/s3VdEeSxFMmGZ/NgpVrqd4vxOmT9tyAnl72Ocew6fCM3u3a7izvqq+vxzRNJk+enLtP13UOOuggVq5c2ee5vRdfgKKiIoYPH557zlVXXcXll1/Oiy++yLRp0zjttNMYO3YsAO+//z4vvfRSbtW/+ef3OoYDDjigz2OapnHmmWdy7733cv755xOPx3niiSd44IEHgOzqPZFI5JxVL5lMhgkTJgCwcuVKDj744G0ex64yaNCgnFPoPbZYLEZxcXGf5yWTSerr6wGIxWL88pe/5JlnnsldOJPJJOvXr9/uZ73//vssW7asT3hISonjOKxZs4ZVq1ahaVqf8zZixAgKCgq2+Z5tbW00NTUxderUbX7mjo5ne4wbN46pU6cyZswYjj/+eI477jhOP/10CgsLd/jaXralCDrtoDre3Khiuqli58Pzl/N/D7xFa2ccpKQ05Of75x+23RLMTUeKVlq+3GLMV5vV/+lc0EN3dYp4KkM5PhJrEhiWpFmJ8uCNixnXXcDRiVKeF42siaTJL/Ux/aghPPvKKmTUyU5gQ9LsJHB6QNUVCkM+OsMJIPs9KorAsrM7KRuJgySKSSJs8acHFoGA751+8HYdmr/Wt9PXha3tpsqBsw4exT///Q4R28KDwrRoBUWtKiv8YZL5FqV24LPvId2D/+xi6gpLc+/R68hT6ayiqiIEGdMilbb2+ICeXvY5x7Dplm/z7drezMUXX8zxxx/PM888w4svvsisWbO45ZZbuPLKK4nFYpx00klbXaVXVlbm/h8IBLZ4/LzzzmPKlCm0tbUxd+5cfD4f06dPB7IXXIBnnnmGAQMG9Hld72r3y2ZzG2OxGJWVlbz88stbPLf3Av3DH/6QuXPn8vvf/54hQ4bg8/k4/fTTdyjNHovF+O53v8tVV121xWM1NTWsWrVql+3v1Sfa3mfu6Hi2h6qqzJ07lzfeeIMXX3yR2267jZ///OcsWrSIwYMH75SN25rVcOa00Zw5bXSfcFB9QxezH19Ca3sMHImCoKMrwV/vXrTNC9LmYarTRg5jdMLoM4Usr0NQYwfxKRot6yIETZ1GNUHEMXl87Wrm6wYnFdZyTrKOhlScQ6YNIVjt5z/PLqdEelF1hTYrSUpaCASDCoMU5nlRVYHtSBwJzkanoPJZ70L2tsBxHB6et4LjDxmaO4ZN5zo0a8mdnqG8+VS7TXsQMu0ZjkyUYnQNpccwKbA0KhNZmZJCDHyqRntHHKPYoDuTJuA1qBlVREH1Z53LvY486PdgOxK/VyOVsfF5dWLJ9B4d0NPLPucYNt/ybbpd2x3U1dVhGAavv/56butvmiaLFy/OhTB6eeutt6ipqQGgu7ubVatW9QlbDBw4kMsuu4zLLruMn/70p8yePZsrr7ySiRMn8sgjj1BbW4um7dpXdthhhzFw4EAefPBBnnvuOc444wx0PSspPGrUKDweD+vXr2fKlClbff3IkSN58skntziOHaHrek77antMnDiRlpYWNE3LJak35/XXX+db3/pWLi8Si8W2SIAbhrHF502cOJEVK1YwZMiQrb7viBEjsCyLJUuW5EJBH3/88Xb7M4LBILW1tcyfP5+jjz76cx3PjhBCMHnyZCZPnswvfvELBg0axGOPPca11167U6/fvMt5cz3/PsPsu2K0tMfIOA4KIJGoCCLhz2YSbMrWwlT/ef8jSjzD+KilOTeFzCc0vh3xcUrtEO6t/4BmNUFEMcm3NSpNHzHd5r7wJ/gUDct0ePuJLk48djiBgEGkO4XPVAmg4pEKXqHi8Wisa+4mY34mx9/bIxF0VKJ8ps2UwcFQVEzbprUrRqXlo/WJtlw+4WWthXl5zWS8cofzlLeVr9z0fifjUJnxMUDxI4SCvXHqw+CyAk7Kr+WprrVsaAsTLPRuda5CryNPJE1URZBIWWiqIJky9/iAnl72OccA206g7Q4CgQCXX345P/rRjygqKqKmpoabb76ZRCLBRRdd1Oe5//u//0txcTHl5eX8/Oc/p6SkJNfYdM011zBjxgyGDRtGd3c3L730Us5pzJw5k9mzZ3POOefw4x//mKKiIlavXs0DDzzA3//+9+2KpwGce+653HHHHaxatYqXXnopd38wGOSHP/wh3//+93Ech8MPPzyXSM3Pz+fCCy/ksssu45ZbbuFHP/oRF198MUuWLOGuu+7a4XnpvXhOnjwZj8ezzVDItGnTOPTQQzn55JO5+eabGTZsGE1NTTzzzDOccsopHHjggQwdOpRHH32Uk046CSEE119//RbzOmpra1m4cCFnn302Ho+HkpISrrvuOg455BCuuOIKLr744lxSf+7cufz5z39m+PDhTJ8+ne9+97vcfvvtaJrGNddcs8NdwS9/+Usuu+wyysrKmDFjBtFolNdff50rr7xyp45neyxatIj58+dz3HHHUVZWxqJFi2hvb99h3mNzdpQs7iVj2qQyFvCZdIWFRJMiN5NgU7YVpvpwZJzHl6zFlpJ8RcfKFzy4aAX/M+EgLo8M4z1fN3O9TVQ6PhQEhqPQLTOojkKl6iOtCZ5/YzUnTBnG3Q+8S5cdAwkhx2C4k099OEFLJI4APLqK7WSt/fqUEby3tJGe7nAfO23Hwe/V0d5L89FTn5DckEIogs4qk+cyG5BdksLBeXQmksx+fMlWd0fbylfqxXqf+9MtaYQikCZIYWf1nTSBXqgzJVXB0EA+2rFBygsDDKvbsghmU0fuNTQsO5sk93q0PT6gp5d90jHArsUOvyg33XQTjuNw/vnnE41GOfDAA3nhhRe2uBjedNNNXH311XzyySeMHz+ep556KlfHb9s2M2fOpKGhgfz8fKZPn86tt94KQFVVFa+//jrXXXcdxx13HOl0mkGDBjF9+vSdmllx3nnn8dvf/pZBgwb1yYVANpFbWlrKrFmz+PTTTykoKGDixIn87Gc/A7Ihl0ceeYTvf//73HbbbRx00EHceOONfOc739nuZ95yyy1ce+21zJ49mwEDBmyzxFUIwbPPPsvPf/5zvv3tb9Pe3k5FRQVHHnkk5eXlAPzhD3/gO9/5Docddljugh+JRPq8z//+7//y3e9+l7q6OtLpNFJKxo4dyyuvvMLPf/5zjjjiCKSU1NXV9SnhnTNnDhdffDFTpkyhvLyc3/zmN1x//fXbPbYLL7yQVCrFrbfeyg9/+ENKSko4/fTTd/p4tkd+fj4LFy7kj3/8I5FIhEGDBnHLLbfkCht2he3F1nsxdJWgz8CKpthEcYhKxZ+bSbApWwtTpdMWT234lBaSICRdIoU3oxPrMFltxEkVOAyI+cjTdSLCxKOrtIsUEodCYeCv8hIqy0prFDgePKZCse3BL1USwqZeiTK0K59GLYoPFc1SEIYgbluMqC3h0DEDueWe1xA2dCVTSAmOlJT5/bz29BrqMgFKVQMUSWtXglTIRrXho4aObG7Ckfxn3nJ+8q0j+xzrtvKViTXJPvd7KjxYYRvFEEgnKyEiVEGmzURKSXV5APsxC9vuYZU/SuY4D9Z4Tx+HvblcyeZJ8j2NkLtaB/cFiUQihEIhwuEw+fn5fR5LpVKsWbOmT427i4vLtvmiv5n6hi6+97unWL2uk00DcSU+Lw/ecvYOcwyqopBMmyiKwvqWHpCgKAJVVbIXxbJ8ZNxBjUCN5WO5GiasZLLqqxJKQ36G71dKR08CIeCMUcO4/YklqDZ0qmksshpH41OFLPP2IAV4UEjhIDT41XeP4aD9q7n8pqdI9mQwotAhU0QxNzY9CwqFh9NiNRyZKaeROH8q/JhWkugeFaEKbNthYHmI239yUp/jTaxNsup/6pFSohfprO3ooVtm2P/cGpSHYrn7zS4TIQQ1lw9AMRSMUoPOBZ0svn8NHckEBabBAAJ4B3l4WTbzRGYdZgEEg14uPeWAHeosfVls79q7OfvsjsHFxWXH1FUXMX5YJavWdWYvpAJ0VSVqmSz9uHmrjmHC8Co21Zm4/ZG3yfN5aNZULMvGkRKNbIIYBIOHFNPWFmNDKo0fD3m6l9KCAA0tYbqiST5Z20FRoZ8LThzHyLwitCffpUVJoshsItkGmtQkY9MFvO/pIS6y+QS/onP/Cx/w3qpmwuEUHZFsxZKDzO19BJIumeKRwHryLY1x6SIOUIp5lgakyHb4DqooyOUjehPyuYqrjfnK59ev4XnRiBWE/Jc38I3x+3HAe8E+ecyiydkIQWJtkgefWs6z2npS+TYeR+HYeCXDWkI8UPgpYZlBjSn0JNL88b43+6XqaEe4jsHF5b+cSaMG8OhLK1AVZWOM28a0tj5zffOKpOmHDSHgNUimTAxNycorKYJgwEM4mqKs0L9xRyHoSaTRDZURNaWEG+MEehTSGzWSZhw9nIOmDgXgyDGDeHDZSqQUKAjKLANHwHHpKsaahTzm34ChqgyrK6WpO8qj81f2yjr1cQpZpyKxgU6Z4t+htYiRPi459TBW/GsupuUQ9OtEEya6plBelLfF8Z118CiGHp/H/Jfa8Pg8DCzLo6MnwRNNn3LIlUdTu5XhPqtWtvGcuR6JpNTxEiHD3EAz4bRJj0yjoeAzNDLSob0nsU0H3J/ss5IYLi4uO8eE4ZVUFGcrX9KmhWVLyooCTBhe2ed59Q1d/O2xJUQTGUpCfqSE599YzfRDh+D1aPi9BooiyPMZFAa9lBb4aWiP8MFHLXy0roNwPEW6x2TFhy181NLJWidKDIuMaWG8mM7J13z78oOorSqgrCDAkKICdFXFg0IopVOe8uJ1VAYV5+PEbMzWDKbjgCPxSQ1lk52M3Rsll6AKgSeo8ZzZgHdANoRjmhYfr+ukqT1CMm3ywpuf9Km4yslbPLKaaFeKkNRzCfd4KkPYZ1EwKbRFLnPtsk6Sjk2+paM4kO/opIVDXFiAQGjZf+zZKP4usUs7hlmzZvHoo4/y0Ucf4fP5OOyww/jd737H8OHDd5d9Li4uu5m66iKuPvsQZj++hGg8QzBgcMnJB2yxin1o3nLWNfegCEF7Z4yqoiC2Khk/vJLjDx26ReL0hTc/4U8PLMK2bHQUAqqBZTt0pbLFAboUBKTOm1YbB7aXULuxCbWuuojvnjmJe555n0hXCsWBSekSwgEL03TwohLGxN9kkZDZzIiCyJXammQnuW06vCeEgS+uEItm+wImDK8i4DfQdZXSggDJtMXDC1ZgWjZDqouRKQd/j6BVWuhFOt5uldamKAOCWq4fYWtlpIm1SfT3THyKRkQ1ybez8y18isrhk2tZuiFCZyxJImUiJVt1wHsDu+QYXnnlFWbOnMmkSZOwLIuf/exnHHfccaxYsWKrzVUuLi5fDXZU3lrf0MXLS9YgHHBsBxtY09zDwIJg7vmbxucBxg+vpDjgxdej4PVoeIXKWhklYKsUmx4MFDyKShspPs704P+kkSGVNnXVRTl7Pn2zlQX/WMkibwcviVZUn6BG+gk7klY7iV/XCFoaGRwyOAhVENINgrpBJJoiRrZBLopJxDEpSfkpL8qjtSuGZTvUVhaiKIKAz6CnIYWuqnT0JAih02Nn8Bs6I7yFyAK5RT8CwBvL1vc5X5n2DCWdOtPsCuYazbTr2fkR5x49hrN/eDDa/MAOHfDewC45hueff77P7bvuuouysjKWLFnCkUceuY1Xubi4fBXYrhZSVwwzZROwVbrJ0JuBCEU0Kq3sXOP7H36Pe5etICksgkEvR0yoQTdU0sIi39Tp1tLojkAIlZTqELR1wtLEVBye8Tfw9PPNGK9qnH7MKL53RlbKIlWTYrG3i6hjEcPEwqGLNKdUDGVE2E8RHj4tjPNo96ckhE1hmY/vnjmJkXlFvHDLcv6dWpUN4WwcGiQ2tvxsXnbb1hYjX9E59oA6FqxcS1M0hqIIposBVGS8pLr9nKANpHJ6OQdPHsTSj5v4/h+e20LC3Mk42DGbKZQzjBCdmRSFjsHhG7XPdra/pL/5QsnncDjbVLI9xch0Ok06nc7d3rz+3MXFZe+nvCgPxRFEsdA3piYdoMNJsfi+errfCHO7s5SIYiEEtPckqG/owu/VSQuLqGOiZ7IS0o4BbekknWqKoDCwpSSKRSaRwYpLbnvoM52jlbFuejwZoskMKgIvKinhsPCjDRwU35/imEapv5Ch5eNhio/ApCAdPQle2dBA9zAH/QOV/aQfW3EIlHqJ6CatXTEOG1uTaypbs7oTLQoHyxKK59t854hRlB1RjPZeGh6M8Uz7p8zzNZPWHPJfaKE+2sNLS9aiKUqu+7tX06jYUFEDCk7KoSLmpdz2gIT1tzcQXR6j+oIq6mp33F/S33xux+A4Dtdccw2TJ09m9Oht1+HOmjWLX/3qV5/3Y1xcXPYC6qqLmDJ2EPfMX5aVohAK5dKDjaT+9VZaownCIRPNEShSkMYBAamMhaIK8Al8Hg/BgIeuRAIzLTGRpGUqlwtQLIHXULEsyUNPf4DZZfLMsnrCmQwmDn5dRQqBnhGkpMU7TjvjKWRAPMCIA8tZOjTGTXfMp6k9iuNkRfYURaDkKQytKs7mBsRnuYHTp45mv3gey/65hk8Is0jt4OVEC94XNb5TcgCnHDmC+U+8x3y1BaEplDseNnTGswlqwGuoqJqgoiiYkzCvLC3FU+7BjJiYHSbSARwwOy3anuig+40wtd+r3q1jAL4MPndV0syZM1m+fHlOqXNb/PSnPyUcDuf+bdiw4fN+pIuLSz9y7mnjGVgQpFh4GCTz0BUFv6ER7FKRjgS5UcxOfFZtYygKqqoQTWaIWSaKR6G1O5EtLxWbJIjJdgwnUxaKBZGuFA8+sxwlLjfOmYakme2REBJi0mKut5nbC1bxitHCshc2cOdD79DaFUdKiRDZ7mcJdCdTrOnqyY0h7V2ttz7ZhjMnTKBN8Ga6FTtpU5Lx4GRs7nnyPVatbKPTTpHWHAo1D6YuickMSImuKVi2ZENLmMa2SC4Z3avVJlQFx5LZbVVvLS1gdVs0/qtljwwQ+yJ8LsdwxRVX8PTTT/PSSy9RXV293ed6PB7y8/P7/HP5Ymw+33hPz1fuZfOh9l82a9euRQjBe++9B8DLL7+MEGK7Incuu4+66iK+d+HBFA3MI1Us8ZR5ON6upkr6GZIJkudomMIhLTZmICTYjiSVNrEdSTSRZk1jF44jEYqATSbtbXz6Rkch8Wk6NtnKoNKAn/KirHS1pilkcPA7KlVWtkx0bqCZj1LdRCKp7DuI7E5BCIEiID/g5YITx3PrtTNyXcaJtUka/9VCQybGUm8XUWGRb2eDZPnSyFYvdccp9fnxOirdTppkxsICPIZGRX4ATQjSGZtM2ua0kcOo3GhP+dfL2O+HNRjF+mdX2I3OQQqJFbfJtG9fGbi/2aVQkpSSK6+8kscee4yXX355p2WAXXYvzc3NO63X/8tf/pLHH388d7F1cdkVNk2e+hsl9uweRA2sbmslIxzsTa/1AtJWtpzUo6uoiiCWNAFwHImuCrbWRmfiMMlXyofpbtZmoiTW9mCTnbJmI3EEpBSbbiVDoWPQrqVBCPIMne5MGqSDI7NtAlIRBHw6xxy4X19V2SfaeL59HfN8zcS8JmHFRKqSATJAzGPhlSrlhQEqzylhxr97eDa1nqiwUFVBnqpT2KVh2gaOdDinpYbRzxmseqU+p75aNLmQijMSbJjdiMxs3EppoCgKWmDvHwOwS45h5syZ3HfffTzxxBMEg0FaWloACIVCO1SkdOlLJpPJCeh9UTafkubisjvprV5K5CdZ5Y/SYMd4qqCRpG2jbKz+2bSHwFBUNFUhljL7vI9pSxQhsuGhz54OwGAjn9ZEnNWEkdZnYSfLEngMDStt066lsG2JV6qMzCui5oRq7pi3hKb2aE59VUowTZulHzcB2eqqUFLj04VNzPM1I4FKx4cjJRHVQlWTBIXBDM9Aho3MyvVfPvZIpq5so1s1eX9dK48+vZz1MoZf1Tixp5ox6RDaqOyc602nRdZ8ZwACSeN9rVjRbNmsXqQx4PyKPT6qc1fZpVDS7bffTjgc5qijjqKysjL378EHH9xd9n1uNh2Evrs56qijcrOEQ6EQJSUlXH/99X3m9NbW1vLrX/+aCy64gPz8/NyIxy9jWP3moaSGhgbOOeccioqKCAQCHHjggSxatIi77rqLX/3qV7z//vsIkd1q90po78wA+5tuuony8nKCwSAXXXQRqVRqh+fmww8/5Gtf+xr5+fkEg0GOOOKIPpPM/v73vzNy5Ei8Xi8jRozgr3/9606dc4B169Zx0kknUVhYSCAQYP/99+fZZ5/d6de7fDF64+nzM020OAkcAY4CtgJSgYDQKLANAhl1C6cA2YvPOFGIhkAh6xQcwAbe7GxmnRNHBXweFVVVNoamHBQVpCJJKw5SgxO8NRz63aGcd9YE7rrhVH74zcmUFwWoLs3ngBGVFOb7+b8H3uLym57i+jvm8+N/zmOe2UjacAiho6AwwPZTgM50qvm+bwzf/OaE3MXbX+tj/IxBHH3cEAoxstEqdaOnEtkZFphZQT070TdMNPA71Yz9+yiG/s9ghvx8MPv/ecRen3iGzxFK+iqwud7J9gZxfFncfffdXHTRRbz99tu88847XHrppdTU1PQZTv/73/+eX/ziF9xwww3A7hlWH4vFmDJlCgMGDODJJ5+koqKCd999F8dxOOuss1i+fDnPP/888+bNA7K7PdjxAPuHHnqIX/7yl/zlL3/h8MMP51//+hd/+tOf+sym3pzGxkaOPPJIjjrqKBYsWEB+fj6vv/46lpXV/7/33nv5xS9+kZtpvXTpUi655BICgQAXXnjhDs/5zJkzyWQyLFy4MDdrYWvjT112HysHxFnobUVudt2XgMdWmJqu4HlP8zZfP1orYr0Vp9NJ97n/I18kGzZKQSpj597TsmUuHAUwaL9Cvvf9KbkRma1dMUoLA+T5jdzMCClh1fo4VaX51FYW0NYWY6nSiSoFUZ9NvqUREzYl5UFOOWVcbqewOfUNXfzn/Y/QFYUS6SWsmMz1NDPUzGeoHtjmtMg9OQLgy2KfE9Hb2oSpPTE3deDAgdx6660IIRg+fDgffPABt956ax/HcMwxx/CDH/wgd/viiy/+0ofV33fffbS3t7N48eJcf8mmE8zy8vLQNK1P+GlnBtj/8Y9/5KKLLsoNH/rNb37DvHnztrtr+Mtf/kIoFOKBBx7ITY3rnU8NcMMNN3DLLbdw6qmnAjB48GBWrFjBnXfeuVOOYf369Zx22mmMGTMGYLtOyuXLp3dWdHds6xU2dWY+BdKDJsVWHwcQPoUDrFJejDcA2ZCRrinEMiZSOihKdpTnttakSxtbebuzhY76eB8p8Ixp55rX2nuyO/CyQj+KIigryyMeSTMhUcQys5N2JU2wyMN3zprI+KmDtmlra1eMpGNRXhUk05Ih39Jp1ZJEQzZWl7Xbp0XuSfY5x7CtCVO7e27qIYccgtikyuLQQw/llltuwbbt3IS1zad37Y5h9e+99x4TJkzYbtPh5uzMAPuVK1dy2WWX9Xn80EMP7TMRbmu2HHHEETmnsCnxeJz6+nouuuiiPs7TsqzcLmZHXHXVVVx++eW8+OKLTJs2jdNOO42xY8fu1Gtdvhj1DV383wNv0doV3yivvQkSNASj0yHm+psJ6R6khC4+C7GoiqDIMXgj2kK557MLqZRg2xLLkRtlwDfTPdoM03J464MNvLFsA6m0RdDvIRZJY6dsUorJ+nQPhq5SWuAnkbLwb+x2zi/1cfFZh2B2mXSrJjWjdtx01tstHZU2hUP9dPTEKdIDHHT+CAZsRWX1q8w+5xi2NQi9P+ambs7melL9Max+a3zRAfafx5ZYLKunM3v2bA4++OA+j+1oVGkvF198MccffzzPPPMML774IrNmzeKWW27hyiuv/Nw2u+wcSz9upq0rjqEpaEKQ2DgeFEAVMEVUMGJSOc+vaqZM+ijSPOT502yIRCkvCVBbUUiqI8Palh66kilUsvkFCViORAE8qoqJxLa3LgEuyO4u8vO8NHdESWUsrIyDsCQGCqenBzP8mApGfK2apR83bTEDe/+Dq3bpmDcdwdkYjRIIfL73+SqwzzmGHQ1C310sWrSoz+233nqLoUOHbvcitzuG1Y8dO5a///3vdHV1bXXXYBgGtm33uW9nBtiPHDmSRYsWccEFF/Q5xu0xduxY7r77bkzT3GLXUF5eTlVVFZ9++innnXfedt9newwcOJDLLruMyy67jJ/+9KfMnj3bdQx7EiHwaAp2xsHEYYK3hJPyaxnTFUKdWkBh6hPSpkNJgR9vTOJNa+RpBh1tcRq6o5iKjQBCXg+JhJl1BEiK8WI4Ck0ygSTrAGzb6bM70VSFb0wZwajBpUTjGaQjMWxBGomNTV5KoXI+VE73UfclaRR9VbSOvij7nGOA/vny1q9fz7XXXst3v/td3n33XW677TZuueWW7b5mdwyrP+ecc7jxxhs5+eSTmTVrFpWVlSxdupSqqioOPfRQamtrWbNmDe+99x7V1dUEg8GdGmB/9dVX861vfYsDDzyQyZMnc++99/Lhhx9uN65/xRVXcNttt3H22Wfz05/+lFAoxFtvvcVBBx3E8OHD+dWvfsVVV11FKBRi+vTppNNp3nnnHbq7u7n22mt3eM6vueYaZsyYwbBhw+ju7uall17abv7F5ctjwvBKSgv8dEaS2Bsv1sV4uaRoFOVRD8IvGDayjG8ZEz5bYXsNpg0axPurW2h2Eht3CNlBOl2JNEXoqKpKj53Gp2kYlkBTFDRdYVhNMY6EdRu6qTPzGCTzGGsUc+Kg/XlncQs+SyHlWGSkRBXgkSoiKkmmU7Q+0cbgqwft1AzsneHLep+9mX12UE9ddRGHja3ZY1/gBRdcQDKZ5KCDDmLmzJlcffXVuZLUbdE7rH7VqlUcccQRTJgwgV/84hdUVX22NZ0zZw5VVVVMmTKFU089lUsvvZSysm2XuxmGwYsvvkhZWRknnHACY8aM4aabbsrtXE477TSmT5/O0UcfTWlpKffff39ugP2RRx7Jt7/9bYYNG8bZZ5/NunXrcgPszzrrLK6//np+/OMfc8ABB7Bu3Touv/zy7R5fcXExCxYsyFVKHXDAAcyePTu3e7j44ov5+9//zpw5cxgzZgxTpkzhrrvu2unGSdu2mTlzJiNHjmT69OkMGzZsl8pdXT4/ddVFXHPuoQwsD1GY72VAQZCzvXWUtukIIXJJ2NOnjubWa2fw68umMuuso7mopY6T9Vp0oWSrjjZ5zy5MbNvhKH8VhqMQxUQVgkK/l5Rp8cm6TpJpi06ZprYwxASthMZ/teDMjVMsvJRoPqotP0WWhyLbQyE6QhF0vxbe6yUo9jaE3MM1qNsbSP1FB5v3F0cddRTjx4/vI1Ph4rIn6O/fTJ/5yJaPTHtmm0nYnsVh6met5YOiML9texcTp09WWQGKbYOfWeMQukK3SLNaifCq0koLSRRVUGZ60Q0VBcEPSsZRtE4BIXijrINnYutJpE0MU3BsspKjZRWeCh1pQd1PaymYtHNFDfsq27v2bs4+GUpycXHZM2weVtleVY5RaqD6VZSoxIuKJZ0+1UYqAlOTrFaiHK1WMSgvn0lFVRS3+LgvU8/A8hBqi41jSdqUFG3dccryslIwU8wKRpQU0tIWJdAtqA2FMCoNnKSDYoi9XoJib2OfDSW5uLjsXfR2ShcrXsqklzy777rUlpI4Fk+KDSwwG9GLsqGgUcXFhKROMmWihlTCMoPHUihWvAw4v4IB51cghKC0TWe8v5Rxxw5EL9Sxuqw+YS2XncfdMXwJbK3M08XFZUvKv17G0WODtDzscN+rH4JMkJAWDqChUIEPXVF4QWlmVEcxtSUFlEc9HO8M4IXOJhpkCq/QOH3kUI6+fGzugh8cG+wTxkqsTW43rOWyfVzH4OLiskfx1/q46IeHMqashI+fbebDng7mqk2U4iNP0zEqDJqiMbrNDJWNaYQqOJpKRvmLiOTZ5MdUqhvztnjPTR3AV1GGYm9ir3QMXxVNJheX/sZxtt789VXgoAuGMvrIasasbGPZYzEQEn+Bn+5Mmnyvj4lnDWGAEiDdkqFhThO1JQUIRSC9knRjmkx7xr347yb2Kseg69lSt/b2dkpLS/tITLi4uHyGlJJMJkN7ezuKonxpEu57Gn+tj/G1g/iOMbFPv8OmHcWJtUlUv4rZZaIX6dsUq3P58tirylUhK5XQ0NDg7hpcXHYCv99PZWXlV9YxbMqmpa+b9x+1PtlG80Nt2Ak7J1b3VZCv3pvYlXLVvc4xQLZxyTS31G93cXH5DFVV0TTtv2Zn7SaUvxhf+T4GVVV3WkjNxcXlvwM3obzncPsYXFxcXFz64DoGFxcXF5c+uI7BxcXFxaUPezzH0JvrjkQie/qjXVxcXP5r6b3m7ky90R53DNFoFMgOWHFxcXFx2bNEo9Edjs/d4+WqjuPQ1NREMBj80svsIpEIAwcOZMOGDTssx9obce3vX1z7+5+v+jHszfZLKYlGo1RVVaEo288i7PEdg6IoVFdX79bPyM/P3+u+lF3Btb9/ce3vf77qx7C32r+jnUIvbvLZxcXFxaUPrmNwcXFxcenDPuUYPB4PN9xwAx6Pp79N+Vy49vcvrv39z1f9GL7q9veyx5PPLi4uLi57N/vUjsHFxcXF5YvjOgYXFxcXlz64jsHFxcXFpQ+uY3BxcXFx6YPrGFxcXFxc+rBPOoa1a9dy0UUXMXjwYHw+H3V1ddxwww1kMpn+Nm27/OUvf6G2thav18vBBx/M22+/3d8m7RSzZs1i0qRJBINBysrKOPnkk/n444/726zPzU033YQQgmuuuaa/TdlpGhsb+eY3v0lxcTE+n48xY8bwzjvv9LdZO4Vt21x//fV9fq+//vWv99rxvgsXLuSkk06iqqoKIQSPP/54n8ellPziF7+gsrISn8/HtGnT+OSTT/rH2M/JPukYPvroIxzH4c477+TDDz/k1ltv5Y477uBnP/tZf5u2TR588EGuvfZabrjhBt59913GjRvH8ccfT1tbW3+btkNeeeUVZs6cyVtvvcXcuXMxTZPjjjuOeDze36btMosXL+bOO+9k7Nix/W3KTtPd3c3kyZPRdZ3nnnuOFStWcMstt1BYWNjfpu0Uv/vd77j99tv585//zMqVK/nd737HzTffzG233dbfpm2VeDzOuHHj+Mtf/rLVx2+++Wb+9Kc/cccdd7Bo0SICgQDHH388qVRqD1v6BZD/Jdx8881y8ODB/W3GNjnooIPkzJkzc7dt25ZVVVVy1qxZ/WjV56OtrU0C8pVXXulvU3aJaDQqhw4dKufOnSunTJkir7766v42aae47rrr5OGHH97fZnxuTjzxRPmd73ynz32nnnqqPO+88/rJop0HkI899ljutuM4sqKiQv6///f/cvf19PRIj8cj77///n6w8POxT+4YtkY4HKaoqKi/zdgqmUyGJUuWMG3atNx9iqIwbdo03nzzzX607PMRDocB9trzvS1mzpzJiSee2Od7+Crw5JNPcuCBB3LGGWdQVlbGhAkTmD17dn+btdMcdthhzJ8/n1WrVgHw/vvv89prrzFjxox+tmzXWbNmDS0tLX3+hkKhEAcffPBX6re8x9VV+4PVq1dz22238fvf/76/TdkqHR0d2LZNeXl5n/vLy8v56KOP+smqz4fjOFxzzTVMnjyZ0aNH97c5O80DDzzAu+++y+LFi/vblF3m008/5fbbb+faa6/lZz/7GYsXL+aqq67CMAwuvPDC/jZvh/zkJz8hEokwYsQIVFXFtm1++9vfct555/W3abtMS0sLwFZ/y72PfRX4Su0YfvKTnyCE2O6/zS+kjY2NTJ8+nTPOOINLLrmknyz/72HmzJksX76cBx54oL9N2Wk2bNjA1Vdfzb333ovX6+1vc3YZx3GYOHEiN954IxMmTODSSy/lkksu4Y477uhv03aKhx56iHvvvZf77ruPd999l7vvvpvf//733H333f1t2n8tX6kdww9+8AO+9a1vbfc5++23X+7/TU1NHH300Rx22GH87W9/283WfX5KSkpQVZXW1tY+97e2tlJRUdFPVu06V1xxBU8//TQLFy7c7TM3vkyWLFlCW1sbEydOzN1n2zYLFy7kz3/+M+l0GlVV+9HC7VNZWcmoUaP63Ddy5EgeeeSRfrJo1/jRj37ET37yE84++2wAxowZw7p165g1a9ZXYsezKb2/19bWViorK3P3t7a2Mn78+H6yatf5SjmG0tJSSktLd+q5jY2NHH300RxwwAHMmTNnhxOL+hPDMDjggAOYP38+J598MpBdBc6fP58rrriif43bCaSUXHnllTz22GO8/PLLDB48uL9N2iWmTp3KBx980Oe+b3/724wYMYLrrrtur3YKAJMnT96iPHjVqlUMGjSonyzaNRKJxBa/T1VVcRynnyz6/AwePJiKigrmz5+fcwSRSIRFixZx+eWX969xu0J/Z793Bw0NDXLIkCFy6tSpsqGhQTY3N+f+7a088MAD0uPxyLvuukuuWLFCXnrppbKgoEC2tLT0t2k75PLLL5ehUEi+/PLLfc51IpHob9M+N1+lqqS3335bapomf/vb38pPPvlE3nvvvdLv98t///vf/W3aTnHhhRfKAQMGyKefflquWbNGPvroo7KkpET++Mc/7m/Ttko0GpVLly6VS5culYD8wx/+IJcuXSrXrVsnpZTypptukgUFBfKJJ56Qy5Ytk9/4xjfk4MGDZTKZ7GfLd5590jHMmTNHAlv9tzdz2223yZqaGmkYhjzooIPkW2+91d8m7RTbOtdz5szpb9M+N18lxyCllE899ZQcPXq09Hg8csSIEfJvf/tbf5u000QiEXn11VfLmpoa6fV65X777Sd//vOfy3Q63d+mbZWXXnppq3/vF154oZQyW7J6/fXXy/LycunxeOTUqVPlxx9/3L9G7yLuPAYXFxcXlz7svYF3FxcXF5d+wXUMLi4uLi59cB2Di4uLi0sfXMfg4uLi4tIH1zG4uLi4uPTBdQwuLi4uLn1wHYOLi4uLSx9cx+Di4uLi0gfXMbi4uLi49MF1DC4uLi4ufXAdg4uLi4tLH/4/OJSz3rrjsS8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"cisplatin\"\n",
    "X_pre = adata_4i[adata_4i.obs[\"drug\"] == \"control\"].copy().to_df()[features_4i]\n",
    "X_post  = adata_4i[adata_4i.obs[\"drug\"] == drug].copy().to_df()[features_4i]\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.values, X_post.values, 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, Y_tr_post, X_te_pre, Y_te_post, max_epochs=1000, batch_size=64, seed=seed)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post, 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",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post\n",
    "target = Y_te_post\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=\"#C331C8\")\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": 10,
   "id": "07d396d9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (10995, 48)\n",
      "X_post cells: (2796, 48)\n",
      "(2236, 48)\n",
      "(560, 48)\n",
      "(2236, 48)\n",
      "(560, 48)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Global seed set to 1234\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.074449069228528\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:15<04:31,  3.49it/s, loss=0.903, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 24.981. 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.01866410956128084, 'mmd2_gamma_0.5': 0.022727546351757624, 'mmd2_gamma_1.0': 0.011662717209000372, 'wasserstein_distance': 2.006938042670972, 'R2_feature_means': 0.6680192579982304}\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:17<05:05,  3.10it/s, loss=0.832, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 28.746. 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.013690425800356731, 'mmd2_gamma_0.5': 0.02093115045622504, 'mmd2_gamma_1.0': 0.011290577359427546, 'wasserstein_distance': 1.96751714048067, 'R2_feature_means': 0.7934363162251987}\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:15<04:34,  3.45it/s, loss=0.885, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.460. 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.01782284099833864, 'mmd2_gamma_0.5': 0.023887403949424235, 'mmd2_gamma_1.0': 0.012612688025339783, 'wasserstein_distance': 1.9712559652299164, 'R2_feature_means': 0.770533643847041}\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:18<05:36,  2.81it/s, loss=0.917, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.403. 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.014332027733248154, 'mmd2_gamma_0.5': 0.02004225357663307, 'mmd2_gamma_1.0': 0.010534093885874701, 'wasserstein_distance': 1.9905927086891373, 'R2_feature_means': 0.7602620952532163}\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:16<04:55,  3.20it/s, loss=0.834, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 24.963. 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.015474245583539825, 'mmd2_gamma_0.5': 0.021586562514049237, 'mmd2_gamma_1.0': 0.011376951865373252, 'wasserstein_distance': 1.9638861297566514, 'R2_feature_means': 0.790065730874069}\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 53/1000:   5%|███████████▏                                                                                                                                                                                                      | 53/1000 [00:14<04:23,  3.60it/s, loss=0.79, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 22.786. 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.014260904195136592, 'mmd2_gamma_0.5': 0.019216898633019994, 'mmd2_gamma_1.0': 0.010016849198631494, 'wasserstein_distance': 1.9780033633841454, 'R2_feature_means': 0.7881409589536692}\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:15<04:39,  3.38it/s, loss=0.835, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.709. 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.020333869492787926, 'mmd2_gamma_0.5': 0.02367291325605045, 'mmd2_gamma_1.0': 0.012202884000087403, 'wasserstein_distance': 2.0293573237411033, 'R2_feature_means': 0.5754647330700058}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:15<04:30,  3.50it/s, loss=0.845, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 21.973. 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.014567226185450255, 'mmd2_gamma_0.5': 0.020055394042481203, 'mmd2_gamma_1.0': 0.010508989654097488, 'wasserstein_distance': 1.98781613895407, 'R2_feature_means': 0.7972490082572712}\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 53/1000:   5%|███████████                                                                                                                                                                                                      | 53/1000 [00:14<04:27,  3.53it/s, loss=0.807, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 26.728. 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.014908426209161996, 'mmd2_gamma_0.5': 0.02175887340025877, 'mmd2_gamma_1.0': 0.011705079604718966, 'wasserstein_distance': 1.981784330142205, 'R2_feature_means': 0.7680969455782595}\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:15<04:45,  3.32it/s, loss=0.862, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 50 records. Best score: 25.411. 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.015915531607872846, 'mmd2_gamma_0.5': 0.021241188055728583, 'mmd2_gamma_1.0': 0.010994170164007302, 'wasserstein_distance': 1.9842334362426135, 'R2_feature_means': 0.7891695121729075}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0160  0.0022\n",
      "mmd2_gamma_0.5        0.0215  0.0016\n",
      "mmd2_gamma_1.0        0.0113  0.0008\n",
      "wasserstein_distance  1.9861  0.0197\n",
      "R2_feature_means      0.7500  0.0721\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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4vegL9OmTeONN96gp6eHjIyMAceX+E5+v5/s7OwR30PJ7o0UDJIdjm3bKIrC66+/jqZp/d7PzMxMed3e3s6SJUsAWLVqFbZto6pbldsPP/yQs846i2OOOYa//vWvlJaWous6c+bM4Yknnuh3/HTnHGx7YkJOaAN/+MMfOPDAA9Pu23fsAzHUuQB+/OMfM2fOHG666SYOP/xwcnJyUBSFiy66KEUzOeaYY1i/fj0vvfQSb775Jn//+9+55557uP/++7nmmmuGNZ6Rjm+k91CyeyMFg2SbKSwsxOPxpDVprFmzJvn/1dXVCCGYMGECkydPHvK41113Hd3d3dx5553ceuut3Hvvvdx8883J95977jncbjdvvPEGLpcruX3OnDnb+Y1SSZh+srOzOemkkwbddzSyvJ999lmuuOIK7rrrruS2SCSSNjciLy+Pq666iquuuopgMMgxxxzDbbfdxjXXXMP48eOB1HuQ4KuvvqKgoCBFWxgOI72Hkt0b6WOQbDOapjFr1ixefPFFamtrk9tXr17NG2+8kXx97rnnomkat99+e8oKGeIr0vb29uTrZ599lqeeeorf/e53/Nd//RcXXXQRv/jFL1i7dm3KeRVFwbKs5LaamhpefPHFUf1+Bx98MNXV1fzxj38kGAz2e7+1tTX5/4mJdnsS3DRN63d97rvvvpTvCaRcL4iv1idOnJg0qZWWlnLggQfy6KOPpoxn5cqVvPnmm5x++ukjHttI7qFk90dqDJLt4vbbb2f+/PkcffTR/OhHP8I0Te677z6mT5/OF198AcRXm3fccQe33norNTU1fOtb3yIrK4uNGzfywgsvcO211/If//EftLS08MMf/pDjjz8+WVvoz3/+M++++y5XXnklCxcuRFVVzjjjDO6++25OPfVULrnkElpaWvjLX/7CxIkTk+ccDVRV5e9//zunnXYa06dP56qrrqK8vJz6+nreffddsrOzeeWVV4C4EAH4+c9/zkUXXYSu68yePXtEK/MzzzyTxx57jJycHPbdd18++eQT3n77bfLz81P223fffTnuuOM4+OCDycvLY8mSJTz77LMp9Zj+8Ic/cNppp3H44Ydz9dVXEw6Hue+++8jJyeG2224b8bUY7j2U7CHsklgoyR7F+++/Lw4++GDhdDrFPvvsI+6///5kGGRvnnvuOXHUUUeJjIwMkZGRIaZO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dR3MnbccIaCy2EdbIMTcecuZOaWM6oq8XXk5+mlQRofR7zqMJuvXr8cwDI488sjkNl3XOfTQQ1m9enXKvr216Ly8PKZMmZLc54YbbuCHP/whb775JieddBLf/va3mTFjBgDLly/n3XffTWoQfc8/efJkAA4++OCU9xwOBxdccAGPP/44l112GT09Pbz00kv861//AuKr91AoxMknn5zyuVgsxsyZMwFYvXo1hx122IDfY6SMHz+ewsLC5Ovly5cTDAb7ZbqHw2HWr18PxDWG2267jXnz5tHY2IhpmoTD4aTGMBDLly/niy++SDEPCSGwbZuNGzeydu1aHA5HynWbOnUqPp9vwGO2tLTQ0NDAiSeeOOA5h/o+g3HAAQdw4oknsv/++zNr1ixOOeUUzjvvPHJzc4f87PYwYsFw3HHHDarGKIrCr3/9a379619v18Ak24a3ykPpBUVsntOIiMWFgqvMhbPISbQ+Sqw11m9CHPfdCvJPyKdjoZ+6OY1YIYvQBit+nxVwl7tx5usIIYjURsk9OoesGVvbAzZ3BOmJxKgs9qGqCgU+L7XNAZo7grtcMMRaY1ghC1e5C0VV0PP0Aa/DWOKaa65h1qxZzJs3jzfffJM777yTu+66ix//+McEg0Fmz57N73//+36f610jJyMjo9/7l156KcceeywtLS289dZbeDweTj31VICkiWnevHmUl5enfM7lco3m1xtwjMFgkNLSUt57771++yYm6P/4j//grbfe4o9//CMTJ07E4/Fw3nnnEYvF+n2m77G///3vc8MNN/R7r7KykrVr1454/IkyFIOdc6jvMxiapvHWW2/x8ccf8+abb3Lffffx85//nEWLFjFhwoQRj3e47PKoJMn20zcCqfisIvR8nQ1/rEXRwFnkxOgw0LwazsL0UR/eKg+R+gh22AYEiltFhAQIEJaN6lYJbwhjBS3a3uqg89PuZGRScV4mGW4nbYEQBT4vbYEQGW4nxXn9V7Q7m4QGZXTE/SVDXYftpbq6OmnXHz9+PBB38C5evJibbropZd9///vfVFZWAuD3+1m7di3Tpk1Lvj9u3Dh+8IMf8IMf/IBbb72Vhx56iB//+MccdNBBPPfcc1RVVeFwjOwnfMQRRzBu3DieeuopXn/9dc4//3x0XQdg3333xeVyUVtby7HHHpv289OmTePll1/u9z2GQtd1LMsacr+DDjqIpqYmHA5H0kndl48++ogrr7wy6RcJBoP9HOBOp7Pf+Q466CBWrVqVYv/vzdSpUzFNk88++4xDDjkEgDVr1gyan5GVlUVVVRULFixIsaSM5PsMhaIoHHnkkRx55JH88pe/ZPz48bzwwgsp0ZyjjWzUs5uTiEBa9+uNrPrJ2mQeQt6RuYy7qhTNrRGtj6IoCqUXFA26SladKlqGiqIpiKhA1RVUr4KiqoRrIhh+E0euhqfKkxKZVF2Rx+VnHICiQG1zAEWBy884YJdrC7BVg1IUZdjXYXvIyMjghz/8Ibfccgvz589n1apVfO973yMUCnH11Ven7PvrX/+aBQsWsHLlSq688koKCgqSiU033XQTb7zxBhs3buTzzz/n3XffTQqN6667jo6ODi6++GIWL17M+vXreeONN7jqqquGNflecskl3H///bz11ltceumlye1ZWVn8x3/8Bz/5yU949NFHWb9+PZ9//jn33Xcfjz76KAA/+MEPWLduHbfccgtr1qzhiSee4JFHHhnynInJs6mpCb9/4ETKk046icMPP5xvfetbvPnmm9TU1PDxxx/z85//nCVLlgAwadKkpLN6+fLlXHLJJdi23e98H3zwAfX19clorf/8z//k448/5vrrr2fZsmWsW7eOl156Kel8njJlCqeeeirf//73WbRoEZ999hnXXHPNkFrBbbfdxl133cWf/vQn1q1bl7xmw/0+g7Fo0SL+93//lyVLllBbW8vzzz9Pa2trygJihzAsj8ZORDqfB6ZnY0j4Pw0knb49G0Ni6aUrxKenfx53Mh+2SHx0+Kei9h+bB/zMUMdfeukKseTby8Tn34n/u/TSFaJ9YYfY/Fi9+PTMz8WK61eLlTd8JVZcv1osOWeZ8H8aSH7+683t4qPlm8TXm9tH5fuOlvNZiJFdh+0lHA6LH//4x6KgoEC4XC5x5JFHpjg0E87nV155RUyfPl04nU5x6KGHiuXLlyf3uf7660V1dbVwuVyisLBQXHbZZaKtrS35/tq1a8U555wjfD6f8Hg8YurUqeKmm24Stm0LIeLO5xtvvDHt+FatWiUAMX78+OT+CWzbFvfee6+YMmWK0HVdFBYWilmzZon3338/uc8rr7wiJk6cKFwulzj66KPFww8/PKTz+eWXXxYTJ04UDodDjB8/XgjR3+maoKurS/z4xz8WZWVlQtd1MW7cOHHppZeK2tpaIYQQGzduFMcff7zweDxi3Lhx4s9//nO/7/vJJ5+IGTNmCJfLJXpPc59++qk4+eSTRWZmpsjIyBAzZswQv/3tb5PvNzY2ijPOOEO4XC5RWVkp5s6dm9aR3Zf7778/ec1KS0vFj3/842F/n8Gcz6tWrRKzZs0ShYWFwuVyicmTJ6c42fsyWs5nRYgdHfc0Mrq6usjJyaGzs1PmNPSid7JZIsHMVepi3a83YgQMFAVwKNghG1epi33vmbxNq+J05yk+q4hQTZivblmHbdjo+Tp2xEZRFCbfUb3DVt+RSISNGzemxLhLJJKBGew3M5K5VfoYdgMGiqyp/GE5ikNBGAJcCkRE/LVpb7NztfisIrJmZBFrjWHHbFSnSqgmTPcX3Vhhi1ibQbQphp6vM/775WPagSuRSLYNKRh2AwaKrDE6DLJnZtJSH0F0b1H8NECwXc5Vb5WH7i+6k5qDoimYIQvd58BZ4sRoM1B1NSUySSKR7DlI5/NuQO/IGmELjA4DK2pTP7eJzsXdyVpHANhg9gztgByMvhqKbdgY7QaqW8WR4cA9zh3PaWgdPDxQIpHsnkjBsBvQN7JGxASKAopTQfMoccGggOJVUJwKVo9F+7vt23y+hIai5+lxDaVgSw5DfRQzaO7wkE+JRLJrkaak3YTetv9oU4y6OQ3xuPzWrS38hCXAAGxoeq4VZ75zmyqg9o39jzZGUVAwOwyCHSaOXAdV11VI/4JEsociNYbdCG+VB98hOWTtn5mcuNVMFSUh3qOAAMUJqkftVwF1uIXkemso4Zowpt9C86qgKwgEZpdJrE2akSSSPRWpMeyGJCbuxqdbMDtMnEVOzB4LK2ihOBW849zohVtLYAA0v9SCf2EnwhKD9lNIZFFnzcgia0YWHQv9NDzehBm0UDUFXCp2yKb5lXbyT8iXWoNEsgciBcNuSm/TkrPQSaQ+Ei+B4QC9MF4CQ9EUWl5vo+vzbqJNMRQVXBWuZNZy30Jy6XIY8o7Kpem5VoTfRPGqYMYzotOFxA7eHEgikewuSMGwG+Ot8qRUSjXa4/kN4ZoIdsRC2ILW1yIACFug6CqxJgPvJA+m30yZ2AerQlo0u4C6vzdgh2xUXUHL1tBzdJyFzqQw6F7RTfs7gWR4a+5RORSfveNKT0gkkh2H9DHsQRSfVUT+CT4QAqPLxApa8S6eGmCDMG3smE20KdovqqhfJFKvZjyV3y1n3DWluEpdOHwOnLlOSi8oovuL7mSdps1/byTaEsWK2YQ3R2h4spmvblnXr3ucZPTp2994Z/dXTtC3qf1oU1NTg6IoyYY+7733HoqiDFrkTrJtSI1hN2C4JppQTZj2dwIoDgVFU0AhXgzPoSIQiCiAwGg38R2ak3KsoaqQJkpzJ8YBsPYX6xFCoPvi/R/s9i0JFQqggm3YO7T3gSQ9jY2Nw67Xf9ttt/Hiiy8mJ1uJBKRgGPMMVLsoHclVf4GO0WEihI3Q4poCAhRdQS90oHk0QuvChGrCKaaohEM7Wh9Nnqv3hN7bdBVY3JnMxjY7zXguhSAuFLbIBy1TS2odUjAMTiwWw+kcnbyQgfqrSyTDRZqSxjB97f6iV6nrdCRW/XbYxlWig6WgoKBmaKgZKpn7ZZBRnYGrxNWvZ3OoJoyr1EXxuYUUn1tI5Q/LB82B6K1hIMTWJylRktGGWHNsr0yEO+6447j++uu5/vrrycnJoaCggP/5n/9JaXBVVVXFb37zGy6//HKys7O59tprgdFpVt/XlFRXV8fFF19MXl4eGRkZfOMb32DRokU88sgj3H777SxfvhxFUVAUJVlCezgN7H/3u99RXFxMVlYWV199NZFIZMhr8+WXX3LmmWeSnZ1NVlYWRx99dEons7///e9MmzYNt9vN1KlT+etf/zqsaw6wadMmZs+eTW5uLhkZGUyfPp3XXntt2J+XbEVqDGOYkXYf673qt03QsjWEGS+sZ0UsYk0xtH20FDNRqCacDGU1OuN+CS1DxVXswmg3kpVV+5qyep/LCJjx4n0JqbBFYzCDFqUX544JbWF9XQfNHUGK8zJ3Sp+IRx99lKuvvppPP/2UJUuWcO2111JZWcn3vve95D5//OMf+eUvf8mvfvWr+Bi3NKu/4447ePjhh2ltbU0KmDlz5gDxZvUNDQ28++676LrODTfcMGiz+mAwyLHHHkt5eTkvv/wyJSUlfP7559i2zYUXXsjKlSuZP38+b7/9NgA5OTlAvIG9x+Ph9ddfJycnhwceeIATTzyRtWvXkpeXx9NPP81tt93GX/7yF4466igee+wx/vSnP7HPPvsMOJb6+nqOOeYYjjvuON555x2ys7P56KOPME0TgMcff5xf/vKX/PnPf2bmzJksXbqU733ve2RkZHDFFVcMec2vu+46YrEYH3zwARkZGaxatSpt+1PJ0EjBMIbZlu5jiTDW7hVB6uc2ojjjAiW0IYThN6Emgp7jIO+EXOrmNuD/uDPe11kBECiqgh2xsSJW3KzUZtDxjj+tKat3yGzL6220vtae9G04fBqKopC9/67/YT67YCVz5y2nJxIjw+3k8jMO4LwT99uh5xw3bhz33HMPiqIwZcoUVqxYwT333JMiGE444QR++tOfJl9fc801XHrppclOb5MmTeJPf/oTxx57LH/729+ora3l9ddf59NPP012GPvHP/4xaNOWJ554gtbWVhYvXkxeXlwg9u5glpmZicPhSDE/LVy4kE8//ZSWlpZkS88//vGPvPjiizz77LNce+213HvvvVx99dXJ5kN33HEHb7/99qBaw1/+8hdycnL417/+lewal+hPDfCrX/2Ku+66i3PPPReACRMmsGrVKh544IFhCYba2lq+/e1vs//++wMMKqQkgyNNSWOYbe0+5q3y4CpxIiyRjDLy7uNFz3dQemE8cqnxqWZaXmrDaDEQhkDYAmEQz262QfVoGJ0GLa+0DWrKSmRjV1xehmecG0euhrvMiebZGtK6K1lf18HcecsRAiqLfQgBc+ctZ31dxw497ze/+U0URUm+Pvzww1m3bl1Kh7VvfOMbKZ9Zvnw5jzzyCJmZmcm/WbNmJZvVr169esTN6pctW8bMmTOTQmE49G5g33ssGzduTJp9Vq9ezWGHHZbyucMPP3zQ4y5btoyjjz46KRR609PTw/r167n66qtTznnHHXekmJoG44YbbuCOO+7gyCOP5Fe/+hVffPHFML+xpC9SYxjj9E1kG65ZJp22oefoeCd4qLl3M2Ygrr6jEPcLWPF/RUSgOhXssIXiUBGmSAlhHciU5a3ykLlfBm1vdGC0miiaQsGsvF1uRmruCNITiVFZ7ENVFQp8XmqbAzR3BHd569GMjIyU17uiWX06treB/baMJRgMAvDQQw/1Eziapg3r+Ndccw2zZs1i3rx5vPnmm9x5553cdddd/PjHP97mMe+tSI1hD2UgbUN1qphBM37nt4SVAnHhoMb/VLeK5tYonp2PnuNIKfc9kCkrVBMmtC6Mq8yJu8qFI1cjuLJnyLpMO5rivEwy3E7aAiFsW9AWCJHhdlKct2NNXIsWLUp5/e9//5tJkyYNOsn1blbf98/pdKY0q08wVLP6GTNmsGzZMjo60mtITqezX5/o3g3s+46joKAAgGnTpqX9joMxY8YMPvzwQwzD6PdecXExZWVlbNiwod85J0yYMOhxezNu3Dh+8IMf8Pzzz/PTn/6Uhx56aNiflWxFCoYxzuaH61j1k7Ws+/UG1v5i/YgSxorPKopHF/WKMnIWOnFkOuJlux1KXFMA0KH4rAKm/XESU/53IpPvqGbcdyuGbcpKOMoVFWKNBobfJLw5QvNLuzbBrboij8vPOABFgdrmAIoCl59xwA7XFmpra7n55ptZs2YNTz75JPfddx833njjoJ/ZEc3qL774YkpKSvjWt77FRx99xIYNG3juuef45JNPgHh01MaNG1m2bBltbW1Eo9FhNbC/8cYbefjhh5kzZw5r167lV7/6FV9++eWg3+/666+nq6uLiy66iCVLlrBu3Toee+wx1qxZA8Dtt9/OnXfeyZ/+9CfWrl3LihUrmDNnDnffffewrvlNN93EG2+8wcaNG/n888959913B/W/SAZGmpLGMLUP11P390aEvaU+kZ2+xtFA9M2BSEQZlV9WwoZ7arG7tkgFDfKO8THpl9X9jjFcU5az0ImiKUTqoqCJuBMagX9hJ8Vnh3epSem8E/dj5pSynRqVdPnllxMOhzn00EPRNI0bb7wxGZI6EDNmzOD999/n5z//OUcffTRCCKqrq7nwwguT+8yZM4drrrmGY489luLiYu644w7+53/+Z8BjOp1O3nzzTX76059y+umnY5om++67L3/5y18A+Pa3v83zzz/P8ccfTyAQYM6cOVx55ZW89tpr/PznP+eqq66itbWVkpISjjnmGIqLiwG48MILWb9+PT/72c+IRCJ8+9vf5oc//CFvvPHGgGPJz8/nnXfe4ZZbbuHYY49F0zQOPPBAjjzySCBuCvJ6vfzhD3/glltuISMjg/333z/pjB8Ky7K47rrrqKurIzs7m1NPPZV77rlnWJ+VpKKI3sHVY4CRNKzekwnVhFn1k7VEG6OoW4rXIcDhczDpl/vgOyRnyM8nMpNVtxrvwKarTP3DJAC+umUdZshEy9DABs2tMfmO6u2awDf+v000PNmMosUzr50lOphQfWvVkONNx2CNzccyxx13HAceeGBKmQqJZGcw2G9mJHOr1BjGKLHWWDwHQVfiQsGhYIdsFIc6ZKTP+roONixuJtzT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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"dexamethasone\"\n",
    "X_pre = adata_4i[adata_4i.obs[\"drug\"] == \"control\"].copy().to_df()[features_4i]\n",
    "X_post  = adata_4i[adata_4i.obs[\"drug\"] == drug].copy().to_df()[features_4i]\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.values, X_post.values, 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, Y_tr_post, X_te_pre, Y_te_post, max_epochs=1000, batch_size=64, seed=seed)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post, 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",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post\n",
    "target = Y_te_post\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=\"#C331C8\")\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": null,
   "id": "3cc05c34",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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
}
