{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "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": 2,
     "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": 6,
   "id": "fe4f5248",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "from typing import Dict, Tuple, List, Optional\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import logging\n",
    "logger = logging.getLogger(__name__)\n",
    "\n",
    "def load_ap1_data_from_csv(csv_filepath: str, replicate: Optional[int] = None) -> Dict[str, np.ndarray]:\n",
    "    \"\"\"\n",
    "    Loads AP1 single-cell data from CSV or Excel file.\n",
    "\n",
    "    Args:\n",
    "        csv_filepath: Path to the CSV or Excel file\n",
    "\n",
    "    Returns:\n",
    "        Dictionary with condition identifiers as keys and feature matrices as values\n",
    "    \"\"\"\n",
    "    logger.info(f\"Loading data from: {csv_filepath}\")\n",
    "\n",
    "    # Load the data based on file extension\n",
    "    if csv_filepath.endswith('.csv'):\n",
    "        df = pd.read_csv(csv_filepath)\n",
    "    elif csv_filepath.endswith('.xlsx'):\n",
    "        df = pd.read_excel(csv_filepath)\n",
    "    else:\n",
    "        raise ValueError(\"Unsupported file format. Please provide a .csv or .xlsx file.\")\n",
    "    \n",
    "    replacement_map = {\n",
    "                        '0.316 uM Vemurafenib': 'Vem',\n",
    "                        '0.316 uM Vem + 0.0316 uM Tram': 'Vem+Tram'\n",
    "                        }\n",
    "    df['condition'] = df['condition'].replace(replacement_map)\n",
    "\n",
    "    print(df['condition'].unique())\n",
    "\n",
    "    # Define AP1 protein features (these are in log space already)\n",
    "    ap1_features = [\n",
    "        'cFOS (log a.u.)', 'p-cFOS (log a.u.)', 'FRA1 (log a.u.)', 'p-FRA1 (log a.u.)', 'FRA2 (log a.u.)',\n",
    "        'cJUN (log a.u.)', 'p-cJUN (log a.u.)', 'JUNB (log a.u.)', 'JUND (log a.u.)', 'p-ATF1 (log a.u.)',\n",
    "        'ATF2 (log a.u.)',\t 'p-ATF2 (log a.u.)', 'ATF3 (log a.u.)', 'ATF4 (log a.u.)', 'p-ATF4 (log a.u.)',\n",
    "        'ATF5 (log a.u.)', 'ATF6 (log a.u.)', 'MITF (log a.u.)', 'NGFR (log a.u.)', 'p-ERK (log a.u.)',\n",
    "    ]\n",
    "\n",
    "    # Check if all features exist\n",
    "    missing_features = [f for f in ap1_features if f not in df.columns]\n",
    "    if missing_features:\n",
    "        logger.warning(f\"Missing features: {missing_features}\")\n",
    "        ap1_features = [f for f in ap1_features if f in df.columns]\n",
    "\n",
    "    logger.info(f\"Using {len(ap1_features)} AP1 features\")\n",
    "\n",
    "    # Create condition-based data dictionary\n",
    "    data_dict = {}\n",
    "\n",
    "    if replicate is not None:\n",
    "        # Group by condition, time, and cell line\n",
    "        for (condition, time, cell_line, replicate_id), group in df.groupby(['condition', 'time', 'cell_line', 'replicate_id']):\n",
    "            # Create condition identifier\n",
    "            condition_id = f\"{cell_line}_{condition}_{time.replace(' ', '')}_rep{replicate_id}\"\n",
    "\n",
    "            # Extract feature matrix\n",
    "            feature_matrix = group[ap1_features].values\n",
    "\n",
    "            # Remove rows with any NaN values\n",
    "            valid_rows = ~np.isnan(feature_matrix).any(axis=1)\n",
    "            feature_matrix = feature_matrix[valid_rows]\n",
    "\n",
    "            if len(feature_matrix) > 0:\n",
    "                data_dict[condition_id] = feature_matrix\n",
    "                logger.info(f\"Loaded {condition_id}: {feature_matrix.shape}\")\n",
    "            else:\n",
    "                logger.warning(f\"No valid data for {condition_id}\")\n",
    "    else:\n",
    "        # Group by condition, time, and cell line\n",
    "        for (condition, time, cell_line), group in df.groupby(['condition', 'time', 'cell_line']):\n",
    "            # Create condition identifier\n",
    "            condition_id = f\"{cell_line}_{condition}_{time.replace(' ', '')}\"\n",
    "\n",
    "            # Extract feature matrix\n",
    "            feature_matrix = group[ap1_features].values\n",
    "\n",
    "            # Remove rows with any NaN values\n",
    "            valid_rows = ~np.isnan(feature_matrix).any(axis=1)\n",
    "            feature_matrix = feature_matrix[valid_rows]\n",
    "\n",
    "            if len(feature_matrix) > 0:\n",
    "                data_dict[condition_id] = feature_matrix\n",
    "                logger.info(f\"Loaded {condition_id}: {feature_matrix.shape}\")\n",
    "            else:\n",
    "                logger.warning(f\"No valid data for {condition_id}\")\n",
    "\n",
    "    return data_dict\n",
    "\n",
    "def prepare_pair_from_mat(cell_line: str,\n",
    "                          baseline_condition: str, baseline_time: str,\n",
    "                          target_condition: str, target_time: str,\n",
    "                          replicate: Optional[int] = None) -> Tuple[np.ndarray, np.ndarray]:\n",
    "    print(\"Cell line: \", cell_line)\n",
    "    raw_data_dict = load_ap1_data_from_csv('mmc5.xlsx', replicate)\n",
    "\n",
    "    if replicate is not None:\n",
    "        pre_key = f\"{cell_line}_{baseline_condition}_{baseline_time}_rep{replicate}\"\n",
    "        post_key = f\"{cell_line}_{target_condition}_{target_time}_rep{replicate}\"\n",
    "    else:\n",
    "        pre_key = f\"{cell_line}_{baseline_condition}_{baseline_time}\"\n",
    "        post_key = f\"{cell_line}_{target_condition}_{target_time}\"\n",
    "\n",
    "    if pre_key not in raw_data_dict or post_key not in raw_data_dict:\n",
    "        raise ValueError(f\"Pair not found: {pre_key}, {post_key}\")\n",
    "\n",
    "    # Equalize N\n",
    "    n = min(len(raw_data_dict[pre_key]), len(raw_data_dict[post_key]))\n",
    "    X_pre_raw = raw_data_dict[pre_key][:n]\n",
    "    X_post_raw = raw_data_dict[post_key][:n]\n",
    "    return X_pre_raw, X_post_raw\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "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": null,
   "id": "c533daf9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "eb96ecaa",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import torch\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.decomposition import PCA\n",
    "from cellot.models.cellot import load_networks, compute_loss_f, compute_loss_g\n",
    "\n",
    "from sklearn.metrics.pairwise import rbf_kernel\n",
    "\n",
    "\n",
    "def mmd_distance(x, y, gamma):\n",
    "    xx = rbf_kernel(x, x, gamma)\n",
    "    xy = rbf_kernel(x, y, gamma)\n",
    "    yy = rbf_kernel(y, y, gamma)\n",
    "\n",
    "    return xx.mean() + yy.mean() - 2 * xy.mean()\n",
    "\n",
    "def compute_mmd_loss(lhs, rhs, gammas):\n",
    "    return np.mean([mmd_distance(lhs, rhs, g) for g in gammas])\n",
    "\n",
    "from cellot.losses.mmd import mmd_distance\n",
    "\n",
    "def run_cellot_pair(train_pre: np.ndarray, train_post: np.ndarray,\n",
    "                    test_pre: np.ndarray, test_post: np.ndarray,\n",
    "                    layers: Optional[List[int]] = [32, 32 ,32],\n",
    "                    n_epochs: int = 5000,\n",
    "                    feature_subset: Optional[List[int]] = None,) -> Dict:\n",
    "    \n",
    "    device = 'cuda'\n",
    "    print(f\"VERS torch={torch.__version__} (CellOT), device={device}\", file=sys.stderr, flush=True)\n",
    "\n",
    "\n",
    "    # Apply feature subset if specified\n",
    "    if feature_subset is not None:\n",
    "        print(f\"Using feature subset of size {len(feature_subset)}\", file=sys.stderr, flush=True)\n",
    "        train_pre = train_pre[:, feature_subset]\n",
    "        train_post = train_post[:, feature_subset]\n",
    "        test_pre = test_pre[:, feature_subset]\n",
    "        test_post = test_post[:, feature_subset]\n",
    "\n",
    "    # Preprocess: standardize jointly and optionally apply PCA for stability\n",
    "    X_all = np.vstack([train_pre, train_post])\n",
    "    scaler = StandardScaler()\n",
    "    X_all_s = scaler.fit_transform(X_all)\n",
    "    d = X_all_s.shape[1]\n",
    "    pca_dims = min(50, d)\n",
    "    if pca_dims < d:\n",
    "        pca = PCA(n_components=pca_dims, svd_solver='full', random_state=42)\n",
    "        X_all_p = pca.fit_transform(X_all_s)\n",
    "        tr_pre_p = X_all_p[:len(train_pre)]\n",
    "        tr_post_p = X_all_p[len(train_pre):]\n",
    "        te_pre_p = pca.transform(scaler.transform(test_pre))\n",
    "        use_pca = True\n",
    "    else:\n",
    "        tr_pre_p = X_all_s[:len(train_pre)]\n",
    "        tr_post_p = X_all_s[len(train_pre):]\n",
    "        te_pre_p = scaler.transform(test_pre)\n",
    "        use_pca = False\n",
    "\n",
    "    # Networks - Using official CellOT configuration\n",
    "    input_dim = tr_pre_p.shape[1]\n",
    "    config = {\n",
    "        'model': {\n",
    "            'name': 'cellot',\n",
    "            'hidden_units': layers,\n",
    "            'kernel_init_fxn': {'name': 'uniform', 'a': -0.01, 'b': 0.01},\n",
    "            'activation': 'relu',\n",
    "            'softplus_W_kernels': True,\n",
    "            'f': {},\n",
    "            'g': {}\n",
    "        }\n",
    "    }\n",
    "    f, g = load_networks(config, input_dim=input_dim)\n",
    "    f = f.to(device).float()\n",
    "    g = g.to(device).float()\n",
    "\n",
    "    # Data tensors\n",
    "    src = torch.tensor(tr_pre_p, dtype=torch.float32, device=device)\n",
    "    tgt = torch.tensor(tr_post_p, dtype=torch.float32, device=device)\n",
    "    te_src = torch.tensor(te_pre_p, dtype=torch.float32, device=device)\n",
    "\n",
    "    # Optimizers matching official config\n",
    "    lr = 1e-4\n",
    "    optim_f = torch.optim.Adam(f.parameters(), lr=lr, betas=(0.5, 0.9), weight_decay=0)\n",
    "    optim_g = torch.optim.Adam(g.parameters(), lr=lr, betas=(0.5, 0.9), weight_decay=0)\n",
    "\n",
    "    # No schedulers in official config\n",
    "    # n_epochs = 1200  # More epochs for better convergence\n",
    "    n_epochs = n_epochs + 1  \n",
    "    # Training loop following official CellOT implementation\n",
    "    f.train(); g.train()\n",
    "    batch_size = 256  # Official config\n",
    "    n_inner_iters = 10  # Official config\n",
    "\n",
    "\n",
    "    for epoch in range(n_epochs):\n",
    "        f.train(); g.train()\n",
    "        perm_t = torch.randperm(len(tgt), device=device)[:batch_size]\n",
    "        yt = tgt[perm_t]\n",
    "        \n",
    "        # Multiple g updates per iteration (official implementation)\n",
    "        for _ in range(n_inner_iters):\n",
    "            perm_s = torch.randperm(len(src), device=device)[:batch_size]\n",
    "            xs = src[perm_s].detach().clone().requires_grad_(True)\n",
    "            \n",
    "            optim_g.zero_grad()\n",
    "            g_loss = compute_loss_g(f, g, xs).mean()\n",
    "            g_loss.backward()\n",
    "            torch.nn.utils.clip_grad_norm_(g.parameters(), max_norm=0.5)\n",
    "            optim_g.step()\n",
    "        \n",
    "        # Single f update (official implementation)\n",
    "        perm_s = torch.randperm(len(src), device=device)[:batch_size]\n",
    "        xs = src[perm_s].detach().clone().requires_grad_(True)\n",
    "        \n",
    "        optim_f.zero_grad()\n",
    "        f_loss = compute_loss_f(f, g, xs, yt).mean()\n",
    "        f_loss.backward()\n",
    "        optim_f.step()\n",
    "        \n",
    "        # Clamp weights for f (official implementation)\n",
    "        if hasattr(f, 'clamp_w'):\n",
    "            f.clamp_w()\n",
    "        \n",
    "        \n",
    "        # ---- Evaluate train MMD and early-stop ----\n",
    "        if epoch % 50 == 0: \n",
    "            f.eval()\n",
    "            g.eval()\n",
    "\n",
    "\n",
    "            # Transport a fixed subset of training PRE (in preprocessed space)\n",
    "            tr_src_eval = src.requires_grad_(True)\n",
    "            tr_pred_p = g.transport(tr_src_eval).detach().cpu().numpy()\n",
    "            # Invert preprocessing to original space (so MMD is comparable to your final eval)\n",
    "            if use_pca:\n",
    "                tr_pred = scaler.inverse_transform(pca.inverse_transform(tr_pred_p))\n",
    "            else:\n",
    "                tr_pred = scaler.inverse_transform(tr_pred_p)\n",
    "            train_mmd_min = mmd_distance(train_post, tr_pred, gamma=1.0)\n",
    "\n",
    "\n",
    "            te_src_full = te_src.detach().clone().requires_grad_(True)\n",
    "            te_pred_full = g.transport(te_src_full).detach().cpu().numpy()\n",
    "            if use_pca:\n",
    "                te_pred_inv_full = scaler.inverse_transform(pca.inverse_transform(te_pred_full))\n",
    "            else:\n",
    "                te_pred_inv_full = scaler.inverse_transform(te_pred_full)\n",
    "            test_metrics = mmd_distance(test_post, te_pred_inv_full, gamma=median_gamma)\n",
    "\n",
    "            print(\n",
    "                f\"[CellOT] epoch={epoch} f_loss={f_loss.item():.4f} g_loss={g_loss.item():.4f} | \"\n",
    "                f\"train mmd={train_mmd_min:.4f} | \"\n",
    "                f\"test_mmd={test_metrics:.4f}\",\n",
    "                file=sys.stderr,\n",
    "                flush=True,\n",
    "            )\n",
    "\n",
    "                \n",
    "            \n",
    "\n",
    "    # Inference (CellOT transport requires gradients for autodiff)\n",
    "    f.eval(); g.eval()\n",
    "    # CellOT needs gradients even in eval mode for transport computation\n",
    "    te_src_for_transport = te_src.detach().clone().requires_grad_(True)\n",
    "    te_tx = g.transport(te_src_for_transport).detach().cpu().numpy()\n",
    "\n",
    "    # Inverse preprocess\n",
    "    if use_pca:\n",
    "        te_tx_inv = scaler.inverse_transform(pca.inverse_transform(te_tx))\n",
    "    else:\n",
    "        te_tx_inv = scaler.inverse_transform(te_tx)\n",
    "    # Final evaluation\n",
    "    metrics = summarize_metrics(test_post[:len(te_tx_inv)], te_tx_inv, median_gamma)\n",
    "\n",
    "    gammas = np.logspace(1, -3, num=50)\n",
    "    mmd = compute_mmd_loss(test_post[:len(te_tx_inv)], te_tx_inv, gammas=gammas)\n",
    "    print(f\"[CellOT] Final CellOT MMD: {mmd:.4f}\", file=sys.stderr, flush=True)\n",
    "    \n",
    "    return {'y_pred': te_tx_inv, 'metrics': metrics}\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b2a6a182",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cell line:  COLO858\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n",
      "Cell line:  COLO858\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1371, 20)\n",
      "(1655, 20)\n",
      "(1371, 20)\n",
      "(1655, 20)\n",
      "Median heuristic gamma: 0.048733884028107605\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-1.3807 g_loss=-4.6045 | train mmd=0.2637 | test_mmd=1.3616\n",
      "[CellOT] epoch=50 f_loss=-2.2082 g_loss=0.7617 | train mmd=0.5367 | test_mmd=0.3421\n",
      "[CellOT] epoch=100 f_loss=-3.2379 g_loss=3.7508 | train mmd=0.7933 | test_mmd=0.2968\n",
      "[CellOT] epoch=150 f_loss=-5.1477 g_loss=6.0825 | train mmd=0.8190 | test_mmd=0.2675\n",
      "[CellOT] epoch=200 f_loss=-7.2641 g_loss=8.8029 | train mmd=0.8093 | test_mmd=0.2321\n",
      "[CellOT] epoch=250 f_loss=-8.6412 g_loss=11.3885 | train mmd=0.7981 | test_mmd=0.1973\n",
      "[CellOT] epoch=300 f_loss=-10.2667 g_loss=13.8707 | train mmd=0.7908 | test_mmd=0.1737\n",
      "[CellOT] epoch=350 f_loss=-11.2706 g_loss=17.4229 | train mmd=0.7390 | test_mmd=0.1443\n",
      "[CellOT] epoch=400 f_loss=-12.7290 g_loss=18.9258 | train mmd=0.7397 | test_mmd=0.1252\n",
      "[CellOT] epoch=450 f_loss=-14.5606 g_loss=20.5021 | train mmd=0.7191 | test_mmd=0.1079\n",
      "[CellOT] epoch=500 f_loss=-14.8307 g_loss=23.8990 | train mmd=0.6869 | test_mmd=0.0916\n",
      "[CellOT] epoch=550 f_loss=-15.6483 g_loss=22.9265 | train mmd=0.6648 | test_mmd=0.0744\n",
      "[CellOT] epoch=600 f_loss=-15.2276 g_loss=26.3852 | train mmd=0.6106 | test_mmd=0.0585\n",
      "[CellOT] epoch=650 f_loss=-14.1773 g_loss=28.5404 | train mmd=0.5767 | test_mmd=0.0438\n",
      "[CellOT] epoch=700 f_loss=-12.9100 g_loss=29.6547 | train mmd=0.5483 | test_mmd=0.0312\n",
      "[CellOT] epoch=750 f_loss=-9.7398 g_loss=28.5993 | train mmd=0.4814 | test_mmd=0.0211\n",
      "[CellOT] epoch=800 f_loss=-8.7542 g_loss=32.0414 | train mmd=0.4288 | test_mmd=0.0138\n",
      "[CellOT] epoch=850 f_loss=-2.5906 g_loss=32.1366 | train mmd=0.3849 | test_mmd=0.0094\n",
      "[CellOT] epoch=900 f_loss=-0.4610 g_loss=31.9175 | train mmd=0.3197 | test_mmd=0.0068\n",
      "[CellOT] epoch=950 f_loss=1.6925 g_loss=30.3529 | train mmd=0.3148 | test_mmd=0.0063\n",
      "[CellOT] epoch=1000 f_loss=6.5441 g_loss=24.2645 | train mmd=0.1478 | test_mmd=0.0114\n",
      "[CellOT] epoch=1050 f_loss=1.9927 g_loss=21.8102 | train mmd=0.0357 | test_mmd=0.0267\n",
      "[CellOT] epoch=1100 f_loss=1.4621 g_loss=19.8080 | train mmd=0.0425 | test_mmd=0.0128\n",
      "[CellOT] epoch=1150 f_loss=0.8494 g_loss=20.4101 | train mmd=0.0403 | test_mmd=0.0094\n",
      "[CellOT] epoch=1200 f_loss=1.2201 g_loss=20.7858 | train mmd=0.0374 | test_mmd=0.0099\n",
      "[CellOT] epoch=1250 f_loss=-0.3227 g_loss=21.1583 | train mmd=0.0354 | test_mmd=0.0110\n",
      "[CellOT] epoch=1300 f_loss=0.1663 g_loss=20.9781 | train mmd=0.0461 | test_mmd=0.0093\n",
      "[CellOT] epoch=1350 f_loss=0.2125 g_loss=20.9944 | train mmd=0.0392 | test_mmd=0.0116\n",
      "[CellOT] epoch=1400 f_loss=0.1959 g_loss=21.1108 | train mmd=0.0283 | test_mmd=0.0084\n",
      "[CellOT] epoch=1450 f_loss=-0.3272 g_loss=21.4712 | train mmd=0.0234 | test_mmd=0.0108\n",
      "[CellOT] epoch=1500 f_loss=0.1694 g_loss=22.4055 | train mmd=0.0277 | test_mmd=0.0137\n",
      "[CellOT] epoch=1550 f_loss=-0.4032 g_loss=22.2382 | train mmd=0.0231 | test_mmd=0.0106\n",
      "[CellOT] epoch=1600 f_loss=0.2094 g_loss=21.9816 | train mmd=0.0265 | test_mmd=0.0106\n",
      "[CellOT] epoch=1650 f_loss=0.3465 g_loss=21.8142 | train mmd=0.0314 | test_mmd=0.0114\n",
      "[CellOT] epoch=1700 f_loss=0.5061 g_loss=21.6609 | train mmd=0.0531 | test_mmd=0.0109\n",
      "[CellOT] epoch=1750 f_loss=0.2868 g_loss=20.7193 | train mmd=0.0774 | test_mmd=0.0096\n",
      "[CellOT] epoch=1800 f_loss=-0.0723 g_loss=20.9672 | train mmd=0.0233 | test_mmd=0.0108\n",
      "[CellOT] epoch=1850 f_loss=0.2734 g_loss=20.5473 | train mmd=0.0142 | test_mmd=0.0154\n",
      "[CellOT] epoch=1900 f_loss=0.5449 g_loss=20.3772 | train mmd=0.0110 | test_mmd=0.0116\n",
      "[CellOT] epoch=1950 f_loss=0.0603 g_loss=21.2094 | train mmd=0.0170 | test_mmd=0.0111\n",
      "[CellOT] epoch=2000 f_loss=0.1420 g_loss=21.2758 | train mmd=0.0087 | test_mmd=0.0120\n",
      "[CellOT] Final CellOT MMD: 0.0154\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=0.4997 g_loss=-4.9388 | train mmd=0.3279 | test_mmd=1.2089\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.011974768005255765, 'mmd2_gamma_0.5': 0.03749607887252271, 'mmd2_gamma_1.0': 0.03755981344213538, 'wasserstein_distance': 0.9169394353023502, 'R2_feature_means': 0.9692449204501639}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.3979 g_loss=0.6087 | train mmd=0.5056 | test_mmd=0.3601\n",
      "[CellOT] epoch=100 f_loss=-3.2114 g_loss=3.8713 | train mmd=0.8356 | test_mmd=0.3191\n",
      "[CellOT] epoch=150 f_loss=-5.3053 g_loss=6.5606 | train mmd=0.8119 | test_mmd=0.2710\n",
      "[CellOT] epoch=200 f_loss=-7.2196 g_loss=9.3778 | train mmd=0.8197 | test_mmd=0.2363\n",
      "[CellOT] epoch=250 f_loss=-9.3766 g_loss=12.0459 | train mmd=0.7976 | test_mmd=0.2034\n",
      "[CellOT] epoch=300 f_loss=-11.0129 g_loss=14.1165 | train mmd=0.7492 | test_mmd=0.1708\n",
      "[CellOT] epoch=350 f_loss=-12.6119 g_loss=16.5476 | train mmd=0.7451 | test_mmd=0.1492\n",
      "[CellOT] epoch=400 f_loss=-13.7717 g_loss=19.4390 | train mmd=0.7339 | test_mmd=0.1311\n",
      "[CellOT] epoch=450 f_loss=-14.5482 g_loss=20.9612 | train mmd=0.6964 | test_mmd=0.1118\n",
      "[CellOT] epoch=500 f_loss=-15.4728 g_loss=24.6986 | train mmd=0.6868 | test_mmd=0.0946\n",
      "[CellOT] epoch=550 f_loss=-16.7158 g_loss=24.7242 | train mmd=0.6664 | test_mmd=0.0753\n",
      "[CellOT] epoch=600 f_loss=-16.3769 g_loss=27.1391 | train mmd=0.6066 | test_mmd=0.0589\n",
      "[CellOT] epoch=650 f_loss=-12.0168 g_loss=27.6686 | train mmd=0.5809 | test_mmd=0.0449\n",
      "[CellOT] epoch=700 f_loss=-15.3652 g_loss=29.1673 | train mmd=0.5456 | test_mmd=0.0338\n",
      "[CellOT] epoch=750 f_loss=-9.4710 g_loss=32.0460 | train mmd=0.5072 | test_mmd=0.0238\n",
      "[CellOT] epoch=800 f_loss=-10.5109 g_loss=33.5725 | train mmd=0.4412 | test_mmd=0.0161\n",
      "[CellOT] epoch=850 f_loss=-6.9819 g_loss=32.2775 | train mmd=0.4098 | test_mmd=0.0103\n",
      "[CellOT] epoch=900 f_loss=-5.1899 g_loss=33.8776 | train mmd=0.4488 | test_mmd=0.0069\n",
      "[CellOT] epoch=950 f_loss=0.6657 g_loss=33.0634 | train mmd=0.3951 | test_mmd=0.0053\n",
      "[CellOT] epoch=1000 f_loss=4.7942 g_loss=31.4228 | train mmd=0.3550 | test_mmd=0.0056\n",
      "[CellOT] epoch=1050 f_loss=5.6602 g_loss=23.5084 | train mmd=0.1578 | test_mmd=0.0114\n",
      "[CellOT] epoch=1100 f_loss=1.5260 g_loss=22.9248 | train mmd=0.0638 | test_mmd=0.0186\n",
      "[CellOT] epoch=1150 f_loss=1.7319 g_loss=23.4958 | train mmd=0.0290 | test_mmd=0.0118\n",
      "[CellOT] epoch=1200 f_loss=0.5657 g_loss=23.6404 | train mmd=0.0281 | test_mmd=0.0152\n",
      "[CellOT] epoch=1250 f_loss=2.1171 g_loss=23.8690 | train mmd=0.0409 | test_mmd=0.0080\n",
      "[CellOT] epoch=1300 f_loss=0.4090 g_loss=23.9005 | train mmd=0.0227 | test_mmd=0.0097\n",
      "[CellOT] epoch=1350 f_loss=0.2657 g_loss=24.0900 | train mmd=0.0279 | test_mmd=0.0085\n",
      "[CellOT] epoch=1400 f_loss=-0.4482 g_loss=24.5687 | train mmd=0.0281 | test_mmd=0.0068\n",
      "[CellOT] epoch=1450 f_loss=0.1469 g_loss=24.8320 | train mmd=0.0425 | test_mmd=0.0082\n",
      "[CellOT] epoch=1500 f_loss=-0.5457 g_loss=25.1255 | train mmd=0.0468 | test_mmd=0.0077\n",
      "[CellOT] epoch=1550 f_loss=0.4304 g_loss=24.8820 | train mmd=0.0720 | test_mmd=0.0047\n",
      "[CellOT] epoch=1600 f_loss=-0.0101 g_loss=24.3913 | train mmd=0.0816 | test_mmd=0.0054\n",
      "[CellOT] epoch=1650 f_loss=-0.1912 g_loss=24.8231 | train mmd=0.0613 | test_mmd=0.0064\n",
      "[CellOT] epoch=1700 f_loss=-0.2710 g_loss=25.0343 | train mmd=0.0450 | test_mmd=0.0093\n",
      "[CellOT] epoch=1750 f_loss=0.0130 g_loss=25.0258 | train mmd=0.0408 | test_mmd=0.0080\n",
      "[CellOT] epoch=1800 f_loss=0.2521 g_loss=24.9987 | train mmd=0.0437 | test_mmd=0.0084\n",
      "[CellOT] epoch=1850 f_loss=-0.7201 g_loss=25.5089 | train mmd=0.0393 | test_mmd=0.0063\n",
      "[CellOT] epoch=1900 f_loss=0.1942 g_loss=25.5348 | train mmd=0.0396 | test_mmd=0.0090\n",
      "[CellOT] epoch=1950 f_loss=-0.1974 g_loss=25.8815 | train mmd=0.0329 | test_mmd=0.0096\n",
      "[CellOT] epoch=2000 f_loss=0.2471 g_loss=25.3909 | train mmd=0.0363 | test_mmd=0.0117\n",
      "[CellOT] Final CellOT MMD: 0.0228\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-1.9994 g_loss=-3.9986 | train mmd=0.2866 | test_mmd=1.1232\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.011717563074204351, 'mmd2_gamma_0.5': 0.056059866498167965, 'mmd2_gamma_1.0': 0.060619488182029946, 'wasserstein_distance': 1.2662725656699942, 'R2_feature_means': 0.9693987904344433}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.4834 g_loss=1.1331 | train mmd=0.4954 | test_mmd=0.3413\n",
      "[CellOT] epoch=100 f_loss=-3.2065 g_loss=4.0631 | train mmd=0.8142 | test_mmd=0.3050\n",
      "[CellOT] epoch=150 f_loss=-5.2591 g_loss=6.6355 | train mmd=0.7672 | test_mmd=0.2501\n",
      "[CellOT] epoch=200 f_loss=-7.6198 g_loss=9.0436 | train mmd=0.7967 | test_mmd=0.2251\n",
      "[CellOT] epoch=250 f_loss=-8.9498 g_loss=11.9572 | train mmd=0.7867 | test_mmd=0.1941\n",
      "[CellOT] epoch=300 f_loss=-10.2501 g_loss=14.1167 | train mmd=0.7584 | test_mmd=0.1607\n",
      "[CellOT] epoch=350 f_loss=-12.6073 g_loss=16.1686 | train mmd=0.7317 | test_mmd=0.1386\n",
      "[CellOT] epoch=400 f_loss=-12.9982 g_loss=18.8990 | train mmd=0.7065 | test_mmd=0.1198\n",
      "[CellOT] epoch=450 f_loss=-14.0567 g_loss=19.9923 | train mmd=0.6852 | test_mmd=0.1034\n",
      "[CellOT] epoch=500 f_loss=-14.9656 g_loss=23.7106 | train mmd=0.6676 | test_mmd=0.0889\n",
      "[CellOT] epoch=550 f_loss=-13.7568 g_loss=24.6677 | train mmd=0.6397 | test_mmd=0.0712\n",
      "[CellOT] epoch=600 f_loss=-16.6186 g_loss=26.8500 | train mmd=0.6245 | test_mmd=0.0566\n",
      "[CellOT] epoch=650 f_loss=-13.7636 g_loss=29.2991 | train mmd=0.5901 | test_mmd=0.0453\n",
      "[CellOT] epoch=700 f_loss=-13.9012 g_loss=31.9591 | train mmd=0.5687 | test_mmd=0.0331\n",
      "[CellOT] epoch=750 f_loss=-10.8589 g_loss=34.5570 | train mmd=0.5399 | test_mmd=0.0231\n",
      "[CellOT] epoch=800 f_loss=-9.1068 g_loss=35.2571 | train mmd=0.5082 | test_mmd=0.0158\n",
      "[CellOT] epoch=850 f_loss=-7.0825 g_loss=40.6049 | train mmd=0.5029 | test_mmd=0.0104\n",
      "[CellOT] epoch=900 f_loss=-2.0126 g_loss=40.1897 | train mmd=0.4160 | test_mmd=0.0061\n",
      "[CellOT] epoch=950 f_loss=4.3905 g_loss=33.7370 | train mmd=0.3088 | test_mmd=0.0052\n",
      "[CellOT] epoch=1000 f_loss=3.6096 g_loss=22.3937 | train mmd=0.0601 | test_mmd=0.0257\n",
      "[CellOT] epoch=1050 f_loss=1.4887 g_loss=19.7225 | train mmd=0.0397 | test_mmd=0.0267\n",
      "[CellOT] epoch=1100 f_loss=0.8383 g_loss=18.6185 | train mmd=0.0305 | test_mmd=0.0128\n",
      "[CellOT] epoch=1150 f_loss=1.2058 g_loss=18.5599 | train mmd=0.0661 | test_mmd=0.0094\n",
      "[CellOT] epoch=1200 f_loss=1.2289 g_loss=17.2175 | train mmd=0.1529 | test_mmd=0.0059\n",
      "[CellOT] epoch=1250 f_loss=0.7243 g_loss=16.6318 | train mmd=0.1183 | test_mmd=0.0069\n",
      "[CellOT] epoch=1300 f_loss=0.1410 g_loss=16.4408 | train mmd=0.0983 | test_mmd=0.0102\n",
      "[CellOT] epoch=1350 f_loss=0.1047 g_loss=16.7125 | train mmd=0.0874 | test_mmd=0.0117\n",
      "[CellOT] epoch=1400 f_loss=0.4891 g_loss=16.7594 | train mmd=0.0754 | test_mmd=0.0083\n",
      "[CellOT] epoch=1450 f_loss=-0.5888 g_loss=16.4504 | train mmd=0.0530 | test_mmd=0.0096\n",
      "[CellOT] epoch=1500 f_loss=0.6208 g_loss=16.0694 | train mmd=0.0354 | test_mmd=0.0092\n",
      "[CellOT] epoch=1550 f_loss=0.2577 g_loss=16.5209 | train mmd=0.0388 | test_mmd=0.0083\n",
      "[CellOT] epoch=1600 f_loss=0.0249 g_loss=16.9267 | train mmd=0.0523 | test_mmd=0.0073\n",
      "[CellOT] epoch=1650 f_loss=-0.1782 g_loss=17.0263 | train mmd=0.0775 | test_mmd=0.0100\n",
      "[CellOT] epoch=1700 f_loss=-0.2480 g_loss=16.7917 | train mmd=0.1108 | test_mmd=0.0111\n",
      "[CellOT] epoch=1750 f_loss=-0.2322 g_loss=16.3896 | train mmd=0.1489 | test_mmd=0.0083\n",
      "[CellOT] epoch=1800 f_loss=-0.4508 g_loss=16.6808 | train mmd=0.1408 | test_mmd=0.0090\n",
      "[CellOT] epoch=1850 f_loss=-0.4618 g_loss=16.7895 | train mmd=0.0996 | test_mmd=0.0127\n",
      "[CellOT] epoch=1900 f_loss=-0.6794 g_loss=16.6913 | train mmd=0.0635 | test_mmd=0.0108\n",
      "[CellOT] epoch=1950 f_loss=0.2498 g_loss=17.1612 | train mmd=0.0397 | test_mmd=0.0095\n",
      "[CellOT] epoch=2000 f_loss=0.0012 g_loss=16.9880 | train mmd=0.0118 | test_mmd=0.0126\n",
      "[CellOT] Final CellOT MMD: 0.0169\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=0.7257 g_loss=-3.7189 | train mmd=0.3030 | test_mmd=1.1369\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.012619605053112881, 'mmd2_gamma_0.5': 0.04206133355539565, 'mmd2_gamma_1.0': 0.04099784700912956, 'wasserstein_distance': 0.9948831852889596, 'R2_feature_means': 0.9697192513638287}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.3799 g_loss=0.5641 | train mmd=0.4246 | test_mmd=0.3161\n",
      "[CellOT] epoch=100 f_loss=-3.0357 g_loss=3.7276 | train mmd=0.7686 | test_mmd=0.2965\n",
      "[CellOT] epoch=150 f_loss=-5.0480 g_loss=6.1896 | train mmd=0.7994 | test_mmd=0.2636\n",
      "[CellOT] epoch=200 f_loss=-6.7431 g_loss=8.9348 | train mmd=0.7995 | test_mmd=0.2265\n",
      "[CellOT] epoch=250 f_loss=-8.4641 g_loss=11.2220 | train mmd=0.7432 | test_mmd=0.1872\n",
      "[CellOT] epoch=300 f_loss=-9.8680 g_loss=12.8093 | train mmd=0.7482 | test_mmd=0.1604\n",
      "[CellOT] epoch=350 f_loss=-11.0063 g_loss=15.5604 | train mmd=0.7286 | test_mmd=0.1419\n",
      "[CellOT] epoch=400 f_loss=-13.1607 g_loss=17.8975 | train mmd=0.7082 | test_mmd=0.1195\n",
      "[CellOT] epoch=450 f_loss=-13.8694 g_loss=19.7999 | train mmd=0.6975 | test_mmd=0.1025\n",
      "[CellOT] epoch=500 f_loss=-14.4660 g_loss=22.8025 | train mmd=0.6560 | test_mmd=0.0847\n",
      "[CellOT] epoch=550 f_loss=-12.9768 g_loss=25.4246 | train mmd=0.6583 | test_mmd=0.0719\n",
      "[CellOT] epoch=600 f_loss=-13.1948 g_loss=27.2216 | train mmd=0.5831 | test_mmd=0.0530\n",
      "[CellOT] epoch=650 f_loss=-12.8033 g_loss=27.5251 | train mmd=0.5720 | test_mmd=0.0419\n",
      "[CellOT] epoch=700 f_loss=-11.7990 g_loss=31.3429 | train mmd=0.5632 | test_mmd=0.0308\n",
      "[CellOT] epoch=750 f_loss=-9.6630 g_loss=32.5492 | train mmd=0.5033 | test_mmd=0.0197\n",
      "[CellOT] epoch=800 f_loss=-8.3315 g_loss=35.1384 | train mmd=0.4644 | test_mmd=0.0131\n",
      "[CellOT] epoch=850 f_loss=-3.4590 g_loss=36.2459 | train mmd=0.3930 | test_mmd=0.0080\n",
      "[CellOT] epoch=900 f_loss=0.7032 g_loss=34.4068 | train mmd=0.2924 | test_mmd=0.0060\n",
      "[CellOT] epoch=950 f_loss=4.3692 g_loss=24.5521 | train mmd=0.0714 | test_mmd=0.0161\n",
      "[CellOT] epoch=1000 f_loss=1.8336 g_loss=21.2606 | train mmd=0.0537 | test_mmd=0.0326\n",
      "[CellOT] epoch=1050 f_loss=1.9508 g_loss=20.0540 | train mmd=0.0268 | test_mmd=0.0130\n",
      "[CellOT] epoch=1100 f_loss=0.9082 g_loss=20.9406 | train mmd=0.0304 | test_mmd=0.0114\n",
      "[CellOT] epoch=1150 f_loss=0.7483 g_loss=21.2669 | train mmd=0.0251 | test_mmd=0.0121\n",
      "[CellOT] epoch=1200 f_loss=1.1223 g_loss=21.7545 | train mmd=0.0484 | test_mmd=0.0107\n",
      "[CellOT] epoch=1250 f_loss=1.3089 g_loss=21.2962 | train mmd=0.0421 | test_mmd=0.0109\n",
      "[CellOT] epoch=1300 f_loss=1.0343 g_loss=21.8477 | train mmd=0.0286 | test_mmd=0.0091\n",
      "[CellOT] epoch=1350 f_loss=-0.3195 g_loss=21.7063 | train mmd=0.0222 | test_mmd=0.0100\n",
      "[CellOT] epoch=1400 f_loss=0.7948 g_loss=21.4489 | train mmd=0.0239 | test_mmd=0.0141\n",
      "[CellOT] epoch=1450 f_loss=0.1690 g_loss=20.8725 | train mmd=0.0338 | test_mmd=0.0122\n",
      "[CellOT] epoch=1500 f_loss=0.7075 g_loss=19.8445 | train mmd=0.0585 | test_mmd=0.0109\n",
      "[CellOT] epoch=1550 f_loss=0.3440 g_loss=20.4299 | train mmd=0.0516 | test_mmd=0.0112\n",
      "[CellOT] epoch=1600 f_loss=-0.6585 g_loss=20.5349 | train mmd=0.0377 | test_mmd=0.0104\n",
      "[CellOT] epoch=1650 f_loss=-0.2009 g_loss=21.1007 | train mmd=0.0235 | test_mmd=0.0092\n",
      "[CellOT] epoch=1700 f_loss=-0.5365 g_loss=21.2779 | train mmd=0.0261 | test_mmd=0.0106\n",
      "[CellOT] epoch=1750 f_loss=-0.3393 g_loss=21.5776 | train mmd=0.0178 | test_mmd=0.0118\n",
      "[CellOT] epoch=1800 f_loss=0.1970 g_loss=21.0122 | train mmd=0.0202 | test_mmd=0.0151\n",
      "[CellOT] epoch=1850 f_loss=-0.0084 g_loss=21.2991 | train mmd=0.0253 | test_mmd=0.0130\n",
      "[CellOT] epoch=1900 f_loss=0.0350 g_loss=20.8710 | train mmd=0.0246 | test_mmd=0.0127\n",
      "[CellOT] epoch=1950 f_loss=0.2009 g_loss=20.7257 | train mmd=0.0289 | test_mmd=0.0105\n",
      "[CellOT] epoch=2000 f_loss=0.3847 g_loss=20.6181 | train mmd=0.0201 | test_mmd=0.0119\n",
      "[CellOT] Final CellOT MMD: 0.0216\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=1.1708 g_loss=-7.6402 | train mmd=0.2647 | test_mmd=1.4262\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.011873078409934346, 'mmd2_gamma_0.5': 0.05069262521408435, 'mmd2_gamma_1.0': 0.05850707190643101, 'wasserstein_distance': 0.9632730002612226, 'R2_feature_means': 0.9709812799410513}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.6534 g_loss=0.2791 | train mmd=0.3951 | test_mmd=0.3887\n",
      "[CellOT] epoch=100 f_loss=-3.0799 g_loss=3.4215 | train mmd=0.8316 | test_mmd=0.3236\n",
      "[CellOT] epoch=150 f_loss=-4.9858 g_loss=6.2069 | train mmd=0.8527 | test_mmd=0.2886\n",
      "[CellOT] epoch=200 f_loss=-6.8918 g_loss=7.9908 | train mmd=0.7643 | test_mmd=0.2359\n",
      "[CellOT] epoch=250 f_loss=-8.4558 g_loss=10.6201 | train mmd=0.7485 | test_mmd=0.2020\n",
      "[CellOT] epoch=300 f_loss=-9.6034 g_loss=12.9092 | train mmd=0.7515 | test_mmd=0.1758\n",
      "[CellOT] epoch=350 f_loss=-11.9614 g_loss=15.0368 | train mmd=0.7584 | test_mmd=0.1566\n",
      "[CellOT] epoch=400 f_loss=-12.5062 g_loss=17.1991 | train mmd=0.7356 | test_mmd=0.1311\n",
      "[CellOT] epoch=450 f_loss=-13.6564 g_loss=20.2544 | train mmd=0.7236 | test_mmd=0.1082\n",
      "[CellOT] epoch=500 f_loss=-14.1402 g_loss=21.6458 | train mmd=0.6865 | test_mmd=0.0889\n",
      "[CellOT] epoch=550 f_loss=-12.9769 g_loss=23.7082 | train mmd=0.6684 | test_mmd=0.0741\n",
      "[CellOT] epoch=600 f_loss=-13.6817 g_loss=23.8068 | train mmd=0.6080 | test_mmd=0.0542\n",
      "[CellOT] epoch=650 f_loss=-15.9919 g_loss=26.5802 | train mmd=0.5671 | test_mmd=0.0421\n",
      "[CellOT] epoch=700 f_loss=-12.5183 g_loss=26.0325 | train mmd=0.5172 | test_mmd=0.0297\n",
      "[CellOT] epoch=750 f_loss=-9.2732 g_loss=28.8610 | train mmd=0.4880 | test_mmd=0.0206\n",
      "[CellOT] epoch=800 f_loss=-7.7829 g_loss=31.3763 | train mmd=0.4848 | test_mmd=0.0144\n",
      "[CellOT] epoch=850 f_loss=-6.2252 g_loss=31.1256 | train mmd=0.4295 | test_mmd=0.0085\n",
      "[CellOT] epoch=900 f_loss=-2.4325 g_loss=31.5851 | train mmd=0.3509 | test_mmd=0.0053\n",
      "[CellOT] epoch=950 f_loss=3.7132 g_loss=19.8088 | train mmd=0.1695 | test_mmd=0.0085\n",
      "[CellOT] epoch=1000 f_loss=4.0843 g_loss=16.2791 | train mmd=0.1031 | test_mmd=0.0153\n",
      "[CellOT] epoch=1050 f_loss=1.1641 g_loss=15.8626 | train mmd=0.0453 | test_mmd=0.0171\n",
      "[CellOT] epoch=1100 f_loss=1.2887 g_loss=15.7754 | train mmd=0.0609 | test_mmd=0.0105\n",
      "[CellOT] epoch=1150 f_loss=0.2445 g_loss=16.8260 | train mmd=0.0512 | test_mmd=0.0093\n",
      "[CellOT] epoch=1200 f_loss=0.4653 g_loss=17.5358 | train mmd=0.0476 | test_mmd=0.0087\n",
      "[CellOT] epoch=1250 f_loss=0.3728 g_loss=18.3764 | train mmd=0.0434 | test_mmd=0.0084\n",
      "[CellOT] epoch=1300 f_loss=0.1572 g_loss=18.5600 | train mmd=0.0347 | test_mmd=0.0130\n",
      "[CellOT] epoch=1350 f_loss=0.3446 g_loss=17.6080 | train mmd=0.0293 | test_mmd=0.0116\n",
      "[CellOT] epoch=1400 f_loss=0.5163 g_loss=17.8260 | train mmd=0.0220 | test_mmd=0.0116\n",
      "[CellOT] epoch=1450 f_loss=-0.1586 g_loss=16.8351 | train mmd=0.0276 | test_mmd=0.0099\n",
      "[CellOT] epoch=1500 f_loss=0.2181 g_loss=16.7563 | train mmd=0.0295 | test_mmd=0.0127\n",
      "[CellOT] epoch=1550 f_loss=0.2485 g_loss=16.0944 | train mmd=0.0283 | test_mmd=0.0106\n",
      "[CellOT] epoch=1600 f_loss=0.1249 g_loss=15.8059 | train mmd=0.0387 | test_mmd=0.0109\n",
      "[CellOT] epoch=1650 f_loss=-0.0626 g_loss=15.6120 | train mmd=0.0401 | test_mmd=0.0118\n",
      "[CellOT] epoch=1700 f_loss=0.1055 g_loss=15.3533 | train mmd=0.0287 | test_mmd=0.0093\n",
      "[CellOT] epoch=1750 f_loss=-0.3570 g_loss=15.3585 | train mmd=0.0274 | test_mmd=0.0120\n",
      "[CellOT] epoch=1800 f_loss=0.2419 g_loss=15.0170 | train mmd=0.0182 | test_mmd=0.0101\n",
      "[CellOT] epoch=1850 f_loss=0.4028 g_loss=14.8330 | train mmd=0.0126 | test_mmd=0.0130\n",
      "[CellOT] epoch=1900 f_loss=-0.3202 g_loss=14.3551 | train mmd=0.0162 | test_mmd=0.0110\n",
      "[CellOT] epoch=1950 f_loss=-0.5995 g_loss=13.9468 | train mmd=0.0149 | test_mmd=0.0083\n",
      "[CellOT] epoch=2000 f_loss=-0.6991 g_loss=13.9727 | train mmd=0.0162 | test_mmd=0.0102\n",
      "[CellOT] Final CellOT MMD: 0.0172\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=1.3442 g_loss=-6.1002 | train mmd=0.3164 | test_mmd=1.3839\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.010183332166564973, 'mmd2_gamma_0.5': 0.04420087201440037, 'mmd2_gamma_1.0': 0.04615319977356974, 'wasserstein_distance': 0.9197484079052509, 'R2_feature_means': 0.9741948634641144}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.3310 g_loss=0.3071 | train mmd=0.4303 | test_mmd=0.3665\n",
      "[CellOT] epoch=100 f_loss=-3.6145 g_loss=4.0326 | train mmd=0.8201 | test_mmd=0.3253\n",
      "[CellOT] epoch=150 f_loss=-5.9080 g_loss=6.9289 | train mmd=0.8527 | test_mmd=0.2967\n",
      "[CellOT] epoch=200 f_loss=-8.0509 g_loss=10.1118 | train mmd=0.8301 | test_mmd=0.2549\n",
      "[CellOT] epoch=250 f_loss=-9.6811 g_loss=12.5602 | train mmd=0.7964 | test_mmd=0.2200\n",
      "[CellOT] epoch=300 f_loss=-11.3884 g_loss=14.7141 | train mmd=0.7965 | test_mmd=0.1970\n",
      "[CellOT] epoch=350 f_loss=-13.2771 g_loss=17.5034 | train mmd=0.7681 | test_mmd=0.1715\n",
      "[CellOT] epoch=400 f_loss=-14.9613 g_loss=20.5971 | train mmd=0.7549 | test_mmd=0.1445\n",
      "[CellOT] epoch=450 f_loss=-16.8022 g_loss=23.1300 | train mmd=0.7310 | test_mmd=0.1242\n",
      "[CellOT] epoch=500 f_loss=-16.3846 g_loss=25.0820 | train mmd=0.6979 | test_mmd=0.1055\n",
      "[CellOT] epoch=550 f_loss=-16.5755 g_loss=27.6784 | train mmd=0.6829 | test_mmd=0.0919\n",
      "[CellOT] epoch=600 f_loss=-19.8075 g_loss=30.1450 | train mmd=0.6424 | test_mmd=0.0726\n",
      "[CellOT] epoch=650 f_loss=-16.6996 g_loss=31.7847 | train mmd=0.6311 | test_mmd=0.0583\n",
      "[CellOT] epoch=700 f_loss=-16.5203 g_loss=34.6975 | train mmd=0.6055 | test_mmd=0.0462\n",
      "[CellOT] epoch=750 f_loss=-15.3240 g_loss=39.1796 | train mmd=0.5926 | test_mmd=0.0349\n",
      "[CellOT] epoch=800 f_loss=-15.4498 g_loss=39.1395 | train mmd=0.5345 | test_mmd=0.0242\n",
      "[CellOT] epoch=850 f_loss=-9.1017 g_loss=39.9431 | train mmd=0.4879 | test_mmd=0.0162\n",
      "[CellOT] epoch=900 f_loss=-4.0761 g_loss=38.2754 | train mmd=0.4298 | test_mmd=0.0106\n",
      "[CellOT] epoch=950 f_loss=-1.6484 g_loss=40.4504 | train mmd=0.3670 | test_mmd=0.0075\n",
      "[CellOT] epoch=1000 f_loss=2.8012 g_loss=36.1942 | train mmd=0.3643 | test_mmd=0.0057\n",
      "[CellOT] epoch=1050 f_loss=7.1112 g_loss=30.4559 | train mmd=0.2131 | test_mmd=0.0083\n",
      "[CellOT] epoch=1100 f_loss=3.2253 g_loss=26.0262 | train mmd=0.0494 | test_mmd=0.0247\n",
      "[CellOT] epoch=1150 f_loss=2.0026 g_loss=23.5594 | train mmd=0.0273 | test_mmd=0.0200\n",
      "[CellOT] epoch=1200 f_loss=1.5455 g_loss=23.5456 | train mmd=0.0232 | test_mmd=0.0162\n",
      "[CellOT] epoch=1250 f_loss=1.0152 g_loss=23.3811 | train mmd=0.0182 | test_mmd=0.0149\n",
      "[CellOT] epoch=1300 f_loss=0.4381 g_loss=23.3346 | train mmd=0.0178 | test_mmd=0.0130\n",
      "[CellOT] epoch=1350 f_loss=0.3330 g_loss=23.1557 | train mmd=0.0192 | test_mmd=0.0127\n",
      "[CellOT] epoch=1400 f_loss=0.3943 g_loss=22.6785 | train mmd=0.0278 | test_mmd=0.0127\n",
      "[CellOT] epoch=1450 f_loss=0.1135 g_loss=22.6865 | train mmd=0.0242 | test_mmd=0.0122\n",
      "[CellOT] epoch=1500 f_loss=0.3257 g_loss=22.3904 | train mmd=0.0268 | test_mmd=0.0107\n",
      "[CellOT] epoch=1550 f_loss=0.0966 g_loss=22.3254 | train mmd=0.0320 | test_mmd=0.0094\n",
      "[CellOT] epoch=1600 f_loss=-0.4256 g_loss=22.1937 | train mmd=0.0276 | test_mmd=0.0102\n",
      "[CellOT] epoch=1650 f_loss=0.5388 g_loss=22.0228 | train mmd=0.0222 | test_mmd=0.0099\n",
      "[CellOT] epoch=1700 f_loss=-0.4427 g_loss=22.0838 | train mmd=0.0131 | test_mmd=0.0107\n",
      "[CellOT] epoch=1750 f_loss=0.2784 g_loss=21.7573 | train mmd=0.0158 | test_mmd=0.0142\n",
      "[CellOT] epoch=1800 f_loss=-0.4149 g_loss=22.0290 | train mmd=0.0167 | test_mmd=0.0160\n",
      "[CellOT] epoch=1850 f_loss=-0.1065 g_loss=21.7631 | train mmd=0.0130 | test_mmd=0.0114\n",
      "[CellOT] epoch=1900 f_loss=-0.4267 g_loss=21.5358 | train mmd=0.0135 | test_mmd=0.0121\n",
      "[CellOT] epoch=1950 f_loss=-0.0230 g_loss=21.3418 | train mmd=0.0160 | test_mmd=0.0115\n",
      "[CellOT] epoch=2000 f_loss=-0.2280 g_loss=21.4330 | train mmd=0.0166 | test_mmd=0.0092\n",
      "[CellOT] Final CellOT MMD: 0.0165\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-0.0061 g_loss=-4.2160 | train mmd=0.2714 | test_mmd=1.2802\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.009219630981491367, 'mmd2_gamma_0.5': 0.04191731860182879, 'mmd2_gamma_1.0': 0.044672810944597685, 'wasserstein_distance': 0.9980348884895028, 'R2_feature_means': 0.9758734250137332}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.9125 g_loss=0.9253 | train mmd=0.5177 | test_mmd=0.3162\n",
      "[CellOT] epoch=100 f_loss=-3.2321 g_loss=3.8896 | train mmd=0.7952 | test_mmd=0.3025\n",
      "[CellOT] epoch=150 f_loss=-5.5526 g_loss=6.7134 | train mmd=0.8127 | test_mmd=0.2698\n",
      "[CellOT] epoch=200 f_loss=-7.4491 g_loss=8.9222 | train mmd=0.8081 | test_mmd=0.2370\n",
      "[CellOT] epoch=250 f_loss=-9.0375 g_loss=11.4979 | train mmd=0.8027 | test_mmd=0.2060\n",
      "[CellOT] epoch=300 f_loss=-10.8369 g_loss=13.7023 | train mmd=0.7956 | test_mmd=0.1744\n",
      "[CellOT] epoch=350 f_loss=-11.2778 g_loss=15.8363 | train mmd=0.7496 | test_mmd=0.1426\n",
      "[CellOT] epoch=400 f_loss=-14.0033 g_loss=17.8716 | train mmd=0.7218 | test_mmd=0.1220\n",
      "[CellOT] epoch=450 f_loss=-13.2127 g_loss=21.4990 | train mmd=0.7182 | test_mmd=0.1076\n",
      "[CellOT] epoch=500 f_loss=-15.3856 g_loss=23.1831 | train mmd=0.6689 | test_mmd=0.0884\n",
      "[CellOT] epoch=550 f_loss=-14.9792 g_loss=23.9238 | train mmd=0.6375 | test_mmd=0.0715\n",
      "[CellOT] epoch=600 f_loss=-14.2441 g_loss=25.9103 | train mmd=0.5985 | test_mmd=0.0532\n",
      "[CellOT] epoch=650 f_loss=-15.0836 g_loss=28.2237 | train mmd=0.5780 | test_mmd=0.0424\n",
      "[CellOT] epoch=700 f_loss=-12.4845 g_loss=27.5971 | train mmd=0.5271 | test_mmd=0.0300\n",
      "[CellOT] epoch=750 f_loss=-9.4964 g_loss=29.1991 | train mmd=0.4653 | test_mmd=0.0225\n",
      "[CellOT] epoch=800 f_loss=-6.8477 g_loss=31.1625 | train mmd=0.4411 | test_mmd=0.0145\n",
      "[CellOT] epoch=850 f_loss=-1.0626 g_loss=28.5400 | train mmd=0.3472 | test_mmd=0.0078\n",
      "[CellOT] epoch=900 f_loss=-1.4466 g_loss=27.7412 | train mmd=0.3187 | test_mmd=0.0055\n",
      "[CellOT] epoch=950 f_loss=3.3889 g_loss=24.1646 | train mmd=0.2460 | test_mmd=0.0060\n",
      "[CellOT] epoch=1000 f_loss=4.1282 g_loss=22.7592 | train mmd=0.1473 | test_mmd=0.0103\n",
      "[CellOT] epoch=1050 f_loss=1.6649 g_loss=21.6486 | train mmd=0.0330 | test_mmd=0.0234\n",
      "[CellOT] epoch=1100 f_loss=1.8609 g_loss=21.6789 | train mmd=0.0255 | test_mmd=0.0169\n",
      "[CellOT] epoch=1150 f_loss=0.3723 g_loss=22.4683 | train mmd=0.0236 | test_mmd=0.0128\n",
      "[CellOT] epoch=1200 f_loss=-0.1646 g_loss=23.6926 | train mmd=0.0228 | test_mmd=0.0105\n",
      "[CellOT] epoch=1250 f_loss=-0.1927 g_loss=23.9778 | train mmd=0.0421 | test_mmd=0.0109\n",
      "[CellOT] epoch=1300 f_loss=-0.1575 g_loss=24.5953 | train mmd=0.0394 | test_mmd=0.0071\n",
      "[CellOT] epoch=1350 f_loss=0.8356 g_loss=24.4572 | train mmd=0.0348 | test_mmd=0.0085\n",
      "[CellOT] epoch=1400 f_loss=-0.1661 g_loss=24.1175 | train mmd=0.0343 | test_mmd=0.0091\n",
      "[CellOT] epoch=1450 f_loss=0.4787 g_loss=23.6902 | train mmd=0.0314 | test_mmd=0.0105\n",
      "[CellOT] epoch=1500 f_loss=-0.2102 g_loss=23.8743 | train mmd=0.0297 | test_mmd=0.0137\n",
      "[CellOT] epoch=1550 f_loss=-0.0199 g_loss=23.3099 | train mmd=0.0426 | test_mmd=0.0088\n",
      "[CellOT] epoch=1600 f_loss=-0.1621 g_loss=22.6944 | train mmd=0.0574 | test_mmd=0.0086\n",
      "[CellOT] epoch=1650 f_loss=-0.5297 g_loss=22.4257 | train mmd=0.0532 | test_mmd=0.0093\n",
      "[CellOT] epoch=1700 f_loss=-0.0097 g_loss=21.7199 | train mmd=0.0247 | test_mmd=0.0141\n",
      "[CellOT] epoch=1750 f_loss=0.3338 g_loss=21.7835 | train mmd=0.0174 | test_mmd=0.0138\n",
      "[CellOT] epoch=1800 f_loss=-0.2070 g_loss=21.9595 | train mmd=0.0174 | test_mmd=0.0082\n",
      "[CellOT] epoch=1850 f_loss=-0.0462 g_loss=22.1059 | train mmd=0.0093 | test_mmd=0.0119\n",
      "[CellOT] epoch=1900 f_loss=0.1233 g_loss=22.5134 | train mmd=0.0133 | test_mmd=0.0155\n",
      "[CellOT] epoch=1950 f_loss=0.0893 g_loss=22.4373 | train mmd=0.0086 | test_mmd=0.0101\n",
      "[CellOT] epoch=2000 f_loss=0.4265 g_loss=21.9811 | train mmd=0.0088 | test_mmd=0.0097\n",
      "[CellOT] Final CellOT MMD: 0.0148\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-0.4836 g_loss=-2.6053 | train mmd=0.2838 | test_mmd=1.0677\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.009715129917866383, 'mmd2_gamma_0.5': 0.03793247109814413, 'mmd2_gamma_1.0': 0.0386244964036484, 'wasserstein_distance': 0.89046584878408, 'R2_feature_means': 0.9763622616022593}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.0884 g_loss=1.1097 | train mmd=0.5987 | test_mmd=0.3382\n",
      "[CellOT] epoch=100 f_loss=-3.8184 g_loss=4.1774 | train mmd=0.8388 | test_mmd=0.3126\n",
      "[CellOT] epoch=150 f_loss=-5.6068 g_loss=6.7136 | train mmd=0.8332 | test_mmd=0.2722\n",
      "[CellOT] epoch=200 f_loss=-7.7163 g_loss=9.6934 | train mmd=0.8182 | test_mmd=0.2341\n",
      "[CellOT] epoch=250 f_loss=-10.0906 g_loss=12.3028 | train mmd=0.7930 | test_mmd=0.1991\n",
      "[CellOT] epoch=300 f_loss=-10.9758 g_loss=15.7903 | train mmd=0.7586 | test_mmd=0.1677\n",
      "[CellOT] epoch=350 f_loss=-12.7717 g_loss=17.0455 | train mmd=0.7461 | test_mmd=0.1456\n",
      "[CellOT] epoch=400 f_loss=-13.3660 g_loss=19.7713 | train mmd=0.7316 | test_mmd=0.1255\n",
      "[CellOT] epoch=450 f_loss=-15.8717 g_loss=21.5395 | train mmd=0.7101 | test_mmd=0.1067\n",
      "[CellOT] epoch=500 f_loss=-15.5271 g_loss=25.0244 | train mmd=0.6775 | test_mmd=0.0915\n",
      "[CellOT] epoch=550 f_loss=-14.4032 g_loss=26.7356 | train mmd=0.6308 | test_mmd=0.0750\n",
      "[CellOT] epoch=600 f_loss=-15.3170 g_loss=29.5598 | train mmd=0.6107 | test_mmd=0.0607\n",
      "[CellOT] epoch=650 f_loss=-13.8343 g_loss=32.8033 | train mmd=0.6018 | test_mmd=0.0475\n",
      "[CellOT] epoch=700 f_loss=-12.5794 g_loss=30.1884 | train mmd=0.5237 | test_mmd=0.0346\n",
      "[CellOT] epoch=750 f_loss=-10.9611 g_loss=33.9412 | train mmd=0.5221 | test_mmd=0.0241\n",
      "[CellOT] epoch=800 f_loss=-6.9600 g_loss=34.4461 | train mmd=0.4744 | test_mmd=0.0154\n",
      "[CellOT] epoch=850 f_loss=-3.0495 g_loss=36.6647 | train mmd=0.4528 | test_mmd=0.0104\n",
      "[CellOT] epoch=900 f_loss=-1.2424 g_loss=38.9114 | train mmd=0.4501 | test_mmd=0.0069\n",
      "[CellOT] epoch=950 f_loss=2.7223 g_loss=36.9695 | train mmd=0.3954 | test_mmd=0.0049\n",
      "[CellOT] epoch=1000 f_loss=6.6520 g_loss=30.6525 | train mmd=0.1991 | test_mmd=0.0081\n",
      "[CellOT] epoch=1050 f_loss=2.7848 g_loss=23.4719 | train mmd=0.0341 | test_mmd=0.0227\n",
      "[CellOT] epoch=1100 f_loss=2.0515 g_loss=22.6456 | train mmd=0.0252 | test_mmd=0.0200\n",
      "[CellOT] epoch=1150 f_loss=0.9344 g_loss=23.2189 | train mmd=0.0360 | test_mmd=0.0184\n",
      "[CellOT] epoch=1200 f_loss=1.5749 g_loss=22.5925 | train mmd=0.0333 | test_mmd=0.0142\n",
      "[CellOT] epoch=1250 f_loss=0.9752 g_loss=22.2913 | train mmd=0.0644 | test_mmd=0.0140\n",
      "[CellOT] epoch=1300 f_loss=1.0211 g_loss=22.1933 | train mmd=0.0488 | test_mmd=0.0113\n",
      "[CellOT] epoch=1350 f_loss=0.4504 g_loss=21.9766 | train mmd=0.0471 | test_mmd=0.0121\n",
      "[CellOT] epoch=1400 f_loss=0.1050 g_loss=22.4966 | train mmd=0.0550 | test_mmd=0.0082\n",
      "[CellOT] epoch=1450 f_loss=-0.4552 g_loss=22.6360 | train mmd=0.0560 | test_mmd=0.0077\n",
      "[CellOT] epoch=1500 f_loss=-0.3640 g_loss=22.8616 | train mmd=0.0432 | test_mmd=0.0091\n",
      "[CellOT] epoch=1550 f_loss=-0.2045 g_loss=23.6583 | train mmd=0.0450 | test_mmd=0.0068\n",
      "[CellOT] epoch=1600 f_loss=0.6987 g_loss=23.4412 | train mmd=0.0595 | test_mmd=0.0075\n",
      "[CellOT] epoch=1650 f_loss=-0.1077 g_loss=24.3462 | train mmd=0.0341 | test_mmd=0.0081\n",
      "[CellOT] epoch=1700 f_loss=-0.6893 g_loss=24.0978 | train mmd=0.0333 | test_mmd=0.0074\n",
      "[CellOT] epoch=1750 f_loss=-0.4745 g_loss=24.2225 | train mmd=0.0258 | test_mmd=0.0094\n",
      "[CellOT] epoch=1800 f_loss=0.1333 g_loss=23.8715 | train mmd=0.0286 | test_mmd=0.0111\n",
      "[CellOT] epoch=1850 f_loss=0.1111 g_loss=24.1267 | train mmd=0.0454 | test_mmd=0.0121\n",
      "[CellOT] epoch=1900 f_loss=-0.0435 g_loss=23.8084 | train mmd=0.0595 | test_mmd=0.0145\n",
      "[CellOT] epoch=1950 f_loss=-0.0219 g_loss=23.4196 | train mmd=0.0784 | test_mmd=0.0109\n",
      "[CellOT] epoch=2000 f_loss=0.0416 g_loss=23.1615 | train mmd=0.0828 | test_mmd=0.0095\n",
      "[CellOT] Final CellOT MMD: 0.0341\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=0.9837 g_loss=-4.9219 | train mmd=0.2956 | test_mmd=1.2924\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.009545201709206141, 'mmd2_gamma_0.5': 0.06702351092850656, 'mmd2_gamma_1.0': 0.08734033264303981, 'wasserstein_distance': 1.3370019432437292, 'R2_feature_means': 0.9715793028932491}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.9542 g_loss=0.7421 | train mmd=0.5160 | test_mmd=0.3403\n",
      "[CellOT] epoch=100 f_loss=-3.1967 g_loss=3.7322 | train mmd=0.8238 | test_mmd=0.3094\n",
      "[CellOT] epoch=150 f_loss=-5.3500 g_loss=6.9672 | train mmd=0.8162 | test_mmd=0.2680\n",
      "[CellOT] epoch=200 f_loss=-7.4936 g_loss=9.4294 | train mmd=0.7899 | test_mmd=0.2332\n",
      "[CellOT] epoch=250 f_loss=-8.8998 g_loss=11.8366 | train mmd=0.7981 | test_mmd=0.1994\n",
      "[CellOT] epoch=300 f_loss=-10.8129 g_loss=13.8755 | train mmd=0.7682 | test_mmd=0.1635\n",
      "[CellOT] epoch=350 f_loss=-12.0830 g_loss=15.8676 | train mmd=0.7491 | test_mmd=0.1411\n",
      "[CellOT] epoch=400 f_loss=-13.9018 g_loss=18.7298 | train mmd=0.7268 | test_mmd=0.1212\n",
      "[CellOT] epoch=450 f_loss=-14.2161 g_loss=21.3142 | train mmd=0.7025 | test_mmd=0.1028\n",
      "[CellOT] epoch=500 f_loss=-14.0816 g_loss=23.1527 | train mmd=0.6646 | test_mmd=0.0832\n",
      "[CellOT] epoch=550 f_loss=-14.9793 g_loss=26.6132 | train mmd=0.6614 | test_mmd=0.0725\n",
      "[CellOT] epoch=600 f_loss=-14.4146 g_loss=26.9715 | train mmd=0.6065 | test_mmd=0.0536\n",
      "[CellOT] epoch=650 f_loss=-13.1667 g_loss=27.3100 | train mmd=0.5770 | test_mmd=0.0416\n",
      "[CellOT] epoch=700 f_loss=-13.3443 g_loss=29.4784 | train mmd=0.5380 | test_mmd=0.0314\n",
      "[CellOT] epoch=750 f_loss=-10.3696 g_loss=32.0290 | train mmd=0.5288 | test_mmd=0.0220\n",
      "[CellOT] epoch=800 f_loss=-9.8312 g_loss=32.7204 | train mmd=0.4906 | test_mmd=0.0151\n",
      "[CellOT] epoch=850 f_loss=-5.7383 g_loss=34.3543 | train mmd=0.4693 | test_mmd=0.0103\n",
      "[CellOT] epoch=900 f_loss=-3.7186 g_loss=36.8072 | train mmd=0.4266 | test_mmd=0.0062\n",
      "[CellOT] epoch=950 f_loss=1.2642 g_loss=35.6430 | train mmd=0.3987 | test_mmd=0.0054\n",
      "[CellOT] epoch=1000 f_loss=3.1483 g_loss=31.6044 | train mmd=0.3060 | test_mmd=0.0066\n",
      "[CellOT] epoch=1050 f_loss=6.6065 g_loss=22.1804 | train mmd=0.2002 | test_mmd=0.0125\n",
      "[CellOT] epoch=1100 f_loss=2.1251 g_loss=21.3230 | train mmd=0.0417 | test_mmd=0.0239\n",
      "[CellOT] epoch=1150 f_loss=1.0475 g_loss=21.1576 | train mmd=0.0260 | test_mmd=0.0174\n",
      "[CellOT] epoch=1200 f_loss=0.2747 g_loss=21.6573 | train mmd=0.0266 | test_mmd=0.0111\n",
      "[CellOT] epoch=1250 f_loss=0.8457 g_loss=21.9061 | train mmd=0.0304 | test_mmd=0.0119\n",
      "[CellOT] epoch=1300 f_loss=0.3128 g_loss=21.1932 | train mmd=0.0179 | test_mmd=0.0116\n",
      "[CellOT] epoch=1350 f_loss=0.3489 g_loss=21.0031 | train mmd=0.0202 | test_mmd=0.0125\n",
      "[CellOT] epoch=1400 f_loss=0.3167 g_loss=21.2279 | train mmd=0.0187 | test_mmd=0.0109\n",
      "[CellOT] epoch=1450 f_loss=-0.2804 g_loss=20.9501 | train mmd=0.0237 | test_mmd=0.0095\n",
      "[CellOT] epoch=1500 f_loss=0.1715 g_loss=20.8596 | train mmd=0.0338 | test_mmd=0.0094\n",
      "[CellOT] epoch=1550 f_loss=-0.2399 g_loss=20.8346 | train mmd=0.0462 | test_mmd=0.0097\n",
      "[CellOT] epoch=1600 f_loss=0.1442 g_loss=20.6752 | train mmd=0.0625 | test_mmd=0.0076\n",
      "[CellOT] epoch=1650 f_loss=-0.3225 g_loss=20.3239 | train mmd=0.0660 | test_mmd=0.0083\n",
      "[CellOT] epoch=1700 f_loss=0.1365 g_loss=20.5181 | train mmd=0.0605 | test_mmd=0.0091\n",
      "[CellOT] epoch=1750 f_loss=-0.2421 g_loss=21.0873 | train mmd=0.0455 | test_mmd=0.0118\n",
      "[CellOT] epoch=1800 f_loss=-0.6219 g_loss=21.4775 | train mmd=0.0268 | test_mmd=0.0088\n",
      "[CellOT] epoch=1850 f_loss=0.0622 g_loss=21.3095 | train mmd=0.0214 | test_mmd=0.0126\n",
      "[CellOT] epoch=1900 f_loss=-0.0024 g_loss=21.4958 | train mmd=0.0166 | test_mmd=0.0128\n",
      "[CellOT] epoch=1950 f_loss=-0.5872 g_loss=21.2973 | train mmd=0.0158 | test_mmd=0.0122\n",
      "[CellOT] epoch=2000 f_loss=-0.4521 g_loss=20.8391 | train mmd=0.0162 | test_mmd=0.0126\n",
      "[CellOT] Final CellOT MMD: 0.0198\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-1.6726 g_loss=-6.5952 | train mmd=0.2972 | test_mmd=1.5229\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.012599537773329672, 'mmd2_gamma_0.5': 0.051839285821891457, 'mmd2_gamma_1.0': 0.05196938131985357, 'wasserstein_distance': 1.0126212255705243, 'R2_feature_means': 0.9671208053549873}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.8569 g_loss=0.4431 | train mmd=0.5439 | test_mmd=0.3389\n",
      "[CellOT] epoch=100 f_loss=-3.3740 g_loss=3.5839 | train mmd=0.7291 | test_mmd=0.3096\n",
      "[CellOT] epoch=150 f_loss=-5.3141 g_loss=6.2404 | train mmd=0.7823 | test_mmd=0.2683\n",
      "[CellOT] epoch=200 f_loss=-7.0276 g_loss=8.8921 | train mmd=0.7812 | test_mmd=0.2385\n",
      "[CellOT] epoch=250 f_loss=-8.4843 g_loss=11.0444 | train mmd=0.7508 | test_mmd=0.1976\n",
      "[CellOT] epoch=300 f_loss=-11.0492 g_loss=13.0815 | train mmd=0.7624 | test_mmd=0.1748\n",
      "[CellOT] epoch=350 f_loss=-11.8114 g_loss=15.9575 | train mmd=0.7650 | test_mmd=0.1569\n",
      "[CellOT] epoch=400 f_loss=-13.0578 g_loss=18.4284 | train mmd=0.7413 | test_mmd=0.1350\n",
      "[CellOT] epoch=450 f_loss=-14.6114 g_loss=20.3688 | train mmd=0.7157 | test_mmd=0.1126\n",
      "[CellOT] epoch=500 f_loss=-15.2726 g_loss=22.9023 | train mmd=0.7028 | test_mmd=0.0992\n",
      "[CellOT] epoch=550 f_loss=-14.7754 g_loss=26.1691 | train mmd=0.6770 | test_mmd=0.0830\n",
      "[CellOT] epoch=600 f_loss=-16.1841 g_loss=26.0853 | train mmd=0.6140 | test_mmd=0.0623\n",
      "[CellOT] epoch=650 f_loss=-14.9406 g_loss=30.1376 | train mmd=0.5864 | test_mmd=0.0476\n",
      "[CellOT] epoch=700 f_loss=-13.7382 g_loss=27.4253 | train mmd=0.5238 | test_mmd=0.0341\n",
      "[CellOT] epoch=750 f_loss=-14.9443 g_loss=31.6893 | train mmd=0.5195 | test_mmd=0.0252\n",
      "[CellOT] epoch=800 f_loss=-6.4305 g_loss=30.2774 | train mmd=0.4637 | test_mmd=0.0165\n",
      "[CellOT] epoch=850 f_loss=-6.1349 g_loss=33.6775 | train mmd=0.4128 | test_mmd=0.0102\n",
      "[CellOT] epoch=900 f_loss=-1.7871 g_loss=32.5354 | train mmd=0.3257 | test_mmd=0.0074\n",
      "[CellOT] epoch=950 f_loss=4.5893 g_loss=21.9733 | train mmd=0.1504 | test_mmd=0.0085\n",
      "[CellOT] epoch=1000 f_loss=4.2100 g_loss=16.9307 | train mmd=0.0604 | test_mmd=0.0191\n",
      "[CellOT] epoch=1050 f_loss=0.0555 g_loss=16.5468 | train mmd=0.0402 | test_mmd=0.0192\n",
      "[CellOT] epoch=1100 f_loss=0.6182 g_loss=16.9326 | train mmd=0.0416 | test_mmd=0.0132\n",
      "[CellOT] epoch=1150 f_loss=1.0230 g_loss=17.1276 | train mmd=0.0583 | test_mmd=0.0149\n",
      "[CellOT] epoch=1200 f_loss=-0.5288 g_loss=17.9117 | train mmd=0.0542 | test_mmd=0.0074\n",
      "[CellOT] epoch=1250 f_loss=-0.5488 g_loss=17.6362 | train mmd=0.0455 | test_mmd=0.0109\n",
      "[CellOT] epoch=1300 f_loss=1.2455 g_loss=17.2955 | train mmd=0.0367 | test_mmd=0.0125\n",
      "[CellOT] epoch=1350 f_loss=-0.8316 g_loss=17.1020 | train mmd=0.0352 | test_mmd=0.0121\n",
      "[CellOT] epoch=1400 f_loss=-0.6770 g_loss=16.6901 | train mmd=0.0293 | test_mmd=0.0136\n",
      "[CellOT] epoch=1450 f_loss=0.2789 g_loss=16.4393 | train mmd=0.0273 | test_mmd=0.0117\n",
      "[CellOT] epoch=1500 f_loss=0.3542 g_loss=15.9292 | train mmd=0.0243 | test_mmd=0.0119\n",
      "[CellOT] epoch=1550 f_loss=0.7089 g_loss=14.9373 | train mmd=0.0457 | test_mmd=0.0097\n",
      "[CellOT] epoch=1600 f_loss=0.3875 g_loss=14.7577 | train mmd=0.0541 | test_mmd=0.0094\n",
      "[CellOT] epoch=1650 f_loss=0.1594 g_loss=14.7329 | train mmd=0.0627 | test_mmd=0.0084\n",
      "[CellOT] epoch=1700 f_loss=-0.0510 g_loss=14.7956 | train mmd=0.0594 | test_mmd=0.0097\n",
      "[CellOT] epoch=1750 f_loss=0.1670 g_loss=14.5446 | train mmd=0.0516 | test_mmd=0.0101\n",
      "[CellOT] epoch=1800 f_loss=-0.3202 g_loss=14.8344 | train mmd=0.0293 | test_mmd=0.0121\n",
      "[CellOT] epoch=1850 f_loss=0.0949 g_loss=14.6409 | train mmd=0.0171 | test_mmd=0.0111\n",
      "[CellOT] epoch=1900 f_loss=-0.1451 g_loss=14.4455 | train mmd=0.0163 | test_mmd=0.0129\n",
      "[CellOT] epoch=1950 f_loss=0.4454 g_loss=14.2415 | train mmd=0.0178 | test_mmd=0.0132\n",
      "[CellOT] epoch=2000 f_loss=0.5473 g_loss=13.6626 | train mmd=0.0241 | test_mmd=0.0161\n",
      "[CellOT] Final CellOT MMD: 0.0233\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 metrics: {'mmd2_gamma_median': 0.016083371074717023, 'mmd2_gamma_0.5': 0.05565217906071929, 'mmd2_gamma_1.0': 0.05874677012775242, 'wasserstein_distance': 1.0390989522780838, 'R2_feature_means': 0.9563775518935641}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0116  0.0020\n",
      "mmd2_gamma_0.5        0.0485  0.0094\n",
      "mmd2_gamma_1.0        0.0525  0.0149\n",
      "wasserstein_distance  1.0338  0.1496\n",
      "R2_feature_means      0.9701  0.0057\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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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"Vem\"\n",
    "X_pre_replicate_1, X_post_replicate_1 = prepare_pair_from_mat('COLO858', 'DMSO','24h', drug, '72h', 1)\n",
    "X_pre_replicate_2, X_post_replicate_2 = prepare_pair_from_mat('COLO858', 'DMSO','24h', drug, '72h', 2) \n",
    "\n",
    "jfe_indices = [1, 6, 0, 5, 4, 7, 8, 2, 3, 19]  \n",
    "\n",
    "\n",
    "X_tr_pre = X_pre_replicate_1\n",
    "Y_tr_post = X_post_replicate_1\n",
    "X_te_pre = X_pre_replicate_2\n",
    "Y_te_post = X_post_replicate_2\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 = run_cellot_pair(X_tr_pre[:, jfe_indices], Y_tr_post[:, jfe_indices], X_te_pre[:, jfe_indices], Y_te_post[:, jfe_indices], n_epochs=2000)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post[:, jfe_indices], median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post[:, jfe_indices]\n",
    "target = Y_te_post[:, jfe_indices]\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#C88131\")\n",
    "ax.scatter(y_pred_umap[:, 0], y_pred_umap[:, 1], s=10, alpha=0.7, label='predicted cells', color=\"#1F4D8D\")\n",
    "\n",
    "ax.set_title(f'{drug}')\n",
    "# ax.set_xlabel('UMAP 1')\n",
    "# ax.set_ylabel('UMAP 2')\n",
    "ax.set_aspect('equal', 'box')\n",
    "# Add a legend to distinguish the points\n",
    "ax.legend()\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "# Display the plot\n",
    "plt.savefig(f\"./plots/cellot_on_4i_drug_{drug}.png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c338b528",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "31734785",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cell line:  WM902B\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n",
      "Cell line:  WM902B\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n",
      "(2837, 20)\n",
      "(2713, 20)\n",
      "(2837, 20)\n",
      "(2713, 20)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.06602327475443821\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-1.2204 g_loss=-4.4333 | train mmd=0.4089 | test_mmd=1.3516\n",
      "[CellOT] epoch=50 f_loss=-1.7853 g_loss=0.3539 | train mmd=0.5397 | test_mmd=0.2644\n",
      "[CellOT] epoch=100 f_loss=-2.4574 g_loss=2.4039 | train mmd=0.6695 | test_mmd=0.2111\n",
      "[CellOT] epoch=150 f_loss=-4.1711 g_loss=4.5755 | train mmd=0.6609 | test_mmd=0.1758\n",
      "[CellOT] epoch=200 f_loss=-5.8823 g_loss=6.7021 | train mmd=0.6505 | test_mmd=0.1475\n",
      "[CellOT] epoch=250 f_loss=-6.4639 g_loss=7.5506 | train mmd=0.5961 | test_mmd=0.1155\n",
      "[CellOT] epoch=300 f_loss=-7.6087 g_loss=9.7667 | train mmd=0.5721 | test_mmd=0.0943\n",
      "[CellOT] epoch=350 f_loss=-8.3212 g_loss=11.5339 | train mmd=0.5313 | test_mmd=0.0754\n",
      "[CellOT] epoch=400 f_loss=-9.1381 g_loss=13.4281 | train mmd=0.4857 | test_mmd=0.0583\n",
      "[CellOT] epoch=450 f_loss=-9.2307 g_loss=13.8366 | train mmd=0.4519 | test_mmd=0.0449\n",
      "[CellOT] epoch=500 f_loss=-8.6409 g_loss=14.6809 | train mmd=0.4070 | test_mmd=0.0334\n",
      "[CellOT] epoch=550 f_loss=-8.8575 g_loss=14.2729 | train mmd=0.3405 | test_mmd=0.0223\n",
      "[CellOT] epoch=600 f_loss=-8.5618 g_loss=15.8269 | train mmd=0.3045 | test_mmd=0.0167\n",
      "[CellOT] epoch=650 f_loss=-5.9480 g_loss=16.2253 | train mmd=0.2751 | test_mmd=0.0134\n",
      "[CellOT] epoch=700 f_loss=-6.0240 g_loss=14.0510 | train mmd=0.2238 | test_mmd=0.0089\n",
      "[CellOT] epoch=750 f_loss=-3.6298 g_loss=14.7930 | train mmd=0.2099 | test_mmd=0.0072\n",
      "[CellOT] epoch=800 f_loss=-0.4613 g_loss=13.3619 | train mmd=0.0913 | test_mmd=0.0132\n",
      "[CellOT] epoch=850 f_loss=0.8737 g_loss=13.1041 | train mmd=0.0197 | test_mmd=0.0067\n",
      "[CellOT] epoch=900 f_loss=0.4181 g_loss=12.9098 | train mmd=0.0180 | test_mmd=0.0145\n",
      "[CellOT] epoch=950 f_loss=0.4167 g_loss=14.5020 | train mmd=0.0179 | test_mmd=0.0091\n",
      "[CellOT] epoch=1000 f_loss=0.2478 g_loss=15.1460 | train mmd=0.0172 | test_mmd=0.0093\n",
      "[CellOT] epoch=1050 f_loss=-0.1753 g_loss=16.3878 | train mmd=0.0143 | test_mmd=0.0146\n",
      "[CellOT] epoch=1100 f_loss=-0.2362 g_loss=17.1115 | train mmd=0.0118 | test_mmd=0.0061\n",
      "[CellOT] epoch=1150 f_loss=0.5774 g_loss=17.9049 | train mmd=0.0105 | test_mmd=0.0080\n",
      "[CellOT] epoch=1200 f_loss=0.4814 g_loss=18.5755 | train mmd=0.0081 | test_mmd=0.0087\n",
      "[CellOT] epoch=1250 f_loss=0.0352 g_loss=18.7226 | train mmd=0.0083 | test_mmd=0.0069\n",
      "[CellOT] epoch=1300 f_loss=0.2097 g_loss=18.6461 | train mmd=0.0072 | test_mmd=0.0137\n",
      "[CellOT] epoch=1350 f_loss=0.0902 g_loss=18.5902 | train mmd=0.0078 | test_mmd=0.0098\n",
      "[CellOT] epoch=1400 f_loss=0.0223 g_loss=19.5056 | train mmd=0.0070 | test_mmd=0.0105\n",
      "[CellOT] epoch=1450 f_loss=-0.1345 g_loss=20.0162 | train mmd=0.0063 | test_mmd=0.0059\n",
      "[CellOT] epoch=1500 f_loss=0.1042 g_loss=19.8720 | train mmd=0.0052 | test_mmd=0.0067\n",
      "[CellOT] epoch=1550 f_loss=-0.1257 g_loss=20.1875 | train mmd=0.0051 | test_mmd=0.0099\n",
      "[CellOT] epoch=1600 f_loss=-0.0967 g_loss=19.8505 | train mmd=0.0040 | test_mmd=0.0094\n",
      "[CellOT] epoch=1650 f_loss=0.1245 g_loss=20.5720 | train mmd=0.0056 | test_mmd=0.0065\n",
      "[CellOT] epoch=1700 f_loss=0.3107 g_loss=19.6818 | train mmd=0.0049 | test_mmd=0.0104\n",
      "[CellOT] epoch=1750 f_loss=-0.1487 g_loss=20.6636 | train mmd=0.0122 | test_mmd=0.0090\n",
      "[CellOT] epoch=1800 f_loss=-0.2226 g_loss=20.3817 | train mmd=0.0066 | test_mmd=0.0116\n",
      "[CellOT] epoch=1850 f_loss=0.2218 g_loss=21.2486 | train mmd=0.0046 | test_mmd=0.0070\n",
      "[CellOT] epoch=1900 f_loss=0.5972 g_loss=20.5644 | train mmd=0.0037 | test_mmd=0.0088\n",
      "[CellOT] epoch=1950 f_loss=-0.0438 g_loss=20.8769 | train mmd=0.0063 | test_mmd=0.0111\n",
      "[CellOT] epoch=2000 f_loss=-0.1879 g_loss=20.9328 | train mmd=0.0038 | test_mmd=0.0107\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0087\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.010743827417293517, 'mmd2_gamma_0.5': 0.019624868032328213, 'mmd2_gamma_1.0': 0.018003721052558874, 'wasserstein_distance': 0.8217104969859785, 'R2_feature_means': 0.9772567256356518}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=1.1308 g_loss=-4.4911 | train mmd=0.4942 | test_mmd=1.1031\n",
      "[CellOT] epoch=50 f_loss=-2.2596 g_loss=0.1700 | train mmd=0.5304 | test_mmd=0.2690\n",
      "[CellOT] epoch=100 f_loss=-2.6187 g_loss=2.9572 | train mmd=0.6846 | test_mmd=0.2164\n",
      "[CellOT] epoch=150 f_loss=-4.2987 g_loss=4.8389 | train mmd=0.6860 | test_mmd=0.1847\n",
      "[CellOT] epoch=200 f_loss=-6.2170 g_loss=7.2341 | train mmd=0.6740 | test_mmd=0.1555\n",
      "[CellOT] epoch=250 f_loss=-7.5902 g_loss=9.1054 | train mmd=0.6431 | test_mmd=0.1294\n",
      "[CellOT] epoch=300 f_loss=-8.3281 g_loss=10.6809 | train mmd=0.6184 | test_mmd=0.1039\n",
      "[CellOT] epoch=350 f_loss=-9.2177 g_loss=11.3738 | train mmd=0.5572 | test_mmd=0.0792\n",
      "[CellOT] epoch=400 f_loss=-11.0813 g_loss=13.7435 | train mmd=0.5165 | test_mmd=0.0643\n",
      "[CellOT] epoch=450 f_loss=-9.6730 g_loss=14.8562 | train mmd=0.4905 | test_mmd=0.0506\n",
      "[CellOT] epoch=500 f_loss=-10.1848 g_loss=16.7181 | train mmd=0.4400 | test_mmd=0.0386\n",
      "[CellOT] epoch=550 f_loss=-10.1151 g_loss=16.5164 | train mmd=0.4014 | test_mmd=0.0287\n",
      "[CellOT] epoch=600 f_loss=-11.6275 g_loss=17.3191 | train mmd=0.3529 | test_mmd=0.0220\n",
      "[CellOT] epoch=650 f_loss=-9.4006 g_loss=18.4146 | train mmd=0.3157 | test_mmd=0.0163\n",
      "[CellOT] epoch=700 f_loss=-6.9303 g_loss=18.2419 | train mmd=0.2593 | test_mmd=0.0146\n",
      "[CellOT] epoch=750 f_loss=-4.5910 g_loss=18.8680 | train mmd=0.2036 | test_mmd=0.0117\n",
      "[CellOT] epoch=800 f_loss=-0.6952 g_loss=18.2552 | train mmd=0.1434 | test_mmd=0.0105\n",
      "[CellOT] epoch=850 f_loss=1.9788 g_loss=17.0852 | train mmd=0.0653 | test_mmd=0.0117\n",
      "[CellOT] epoch=900 f_loss=0.0867 g_loss=15.1560 | train mmd=0.0239 | test_mmd=0.0068\n",
      "[CellOT] epoch=950 f_loss=-0.0732 g_loss=16.4396 | train mmd=0.0252 | test_mmd=0.0098\n",
      "[CellOT] epoch=1000 f_loss=0.5152 g_loss=17.0378 | train mmd=0.0271 | test_mmd=0.0111\n",
      "[CellOT] epoch=1050 f_loss=0.1807 g_loss=18.6638 | train mmd=0.0258 | test_mmd=0.0066\n",
      "[CellOT] epoch=1100 f_loss=0.1065 g_loss=19.2403 | train mmd=0.0302 | test_mmd=0.0077\n",
      "[CellOT] epoch=1150 f_loss=-0.2825 g_loss=20.3245 | train mmd=0.0280 | test_mmd=0.0096\n",
      "[CellOT] epoch=1200 f_loss=0.1195 g_loss=21.4243 | train mmd=0.0288 | test_mmd=0.0106\n",
      "[CellOT] epoch=1250 f_loss=0.3843 g_loss=21.5564 | train mmd=0.0321 | test_mmd=0.0106\n",
      "[CellOT] epoch=1300 f_loss=0.0135 g_loss=22.4373 | train mmd=0.0211 | test_mmd=0.0067\n",
      "[CellOT] epoch=1350 f_loss=-0.0046 g_loss=23.0349 | train mmd=0.0154 | test_mmd=0.0075\n",
      "[CellOT] epoch=1400 f_loss=0.1792 g_loss=22.4709 | train mmd=0.0083 | test_mmd=0.0066\n",
      "[CellOT] epoch=1450 f_loss=-0.0224 g_loss=22.3075 | train mmd=0.0083 | test_mmd=0.0113\n",
      "[CellOT] epoch=1500 f_loss=-0.4658 g_loss=22.6618 | train mmd=0.0113 | test_mmd=0.0127\n",
      "[CellOT] epoch=1550 f_loss=0.5885 g_loss=22.3420 | train mmd=0.0071 | test_mmd=0.0097\n",
      "[CellOT] epoch=1600 f_loss=-0.3826 g_loss=22.3046 | train mmd=0.0095 | test_mmd=0.0082\n",
      "[CellOT] epoch=1650 f_loss=0.5290 g_loss=22.7514 | train mmd=0.0088 | test_mmd=0.0080\n",
      "[CellOT] epoch=1700 f_loss=-0.2119 g_loss=22.7469 | train mmd=0.0099 | test_mmd=0.0068\n",
      "[CellOT] epoch=1750 f_loss=0.3468 g_loss=22.1411 | train mmd=0.0071 | test_mmd=0.0076\n",
      "[CellOT] epoch=1800 f_loss=0.1086 g_loss=22.4858 | train mmd=0.0055 | test_mmd=0.0108\n",
      "[CellOT] epoch=1850 f_loss=-0.2591 g_loss=22.5517 | train mmd=0.0038 | test_mmd=0.0082\n",
      "[CellOT] epoch=1900 f_loss=-0.0798 g_loss=22.5272 | train mmd=0.0058 | test_mmd=0.0056\n",
      "[CellOT] epoch=1950 f_loss=-0.2212 g_loss=22.2917 | train mmd=0.0073 | test_mmd=0.0138\n",
      "[CellOT] epoch=2000 f_loss=0.1077 g_loss=22.3791 | train mmd=0.0080 | test_mmd=0.0125\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0090\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.012499773040409945, 'mmd2_gamma_0.5': 0.018283076683755617, 'mmd2_gamma_1.0': 0.017021368927331193, 'wasserstein_distance': 0.9393099422088943, 'R2_feature_means': 0.9685450890575199}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-1.4527 g_loss=-3.6043 | train mmd=0.3930 | test_mmd=1.0308\n",
      "[CellOT] epoch=50 f_loss=-1.9148 g_loss=0.3034 | train mmd=0.5451 | test_mmd=0.2475\n",
      "[CellOT] epoch=100 f_loss=-2.5081 g_loss=2.8862 | train mmd=0.6429 | test_mmd=0.1995\n",
      "[CellOT] epoch=150 f_loss=-4.1950 g_loss=4.4760 | train mmd=0.6558 | test_mmd=0.1766\n",
      "[CellOT] epoch=200 f_loss=-5.3809 g_loss=6.4663 | train mmd=0.6452 | test_mmd=0.1466\n",
      "[CellOT] epoch=250 f_loss=-6.6374 g_loss=8.8042 | train mmd=0.6054 | test_mmd=0.1172\n",
      "[CellOT] epoch=300 f_loss=-7.7353 g_loss=9.8721 | train mmd=0.5626 | test_mmd=0.0929\n",
      "[CellOT] epoch=350 f_loss=-8.0977 g_loss=10.5293 | train mmd=0.5002 | test_mmd=0.0740\n",
      "[CellOT] epoch=400 f_loss=-8.9012 g_loss=12.1801 | train mmd=0.4624 | test_mmd=0.0558\n",
      "[CellOT] epoch=450 f_loss=-8.5930 g_loss=13.1779 | train mmd=0.4046 | test_mmd=0.0429\n",
      "[CellOT] epoch=500 f_loss=-8.4452 g_loss=13.8430 | train mmd=0.3639 | test_mmd=0.0304\n",
      "[CellOT] epoch=550 f_loss=-8.6984 g_loss=13.8791 | train mmd=0.3150 | test_mmd=0.0213\n",
      "[CellOT] epoch=600 f_loss=-6.6630 g_loss=14.4498 | train mmd=0.3075 | test_mmd=0.0170\n",
      "[CellOT] epoch=650 f_loss=-6.6653 g_loss=14.7991 | train mmd=0.2664 | test_mmd=0.0116\n",
      "[CellOT] epoch=700 f_loss=-4.4249 g_loss=14.6142 | train mmd=0.2332 | test_mmd=0.0081\n",
      "[CellOT] epoch=750 f_loss=-3.3425 g_loss=12.5200 | train mmd=0.1721 | test_mmd=0.0074\n",
      "[CellOT] epoch=800 f_loss=1.3330 g_loss=10.3582 | train mmd=0.0392 | test_mmd=0.0135\n",
      "[CellOT] epoch=850 f_loss=1.3071 g_loss=11.4246 | train mmd=0.0220 | test_mmd=0.0157\n",
      "[CellOT] epoch=900 f_loss=0.7545 g_loss=13.5303 | train mmd=0.0210 | test_mmd=0.0102\n",
      "[CellOT] epoch=950 f_loss=0.2122 g_loss=15.2077 | train mmd=0.0203 | test_mmd=0.0120\n",
      "[CellOT] epoch=1000 f_loss=0.0964 g_loss=16.6044 | train mmd=0.0268 | test_mmd=0.0067\n",
      "[CellOT] epoch=1050 f_loss=0.4781 g_loss=17.4419 | train mmd=0.0244 | test_mmd=0.0142\n",
      "[CellOT] epoch=1100 f_loss=0.4475 g_loss=18.4379 | train mmd=0.0200 | test_mmd=0.0121\n",
      "[CellOT] epoch=1150 f_loss=-0.3205 g_loss=19.3111 | train mmd=0.0177 | test_mmd=0.0062\n",
      "[CellOT] epoch=1200 f_loss=0.0254 g_loss=19.9598 | train mmd=0.0154 | test_mmd=0.0077\n",
      "[CellOT] epoch=1250 f_loss=-0.5163 g_loss=20.6569 | train mmd=0.0143 | test_mmd=0.0096\n",
      "[CellOT] epoch=1300 f_loss=-0.4189 g_loss=20.7932 | train mmd=0.0156 | test_mmd=0.0076\n",
      "[CellOT] epoch=1350 f_loss=0.0859 g_loss=21.1861 | train mmd=0.0140 | test_mmd=0.0102\n",
      "[CellOT] epoch=1400 f_loss=0.1436 g_loss=21.7345 | train mmd=0.0124 | test_mmd=0.0073\n",
      "[CellOT] epoch=1450 f_loss=0.1422 g_loss=21.8996 | train mmd=0.0098 | test_mmd=0.0082\n",
      "[CellOT] epoch=1500 f_loss=0.0613 g_loss=21.9107 | train mmd=0.0120 | test_mmd=0.0214\n",
      "[CellOT] epoch=1550 f_loss=-0.0200 g_loss=22.7004 | train mmd=0.0060 | test_mmd=0.0093\n",
      "[CellOT] epoch=1600 f_loss=0.0203 g_loss=22.8472 | train mmd=0.0100 | test_mmd=0.0056\n",
      "[CellOT] epoch=1650 f_loss=-0.1549 g_loss=23.0744 | train mmd=0.0079 | test_mmd=0.0092\n",
      "[CellOT] epoch=1700 f_loss=0.2011 g_loss=23.0757 | train mmd=0.0067 | test_mmd=0.0098\n",
      "[CellOT] epoch=1750 f_loss=0.4130 g_loss=23.3411 | train mmd=0.0066 | test_mmd=0.0168\n",
      "[CellOT] epoch=1800 f_loss=-0.2150 g_loss=23.7937 | train mmd=0.0065 | test_mmd=0.0074\n",
      "[CellOT] epoch=1850 f_loss=0.6650 g_loss=23.0471 | train mmd=0.0089 | test_mmd=0.0104\n",
      "[CellOT] epoch=1900 f_loss=0.0323 g_loss=24.0756 | train mmd=0.0064 | test_mmd=0.0069\n",
      "[CellOT] epoch=1950 f_loss=0.4985 g_loss=23.8118 | train mmd=0.0095 | test_mmd=0.0160\n",
      "[CellOT] epoch=2000 f_loss=-0.2324 g_loss=24.7278 | train mmd=0.0076 | test_mmd=0.0120\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0093\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.011953211328853186, 'mmd2_gamma_0.5': 0.021721396757434674, 'mmd2_gamma_1.0': 0.01856611778775713, 'wasserstein_distance': 0.8916100388049552, 'R2_feature_means': 0.9745975121591473}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=1.2924 g_loss=-3.7203 | train mmd=0.4107 | test_mmd=1.1541\n",
      "[CellOT] epoch=50 f_loss=-1.7041 g_loss=0.2012 | train mmd=0.4884 | test_mmd=0.2463\n",
      "[CellOT] epoch=100 f_loss=-2.6379 g_loss=2.6609 | train mmd=0.6864 | test_mmd=0.2184\n",
      "[CellOT] epoch=150 f_loss=-4.3972 g_loss=4.3093 | train mmd=0.6855 | test_mmd=0.1882\n",
      "[CellOT] epoch=200 f_loss=-5.7555 g_loss=6.3210 | train mmd=0.6736 | test_mmd=0.1583\n",
      "[CellOT] epoch=250 f_loss=-7.0414 g_loss=8.0630 | train mmd=0.6087 | test_mmd=0.1185\n",
      "[CellOT] epoch=300 f_loss=-7.6670 g_loss=9.7943 | train mmd=0.5838 | test_mmd=0.0982\n",
      "[CellOT] epoch=350 f_loss=-8.4421 g_loss=10.3969 | train mmd=0.5380 | test_mmd=0.0749\n",
      "[CellOT] epoch=400 f_loss=-8.5576 g_loss=11.4825 | train mmd=0.4801 | test_mmd=0.0562\n",
      "[CellOT] epoch=450 f_loss=-9.4960 g_loss=13.8964 | train mmd=0.4056 | test_mmd=0.0411\n",
      "[CellOT] epoch=500 f_loss=-8.8402 g_loss=13.3616 | train mmd=0.3660 | test_mmd=0.0289\n",
      "[CellOT] epoch=550 f_loss=-8.0381 g_loss=15.0992 | train mmd=0.3116 | test_mmd=0.0203\n",
      "[CellOT] epoch=600 f_loss=-5.8014 g_loss=12.7120 | train mmd=0.2338 | test_mmd=0.0118\n",
      "[CellOT] epoch=650 f_loss=-4.3388 g_loss=12.4472 | train mmd=0.1416 | test_mmd=0.0114\n",
      "[CellOT] epoch=700 f_loss=-1.4812 g_loss=9.9819 | train mmd=0.1086 | test_mmd=0.0108\n",
      "[CellOT] epoch=750 f_loss=-0.2413 g_loss=8.7209 | train mmd=0.0497 | test_mmd=0.0104\n",
      "[CellOT] epoch=800 f_loss=0.5351 g_loss=7.8443 | train mmd=0.0219 | test_mmd=0.0082\n",
      "[CellOT] epoch=850 f_loss=0.8240 g_loss=10.3547 | train mmd=0.0238 | test_mmd=0.0119\n",
      "[CellOT] epoch=900 f_loss=0.3498 g_loss=12.0701 | train mmd=0.0202 | test_mmd=0.0092\n",
      "[CellOT] epoch=950 f_loss=-0.1642 g_loss=13.4770 | train mmd=0.0185 | test_mmd=0.0048\n",
      "[CellOT] epoch=1000 f_loss=-0.2181 g_loss=14.0519 | train mmd=0.0125 | test_mmd=0.0077\n",
      "[CellOT] epoch=1050 f_loss=0.4312 g_loss=14.0801 | train mmd=0.0173 | test_mmd=0.0086\n",
      "[CellOT] epoch=1100 f_loss=0.4308 g_loss=14.5829 | train mmd=0.0106 | test_mmd=0.0078\n",
      "[CellOT] epoch=1150 f_loss=-0.5348 g_loss=15.2056 | train mmd=0.0092 | test_mmd=0.0100\n",
      "[CellOT] epoch=1200 f_loss=0.4726 g_loss=14.8127 | train mmd=0.0075 | test_mmd=0.0064\n",
      "[CellOT] epoch=1250 f_loss=-0.7660 g_loss=15.6835 | train mmd=0.0066 | test_mmd=0.0064\n",
      "[CellOT] epoch=1300 f_loss=-0.0229 g_loss=15.5332 | train mmd=0.0055 | test_mmd=0.0132\n",
      "[CellOT] epoch=1350 f_loss=0.3196 g_loss=15.8184 | train mmd=0.0064 | test_mmd=0.0169\n",
      "[CellOT] epoch=1400 f_loss=0.3019 g_loss=15.7807 | train mmd=0.0091 | test_mmd=0.0067\n",
      "[CellOT] epoch=1450 f_loss=-0.0716 g_loss=15.9554 | train mmd=0.0058 | test_mmd=0.0097\n",
      "[CellOT] epoch=1500 f_loss=0.2356 g_loss=16.3297 | train mmd=0.0067 | test_mmd=0.0084\n",
      "[CellOT] epoch=1550 f_loss=0.2469 g_loss=16.4343 | train mmd=0.0072 | test_mmd=0.0085\n",
      "[CellOT] epoch=1600 f_loss=0.0471 g_loss=16.7954 | train mmd=0.0053 | test_mmd=0.0109\n",
      "[CellOT] epoch=1650 f_loss=0.6448 g_loss=16.4889 | train mmd=0.0071 | test_mmd=0.0128\n",
      "[CellOT] epoch=1700 f_loss=0.2415 g_loss=16.9315 | train mmd=0.0061 | test_mmd=0.0127\n",
      "[CellOT] epoch=1750 f_loss=-0.0810 g_loss=16.8040 | train mmd=0.0037 | test_mmd=0.0091\n",
      "[CellOT] epoch=1800 f_loss=0.2444 g_loss=17.2854 | train mmd=0.0043 | test_mmd=0.0068\n",
      "[CellOT] epoch=1850 f_loss=-0.0288 g_loss=17.3632 | train mmd=0.0042 | test_mmd=0.0094\n",
      "[CellOT] epoch=1900 f_loss=0.2876 g_loss=17.2221 | train mmd=0.0059 | test_mmd=0.0099\n",
      "[CellOT] epoch=1950 f_loss=0.0597 g_loss=17.3247 | train mmd=0.0043 | test_mmd=0.0094\n",
      "[CellOT] epoch=2000 f_loss=-0.2564 g_loss=17.6988 | train mmd=0.0076 | test_mmd=0.0077\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0075\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.0076633175537941245, 'mmd2_gamma_0.5': 0.01726737513756338, 'mmd2_gamma_1.0': 0.017222533219283354, 'wasserstein_distance': 0.8388544327331703, 'R2_feature_means': 0.9844228402420775}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=1.1185 g_loss=-6.5213 | train mmd=0.3986 | test_mmd=1.3869\n",
      "[CellOT] epoch=50 f_loss=-2.6069 g_loss=0.1390 | train mmd=0.4875 | test_mmd=0.3126\n",
      "[CellOT] epoch=100 f_loss=-2.7355 g_loss=2.2237 | train mmd=0.6971 | test_mmd=0.2332\n",
      "[CellOT] epoch=150 f_loss=-4.1104 g_loss=4.5526 | train mmd=0.6764 | test_mmd=0.1896\n",
      "[CellOT] epoch=200 f_loss=-6.0524 g_loss=6.4090 | train mmd=0.6536 | test_mmd=0.1589\n",
      "[CellOT] epoch=250 f_loss=-6.7368 g_loss=8.1411 | train mmd=0.6360 | test_mmd=0.1328\n",
      "[CellOT] epoch=300 f_loss=-8.0375 g_loss=9.8946 | train mmd=0.5861 | test_mmd=0.1047\n",
      "[CellOT] epoch=350 f_loss=-8.5625 g_loss=11.1941 | train mmd=0.5039 | test_mmd=0.0825\n",
      "[CellOT] epoch=400 f_loss=-9.0584 g_loss=13.0273 | train mmd=0.4608 | test_mmd=0.0587\n",
      "[CellOT] epoch=450 f_loss=-10.5105 g_loss=12.5762 | train mmd=0.4203 | test_mmd=0.0464\n",
      "[CellOT] epoch=500 f_loss=-9.0195 g_loss=13.6654 | train mmd=0.3815 | test_mmd=0.0339\n",
      "[CellOT] epoch=550 f_loss=-10.7686 g_loss=15.6099 | train mmd=0.3454 | test_mmd=0.0248\n",
      "[CellOT] epoch=600 f_loss=-9.3121 g_loss=13.6949 | train mmd=0.2878 | test_mmd=0.0164\n",
      "[CellOT] epoch=650 f_loss=-7.7874 g_loss=15.3589 | train mmd=0.2410 | test_mmd=0.0117\n",
      "[CellOT] epoch=700 f_loss=-5.5263 g_loss=13.7600 | train mmd=0.1549 | test_mmd=0.0119\n",
      "[CellOT] epoch=750 f_loss=-1.4747 g_loss=11.3900 | train mmd=0.0825 | test_mmd=0.0069\n",
      "[CellOT] epoch=800 f_loss=0.2848 g_loss=9.6496 | train mmd=0.0496 | test_mmd=0.0087\n",
      "[CellOT] epoch=850 f_loss=0.6288 g_loss=10.6838 | train mmd=0.0510 | test_mmd=0.0075\n",
      "[CellOT] epoch=900 f_loss=-0.2308 g_loss=12.4635 | train mmd=0.0399 | test_mmd=0.0065\n",
      "[CellOT] epoch=950 f_loss=0.0345 g_loss=13.4650 | train mmd=0.0274 | test_mmd=0.0095\n",
      "[CellOT] epoch=1000 f_loss=0.2414 g_loss=13.8782 | train mmd=0.0262 | test_mmd=0.0090\n",
      "[CellOT] epoch=1050 f_loss=-0.0161 g_loss=15.0876 | train mmd=0.0161 | test_mmd=0.0076\n",
      "[CellOT] epoch=1100 f_loss=0.6623 g_loss=15.1829 | train mmd=0.0178 | test_mmd=0.0072\n",
      "[CellOT] epoch=1150 f_loss=0.2203 g_loss=15.6436 | train mmd=0.0124 | test_mmd=0.0063\n",
      "[CellOT] epoch=1200 f_loss=0.3441 g_loss=15.6680 | train mmd=0.0083 | test_mmd=0.0117\n",
      "[CellOT] epoch=1250 f_loss=-0.3729 g_loss=16.3607 | train mmd=0.0112 | test_mmd=0.0068\n",
      "[CellOT] epoch=1300 f_loss=0.1959 g_loss=16.2425 | train mmd=0.0086 | test_mmd=0.0049\n",
      "[CellOT] epoch=1350 f_loss=-0.2000 g_loss=16.2742 | train mmd=0.0070 | test_mmd=0.0057\n",
      "[CellOT] epoch=1400 f_loss=0.0888 g_loss=16.1677 | train mmd=0.0045 | test_mmd=0.0106\n",
      "[CellOT] epoch=1450 f_loss=0.1959 g_loss=16.2152 | train mmd=0.0069 | test_mmd=0.0070\n",
      "[CellOT] epoch=1500 f_loss=0.1720 g_loss=15.7628 | train mmd=0.0050 | test_mmd=0.0127\n",
      "[CellOT] epoch=1550 f_loss=-0.1226 g_loss=16.0123 | train mmd=0.0074 | test_mmd=0.0086\n",
      "[CellOT] epoch=1600 f_loss=-0.0466 g_loss=15.8542 | train mmd=0.0057 | test_mmd=0.0069\n",
      "[CellOT] epoch=1650 f_loss=-0.2958 g_loss=16.0643 | train mmd=0.0041 | test_mmd=0.0101\n",
      "[CellOT] epoch=1700 f_loss=-0.2703 g_loss=15.7452 | train mmd=0.0050 | test_mmd=0.0079\n",
      "[CellOT] epoch=1750 f_loss=0.2010 g_loss=15.6727 | train mmd=0.0057 | test_mmd=0.0134\n",
      "[CellOT] epoch=1800 f_loss=-0.2836 g_loss=15.6171 | train mmd=0.0037 | test_mmd=0.0114\n",
      "[CellOT] epoch=1850 f_loss=0.0508 g_loss=15.7766 | train mmd=0.0051 | test_mmd=0.0113\n",
      "[CellOT] epoch=1900 f_loss=0.0351 g_loss=15.3382 | train mmd=0.0040 | test_mmd=0.0063\n",
      "[CellOT] epoch=1950 f_loss=0.4527 g_loss=15.5025 | train mmd=0.0059 | test_mmd=0.0085\n",
      "[CellOT] epoch=2000 f_loss=-0.4733 g_loss=15.7922 | train mmd=0.0038 | test_mmd=0.0067\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0069\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.006663825577053251, 'mmd2_gamma_0.5': 0.017174679203099896, 'mmd2_gamma_1.0': 0.016540069436332128, 'wasserstein_distance': 0.7310519683233498, 'R2_feature_means': 0.9883162432943805}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=1.8387 g_loss=-6.1593 | train mmd=0.4605 | test_mmd=1.3589\n",
      "[CellOT] epoch=50 f_loss=-2.6826 g_loss=0.3678 | train mmd=0.4625 | test_mmd=0.2984\n",
      "[CellOT] epoch=100 f_loss=-2.7742 g_loss=1.9265 | train mmd=0.6973 | test_mmd=0.2310\n",
      "[CellOT] epoch=150 f_loss=-4.7258 g_loss=4.5979 | train mmd=0.7072 | test_mmd=0.2015\n",
      "[CellOT] epoch=200 f_loss=-6.1027 g_loss=6.8593 | train mmd=0.6887 | test_mmd=0.1678\n",
      "[CellOT] epoch=250 f_loss=-7.9066 g_loss=8.7732 | train mmd=0.6526 | test_mmd=0.1369\n",
      "[CellOT] epoch=300 f_loss=-9.6545 g_loss=10.7854 | train mmd=0.6158 | test_mmd=0.1130\n",
      "[CellOT] epoch=350 f_loss=-9.2822 g_loss=12.2785 | train mmd=0.5733 | test_mmd=0.0909\n",
      "[CellOT] epoch=400 f_loss=-10.3073 g_loss=14.3730 | train mmd=0.5345 | test_mmd=0.0719\n",
      "[CellOT] epoch=450 f_loss=-10.7419 g_loss=14.5467 | train mmd=0.4877 | test_mmd=0.0556\n",
      "[CellOT] epoch=500 f_loss=-11.7473 g_loss=16.2004 | train mmd=0.4445 | test_mmd=0.0446\n",
      "[CellOT] epoch=550 f_loss=-10.5558 g_loss=16.6985 | train mmd=0.3718 | test_mmd=0.0316\n",
      "[CellOT] epoch=600 f_loss=-10.4764 g_loss=17.1837 | train mmd=0.3581 | test_mmd=0.0253\n",
      "[CellOT] epoch=650 f_loss=-11.2827 g_loss=19.9003 | train mmd=0.3016 | test_mmd=0.0226\n",
      "[CellOT] epoch=700 f_loss=-9.2807 g_loss=22.8244 | train mmd=0.3089 | test_mmd=0.0168\n",
      "[CellOT] epoch=750 f_loss=-6.9360 g_loss=23.4003 | train mmd=0.2697 | test_mmd=0.0115\n",
      "[CellOT] epoch=800 f_loss=-3.9063 g_loss=22.3629 | train mmd=0.1599 | test_mmd=0.0148\n",
      "[CellOT] epoch=850 f_loss=2.2015 g_loss=16.9067 | train mmd=0.0468 | test_mmd=0.0135\n",
      "[CellOT] epoch=900 f_loss=0.5798 g_loss=16.0270 | train mmd=0.0151 | test_mmd=0.0102\n",
      "[CellOT] epoch=950 f_loss=0.1625 g_loss=16.9155 | train mmd=0.0213 | test_mmd=0.0108\n",
      "[CellOT] epoch=1000 f_loss=0.2641 g_loss=17.6607 | train mmd=0.0193 | test_mmd=0.0093\n",
      "[CellOT] epoch=1050 f_loss=-0.6316 g_loss=18.7039 | train mmd=0.0178 | test_mmd=0.0089\n",
      "[CellOT] epoch=1100 f_loss=0.4595 g_loss=19.2371 | train mmd=0.0176 | test_mmd=0.0053\n",
      "[CellOT] epoch=1150 f_loss=-0.3809 g_loss=19.0722 | train mmd=0.0125 | test_mmd=0.0113\n",
      "[CellOT] epoch=1200 f_loss=-0.1624 g_loss=19.2966 | train mmd=0.0150 | test_mmd=0.0080\n",
      "[CellOT] epoch=1250 f_loss=0.3364 g_loss=19.2906 | train mmd=0.0104 | test_mmd=0.0085\n",
      "[CellOT] epoch=1300 f_loss=0.2586 g_loss=19.4004 | train mmd=0.0102 | test_mmd=0.0084\n",
      "[CellOT] epoch=1350 f_loss=0.2090 g_loss=20.1236 | train mmd=0.0092 | test_mmd=0.0077\n",
      "[CellOT] epoch=1400 f_loss=-0.1079 g_loss=20.1870 | train mmd=0.0102 | test_mmd=0.0074\n",
      "[CellOT] epoch=1450 f_loss=-0.3602 g_loss=21.1643 | train mmd=0.0092 | test_mmd=0.0097\n",
      "[CellOT] epoch=1500 f_loss=-0.0239 g_loss=20.3315 | train mmd=0.0084 | test_mmd=0.0080\n",
      "[CellOT] epoch=1550 f_loss=-0.1893 g_loss=20.8670 | train mmd=0.0066 | test_mmd=0.0111\n",
      "[CellOT] epoch=1600 f_loss=0.2000 g_loss=21.2840 | train mmd=0.0080 | test_mmd=0.0062\n",
      "[CellOT] epoch=1650 f_loss=0.3548 g_loss=20.9910 | train mmd=0.0050 | test_mmd=0.0078\n",
      "[CellOT] epoch=1700 f_loss=-0.4136 g_loss=21.1095 | train mmd=0.0062 | test_mmd=0.0115\n",
      "[CellOT] epoch=1750 f_loss=0.3542 g_loss=20.9814 | train mmd=0.0061 | test_mmd=0.0089\n",
      "[CellOT] epoch=1800 f_loss=-0.1328 g_loss=20.3863 | train mmd=0.0046 | test_mmd=0.0106\n",
      "[CellOT] epoch=1850 f_loss=-0.2841 g_loss=21.2981 | train mmd=0.0057 | test_mmd=0.0102\n",
      "[CellOT] epoch=1900 f_loss=0.2168 g_loss=20.4669 | train mmd=0.0048 | test_mmd=0.0096\n",
      "[CellOT] epoch=1950 f_loss=-0.1789 g_loss=20.5949 | train mmd=0.0033 | test_mmd=0.0099\n",
      "[CellOT] epoch=2000 f_loss=-0.2148 g_loss=20.8310 | train mmd=0.0049 | test_mmd=0.0109\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0099\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.01087788855344729, 'mmd2_gamma_0.5': 0.024030920207992246, 'mmd2_gamma_1.0': 0.022152373242287637, 'wasserstein_distance': 1.379375964216025, 'R2_feature_means': 0.974837187831876}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=0.5367 g_loss=-3.9352 | train mmd=0.4103 | test_mmd=1.2193\n",
      "[CellOT] epoch=50 f_loss=-1.8016 g_loss=0.5499 | train mmd=0.5239 | test_mmd=0.2413\n",
      "[CellOT] epoch=100 f_loss=-2.8704 g_loss=2.6370 | train mmd=0.6328 | test_mmd=0.1996\n",
      "[CellOT] epoch=150 f_loss=-4.3718 g_loss=4.6201 | train mmd=0.6622 | test_mmd=0.1819\n",
      "[CellOT] epoch=200 f_loss=-6.2492 g_loss=7.0447 | train mmd=0.6432 | test_mmd=0.1516\n",
      "[CellOT] epoch=250 f_loss=-6.8756 g_loss=7.6594 | train mmd=0.6137 | test_mmd=0.1221\n",
      "[CellOT] epoch=300 f_loss=-8.0908 g_loss=10.3445 | train mmd=0.5708 | test_mmd=0.0988\n",
      "[CellOT] epoch=350 f_loss=-9.2015 g_loss=11.2333 | train mmd=0.5135 | test_mmd=0.0747\n",
      "[CellOT] epoch=400 f_loss=-10.2705 g_loss=13.0658 | train mmd=0.4986 | test_mmd=0.0622\n",
      "[CellOT] epoch=450 f_loss=-10.0482 g_loss=14.1704 | train mmd=0.4613 | test_mmd=0.0466\n",
      "[CellOT] epoch=500 f_loss=-10.6500 g_loss=15.1057 | train mmd=0.3945 | test_mmd=0.0350\n",
      "[CellOT] epoch=550 f_loss=-9.6559 g_loss=14.9231 | train mmd=0.3175 | test_mmd=0.0251\n",
      "[CellOT] epoch=600 f_loss=-8.4025 g_loss=14.8486 | train mmd=0.3153 | test_mmd=0.0161\n",
      "[CellOT] epoch=650 f_loss=-7.8789 g_loss=15.8714 | train mmd=0.2478 | test_mmd=0.0115\n",
      "[CellOT] epoch=700 f_loss=-3.8893 g_loss=13.6149 | train mmd=0.1483 | test_mmd=0.0110\n",
      "[CellOT] epoch=750 f_loss=0.6865 g_loss=7.7708 | train mmd=0.0169 | test_mmd=0.0151\n",
      "[CellOT] epoch=800 f_loss=0.6900 g_loss=9.0376 | train mmd=0.0202 | test_mmd=0.0104\n",
      "[CellOT] epoch=850 f_loss=0.5905 g_loss=9.9601 | train mmd=0.0207 | test_mmd=0.0077\n",
      "[CellOT] epoch=900 f_loss=0.4313 g_loss=10.5061 | train mmd=0.0210 | test_mmd=0.0079\n",
      "[CellOT] epoch=950 f_loss=0.5249 g_loss=11.2974 | train mmd=0.0232 | test_mmd=0.0093\n",
      "[CellOT] epoch=1000 f_loss=0.5369 g_loss=11.8728 | train mmd=0.0225 | test_mmd=0.0089\n",
      "[CellOT] epoch=1050 f_loss=0.0229 g_loss=12.7819 | train mmd=0.0218 | test_mmd=0.0062\n",
      "[CellOT] epoch=1100 f_loss=-0.2781 g_loss=13.1561 | train mmd=0.0220 | test_mmd=0.0041\n",
      "[CellOT] epoch=1150 f_loss=0.4193 g_loss=13.0742 | train mmd=0.0182 | test_mmd=0.0097\n",
      "[CellOT] epoch=1200 f_loss=0.2602 g_loss=12.7325 | train mmd=0.0106 | test_mmd=0.0092\n",
      "[CellOT] epoch=1250 f_loss=0.1103 g_loss=13.6508 | train mmd=0.0097 | test_mmd=0.0075\n",
      "[CellOT] epoch=1300 f_loss=0.3850 g_loss=13.4209 | train mmd=0.0128 | test_mmd=0.0082\n",
      "[CellOT] epoch=1350 f_loss=0.0988 g_loss=13.4869 | train mmd=0.0060 | test_mmd=0.0101\n",
      "[CellOT] epoch=1400 f_loss=0.0885 g_loss=13.6232 | train mmd=0.0064 | test_mmd=0.0126\n",
      "[CellOT] epoch=1450 f_loss=-0.0077 g_loss=13.8012 | train mmd=0.0066 | test_mmd=0.0089\n",
      "[CellOT] epoch=1500 f_loss=-0.1312 g_loss=13.8993 | train mmd=0.0066 | test_mmd=0.0086\n",
      "[CellOT] epoch=1550 f_loss=-0.3798 g_loss=14.2428 | train mmd=0.0063 | test_mmd=0.0137\n",
      "[CellOT] epoch=1600 f_loss=0.0833 g_loss=13.5399 | train mmd=0.0037 | test_mmd=0.0067\n",
      "[CellOT] epoch=1650 f_loss=0.2146 g_loss=13.8888 | train mmd=0.0043 | test_mmd=0.0083\n",
      "[CellOT] epoch=1700 f_loss=0.3236 g_loss=13.4072 | train mmd=0.0047 | test_mmd=0.0083\n",
      "[CellOT] epoch=1750 f_loss=-0.1086 g_loss=14.2190 | train mmd=0.0034 | test_mmd=0.0076\n",
      "[CellOT] epoch=1800 f_loss=-0.0642 g_loss=14.0113 | train mmd=0.0039 | test_mmd=0.0074\n",
      "[CellOT] epoch=1850 f_loss=-0.4106 g_loss=14.2456 | train mmd=0.0030 | test_mmd=0.0064\n",
      "[CellOT] epoch=1900 f_loss=0.1428 g_loss=14.3244 | train mmd=0.0045 | test_mmd=0.0080\n",
      "[CellOT] epoch=1950 f_loss=0.0386 g_loss=14.2799 | train mmd=0.0038 | test_mmd=0.0066\n",
      "[CellOT] epoch=2000 f_loss=-0.1236 g_loss=14.2591 | train mmd=0.0044 | test_mmd=0.0101\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0077\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.01008700449627753, 'mmd2_gamma_0.5': 0.016550380014787702, 'mmd2_gamma_1.0': 0.015274735443866316, 'wasserstein_distance': 0.8572185381457412, 'R2_feature_means': 0.9761938901916605}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-0.1870 g_loss=-2.6203 | train mmd=0.4507 | test_mmd=0.9842\n",
      "[CellOT] epoch=50 f_loss=-1.8968 g_loss=-0.4603 | train mmd=0.5375 | test_mmd=0.2493\n",
      "[CellOT] epoch=100 f_loss=-2.6483 g_loss=2.3388 | train mmd=0.6935 | test_mmd=0.2199\n",
      "[CellOT] epoch=150 f_loss=-4.1005 g_loss=4.3212 | train mmd=0.6727 | test_mmd=0.1842\n",
      "[CellOT] epoch=200 f_loss=-5.6497 g_loss=6.5775 | train mmd=0.6380 | test_mmd=0.1511\n",
      "[CellOT] epoch=250 f_loss=-6.9168 g_loss=6.9048 | train mmd=0.6224 | test_mmd=0.1254\n",
      "[CellOT] epoch=300 f_loss=-7.4799 g_loss=8.4178 | train mmd=0.5459 | test_mmd=0.0966\n",
      "[CellOT] epoch=350 f_loss=-9.0281 g_loss=10.1324 | train mmd=0.5165 | test_mmd=0.0761\n",
      "[CellOT] epoch=400 f_loss=-8.6544 g_loss=12.2876 | train mmd=0.4644 | test_mmd=0.0596\n",
      "[CellOT] epoch=450 f_loss=-9.3352 g_loss=13.8143 | train mmd=0.4539 | test_mmd=0.0466\n",
      "[CellOT] epoch=500 f_loss=-8.5420 g_loss=12.8308 | train mmd=0.3633 | test_mmd=0.0337\n",
      "[CellOT] epoch=550 f_loss=-8.1219 g_loss=14.3065 | train mmd=0.3327 | test_mmd=0.0222\n",
      "[CellOT] epoch=600 f_loss=-7.2134 g_loss=14.2950 | train mmd=0.2891 | test_mmd=0.0144\n",
      "[CellOT] epoch=650 f_loss=-5.5701 g_loss=13.4824 | train mmd=0.2040 | test_mmd=0.0100\n",
      "[CellOT] epoch=700 f_loss=-3.4825 g_loss=11.3586 | train mmd=0.1581 | test_mmd=0.0071\n",
      "[CellOT] epoch=750 f_loss=-0.8944 g_loss=10.4762 | train mmd=0.0768 | test_mmd=0.0099\n",
      "[CellOT] epoch=800 f_loss=0.7839 g_loss=9.8612 | train mmd=0.0150 | test_mmd=0.0080\n",
      "[CellOT] epoch=850 f_loss=0.9231 g_loss=10.8369 | train mmd=0.0194 | test_mmd=0.0084\n",
      "[CellOT] epoch=900 f_loss=0.0293 g_loss=12.4874 | train mmd=0.0168 | test_mmd=0.0065\n",
      "[CellOT] epoch=950 f_loss=0.6825 g_loss=13.2525 | train mmd=0.0199 | test_mmd=0.0068\n",
      "[CellOT] epoch=1000 f_loss=0.4010 g_loss=13.7977 | train mmd=0.0210 | test_mmd=0.0116\n",
      "[CellOT] epoch=1050 f_loss=0.3171 g_loss=14.8964 | train mmd=0.0120 | test_mmd=0.0095\n",
      "[CellOT] epoch=1100 f_loss=0.4543 g_loss=15.2557 | train mmd=0.0157 | test_mmd=0.0133\n",
      "[CellOT] epoch=1150 f_loss=0.0711 g_loss=15.8616 | train mmd=0.0164 | test_mmd=0.0066\n",
      "[CellOT] epoch=1200 f_loss=0.2180 g_loss=16.2019 | train mmd=0.0139 | test_mmd=0.0091\n",
      "[CellOT] epoch=1250 f_loss=0.3401 g_loss=16.0118 | train mmd=0.0140 | test_mmd=0.0064\n",
      "[CellOT] epoch=1300 f_loss=-0.4127 g_loss=16.4527 | train mmd=0.0091 | test_mmd=0.0103\n",
      "[CellOT] epoch=1350 f_loss=-0.2784 g_loss=16.4545 | train mmd=0.0111 | test_mmd=0.0094\n",
      "[CellOT] epoch=1400 f_loss=0.1394 g_loss=16.7254 | train mmd=0.0075 | test_mmd=0.0105\n",
      "[CellOT] epoch=1450 f_loss=0.3848 g_loss=16.8116 | train mmd=0.0115 | test_mmd=0.0084\n",
      "[CellOT] epoch=1500 f_loss=0.3670 g_loss=16.9992 | train mmd=0.0100 | test_mmd=0.0066\n",
      "[CellOT] epoch=1550 f_loss=-0.0570 g_loss=17.3961 | train mmd=0.0059 | test_mmd=0.0116\n",
      "[CellOT] epoch=1600 f_loss=0.2680 g_loss=17.8116 | train mmd=0.0087 | test_mmd=0.0067\n",
      "[CellOT] epoch=1650 f_loss=0.1838 g_loss=18.0120 | train mmd=0.0075 | test_mmd=0.0052\n",
      "[CellOT] epoch=1700 f_loss=-0.1915 g_loss=17.9581 | train mmd=0.0068 | test_mmd=0.0106\n",
      "[CellOT] epoch=1750 f_loss=0.0706 g_loss=18.5637 | train mmd=0.0085 | test_mmd=0.0128\n",
      "[CellOT] epoch=1800 f_loss=0.1178 g_loss=18.2001 | train mmd=0.0069 | test_mmd=0.0151\n",
      "[CellOT] epoch=1850 f_loss=-0.2008 g_loss=18.7766 | train mmd=0.0045 | test_mmd=0.0099\n",
      "[CellOT] epoch=1900 f_loss=0.1372 g_loss=19.0685 | train mmd=0.0057 | test_mmd=0.0075\n",
      "[CellOT] epoch=1950 f_loss=-0.4242 g_loss=19.2489 | train mmd=0.0085 | test_mmd=0.0147\n",
      "[CellOT] epoch=2000 f_loss=-0.0983 g_loss=19.3486 | train mmd=0.0063 | test_mmd=0.0066\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0077\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.006583817345386489, 'mmd2_gamma_0.5': 0.019745865730752765, 'mmd2_gamma_1.0': 0.019723188201074826, 'wasserstein_distance': 1.0146913947406753, 'R2_feature_means': 0.9886128967598525}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=1.4717 g_loss=-4.5110 | train mmd=0.4209 | test_mmd=1.1142\n",
      "[CellOT] epoch=50 f_loss=-2.3304 g_loss=0.1648 | train mmd=0.4527 | test_mmd=0.2350\n",
      "[CellOT] epoch=100 f_loss=-3.1462 g_loss=2.7470 | train mmd=0.6884 | test_mmd=0.2145\n",
      "[CellOT] epoch=150 f_loss=-4.5648 g_loss=5.2703 | train mmd=0.6955 | test_mmd=0.1855\n",
      "[CellOT] epoch=200 f_loss=-6.4245 g_loss=7.6053 | train mmd=0.6795 | test_mmd=0.1563\n",
      "[CellOT] epoch=250 f_loss=-8.2025 g_loss=9.5780 | train mmd=0.6271 | test_mmd=0.1220\n",
      "[CellOT] epoch=300 f_loss=-8.7721 g_loss=10.4857 | train mmd=0.5849 | test_mmd=0.0972\n",
      "[CellOT] epoch=350 f_loss=-9.5237 g_loss=12.3997 | train mmd=0.5490 | test_mmd=0.0770\n",
      "[CellOT] epoch=400 f_loss=-10.6150 g_loss=14.2019 | train mmd=0.5271 | test_mmd=0.0623\n",
      "[CellOT] epoch=450 f_loss=-9.6510 g_loss=15.6628 | train mmd=0.4806 | test_mmd=0.0477\n",
      "[CellOT] epoch=500 f_loss=-11.2452 g_loss=17.6924 | train mmd=0.4264 | test_mmd=0.0357\n",
      "[CellOT] epoch=550 f_loss=-10.2205 g_loss=17.3928 | train mmd=0.3818 | test_mmd=0.0288\n",
      "[CellOT] epoch=600 f_loss=-10.6054 g_loss=17.7844 | train mmd=0.3631 | test_mmd=0.0218\n",
      "[CellOT] epoch=650 f_loss=-8.8725 g_loss=17.8057 | train mmd=0.2854 | test_mmd=0.0170\n",
      "[CellOT] epoch=700 f_loss=-5.8865 g_loss=18.7243 | train mmd=0.2451 | test_mmd=0.0118\n",
      "[CellOT] epoch=750 f_loss=-3.6747 g_loss=17.3128 | train mmd=0.1727 | test_mmd=0.0113\n",
      "[CellOT] epoch=800 f_loss=0.5686 g_loss=10.8681 | train mmd=0.0200 | test_mmd=0.0125\n",
      "[CellOT] epoch=850 f_loss=0.8146 g_loss=11.7153 | train mmd=0.0198 | test_mmd=0.0083\n",
      "[CellOT] epoch=900 f_loss=0.5574 g_loss=12.3438 | train mmd=0.0181 | test_mmd=0.0097\n",
      "[CellOT] epoch=950 f_loss=0.1942 g_loss=12.5787 | train mmd=0.0235 | test_mmd=0.0143\n",
      "[CellOT] epoch=1000 f_loss=-0.4443 g_loss=13.5856 | train mmd=0.0266 | test_mmd=0.0069\n",
      "[CellOT] epoch=1050 f_loss=-0.0253 g_loss=14.6065 | train mmd=0.0178 | test_mmd=0.0120\n",
      "[CellOT] epoch=1100 f_loss=-0.0606 g_loss=14.7923 | train mmd=0.0215 | test_mmd=0.0097\n",
      "[CellOT] epoch=1150 f_loss=0.2776 g_loss=15.2066 | train mmd=0.0186 | test_mmd=0.0105\n",
      "[CellOT] epoch=1200 f_loss=0.1151 g_loss=15.2491 | train mmd=0.0138 | test_mmd=0.0132\n",
      "[CellOT] epoch=1250 f_loss=0.0537 g_loss=15.2095 | train mmd=0.0132 | test_mmd=0.0075\n",
      "[CellOT] epoch=1300 f_loss=0.2979 g_loss=15.6682 | train mmd=0.0154 | test_mmd=0.0064\n",
      "[CellOT] epoch=1350 f_loss=0.3850 g_loss=15.9282 | train mmd=0.0101 | test_mmd=0.0066\n",
      "[CellOT] epoch=1400 f_loss=-0.2472 g_loss=16.0183 | train mmd=0.0072 | test_mmd=0.0085\n",
      "[CellOT] epoch=1450 f_loss=0.5167 g_loss=15.8647 | train mmd=0.0077 | test_mmd=0.0090\n",
      "[CellOT] epoch=1500 f_loss=0.4818 g_loss=15.9552 | train mmd=0.0066 | test_mmd=0.0126\n",
      "[CellOT] epoch=1550 f_loss=-0.3527 g_loss=16.7699 | train mmd=0.0073 | test_mmd=0.0061\n",
      "[CellOT] epoch=1600 f_loss=-0.0351 g_loss=17.1495 | train mmd=0.0059 | test_mmd=0.0080\n",
      "[CellOT] epoch=1650 f_loss=0.1075 g_loss=16.9046 | train mmd=0.0043 | test_mmd=0.0095\n",
      "[CellOT] epoch=1700 f_loss=0.4051 g_loss=16.5389 | train mmd=0.0047 | test_mmd=0.0064\n",
      "[CellOT] epoch=1750 f_loss=0.1099 g_loss=16.8561 | train mmd=0.0043 | test_mmd=0.0060\n",
      "[CellOT] epoch=1800 f_loss=-0.3872 g_loss=16.7476 | train mmd=0.0040 | test_mmd=0.0092\n",
      "[CellOT] epoch=1850 f_loss=-0.3926 g_loss=17.1337 | train mmd=0.0051 | test_mmd=0.0069\n",
      "[CellOT] epoch=1900 f_loss=-0.1208 g_loss=16.5515 | train mmd=0.0040 | test_mmd=0.0104\n",
      "[CellOT] epoch=1950 f_loss=0.4149 g_loss=16.3047 | train mmd=0.0062 | test_mmd=0.0081\n",
      "[CellOT] epoch=2000 f_loss=0.5016 g_loss=16.5629 | train mmd=0.0049 | test_mmd=0.0109\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0101\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.010895512684885311, 'mmd2_gamma_0.5': 0.025024603387669653, 'mmd2_gamma_1.0': 0.02279880114705396, 'wasserstein_distance': 0.8378774633843065, 'R2_feature_means': 0.9808215457439904}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-0.8976 g_loss=-6.2964 | train mmd=0.3840 | test_mmd=1.4560\n",
      "[CellOT] epoch=50 f_loss=-1.8160 g_loss=0.0970 | train mmd=0.6230 | test_mmd=0.2620\n",
      "[CellOT] epoch=100 f_loss=-3.0547 g_loss=2.2769 | train mmd=0.6874 | test_mmd=0.2207\n",
      "[CellOT] epoch=150 f_loss=-4.5704 g_loss=4.8700 | train mmd=0.6960 | test_mmd=0.1951\n",
      "[CellOT] epoch=200 f_loss=-5.4969 g_loss=7.0988 | train mmd=0.6588 | test_mmd=0.1532\n",
      "[CellOT] epoch=250 f_loss=-7.2012 g_loss=8.0849 | train mmd=0.6021 | test_mmd=0.1225\n",
      "[CellOT] epoch=300 f_loss=-8.4961 g_loss=9.8627 | train mmd=0.5796 | test_mmd=0.1024\n",
      "[CellOT] epoch=350 f_loss=-9.4407 g_loss=10.4042 | train mmd=0.5423 | test_mmd=0.0815\n",
      "[CellOT] epoch=400 f_loss=-9.3840 g_loss=12.6060 | train mmd=0.4930 | test_mmd=0.0619\n",
      "[CellOT] epoch=450 f_loss=-10.5341 g_loss=14.0882 | train mmd=0.4369 | test_mmd=0.0502\n",
      "[CellOT] epoch=500 f_loss=-10.1167 g_loss=14.6176 | train mmd=0.3912 | test_mmd=0.0360\n",
      "[CellOT] epoch=550 f_loss=-9.4337 g_loss=15.7562 | train mmd=0.3550 | test_mmd=0.0256\n",
      "[CellOT] epoch=600 f_loss=-9.2930 g_loss=16.5448 | train mmd=0.3100 | test_mmd=0.0208\n",
      "[CellOT] epoch=650 f_loss=-8.1746 g_loss=17.3565 | train mmd=0.2717 | test_mmd=0.0142\n",
      "[CellOT] epoch=700 f_loss=-7.6891 g_loss=18.2307 | train mmd=0.2658 | test_mmd=0.0107\n",
      "[CellOT] epoch=750 f_loss=-5.0444 g_loss=19.9717 | train mmd=0.2143 | test_mmd=0.0083\n",
      "[CellOT] epoch=800 f_loss=-0.6728 g_loss=14.2119 | train mmd=0.0910 | test_mmd=0.0119\n",
      "[CellOT] epoch=850 f_loss=0.3441 g_loss=12.8501 | train mmd=0.0278 | test_mmd=0.0095\n",
      "[CellOT] epoch=900 f_loss=0.1934 g_loss=14.3629 | train mmd=0.0361 | test_mmd=0.0098\n",
      "[CellOT] epoch=950 f_loss=0.1564 g_loss=15.8381 | train mmd=0.0322 | test_mmd=0.0066\n",
      "[CellOT] epoch=1000 f_loss=0.1512 g_loss=17.0881 | train mmd=0.0250 | test_mmd=0.0056\n",
      "[CellOT] epoch=1050 f_loss=0.2352 g_loss=17.2873 | train mmd=0.0173 | test_mmd=0.0132\n",
      "[CellOT] epoch=1100 f_loss=0.1375 g_loss=18.1811 | train mmd=0.0165 | test_mmd=0.0098\n",
      "[CellOT] epoch=1150 f_loss=0.2340 g_loss=18.8189 | train mmd=0.0120 | test_mmd=0.0092\n",
      "[CellOT] epoch=1200 f_loss=-0.0984 g_loss=18.5117 | train mmd=0.0104 | test_mmd=0.0103\n",
      "[CellOT] epoch=1250 f_loss=-0.2754 g_loss=19.2462 | train mmd=0.0133 | test_mmd=0.0042\n",
      "[CellOT] epoch=1300 f_loss=0.6016 g_loss=18.9024 | train mmd=0.0076 | test_mmd=0.0128\n",
      "[CellOT] epoch=1350 f_loss=0.3978 g_loss=19.3913 | train mmd=0.0093 | test_mmd=0.0069\n",
      "[CellOT] epoch=1400 f_loss=0.2361 g_loss=19.1812 | train mmd=0.0069 | test_mmd=0.0117\n",
      "[CellOT] epoch=1450 f_loss=0.0711 g_loss=18.7057 | train mmd=0.0063 | test_mmd=0.0086\n",
      "[CellOT] epoch=1500 f_loss=0.4418 g_loss=18.8184 | train mmd=0.0068 | test_mmd=0.0105\n",
      "[CellOT] epoch=1550 f_loss=0.4975 g_loss=19.4686 | train mmd=0.0076 | test_mmd=0.0070\n",
      "[CellOT] epoch=1600 f_loss=-0.1130 g_loss=19.4120 | train mmd=0.0080 | test_mmd=0.0115\n",
      "[CellOT] epoch=1650 f_loss=-0.1592 g_loss=19.4692 | train mmd=0.0082 | test_mmd=0.0049\n",
      "[CellOT] epoch=1700 f_loss=-0.4150 g_loss=19.9448 | train mmd=0.0082 | test_mmd=0.0059\n",
      "[CellOT] epoch=1750 f_loss=0.2734 g_loss=19.4884 | train mmd=0.0075 | test_mmd=0.0092\n",
      "[CellOT] epoch=1800 f_loss=0.0139 g_loss=19.5443 | train mmd=0.0093 | test_mmd=0.0112\n",
      "[CellOT] epoch=1850 f_loss=-0.5130 g_loss=19.7818 | train mmd=0.0072 | test_mmd=0.0098\n",
      "[CellOT] epoch=1900 f_loss=-0.0511 g_loss=19.9674 | train mmd=0.0067 | test_mmd=0.0060\n",
      "[CellOT] epoch=1950 f_loss=-0.1343 g_loss=19.4556 | train mmd=0.0052 | test_mmd=0.0071\n",
      "[CellOT] epoch=2000 f_loss=0.0188 g_loss=19.9823 | train mmd=0.0071 | test_mmd=0.0074\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\n",
      "[CellOT] Final CellOT MMD: 0.0085\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/ot/lp/_network_simplex.py:332: UserWarning: numItermax reached before optimality. Try to increase numItermax.\n",
      "  result_code_string = check_result(result_code)\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/umap/umap_.py:1952: UserWarning: n_jobs value 1 overridden to 1 by setting random_state. Use no seed for parallelism.\n",
      "  warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 metrics: {'mmd2_gamma_median': 0.007403159087441935, 'mmd2_gamma_0.5': 0.021735806055422024, 'mmd2_gamma_1.0': 0.021429519448054768, 'wasserstein_distance': 0.9262557331337556, 'R2_feature_means': 0.9889823403940448}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0095  0.0022\n",
      "mmd2_gamma_0.5        0.0201  0.0029\n",
      "mmd2_gamma_1.0        0.0189  0.0026\n",
      "wasserstein_distance  0.9238  0.1775\n",
      "R2_feature_means      0.9803  0.0071\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/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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Xh75aNx///1ccMEFPPLII9x55514nsdJJ51ENpvd6X6pVGrUM9i4ceNeGvHOMW/evFHjevDBB3e47b76TEp4/PHHR13LnXfeCcCZZ565w332leeSzWY58MAD+fGPfzzu59/97nf5wQ9+wNVXX82jjz5KIpFg6dKlFAqFHR5zT39zrxR2di25XI4nn3ySL3/5yzz55JP85S9/YeXKlbztbW/b5XH35Lv6qkG/BvDd735XT5s2bafbLFmyRF988cV7Z0A7waGHHqovuOCC8usgCHRra6u+4oorxt3+rLPO0m9961tHvbd48WL98Y9//FUd556is7NTA/r+++/f4TbXXnutTqfTe29Qu4nLL79cH3jggbu9/WvlmZRw8cUX6xkzZmil1Lif76vPBdB//etfy6+VUrq5uVn/z//8T/m9/v5+HYlE9O9///sdHmdPf3OvBra/lvHw2GOPaUBv3Lhxh9vs6Xf11cI+t2IYDwMDA9TW1u5yu9/+9rfU19dzwAEH8IUvfIFcLrcXRjcM13V54oknOPHEE8vvSSk58cQT+de//jXuPv/6179GbQ+wdOnSHW7/n8LAwADALp9DJpNhypQpTJo0ibe//e08//zze2N4u8Tq1atpbW1l+vTpvP/972fTpk073Pa18kwg/M795je/4SMf+QhCiB1ut68+l5FYv34927ZtG3Xv0+k0ixcv3uG9fzm/uf8UBgYGEEJQXV290+325Lv6amGfdwxr1qzhhz/8IR//+Md3ut373vc+fvOb33DvvffyhS98gV//+td84AMf2EujDNHd3U0QBDQ1NY16v6mpiW3bto27z7Zt2/Zo+/8ElFJccsklHHnkkRxwwAE73G7OnDn88pe/5Oabb+Y3v/kNSimOOOII2tra9uJox2Lx4sVcd911/OMf/+AnP/kJ69ev5+ijjy5rf2yP18IzKeGmm26iv7+fD33oQzvcZl99LtujdH/35N6/nN/cfwKFQoHPfe5zvPe9790pq+qefldfLew12u3Pf/7zfOc739npNi+++OKoRMuWLVs4+eSTOfPMM/noRz+6030/9rGPlf+eP38+LS0tnHDCCaxdu5YZM2b8e4N/g+OCCy7gueee22Ws8/DDD+fwww8vvz7iiCPYb7/9uOaaa/jGN77xag9zhzjllFPKfy9YsIDFixczZcoUbrjhBs4999z/2LheCfziF7/glFNOobW1dYfb7KvP5Y0Cz/M466yz0Frzk5/8ZKfb7ivf1b3mGD7zmc/sdFYDMH369PLf7e3tHHfccRxxxBH89Kc/3ePzLV68GAhXHHvLMdTX12MYBh0dHaPe7+jooLm5edx9mpub92j7vY0LL7yQW265hQceeGBcnYydwbIsDjroINasWfMqje7lobq6mtmzZ+9wXPv6Mylh48aN3HXXXfzlL3/Zo/321edSur8dHR20tLSU3+/o6GDhwoXj7vNyfnN7EyWnsHHjRu6555491mDY1Xf11cJeCyU1NDQwd+7cnf6zbRsIVwrHHnssBx98MNdee+0u1YbGw4oVKwBGfcFebdi2zcEHH8zdd99dfk8pxd133z1qxjYShx9++KjtAe68884dbr+3oLXmwgsv5K9//Sv33HMP06ZN2+NjBEHAs88+u1efwe4gk8mwdu3aHY5rX30m2+Paa6+lsbGRt771rXu03776XKZNm0Zzc/Ooez84OMijjz66w3v/cn5zewslp7B69Wruuusu6urq9vgYu/quvmr4T2e/t0dbW5ueOXOmPuGEE3RbW5veunVr+d/IbebMmaMfffRRrbXWa9as0V//+tf18uXL9fr16/XNN9+sp0+fro855pi9Pv4//OEPOhKJ6Ouuu06/8MIL+mMf+5iurq7W27Zt01prffbZZ+vPf/7z5e0feughbZqm/t73vqdffPFFffnll2vLsvSzzz6718c+Ep/4xCd0Op3W991336hnkMvlyttsfy1f+9rX9B133KHXrl2rn3jiCf2e97xHR6NR/fzzz/8nLqGMz3zmM/q+++7T69ev1w899JA+8cQTdX19ve7s7NRav3aeyUgEQaAnT56sP/e5z435bF9+LkNDQ/qpp57STz31lAb097//ff3UU0+VK3W+/e1v6+rqan3zzTfrZ555Rr/97W/X06ZN0/l8vnyM448/Xv/whz8sv97Vb+4/cS2u6+q3ve1teuLEiXrFihWjfkOO4+zwWnb1Xd1b2Occw7XXXquBcf+VsH79eg3oe++9V2ut9aZNm/Qxxxyja2trdSQS0TNnztSXXXaZHhgY+I9cww9/+EM9efJkbdu2PvTQQ/UjjzxS/mzJkiX6gx/84Kjtb7jhBj179mxt27aeN2+evvXWW/fyiMdiR8/g2muvLW+z/bVccskl5etuamrSb3nLW/STTz659we/Hd797nfrlpYWbdu2njBhgn73u9+t16xZU/78tfJMRuKOO+7QgF65cuWYz/bl53LvvfeO+70qjVcppb/85S/rpqYmHYlE9AknnDDmGqdMmaIvv/zyUe/t7Df3n7iWko0a71/Jbo13Lbv6ru4tVPQYKqigggoqGIV9vly1ggoqqKCCvYuKY6igggoqqGAUKo6hggoqqKCCUag4hgoqqKCCCkah4hgqqKCCCioYhYpjqKCCCiqoYBQqjqGCCiqooIJRqDiGCiqooIIKRqHiGCqooIIKKhiFimOooIIKKqhgFCqOoYIKKqigglH4/wEWnQTY0JL4mQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"Vem\"\n",
    "X_pre_replicate_1, X_post_replicate_1 = prepare_pair_from_mat('WM902B', 'DMSO','24h', drug, '72h', 1)\n",
    "X_pre_replicate_2, X_post_replicate_2 = prepare_pair_from_mat('WM902B', 'DMSO','24h', drug, '72h', 2) \n",
    "\n",
    "jfe_indices = [1, 6, 0, 5, 4, 7, 8, 2, 3, 19]  \n",
    "\n",
    "\n",
    "X_tr_pre = X_pre_replicate_1\n",
    "Y_tr_post = X_post_replicate_1\n",
    "X_te_pre = X_pre_replicate_2\n",
    "Y_te_post = X_post_replicate_2\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 = run_cellot_pair(X_tr_pre[:, jfe_indices], Y_tr_post[:, jfe_indices], X_te_pre[:, jfe_indices], Y_te_post[:, jfe_indices], n_epochs=2000)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post[:, jfe_indices], median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post[:, jfe_indices]\n",
    "target = Y_te_post[:, jfe_indices]\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#C88131\")\n",
    "ax.scatter(y_pred_umap[:, 0], y_pred_umap[:, 1], s=10, alpha=0.7, label='predicted cells', color=\"#1F4D8D\")\n",
    "\n",
    "ax.set_title(f'{drug}')\n",
    "# ax.set_xlabel('UMAP 1')\n",
    "# ax.set_ylabel('UMAP 2')\n",
    "ax.set_aspect('equal', 'box')\n",
    "# Add a legend to distinguish the points\n",
    "ax.legend()\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "# Display the plot\n",
    "plt.savefig(f\"./plots/cellot_on_4i_drug_{drug}.png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9747cc38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "610e4869",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cell line:  SKMEL19\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n",
      "Cell line:  SKMEL19\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1514, 20)\n",
      "(1163, 20)\n",
      "(1514, 20)\n",
      "(1163, 20)\n",
      "Median heuristic gamma: 0.10646172143931386\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-0.1288 g_loss=-4.6910 | train mmd=0.3141 | test_mmd=0.8676\n",
      "[CellOT] epoch=50 f_loss=-2.5526 g_loss=-1.6935 | train mmd=0.1034 | test_mmd=0.0861\n",
      "[CellOT] epoch=100 f_loss=-0.9097 g_loss=-0.7224 | train mmd=0.1247 | test_mmd=0.0291\n",
      "[CellOT] epoch=150 f_loss=-0.8934 g_loss=0.5856 | train mmd=0.1036 | test_mmd=0.0164\n",
      "[CellOT] epoch=200 f_loss=-0.9848 g_loss=2.0051 | train mmd=0.0801 | test_mmd=0.0130\n",
      "[CellOT] epoch=250 f_loss=-0.7718 g_loss=1.9986 | train mmd=0.0706 | test_mmd=0.0103\n",
      "[CellOT] epoch=300 f_loss=-0.0440 g_loss=2.0497 | train mmd=0.0649 | test_mmd=0.0073\n",
      "[CellOT] epoch=350 f_loss=-0.4820 g_loss=2.5921 | train mmd=0.0500 | test_mmd=0.0059\n",
      "[CellOT] epoch=400 f_loss=-0.4879 g_loss=2.8285 | train mmd=0.0478 | test_mmd=0.0057\n",
      "[CellOT] epoch=450 f_loss=-0.2042 g_loss=3.5881 | train mmd=0.0368 | test_mmd=0.0075\n",
      "[CellOT] epoch=500 f_loss=0.1309 g_loss=2.8540 | train mmd=0.0269 | test_mmd=0.0072\n",
      "[CellOT] epoch=550 f_loss=0.0302 g_loss=4.2940 | train mmd=0.0133 | test_mmd=0.0072\n",
      "[CellOT] epoch=600 f_loss=-0.1290 g_loss=5.1911 | train mmd=0.0107 | test_mmd=0.0091\n",
      "[CellOT] epoch=650 f_loss=0.8269 g_loss=5.8186 | train mmd=0.0079 | test_mmd=0.0052\n",
      "[CellOT] epoch=700 f_loss=-0.3235 g_loss=6.2039 | train mmd=0.0044 | test_mmd=0.0086\n",
      "[CellOT] epoch=750 f_loss=-0.5048 g_loss=7.3268 | train mmd=0.0061 | test_mmd=0.0122\n",
      "[CellOT] epoch=800 f_loss=-0.0348 g_loss=7.0312 | train mmd=0.0037 | test_mmd=0.0092\n",
      "[CellOT] epoch=850 f_loss=-0.0548 g_loss=6.7285 | train mmd=0.0039 | test_mmd=0.0129\n",
      "[CellOT] epoch=900 f_loss=0.0046 g_loss=7.2523 | train mmd=0.0051 | test_mmd=0.0086\n",
      "[CellOT] epoch=950 f_loss=-0.2304 g_loss=7.5115 | train mmd=0.0026 | test_mmd=0.0087\n",
      "[CellOT] epoch=1000 f_loss=-0.0509 g_loss=7.4957 | train mmd=0.0038 | test_mmd=0.0090\n",
      "[CellOT] epoch=1050 f_loss=0.5969 g_loss=7.6046 | train mmd=0.0037 | test_mmd=0.0105\n",
      "[CellOT] epoch=1100 f_loss=-0.0387 g_loss=7.5855 | train mmd=0.0027 | test_mmd=0.0103\n",
      "[CellOT] epoch=1150 f_loss=0.0096 g_loss=7.1153 | train mmd=0.0025 | test_mmd=0.0108\n",
      "[CellOT] epoch=1200 f_loss=0.0016 g_loss=7.4889 | train mmd=0.0035 | test_mmd=0.0121\n",
      "[CellOT] epoch=1250 f_loss=0.1730 g_loss=7.4933 | train mmd=0.0022 | test_mmd=0.0103\n",
      "[CellOT] epoch=1300 f_loss=0.1677 g_loss=7.5615 | train mmd=0.0018 | test_mmd=0.0098\n",
      "[CellOT] epoch=1350 f_loss=-0.2139 g_loss=7.3055 | train mmd=0.0057 | test_mmd=0.0143\n",
      "[CellOT] epoch=1400 f_loss=0.6843 g_loss=7.6086 | train mmd=0.0019 | test_mmd=0.0088\n",
      "[CellOT] epoch=1450 f_loss=0.3078 g_loss=7.6328 | train mmd=0.0022 | test_mmd=0.0096\n",
      "[CellOT] epoch=1500 f_loss=-0.2151 g_loss=7.9714 | train mmd=0.0040 | test_mmd=0.0116\n",
      "[CellOT] epoch=1550 f_loss=0.5224 g_loss=7.3651 | train mmd=0.0041 | test_mmd=0.0100\n",
      "[CellOT] epoch=1600 f_loss=0.0582 g_loss=7.4285 | train mmd=0.0026 | test_mmd=0.0110\n",
      "[CellOT] epoch=1650 f_loss=0.0445 g_loss=7.6658 | train mmd=0.0014 | test_mmd=0.0111\n",
      "[CellOT] epoch=1700 f_loss=-0.4964 g_loss=7.7074 | train mmd=0.0022 | test_mmd=0.0100\n",
      "[CellOT] epoch=1750 f_loss=-0.6487 g_loss=8.5360 | train mmd=0.0027 | test_mmd=0.0097\n",
      "[CellOT] epoch=1800 f_loss=-0.4959 g_loss=7.8492 | train mmd=0.0036 | test_mmd=0.0121\n",
      "[CellOT] epoch=1850 f_loss=-0.2508 g_loss=7.6765 | train mmd=0.0021 | test_mmd=0.0108\n",
      "[CellOT] epoch=1900 f_loss=0.1558 g_loss=8.0886 | train mmd=0.0021 | test_mmd=0.0083\n",
      "[CellOT] epoch=1950 f_loss=-0.0191 g_loss=8.1003 | train mmd=0.0021 | test_mmd=0.0100\n",
      "[CellOT] epoch=2000 f_loss=-0.3714 g_loss=7.5066 | train mmd=0.0049 | test_mmd=0.0144\n",
      "[CellOT] Final CellOT MMD: 0.0099\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=0.5185 g_loss=-4.1128 | train mmd=0.3520 | test_mmd=0.7553\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.014379312181877157, 'mmd2_gamma_0.5': 0.025850529153371937, 'mmd2_gamma_1.0': 0.02316241446454717, 'wasserstein_distance': 0.6483409992457778, 'R2_feature_means': 0.9761351667751984}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.0442 g_loss=-1.3686 | train mmd=0.1192 | test_mmd=0.0824\n",
      "[CellOT] epoch=100 f_loss=-0.7159 g_loss=-0.1028 | train mmd=0.2068 | test_mmd=0.0381\n",
      "[CellOT] epoch=150 f_loss=-2.1043 g_loss=1.0695 | train mmd=0.1561 | test_mmd=0.0266\n",
      "[CellOT] epoch=200 f_loss=-1.2999 g_loss=1.7679 | train mmd=0.1202 | test_mmd=0.0161\n",
      "[CellOT] epoch=250 f_loss=-2.2656 g_loss=2.3754 | train mmd=0.1006 | test_mmd=0.0114\n",
      "[CellOT] epoch=300 f_loss=-1.5010 g_loss=2.7535 | train mmd=0.0822 | test_mmd=0.0086\n",
      "[CellOT] epoch=350 f_loss=-0.2776 g_loss=3.0432 | train mmd=0.0674 | test_mmd=0.0075\n",
      "[CellOT] epoch=400 f_loss=-1.1024 g_loss=3.3048 | train mmd=0.0456 | test_mmd=0.0063\n",
      "[CellOT] epoch=450 f_loss=-0.4714 g_loss=3.3371 | train mmd=0.0332 | test_mmd=0.0063\n",
      "[CellOT] epoch=500 f_loss=0.1743 g_loss=3.5129 | train mmd=0.0244 | test_mmd=0.0099\n",
      "[CellOT] epoch=550 f_loss=0.2496 g_loss=3.5112 | train mmd=0.0197 | test_mmd=0.0105\n",
      "[CellOT] epoch=600 f_loss=0.0455 g_loss=5.1064 | train mmd=0.0198 | test_mmd=0.0070\n",
      "[CellOT] epoch=650 f_loss=-0.5297 g_loss=5.7643 | train mmd=0.0196 | test_mmd=0.0085\n",
      "[CellOT] epoch=700 f_loss=-0.3020 g_loss=7.2682 | train mmd=0.0156 | test_mmd=0.0069\n",
      "[CellOT] epoch=750 f_loss=-0.2677 g_loss=7.2686 | train mmd=0.0134 | test_mmd=0.0069\n",
      "[CellOT] epoch=800 f_loss=0.3413 g_loss=7.3010 | train mmd=0.0124 | test_mmd=0.0107\n",
      "[CellOT] epoch=850 f_loss=0.0245 g_loss=8.2002 | train mmd=0.0065 | test_mmd=0.0087\n",
      "[CellOT] epoch=900 f_loss=-0.2605 g_loss=8.1431 | train mmd=0.0043 | test_mmd=0.0069\n",
      "[CellOT] epoch=950 f_loss=0.2334 g_loss=8.6113 | train mmd=0.0040 | test_mmd=0.0111\n",
      "[CellOT] epoch=1000 f_loss=-0.1551 g_loss=8.4235 | train mmd=0.0044 | test_mmd=0.0101\n",
      "[CellOT] epoch=1050 f_loss=0.1564 g_loss=7.3780 | train mmd=0.0038 | test_mmd=0.0089\n",
      "[CellOT] epoch=1100 f_loss=-0.2224 g_loss=7.9982 | train mmd=0.0026 | test_mmd=0.0099\n",
      "[CellOT] epoch=1150 f_loss=0.2315 g_loss=8.3204 | train mmd=0.0043 | test_mmd=0.0089\n",
      "[CellOT] epoch=1200 f_loss=-0.0600 g_loss=8.4974 | train mmd=0.0029 | test_mmd=0.0088\n",
      "[CellOT] epoch=1250 f_loss=-0.0394 g_loss=8.0828 | train mmd=0.0031 | test_mmd=0.0069\n",
      "[CellOT] epoch=1300 f_loss=-0.5747 g_loss=8.1790 | train mmd=0.0021 | test_mmd=0.0076\n",
      "[CellOT] epoch=1350 f_loss=-0.0340 g_loss=8.6664 | train mmd=0.0039 | test_mmd=0.0091\n",
      "[CellOT] epoch=1400 f_loss=0.2589 g_loss=8.6433 | train mmd=0.0026 | test_mmd=0.0064\n",
      "[CellOT] epoch=1450 f_loss=-0.1178 g_loss=8.2986 | train mmd=0.0027 | test_mmd=0.0105\n",
      "[CellOT] epoch=1500 f_loss=-0.0064 g_loss=8.5489 | train mmd=0.0020 | test_mmd=0.0064\n",
      "[CellOT] epoch=1550 f_loss=0.0990 g_loss=8.2947 | train mmd=0.0033 | test_mmd=0.0112\n",
      "[CellOT] epoch=1600 f_loss=0.1940 g_loss=8.6850 | train mmd=0.0023 | test_mmd=0.0095\n",
      "[CellOT] epoch=1650 f_loss=0.1575 g_loss=8.8025 | train mmd=0.0027 | test_mmd=0.0083\n",
      "[CellOT] epoch=1700 f_loss=-0.1240 g_loss=8.2129 | train mmd=0.0017 | test_mmd=0.0100\n",
      "[CellOT] epoch=1750 f_loss=-0.0437 g_loss=8.5194 | train mmd=0.0028 | test_mmd=0.0096\n",
      "[CellOT] epoch=1800 f_loss=1.0199 g_loss=8.2312 | train mmd=0.0025 | test_mmd=0.0089\n",
      "[CellOT] epoch=1850 f_loss=-0.5727 g_loss=8.8161 | train mmd=0.0022 | test_mmd=0.0083\n",
      "[CellOT] epoch=1900 f_loss=0.0830 g_loss=9.0805 | train mmd=0.0022 | test_mmd=0.0096\n",
      "[CellOT] epoch=1950 f_loss=0.2028 g_loss=8.4227 | train mmd=0.0027 | test_mmd=0.0090\n",
      "[CellOT] epoch=2000 f_loss=-0.2625 g_loss=9.1412 | train mmd=0.0026 | test_mmd=0.0108\n",
      "[CellOT] Final CellOT MMD: 0.0076\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-0.6539 g_loss=-3.9701 | train mmd=0.2692 | test_mmd=0.6472\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.0107527583250977, 'mmd2_gamma_0.5': 0.018305496981259717, 'mmd2_gamma_1.0': 0.01740957390760095, 'wasserstein_distance': 0.6435498425921716, 'R2_feature_means': 0.9813137485166155}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.3617 g_loss=-1.4341 | train mmd=0.1009 | test_mmd=0.0793\n",
      "[CellOT] epoch=100 f_loss=-0.8986 g_loss=0.1176 | train mmd=0.1158 | test_mmd=0.0267\n",
      "[CellOT] epoch=150 f_loss=-0.9153 g_loss=0.2500 | train mmd=0.1233 | test_mmd=0.0169\n",
      "[CellOT] epoch=200 f_loss=-0.9341 g_loss=1.9341 | train mmd=0.0937 | test_mmd=0.0130\n",
      "[CellOT] epoch=250 f_loss=-0.9063 g_loss=2.0978 | train mmd=0.0623 | test_mmd=0.0081\n",
      "[CellOT] epoch=300 f_loss=-0.4201 g_loss=2.3785 | train mmd=0.0470 | test_mmd=0.0051\n",
      "[CellOT] epoch=350 f_loss=-0.9392 g_loss=3.0938 | train mmd=0.0544 | test_mmd=0.0073\n",
      "[CellOT] epoch=400 f_loss=-0.3874 g_loss=2.9052 | train mmd=0.0408 | test_mmd=0.0052\n",
      "[CellOT] epoch=450 f_loss=0.1999 g_loss=2.3848 | train mmd=0.0264 | test_mmd=0.0081\n",
      "[CellOT] epoch=500 f_loss=-0.5637 g_loss=3.6466 | train mmd=0.0148 | test_mmd=0.0079\n",
      "[CellOT] epoch=550 f_loss=0.3637 g_loss=3.7612 | train mmd=0.0102 | test_mmd=0.0053\n",
      "[CellOT] epoch=600 f_loss=0.2616 g_loss=4.7221 | train mmd=0.0083 | test_mmd=0.0086\n",
      "[CellOT] epoch=650 f_loss=-0.4170 g_loss=4.7286 | train mmd=0.0069 | test_mmd=0.0092\n",
      "[CellOT] epoch=700 f_loss=0.3210 g_loss=4.9289 | train mmd=0.0044 | test_mmd=0.0102\n",
      "[CellOT] epoch=750 f_loss=0.1762 g_loss=4.9249 | train mmd=0.0051 | test_mmd=0.0073\n",
      "[CellOT] epoch=800 f_loss=-0.3000 g_loss=5.2340 | train mmd=0.0032 | test_mmd=0.0091\n",
      "[CellOT] epoch=850 f_loss=-0.4168 g_loss=5.5061 | train mmd=0.0043 | test_mmd=0.0112\n",
      "[CellOT] epoch=900 f_loss=-0.3421 g_loss=5.9370 | train mmd=0.0032 | test_mmd=0.0108\n",
      "[CellOT] epoch=950 f_loss=0.2888 g_loss=5.1711 | train mmd=0.0034 | test_mmd=0.0055\n",
      "[CellOT] epoch=1000 f_loss=-0.4688 g_loss=6.0022 | train mmd=0.0026 | test_mmd=0.0076\n",
      "[CellOT] epoch=1050 f_loss=0.8013 g_loss=6.1329 | train mmd=0.0037 | test_mmd=0.0128\n",
      "[CellOT] epoch=1100 f_loss=-0.3182 g_loss=5.5409 | train mmd=0.0030 | test_mmd=0.0099\n",
      "[CellOT] epoch=1150 f_loss=-0.1814 g_loss=5.8875 | train mmd=0.0033 | test_mmd=0.0107\n",
      "[CellOT] epoch=1200 f_loss=-0.1737 g_loss=5.7565 | train mmd=0.0020 | test_mmd=0.0112\n",
      "[CellOT] epoch=1250 f_loss=-0.1374 g_loss=5.5331 | train mmd=0.0024 | test_mmd=0.0111\n",
      "[CellOT] epoch=1300 f_loss=-0.5889 g_loss=6.3353 | train mmd=0.0034 | test_mmd=0.0133\n",
      "[CellOT] epoch=1350 f_loss=0.3844 g_loss=5.7581 | train mmd=0.0023 | test_mmd=0.0088\n",
      "[CellOT] epoch=1400 f_loss=0.3117 g_loss=5.7742 | train mmd=0.0024 | test_mmd=0.0075\n",
      "[CellOT] epoch=1450 f_loss=0.1278 g_loss=5.7979 | train mmd=0.0036 | test_mmd=0.0110\n",
      "[CellOT] epoch=1500 f_loss=-0.3262 g_loss=6.0535 | train mmd=0.0016 | test_mmd=0.0084\n",
      "[CellOT] epoch=1550 f_loss=-0.0446 g_loss=5.4616 | train mmd=0.0025 | test_mmd=0.0123\n",
      "[CellOT] epoch=1600 f_loss=-0.3076 g_loss=6.1155 | train mmd=0.0033 | test_mmd=0.0130\n",
      "[CellOT] epoch=1650 f_loss=0.0135 g_loss=5.6465 | train mmd=0.0026 | test_mmd=0.0075\n",
      "[CellOT] epoch=1700 f_loss=-0.5956 g_loss=6.0455 | train mmd=0.0020 | test_mmd=0.0112\n",
      "[CellOT] epoch=1750 f_loss=-0.2758 g_loss=5.3850 | train mmd=0.0034 | test_mmd=0.0104\n",
      "[CellOT] epoch=1800 f_loss=0.4400 g_loss=5.6228 | train mmd=0.0019 | test_mmd=0.0103\n",
      "[CellOT] epoch=1850 f_loss=0.1596 g_loss=5.2360 | train mmd=0.0026 | test_mmd=0.0107\n",
      "[CellOT] epoch=1900 f_loss=-0.2433 g_loss=5.8434 | train mmd=0.0016 | test_mmd=0.0086\n",
      "[CellOT] epoch=1950 f_loss=0.0392 g_loss=5.6385 | train mmd=0.0026 | test_mmd=0.0123\n",
      "[CellOT] epoch=2000 f_loss=0.2300 g_loss=6.2252 | train mmd=0.0029 | test_mmd=0.0076\n",
      "[CellOT] Final CellOT MMD: 0.0059\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=1.0261 g_loss=-3.6595 | train mmd=0.3392 | test_mmd=0.8216\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.007552635909647387, 'mmd2_gamma_0.5': 0.01461354606251597, 'mmd2_gamma_1.0': 0.014160784891908307, 'wasserstein_distance': 0.6094025653334805, 'R2_feature_means': 0.9881658985274007}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.7330 g_loss=-1.6853 | train mmd=0.1195 | test_mmd=0.1011\n",
      "[CellOT] epoch=100 f_loss=-0.4814 g_loss=-0.0681 | train mmd=0.1166 | test_mmd=0.0263\n",
      "[CellOT] epoch=150 f_loss=-1.1962 g_loss=0.8765 | train mmd=0.1117 | test_mmd=0.0191\n",
      "[CellOT] epoch=200 f_loss=-1.3470 g_loss=1.2103 | train mmd=0.0979 | test_mmd=0.0146\n",
      "[CellOT] epoch=250 f_loss=-1.0889 g_loss=1.5548 | train mmd=0.0721 | test_mmd=0.0134\n",
      "[CellOT] epoch=300 f_loss=-1.3671 g_loss=2.1863 | train mmd=0.0822 | test_mmd=0.0081\n",
      "[CellOT] epoch=350 f_loss=-0.8212 g_loss=3.0793 | train mmd=0.0638 | test_mmd=0.0086\n",
      "[CellOT] epoch=400 f_loss=0.0607 g_loss=2.8015 | train mmd=0.0506 | test_mmd=0.0075\n",
      "[CellOT] epoch=450 f_loss=0.0408 g_loss=3.1258 | train mmd=0.0362 | test_mmd=0.0063\n",
      "[CellOT] epoch=500 f_loss=-0.8080 g_loss=3.2454 | train mmd=0.0381 | test_mmd=0.0077\n",
      "[CellOT] epoch=550 f_loss=-0.2488 g_loss=4.1154 | train mmd=0.0220 | test_mmd=0.0069\n",
      "[CellOT] epoch=600 f_loss=-0.3337 g_loss=4.5706 | train mmd=0.0144 | test_mmd=0.0112\n",
      "[CellOT] epoch=650 f_loss=-0.1766 g_loss=5.3382 | train mmd=0.0144 | test_mmd=0.0098\n",
      "[CellOT] epoch=700 f_loss=-0.6547 g_loss=5.8962 | train mmd=0.0076 | test_mmd=0.0102\n",
      "[CellOT] epoch=750 f_loss=0.5753 g_loss=5.8605 | train mmd=0.0052 | test_mmd=0.0085\n",
      "[CellOT] epoch=800 f_loss=-0.0216 g_loss=6.4251 | train mmd=0.0045 | test_mmd=0.0108\n",
      "[CellOT] epoch=850 f_loss=-0.0267 g_loss=6.7416 | train mmd=0.0038 | test_mmd=0.0073\n",
      "[CellOT] epoch=900 f_loss=0.3998 g_loss=6.3137 | train mmd=0.0029 | test_mmd=0.0086\n",
      "[CellOT] epoch=950 f_loss=-0.0364 g_loss=6.7906 | train mmd=0.0031 | test_mmd=0.0075\n",
      "[CellOT] epoch=1000 f_loss=0.2820 g_loss=6.9980 | train mmd=0.0042 | test_mmd=0.0139\n",
      "[CellOT] epoch=1050 f_loss=0.0064 g_loss=6.4702 | train mmd=0.0031 | test_mmd=0.0100\n",
      "[CellOT] epoch=1100 f_loss=0.0178 g_loss=6.7180 | train mmd=0.0021 | test_mmd=0.0084\n",
      "[CellOT] epoch=1150 f_loss=0.1757 g_loss=6.9853 | train mmd=0.0026 | test_mmd=0.0060\n",
      "[CellOT] epoch=1200 f_loss=-0.1414 g_loss=6.7832 | train mmd=0.0016 | test_mmd=0.0082\n",
      "[CellOT] epoch=1250 f_loss=0.5281 g_loss=6.9662 | train mmd=0.0026 | test_mmd=0.0091\n",
      "[CellOT] epoch=1300 f_loss=-0.4546 g_loss=6.6016 | train mmd=0.0017 | test_mmd=0.0076\n",
      "[CellOT] epoch=1350 f_loss=-0.2807 g_loss=7.0061 | train mmd=0.0031 | test_mmd=0.0069\n",
      "[CellOT] epoch=1400 f_loss=0.0654 g_loss=6.6949 | train mmd=0.0029 | test_mmd=0.0109\n",
      "[CellOT] epoch=1450 f_loss=-0.3275 g_loss=6.6581 | train mmd=0.0021 | test_mmd=0.0120\n",
      "[CellOT] epoch=1500 f_loss=-0.3123 g_loss=7.1190 | train mmd=0.0023 | test_mmd=0.0091\n",
      "[CellOT] epoch=1550 f_loss=0.7029 g_loss=6.8521 | train mmd=0.0016 | test_mmd=0.0068\n",
      "[CellOT] epoch=1600 f_loss=-0.4171 g_loss=7.1674 | train mmd=0.0032 | test_mmd=0.0069\n",
      "[CellOT] epoch=1650 f_loss=-0.4373 g_loss=7.0088 | train mmd=0.0039 | test_mmd=0.0098\n",
      "[CellOT] epoch=1700 f_loss=0.9229 g_loss=6.8439 | train mmd=0.0026 | test_mmd=0.0098\n",
      "[CellOT] epoch=1750 f_loss=0.0679 g_loss=7.4088 | train mmd=0.0023 | test_mmd=0.0102\n",
      "[CellOT] epoch=1800 f_loss=-0.1332 g_loss=7.0890 | train mmd=0.0028 | test_mmd=0.0102\n",
      "[CellOT] epoch=1850 f_loss=-0.1778 g_loss=7.1085 | train mmd=0.0027 | test_mmd=0.0100\n",
      "[CellOT] epoch=1900 f_loss=-0.5251 g_loss=6.6521 | train mmd=0.0018 | test_mmd=0.0112\n",
      "[CellOT] epoch=1950 f_loss=-0.8353 g_loss=7.2095 | train mmd=0.0018 | test_mmd=0.0087\n",
      "[CellOT] epoch=2000 f_loss=0.1739 g_loss=7.6708 | train mmd=0.0025 | test_mmd=0.0135\n",
      "[CellOT] Final CellOT MMD: 0.0092\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=0.8951 g_loss=-7.8485 | train mmd=0.2552 | test_mmd=0.9456\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.013501400142071684, 'mmd2_gamma_0.5': 0.023732506946027465, 'mmd2_gamma_1.0': 0.02110075389143712, 'wasserstein_distance': 0.6441105063705861, 'R2_feature_means': 0.9782364583285744}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.4685 g_loss=-1.6270 | train mmd=0.1508 | test_mmd=0.1467\n",
      "[CellOT] epoch=100 f_loss=-1.6968 g_loss=-0.0579 | train mmd=0.1764 | test_mmd=0.0390\n",
      "[CellOT] epoch=150 f_loss=-2.0715 g_loss=0.5866 | train mmd=0.1443 | test_mmd=0.0236\n",
      "[CellOT] epoch=200 f_loss=-1.4991 g_loss=2.0609 | train mmd=0.1190 | test_mmd=0.0164\n",
      "[CellOT] epoch=250 f_loss=-1.3255 g_loss=1.5561 | train mmd=0.1067 | test_mmd=0.0115\n",
      "[CellOT] epoch=300 f_loss=-1.3263 g_loss=2.5341 | train mmd=0.0916 | test_mmd=0.0090\n",
      "[CellOT] epoch=350 f_loss=-1.0154 g_loss=2.9496 | train mmd=0.0810 | test_mmd=0.0083\n",
      "[CellOT] epoch=400 f_loss=-0.4526 g_loss=3.0889 | train mmd=0.0587 | test_mmd=0.0069\n",
      "[CellOT] epoch=450 f_loss=0.8012 g_loss=3.7668 | train mmd=0.0475 | test_mmd=0.0086\n",
      "[CellOT] epoch=500 f_loss=-0.1894 g_loss=3.6164 | train mmd=0.0538 | test_mmd=0.0075\n",
      "[CellOT] epoch=550 f_loss=-0.0789 g_loss=4.3394 | train mmd=0.0382 | test_mmd=0.0071\n",
      "[CellOT] epoch=600 f_loss=0.0306 g_loss=5.2876 | train mmd=0.0269 | test_mmd=0.0070\n",
      "[CellOT] epoch=650 f_loss=-0.1684 g_loss=7.5198 | train mmd=0.0257 | test_mmd=0.0062\n",
      "[CellOT] epoch=700 f_loss=0.5837 g_loss=8.5088 | train mmd=0.0257 | test_mmd=0.0079\n",
      "[CellOT] epoch=750 f_loss=-0.1967 g_loss=9.8463 | train mmd=0.0176 | test_mmd=0.0067\n",
      "[CellOT] epoch=800 f_loss=-0.0149 g_loss=9.9571 | train mmd=0.0128 | test_mmd=0.0085\n",
      "[CellOT] epoch=850 f_loss=0.1715 g_loss=10.7613 | train mmd=0.0063 | test_mmd=0.0075\n",
      "[CellOT] epoch=900 f_loss=-0.0440 g_loss=10.9866 | train mmd=0.0048 | test_mmd=0.0084\n",
      "[CellOT] epoch=950 f_loss=0.1325 g_loss=10.7678 | train mmd=0.0051 | test_mmd=0.0126\n",
      "[CellOT] epoch=1000 f_loss=0.4867 g_loss=10.4208 | train mmd=0.0036 | test_mmd=0.0099\n",
      "[CellOT] epoch=1050 f_loss=0.3748 g_loss=10.5197 | train mmd=0.0033 | test_mmd=0.0117\n",
      "[CellOT] epoch=1100 f_loss=0.4744 g_loss=10.5551 | train mmd=0.0044 | test_mmd=0.0106\n",
      "[CellOT] epoch=1150 f_loss=0.0671 g_loss=10.6660 | train mmd=0.0021 | test_mmd=0.0083\n",
      "[CellOT] epoch=1200 f_loss=0.5038 g_loss=10.4866 | train mmd=0.0024 | test_mmd=0.0069\n",
      "[CellOT] epoch=1250 f_loss=0.3500 g_loss=10.7938 | train mmd=0.0030 | test_mmd=0.0077\n",
      "[CellOT] epoch=1300 f_loss=0.2864 g_loss=10.8335 | train mmd=0.0027 | test_mmd=0.0066\n",
      "[CellOT] epoch=1350 f_loss=-0.3569 g_loss=10.7947 | train mmd=0.0030 | test_mmd=0.0097\n",
      "[CellOT] epoch=1400 f_loss=0.3577 g_loss=10.7991 | train mmd=0.0030 | test_mmd=0.0103\n",
      "[CellOT] epoch=1450 f_loss=-0.1091 g_loss=10.7166 | train mmd=0.0026 | test_mmd=0.0083\n",
      "[CellOT] epoch=1500 f_loss=-0.8621 g_loss=10.7971 | train mmd=0.0018 | test_mmd=0.0099\n",
      "[CellOT] epoch=1550 f_loss=0.0905 g_loss=10.9779 | train mmd=0.0028 | test_mmd=0.0110\n",
      "[CellOT] epoch=1600 f_loss=-0.0264 g_loss=10.4554 | train mmd=0.0018 | test_mmd=0.0084\n",
      "[CellOT] epoch=1650 f_loss=0.0268 g_loss=10.7575 | train mmd=0.0022 | test_mmd=0.0134\n",
      "[CellOT] epoch=1700 f_loss=0.1570 g_loss=10.7790 | train mmd=0.0022 | test_mmd=0.0092\n",
      "[CellOT] epoch=1750 f_loss=-0.0082 g_loss=10.6060 | train mmd=0.0031 | test_mmd=0.0136\n",
      "[CellOT] epoch=1800 f_loss=0.1271 g_loss=10.8837 | train mmd=0.0023 | test_mmd=0.0099\n",
      "[CellOT] epoch=1850 f_loss=0.1663 g_loss=10.5998 | train mmd=0.0021 | test_mmd=0.0119\n",
      "[CellOT] epoch=1900 f_loss=-0.5052 g_loss=10.8837 | train mmd=0.0021 | test_mmd=0.0076\n",
      "[CellOT] epoch=1950 f_loss=0.7681 g_loss=11.3426 | train mmd=0.0022 | test_mmd=0.0107\n",
      "[CellOT] epoch=2000 f_loss=-0.7320 g_loss=11.3484 | train mmd=0.0021 | test_mmd=0.0056\n",
      "[CellOT] Final CellOT MMD: 0.0049\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=1.9135 g_loss=-4.9904 | train mmd=0.3465 | test_mmd=0.8631\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.005603222604157576, 'mmd2_gamma_0.5': 0.012199596851060868, 'mmd2_gamma_1.0': 0.012515756968021208, 'wasserstein_distance': 0.6010577658402138, 'R2_feature_means': 0.9918046153133796}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-2.3496 g_loss=-1.2002 | train mmd=0.1266 | test_mmd=0.1333\n",
      "[CellOT] epoch=100 f_loss=-0.8596 g_loss=-0.1406 | train mmd=0.2000 | test_mmd=0.0365\n",
      "[CellOT] epoch=150 f_loss=-1.4817 g_loss=0.4742 | train mmd=0.1453 | test_mmd=0.0207\n",
      "[CellOT] epoch=200 f_loss=-1.8019 g_loss=1.5087 | train mmd=0.1065 | test_mmd=0.0149\n",
      "[CellOT] epoch=250 f_loss=-1.1183 g_loss=1.7990 | train mmd=0.0885 | test_mmd=0.0119\n",
      "[CellOT] epoch=300 f_loss=-1.5963 g_loss=2.2050 | train mmd=0.0658 | test_mmd=0.0082\n",
      "[CellOT] epoch=350 f_loss=-0.4937 g_loss=3.1440 | train mmd=0.0645 | test_mmd=0.0103\n",
      "[CellOT] epoch=400 f_loss=-0.7339 g_loss=2.8244 | train mmd=0.0298 | test_mmd=0.0064\n",
      "[CellOT] epoch=450 f_loss=0.0277 g_loss=3.0614 | train mmd=0.0294 | test_mmd=0.0093\n",
      "[CellOT] epoch=500 f_loss=0.6043 g_loss=3.4449 | train mmd=0.0252 | test_mmd=0.0069\n",
      "[CellOT] epoch=550 f_loss=0.4068 g_loss=4.5587 | train mmd=0.0190 | test_mmd=0.0074\n",
      "[CellOT] epoch=600 f_loss=-0.0415 g_loss=5.9783 | train mmd=0.0133 | test_mmd=0.0068\n",
      "[CellOT] epoch=650 f_loss=0.6559 g_loss=6.2609 | train mmd=0.0143 | test_mmd=0.0113\n",
      "[CellOT] epoch=700 f_loss=0.4955 g_loss=7.2936 | train mmd=0.0077 | test_mmd=0.0075\n",
      "[CellOT] epoch=750 f_loss=0.0334 g_loss=8.2753 | train mmd=0.0045 | test_mmd=0.0078\n",
      "[CellOT] epoch=800 f_loss=0.9627 g_loss=7.9989 | train mmd=0.0043 | test_mmd=0.0119\n",
      "[CellOT] epoch=850 f_loss=0.0021 g_loss=8.3557 | train mmd=0.0039 | test_mmd=0.0098\n",
      "[CellOT] epoch=900 f_loss=0.6717 g_loss=8.2618 | train mmd=0.0070 | test_mmd=0.0098\n",
      "[CellOT] epoch=950 f_loss=-0.3192 g_loss=8.3581 | train mmd=0.0030 | test_mmd=0.0099\n",
      "[CellOT] epoch=1000 f_loss=0.2141 g_loss=8.6618 | train mmd=0.0029 | test_mmd=0.0083\n",
      "[CellOT] epoch=1050 f_loss=0.4050 g_loss=8.2967 | train mmd=0.0028 | test_mmd=0.0109\n",
      "[CellOT] epoch=1100 f_loss=-1.0453 g_loss=8.3180 | train mmd=0.0042 | test_mmd=0.0148\n",
      "[CellOT] epoch=1150 f_loss=0.5573 g_loss=8.1658 | train mmd=0.0029 | test_mmd=0.0067\n",
      "[CellOT] epoch=1200 f_loss=0.0072 g_loss=8.5725 | train mmd=0.0032 | test_mmd=0.0102\n",
      "[CellOT] epoch=1250 f_loss=-0.2507 g_loss=8.5485 | train mmd=0.0041 | test_mmd=0.0135\n",
      "[CellOT] epoch=1300 f_loss=0.4894 g_loss=8.0949 | train mmd=0.0021 | test_mmd=0.0093\n",
      "[CellOT] epoch=1350 f_loss=-0.0327 g_loss=8.5875 | train mmd=0.0030 | test_mmd=0.0072\n",
      "[CellOT] epoch=1400 f_loss=0.4364 g_loss=9.0893 | train mmd=0.0039 | test_mmd=0.0161\n",
      "[CellOT] epoch=1450 f_loss=-0.3393 g_loss=8.4965 | train mmd=0.0036 | test_mmd=0.0109\n",
      "[CellOT] epoch=1500 f_loss=-0.0892 g_loss=9.0625 | train mmd=0.0027 | test_mmd=0.0122\n",
      "[CellOT] epoch=1550 f_loss=0.5111 g_loss=8.7829 | train mmd=0.0026 | test_mmd=0.0084\n",
      "[CellOT] epoch=1600 f_loss=-0.0474 g_loss=8.8165 | train mmd=0.0030 | test_mmd=0.0093\n",
      "[CellOT] epoch=1650 f_loss=1.3869 g_loss=8.6689 | train mmd=0.0027 | test_mmd=0.0077\n",
      "[CellOT] epoch=1700 f_loss=-0.1937 g_loss=8.8901 | train mmd=0.0026 | test_mmd=0.0150\n",
      "[CellOT] epoch=1750 f_loss=-0.2643 g_loss=8.9489 | train mmd=0.0027 | test_mmd=0.0137\n",
      "[CellOT] epoch=1800 f_loss=-0.4102 g_loss=9.0533 | train mmd=0.0022 | test_mmd=0.0068\n",
      "[CellOT] epoch=1850 f_loss=-0.3544 g_loss=9.4077 | train mmd=0.0039 | test_mmd=0.0068\n",
      "[CellOT] epoch=1900 f_loss=-0.1019 g_loss=8.8949 | train mmd=0.0029 | test_mmd=0.0105\n",
      "[CellOT] epoch=1950 f_loss=-0.0099 g_loss=8.7750 | train mmd=0.0027 | test_mmd=0.0107\n",
      "[CellOT] epoch=2000 f_loss=0.1219 g_loss=9.1123 | train mmd=0.0020 | test_mmd=0.0069\n",
      "[CellOT] Final CellOT MMD: 0.0051\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=0.2062 g_loss=-4.3245 | train mmd=0.2775 | test_mmd=0.8383\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.006859103164905012, 'mmd2_gamma_0.5': 0.012558527950271237, 'mmd2_gamma_1.0': 0.011918752636635499, 'wasserstein_distance': 0.6117725203507216, 'R2_feature_means': 0.9886163001494821}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.3606 g_loss=-1.3195 | train mmd=0.1231 | test_mmd=0.0884\n",
      "[CellOT] epoch=100 f_loss=-0.4340 g_loss=-0.0630 | train mmd=0.1413 | test_mmd=0.0304\n",
      "[CellOT] epoch=150 f_loss=-0.9327 g_loss=0.5415 | train mmd=0.1138 | test_mmd=0.0208\n",
      "[CellOT] epoch=200 f_loss=-1.8279 g_loss=1.4673 | train mmd=0.0913 | test_mmd=0.0117\n",
      "[CellOT] epoch=250 f_loss=-0.8945 g_loss=1.3462 | train mmd=0.0538 | test_mmd=0.0131\n",
      "[CellOT] epoch=300 f_loss=-0.5366 g_loss=2.6484 | train mmd=0.0418 | test_mmd=0.0080\n",
      "[CellOT] epoch=350 f_loss=-0.7413 g_loss=2.2339 | train mmd=0.0373 | test_mmd=0.0099\n",
      "[CellOT] epoch=400 f_loss=0.1570 g_loss=2.7306 | train mmd=0.0299 | test_mmd=0.0094\n",
      "[CellOT] epoch=450 f_loss=1.0773 g_loss=3.0616 | train mmd=0.0161 | test_mmd=0.0107\n",
      "[CellOT] epoch=500 f_loss=-0.2621 g_loss=3.6086 | train mmd=0.0154 | test_mmd=0.0120\n",
      "[CellOT] epoch=550 f_loss=0.3712 g_loss=4.6847 | train mmd=0.0116 | test_mmd=0.0082\n",
      "[CellOT] epoch=600 f_loss=0.2392 g_loss=5.1280 | train mmd=0.0074 | test_mmd=0.0090\n",
      "[CellOT] epoch=650 f_loss=-0.3041 g_loss=5.0485 | train mmd=0.0043 | test_mmd=0.0078\n",
      "[CellOT] epoch=700 f_loss=0.2147 g_loss=5.2196 | train mmd=0.0033 | test_mmd=0.0074\n",
      "[CellOT] epoch=750 f_loss=-0.1276 g_loss=5.7199 | train mmd=0.0031 | test_mmd=0.0141\n",
      "[CellOT] epoch=800 f_loss=-0.5912 g_loss=5.9883 | train mmd=0.0028 | test_mmd=0.0090\n",
      "[CellOT] epoch=850 f_loss=0.2043 g_loss=5.7458 | train mmd=0.0030 | test_mmd=0.0096\n",
      "[CellOT] epoch=900 f_loss=-0.2355 g_loss=5.4162 | train mmd=0.0031 | test_mmd=0.0093\n",
      "[CellOT] epoch=950 f_loss=0.1848 g_loss=5.5955 | train mmd=0.0037 | test_mmd=0.0114\n",
      "[CellOT] epoch=1000 f_loss=-0.0828 g_loss=4.9206 | train mmd=0.0026 | test_mmd=0.0094\n",
      "[CellOT] epoch=1050 f_loss=-0.4033 g_loss=5.6481 | train mmd=0.0021 | test_mmd=0.0072\n",
      "[CellOT] epoch=1100 f_loss=-0.6671 g_loss=5.4076 | train mmd=0.0020 | test_mmd=0.0097\n",
      "[CellOT] epoch=1150 f_loss=-0.6252 g_loss=5.5479 | train mmd=0.0023 | test_mmd=0.0092\n",
      "[CellOT] epoch=1200 f_loss=-0.2004 g_loss=5.4535 | train mmd=0.0027 | test_mmd=0.0132\n",
      "[CellOT] epoch=1250 f_loss=-0.3995 g_loss=5.8024 | train mmd=0.0024 | test_mmd=0.0098\n",
      "[CellOT] epoch=1300 f_loss=-0.0802 g_loss=5.3261 | train mmd=0.0025 | test_mmd=0.0104\n",
      "[CellOT] epoch=1350 f_loss=0.6408 g_loss=5.9133 | train mmd=0.0026 | test_mmd=0.0074\n",
      "[CellOT] epoch=1400 f_loss=0.1979 g_loss=5.4244 | train mmd=0.0036 | test_mmd=0.0069\n",
      "[CellOT] epoch=1450 f_loss=-0.0453 g_loss=5.7590 | train mmd=0.0018 | test_mmd=0.0074\n",
      "[CellOT] epoch=1500 f_loss=0.0921 g_loss=5.2501 | train mmd=0.0030 | test_mmd=0.0099\n",
      "[CellOT] epoch=1550 f_loss=0.5346 g_loss=5.6313 | train mmd=0.0022 | test_mmd=0.0103\n",
      "[CellOT] epoch=1600 f_loss=-0.2107 g_loss=5.3885 | train mmd=0.0033 | test_mmd=0.0119\n",
      "[CellOT] epoch=1650 f_loss=-0.6888 g_loss=5.6076 | train mmd=0.0024 | test_mmd=0.0085\n",
      "[CellOT] epoch=1700 f_loss=-0.0181 g_loss=5.9048 | train mmd=0.0024 | test_mmd=0.0089\n",
      "[CellOT] epoch=1750 f_loss=-0.1031 g_loss=5.4214 | train mmd=0.0018 | test_mmd=0.0116\n",
      "[CellOT] epoch=1800 f_loss=-0.4524 g_loss=5.9409 | train mmd=0.0028 | test_mmd=0.0071\n",
      "[CellOT] epoch=1850 f_loss=0.0189 g_loss=5.5971 | train mmd=0.0015 | test_mmd=0.0090\n",
      "[CellOT] epoch=1900 f_loss=0.1830 g_loss=5.6990 | train mmd=0.0019 | test_mmd=0.0119\n",
      "[CellOT] epoch=1950 f_loss=0.1461 g_loss=5.6109 | train mmd=0.0015 | test_mmd=0.0090\n",
      "[CellOT] epoch=2000 f_loss=0.2881 g_loss=6.2068 | train mmd=0.0016 | test_mmd=0.0084\n",
      "[CellOT] Final CellOT MMD: 0.0064\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=0.3732 g_loss=-3.3789 | train mmd=0.3306 | test_mmd=0.7211\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.008445008852562275, 'mmd2_gamma_0.5': 0.01611323740492665, 'mmd2_gamma_1.0': 0.01538634118757215, 'wasserstein_distance': 0.6055713981251073, 'R2_feature_means': 0.9873059244961738}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.5869 g_loss=-1.5295 | train mmd=0.1121 | test_mmd=0.0966\n",
      "[CellOT] epoch=100 f_loss=-0.8463 g_loss=-0.3761 | train mmd=0.1390 | test_mmd=0.0294\n",
      "[CellOT] epoch=150 f_loss=-0.8988 g_loss=0.9363 | train mmd=0.1090 | test_mmd=0.0161\n",
      "[CellOT] epoch=200 f_loss=-1.6476 g_loss=1.6267 | train mmd=0.0755 | test_mmd=0.0125\n",
      "[CellOT] epoch=250 f_loss=-1.0630 g_loss=1.6799 | train mmd=0.0691 | test_mmd=0.0104\n",
      "[CellOT] epoch=300 f_loss=-0.9625 g_loss=2.0935 | train mmd=0.0719 | test_mmd=0.0086\n",
      "[CellOT] epoch=350 f_loss=-1.4483 g_loss=2.7826 | train mmd=0.0577 | test_mmd=0.0076\n",
      "[CellOT] epoch=400 f_loss=-0.3546 g_loss=3.0711 | train mmd=0.0379 | test_mmd=0.0081\n",
      "[CellOT] epoch=450 f_loss=-0.3970 g_loss=2.7226 | train mmd=0.0433 | test_mmd=0.0080\n",
      "[CellOT] epoch=500 f_loss=0.6454 g_loss=3.5622 | train mmd=0.0286 | test_mmd=0.0064\n",
      "[CellOT] epoch=550 f_loss=0.4274 g_loss=3.6264 | train mmd=0.0168 | test_mmd=0.0063\n",
      "[CellOT] epoch=600 f_loss=0.2262 g_loss=4.4591 | train mmd=0.0124 | test_mmd=0.0086\n",
      "[CellOT] epoch=650 f_loss=0.1578 g_loss=4.9630 | train mmd=0.0081 | test_mmd=0.0100\n",
      "[CellOT] epoch=700 f_loss=0.2098 g_loss=4.7905 | train mmd=0.0050 | test_mmd=0.0107\n",
      "[CellOT] epoch=750 f_loss=0.5512 g_loss=4.8938 | train mmd=0.0037 | test_mmd=0.0078\n",
      "[CellOT] epoch=800 f_loss=-0.2222 g_loss=5.8560 | train mmd=0.0037 | test_mmd=0.0099\n",
      "[CellOT] epoch=850 f_loss=0.2696 g_loss=5.8473 | train mmd=0.0038 | test_mmd=0.0108\n",
      "[CellOT] epoch=900 f_loss=0.2225 g_loss=5.7089 | train mmd=0.0048 | test_mmd=0.0109\n",
      "[CellOT] epoch=950 f_loss=-0.2367 g_loss=5.8375 | train mmd=0.0036 | test_mmd=0.0068\n",
      "[CellOT] epoch=1000 f_loss=0.5195 g_loss=6.2684 | train mmd=0.0062 | test_mmd=0.0061\n",
      "[CellOT] epoch=1050 f_loss=-0.3889 g_loss=6.3357 | train mmd=0.0035 | test_mmd=0.0093\n",
      "[CellOT] epoch=1100 f_loss=0.0493 g_loss=6.1141 | train mmd=0.0029 | test_mmd=0.0070\n",
      "[CellOT] epoch=1150 f_loss=0.5177 g_loss=6.2289 | train mmd=0.0029 | test_mmd=0.0089\n",
      "[CellOT] epoch=1200 f_loss=0.2113 g_loss=6.0257 | train mmd=0.0042 | test_mmd=0.0104\n",
      "[CellOT] epoch=1250 f_loss=-0.0586 g_loss=5.9308 | train mmd=0.0037 | test_mmd=0.0099\n",
      "[CellOT] epoch=1300 f_loss=-0.6616 g_loss=6.3871 | train mmd=0.0024 | test_mmd=0.0063\n",
      "[CellOT] epoch=1350 f_loss=0.3639 g_loss=6.0377 | train mmd=0.0045 | test_mmd=0.0076\n",
      "[CellOT] epoch=1400 f_loss=0.1159 g_loss=6.4464 | train mmd=0.0027 | test_mmd=0.0100\n",
      "[CellOT] epoch=1450 f_loss=0.0996 g_loss=6.0860 | train mmd=0.0041 | test_mmd=0.0109\n",
      "[CellOT] epoch=1500 f_loss=0.3053 g_loss=6.5984 | train mmd=0.0020 | test_mmd=0.0105\n",
      "[CellOT] epoch=1550 f_loss=-0.5065 g_loss=6.2775 | train mmd=0.0025 | test_mmd=0.0120\n",
      "[CellOT] epoch=1600 f_loss=0.3030 g_loss=6.5337 | train mmd=0.0028 | test_mmd=0.0088\n",
      "[CellOT] epoch=1650 f_loss=-0.5923 g_loss=6.1465 | train mmd=0.0026 | test_mmd=0.0091\n",
      "[CellOT] epoch=1700 f_loss=0.0896 g_loss=6.3813 | train mmd=0.0025 | test_mmd=0.0110\n",
      "[CellOT] epoch=1750 f_loss=-0.0034 g_loss=6.0918 | train mmd=0.0025 | test_mmd=0.0066\n",
      "[CellOT] epoch=1800 f_loss=0.1082 g_loss=6.7236 | train mmd=0.0019 | test_mmd=0.0084\n",
      "[CellOT] epoch=1850 f_loss=0.0123 g_loss=7.1499 | train mmd=0.0029 | test_mmd=0.0110\n",
      "[CellOT] epoch=1900 f_loss=0.0933 g_loss=6.5773 | train mmd=0.0018 | test_mmd=0.0077\n",
      "[CellOT] epoch=1950 f_loss=0.3279 g_loss=6.8711 | train mmd=0.0025 | test_mmd=0.0075\n",
      "[CellOT] epoch=2000 f_loss=-0.0526 g_loss=6.8744 | train mmd=0.0019 | test_mmd=0.0105\n",
      "[CellOT] Final CellOT MMD: 0.0075\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=0.3330 g_loss=-4.4052 | train mmd=0.3527 | test_mmd=0.9015\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.010545478718688495, 'mmd2_gamma_0.5': 0.019087491325098016, 'mmd2_gamma_1.0': 0.01753928296031143, 'wasserstein_distance': 0.6304172371974208, 'R2_feature_means': 0.9835861347085763}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.7561 g_loss=-1.3039 | train mmd=0.1132 | test_mmd=0.1005\n",
      "[CellOT] epoch=100 f_loss=-0.2296 g_loss=-0.1264 | train mmd=0.1733 | test_mmd=0.0348\n",
      "[CellOT] epoch=150 f_loss=-1.8582 g_loss=0.4353 | train mmd=0.1381 | test_mmd=0.0232\n",
      "[CellOT] epoch=200 f_loss=-1.6027 g_loss=2.4064 | train mmd=0.1110 | test_mmd=0.0159\n",
      "[CellOT] epoch=250 f_loss=-0.9850 g_loss=2.1118 | train mmd=0.0991 | test_mmd=0.0106\n",
      "[CellOT] epoch=300 f_loss=-1.0084 g_loss=2.4533 | train mmd=0.0700 | test_mmd=0.0120\n",
      "[CellOT] epoch=350 f_loss=-0.8753 g_loss=3.2567 | train mmd=0.0789 | test_mmd=0.0071\n",
      "[CellOT] epoch=400 f_loss=-0.7588 g_loss=3.2495 | train mmd=0.0621 | test_mmd=0.0073\n",
      "[CellOT] epoch=450 f_loss=-0.2266 g_loss=3.4936 | train mmd=0.0454 | test_mmd=0.0092\n",
      "[CellOT] epoch=500 f_loss=-0.1430 g_loss=3.8233 | train mmd=0.0383 | test_mmd=0.0073\n",
      "[CellOT] epoch=550 f_loss=0.0520 g_loss=4.2980 | train mmd=0.0214 | test_mmd=0.0109\n",
      "[CellOT] epoch=600 f_loss=0.2774 g_loss=5.2509 | train mmd=0.0208 | test_mmd=0.0070\n",
      "[CellOT] epoch=650 f_loss=0.1656 g_loss=6.2542 | train mmd=0.0116 | test_mmd=0.0063\n",
      "[CellOT] epoch=700 f_loss=0.2574 g_loss=6.7420 | train mmd=0.0068 | test_mmd=0.0106\n",
      "[CellOT] epoch=750 f_loss=0.1028 g_loss=7.4040 | train mmd=0.0051 | test_mmd=0.0046\n",
      "[CellOT] epoch=800 f_loss=0.2637 g_loss=7.4033 | train mmd=0.0045 | test_mmd=0.0065\n",
      "[CellOT] epoch=850 f_loss=0.2185 g_loss=7.5600 | train mmd=0.0037 | test_mmd=0.0070\n",
      "[CellOT] epoch=900 f_loss=0.7100 g_loss=7.8315 | train mmd=0.0032 | test_mmd=0.0073\n",
      "[CellOT] epoch=950 f_loss=0.0362 g_loss=7.4984 | train mmd=0.0032 | test_mmd=0.0095\n",
      "[CellOT] epoch=1000 f_loss=-0.0018 g_loss=7.8831 | train mmd=0.0033 | test_mmd=0.0065\n",
      "[CellOT] epoch=1050 f_loss=0.0317 g_loss=7.6405 | train mmd=0.0028 | test_mmd=0.0105\n",
      "[CellOT] epoch=1100 f_loss=-0.4871 g_loss=8.0462 | train mmd=0.0018 | test_mmd=0.0075\n",
      "[CellOT] epoch=1150 f_loss=-0.2546 g_loss=7.5945 | train mmd=0.0022 | test_mmd=0.0109\n",
      "[CellOT] epoch=1200 f_loss=0.6401 g_loss=7.1583 | train mmd=0.0033 | test_mmd=0.0104\n",
      "[CellOT] epoch=1250 f_loss=0.1228 g_loss=7.5868 | train mmd=0.0019 | test_mmd=0.0077\n",
      "[CellOT] epoch=1300 f_loss=0.1757 g_loss=7.6690 | train mmd=0.0020 | test_mmd=0.0073\n",
      "[CellOT] epoch=1350 f_loss=-0.0666 g_loss=7.4484 | train mmd=0.0027 | test_mmd=0.0091\n",
      "[CellOT] epoch=1400 f_loss=0.0121 g_loss=7.7050 | train mmd=0.0021 | test_mmd=0.0107\n",
      "[CellOT] epoch=1450 f_loss=-0.1856 g_loss=7.7340 | train mmd=0.0021 | test_mmd=0.0102\n",
      "[CellOT] epoch=1500 f_loss=0.5624 g_loss=7.5245 | train mmd=0.0022 | test_mmd=0.0118\n",
      "[CellOT] epoch=1550 f_loss=-0.1812 g_loss=7.5040 | train mmd=0.0013 | test_mmd=0.0086\n",
      "[CellOT] epoch=1600 f_loss=0.3658 g_loss=7.6464 | train mmd=0.0032 | test_mmd=0.0090\n",
      "[CellOT] epoch=1650 f_loss=-0.3742 g_loss=7.4963 | train mmd=0.0023 | test_mmd=0.0122\n",
      "[CellOT] epoch=1700 f_loss=-0.3954 g_loss=7.6846 | train mmd=0.0016 | test_mmd=0.0074\n",
      "[CellOT] epoch=1750 f_loss=0.2860 g_loss=7.8413 | train mmd=0.0021 | test_mmd=0.0106\n",
      "[CellOT] epoch=1800 f_loss=0.0678 g_loss=7.4776 | train mmd=0.0022 | test_mmd=0.0138\n",
      "[CellOT] epoch=1850 f_loss=-0.0549 g_loss=7.5551 | train mmd=0.0039 | test_mmd=0.0075\n",
      "[CellOT] epoch=1900 f_loss=0.1440 g_loss=7.7465 | train mmd=0.0023 | test_mmd=0.0074\n",
      "[CellOT] epoch=1950 f_loss=0.1174 g_loss=7.3365 | train mmd=0.0018 | test_mmd=0.0089\n",
      "[CellOT] epoch=2000 f_loss=-0.4316 g_loss=7.7777 | train mmd=0.0020 | test_mmd=0.0085\n",
      "[CellOT] Final CellOT MMD: 0.0067\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-0.4422 g_loss=-5.1487 | train mmd=0.2818 | test_mmd=0.9760\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.00846164628520496, 'mmd2_gamma_0.5': 0.01680992720265373, 'mmd2_gamma_1.0': 0.016587371211605806, 'wasserstein_distance': 0.6166857496155, 'R2_feature_means': 0.9871851630201847}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1.4919 g_loss=-1.5063 | train mmd=0.1268 | test_mmd=0.1072\n",
      "[CellOT] epoch=100 f_loss=-0.6949 g_loss=-0.7158 | train mmd=0.0848 | test_mmd=0.0315\n",
      "[CellOT] epoch=150 f_loss=-0.1203 g_loss=0.3644 | train mmd=0.0986 | test_mmd=0.0156\n",
      "[CellOT] epoch=200 f_loss=-2.1778 g_loss=1.3392 | train mmd=0.0997 | test_mmd=0.0140\n",
      "[CellOT] epoch=250 f_loss=-0.7971 g_loss=1.9096 | train mmd=0.0925 | test_mmd=0.0096\n",
      "[CellOT] epoch=300 f_loss=-1.6236 g_loss=2.5775 | train mmd=0.0743 | test_mmd=0.0098\n",
      "[CellOT] epoch=350 f_loss=-0.5056 g_loss=2.7110 | train mmd=0.0761 | test_mmd=0.0066\n",
      "[CellOT] epoch=400 f_loss=-0.8241 g_loss=2.8641 | train mmd=0.0496 | test_mmd=0.0060\n",
      "[CellOT] epoch=450 f_loss=0.0054 g_loss=3.2386 | train mmd=0.0363 | test_mmd=0.0098\n",
      "[CellOT] epoch=500 f_loss=0.0296 g_loss=3.9032 | train mmd=0.0383 | test_mmd=0.0082\n",
      "[CellOT] epoch=550 f_loss=0.3591 g_loss=4.3268 | train mmd=0.0193 | test_mmd=0.0111\n",
      "[CellOT] epoch=600 f_loss=-0.6027 g_loss=6.0628 | train mmd=0.0183 | test_mmd=0.0082\n",
      "[CellOT] epoch=650 f_loss=0.0337 g_loss=6.6486 | train mmd=0.0132 | test_mmd=0.0107\n",
      "[CellOT] epoch=700 f_loss=0.7896 g_loss=7.0103 | train mmd=0.0141 | test_mmd=0.0088\n",
      "[CellOT] epoch=750 f_loss=0.2496 g_loss=7.6629 | train mmd=0.0065 | test_mmd=0.0079\n",
      "[CellOT] epoch=800 f_loss=0.1346 g_loss=7.5711 | train mmd=0.0046 | test_mmd=0.0072\n",
      "[CellOT] epoch=850 f_loss=-0.0181 g_loss=8.1104 | train mmd=0.0032 | test_mmd=0.0112\n",
      "[CellOT] epoch=900 f_loss=0.2399 g_loss=8.3383 | train mmd=0.0040 | test_mmd=0.0104\n",
      "[CellOT] epoch=950 f_loss=-0.4829 g_loss=8.1845 | train mmd=0.0033 | test_mmd=0.0068\n",
      "[CellOT] epoch=1000 f_loss=0.1626 g_loss=8.3659 | train mmd=0.0038 | test_mmd=0.0100\n",
      "[CellOT] epoch=1050 f_loss=0.3054 g_loss=8.3629 | train mmd=0.0029 | test_mmd=0.0079\n",
      "[CellOT] epoch=1100 f_loss=-0.4857 g_loss=8.1507 | train mmd=0.0026 | test_mmd=0.0071\n",
      "[CellOT] epoch=1150 f_loss=0.0715 g_loss=8.2909 | train mmd=0.0023 | test_mmd=0.0088\n",
      "[CellOT] epoch=1200 f_loss=0.3291 g_loss=7.8903 | train mmd=0.0039 | test_mmd=0.0057\n",
      "[CellOT] epoch=1250 f_loss=-0.2395 g_loss=8.1125 | train mmd=0.0031 | test_mmd=0.0085\n",
      "[CellOT] epoch=1300 f_loss=0.0093 g_loss=8.4438 | train mmd=0.0024 | test_mmd=0.0066\n",
      "[CellOT] epoch=1350 f_loss=-0.1634 g_loss=8.2962 | train mmd=0.0017 | test_mmd=0.0088\n",
      "[CellOT] epoch=1400 f_loss=0.6013 g_loss=8.5888 | train mmd=0.0022 | test_mmd=0.0084\n",
      "[CellOT] epoch=1450 f_loss=-0.1147 g_loss=7.9896 | train mmd=0.0023 | test_mmd=0.0117\n",
      "[CellOT] epoch=1500 f_loss=0.2443 g_loss=8.3941 | train mmd=0.0026 | test_mmd=0.0116\n",
      "[CellOT] epoch=1550 f_loss=-0.3119 g_loss=8.0909 | train mmd=0.0028 | test_mmd=0.0127\n",
      "[CellOT] epoch=1600 f_loss=0.3495 g_loss=8.0485 | train mmd=0.0014 | test_mmd=0.0078\n",
      "[CellOT] epoch=1650 f_loss=-0.1951 g_loss=8.3879 | train mmd=0.0017 | test_mmd=0.0079\n",
      "[CellOT] epoch=1700 f_loss=0.3407 g_loss=8.3070 | train mmd=0.0026 | test_mmd=0.0106\n",
      "[CellOT] epoch=1750 f_loss=0.2863 g_loss=7.9618 | train mmd=0.0021 | test_mmd=0.0104\n",
      "[CellOT] epoch=1800 f_loss=-0.3131 g_loss=8.9548 | train mmd=0.0040 | test_mmd=0.0116\n",
      "[CellOT] epoch=1850 f_loss=0.3988 g_loss=8.0635 | train mmd=0.0020 | test_mmd=0.0113\n",
      "[CellOT] epoch=1900 f_loss=0.2452 g_loss=8.2065 | train mmd=0.0028 | test_mmd=0.0107\n",
      "[CellOT] epoch=1950 f_loss=-0.4527 g_loss=8.3471 | train mmd=0.0019 | test_mmd=0.0085\n",
      "[CellOT] epoch=2000 f_loss=-0.6483 g_loss=8.2609 | train mmd=0.0020 | test_mmd=0.0107\n",
      "[CellOT] Final CellOT MMD: 0.0076\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/umap/umap_.py:1952: UserWarning: n_jobs value 1 overridden to 1 by setting random_state. Use no seed for parallelism.\n",
      "  warn(\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 metrics: {'mmd2_gamma_median': 0.01068705410312809, 'mmd2_gamma_0.5': 0.019104611629782053, 'mmd2_gamma_1.0': 0.017776651683633737, 'wasserstein_distance': 0.6362242126788694, 'R2_feature_means': 0.9830026969104776}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0097  0.0028\n",
      "mmd2_gamma_0.5        0.0178  0.0044\n",
      "mmd2_gamma_1.0        0.0168  0.0035\n",
      "wasserstein_distance  0.6247  0.0178\n",
      "R2_feature_means      0.9845  0.0050\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/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": "iVBORw0KGgoAAAANSUhEUgAAAYUAAAEbCAYAAAA1T5h7AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOy9dZhd1b24/65tx8+4zyQTD0ljuDZI8CKlaCktBWq3FKiXeytw2/ur3Nq3cuvFCrQptAQIEiC4hQAxEiITmYzLmeO2Zf3+2DMnMzEsQID9Ps88M2efLWvvOWd91seFlFLi4eHh4eEBKO/2ADw8PDw89h88oeDh4eHhUcITCh4eHh4eJTyh4OHh4eFRwhMKHh4eHh4lPKHg4eHh4VHCEwoeHh4eHiU8oeDh4eHhUcITCh4eHh4eJTyh4OHh4eFRwhMKHh9IzjzzTILBIKlUao/7XHzxxRiGweDg4Ds4Mg+PdxdPKHh8ILn44ovJ5XL8+9//3u372WyWRYsWccopp1BVVfUOj87D493DEwoeH0jOPPNMIpEIt912227fX7RoEZlMhosvvvgdHpmHx7uLJxQ8PpAEAgHOOeccHnnkEfr6+nZ5/7bbbiMSiXDmmWcSj8e55ppraGlpwefzMXnyZH784x/jOE5p/61btyKE4Kc//Sm//e1vmThxIsFgkJNOOont27cjpeT73/8+zc3NBAIBzjrrLGKx2Dt5yx4erwvt3R6Ah8e7xcUXX8xNN93EwoULufLKK0vbY7EYDz74IBdddBFSSubPn09nZyef+9znGDduHM888wzXXnst3d3d/PKXvxxzzltvvZVisciXvvQlYrEYP/nJTzj//PM5/vjjeeyxx/jmN7/Jpk2b+PWvf83XvvY1/vrXv77Dd+3h8RpID48PKJZlyYaGBnnEEUeM2f773/9eAvLBBx+U3//+92UoFJIbNmwYs8+3vvUtqaqqbG9vl1JKuWXLFgnImpoaGY/HS/tde+21EpBz5syRpmmWtl900UXSMAyZz+ffxjv08HjjeOYjjw8sqqpy4YUX8uyzz7J169bS9ttuu426ujpOOOEE/vnPf3LMMcdQUVHBwMBA6WfBggXYts0TTzwx5pznnXceZWVlpdeHHXYYAJ/4xCfQNG3M9mKxSGdn59t7kx4ebxBPKHh8oBlxJI84nDs6OnjyySe58MILUVWVjRs38sADD1BTUzPmZ8GCBQC7+CPGjRs35vWIgGhpadnt9qGhoX1/Ux4ebwHPp+Dxgeaggw5i+vTp3H777fznf/4nt99+O1LKkrBwHIcTTzyRb3zjG7s9furUqWNeq6q62/32tF163XA99jM8oeDxgefiiy/mO9/5DqtWreK2225jypQpHHLIIQBMmjSJdDpd0gw8PN7veOYjjw88I1rBd7/7XVasWDEmN+H888/n2Wef5cEHH9zluHg8jmVZ79g4PTzeCTxNweMDz4QJEzjyyCNZtGgRwBih8PWvf527776bj3zkI1x66aUcdNBBZDIZVq9ezR133MHWrVuprq5+t4bu4bHP8YSChweuIHjmmWc49NBDmTx5cml7MBjk8ccf5//7//4//vnPf3LzzTcTjUaZOnUq119//ZhIIw+P9wNCep4uDw8PD49hPJ+Ch4eHh0cJTyh4eHh4eJTwhIKHh4eHRwlPKHh4eHh4lPCEgoeHh4dHif0uJNVxHLq6uohEIggh3u3heHh4eLwvkFKSSqVobGxEUfasD+x3QqGrq2uX4mEeHh4eHvuG7du309zcvMf39zuhEIlEAHfg0Wj0XR6Nh4eHx/uDZDJJS0tLaY7dE/udUBgxGUWjUU8oeHh4eOxjXsss7zmaPTw8PDxKeELBw8PDw6OEJxQ8PDw8PErsdz6F14tt25im+W4Pw8Njv8YwjL2GH3p47MwbFgpPPPEE//u//8uLL75Id3c3//73vzn77LMBME2Tb3/729x3331s3ryZsrIyFixYwI9+9CMaGxv3yYCllPT09BCPx/fJ+Tw8dsa0HBzHQVEUdO29PaEqisKECRMwDOPdHorHe4Q3LBQymQxz5szhsssu45xzzhnzXjab5aWXXuI73/kOc+bMYWhoiKuvvpozzzyT5cuX75MBjwiE2tpagsGgl+DmsU+Jp/PEUzmkA0KB8kiA8rD/3R7Wm2IkEbS7u5tx48Z53xWP18UbFgqnnnoqp5566m7fKysr46GHHhqz7Te/+Q2HHnoo7e3tjBs37s2NchjbtksCoaqq6i2dy8NjZ/JFi1TORtUMNFXBsh1SOZvyqIbf0HbZ17JsNE0FKP1tCBvHsTBtgY2Kpqm7HPtOUlNTQ1dXF5Zloev6uzYOj/cOb/unNZFIIISgvLx8t+8XCgUKhULpdTKZ3OO5RnwIwWBwn47RwwPcid1xJIauIgBNVSiaNpZlg6GRy2YxTYucKUnmLBxH4jgSiUQRAkVIyrQ8UkqSpo4tVRRFUB72UVPmx3EsFEVD0X3v2D2NmI1s2/aEgsfr4m0VCvl8nm9+85tcdNFFe0xE++EPf8j111//hs7rqcEebwea5k7ilu2UNAVFEUgJnd39pHIWUoItBaoiEIqCadmA+5lUhEPM0kG4vi9HOliOoD+ew8rGqfCbCKGghSrRg+XvyD153xWPN8rb5kUzTZPzzz8fKSW/+93v9rjftddeSyKRKP1s37797RqSh8de8RsaVWWuFlo03cnerws6++LEMjam406wErAcWdoHXCFgOwLTEVi2wHbcr5aCRAJJU8N0NPfYTAzH3KEd54sW6WyBfNF6R+7Tw2NvvC2awohA2LZtG0uXLt1ruQqfz4fP986p0x4ee6MyGiDo17EsGzOfpmeogCVdbQHAkjsEw96QgCj9lkgpSBccQrqNrkhsM4ei+4glcwwmsjiORFEEVWVBKqOBt/EOPTz2zj7XFEYEwsaNG3n44Yc9h/Dr5LHHHkMI8b4JtX0v34/f0AjqUMxlsKRgtAFGDv+cetwh/O3GP+72eFU47r5yx5E2CgnTT28uQLKoUkz1kUnGGExkATB012E9mMiSL1pcd911zJ07t3T8pZdeWgr99vB4O3nDQiGdTrNixQpWrFgBwJYtW1ixYgXt7e2Ypsm5557L8uXLufXWW7Ftm56eHnp6eigWi/t67B7vcYQQ3HXXXe/Y9VpbW/nlL3/5uvZ1HAs5oh68pl6wAwEoQqIJpyQcnGFNw0Fgo5A0fRRNST6dwHFc/8WIY9txpOvY9vB4l3jD5qPly5dz3HHHlV5/5StfAeBTn/oU1113HXfffTfAmFUOwKOPPsqxxx775kfqsc8pFov7fVLTvh6jtC2sQuY1o4AURSOg2ahCYo9a8b9et22FkUMTDv2FEBKBEK5gcaRAolBwVHyiiJA2lq2McWyPhLl6eLwbvGFN4dhjj0VKucvPjTfeSGtr627fk1LulwIhN7CVxJYXyA1sfduvVSgUuOqqq6itrcXv93P00Ufzwgsv7LLf008/zezZs/H7/Rx++OGsWbOm9N62bds444wzqKioIBQKMXPmTO67777S+2vWrOHUU08lHA5TV1fHJZdcwsDAQOn9Y489liuvvJJrrrmG6upqTj75ZD7+8Y9zwQUXjBmDaZpUV1dz8803A24S1A9/+EMmTJhAIBBgzpw53HHHHWOOue+++5g6dSqBQIDjjjuOrVu37vV5tLa2AvDRj34UIUTp9YjZ5M9//jMTJkzA73cTx+LxOFdccQU1NTVEo1GOP/54Vq5cWTpfW1sbZ511FnV1dYTDYQ455BAefvjhMfe+bds2vvK1r6P7w6iGHzMbB+CJx5Zy9FFHEggEaG5p4Qv/8UUGBvrQhU2lniUR6+NLn/skh86awKnHH8q9d9855l4EYKgOPsVGVSTlRoGIVuS2f9zBmacex0Ezx3PckXP5wXX/hSMFjlRoHyzyH1/9LkccNJN5M1q56NwzWbd2DVVlwVJeg5Ryjw7oO+64g1mzZhEIBKiqqmLBggVkMpm9PnMPj9fDezuH/y3Qt+Ju2u76Nlvv/yFtd32bvhV3v63X+8Y3vsGdd97JTTfdxEsvvcTkyZM5+eSTicViY/b7+te/zs9+9jNeeOEFampqOOOMM0r5GV/84hcpFAo88cQTrF69mh//+MeEw2HAnTSPP/545s2bx/Lly3nggQfo7e3l/PPPH3P+m266CcMwePrpp/n973/PxRdfzD333EM6nS7t8+CDD5LNZvnoRz8KuGHDN998M7///e955ZVX+PKXv8wnPvEJHn/8ccBtiHTOOedwxhlnsGLFCq644gq+9a1v7fV5jAjEG264ge7u7jECctOmTdx5553861//KpkpzzvvPPr6+rj//vt58cUXOfDAAznhhBNKzy+dTnPaaafxyCOP8PLLL3PKKadwxhln0N7eDsDC226mqbGe73zzGja/8gJtq5/DysRYt/IFTjv9DM485TiWLnmAn/6/3/PEE0/yhS99jZTloyyocv21VzHQ28lfbrmDn/7qTyy87SZigzuErSokmiIRioIiAKHwh1vu4Fvf+W/OvfAS7rx3Kf/vdzcxbnzr8P4O11z5eXr64/z+L7dy590PMXfePC67+GNg5QDIFUyKls32viTtPXHyBRPLdsgXLbq7u7nooou47LLLWLduHY899hjnnHPOKHOXh8dbQO5nJBIJCchEIrHLe7lcTq5du1bmcrm3dI1s/xa5+k8Xy1V//Lhc97cr5ao/flyu/tPFMtu/5S2dd0+k02mp67q89dZbS9uKxaJsbGyUP/nJT6SUUj766KMSkH//+99L+wwODspAICD/8Y9/SCmlnDVrlrzuuut2e43vf//78qSTThqzbfv27RKQ69evl1JKOX/+fDlv3rwx+5imKaurq+XNN99c2nbRRRfJCy64QEopZT6fl8FgUD7zzDNjjrv88svlRRddJKWU8tprr5UzZswY8/43v/lNCcihoaE9PhdA/vvf/x6z7Xvf+57UdV329fWVtj355JMyGo3KfD4/Zt9JkybJP/zhD3s8/8yZM+Wvf/1rWcwMyUzvRjmuuVH++PpvyUzfJpkd2CYzPRvkpz5+nrzskgtlorddrm/rlK+2dcp/3HG3VBRFrly7WT79xFIJyAfvuVOu2tAtV27olovuf0IC8uv/eb1cvbFLrt3UKddt6pRrN3XJtW098tUtvbK2rl5e/eWvyVfaeuXqjd1y1Ub32FUbuuXf/v4vGQ5H5PI1W+X6tk65YVu/3NA+ICdOdO8nVzDlF6/+mpx2wEy5elOPXLWxR5750fPlCSeeIje0D8iljz8tAbl169Y93vsI++o74/HeZ29z62jes1VS3wrFVD92MYuvrAmhKOjBSgqJToqpfgLVrfv8em1tbZimyVFHHVXapus6hx56KOvWrRuz7xFHHFH6u7KykmnTppX2ueqqq/jCF77AkiVLWLBgAR/72MeYPXs2ACtXruTRRx8taQ47X3/q1KkAHHTQQWPe0zSN888/n1tvvZVLLrmETCbDokWL+Pvf/w64q/ZsNsuJJ5445rhisci8efMAWLduHYcddtge7+ONMn78eGpqakqvV65cSTqd3iWSLZfL0dbWBriawnXXXcfixYvp7u7GsixyuRzbtmzBysQY7Q2QlklRCGxHY9Urr/LKuvX84867S+5kKV2T2ZZt29m+dSuapjHxgAPJOe5ZJkyaQiRaBoAioCZoYkuVobyCwCYxNERfbw8HHnoUqgIKDgJBcTjP4dV1a8lmMxxz6IwxPop8Pk9bWxvZvInjuKMRQiCl67BmOBGtYdxkjjvueGbNmsVJJ57IguM/zDlnn0V1bcM7mi3t8f7kAykUjEgNqhHEzMbQg5WY2RiqEcSI1Lz2we8iV1xxBSeffDKLFy9myZIl/PCHP+RnP/sZX/rSl0in05xxxhn8+Mc/3uW4hoaG0t+hUGiX9y+++GLmz59PX18fDz30EIFAgFNOOQWgZFZavHgxTU1NY457u/JLdh5jOp2moaGBxx57bJd9R8qnfO1rX+Ohhx7ipz/9KZMnTyYQCPCxj32MdCZDwZL4dLU0qaZMnbjlR6KQSOe45OMX8oXLP8Fg0c0PUHWDQtGhoaGRzm0bASg4KjuyD0aNVS0SVC3yUgUEKha+YUexlDaRoEE6Y2E6o+4nk6O6po4bb70DXZE4EhRNp6E6Sl1tNZbl7Ih3kmNjn0YilO66axHPP/kISx5+mF//5v/4zvf+m8fv+ydTPnTgO5Yt7fH+5APpUwhUt1J78PkIISgkOhFCUHvw+W+LlgAwadKkkh1/BNM0eeGFF5gxY8aYfZ977rnS30NDQ2zYsIEDDjigtK2lpYXPf/7z/Otf/+KrX/0qf/rTnwA48MADeeWVV2htbWXy5MljfnYnCEZz5JFH0tLSwj/+8Q9uvfVWzjvvvFKdnBkzZuDz+Whvb9/lvC0tLQAccMABLFu2bI/3sSd0Xce2Xzv88sADD6SnpwdN03YZQ3V1NeA66C+99FI++tGPMmvWLHRfiC1btpIpWPRm/SSyNoauU3QEMTOI5ShYDkyfMYtXNmxm4oRxzJ7cyPjWiTQ2tzJu/ASCQR+TJ0/CsixeWbOKgGohhGTL5k2kkgkM1aHal0XaRVQsBA62VAhHojQ1t/Dc009QETaoKfOhCtAVB79qM2Pmhxgc6EOoOnUtk2geP5G5H5rKzBnTUYwQ8ZSbu4AEZ5SfQACW7SBwiA/FaJ5+MJddeS0LFz2Ephv8a/FDmOnBMdnSHh5vlA+kUAConXsmk87+Aa2nXsuks39A7dwz37ZrhUIhvvCFL/D1r3+dBx54gLVr1/KZz3yGbDbL5ZdfPmbf//7v/+aRRx5hzZo1XHrppVRXV5eSlq655hoefPBBtmzZwksvvcSjjz5aEhhf/OIXicViXHTRRbzwwgu0tbXx4IMP8ulPf/p1Tbwf//jH+f3vf89DDz3ExRdfXNoeiUT42te+xpe//GVuuukm2traeOmll/j1r3/NTTfdBMDnP/95Nm7cyNe//nXWr1/Pbbfdxo033via12xtbeWRRx6hp6eHoaGhPe63YMECjjjiCM4++2yWLFnC1q1beeaZZ/iv//qvUkn2KVOmlBzTzz39BJ/+9KfcngjD6WYJ00dzUyNPPfsCXd09xAYHQcKnP3MlK15aztXX/n9s2bSWdM86lj/9MD/6/n8ihGDixMkc8+Fjuf7b32LLK8/Ss/45/uc7Xybg9xPVCkg5XOfIKhJQTKRwS1186eqvcsOf/8Cvf/0bNm3rYu26tdx+600omsHhR81n9ryD+PJ/XMrzTz9Kd+d2Vq94iW9+61oeffxJLGtHtJGUw8X2hmswISVrXnqen/3qd6xctZrtnV088MCDDA7GqBk/k6G85pXM8HhrvCMejjfAO+FofjfI5XLyS1/6kqyurpY+n08eddRRctmyZaX3RxzN99xzj5w5c6Y0DEMeeuihcuXKlaV9rrzySjlp0iTp8/lkTU2NvOSSS+TAwEDp/Q0bNsiPfvSjsry8XAYCATl9+nR5zTXXSMdxpJSuo/nqq6/e7fjWrl0rATl+/PjS/iM4jiN/+ctfymnTpkld12VNTY08+eST5eOPP17a55577pGTJ0+WPp9PHnPMMfKvf/3razqa7777bjl58mSpaZocP368lNJ1NM+ZM2eXfZPJpPzSl74kGxsbpa7rsqWlRV588cWyvb1dSinlli1b5HHHHScDgYBsamyU3/7eD+Shhx0uP3XpZXJjW7tcu6lD3rdooTzggBnSMHwSkCuHHce33nG/PPKoD8twKCRDwaCcPWuW/M///C/5alunXLupUz753EtywfHHSZ/PkC1NDfJPv/pRyWmd7lonu7Ztkq+2dch1bZ1yXVunbN/eITu2t8vrf/AjOWHiZPeZ1dbJSy79jNzYPiBXbeyWz728QV7yqU/Luro6qeu6bG5ulueff4F85IkX5OqN3fILX/qKnDZ9hly1oVuu3dQlL7rwQnn6R86QQ0Nxec8Dj8kjjzlWVlZWScPwyfETJslvfed/SvezdnOv3NA+IAcT2ff0d8Zj3/J6Hc1Cyv0rji2ZTFJWVkYikdilZlI+n2fLli1j4tc9PEZjFTKkYz305vwg5Zjks0ojR8yOUrQkoz/1AtAUh9pAgWh5BaoeoBDvpOgoWDYosoih2AhFRw1EkI6NnUsAAtNR6S245jlNU0b5AwSKqqLrOpbtYA8npjm2jWVLFCExVAcHDaFqtNSV4RRzbOtNYUnFrZc0PDZVQG2wSEV1PZm8RUdfEluCRLC7b68QoKkqmqZQW+ajq3O7953x2OvcOpoPrPnI4/2JomgYKpRpeQBMqeIgCGlFhKKC2LXFpiLcSdofLkcPlg+XuHAwNIWQT8HvM0BR0SPV+KJ1GKEqhGogVA1b9SERqIpEUXUMnw8pNBxUFEXFcaRbxkIIqqI+avx5KnwmmgKWo4C0qQwb+A0Nv88g6rOHfQkCKQVy2LGtDjfv0X0+VE118yH2sJyTEkzLxjRtLNvZ/U4eHnvAEwoe7ysU3YceriLqcwhpJiMRQxnbh6VFURQFVVHcZDPhrqpVRVLuswkE3LLZiqIhhIJ0LNcjIR0URUPVA2OuIYSCioUiJI7QQbjOaxA4UpIrWOQLJoWihaIIAhoEVJPKoKQ+bFEbtKgN5CkLKqXzlkdDqKPGNoIQCoridoCrroig6zqKsveiG7YjcWwTxyqQH+rc58/a4/3JBzIk1eP9w+i2mCPlIfRgORYG2XwaVZVoqsCWCqmioCzklqseMSkpSCKGTWVFlKJUsbIFVGwUXwg7n0baxVJjnNE5AHqwHFUPoDsWts8hli5SNO3SZK6pCrbtlnixbIfKaAC/T6eQc4WNrmhoWG4BPWXH11BqIVTNRsdGOg4CiS0VMKKl61dGA+iqQtdACuE4rjawG61BEZBLJylkUrSv+AvFWSe+rQEVHu8PPKHg8Z5lb70IbFQkCobhttYUuI1zRrqrGbqGpoDjSLKOzlBeI5FJ4NgWQtpEdZOoAao/gh4o321SmKL7UPBR5YNQyBVORcuhfyjt5h8IiURgSwj6dRTdhxaqxMrE9ihs3PEpSEcgVDeJTlUVfKHoGAE4okUEfDpF06Zo2qUyF24XODdyKVVUSZo6r3aVcXRhIZHm2W9b6LXH+wNPKHi8J8kXrTG9CCzbYTCRJejX8RvaHltrgmtzH+nDrKhQKFrEkjk3/FPaOEDSNAjoElHIQKB8zHV31kzGTNZWBmwT05KowsGRijuBF5OYuLkfeqQWhNhtpVa/oREwNOLpPFK6Wkd5QCebN3cIQAGRgIqCxDItDE1x0+Zsx22/KcC2HNdXorpKxNKOWlrEFlrepqx9j/cPnlDweE9iWTaOI0uTu6YqFE3b7UVgaKXWmoOJLEXTLmkSQb++i7BwpHRNPUgYnsRVAbZUkdLCcSwUdt8lzbJshlJ5pJSoiiCqZohqFknThykVFCRRrQDZJEW31h1C0dAjNSi+XZMK80WLXNHCGBZqjiPJFkyy+aJ7n8LBsmwSKUlILZKxDQq2gqKq1FdHCPp1UpkCg4kM0oaiJbAdQW9WZWl3E8fv51n7Hu8+nlDweE+yJ02gYNrkhjL4DW1Ma83RK/vRwkIMR/GUTC+4moQNONIpOXh3p5n0Dqaxh6N73BpFkrilUakXKdPzSMCv2OjKSPKga8iSjoWZGkDVAyVNYUTbKFrOGGEnVcjni240lGIjkahCYDkKftUmpGVwhIGmQiRQhqK79zgQz2I6O0JWpYQVqRa68lEmve3/HY/3Mp5Q8HhPIq0iIUOQztsUHQcFEIqgeyBVMruEAgYN1RHCwbETb9CvE/SXYVk28VSeoWJ+x3mHfyvDwaAjNn8rWxgzWStClMI9VcWNNrIdsKXCQDFYOgd6oSQUJMBwcTtpm5i5OD69bowGIoZ9AZbtoCluaKnAFV62VFCxsYeb9miKRBcOiuYgpVPSaNxrjfU8q6pKET+9sTSTmivfjn+Jx/sETyh4vOcYGBgkliowXEiUkGahK5KBvDshCuGaXVKZAkXTpqbCNdPsbPoJ+nWyhZGw1R0I4WoiwbIa9KA7wavYwzZ8E1VVsCxZ2tdx5HDoqhv+qiAwFBtbCpKmD79iuYJhp4w5O58mp0UYTLh2pRENBCSObVEw3TpH5VoeVI1k0cByVISQlGkFdGEBroYyotGAa1obKY3hSOFqMUJBVxXqKnetouvhMRovT+F9ys79iN/pfsgj7NyA/q2Sy2aJpdyaQ7oCnR3tjBs/nhVrXkUCLzz/DLMm15NKJWB4wh6IZxiIu13JDN2tYDqYyJLNm0gp0YQckxOgCEl1WYDAsEAws3HI9BBR0ji2SbFQRDommgqqoiCRYyJ/HKEghYKqgETBZtf2moqiAxLTtHYkuMFwohuU6wVqAkXqQxYRvUhEyVIXLFLtz1PryxAx3MZLCDcxbnQUk6apqKqCqgjXBIVbP+nc42d4WoLHa+JpCh8Quru7qaioeF37Xnfdddx1112lrmf7E6Zp4UjQVYbLWLjmGEVIdk7yFQi39MSwmcdvjHVKgys0rOGcBSHc2P66QIGyoFsGwDELWJkYBRvAde5qisSvQ8HWGDL9gEBRduQmOBJQfW40kyLRNAVF9SOtwo7i28JNSNN1DUUxx/pGAJ9q4dM1BODYBtIuolHAMDRUfyWKEWDETrZzFJPf0KgIQCxl4eCgIlkwI8DcaQ20dcQ8weCxVzyhsB+zL5vW19fX75PzvNvouoYiwLJBU9ykNICA5hDWR1UXxZ2kwbX5A7s4pfXh1fnovGAFWRI4ViGDtE0SBZWhglESHqpwKBM2PlGkXJMM2TpCCAxVUEQgbYntSFRVoSps4LPSriahaAhnZIzu6l4PBqmyxJgoqcqoH5+VQjoWKBoIgVAN9HDVbp3TmlAZXdXIMQuEZAI9qJArSpKazZrNfTy89gHCoRCfPH0O557woX3/z/F4X/CBNh+1dcR4ZlU7bR2x1975LXLsscdy5ZVXcuWVV1JWVkZ1dTXf+c53xvTVbW1t5fvf/z6f/OQniUajfPaznwXgqaee4phjjiEQCNDS0sJVV101pkl7X18fZ5xxBoFAgAkTJnDrrbfucv2dzUcdHR1cdNFFVFZWEgqFOPjgg3n++ee58cYbuf7661m5ciVCuPbokTLY8XicK664gpqaGqLRKMcffzwrV64cc50f/ehH1NXVEYlEuPzyy8nn87wWr7zyCh/5yEeIRqNEIhGOOeaYUkc1gD//+c8ccMAB+P1+5h14IHf981aEYEzjGk1Y1AWL1ERcU41P01AUQWfHdq763Cc5dPYU5kwbx0nHHsFjSx+iqiwIjoUQ4NcFhurgU22EkNjomKk+iolusskY8aKOJQVuJSI3wziW1+nPB0gUdQK6K0yKpo2qCGorQjTXRmmpK6OqIoLQ/Ui7CLYrEBQjhL+iudQMpzIaoKWujKaaSOkYLVTpaj62G4qqh6vQgzuS6PpiabZ1x+noS7K9N0EsmSs9C9vM4TgWhgqaCgVbxXEcGst1pISbF698Rz7zHu9NPrCawh2PrOHmxSvJ5IuE/MY7snq66aabuPzyy1m2bBnLly/ns5/9LOPGjeMzn/lMaZ+f/vSnfPe73+V73/se4LbSPOWUU/jBD37AX//6V/r7+0vC5YYbbgDg0ksvpauri0cffRRd17nqqqvo6+vb4zjS6TTz58+nqamJu+++m/r6el566SUcx+GCCy5gzZo1PPDAAzz88MMAlJW5rSfPO+88AoEA999/P2VlZfzhD3/ghBNOYMOGDVRWVrJw4UKuu+46fvvb33L00Udzyy238Ktf/YqJEyfucSydnZ18+MMf5thjj2Xp0qVEo1GefvrpUk+BW2+9le9+97v85je/Yd68ebz88st85jOfoaK8jAsuuBAK7tj0cA2+8iYi0XYAWurLCIcjfPkL/4VdzPPQotvQ/QHWrt9MVU2YiFYgm4qDY2ADmiqwbNyJ38rgaAJF1bEs6TproWSeGoluUoTr4C3aUBW0wTEJRMMER7VEdcwC0swjVIPh0CJwdu114Dc0MHZ8HUfKaDiOtYt5qC+Wpm8oA9IV9rAjcU+10pjpQXBsHCeHaRlIIOqTFA0f1cEA7b1xLwrJY498IIVCW0eMmxevREoYV1fOQDzLzYtXMm9a49v6RWlpaeEXv/gFQgimTZvG6tWr+cUvfjFGKBx//PF89atfLb2+4ooruPjii7nmmmsAt5nMr371K+bPn8/vfvc72tvbuf/++1m2bBmHHHIIAH/5y1/GdGvbmdtuu43+/n5eeOEFKivd+508eXLp/XA4jKZpY0xOTz31FMuWLaOvr6/UhvOnP/0pd911F3fccQef/exn+eUvf8nll19eahz0gx/8gIcffniv2sJvf/tbysrK+Pvf/17q9jbSTxrge9/7Hj/72c8455xzAJgwYQJr167lhhtv5DOf/SyxIXfFqxmBXezq4aCPju3tnHnqCcycMQ2haEydOA7ThmQ87sb2+ySJvELRcjOFy302hmKDA45jo0gFBcO1zAtlJK50uJSEQAinVO00qEt8Ptfc55gFd8VuFZCOjdB8O4SKXRwTPronRspojCZftIaT5dywWInE7aHkYBYKyHysZG6SdhFFFhFIskoFuhZgIJ4l5De8KCSPPfKBFAq9sTSZfJFxdeUoiqC6PPiOrJ4OP/zw4ZWdyxFHHMHPfvYzbNtGVV2zx8EHHzzmmJUrV7Jq1aoxJiEppdtYfssWNmzYgKZpHHTQQaX3p0+fXupdvDtWrFjBvHnzSgLh9bBy5UrS6TRVVVVjtudyuZKpZ926dXz+858f8/4RRxzBo48+utexHHPMMSWBMJpMJkNbWxuXX375GMFpWVZJe3ktvvgfn+fKq67hkcef4vgPH82Ck0+nceIMtyy1EGM802HDJupzcEyBlA4IMBSHcqPAUDEwyiEt0FQFVRWYpoXAzRkYiQAys3HMVL/rExhGWqBoPqRjjQkffaNYlo1tO64wkDuc65pQUIWbryBUw3VQC4FuFQj6VPRgGe298ZJW7GkJHnviAykU6irDhPwGA/Es1eXB/Wr1tLum9Z/73Oe46qqrdtl33LhxbNiw4Q1fIxAIvOFj0uk0DQ0NPPbYY7u8tzcB9FbGkk6nAfjTn/7EYYcdNua9ESH6Wnzmiis4/og53P/QYzz02NP87//7P75x7Xf51KWfpmC7LjWfauNISBdVIgaoQgHplBzQUZ/Er+ewjUqE5nPLTGQKmI5E0QwqgoJgMOiae8wCZnpwWCCM1FqSCMdCWiAUdZcieG8EOdy3eSTz2pVpkpAh8fuMUhVWKaXrx5AOPpnjs4fkkC0nUDRtDF31opA89sgHUihMaq7kk6fP4ebFK9/R1dPzzz8/5vVzzz3HlClT9jrBHXjggaxdu3aMeWc006dPx7IsXnzxxZL5aP369cTj8T2ec/bs2fz5z38mFovtVlswDGOXvs4HHnggPT09aJpGa2vrbs97wAEH8Pzzz/PJT35yzD3ujdmzZ3PTTTdhmuYu2kJdXR2NjY1s3rx5TN/oN4Ki+2id+iE+09TIxRdfzLXf/zl3LLyNT132WRgOVZW4K/+iJUkXJCFdQ1PdkFGhaEjp4FPBF9lhooqG/ViWjbAyKIU4ZtrBEorrVB7REIa1QoEE4QoDzRd+0wJh5JSKcDOoEaXCGQTIAlG0UKUrlOyiW74DkNJG3XgHL27s5/72etKZDAENLj5xKh8/+9g3PRaP9ycf2Oijc0/4EL/4yql8//Mn8IuvnPqOhOi1t7fzla98hfXr13P77bfz61//mquvvnqvx3zzm9/kmWee4corr2TFihVs3LiRRYsWceWVVwIwbdo0TjnlFD73uc/x/PPP8+KLL3LFFVfsdQV+0UUXUV9fz9lnn83TTz/N5s2bufPOO3n22WcBNwpqy5YtrFixgoGBAQqFAgsWLOCII47g7LPPZsmSJWzdupVnnnmG//qv/2L58uUAXH311fz1r3/lhhtuYMOGDXzve9/jlVde2ev9XXnllSSTSS688EKWL1/Oxo0bueWWW1i/fj0A119/PT/84Q/51a9+xYYNG1i9ejU33HADP//5z1/XM7/mmmtY+uTzdA0VeXVzB8uef5aJk6eiqNrwpC1QNQNTujnLSctPXzFKTq0qNdoZXe5iBL+hEdRBKcTd3APVKLXplM5wGWvplLKYhaK+ZYEAbmKargo0xcGnDpe6UEd1ZguWo4erQKglLQIJvTk/dzwXIxfbToXdST7RzQ3/epIXHr7jLY3H4/3HB1YogKsxHDl73DumRn/yk58kl8tx6KGH8sUvfpGrr766FHa6J2bPns3jjz/Ohg0bOOaYY5g3bx7f/e53aWxsLO1zww030NjYyPz58znnnHP47Gc/S21t7R7PaRgGS5Ysoba2ltNOO41Zs2bxox/9qKSxfOxjH+OUU07huOOOo6amhttvvx0hBPfddx8f/vCH+fSnP83UqVO58MIL2bZtG3V1dQBccMEFfOc73+Eb3/gGBx10ENu2beMLX/jCXu+vqqqKpUuXliKiDjroIP70pz+VtIYrrriCP//5z9xwww3MmjWL+fPnc+ONNzJhwoTX9cxt2+aLX/wiM2fP5aPnfIxp06Zx3f/8bylnQdMUTFuWXvt8OgjBUA4I1WOUNeArbyqFj45mpG2nUDQYrj00OsTY/VsiFA0tUIbjWDhm4XWNe0+4hf78KAIc6SbblRkmPnVHsx5VDwz7rnaMJVH0kXM0QlY/irSpDKnkLIWNyx8mN7D1LY3J4/2FkKM/xfsBe2sunc/n2bJly3uyCfmxxx7L3Llzx5Se8Hh3GN3/ABguNZ3FZ2glx23RtGmq2VFMb3c4ZoFCvHM4IEniWO6ELxQVpERKB80fBUXBKeZwo5aU4aS18rd0D5lkjHwmhSpsfCq7nDMf246VT1GwHLZ39rH9sd/zy5WTcYCKgCBh+VGEwjUfWsvR511D2YRD3tJ4PPZ/9ja3juYD6VPw+GCzc04AQDyd3yXjeURo7AlF9+H4yt3JWZrul2l0ESXANrPguP4Zobo5A1YmNiYz+c0QilYSCIR2m8dgZuM4VnHM/rVGmpNqN7Ckbyo9GY2AWuDE+jYafUkMr8eCxyg8oeDxgWdPDXn8xt6/Hm7Ja4njBBFIokqGsJYH6VDqzjDSzwABtoky7IgeyTreXfe118vu8hhGajUhBIpmgDWSIyI4tmYbU8ODDNlhKo0CTYE0CC8CyWMsnlB4h9hdKKfH/sOeGvLsibFNdzQs2yFpB/Ap5nBJa3CFglPyLUjAsU0EuFnH+9CcNELJz6Eablit4mo7ii+EptcxPlRkamUd0jYRqo6VjVH0WnR6jOID7Wj28BjNSBb0awkE2NEOtFTyWnErrtpooxIUR0pq7zApSdsaTowTY8xJIw5oxyxgFTJv2iGtKJobNWUVcMw8OO61yiYdRuup16IFyzDTAwhFwzFzqEbQMx95jOE9qSk4jvPaO3l4vI3s0g7UchBIVNykNbc9p9swZywS6dgow2UvULRS2Qs7m8PKxNyVvlBwfOVILfS6NJcRFN2H6o+SScawpYrtuCU58gNbyIYrsIs5zNQAxUQPeriKpvmf87QEjzG8p4SCYRgoikJXVxc1NTUYhjGmbISHxztJJKAST+WwisPtP5Uc0jYpOApIiekIbClQhUQb06dZIpw8imogpe2WpMjnXYEACKGSyAsy8TQoORRFoTwSoDz8+iLuhjIO8azfjaLKm6TyklCim4FV96AFyjCi9ZjpARRVJ9I8++15OB7vWd5TQkFRFCZMmEB3dzddXV3v9nA8PDAtB8dxUBQF08oyWEgDkrytk3c0t6IqEr9q4VeHBYOUCEXBTUlWUH1BxGAGK5dEKCoZUyFTVCgV3lMEvUKhIhpA1/Zu8TUth6FkdjjpTpLOmdz50Bo+VuOjyZ9CD1YiFAVVD1BIdHr+BI9deE8JBXC1hXHjxmFZ1i6lGDw83m16XryTV19+lpvWtyKHJ/JYPIWQDp8Yv4YaPQlItGA5quajYtpx1M3+GPmhTtof/gs9GZ3fr2llMKfiUx2k6kcIQSTk42ufOIp5Exr3ev2X13fxu3tXUu0rUEz3k0xl6EgZ2HPno+WexMzG0IOVmNnYXv0JbR0xemNp6irDXo2kDxhvWCg88cQT/O///i8vvvgi3d3d/Pvf/+bss88uvS+l5Hvf+x5/+tOfiMfjHHXUUfzud79jypQp+2zQQgh0Xd9tZU0Pj3eT1qMuZqszlZ6Vy2mpjVL0hVANaO8eZKDCojbYhx6qIhAux8zGSL16P7XTj6K8YRLFWSey5oH76OxPkSrqCE3H5zPJ5EyaalRqq8pfM2mztqqcbEGyLW9QEWwimctQXq0xc/7ZRAYa6Fu+kEKiE6GoRCcfvdtzvJ5eI29WaLR1xNi+pY0KPcvUyeM9LWU/5A0LhUwmw5w5c7jssstKNe5H85Of/IRf/epX3HTTTUyYMIHvfOc7nHzyyaxdu/Y9l4Xs4fFmaJkwiUhkA0NZqDYkKRmlvMbHtMObMTbfib+qFcfKI4SCmY2XTDi1c89krjqB6u3PomVtElmLdM5EVQTnLpjxuibf0cUeO4eKhPyhHcUem88k0jybvpcXkdj0FPENj7NuzSqccScSHH8Yhq5SNO1Sr5GmCoOBeIYbFy0b02vkzTaouuORNfzln4+TSsbxKxanj+/lnOOmUTv3LE847Ee8pTIXQogxmoKUksbGRr761a/yta99DYBEIkFdXR033ngjF1544S7nKBQKFAo7wu+SySQtLS2vmYrt4bE/s7uJ8/Q5Ydru+jbFzBB2Pom0ioCg9uDzaD35q7scO5TKo2sK5x4/g/8477BdrjGyWh8phz161T56Jd/oT1JM9WNEalwz1ZKfgqLx+OBk7lkfZCCvk5MBIkEfkaCPdK7I5CoHM9WDY9v05gP857mTOO2cC2nriPHln9+PlJTKzgsBv/jKqXsVWm0dMa7+yV3khjop95nE8xrYRb406XkmNpVTf8Ql1M49c5//Hzx28K6UudiyZQs9PT0sWLCgtK2srIzDDjuMZ599drdC4Yc//CHXX3/9vhyGh8c+542aS8494UPMm9a4yzHl04+n+8k/49imm0OgKPS/dCdaqIJC69n0xtLMm9a422NHMyI4egbTpLIFwgGDhupIadU+qbmSSc2V9K24m7blCzGzCRwzh3QcnEKGLrOSuzcHMKVG3lJAkeSLFiG/QTKTp8NMUxOUJO0QAdWib93jPPbkJAaKwTfVoKo3lmYolSMkbYqORlRJ01cMEjODtNomfcsXEmme7WkM+wH7VCj09PQAlKpmjlBXV1d6b2euvfZavvKVr5Rej2gKHh5vN693on+z5pKRiXk0kaZZ9AXKkNkEQlMQqoFTzLJw8fMszUDOErtcIzewtbTSD1S3ltrJ5gsW2XwRKd0M63zBGtNWNjewlb7lC13NZFgogESoOrG8Qa7gEPQVkQQJ+FQKlqQ86iedyWDZkr5ckIAuaa20+esrjRQ3LCMQCGCa9utuUDXyjB95YTODKYteM4wqHAKqQpWRp8pvoocbvczq/Yh3PfrI5/OVev56eLxTvN6Jfl/38zYiNai6H0sOIVS3DlJXoZzF2+rQoznGNTSOuUZk4Cl6nrsFK59G84epP/wSepW5ZPJFwgEfjoSgXyNftAkGdFLZQmnVXkz1Y2YT2PkkMJLwKZASKn0F/KpJ3vKjqhq5okTXFLI5k/qqEOfWrUVXHBytjN8sryBe0FA0k6GMhaYo5E2L3liaiqifz5x90F61maFUjoF41m0OhILlCIpOgGmhQVobwl5m9X7GPi1zMdLovbe3d8z23t7eMU3gPTzeTXae6KWEmxevpK0jtsu+I/28q8uDJXNJJl+kN5Z+U9cOVLdSPfsMhKLgFLNI22Qwp5GzFEJmN2aqt3SN7Vva6Hz8D+SHOrFzSXKx7Wx/5FcEUhsI+Q1yeRNFQCZnIqUknsyPWbU7VtFtzWkVQdF3dIJTFMZVqZzeOkCkspZQKIgQbpkPv0/j0rMO5bTTT2VOTYaBoQSxgo6qqSiqSqFok8mbDMRz9A1l9vgcRj/jqrIglu2QL1r4DI1wQEdVBB1mNR1JHSEEtQef72kJ+wn7VFOYMGEC9fX1PPLII8ydOxdwzUHPP//8azZb8fB4pxiZ6F+PXfzt6OfddMxlSAH9L/6LYqqfqkCRoKEQL/og3s1QwSDk9xEqtGOmBxGq7tZQsi2sTAzjxV9y9qwLuGu1W2epaLlZ0b1DaQ6b1VTyJfQtX4hjFobrLWVhuBkQUqL5gnzigtM5q/roPTirP0SkeTYvP7IGsX4TKCq5vLnLvcRTBa77w8PMqJXMmDVrt884VzDRVAXTckuCAPh9OkowiDH3UiYdOIWufJRNq9q9vIj9gDcsFNLpNJs2bSq9HmnbWFlZybhx47jmmmv4wQ9+wJQpU0ohqY2NjWNyGTw83k3eyET/dvXzbj76MoxwDR2P/R9Tyho5y5fnng0RejOCMp/FJ08/lEbfC3QOd3TDtnaUUZKSQ+0Haf7Ilfxo4TqqokHKo36yOZN1WwZYu3o1zvKFSCkJN84k07ue7TFJQq2hJqwyc+7B1M5zw0Brh+9xdwSqWznyqCi1S7rpi2dxdhunKEnnbf7xtxv44kXHUjv3TNo6YnT1p9BUpfSMI0Gf6/coWvh0lbKgRtSv0NRQz+KVaW5e/DSZfBFVUThwWgMHz2hi3rQGT0C8C7xhobB8+XKOO+640usRJ/GnPvUpbrzxRr7xjW+QyWT47Gc/Szwe5+ijj+aBBx7wchQ89hve6ES/p0iit0qkeRZGuArHynNia4rJwR6GCgZzTz+LanszPc/d5xbctkZCtgVC82GUNWBlYwgrhVBgQkMFiiKoiEjae+N0dvdQW8ziK2tCKApPZw/i7q0+TL2CSCTCpQceyrl7MdWMdmxPam7lmo8fwW//uYz2ngT2GMmw4+9UHrqfvoH7X7G588UsmXyRQsEiq5hkC0Xqq8LMnRhlw/Y4xUKeoB3nhLJO2h95nr+8eiCKHkCxi2zuzrGxfZA7H11LfVWYqy88/B3pn+6xg/dUO04Pj33J/lDKYcTMYxezqEaQ2oPPJ9I8m7a7vo2UEscyyce2wXD/A1/VeBTVtcMrh32Tb92wapecgR99ejbO8z9GSkmPVcdPnqnAAZrGTWQoy27zCkYEQapzNfFXl44Zz8jq/58Pr+HvD60hnhpp3ONOHZqQfH36s9RpCX6z7RgcXyWhSJhstoCiqnzu3CMZL9cR2HoX2/qL9CUKVEcNpoyv54H18Ld19ZT5LDozAQq2ikTg0xWEUBjfUMb/ffMMT2PYB3jtOD08XoPdhYy+E4wRRnPdLOPRIaeJLS9gj1rpa/4I2f5NaP4IOBZCM9zJetYsPnm62EXjmTHrQ/TZ59O3fCE9A0Pk7CrG1Vei+0NUG3IX/8mIYLKyCczMIGqwgmD1RMxsjL7lC9FDVVRrBld/ZBxKcjN/fTRD3nZ9AwqSD0V7qTNSDJlhBvMG+XQWGcu7hQA1B3XrAxj5p7AVDSVQhhzqxS6keXCTj3+3VZIoasSLBrYUw2JGYtoOqpCkMsXXzIHw2Ld4QsHD4x1kT6GwoyNvjEgNqhEsFa9zrDyByhaa5n8BRTNKwgP2bNqqHRY29qZtlPe3kZI+fI4c4z9Zu3o1WzeuhbZ7aSmXqMFyiql+7HwSx8qjByvJ9LzqZkALQWcmxJIVE2kKayiKSldKoWCrdOXC/HrToUwP95O1VKSU+IRJQepkTYW+dU/QWNbJ47EpLOlvIVdsRhEORQKE1Bz1PofufBQ5HAwpkEhHYAmJz1DfklPf443jCQUPj3eI3eU83LhoGVNCg2OKwwWqW6k92F3p5we3IlSN6tlnUDHlqN2ed08aT6C6lTnVrVyaqdpFm3j8ocXc/uhWskWJX4zntNZ+ZlQX6E7VU6llmFyVx8wO4RQzECzHF61ncCBJ1hQ0ljkUpYJERQBRw8J24OVEI7owsVEpShVN2OjCQqNIVy7Mg90TcDCpC1p0Z/3EChoVoQLlPguEoCNX5goEFBCgKgonHT7Z0xLeYTyh4OHxDrFzKGxEJGkfiLHqoSdR15glf0K6czUgCLXMI7npKRzbYvCV+7EKqddVPG5nX8lobaJcJMj0rufapVuQCBoiksGU5O8bGvFvtrHleAKqxWlWHwta0qi+ML5ovZtXYZS795FWCPoEpgO6KgmFI4hcH115g6hWRAgHv2KRdzT8ik2lkSNmRcg5OrVGCkXxUxX1MdAPCTMA5MhZOppwqDJyBMIRTCVKMKBz/gLPyfxO4wkFD493iNGhsBVB6O0fIKBCfXUFUvbS+fgfkI6NlY0z0t9Zj9SgGiHyQx3kn7+dxMandls8bkQQrFjfzaInXiWVKRIJGXzm7INKtZAiA0/Rt3wh67ZLsoUpNIRtCraOJRWGrCA1SoY6f4qkHeLh+FyOP2MaxrobMbMxlnbWc8+mCFnbIFfU8RVtFCAS0CirqaNzW46IYXNo2TaWDTWTsw0CisVJtRto9KchrxBQTBKWn6pggFzOotwnydsaA5lqAHyKhSM0hBGmMhTYJ6G/Hm8cTyh4eLxDjA6F3d6XRJUOZ0zPM67cxsr7MdMDuHYTHRwb7AJmehBLxBBCQQoFZzfF40aXk+gZdDOMNVUhlszx//7+HPOmNVIY6mTFA/dR4TOoq/YTUC22JQ2yjp+CFcAetucrQhBVs8RyBXKRqTQdfD7L7v8bd68P4EiLidECg1YZuYLNzPIYXfko7d0xAuFqTqp6haOCr3JYVRcpvZEKLUONsw0ch0Z/gpNqN7CkfxrdSQhoNqdPKfDoFj+ayBJQTBwEQsB5U/o56cJzxwiE/SFS7IOCJxQ83hO8XyaFEVPO9i1t5F/8PU2hPNKppJDsQTo2CBVNM9ie9jOYdqg0cjT6k27vZs2HHq7GysbYsGkbmS5lTP+DkN/AshwQw3/bNn2xDH+86wXWrNtGItZM0FA5Y2qKI5tSLNzUhCMFmnAzogfNAOVGgYKtYmiuqSnSPJu4E6GAj/qIA7akmMszaIaxqCaiFzmobDuXX3YJExpOp+/lRfg3PYWUSVQjiBo4nNTWZUgExzf2UFNdQXtCY1wkj89nsMicQN7USAo/ChJdcejetp7ktpeg2a22/GYLEnq8OTyh4LHf836bFEplrSPd9C1fSKbnVexCGhDgWDy8vZolfVPI2SoBxeSk2g0cW70ZaVtYuQSP9jTz8G1t5KzNSAmpTIEPTaqjJ5YGt7wRtuOAEDhS8vSK7ZQFNOpCJvGC5J4NEU4bn6LcZ1JVWY7uZIgNJekpROkvhCgPOJzW0kVTOE8xladCzxM0NIZyJtmCTk8xjESQKYKu6KzsD2FmYgSqZzH+xKvJzTuLDZu2MWAGqS3340/24Ngmjw9M4t62cnK2QjgVZlqgk6ypIJH4hE3W1sk7Ovd2TeaFm9dyeb6eedMa92lBQo/XxhMKHvs1+7pK6f5E7dwzkbZF55N/wojUInQfm7cPsqR3Eg6SWiNFwgqwpH865XoOTTg4OY0HBiahh3yMqwrS2ZcknSvS2ZfE59NQcAWBaTkIAWVhP0JAbXUFZqoI8W56M66ZprKiHNVfTlmwnHRmEw1qjnOnJ5gSHaIlUixVLR1fKTileTsLN9bRVwi5yWXCRBWQLCgIDIbMYOm+3LIVHWTyRTRV4dDmU5hkLeeeTVGkgHH1laRklFWZAH4jTbFYpOBoOAjAodLII9Qabl68EhBvqn+Dx5vHEwoe+zVvpHjde42+FXe7ZbHTMYRm4KtoIlc+kzx+GsoUnFyeMqPI1kw5N24/BDe1SyUncxwQTqIoIZpqo8TTeYbSOZI9BYQiUKXEp6vUVYU5e/50Hnh203ANojqGCgZlPosTzz2Lpj5RattphKs5o3Y982s6UI0g5dOPLyXU1R58PrQtxnYEElEKG1UxyUsVXyBMy4RJwFghrmkK27oSbO2SlIdmkbcspjSVESgvw+dI4uk8VZUVONkBivk0ffkQuuIQDAYpr4jQOVQE2GOdqveLSXF/wxMKHvs1b0eV0v2BkQY4KCpCN5C2TWGokzJVJ2jUkFWr8atZBjIaOVsnrOap9mWJOVVkMyodPTFqRZDBjE0ooCMlhAM+aiuCDCXzWI7Df376wxx70ARqK0Oj8hR8fPL0Q5kx60PMgDGJbyNtO9Mdqxl6dSmDq+5FNYLkWs/mwf6p+JUEfsWi6CiYUsFxDDRN54LTDi1NyiNCPOg3aO+OI3CwJQymCti2ZPXWOK1NYKgaFRE/pxw5mQee2cRgbAjVzBPWTXSZo7N9M0aoknnTGgC5S57Fy+u73lcmxf0JTyh47Ne8XVVK322Kqf4dpSyESiHRhTSLNEfSXHRcK3etVojlG3CUJEHVotqXRTeC1GkOqaIkWVTo2eJGJUVCPmzbYVx9OUIImmqjtPfGMXQV2HtBv7GJb+7vofVL3azksibMbIz1z91PJjOB2pCJIjL05UMUpKBML3LBh6vH9I+uqwxTNG3au3sxbTms3Qh0TSAV17S1tTNOa2N5KVz25MOnsH1LG48s+hvP9lTQm3dbgJ5cu55Gf5JJO40fKPWJfr+ZFPcHPKHgsd8yYh54PT2L32uMLmVhRGqR0gbHZtxJX2POlKOYP3zv6YEufrHwRVJpk3Jhk8yrRPUiplQoDwepLvOzrSdFPF0kvaXPLUsd8VMVDY7Rpl5PnafcwFaGNj6FlU3gr2pFKAp6sJJy0Y1PMUnaYSp9cRwUbCm44oBtHBpcR27guDEJdY5lgrQRKMhhz7dpOSAUDEXF0FU+c/bBnHvCzNLYup65mQnKZgJVEfJSZ1yZ5ODqoVKLztHjf2ZV+y4mxU0dgyxdvrl0Po83jycUPPZL3m8RRzszupRFIdFZqkhaMeWokjAsmjbh6kbOOEFwzyPL6U3G8StFDq7L8GKihcaIQ2pwK+lMAAUFVYBpCWKJHBefPHu3k+PO/Z5HGCmKZ2YTWJlBpHQIDBfFU4wAc6pTLO8rp9ceXsXXb+awCUGsbGJMb+XeWBpDg6nRFINmkIGshiVdX4RfBYlD0XKruo6M5/Z7nuK2R+IMZA8n5+gE1CJVfVliqQIf71xN2YRDxtzDzibFDe0DxJI5bl68knueWP+++6y803hCwWO/4/0ccTSa2t1USB0Rhj2DaVLZAuGAQUN1hDMWHMyMOoUKPYseqmT9n16gt78TRQgsqeBTHZqCaYxwDYmiytxpDbtcb3dlumvnnlnyb0gpCVS1kpUOVnaI/OBWHhuYwIN908gVHSQxDi5r57iazTSG8hQTVeihijG9lesqw4QCPnJ5HZ9ismOKkZiWjaFKQgE/hq7St+JuXnpsEbe90EzOlBSlhpSSgqVRUFUe7JvKzGceJlQ3bUzdp0nNlVz44SZufWgDG9tTxJJFKssCTG6ufN9+Vt5J9mmPZg+PN0NbR4xnVrWXeiTv677I+zOB6lbKJhxCoLq1JAzzBYtsvoiUuN3KChZ3PfYqA8Ug4eZZzJg1i/OPrEFIh5TpQxEQ0ixCpMkn+giY/eh9y8ZcJzewlZceW8TK/hB9ohUpJX3LF5Y0B7uYRQ9WIhSFYPVEtFAVuYkf4+H4XLRAOdUVUWyp8XJqHELzIwArO0TFtOPHaByTmiu59KxDkb5yujJ+BA46NhrSHadSoFxJEEhtoG/5QgZzGnnpZljb0i11IYXAp9jkLJXegRTtS35K34q7S9foW3E3swf+zH+Mf5yTa9dTGYSpLdXv+8/KO4WnKXi8q+zOTDRvWuPbHnG0P4Yz9sbSDKXyGLqCZUuCfo180SZXNOmLZfj5rc9QXR7kk6fP4bwFs6jtuYvBnMaGRBlPbTPoL4QJ+nVOG99DYOt6cgMHE6huJTewlb/d+RD/WN5CQfoJ6JKPTPYxv3J9SUsZXarb/V1GomwmOWsNGhZbOuOYRQMHH09lD+TScdsxs3HCzbN2uQ/XdCP43xsfoVL20JcLEDMDSKmQsALMCXZTp/TQX8xSW15L0IBcIYCCpOBoqML9HVBNKnx5rIJC5xN/RA9V4a9oKmk1k5oqUfQET3Qm6BsIU1td8b6JTns38YSCx7vG3sxEb2fE0f/983nuWLoW03KoiPjH2KBzA1tJd65GShhQW+mL56nQs2NKW+9rRlbrL7w8yEA8g2U7WLaD7ThoikLPQBqhCJpro+QK1vAzOpUDjz2LvuULOSDQzjzNIhUYT0N1Gc1hKCSybie1jlW89Ngi/rG8Bce2qPEnSDlR7lkfZOpBFUwdNlvtzr8RqJ6Epq5lW1cCVQFVkeDA8p4oJzTptETKxpiORjNvWgM1FWESfT7Slo6KRAiHSj3Ltmw5HUkdn5TUiu18ZLKPe9YH8WmSvK3jV/L4FIuTajbQqA9iDS/6N9/9ParnnDGmAdGE2hCnNnfySKJuzGcFXIf0/iT03yt4QsHjbWdPzs29Jaa9XX2R/++O5/n1wuexbQddBauY44Z/PcMkfw+V2VcYXHM/VjbOY33jebB/KnnHIKA5fGTiIB8/Z8Eu1UlfL3vSTEbs/NtiknvXTKfMHyVjauQKJqblYAsHR4JfVUllC9RXRXYk7w37JFIdq9GevRmh5dCDAcxsDNUI4ljFYRNNiIL0U+NPIByTiJKizwzhjDux9P/YnX+jFjj2oAnceM/LSBQUVacmkMGyYahgcNBxZ+9RUE5qruTjx0/kJ3/rpSB1BBJNSnyKTYEAm15+lGl6GqeY4ehgguj0SQyVH47015Jadw/1dDI32jHqjAK7kGHo1aUoqjFGqzlpouCUw44gLsuoqwzz8vouvvzz+9+3QQpvN55Q8Hhb2ZNzE/ZNYtobMQO1dcRY+OAKLMsioBSxLEE8kcfOFnn57nuYGe4B6dBVrOTBvik40qZGT5AWFSzeUsP0xxYxf1R10tfLHY+s4Y//fpF0tkA46OOzH3Xj80ccvLaZJ+HUkDMFTaEYorqZRFZjS2+WspBOrujgSMG27iESiSShoL/0jALVrcPjkbus9BXNYFtMMmRX4EhBb6GMMi2Do9dQHgkz7dCTgLFCe3SkT25gK6dNlyx9PoglNWorgqTTGXAs5p5+FrWzdjUdjWZmvSCgWmQUDVU4CAQ9xQj1ap4ykcBfNR4rF+eR9iru7Z/BQDpOvjhIUGmhyl9LvKhzbLUbZopmIITC9oSG1XgUgcRqGswd91o7axa5ga1s2LSaGxe1IVTf+zpI4e3EEwoebxujo1pGEqFGl33eW2La3kJScwNbSXWs5t6XE9y+LE+mIMf0DtjdOIqpfl555iVyyQE0qWLaoAmbnNRQsanQsiAdQBIrGORsjVojiSIUfIpFX87P2j6NI0aFX44+985a0AhtHTF+eduzDCZzCCEYSuX55W3PMm9aI9VmP4VEL46VJ5hN4aOKWEZQ6Wwlk/YhZIBaMUjeF6AzHSDvQKFYpCqf4vGHFjPp05eUrjOy0h8xfUWaZ/Hvp7Zyw5rp9GR0MqabyNanlFGrGXz5LDcLeU9Ce2Q7xSyn1zTzYN80BhKMyYh+LYbMIKqq0BjKM5D3YzsgJcyJbKfG3kauV6NXbeX2jc3ErTyW48a9ZIRKRFdY0j+dqeEBGv0pFKHwaN84lgwcgNMeJOg7ivOPrOG8BbMIVLeWxruqW2egbyqVFRFyBf19VRblncITCh5vG2OydocToQqJzjFx7bszE+2pbeV4uZ7K7CsMbXiCjiHJ79bPJ2H5URSNWFzw85uWMqNWMmPUCvaFh+9g4/KHKZMxnOwQYeVwbFUnYxvkHB0BHFjWQWM4DyaAoFLPEFDdhjCWo9JnBnGkYNG2cdSvzPDxCe6596YFjfDy+m7641l0XcWnqRQsm/54lgef28Tk0ADZhKDRb9McMTmpdiNLeifRkw2gCpNyPUfBVgjoBRxpoAqF5rCFpljc/uhWDj949Zh7TXWsKo3npWIFt7x6ILGin7Tp5hUDhHVJKBhg3rRG1q5eXeqxMKG2oiS09VDVGGE+rZBGiFepPfBcDj1o1uueXFsmTCISLaeYidEaSjFUNFCFzQn12xCKiiMlr2zPEzf9KMPVXQUSS6qoAvK2wZAVoVHJ0JkJsqRvKlq4kobGGgbiWe5YluSoo6M0jlp8tOWbGMprDHbn8A12UxYN7pLI57F3PKHg8baxu6gW1Qju4pzcOdt2tK8hVzDJpWIMDKVYes8DHFu1CYANqQnETT8qDgY5irZKf0Llgb/9kuqLziLSPNtNilq6mbzdgl+p58TKNZxUs457ew4gYxtIKfGrJq+m63i8N838mm3gWDT6k5xUs557ew6gpxBFCGgK5fGHy/n7E50cdnCMRn9yt1qQHqpC0Qw6037isoy+oYx7U1K6Za2lxLJt/nbvCxiKg1o4nJNr2ziudivH1W1naqiPtH8CEauTjZk6HugaR3sm4k6USAbyGrVBKJg2nd09JaGws1Y22F4kNhQnVTAAgYrEQZA3JZlUgtvueZrn1nSP6bFwYisUEp3kBraUhPlDWyPcs6GRbNGmbGA9erjqdQuFSc2VXH7efG5ctIxMrkBZ0OHEytVMaCjHTObdRkLDCOH+SOlKh7xWRlVFgHlnXU1zOMdgWxanP0FDY80u/qfqiLv46BOtPNMZoszvkC64z2hwKM35R7fQ6E+S2NK2R43OYweeUPB429hzVEvrXo8b8TW8srmPWDKDZUvAxz86ZoN03N4Cw/sKId35VgASrGKGjkd/S49Vy20rJmLbNrUBSTyvsKRvKodWbMeSKkVHRRGSCj2PFAoP9k5hWkWWBr0foRqcOLmAHurhtrYgLXVllJU3IbTALhPRaC0o27ue9iU/5ZHOOu7vaMLUyvGFogT9OrmChZ03sS0LIR3UQoyqYIE4Gkv6pzFrfIB6tZ9m0Y8eHsTMZGn0byKqZfjLlgMpWAJdkUip0JXSqA85NDXUl57ZzlpZbXkIVTgMt1XAke4Dchwwc0kefmolgWCYupBJXxb+8UqUMDEOqQsSqJ6AagTZ0pfhng2N2I5FXcgir2hv2D6/c39o5/lnkVInUDsFMzPIAY5DRXeReNFAQWIjUIQkEgry6XOOIDq+kY2xNMHxNuHQM7v1Pxl+B9UI0tefIWfW0hyIk1cdCo5CygxQtuFPPPQ7i7gdpbbc4MBjz3rTAQMfBDyh4PG2sruoFti7LX5ScyVNtRFWbeotbVNwSNs69/YcwNTwAFPDg5RrORKWH2e4xk65nmdqeBAzk2DQqScv/dTog2BLopqgKxflscGJbsdL4aCpgkEzTKsvRdL0Uaiai5J7GumY2JkYEw2LMq2BglOF0AK7nYgKyR4U3U/7gElfPIAMVPJA53gcaVGlDJAnRDhoUB7xk88XcHIZio6gLux2MSvT8/QVwgykbFoaIkTHH0iubyOOmcMupPHpGoYGzX5Bbxoc9zCmjqvGV9FUej47a2X12gAnNNksbGvGcdyidAKJqkjm1hVYO+gnJIeIy3IG8yZFW+HPa1qQjeO4bMpRmJlBVj1wH9miTV3IIlDeQDRSsVf7/J6c/qM1wT7bXSRYuSGkY9EcNjl/3Ebu2NZK1vHh1+DkA2u59OKP7hJFdMCEatZtGdhNmHIltQefT9Vji/CJPEM5lTK9SN4JEtELvDoU4IXN48g5BgFdckbsYT73JgIGPih4QsFjn7G7iX70tq58lN5V7eh9ywhsvWuPtvi2jhjrtw2iKmJ4QnMnNekIsrZOrBjgQ9Fezm1azb09B5C1dYKaxRmNbTT4k3TnosT0KlRFknTCRJQUCdOHpjjY6FT58iQs16IjUUjYYYK6SSizEcfOAQJF99PoS3By3UYeKzbtdiIK1E4h9sqDPNrTwj0900hZPoSi40iYWmWDZVMRFORtlS987FDK7C62P3M7t7W1EktbRLUCCdNPKOhj+hEfobbaIDKcDFZM9eNYRYxBi+gtrwKC6RWwtT9PpuDw6oDGl39+f8kBvzut7PNnz8H/ZJzFq3LkLYlfsTi4PsXUOoMNQyp9GZWYBTY6Ph0CZbXctVphfkeMSXPPZK46Af/mpxmUgjq9nMReosNeb62q0Q7x7mdvRqgGRnkDRpeKZUmiZRXMOfgwtvcm+L87XkBTlJJfad2WAb5y8ZEYurqL4Kmdeybzm2ezPfAQtzzaRUfOR0CzOLpiK8uGxuEAtf40STPAvZsrOW7TNuZ4QmG3eELBY5+wO6crUNr2aI8bwVKQOmqul9PGV3DSRB9mZpCe524Z04i+N5bGtBwMVZJ33PLLDgJFQFA1saTCmmQdUyNDXNvawUDSJGr10hhI8UR8Bg90jydnqRQtC1DIKRGCBsyPbmXZUBN5S1AXcuhMaUgEugpnTMvS4EvgFH1Ix0ZaBYSisqBlkJOPnE4mOGHMRJQb2EqubyN92kTu7JnJQM7tHDZSFbRtUGVCucpQVhLy+5g3rYFGf4hHV5rMDHbwUrye/kIYv2pxYvU6fJuW0b3Bpm8nIWlm7uakqle4d3MVg5ZO1gxQXRFmQq2fgXiGGxctK5lzRmtlsQ1PMLDqHk4LW8w7uJxsZDorNwzxXF81Lw/qFC1J3tIpWDa64lDrL1Ib9NM7XCJiUnMla/sEBanRF8vQHeuhpjzINR8/Yhct4Y3WqgpUt1JM9SMdm15Zx72bovh0qPFnyOnV/L+/P4eU7ufAp6uomqC+MlIqB37k7HG7/QwGqlsJ1U0BpQfLgbyp0JsPkXN0ao0UqtCIajkGrPIxneI8xuIJBY+3zO5CT3uevQUECNWgT7SyeEsFDjHqa2vozTgs3lLDROU5Gv0JpGPT9/Iixp94NeD6FMoCgoJWwLI0TOmGKkZ1k6nlGf7Zewh5R8ev2HxEHeBTl1yAlY2xtb/IY3cn0AJJagsdxPFjSYWzxrcz2d9Fa02A2v4yFm+uIm/ZNAQtDqpLcupUm3qtF2mHwRdGAoruxzHzqLqPSZPHE6geOxGN2PA3F6YxmNdxo/AdACSCpKnTUwxRFfWNCrPt4s/r55FMJlGF5ODKHk6ckKDW2oJj1eOvaMHMxnjpsUX4Uw3Ulvtxli/khBbJzAaN57Y5LN5aR0tYIdfXQcC26c0HWL9sCZOaLwTciTG2bin9L96BdGwU1aA+6NCX28wLqdk4JKn1pYkLHQUFvybx64JKf5He/gECFU2lrmY3L15JeThAQ1WE/ngGQ1eZN61xl///m+mON2LuGvED1AayKEIl6PfR1hOnpjyE39AwLYftPQlsS75mDktbR4y/P9FJQYQoOEUyUuHJ2ETCaoGE4qdMFEhaAcKRSKlTnMeueAXxPN4yOxdU04OV2IUMVj6NHqwkVtDIOzrlegEckzK9QLboECv6kEJBCIXEpqfIDWwFoDDUyZy6An7FpCroUBcyOXlCii9OX8fWTASh+qgPuYXT7t1cSfugRc2cMzBrDyFnCaory1A1g8qwClqAxsoAjUYCNRDltAPgm0fF+dyMNn7w0QiXzeymVm5FCEH94ZdQf8QlqLoPp5hB1X0ljSex5YXS+AAcqwhSUkz0IKVr4hKAEAIQRMJ+Lj3nSH7xlVM594QPlSZZNVBOQ8TC0BTWZluG9QrQQ1UIReHR3nH8dPk4rr95OV///bMs2RxGD1Yyrtzm8PEKYa1A/0AcR0qSdgi/YiE33c3QxqcBV0D3LLsdaRXAsXGsPFYmRm8sS86EhoZGQnWTqautQ1UEHx6Xx6dBXy6IkA7nH1nDpObKMUUJIyEfrQ0VWLaz20Jzo5MQHUe+riTEEXNXVcDCJwrECzp6pJ7BjBuR1FQbobHSj6ZICkULy3Fes9SJWzsqR8ZUEUIQ0BxAIIVCzjLoyFcifRVcccEJXs7CXvA0BY+3zMgEWUh244s2uKGnvhAIMLMxKn11+BWTeEGlPNFLPK8SUIqUK0kUIdArm3GKOYY2PsUt/7yffz47QLYIirQ4omaA02Zq1Gu9rOz1U3B0apUksmgRQdJfDLOt7VXmHD6/NDkNZQv4FZ14QSOgQZmaQkgVx8wjHYd6bYCGBsGk484Gzh7jB3EnfrexfbhpFqmOVbTd9e1dzGI9z95CMdXPRH2IqDaRuBV09QQJuioojwSpiARKz2jHaroCM9UM8W56M5IhM0hjpArHytMeL+Oe9UGkgJbaKIPJAvd3NHFAzRYm1Iao1wY4rSXDfdsb6MsF8SlFTqrdQHVhE1sW/4DMwefhi9Rg55O4apoCUiKtAlG7D90cors7SV1NNQnTR0CXHN/YwUkTy+mLZ6gKWMxf8CngjWWbv5HueGOc0cN+gL761Sx8pp/evMDQFWrKgyRi/YTtfipUFUdVuer4es5+jVIVdZVhdFWlaEn8ClhSQVdxmwINr38LhTwrX3zey3DeC55Q8HhLlHwJhQx2IY2VTeArq6PuCDfbtue5W6gqrOOU5hbu395Ibz5AQIcTK1fRFMzgq5yMlR3Cyg7x4tJ/8Y81M0BRaSzTiaUFqwajLIhvQNQYTDv8VMLtncRTeaKaSdIKENAlRv8ycgMnM6m5tTQ59SSqwEpxfGMX4ysgUHsyub6Nuw2NHSlbvf5ff0dpf4gGY8iNLEr1E3916S5mMSufwszEhnMa4MLmlfy9cx5JywdIAoaCadr87s5le6j8WsdQwaDMZ3HgWWdRbW+hb/lCegaGyNlVjKuvRPeHqDWCbMlkGCoYNA6P+4LTDmPGi0/Tn5ZEzG4atEHAwcrE6H7yz0QnHQUIhKYjbQuGg3dbyh3ODBS4Z32Q9p4Y5dUNXHRcKy32euziVhpqxj6TN9oG9fXUqtqTM/qTF7Zy1NE7hMXzy1dxw7+epNcyCBoKp47rYnJiHbmBI/YYMZQb2Eq12c9ZRzTw+3tT5C0dDQu/apKxNMoCRVRNoTul8fdnhnhuy7/43LmHezWRdoMnFDz2yt5CR0f7EoJ10ygke8CxaJr/BbfE8cuLcCwTgeD4hi6mBPvIhaZQFXKocSSFGJipPuxCGjVYQTJXR87WqNMzCBmmMqzTldBwJpzCpAVu3f6PD9zDzfcOMWBXEDDgjClpGowdbRtPnxOmfZOfe9J+LN3gpXwNB1RP5eNnHrvHe7njkTXcuGgZ8YFuAmorZ0yr5bi6dgZX3oO0rTGtKbO96zGzQ25sqFBKeRPt2XKejrViSo28pRERY52u1eUhjpjdwmMvbhmeZEeXi5hFpHk29qZtlPe3kZI+fMNmmGh5JXNP/yJN4Xxp3Hqkms4n/kgx0Q9SIjQDRQ/gFLNke9ah+EI4hTRC0ZDSoSsbot2Zh6rDJ2enIN/P7BOPZs7h88kNHLPH/+8bLUq4t5afa1ev5oZ/PQuKxri6il2c0aOPrTZD5FdsocduYFy5xcH1O6q+7k4ojA5yOMEIUjhmAQ+sk5jFAsIu4KSylAU1tsQ1VAWwHfLZ9BgnvccOPKHgsUf6VtxNz7O3YBcydJtV9FafTGTcPOZNa2BSc+UuCVO+aD2FRCfJbcvZ/sgvyQ9uRwgFo7IZpKRB68QIaPjCDZhZHaOsjlDDDFLtLxOsnkhVf56AahEvGlQaDvGCQtCASTMPKU0Go/sI1JaHqNd6EcLNkh7p5HXf8nEoQqGlppqUDJWykCc1t+4yqYzY+h3bos6fI2mHuHdTlAOq6qi2N6Ko2piM7K5COb0JnUo9Q6M/Q1c+yt3d03kqNhGGE69sy2EomaO9N46mqfTHMvz3nx5DKKAqCgfPaGR8fQUgaOuIuT2K81EywQmc9mE/DzyzaczqfHd1hoRQh/+SIBSkYyFUHbuQRSgq0pGAzRPxA1jYPo246QMElT6Ti6blmTp5/Ov6DIyerHfOQ3AL0G1jyAzSMmHSHifXvhV3s+KB+0jEmqkLmZipItXlbqnr7VvaqDbHZhovXpnh9s0TyFkKQV2hP57lxPG7ZsLD7oMcTgs+zEf+45v0xfPEe9r4zaJXiaVVt/aSI0FIDGuI+EBmjJPew8UTCh67JTewlc4n/oiVjvFo33j+2TGFuNmN0Aaoqwxz9YWHc/qcXctYCKGS2PQU2xMafal6KnwFmhM9BOqmYucS4NgUEp3YhQzScUi1v4ydT5LuWkM+7WdGxGFFvJGelELQBxcd1zqmvk+gurXUR8Au9iPE2PBXt0y0j1p/FjPVQ0VtlM6h4h4jYXpjadKZDPUhBzMPUT1HXy5IXzxDQ00ZFdOOZ2j9UgqJTu7c2sqjveMo5FL4KFJlZOjJR+gvhrFR8CsODm5yWTZv0dYxVLqOpipMbw6zsWOIOx+J4SaTQVV5gPkHtrJuy0DJrHLKEZOZO62B9EAXwupm7Wq5SzkL1R/GKG+mOLQdaeZAD6D5wtiFFOgBhKrSmQlzd8cEkpYfXXGQUhIvaNzdMZHjNm2j6tWlxF9dutfaTSPsbPo5e5ZDcssL3Lu5iryjEYmWc/l583cxx4yMt8JnEDRU4gUJ8W6GCgaGkyP/4u/ZunqodP1U9dH8/YlO1EAFdXY/8bzCfdtqOXr+/N1qCXuqrxXpWUr1theIJvs4sbKMe3umU7T9SBRUKenIhik3LJT2h8gNHO4lso3CEwoeu5Ab2Er/irspJvvpNiu5p2caCcuPJmyE0OgfyvKnu15kRu2BRFoPIbHpqZKtPjr5aO58dB33tbv1cgKqzcm1mzgpNIARraVp/hfoe/kuEhuecEM/NQOExiPbq1jSP428raMokkNrBvnkhWcy76gFu4xvd1nSiS0vYA938grokqQZIKpmGIhnCPlDJQfpiAlppDbR6mWPk0/2sz1hUe0zSZh+fEqeqoBFxbTjCTfPIlg/jRuW9rBwcwe2I0GGsO0A2/PlqMNhqALIO0opmmhnkukM3dt7GUq6RfbE8J69gxnuXLqOiY0VJXPTA89uIt29jsXPd5IxBSFd8omjnuL8Uw9mQ1s7r3br1FdXMK7ajdQpJrrQfCFUXxCrkMHJJUBKYoUKspYG0sHn94FQyOVNUukcqx74M9N9bajBCoLVE3epYDuaEW3KNgs0RASxVIqbHh5EOjXoGtT5c8Qzzm7NMcVUP2Y2QUuknNMnDrJ4cxU9aYgQ5+S6TTSF8ujBHbWjBqY1uA75xiakVUmgWKArbmLWHrrb57q7+lpCcRcmEjCzCY6tHqBcz/J/m48g6xgoQoJU3PczcYY2PgXgCYZhPKHgMYaOp/7K4Mp7sHIJcCwGcxo5S3ObpAgHTRPkbYjH46xY/FtmRvsQQqV8ynxq553Flu4Ui7cO4jh5ao08CcvPg70TOaD2VQ47+nyyPetJbHwC6Zgls8fLQ/Us6p6JoirU+tPEiz5WDURJd60BdhUKMLqPgMvI5FAve0udvHrNAOVhreQgHbE9L9kc5v6OJmJmmHTOBKnioDNU0KjzZTl1XC8TGisYWr+UgdX30l2sYNHKuVi2xHYcpISRaG5FUbAcEDjI4XIbo1EEOBLypqQrbVAcLg8tkaiKwHbAsh0UVZRi/De293L7k3GyplvMLll0+OOj/WzbeCPPDdSRMycS1N2Eu+PqQqj6eBqO+CSOZbLtgR8zPEAqjSxB1SRl+SiY9rALxCao21SX+5AZBzufxLHypRV2qmP1Lj6G3liaZDxGlTJAIWsTkJK+QgAktOhJsKFMtRjKFUoa2YjwXfn8E7R1KVRoPRwZ2cr4CWUM5VWqQwp1SjeOPW7MCr9Cz46JekqkJeHQnsNbd87kFoqKv2YS2c5XUIwAOBYAmnAI6SYNapKcbeAIQcHW6BvK0f30X4m98sBeNaUPEp5Q8CjR+eRf6XriD0jHQajuR6NSSxFQiyQtAwsVxxFI6eB3MhRseCI2DTMXZ1rqeY5sPZiOjgQ5S1Br5FEElGl5+ooRYsUAeqiK7qdvcOcsoQKSf2+fzJK+qcRNP4Zio2BTZeTozYfYtmE1Bw9s3a2De+eJa/TkML9yPVMPqqBYcyjjJ01i6uRwyYyxPWXwQOd4CpZNNl/EcgQO2nB/YJ3p4R6Ore0g2bYWo7ypVHE0k8lg2wY7qwKqpmGbNo50bfxuroIrCGDHb4CMpQM7NtjOjvdS2WIpxt+xbFJFDUOV6IpD0XIYKgZ4qKuJsGFTF8iSMP3c/aqfqWE/Bx57ATVzziCx5QUUI+Sa6ZA0+pN8pH4dd3TNJm4pCAHlRpGPHZBhfIVCJq8jLRPHzGNmh7BySbqe+gtCUcaYkwKpDWjFGHEUKkM68bRFQCmAECSsAFE1S9LSCIQUAqkNbLjj/8h2r+Ph7VXcv72RvH0gftUtDX5s1SbG1Vbjq2gm09NLMdaB5o/imDlUI8ikyeO58MOSWx/awLauDOFQaK9RT20dMXqVuQQOCBLqfphsz6tkOl/BygwiCr7S8640cgQUk4FiiIztw5IKCpJNmWpmW1uwzcIeNaUPGvtcKNi2zXXXXcff/vY3enp6aGxs5NJLL+Xb3/72cGKPx/7C6MkV4IWH/8lgppJKI0ejPwlC0BjMcmbLVha2Tydh+nFsqIroTAkk+P2aCQxmFaSsJKrnuWToZuZMriagQsLyU6YVSFh+AopJhZoiN7AFaVsomoFjm/y7Yyr/7pqJjYKDQtGBgYLbuyBoKFTo+V0iTvbWwyBVfTQD0xqo0LNMTywnsekB5LJ7aVtTRmT8IdjFLEnZQM4WaKqKaQuc4RW/ISxMVF5KNDNvyEQUdOpVH7rtdi6T0hk12e+Y2AtF14Sja25OgBBu7wJpj2gULsNFXIfL0o1FVQS6qpScy0d8qJ67n94MyOHEOPfYoqNQGXTAUqmrraM7JfEfdBq1c91uaUakBn9FIzkpcfJJAI6t2crMJp0NiSgVUz5MQ2IpTaE8ilaJFohiZYfIDbbjmHmQDk4hi1HZjJRuJ7diegBl5T2cVGXwYN8UupMaAV3lI1VrEELlwb4p9BfD+FWHUxq2Yj5+I0NWga58lPvbZ+LgUGMkSckIDw3OYGp4gMmNtWj+MHqkFjPeRSHWjhGtdX0KHav4UM8tfL7RIUE50w47lUOGk/92joIa8XMk4zE0c4iTKrdwbG0PRlkDarACKxNzFx/SptGf5JCKdv7dNQsHBU2RhNUCyxKtHJbtZVK1H7uY2WOE0weJfS4UfvzjH/O73/2Om266iZkzZ7J8+XI+/elPU1ZWxlVXXbWvL+fxJtl5cv1X+2QeWHcollSIaAVOqt3AsdWbUXQfn/rEeZyutrK2T8FMDxAodvOLf8cYyIxY1CFuBvnbxvFMK1vFybWSB3sn0VcME1AsTqrdwLgKQaB6AlqwDCkdtsUcnhicgIMg5FMo2CoFEwqOQCp+Tp/QxfhKMSbiZG+d3BavTJccobqV5PjQco6t7kaoOlI6JDY9hVBUwnY3RbOSnoKG5a7rAbBQUZAkLT9/XT8ZsMm1aThSQQqVjKmViliMRiLx6QpzpjTQ0ZegeyCNBFQFFAVM2530ARzHQQA+VeKggqKiKYJw0MeV5x9GY02kZCZ5ZlUHsVQRGzdXukw3ifoUYllJuU8lYRpEIr4x5RpGtKWe524hV8wiAL28gRbVoiXcx7ijWzEzrpO+rTNGwmmhumwy5UPPu13npIMjHczhwAAz2cvgyntAUTmusYup0SGGrBCVAZt6OkFRmVo2RFxWUROW1NjbhrvXCWLFQKnmkCIgItL0m2XE7TCOmSef6MZK9iERCM2gfPrxRJpn8+qtX8TMDlGvCOroRnulh9vS1fz9ic4x+Q3zpjWW/BxVygBDtvuZmxLqpdHZjq+iBT1cTahxJtmedTiFHDPq4PGURkTJYCg2upOlNx9iQ7KCZKdCbVkFU3cT4fRBY58LhWeeeYazzjqL008/HYDW1lZuv/12li1bttv9C4UChUKh9DqZTO7rIXnsxOjJVQtUcPvqAP/cHMSRru3VkbCkbypTwwM0GTaR5lnUVrdSveJu+rYs5OVunURhSqnejwAcBEnTYH2yjDMONZi6dhmDBZ1KI0dLhaDxmC9TMVySuW/5QlJDAlsYGLqGo7hJSraTp0wvcvm0jRzaXNyl98KeIk02bNrGzYs7kBKaKgw6t8V5MDWRqdE4TYEUVi6JEAq+qvGYXRtw7KkIqSBG+QBMqSKQmLbbT1gTCkOmm5G8o8zdzmt8F9uGvliGwUS2tE04NqpiY6FjO65vQVVVFAF1VUF8hp+AXyeXN/H7tFKY7whfvfQE/nDHs6SyBTRpcljVAEElx3P9tQw61UR1327NKiNO+L6XF5HY9BRWLkGxkEYxQnQ+/jtqDz6fR/RP8O/1mzFth4A1wIlV4ziuvhtp5cC2cBCY6QGEquHYFoHyZoRQaaKLhmIcoSgoRhRpWzSKJE1KmnDLQaQ2b0HofqSTKZlrElYAn2KSMIPoumTCjIMQmdXkB9tBUfBXjacjbbBm6ROM74jjTw8iVB2hGWAV2dZf5JZ1r6AFysfkfYAgky/SEBHkMyZRzaQvHyRmBmn0JykmuvFXttBy7OdLnx1/2k/NDasoZobw2f3EMn5MW3BP1xScLpVwOER6ZZpzT3ir37D3NvtcKBx55JH88Y9/ZMOGDUydOpWVK1fy1FNP8fOf/3y3+//whz/k+uuv39fD8NgLI5MrQmNzxxBLOw7FlhBQ3AqkGduHIiBWDDBetxja+BT5oc6SIKktD2CoEjncvnI0qm7QevJXqT+0k+S2F5G2Rah+CuEmN6RyZNKyN22jJtaGlrFJZgpkciaapnHJaTP42PwFu02m2lMntwEzWCrIZucTRNUsvUU/gxlBg5oHRdCRCRBP5ei3J+EzVFqMDB2ZEEUpkbj+gJEpP2n5x1xXlow/u8eRkoFkhoLpoAjwCcvVEhyNiZEU7ekQjlDRVIWz5k/nkBlN3Lx4JelcYY+ZwiOJY/98eA1Ll2/h5WyIgAYfOX4chxw4Y0zr0u1b2qjQs0ydPL7kgB9/4tUMtR5M+5KfogaipfIjv7ntMRZuHo+Ubo/qglRY0juZqaE+GgMCsEHaKKpO1YdOZXDN/eSHtqOHqzFkHXbB7SQXrJmMYxWwzRx2Nk503IGkt72ItE1Qdbd7Xe0G7uiaTYdZDgKqgwEGmo5lRtU8nl98I0lZzboNGs/2VJCzVQKvxjmpehzHNXbTnQ0xkIsymNPJ5Aq0VjGm2B6wo6QJgkTRR0C1qdRzjBjryiYfPcbnVAZ88nTBzYtXMphUcBhAqCqGT6FcLxA3815CG2+DUPjWt75FMplk+vTpqKqKbdv8z//8DxdffPFu97/22mv5yle+UnqdTCZpaWnZ18N6z/NaDeLfyH5GpAahqOSHOogV69waMThYUnWb2ds6thRYwoeVH6Lnub+hGgHsQgY1WE5+YCsfCis8nh+PjRvapwmHKr/FkcfML01MI1pBou2psY7L6lbmVLdyaaaKmxevRFEEuqpy7oIZ/Me5h+3x3vbcyW0SIf8GBuJZdFmkJxdEw6bSyAOSx/paeSR5INmChaoomLZAKgFAoACuV8C1+I9MKGPFgNwlqmgHAl1T0VQVRTHRVfDhYErXkX5K7Tqi9Wk68hW0VgrOOGYCtXNff6bwM6u249M1mmqiDMSzPLJqkI8sCA9XXV3DX/75OKlkHL9i8ZGJg3z8nAUlH4sb7ivwRRsQikKPVcfD7ZU4jkPIr1HI50shmrFiwPUjAcGmWUw64zukOlZhF7OY6UGKiR70SDW1B59H/NWlJcFsFzNowTIqpx9HPtZO7JUHwXaQisa0ijSBftD1InVV5Vh6OTcvXknn7CrufmUmKVMlUfQT0fI0BxIkrABL+qYQtwIsG2ohZ6uowqEgc3S2b6auppqUjBLyG8yb1gBIbl68kgGnBk0McFLtRhpDOVQjihGppnbeWbs8zxFhu3nti6x5bCX/2jaByqBEEX7KyRMbFUH1QWWfC4WFCxdy6623cttttzFz5kxWrFjBNddcQ2NjI5/61Kd22d/n8+Hz+fb1MN435Aa20rfCNQVIx95rktHraSQPw6umyUeTf/52ytU0EbWAqQkylkHecf8XptRYuH0G8YLB8U3dSCmx8ykebq/gwd4DydsaZXoBEw1fIER5SOeyU6dzyIJjd4x7D/b/EWH1RssowA5nciYZIxStJFA9qVSn5//9/Tl6BzNIO0i5nmNDxhV+SwZmoEcj1IoOhvIqjm3gSIktg9iMZAaLUYJgrEhQYJQ/YbRwEKiKoDzqJ5bIAVA0wRaa21JSLeDYNrWBDAdWx5HIUu+ISc2tr3m/eytJDXDjomUUMzHqgiZJM8DiLTVMf2wR84ef8c6aVV88j0MNhqZgWg4akpxU0YRDpeGOXw2UgV0oaYZasBwjWo+ZGUTRdKqmH48Rrqbn2VvI9beh+kLUHXEJgepWJp35PSoPWEBuYAuB6gnkegzUruW01kbR/SEcR7KpY5B/PrwS3bGIqCYxAmRsH0VHo0zL0ZUv4+G+iWgKlGlZMk6QoqOTs8zhmk0+PnXWoaVM65HPT/b5/yPatw0pHaRVINT4oT0uiiY1V9Lon4K91sK/3SSe14jqOeKmj1DYt9fqrh8E9rlQ+PrXv863vvUtLrzQTR2fNWsW27Zt44c//OFuhYLHnhkpM5GPbQdFwVe+Iypk59C51zMJj6Z27lkkNj7F+HyKcV0JOmJlWNK1ngdVk0mRBPGCxpKB6UyrSNMUTNFVKOfB3slIBLX+LEknjOmYfOaMCRx51JG7JC3tzv6/c3TH3url7MxItEnPYJpUtkA4YNBQvaHkeAz4dBqrgqjZLrJFwb090xC8St7RaYj6yQ8IyrU8BVvjo42vsqR/KhtT5TsuIEBIiAQNDA0SGROQVOg5Dgj3sDZZw1AxgFtAwv3qCCEZGMqiKILx9eV09aewbQhoRVQcFvXMJKDanNLUzrFVbVj59OuOcNlbpdLeWJpMrkClXkDT/JSrNtuTOs93BmjYtI1wPkpvTEFvPZvA1rsoJDqpClRQUR5FtQwSySw5x/VxzK/ZRlO4gFCCBGomsbUvx5YX16PEJJOaKkshqiP/v5FnJZG7hOhWTDmKiilHAdASiBGJbGAoC9WGG26rOEVyhQLVvjxFqQ1rqAoFRyXnaBRslYzjQxWSwWIQKQVSgE9VOayml0s/fjRzDt+RNe1O8EnaRAd2ZUupD0aubyO51whnPvDYszg99jD3bq6i1/QRiZZz6bDA+SCzz4VCNptFUca2aVBVFcdx9nCEx+4YmeQd203yEkLFTPYQqJ2ClRsqfTlHPuCvdxIeIVDdSv0Rl7D47rtZn66mQs+haiq9WT9SCoq2QpleoK8QZqjoo0EfJCmqKEg/tYE8mh6i3LHozfpoaazb5Yu0J/v/7urXvB5GsmrzBYtsvoiUkC9a5AtWyfFoOw6GrtCRDWLabsnkF+NNBFSLgWSeEAopUUHIL6mtr6PQq+HTBIqqIqXEkWDoCgXTJleUKIrCwZNCnOd/gEZ/mlvbZ3Nf90RUIdFUQdGSWDaAxHEk+YLJ3Kn1bO4aQscgYA0QUTIkrAAPdI5jSrCHiRXhPdbw2dns91qVSkMBH30DftSCZDDvI28J7t/exJI/rEXRNmLoKiG/wYUfvoLT54SYGqkhPRylpQgFxcry4apNnFHxKgIFo7yRJW0B7ts2HnNDHr04ndNSfZw63Sn9//Kx7fQ8dwsoKsGayXtdfOxu/KfOUHnohQIJK0CZliesF0iaflKWH59ioSqgDitppuOa83yqg6FYrIlXood2nbB3/uxLx9ntZ393mvTnrvoKx72O+k0fJPa5UDjjjDP4n//5H8aNG8fMmTN5+eWX+fnPf85ll122ry/1vqbUuCZcjZWJ4UgJjo2ZGUTzh0l1rh5Tt6Z8+vFveBK+Y2MdN7cdRH8xh09YVKgFDMWm6AjyFmQx3L4HYoiubIBkZAK+cDmJQpxyUSA+vLoaHRY5enLbvf2/9XU/g9Gx6SOmlHDAhyMh6NfIF22CAZ3U/8/ef0fJdV13/ujn3Fw5dHd1Rk4EQRCMYpKYCVKUREqiZFuSadkzHs/Y682MNb+3JryxZ43XLM/Ps+bnn3/P8xwlU6ZsBYqSmAOYcwDBAJAgcjc6d3V15apbN573x+0udAOgZI8lB4l7LVEE2F3h3nPPPnvvb2hH6DVNVTg50yIIFbwl/sGb1WEu7lukCpFstxryya1tNNkhFCpr+5NML3bwQ0kYhli6yVBPrIsMqrYc1HSCmY5g2CrTYwyiCEEsk+bEfNRyWT4sz5fbmLpOKmbiBTr9Pf24VZcMNkUnSV0UGLjszGvww9p+H9Ri2ziS59zNw3x/oooXLje9JLqZoNT0kNJj56Z+bMdfEgS8hY29ee64nlWvN2TVu0ilybrOIycLqLEcI0ODzM6EPHIStqQOMZp20VIDzLz0F3j1BYRuIISKkSpgL45TOfoi9ZNvErhtYr3ru9XC6Z8/b7+PmHiKPfObKLpJ0prDDX3H2JQosRikeWBuJ2nFYa5tIlEQSDKaSyHusRj2UpWZM9bJDzuALK+hrKgRfkAlff5lV/+N1+TPQvzYk8If/uEf8lu/9Vv8+q//OsVikaGhIX7t136N3/7t3/5xv9VPdSwv9NCz0TMDuOUppAxRND0SaTtN57966OlV4m0/ahP+o3tf4w/veQ0/CAlDcBSdsqdhihaBMGkEMVJqh5sKRzjSLLCntA0HE2lqoPdRViWJpLmq3D7b5rbx9v/2NxqQnx6nC7DdfMUmEpaB3fFQRCQ4p2sKbdvrDh53bRnk2OQiwZJ9pwA8KXi/muF//PpF+NXxrl/CrJsjlc5Sd6P3C8NolOz7DgPZFLoVJwwlJ2cWeHp+lP2lNHagEUhBKFQWmj4SiJkqqqLQ7niEUuJ4Pr946/k89vIxGtIiN3guxcUqmQRcfMdnSQ2mqI3tXWXq86PafmdrsR2fKvP2kTkUTUUPQ3w/Is4Vm9H/CwFeEJ7VGnP16+VZe+O/wb7gNubfPIp35Cj92RjStxkcGubkjIHblyJsPkNjfG/UNhICggCnMo1TnUUGDlPP/hHScwCBohvkz93Nxk/9l1XvZ5fGaZTKXD88z5ZEkbIbI2/YjKQD8ufeyOHDR9mz4COFwvr+GMeLAUJIhof66QQKaf3s/f6VAITO4jhC1ejd+ckl7spLtDoulvC4PpPk4+fq3Ur6+HSZ2TePsmF7+sMKYUX82JNCKpXiD/7gD/iDP/iDH/dL/9TGj5JtIPQxc8NkNl1Fa+A6Ds7O4a7o9y63ipIj55E/57ofuQkfnypz75MHCUOJvjR0DEKJHYKhKXx29CibU2WyLALwv8auRCLpMxo48T58YfLpa86hL5dYQoH88JlGZv0lf6vrcTYj+MdePsbNl2/isVeOEbcMGm0Hy9BAwBU7R3n8laO8fWR2BUrolFBdKzCoyxR3fObnsUuXceTYSSwvzhWpJt987ABBKDFUiSU6NG2NsbExRgd6aMg0qqKwr9SDike/1aLqmdS8GJoevU/HCYhZEQJJAv/65y/jF3bvpJBLREibiksinuXOW8+nNzjB8ftWJ00zM/i3avstx3y5SaPlggRD1wgCD0kEjxWAQsSSLlXbxDRJoj2GXQo/8DVjvevIKm+gu4vMTodkrZCW2kfcjBOrHQBNRJLcQkGEPjIMkGEHgJlOurvBD1lNwsCndOARzPwaEv1bUDSjW9m6zUUCt81QTDAUt5fmFSl6d9zC0OV3cuh7+3hw3yLNQKW/RyJDSc1ViWmSOy5NLyGkVm/gdmkcMzNIcvQCasdeJAx8Dux7ia8dsrv8hmKpssrF7tFD8MjJbQTHx4g/NMnnr+jjczec9zPPZoYPtY/+weOHtQ5OVwN9+J0md9/1Ds1WC9U+s9+7nAh+1MKeLzfxggBFEbQ7/qr/5gQqa60S56ZKSK/Fu/V+7ECnYDZRgKzpc6To8J3H30LVjW6f+8YN9v/W5nY2+YIPQt3s2jrI7ss3M19u4noBrxyY5OnXjvDgcwdYbPjETD0SoANYgsqa2pIt5VJEp8cpWh0XGULM1BnutZDVcQzhM9ZME0rRRbpcuS3FE68o9CUEirBIqDpTtsFQRsHQE8xXWrQ7PpahcvvV2/iF3TuBM9smQ1ad4/etTppvPns/ytbPEro5hv+Ws5f+fJJQhrh+EIndcQovlUtZGLrKYr2NEbbZXTgMbz7E8Xc/GJFml8aJjd/Hx9fmeHRiiPl2SEyr8JldGgVnBtXI4ytlWJq9LL/bs6UN7CluwQ51YorXZcID7H30r6kGCXrikkG9hBrPoSd68OrF6A4ZSWTgEThNQt/l4XeaPHagSasTYhgKX7j5PHZftpnDr++JKrxyheP3rf4Oy8+P167htxbR4jlivRtYnHBp1Kts6InWUKE313WxC6fLPHJyG2osR18iYH5hnrsfmqQwdx8XXnPbz7wo3odJ4R8w/iatg+VNfqVz1dqhPmZn3G6/d21e/K369f35JDKMDNFPj47U+V/HLuFLo29zTe+xJWaqS80zyOguk7OLNGyLWFhjaKCHhjS4++F32P7LO3/oTONs1dAH2TP+Tf2Bn3/1AGGrTEIGzHtJqm6AZWr4wYrvpSgUliqa0yuQ6WId2/FoVG2yQYuKZ5HXGnxxyzS6BjtvvIrW/BFeeNWh3IKs4VB2dEDQl02QyWYoVJpMzVf40jXD/KtPb131+Va2aWpjx1clzWfm1/DAIYvgvZNY6oXsLhzm2oGpVT7QK9tMZwtNUdBUBT8IQYKmCj5z7Tn8i09HldnxA6/iHfgrRlIuZvrs62s5KSfaJ8Ftc8u2HOeNlFhsKcTbxxhxPbxWBd+uoZopQqeBkAESyUwny57iVkIkBaNBzbe6TPgjzd6lZGEQU312F45y7dAMmpnq6hHJwEWoGopmMbHo8wfffIXFuh3pR9ku33x0P9dsjbOm/BAyIVdJbKdGouS7/Pzo8SxeYwHfrhP6DoVsEkvxKVVb9Bfiq1zspmfnCI6PMdibwC4eIWtKinacRVv7UBSPD5PCP2g0pw/g1ouo8Syh76DoMdzqDM3pA2egJk53rlru9xq7LmPjhZv/1otYKBHGPgxOZ+oKOlg8Vr2Erekyw8kmuwdP8vjcOopOAhSI65JC3F1lYlOVGTZ9wGD5bNVQo/eqM1pEK+0ZT0et3Hz5Ju558l2e3TeGH4QEnkut2mBDxsPDRG1J/ECiCrAMFdeLKGmFXIJ/8/OXsXEkz8v7J1ZVIMOFNOV6A8+xKQaJSKep7zDnqifQ4nnW9GhMv/scH19j8sjEIPOdBKrw6U2qOKFGGErcVpUUNcTYuzz3Vw9/4Elz5TD07eow33kviSpgXSFNpQ1PVndx7cc/y8ZNa2lM7ef4ff/5h/JN5stNTFPjwq2D1FsOEmjZLrddfQ4bR/LsffJe5vc+RLveolhR6O+ps2FwdfW2MinHNMkN2RGu1xcZSebpC+dwnXkUYwizZw1OeQK/XUGLZYkPbOXY+CxvNhI0fIMhq7ZKEfdos6ebLPqtFlXX5PHiZrakyqzPSBRVI0TBzI0CIapucWAeFqptdF3F1FQcP2Ch2mbfwZPs/IAK1KnN4TYXMTNDCEWJfKl9j8CzGdBafGKDz5PV0TNc7MzcMMnHipSqLWJBQD1IENMlhWyCwF34mRfF+zAp/APEMiGt9M6D+K0KXrNER6ggBEIozL5ydyQnsetTZzhXLbTBcouETZVkIsGG7RcR6/3bDcnmy03UwGZNos5YPb6kFHoKcK6qGrYwOOYMUwnqbEmV2JJa4HA1zayygVfmdUqdOL1Gc5WJTWHkTPObD6qGumYqZyFmbRzJr2q/PLX3ON98/ED0uRWFtUMZ8CVNT2WqmaAv4ZPQQ9wggpNapk4mYZGIGfz2r17DNRetB86O++9PG3ym5zB0KuS1RpfV67eqFN++j8Btc+vOHOeNVlloBqSDInO9N3P/ew4nZ1o0qw0EKt8/uR5r0uPW8pP82llOmsszom9+/0nuOZKmaJuYukqiGTCQTzEx73K01Uvl/QU6++5nOPHD+Sb9+SSqolCstCnk4rQ7PrlUjP58km/e9yx3ff99SvY22p6CpXj0mja3rJnlpvVqF5VzelJ+vLiVbfk3GfSmQUoUI4GZHsRtLiyd7n18u8bDbzV4bPZc6q5KzTORwLBV6yriSiG6YngCQdZwKLopKn6ctW4bLZmPPB+kf6oyOklEPAtZeq/osKJZqbO6+5UOPEp97DX85iJ+u4qZG2UuGKDUcCkoDmv7DL7wmRv4ZO9VZ0Vu3Xnr+fzpva+y0EwQ03w+valEgZm/E2z6pyU+TAp/z3GKkDaBDPyu+TsyACnQ80MI1ehuBMvQ1PWFHOuzLs9OJAhC0Fotbrtmzd8YNbGyd58VNTR3kdD3KRhN5tw0XWFnEcmfh4HggamNBFIQN2BNrMb+xTRVLxZJ4EmoGQlGVpjYwJnmNx/EnzjdTKVUbaOpCjMLja5v8caRPI+/cpRvPnYA3w/xw0hbaKbYoCepE4SCRVul3FHJmx6XD1SYkaMEqORSMe689fxuQoDVuPljU2V0TeG2j6zh4lYDp1qM7kc3QmpHnkeLZfH0MmtyefqC6LQ84jzA6IYCJ5Ud/PWrPqaukbV8qh2Nh070cOXb+9iy8cxhf6P3Kp6sloilXSzp4gcwOVcj8CWuF/BnP3gDz2mj2mv41LYOuze2P3A289bhGWzHo1huMbNQpy8b599+4XIA/vqJI3S8aD4USW6rdALBoxMDbMs2GJjaz7yy64ykfKzZYazv5xncaERV0nN/jFOfw63NReuTaKj86PQIqAojyQ5hQ1D3YwhHdNFqWxIlYqpHLYiTVWzqfpy4Idh6+SfYsHMXoe/itcoIAcnh82hM7Sc3djdZbQM116DlB6BoFPIJLr3oPFKlUxVo6LvIwKO0/0EII0VWwoDHDsET5fPw1DTJRpwvnrOFL+y6hsLSfT/9WXj/8BiO64KiIgMbrzaHG5smf+7un+kqAT5MCn+vYZfGmXvlG/idZlcnHwDNBL8DQkWPZdCsdHcjWG47jBVbjFWHKMQ6xLSQMD7I+2Mlnt03hqGrZ8hErOzhL8tKVxo2uqpy83bBTT3v83hxM6FQUQkJl7VAJUgp8Z0Wmh7Qo7couSmer/eDlKgEaELio2IoAf/8ozFuv/5MY/nlWNk2mfP7KVY79MRyXL1pLXfe2tNtEblegAwlf/y911fJI9/79EGCUBK3NBptD88PCaXPTDmCpI7EG9i+iq7Cb35+F/lt160QiDsTvnjH9TsoVlrc++RBPD/godemOJT4CBv8N9kULy5VCgKEIKKGePh2Da9VZqIcUBMbULQhFL9Gu3mEUA6T1m0UYZDWbeYcncOvPoJxpHJG62e+3KTt+AzlTDRNY6bcoeP62K6HDCWmrjGQSTM9UeLBw3HO6XEY0EpnnF6XT/nZZIzBnhQL1RaGrnYrK9uHmC4JO2CpEicQWKqPI5LUyFF84x6yH1m/KikfmSxRrtl889mTPLovSqgfu/jzkSmS74KqglCpBhE0dzDuIySsSbYZb0jOT09zcXaaXZlZQHDL8BRPNS+l4gticcnnPpLhgiuvojG1f1Ur0WksUH73UQY0jy9uz/D9o3nankq2J82v3XEZAMeUXWQ/sp7+cJzZV+7Gd+RSQgCEYMbNsae4GT2ZYXRkDaVqe4mbUT4jIdz71Lv80beeYbLUQSAZMJtoquCJyg7OHdGJfQAT+mcpPkwKf49RfPt+OuXJpc03JNqBAwij9o1QFISqn4EmKlz8efY/9ghtx6c/3sHK9GNke3n3+Dy/89VnEYJVg9qVPfxZN8fXDl1I3TOotxxcL+Avngu5Pp9md98hpuw0r1bWkjfadKwRfHTq9RqKkPSkdPAtTN8jCAWKAEONDODDJWOc9vHnsEuX06lMdzVvlolLsLpt8tCJDJ2wh1Q6uyRRHLWI3jo8y5/94A1MXetWDcssZc8PMTSFUIJlqtgdnyCI3n040SZveSixFAtuEq9wKanSi/Qejr77c6/mmM1cS2rNBV1p6uNTZR57+RiJmEG7WebEtMNRdDRxCTnd5o6h/VzTN77kwyAJ3RZC0XhmfoRHp0Yoe0navkJc7yWldvDVOFVHkg07VF2dmBbQ8wGtH734Oqo9z2wrgnz2JnoR2Qx33HAu33v6PXqzccoNm0DPUGu2mStVGBw8E0RwOjorETO6rbf+fJJkIkHTz6Fg0wlAReISJ24o3b75aLKzqmoq12zy6RibRnpOzXe+cgtrbuphYs//JAxD3Po8WbFITHEptxRyMcm020srCHinNsSJVg9Vz+Ka3hN8LHeIj3zkAhrqQIQcsisc/e79BG4bLZ5Fi+XwWovMvfINQreNUDSujJXZtGsd5Y7Kzhuv4GgLfvP3H+0CEe64NM35YYBmJogEeqPnqOLGsQOd/pSJoghycZgs1pkcO74qKRyfKvMX33+JTrOGiokQUHLjrI3XaAYWTXWQwD3+4UzhH/oD/KyEXRqn8v7TgERRIlvLboQeKBqKEcetz6PHM6s2gsKuT7Hu5DzWuzNUHZ1sY5GZuqBpS3KpGMOFdPdBTosmpdcfIWcarC/kWJxwKVdrtGQSIRQSMZ1as8Oe4hZSmo0qJIFUWHQTNF0fL/ARoYJuQrUDSeFj+zqqiJKYGygIJaoqEnpIRpY5dt9vYRePQRgiVHUVcQlOtU2MjM9QNkGlzaqh8ny5SRBGRKvT5ZFzKYtQhlTqNq4XeURf2rvIVMvC0HRCfMrVFvFclqyodecXz5W38tcH0pSdOYT6BIVsgn/7hcsZ6kvT6rjkYgrHSjYhaoTrF5Fb3EPz29mSqjKctKP7omqU9I08NtNPxw9w/MgNzfEgpamoegzFSlP2PaxkyI35A6wvJM4YigJngXxW+eVPnsdHLt7EYy9HPItqs4OUIITBc87V3HH7NWdsUMuzkWKpQi4uqLQlCcvsVos3X76Je58+iBkThI6HKTpYGnxiU50BbR4h4oS+y40bYPsv7+Sl4w53P/w2m0Z6zpzv7Iw8MOZe/caSg1mDm/qPsae4halWglqgEjchr7ZxQpU9xS1kTR9dlfSfeJXRdIBIGOjxYTqVSbzmIig6QXuSMPCQvgOKCkJhup2g7NQY6E2jJ/Lcfc9qpNhdT8/yS2v7OT8dGfwQRi2tnNYipktqngGVWeYXSqgypLPvTyimZruV2uHX91AvL5BWGlSFRiSNIqi6JsmYT1osfjhT4MOk8PcWxbfvx63PI0OJDCJJ55lOmnKYJa/UGLJqBE4Toajktn56FdrELo1TH3uVnX153lzoYb4dIGWdpJVluJDuPsjvHp/nd7/5Fn5rBE3VuGTIZmefjUqI6wUk4xqOGxCGkTh00zcJEYQy0phZFjhTpMD2BS03pBWYxBSPq/LjvNvop+rFIISs3uGTQ2P0hidpz3iAiAxWpKT83uPkz7mhWzFELQ3Bmv6+6LMactVQ+YMgqMvyyP/Pt1/F8yMzn2xc46LeEpcOxXnweJb5lomlenz+ij6Gkx3G3TZFsY7vH85QdVUUIhvNhWqbP/vBPv6Pz2zFEh7zZQc/iBKzAEwNXF/gKGma5giaOYNv1zGzIyyUfdouxBSfQIIpXDypk8xkcITFr332Uob6UmRFjYmn3mTfRIRkWdn6WZ6trIR8Jv0Zrjr/ZjIjeS45d5gDx+dBRk5tQsBLh+u8dlJyTe/qtbRxJM/t54V865lpxkuCmC75hWvXdeW0H3vlGJ4fkEsn+Mwl67goN99lcgsRR08PMrHnfyIDHy2eYde62/muqTM2VSSfUHECpZtkIDqUCCGYeuaP0RJ5bh1W2dUu8439aV5dSNCSKie9An1albJv8ZcnL0BRNcxJl1uGTrJ7a0DoO+jJXtzaLG5tBqFoSy3UiGr37Pwoj89twA400qU0V/dWutXQXLnBTKmO4wV8rb2BT/ZVuTq/VGkjGIo1+PjoNHtKaSZKNpYq+dS2DsOJzir4qjLxBJa6Bjcw6NFbzLsp5JI96rmpIrM1iVf4KLFOmo387MaHSeHvIezSOLVjL4KioKg6oe/ybHGUPQtbsYNl0s9hrh2YJnRaLL77KPlzruueEL/75AHufmMNjjRRFbh82OGcxBTfnLmU8dkqhVycSr1D03bJxGNIBaYbKpOHU7w0abAubVMup2jaHqoQKApRpSIEhoBOEPmnGZpAVdVIdM4XmMLjo/lJrhucZijeYrpusLcyRDMw2dHT4IL0FCgWYeADAhm4KHoc6XWwS2PdpPCjeAc/SvgtZuqMFDIUcnGazRaPnOznN9a9xG+M+ktM2g4X5FKEfoRqmSvXaHn9BGGU8KQX9Z/nihVKr3+d6zNwX3kQSeSspooA35eAQiab5aJP/zv6lvrXUoa0aosgh2j4BgoSJ9RQFYkrTRIxo9uauvepd/naoQtX+Bv4fOEzN3Tv4/JsZSSZp18pI8Qpu9GBniSqIoiZGqqioijQaLscnVxcNSxfXk+XBo8zeIFBXfaQFouMBoc5eGAXdz+8HynptoH2vjfDF75yC/nzRjl0+CgTxw9jju9l0GpEXtm+ywtPPUG9soXFlmR6QZIzff7lzSOrWi8Lyjre76whJ13WFxKE9RYHq2sIpCQIJJ4UTPtpFAUyOvTFHKptwaNTI2wyX2M42UGLpRGagXRayKVTPorKbCfNntI2UCSDMY9OLMuz+8ZQFYXpYp2ZUh0/iGxPCR32LJzDucM6fc5hQBArbOK61CwbtZMsOiY98YANfRn0eN+qSm3QqPCpbQUeOBwjDEL6zQZ9MZ9ykOW5+SEenVaJHViksOdP+eJN2/ilL376x7kN/JOJD5PC30O4jQVkGGBmR3DKE8y0Y+wpbiEECkaDBTfO/bPnkosLdqWnCZxTBuLHp8rc8/ICUiiRXLUX461ZFbM/QdvxWWw6zCzUScVNUnGTnlyat+Yb+FIigQXbQGpJvnjL+ex59Rgt28Nvh4RhiBcqROLQUaUgYAWhTaAaMd5rDnGdnEJRDY60+nituhbf7OVoWaUhD3DTRpv23CGQMNNOUPFT5C2Tzb1nR/2cbdOHDxZ+e+vwLI1mi8GsQUwLMNMmxxdUyo7BjnS5CyF96/lHqL3wGlnNJRVMoIVrCWQCEChCEIYS2/HoOB67N8MG7SWenlvDC4trafgWrhTk4gq/dsdlbD9vB3AeUkr+6jsP8/BEL+1Qxw6MpcojGtyaqux+j+XhrxbLsqEny/RCg/tmB9gVnEeBU7OVN5+9n4W5Jn0piwuvua2bMDaP9qBrKp4v0a1I20lTFTaP9qxaS3YpEp/z2jXWF9YhFBcZJnBqVWZn5yjXGmRjCq1mQG82xcR8leefeIR39+/n9dkYQWgQUy7lpsIxrukbY6qu8vBYLzEqbE5BLUiiiYCh2rPYpY+u4DPsp149F92vcsvINKqeoOkbaKpCEISEQICKpfj0mTYKkDFD5u0YlSDJUNDAa5VRjARCW6oshcJU0+LN2iANR2Uk7RLLjpBO5ZiYr3LjpRvZ89rxCGZsaAxmNVJuh6KTpOYnKSga0+0EzWKMpLvIUKzOUEIFCU6l2fUfWU68qhHn2v4JNloq88UKXii4Z/YCgtCh45tRWzBQaNkt7n7wDdYGB7jmzp89zbYPk8LfQywjcAKvg1A0Kn4qwnGbTcpOjLKbwJUqXz9xLrcPKdy8Newu5OXWS39fL15jjiQ1pjtxnp7qI2ZU2D6Up+rFcJfaK2OzVbyQSBQN0DSdxVZIdXGRmKkTBCG+J6n7UekdiUFECcT3g1WcBTvQCchGXsXVFnuKm1GtDGvWraNYqvDYzBq2949RSPbw5FiqK3eQjMfwJzLcsfnUNfibGOqcLvz2zfue5c/ve5NSNaBcbTGQmMO04pHtoumw7JT2bGndKakFNeCmviNcnDnJI51zCInE7jQREFddhL1Ip9xmyGrwpXUHScU0npgewpUKcULqE28BEZqq0XsVjy8cJaTMuliZkpsgQOWTg0dYU4hx4ac+uZRAVg9/5xYbFOs+Hdfnd776LKVqizuu38Hzixv4+okradkOiZjJl8/bwB1L3/Wai9bzqY9t5f7nDtFoOaiqwqc+tm1VlbAMIPCXJB1avouRLhDYdabtBA8/uZ+5UsgsoCtVsskKqmbw53tmWWj3IYhOxyGwp7iJLclIlM4ONQpmxAGJWwbzbYOFRojbWGCmk+7yGdavHaFYSvBEOc9125MEchG5hAISSzob2WwaO5Yla4WU5+dJmBrDw0OYmoFXn0dRFPT8GrzaHE/PDvP4/EZaIkMt0NGCPFtS/d1K8rLzRkknLb71+H5ihs5AVmN6wsRSPHrikmfG1vD43EYcYpj0s3twjJs2tPFaJaTnQuiT23rLKtXeuVe+QZ8zSV9O4XCwHWdaw5Q2ISam4uNKDUvxsUODE++9wflHX1oFnPhZiA+Twk8oVvIChixIrbuE8sEnCH2HnG4TNwTlsIeSpxAgMAhQCHh8fhOXXmh2T5DLrZeGNMjkDMozU6CodKROTm2jdYro+ggzlTYxU6dlu8u8H2JG1NIJQ8GL+46Qy6YYyqcYby4i0JesKMUSGFViaGD7AJK4qUYieeikzvk4hDbBvMGa0UGkb5OLCyYbKSqOwYHqeu6ZGUVXfIbiHWqBxte++9wZXrfLm/7xqTIv759YlRxOl8HY++S9/MX3DoLnMmgqzDkpZlomg2GLTw2PM2RWAJjppFZVXbUgwZ7iZj4//DbvtNZhewJLdAgRWEpAVqnitxpEM50MrxZ7SWguw4ZDPUzyrWfGueziA2w/7zwmx47TancoxEIIFHqNFkU3xXBactOtt61SPO3PRzaR08U6s4sNPD/E1FU0ReHuh9+hNxsJ5LmBSiaToW17q4btAP/uow7n1A9xsqqyNhvw8Y+eSggrSYBWzzp8p4nfLOE3SzxbWs9D85uZsUOCJcnwIICFmkdPCrQwQBBZWy66SdbEytSDWFfELqZD3Y9jCo+aq6IrPn0pBSPVx/zMaqRTRneYWKxSP3kIIdcSSiVSTl2ahVy+cx1HJhaZa7ZQFYXL+heYL7dou2UGrTah7yBUncX4DvaUCrgoFPp6Casu5abDsakyuZTFOet7+f2/fnlJo0rSsm0mXYkZS3PzwHH8Tp09xS2gCApGi2pH4fH5TVywuUEhHQ2hM5uuonL4aUoHHurCgwcuv5Opp/4QYcbpdXxiGnQcDUVKHKmhCkkn1IgpHjmtuaoN+rMSHyaFn0CslA9YFiS7dmAKv12LEBxmmRvz73H/3A7cMIGuBPTHHXpiMN+OMTMz1cVKr2y9TFdcmq5GKDQajkLLS9BjdCh7DYSisnVtD1PzdWbLTRQBgR/1+lOmBCGxm1Wmyj6upyERBEh0EaIQgFBJaBE5zA8kUqqoBBjCwZ54m76UQky7kNmZaRLBAtWOgqEoPF7azsvHfbxgSXpaWKxNtZivVTiy9wmGrI9022Dz5SZvH57lsVeOrdI7+ljPiVXY9dzW6zj6xut0/GH6DCeC3GoeJT/Dp9ee5GN90/htDaS/dNKN2LOKEGT1DvOdOJqQ3L52mofHeyNT+KUKYrndBFB2LexApWA0UVWDfExltg7Ts3NsP+88cnobS/FphGkypkfNhpjus/3q6Hx/uhTFnbeezx99dy8d18fUVUYHMkts5SpHJxeZLTXouD5BKFEVgWVo3WH78qZ/UUFy2bo8Xru+Cs66kgQY+k5EtFNUZuw0exa20QnUFQleoCohoRQEYUBK9RHCiAAFQlD1YyRUb0nVtMHuvsN8d/pcJt00ADnLZyZzDTOdNDMLs2hLaqu5OMwvlIip0J9LkDJ8bE/FQ+3alb7x7hif/uh6zt+whZdeeIHH9gc84ObRxXpu6B/js+tO4rcrzHUylDqjeJgszja71+POW89n82gPv//XL3eRRycnpqg2mmzvLXPlSJMbP3YJB+1RwuNjjPQmIPTQm4tMl2xm5xcYHLHIbruO6mny8sU37iExegG+XUO2SuSZ4IZ8mz3FrZhagO1rGIqPpQTcVDjCcLxFbKkNapfGaU4fQEpIjfx0q6l+mBR+zLFSPmA4ZzA9McXDY31szbXIuyeBiBXaazT5RP+7PFK5GBG49KVUqh2DuAEZpbEKK73cenl93wH+5J4X0RSXlKEx21CZ71gIAoZjbcolhXo7OrYJIdDVkN6Y5Np1LZ4ZTzDd1FHVZZVLAIEnBRqS4biNg0FWdVEFpPNp6uVFTDVkoDfHgDbPTT3v8fDEAPOBQVxXOCdb4bHjFqCiIAkRlGwNXZjEhc3Mvgf5weFnmIp/hBfHDSoNm1K1TT4TY8toL6Vqm6/f/zrJDS+tknUo7X+QtNSJ6aPUPIu03on09DWbLfk2ih4jObIWpzpDj+cTU/yuk1fNi9BSPabLRYNzrBdHKLsmedNjyCwDAqFqSCHIGx1iavS7WcWh3gywVOhNRO2zLZvW8okNizw81sd828BSPG7dUGXT2gHuv+evmGz0sq7HYJce+Rnfevt/ozd7Db/z1WfRFIWBfKrbCknGDJpLVVzc0mh3fPzA7Wo0/SjnvJUkwKlWjNlylrzlUPEtOqFOXPXOcJkWSDzXZTKIE4QKIQIho4PATYUoQc500hB6qNKnL+4z0N+HEyj8xYsdvvPmg/hBiOP4tBWPZtNDlSFXrvVACDImmIpDNUgShiGa9AlaJR7cM0dneIZ7jm+g6SW6xMh7ps4FofDZtSeYa8VoeRqIgIQp6PiRXpXnh5Sq7W51MltcZLLUwZMGT03382aph6rzNjd97hKSiSKVNqREtK5MxSent0mOXkFq+DwW9z/UvZ6KZnFiqkx54g3SQZIhqwZSck3Pcbb3eXiDV7Fw5GW0oN31qz7YGmXm7QmMA5OEh79PIZwAQE/2MHz1r/3Uqql+mBR+zLGytxx0amSXLC1LTUkeybOljexZ2Eon0LBUj51rdY7OuMw2BHEdblkzw9q8OAMrvXEkz1uHe+koSXrVKjGlQSwRMNfJoGsKYRgyXbIJVYO4pZNPGQStNr90ziSXr9PZPyMYDzNLLl0qK43pA1Tqnk6P5XDFUI299Y20HImh+Hxya4c12QAZ5rmm7zib4vO0YxvoSYS8PmURhAJdJSITLUXdUdiWq/LtiXOou4KqU6Ink6TQm6FYblFrdLAdj95snPGpOguNkHV9p7whOnad0TR8fO0cD53IU+zEiSkeu/sOY+bW8d78Ajm7zZp8D2uUCh/35tlTOodSy8ZUXHb3jzGUdHBrDYYsjyFr5ZWUoFrgNhmyXHYXjvF4cTPznTgx1WX30CTK228zHU4w/NFf4QufuYFtz95PserSEw84/4ob+J17xnhk7wYCKVAVuHpNnN/Yuh+3scA1F11Cqdo6Y6juNRfRVYnvSzpugKZILEOBdglY/yPtS2c6aSbyn+DVV1/n5Zk0tjuCpUsuzU5iKR5uqKKJEE9GEEspIW14BKGCREEVEgVJXPX40pp32JWeWpK93krVM6n7FoO6TToVx/ZVjs3Moesq6wZzlKptHM/nl2/czPsvHeWliRwNX6fjQohOEEp0fPKWR0wXzDVNvnVsHTXf6F5zhai19dT8WpAhT5U24EsFKaHRCZYOKwp3PfgWqiJwXB8/kBRLDbwl0ySJoOzofO3dITZ/ZIY7bz2fr9//OieKVRTg6t5J+plm4c3v4dt1kBKnPgcIHj+i8vjcduxAI6ZuYPfQBFuSiyzaKv0Zleuv+xjvJODovmd4rTLK3upaFt0E9sEp4ppPXt/C7gGda/snGC+5PPPtB+g9GHDlx67+qTPo+TAp/JhjJfwyF9epeiamcMgbHWZqafYUNyOFoM9sUvctxhsJfuOTg7SPP0dGaZxVBtsujfPdJw/wjefmqLahRoahlI+QDXriPpdmxnm2uAYnFJhKyOhAnoF8irGTLqYKx6fLjDeGWe2yfurfJdAKY3ziwvVcd8lGrov3QrvE+PN/ga6ETFSXMPdmglHVBXEU3exl0GohRBbbl6tezwsFh9uDJEyFrCUpd6DedumTEkNXIw9kx6dle2iaTtlP8sq4RzyWiuCVqQzZbddxvfoo6+Uhyp5FIRvjSLOX//M5C9tfi4XDTYXDXFMoct2Q4GM33MyJg29hFl9n0KwivRChm9HZOfCjbykUZuw05UacvC4YTna4ZnCGLalFym6M3qRg0KjgVD1mXvwqUsDIVb/CeY0Spf0PIgOfJ5/by6P7NkdeDWqAG6o8M55g0FrHzzUtMkSV3faCZHp2juHBAV594y3+8skJ7E60SWYsH0V6WKG/imC10r5UKCrVnit57f0FDs7N89grx6g0OixU1pJLqKwdClhYrPN6dYRL8xO8XlmzlHSW2fEqSbXFrJeMzulCktfaaLqOFUsw00kvzWIkfWaThm8yZ8fobbSpdFQA+rIJFEUQtzQWay0qXoy99Y1UnTotT8GTUcKxDAU1DCg7BnNtCKSCJZxVa00u/dMOdB6Z30LTM7rHkkAKpB+iqlBt2Ph+iARqrc4pNYvuK0DD1/nde0/wm18a5rodGe59ehrfl7y4MELbN7im5wjyvcdRjDiB22KmFefxuStB0SloDWqewXdPbsbSNhCGgpih8ORfv8+7h5rUnUupeRYx1cUNI+5Ox1dwVZXH5zdSdgyeKq6L+DqHjtH76AT/7svXc8cPkXr5pxYfJoUfc5w+A9B0i+szb9LnneCA17vU/26iCEFvLs2iNChsvZILrr38rI5pe5+8l5dfeI7vHS2gqzCUsJipw0QF8obK9ZljXNqzAEienF+PqQv6kv1MF+sIzSS+8RqKzYCaV2RldbAyNEUQs3SeOdjkqXffIhk3uWDrAPsnd6zC3H/y4h7qY6/jNRdxa3OcH8+yOdXLwVpu1eu5Umfe1lijeyQ1F11ouEt2kemESbluU67bQOSs9Y2jm2jYLjHVpy+e5heuXcfV625leiGBtvhdhvsLHK1nuH88hRK0yehQcQwemt/O1mwD3clRfulBUv4MQ/EWQrEI3RbSc5hx81SDNDmtzolwMz8YK2B7GnE95JODh7mmb5whq85wcmkTEwKhmYSezcKb3yfRv5XK4adRjDh6PM/kjIofhOiqih2cIv59++gIb921nztvFXys5wThG/dQcNuM70/wzbc3oikqIymfybpGqS3QhEZPTOH9xTgjS7ODwq5PUVLXc/SNp3jrvTFefrFGw3+CmhejJ5ekN5Ngvtyk6QDxQYYTvUwW61z7icu4YOowf/BUm7TukNI9Gq7GrB0HAlQlSthlP8GA3qEvrTG3mF0xi4EBs8Gsk2G6bJNJpynkE9iOT73lcHKuShhKvvX4fhqtEE9aCE2gS7DdkFYnAAwUIdEUSRCESJRII0uuUN8VEtMyqbTD7gxi+TARIpBBRDQUS78iEChCLl3jU6tXIBCKzp/9YB+h28YSLr4imeukeGR2A2+W+/jk4BHO6ZcUa3EWO2ZXr0kRMczAZcqz6BVtBpMuFWWQR99aJK1qxBWHihTYgUEoJZYa4kkFU/GpeyZ75tdT9y1UQhQhKDdc/vTeV84AVfxTjg+Twk8glmcAk2PH6ez7EwZNH0XfQoEmMdWnHsTJ6iH1IE4iEZG4Yr35M4ZXyxLIlc4QNVdnKN6mV5/HMTPMd2K4ocaTCxt5cmEThiqRQsPxJQdPlmnaPgYu/+N7RfoTLkGYjaRizpIXIi1+j47jo6oKizWbseky64fybFifpVRtsWdxgG0nXmc4kaUo1lCstsl1bAatxmlJISKBgWSyrrEu7ZFJWVRtWKy16cnE+eItOynkkvzZD94ACdVmB6Hq+IqBjMe7/WzPdWhWL0IAoVCodhRSism8axIEkf7S10+cR5MUtgeWGOHm4UmuHZgEofDswrouQVBVJBU3hheqCAENH747fR7b+0OGk22kDPAapUg103dASrzGAgvvPNjt9U81DaRqIZB0/KgpshxuAPOLze6MZNDsoBoJFuYlbRfyCUk7iK6MSshI3EbTVR6dGGJLqsxoY4GH32ny9fv3UiraVDojZKwwMvbpBNTqbXqzCQxNwfUCOq5PK4BUKs3IyCildx5AUUYZSoSEbhupmpSIk9fbNAODQEaCdtddtpVrv3gnbzxzH7HxBWq+RUbroCowGG/zq7eewxVXXsFbh2f4sx/s4+RsFYD+fALptWm1HaQEUw3pBDpCgKoqhEGIJkIGLJuibeJLlR7ToeSYBFJBVRX6sxaXby/wgxfHVtimrlw5ootiEoCuqZEPd8cj6FYMYBoqw4UU45NzBG6bXs1hzs2jIJECPKnwV5PnISYFqghJqC5eqFBu+eRiknqYQigaAwMF0tksC3NtHK9OxTepCQMpJQECVUhcDDRV4EgDN1Co+2ZX90sPAxCSeqO9ygP7n3p8mBR+QrFxJE+vd5zxAxXMdIQYGdDG2V04xhOVHRQdhVhQ4edv2dGFaa7E8B88cIBvPLqfMAgYSCk0yjDXjqFaHRYdC02RZCzJdDOGQLAu3kF6Ej8UGKogrjh0fIWFjkXRtpbGwMoZn7PraByGWKaBqam0HQ/HkwhFoCiCfFJnbLbBnhMpmnKQw+UYgVRQpEuto6EsqawujzdVBRSh4gWSk80UA71x/l+fPI9dWwe73+/l/RMEYUgyZhJKiFtG1Gs3TBYWKui6Sk/KZHrBRIYBo4kWNRJU/DiGEiydICXv1fvot5qkNIeaF+OBqXVsSVcIXYU9xS1IodBvNZmyMzR9nZiuYOrguh4VR+VYu5dLdt/IsZPzHHr5AXJqgyErUqyVQHPibYSq8vC7Lo9ND2D7oCmSpfnwqqg1bTTpMFdq0pOahzAkI5N44RaOViLJcU8KVAJUOiRxWXDS1MIU002Lux9+hzDwSWkOi+g0PYWspaGLENeP3NUyKYvFapuFxQq5VIxfuu1ShpM2Y0qDuK5Q6Sikheiyri1To1dp0tD6iSfT/OJnbyTWm+fia2/nE2//Dx4e76MUJLC0gNs2lLjj+h3Eepf5IoL/9rXncP3IwQzfQRWCAEEnUJBSYmgKmq4iVQU/UEj1ZPBbAYsNF80yWZsWXLh1iMsu3MYFWwdpTh3g6dePUHaMVddOISAkaltJKdHUSOpjsDfFRy9Yy8MvHqFUbaMqgnWDOZrNFpZsINWQmp/AkwpiKU03PINWaC2t74iQFld9/FAw19IwTI1ey8QJFBrNNvPlBhC1vfylU5OKxDJ0XKmRiJsYuo5baiyt86iycaSKTogZ1tGLrwNr/m6bxj+S+DAp/ARj5fAQoSADj2uHZti1uZeKG+9q3yxDWE9JW8NI+zUatWH6jCaq1BlMKkw3NEpuAj8UmKpkpmngLw3hxmoWmgK+VLFkQOArKIogJiRtX6BIiapAENJFH1mGSjIesVIXa3ZURghARku/VlkkaVeZqBtUHJP7qsOEKKiEDMcaVLwYjcBg2RW5GxIUVSGhK+RSMWKmzu7LN6/iKLheQMIysDseiogYvLqm0Gy5AGR1m8bCIiKMpCjMRJqCGWeq1CaUAlVAVmtT9hO4gcaEl1hC2MBT0/1ckF/A1TKsHS6gCEmu6rIw00YKFVXXEaGC8EMKF97B84s9/PmTFSqlqzGDGp8YeD/yGQ4EXnOBt2sDfG9iACEc+uMemt7HZG3pZBvKpQosxPcDpNshI0vIIEDRLebtOG6odkl0IAhQmWqnSWkOGb2DKw2e2z9HpdFhfSFBpS3QRYgXKBD6JHRBI4zabmnN5foNJ9mcqtCXUriwpxcjtZO1ecEta2Z45OQA850EMdXn6uE6YzWDehAjm0vw5dsuWuV78cXP3cw5z97PQiOMXmsFwxqgNxvH8XykBEsXtD2BEIJLBtu8v2hS74AQKiP9aZptl3LNpuYo9OQS3HaBx0j71WhOlhMUej5PYeRcbGstd57zPb5+cIiqqwOgE5A1OtGmjEbbV5EhZBMK/+LTF3HH9Tv4wu6dfPfJd3n6jTG8IEAVPretnUI1EvzlgRyejBKKIgNClhNCtC5boYki4PrCUTanG+S1Fsc6gzw2s5aibxH6JgJ1BW4LDF3lt37tRnqzcQxd5dWXX+WPH7XRlgbmyyoAlhry6Y1FYuOHsUsX/1RAVT9MCj/BWJY2iFioVYSioFpp1uQUBtszCCG6J8TFWpt6y8Fxfb4273HzmjRxU6PuJ0jTQg0dhhIBhqZytCJoB6uHxr5U0VUFRQocL0SGgrgSuZGpSEwtIJtNIVFxPT+SajB1cimLmy/fxLf2HGC+3MJxbJABST1A99pMOjo1zySQdEv+AIUpO909NXFaBRJIkH5APmOxeU1PV/zurcMzqzyZz1nfy/tjJeKWQaPtYBka8ZhOrzSpVxew1BC51PMSbgPLSmHqKrm4Rp5ipEXkSyp+DE1Eg0pCOOBs46Yrbif3bI2aG21uNOroWgcpJe2Oh5SCfCZO1Yvxtb98gVrTASkgTPKNyQuoeRaX5KY40uzlvtlzmXeSaCIklG0GkyUW1TROaBAqgiCMroSqCK4bmmcoVmemk+eBE5vZVx6k6RuoIpqpaDIkQOBJlUZgsTGxyDf2p2i+/To1P04oQ9bmCiTbVWqOoOZq9ObT/PINF7O9X6Gz708YTnS6CKVlLkPh4s9zI/ewJVVmsSXIWy6jGZ9ZN0e45ka2XnrTGe2Nwq5PcfVpTnkrw9BVkjGDjuvj+hFiSkrJRN3AUALSpkSPJfAch6wJn791C5dcuJ2sqBG+9nvImOx+zpkXv0anNE5q7UURoit/P999L8WBSh4hBCkz5Jbhk2wfkBxr9RO4Dbblba4+/zYgqrz/w5c/xudu2MF8ubn0Hs8z2XBJmln8sIMTqkvJYVnocDktCFqBwUuL68np77Ojt8yQWWaTOcnRZi/fmj6fihfnVN0MjhfiNUtcsCFCgB3PxQHQlRATH1eqBFLhM5sXuGUbOLX2T43k9odJ4ScchV2nLCob0weoHnp6lYfxMZmh0rCpt6JBZ9xUaNmwr5TnxvUtXpqMs+BopDIZLh4S3Pd2Z6lds3IjXjqBhrB+JEtxsUWzLWl6ET5cERIhTG6+chvXX7KhK0T31uFZAC7YOsjJuSr3Pfs+gQxRBVzau8AnevbxZnWI++d24IUmgrCbGE4lhFPY+OhPIvJjEVBv2EzOlkjE47hecIb94/tjJb7yxSsoVdssVFr05RJcsHWQl158ibsfmqfuWWTNAATUHJVMQnL7Ndt47+g01VIDSw04N73Ae/UCIQIVGEi4CKtAft1O7ry1vgoa+plrz+HtI3NU6h08P+r//NG9r9Nouyu+iYoXaHxn+nweLW5BIHDD6GToSo05J0VHegzEPbbny7zdGKXVaGAZCjeub3HHpg4Pv7WBv57aFUk5L98hGTXwTMVHQ9JnNGkHJpN2DlMNGI63CVsKi1UFRSQp9Pfz8+dmuHD7GkbXb2TjSJ7a2F7GD1TQ42dyGZbX2ejSBg8R92HLWTb7lXG6U97K6M8nGexN0XF8FEVQKpeptzxE6DGS9GmpfXhBwKcG3mdTosxaX1AIP4+ZGWR8BefCbUTM633P3Ec1eIr12y/i6i/9Fpc3FjgxU6PUkmSVOsaR/ZiZYTYobWQocGqVMzbalVIoe+dv542nXsIJFDbnbAIzT9VLMF5sdavi5Y0+pUY+1nuKW9iSLDFk1bv/21dbw2uVOCsH31LCoZfvZ/v0OKoRJ6Z/lLjm0/ZVlCUJmR7D5orhNl67/lMluf1hUvgJRzQrUOjPb2TjVZfQs+26VSezxlQZlQDH9UhYGl4AupB4Qci2fIc1sQWmmjEuuPwC3nrlKfxgGF34OHK5hw/Li1lRBDKA0f4Mm9es54HnDhFKGZ2uMwn2vjfNF3bv7Cp6Lp/aVUXBdjxGeiyU9hyONBivx6BHcGF2hseK26hjriBHrR4SqkIQyOXPIZFBdBr2/RC7VuQLH1mDoatn9WR+9cAkL++f7FYPIPnkRXl6Jg5Tdi0GerL4nSoVx2DXrbex/bzzOD5V5vDre1AmnsBrlvkfB2L4UiMflwRmD0Yi8oy+YueaM/SW/uje1/jmYweoNGzajiDwT7W+VrYPQFLzYiuS77JGlKDp69y2psWnh4/hbvkIR994gpwZqYeOFUO+PX3+qoQAp5JoKAUDZgNNCTGkjy8V+o02mp5kTbLFnEx3Wb2nO+r9KC7D6Rv8skf2shTH3/YUO2TVuePSNH+6Z5qFWocwCJGoKPEe/FScpCKYm52i13LZOHyqchm++l+daptKulIcexbOidjlJ13uVN/il774aS5YUvKwS+McH//BB36302du9z71Lnc/4lCpbaXmd1DDPFsHBgiqbbJtH9vxCMOwC2TtSB3X0TA1n7IbX8FsV7g4P8veylBE7lta4ooIyZkeZmaYRw/Bw2PzKCLaLjVC8labTwwcpoCNEJkzYOT/lOPDpPATjJUb70pntJWLJ1V6kY/lDvOdhUGabR9D08ikLJLUeHe6w6sLw3hallcfn0FrJZYGXPoZ76UpEIQSPwy589bzOTZZBiFQxRJmPW7Q6rjMl5sAq07t47NViuUWm4dTtNoqvh9Q9y1er65hU2KB7akiLy6u7erqnEoMS+2kbkKI/qmJgEAqCEXh9o1zXBq8jyJ2ndWT+ek3xjB1rVs9fO27z5Hc9iaDWolC0ERpJzAz/fSe93GqMtP1bx6yLqM5nUBK+Ofrfe55eQHbh2QisUqBNfrZOm7jOAcPTPPYy8eWUC0qYRgSnA2ORUToOz0EoImQjCnZnFxANeLs2HURa3v1JX5BlSPVYer+SrbcyipKktU6hIqJIhyu6T3B65VR6kGCbBhQ9UxyuRieF3R1f05fN6u4DEIlvemqD1x/Kx34TrcG/VGx/Ls9ZYlqb6FXU4hbAePNJBMLHeaqHgJJWoVCNoFQAvR4nuPTZWbH2mTX3U5s/D46tdlIn2phG1II+mM2VUfj289PctXV5VUzjpXfbfnznlJpPfUc3XzFJh57+VgkEb6mn1BEVqLHphbJxBS+8qk1HC+F3PfCCWp2lBhYQhTZvo4vReRlsiS7vjldpdfqUHZMECpCFeQ0h3MHdaaagkcnepFhh/VJm5KXJAgF/3xnjfMTNoVLfo7c5qt+ahICfJgUfmKxUu5iecNbFkCDiPkcaxxBefsuPrteQ9HjPHEiRiB9erL93HjhFvbsncDIaIz05picLXGslsFSfexg5W0LMUVAKAyyKYsvX7+OzYlF/vS1I2hqBAVESk7O1Fg7mKE/nzzDzrGQizM5X+P9k7UlueloI7tnagemGhJIBU2ES5tiQCBVVBGgaAYdL5LNsBQPJ9SQgCN1BJKYCFmTtwjc9ir7x+V2zjUXrefJ1493HddycTgxX2XR1li3ZmvERg199sU+y/ceadPqPEXCMrj9vJBLg8e7m90tF3+eq66+46wKrCs3xvfqBerVc+nNp1koh10ht79ZRMSphO6T1R16Yn5304r1ruu2CAv724gDbyFkuPTap9prKd3nFzafpD+j0ZtU6XXnyE167CltY75tkkpn+fjHzu1ueKevm40j+W6bqPj2/dSOvUj16HM0Tu4lt/U6kiPndSuClQJ6Z7MGPT1WChICvPns/SzaCRadBH4gKZhVfC1NROeKqqaIVKDgd6rIMMGjh+C+E9txDx7Dskyu2/lzXL95nsrLD2AHGhndoelGmH870M6Aca5stS5/j7M9R/c+eRAvCNk0kkdRBFtGezkmynxml8Y53vMEEx2+8e420rEMbTc6LLlSx1R8TMXjvXo/9zQHIy8TLWT3wAnOTc3xoruWQIZoUuH8njp9wQkONkZpeyH9VoCiqPRpDkU7joaDFs/81CUE+DAp/Fhj5YM1X1bO2i6558l3eWX/JPVqGc0tc1OPwbWDM3xmjcqVI0PMlSrsvPEKWvH1PPD6LGt6s0jfxtIkXqiiiwjnHhBB8DQREqATBOB0OnzjgRd5K1vGrvUylE5TbIEXRISiXVsGug/hylN7pd4BGa7SRIJooNwOFHQlRFcgo7Vo+SZeGI2Ww8BjIBfDaTXYlZ7m+dJaADQCfCKBtrbdQE1HbYA7rl+3qp0D8Mr+yRXVQwtL8bsnTzM9wPHpMvccXEAxEvSk48wv1vjLJ+bpPz9gXX+e0LMpvnEPG2/fycad67r34vhUeYkncn9XVynntNCcEvMzVeIoVFyD04fkZ49TDm2ZXI6rdmRZc91nKJx3XvcnlpPDpXqZ/geOMFtqEKyoErKWYGSgwEdv2ERs/L7IP1tdw7ZLLuXc7DoS6Tyj6zcyX27yvacPMpwzCDo1MnrAdMU9w2+4Mb4XoRoYqTx26QQzL34VLdHTtXI1M4M/VEtpZZxeUbzYuoh7l0ydROjihZKaZ6L4DpIEOiGDuRj9fT2MTc7xzSOD5E+0eXGun1ZgEtgOfsXmL+drvDCc56OFy/BCn+PNJa4Mgh7V666BlXF6C+z0A0xvNk61aaNralekr1RtkTIk53gvM5zocDAcwvYVMkaFqpEjkALP80hpHnFd8nZrPboSkhE2VT/GDyY3oWmCoWSAqbjYHpyoW4zPtYhzCEvkaekD5BMq8wslTLH6ULC83n6YLPw/pfgwKfyYYu+T93L0jSe7UhX6utvPaJeoisKz+8YIPBfDr2AHgseLm9mSrjDMNIVMwOCgiZLIM1NsoCpKV5W01NCRMoZUVDRNEPhRfxtFQcrINW00VqMTKLxV7kfFB7dKT6rA9KINAt46PMe9T73LHdfvWHVqlxISMRPb9fC8EKGwJC+wBM/TVAJfYikB5UBDEaAICRLKdY+CFbBjUPJm1aMTqIQoaEgsNcBUWfXwDFl1elMLTFdqVGWG68/vYc/rE5ycaRE3NT6xYZEBbREZRn3lWpjC9kFXfcbHK7iuSxhY7DmR4hc5hJ4ZgNBftdkttxsajTqqvYZPbeuwe2ObNVnBqFni5fI6Ahmd4A18+mIu853YKvbtqTj1d6ahIhSdFw63efNkxF4+Xd5g40ieX//kZv7Xd16iZOv4oUJS9+mzPL5w3YVccsM12KWL+daDL/Ld/TWc9wXJRIk7bx3mmuXZQdhmemKKtNKi5mooSoQ6muYAyZHzcGpzqxRTfbuODEP0eBYpwzP6+mfr0S/H6RXFWLHFvfsaSIj8PtoSpIEfqlR9i2AJtVyqexRr87SdgGK9B4jMgHQVQhmtjSCUtG2P52f7CMTCElU5mkyFbpvjR44wXx76oRvp2Vz7cqkYN1++iQefeoMT8xHj/uOjM/QFE+jxbfSEIXFdoePDQNZgquwiFIW4IbioUOP1+TyebzPrZgmkiheC4QZszNrEDYjLFiU/QztzDttjE9wqF3iqsZb5jiCWG+bzV/Rx9Q2/dMZ6O73dt3x9Pwjd9Y81PkwKf4dYPh3sffMgDz39PrY/SkyDm4cnOKd6P5ds/jwvvFfutksu2DrAYy8fw/M9Qj+GooAhDCp+giG/BqHP6+qnuO+u/bQ6Lp2Og9dq0FQNNE3FUgMkAidQu+zkQEZY+YEekzgecdNirgUfGXF5acJgodFCVVXWD+UIQ8kffXcvvdnEKtMb1wv43bue5+RsFSHo6s0stz0cb4nS70acgYxm0whMpIx0di7pb7Ctp0NvAjqeh6WFhFYflqGx69ZPdE/UyyfSPSeSPDo1TEdaWKLDR/qKbO/z2HzxDaztvWFVX3nzxTegT7c4OVNBQaJIDykEb1YHuLY9yXAwhZkbXjWQXG43jBbSTE+UePBwnHN6HNx6mwl7kP6EF3kIdKBka1Q9fSlJLMeZyUFVBEEYwUrP1tZZDrs0Tmv+KBoBGUvDUAKuGG5zTd9xrjr/ZgDeffsNvvXMGGEYkrNCWq2+7msNWXV2Fw7z0Ikeih0LS/HZXThOISx1qwFVtwg9Z7Viasxni26haBZObRq/XSa19hJqx148o0e/Mk5XZ63LHjqBwnBvnKBVIqN1cEKNq3rGeK60EZUQT8TpeCF+IFddG1iSXV/6u1BKkgmDaq2OgmRz1sYOdCSCUlvwu998C9V4/4yNdGV8kGvfrecn2TD9Jou2RiGboEAZt9rCqc8ykh5c4mwUCFAY7c9w3cXruX6kyOK7j/LGXJI5J4FKxB0JUelIhSNVZQkEYKKqKmU3wUJyA9f0H+Wyyy/FyZzbRYKt3AM+qE2cKr34vz3T+YeMD5PC/2asJJwtlJukVIU+q0Olo/FXR0ZIah7COkos3cMNl24kkzT5zmNvU29F0DhdRAPaQGhIK4+Zg3DXb3Df9+a7C2y+uEC1HXDFsMNgOuDRYymqdkjVj6OpKkIICj0JpubroGiEUqXalsRUSZwmIX1IBJqqUGvaNG2Pjuvzn//4KT5x1RY+d8MOrtgZsTBL1RZ/8M1XmF1sIqQEImiqIsANFZDgYgKSihdDVUAqKvl0nJ+/9VJi4/dxy8gkj04N42l50qkM1+/sYXp2DoD1gynefPZ+DpWzPDAxgopDrzJPPUzxemmIK0eOYh79DvTeyfDV/wpFM7qnq0v3fY0Tkx4SiSok/WaLQCqUOzpDRkhm06m+7nK7YThnQOjR15NmqthkrlRBKHE60mQg1kHTDDquJJA6Lf/Mwf3pkYjpOG5AIRdH+jYZw2Wm6vHW4dlu26B86OlIp+pIHxouozGbRpjm7Tmd64ctjFQfdmmco288ie2PMpgSEAYkggUqLYP5cpPe1ALXDkyxLd9mdq5EPhYwqC/idwB5qhrAs3lyPMMPTgzQdtcSM0I+p3e4tn+C0Hcjf+kwQCgq2c1XU9h121lbHUOnIZrSYpGYnqZJlnRaY3FuPnK6i0dufusSVZRcL3NNlZlSs6tVpKmimxAg2mx1XRAGkpjq4ysOxaZG01fwQpUAhZgrOXf0hydYt7HAref3ccHWW1a1Z2pje+lXioz0ZVH0EEUbILBrTDUMjky6KLrBb3xyE4WtV+J6AYauks/vYMeui3nJeZpvv7KIL0N8FHThE8rIg3DOSZHUHHQJ3zmYwaDN7t44N4TfIZXsIZX6PIyc2tjP1t6amK8yOXac3sN/85nOP6b4mUgKP+4SbuXpoCcTZ26hTtnTqbsaoQRPaoSyw6ZEmQ6RCXmrUaPRaBNdchHJAUuIawGWqTN45S9zTNlCqzPZXWC+FBRti8dOaORjsDldw/ETVHzwgpCR/jRJy6Q/l8CyDBZbveiiykd6Z3hlrkAikaQlwfND5sttNE1BCFiotLjrwbd4Zt8Yv3p7xBi94/odDDVf4dXXDlFuQlpUINHH98bWUG6rKCIERcPxBQHRJqAINXrYtl3H0K6L+WeNBa6dqfHuZIen3jjBNx+bABmSNkM2DyY4Mr2GmmdRdVSGE36ExrFCih1Bqa3Q055k6tk/wkj2kN12Hanh8+hUprnSfJnn4+vxgpC00sSRGoaAnNpAi2cpXHBb995kRQ3drTB9skHW8Kh6Jslkmp03fhk9kSc9+TzVVhnTdZlrp1AVgSqXFP+FoCdjMFsNUAkI5ZJljRBkkhYylNTKC/hLJkNVx+T3//JJQtXCdRyE10SIQWquwWAsRIQdUkqDopcgXHMjsd511Mb2klmSpKh2IGsZFOsSNRFEm9fSJj0oqnRMh8W2gTSSDJk1hG6gLFUDEyWP74xvoupGbbCGHfCN/RqbLlEYNGR33uC1y7z/7n7GzCsYXZ8+g0B4563n87EVqJ/RVJxfuHYd9x1QmG/5qKrGTYUjbE6UsdR1NMIkw6k0RmdJQFBGFWu4VCkoIgIjSAlxEaB4VW4bOcFC3efe8XURG10JkVKl7QRdCfVlguNyUjgbcmrjilN2c+oAfmsRr7GA0HRUK83z1W3cc3ILpUbk91CYanLl3Pu8P1Za9X2//MXbefH9r1NtdGj5JgoSXQ0YNBss+il0RZDSPdJqm6qj8nhxE1uyb7JWVM7Y2M/W3kpYBjm9zcmypKkN0ROGjCQ/eKbzjy1+6pPC3wWWB2cfIK08HYxPFbseBUEou2T5TqjjBA4Z3eXAlE2rExCy+kSqqYJQGPibfo5jysau9EOp2iZmaozNRSfiTqAy24S2l+b6XQWefN+j2uwwU2zQlw34t1+4nAu2DvHW4Vm8ZgnfbvDSMzOsHerDLDcYn64SStnd+DRNJQjCLqHsgq1DmOP3oR+8i6sSIaRUCHzeazgEwSiqIjEUSaCqOH6ApgpGB3LkUzEW60tiYDvX0Zjaz3OPP8ndBwcouyZgRHINoc/E4YBCTFCI2dTdJDMtk1hCx+0oWEpAqjMBcQUzM4RTn2P2ha9SSvQgVI1C2OJTazUeGeuhHsSIKV7XJAbZu+pe+69+g+sSCo+3NjNvx4hpITcPHGfLpuik/M8+J/j6/a9TqtlI4ZDTO9RcLWoYKSooJobSIG+6KIpK3REYiuS3fmEHpXqHu77/AvO+ge3r1F2FmusRymCJwWDQa7QR6Mx3kiT1gFDvI5tKsvXSm4CIa7AsSfHoxBCHF3VsXyEpfH7/r1/mzlvP5/Kt1/GdR17j4ZPb6fgKlhayu/8oN6yro2gWdukEB4spFpsBqiJRNY0AnYqn8Z55PcPaA+jxyJ/imfk1PHDIInjvDXTzILbjkU3GVrc6vnILG28/hfrZ0buO2OP7efdEkTV6jMv9g/gdhU9sKLNn8VymKy7ppMml25fWXHBqoC5lBAHd0dfhjo1TZNUGQ1aDI9ltPDUfktZdZBAw6+Vx/bAroZ6wDLKiRm1sL6Hv/lDklF0ap3L4aVQzhd9pID2XiZbHA1MbKLdCDF0DIViotrnv2UOsHcie0dr51dsv5E/ueYGmLwhFZOkphUJcizSY+gt53MokGd1hwU1TcWMM2wsIodCcPtC9VhtH1p21vfXeXIm73t2G7SvEdYVb1sxw49p/GgS3n+qk8LeF5Z0eHzRAWj4dTBfrLNQ6XdexZbUVjRBfCsodjeJUGdvRVzCAV4QEXdf4+pPjiKfHSVgGmwdMDp0sM1by8f0QXVdJWgaOF1DxNF48IRnoSbF+KMdCtYWhq0sJYWYVGc0LIwvFgXyKdsdnttQgm7Ro2G6k0SNBFQGNRp3jB16l/8SDyDBEMeLI0CcMA3J6i7jq0HDjEfmnE7GAg0AShtEDnbAilVe7NM6bz97PD46vp+7pSwDOSDq54aiEQpBIJolTY8BqM2PHWAx7yeg2Nw+cYMiqY2bXIBSFoBMNTtV4ltCz8Tt1Ppp4mw0bTvkKD1kNUDSEouI2FgAovnEPoe9x7cACW7J1qm6MwaEBBtS57gltpYvd//yrV6i5On4oIrlAGRJTfa4qzPN6qY+Gt0RWEiEPPL2P375jDZkdhxhzR/nGezlYmr9IQpYhq3XfpEdvUfISFDtxBrJJvnzbpWfg8W/kHsaqOmO1QUDFC2CxHvE0mqPv8sjkICiCkf4kjTDF060edsr9DCyO47crKMYAgRT4gYIMonYfwH1vd9BHRrheX2TO7+fBw3GkiOYrk4suxXKLwZ7UqlbHclJffib+/R8+zv3PHSIIQlRV4cilP8dvf24tVtNitBihtS7YOsjGkTzP7hvjO0++yxOvHkMRYOHjSJWDizHCrRmGzRmEqpEOFkkbeYJQkI1BSzeotDzKdZtcyuL280LC136PcbcdcQqcFvH+rWdFTrmNBdx6kcCNHNJQVKphlnagI0SAaWggwfMC/CAkZuldX4jJ+RpvHZ7lC7dfwzpxlO8+dZA3ihmCMELZ3TC8uOQZoUGgUXEsNBGStzxk4BF4nW5rbvmQecf1nzoDVfebv/8OaixH/1JV+cjJAlddfTUznTTzp/mT/2OLn+qk8KMsDn9YLLeIAs9hMCWotB3ufvgdthckw8kOP/+xYb762BiOF2IoEYNXQeKFUWIIpcKMnWDZM1dwqt+6HDIMcD0fTVUYyGrMzc3zTrHJFzaNc9Ds4f7GIIamIBQVIaI63XGDLq4/ETOYmK/y+r4D3P3ou0hguCdLpQ1t28X1fSbmq2QSJpftGOatw3MsVNsROgQ4Nl0nofl4B/4KT9QQmo4MfYSigXQYzQl+4SMp/mKvSqkRRPo+atROmS42WDek8qu3X7TU4z3OwaJGpaMtCeotu2URyRAj8bCIFfpJGC3WhYJfuXkLMXcWxe2nNOsyqoWEXgfpewhVR9Vj6LEsbqNE6DS7sgTLIQDVTGCk+rr3Wk/04LfKDMeaDJk1Ftom78kC+pIBDkTDy/KhEgo+CBVdhUCGxFWPXz63Qmv2OM/PFdBEiCl8PBSeeLfNRfr97MpWOdrM4wX5pdmLsuLeiq72/2Dc5pdv3MDHbvz4WTWHSup69r/yAkJxScYNPD+kUm3RFh0OxBI40qIQaxN26vQWBpiu6FgX/UsK2mHm936HgtaDooB/mhah7UoeL25lW/5NFhoV7KCHNQN5dCtBIacxs1BnodoiEYsONVLStQQFeHbfGPc/e5Aw8IkpAR1f5eHXJsn29LD3vSOrmOcAtEsMWG0EkLA0QtfFlCFtX+XEfBM/1c9i6kJ67QPcPHySR6eGWQx76c2n+dInNrFry+ApraSlw5tTnyVwmjj1Ocz0wBnIqdB3CZwmUoKiW4Reh6xSJWkqVFsBjut3TRk0VcHueEwX65ycqxKEIX9yzwtUDj/P5cZL/NKmGjeMpHB7LmJk7TrW9ho8OZ7iD77/Hou1DAJJzuhwuBxnsF8gFIVpO0Vd9pB2FmHpkLlxZF33Pr+8fyLqJAwNI/08Mddhpurx1FSBlx959KwopX9M8VOdFH6ULMAPi/lyk3q1TI9SwmkHWEJlppzke998gwtzRXbmBf/6+lv5/z6dBbeJ3y4z24pkETSxLI4QokTcMbxwtSRF9G8CUxf0mm3s+WnibocFN4muK1w/usjzU1lqHvh+tHn1ZGNkktaq/qURtpl9+W5q5VEKZpO2a5DKjtI2LX719osZ6kt1TyXfenw///mPn1x6nqOHuuVrPD41yC8OjqOYSULPJug0It6CZzNYe4ydiXN4xR6iN2MxNDiIlJLJ+Rq/evvF3HH9uQB8/blFvnN8LS1PXaqKlgUGIl36TckqnpJiuuKSsBLccV7I/L7v8dCJHjqBStw4h1tGprimfxKhKGixNIpmLt27DK5nI2U0mF0ONZZi4PJf7CZ41YgT+h309ABOdYpn50fZs3gOvpEjXTwFIS2+/QCHX30EXYyyPt4gFAaKdKl7Fu7sfqY7vUgEMcVFiIjJYAcqU3aSsj3I/RMFGq7oeg+vjBAFoWpcd8kGPnbjzR94GqzKDIFiYBohnh8ShCG2G+IIjVfmewlCQd2LkVZblKotElaC0fUbyVl9lN97DKVVI671UndXM69tx6MZi2Nd9C/ZqbfJLhynIU3MUNLu+PQtqX6+d6JIo+2QjBn8/l+/TKna4o7rd/D+oWP4fkBcC1EUFUuEtPyAh55/n0I+w5r+LNPFOv/n118kpnlIpx4heEKLdkcS0w1sx0MVIftm43zz2DpCOqjaNm65oIf/5/99PlUZkSgjpvk8Tm2O2RWHNzM9iN+O0HhnQ04pmsGsX2CxLchpLYbjMJLyuXP7CH/+1DzFcguAvmycK3et4a3Dc4zNVBAyZCjWQjarfPsFn8HzHDatXceadhmv/gTioMYMgkNTm6k1RxBCQSMAobBncTuXXrSDNw9N89j0WuxAEFPz3Dx8kn922iHz9DlDrSnRjTPZ+2cbrv9jiJ/qpPDDqPM/KrKihu5XqUqNfFxnoiKoOpLvHy3wpNnHR/tn2NbzJLdd9jme2DdDtV0jZ3nYAfRYLjMtE01IAinIWT4Lba3bYtKEJKH7JPSQWCrB/EKJjCap+zEUETK/aJMOWnx2oM5Dc+dghwaphMVvfOk6gG7/MqZJbup5j/XqJDF1MDKgx2a+WERJRczplWVq03ZPk7OTSBRenitwY6GfNSZM2EkWGh69SYVD80m+O7mVihvDR2Gm7GLFaphmnN5sJF4H8Ef3vsafPHwE37dQ8ImaGQoqAboSElMDGjKOKSUf3Rrntot7mN/7Lb41tg6JpFevUnMsHj5Z4OLzt7BhME3l8CnhwNy26yi98xCh30EGASARisaaG/4N9Z4rObZ/gv58unuvkT4lfSNPty7AzGUZ7c11H8LtBUn4xj30JAzipoLj6WS0FrUgRkz1yWkNPF2iCuiEBprw8WXEzZhoZ3lnro9EOs26lM5EqUPgRa2jyIkrch5TrTQvHHV48/cf/cDTYH8+SS4VIwwl1UYHu+MDMBBzsNSQpjRwvYB5L0Y2qa2Q7shTuPjzZB75BkllkBYJgqVaVFFE1xVuGTr55VbPqn73v/3C5fRmE/zOnz9LNmkxXEgzXax3ocprsiGqkDihginACZXIvEZGFercYoPphTqtjoeuBBQsEIqGpYa4oaTlaigIzslUeb/ejwRiqoeLwmNvl7nt5iTXXLSG4tsPcHxp1ieE2oXY6vE8Tn0OzUoycNkvYuVHzwCIPPxOi7uOXkTblVjC5abCUa4bmOT64QWu/C+fWSX0GOkkvcf/9Y3nyVMkrkcAgtm6xkLDZ02jGFWZdhUUjVmvhydPZgnDkFTcxAs02qGOZVrMZs7h0annCaXPQEJQbksenRrm5hVVKJwJo41pkss3JXj+YI3hvnS3dXdsapE9z+3jio0GWzat/UczgP6pTgpwdur8B8XKoXJvMM6luWmeLY4yVlGjtgiSpqdRd+FbjbX0TLTJHT/A7o9soK/4Alh9fOO9HIttHS9UcJfaRq7vMZrq0JfWObYgUUVIPhbwC9euQ4tlufuhIkUnieP5IOD7U5uIzUTD1K9seoGyGydvOlyz5gpym6/sDpXthTGyx+cZUFrcPDzBYzPrmHeSeFJF11z++HuvrypT16Z9IuyQskLxVOIGkhPeCOXsdXx7/ySNWg1VVah3JK3AQF1Ck/hSYWy2yYYRo9s2Oj5V5t4nDxKGkmRMx+n4KKHEVD0uyU5ypBkJu/WkYyw2Sry4t8glzmFKjRA70EiJOm3fxFJ9GoHJ5IlDXHzdfyB/znWrZBca43sJvA6qHiPwbFTd4omxFN/+y9Xl+K23/zfcxgKVKfBOvMtg72qo4PTsHAW3zfpCjtu2dbj/kEXRUYmpAbsHjjNkNRiy6qyPL3K42YcnI2E7FckzJ5P4UmAGARuGM6wfjnN0osRIr0UmphKEcHTORrOSP/I0uHLjcP0IeTQ6kGYoEceuzuL4gs9snmfz+VeeIXudGtnJmhxcN1Liu2MJCE8RxjRV5Y4btnd//tbzk2xOjFDx4t1E8fL+CYQCw4U0c4sNZhcbdFyf3/nqs/zz3ev52HCZ56fztL2oyrukv8aCmuXI5CLVuo3rR61EKWG2HRk+SWBHrsq6NUMMOofx9R7ePSCIaxHAwdIVWk7I0clFPrJWnDHrw7OZrCkUT86TpcpIJmDhre9HCXD9Jaue0W8/P42vJomJBexAY09xM+f2h8QOP83wwFZu3LAMZ46uwQVbB8knVDo1iOkqxZYCBLiuh108CRBpIXlJykEGPwBdBHh+iGHoNG0PTVXwOw1cJUWvVgE/IGuqLIa9VOXKlBDF8uxqWbgxcDq8ZG9jdsZlcGiY904UqdRbfO3+fXxLddmWt7n84nPP2m78+46fSFKYnp7m3//7f8+jjz5Ku91m06ZN3HXXXVx88cU/ibdbFWeDn/4weeDlWDlUNsI2I2KCE9UePM/HCyXhEpQ06OrZgKl4uO0aj+8d5zd3KAwnpjk+bPDN96JeJEKgILBlnEu29DO+4KLHGuiK4BPXbeRXfulm7NI4hbn7OFSO8f1j/ahhh4xmU/OtJZnfRXZkiszYSZ59cS87Y+d0h8r1eo2wdT670nmuG5hi8+YFXl/o56nSZuKWwehpG9NH1qtc3Fvm1WLvkvpn5FRl+yr3nFiHPDlDTNeIG5JqJxqaSilZXiaRRaJY1TaaLzfxggBNVeh4Ek3T8VyfpO6zYzDk6GSWwf4MTmWCrCkp2nHKrkVGTOH6IcfdbLejlrMkGaWB21ggs/6SVfdsuQrw2lUUVaPedzXffOoEYeAznEtQabNUCexkOAmFrHVWqODw4ADhRNRSvHEdbDAmmF+okdOa0fAayUwnjRcqDFhtPGFSthUCKTCUECEVXD9kYq5GNibRREDYWkTHp+L3IBAk4ybVZoeYqZ1CZy096CvX5/LG8dbhWf78vjcwNA09laPiGGRMnxvviFRhTw+3sYCUAV+6SKDH6zxxIoHthaQyOT6/+0J+/Y6PADD9wl9Q2v8gMvDpjWe6GPuVQInZxQaeH2JqAhE4fPPpE/yXT1/Ela89xcmqytpsQDh0BXe97DBXahCEkSuaril4/pIKqZCEoeDdSoailMTDYbbnGlG15YOlRh4fmqqwebTnrLO+J8ZSPDa9hqbtEFN8dg+Nc4NxJgR0vtxkttTA7ij4bhZFAVNKWtY63Po7TOz5n5EQ5Aqk4caRPF+8cQt/ce8Mh0sGnVAnprrcM72TqheJF+4pbsEOdVQhuxpXthC0bA+FkJ2xYyy8sw+8NbT0HL09GSptSVo3zyrXARF73y4/hExI9L48H28UeeQkvHVYUm1Gr1sNVMokmGgleHpqjq8+/x1+80sf/QedNfzYk0KlUuHKK6/k2muv5dFHH6Wvr4+jR4+Sy+V+9C//HWMl/PRs5iKVoy9hl8aI9a4nt/nKbmWwUut/MBlycnKR5+1e+owGQ1aNk3a2e6pe6R7QDgz6tBbNlo3bdynCfoFao0UoM6iKgqYp9OaSeH7Im8eqtDoeQgikDPnu85N84voyG0fWceE1t1F66H6CUJLXOyiKQoYORTdF2bU40uxhT3EL/gyY+x7EdjwSSgfsKnO2xaPtzbxVHWBToszh9gBlN0a76qAbDQZ6Ul2EydBQH/+fyyb58wMBz0330PAUVBEyYLbxHEHRkehCgpJAhss4fWUJVxP1z/0wOnUvb25ZET1UHc8nXCIv6arGHdduYPcVt/HMXfspt1rEgoB6kCCmSwZ6stil8tJoQ0RDdBTC0EM1rLPOfAq7PoXXKFF86/sEnRZH9z1NpbidgbiD7aqkUgPMVH3efvj/h5cuohpxbj9vN/cdUFZBBbeft4NicKqluDYXZ/3AKI2x17p3tuzGsEMdXXhUXKsrny1Unbip0l4iAaK2+dhgk5OtNPNtBVXUiZsZjk4sdhnnfbl4d9P4IOx9tD7lijaPyZ23Xsr2886+Mayclf3cOXBpz/SStPgnu0lk6sW/YPbFryLDEKHqXfmL5aHonbeezx99dy8d18dQJH1Gi6y/wHQxwYuHVXZ/6tf5dLLDdNPiP9y1PyKjqRFzOQgkiYSO50dTFeTS6hAqvT05nKbkYAUu7FnkzcU87UBHUQXXX7yOay5aj12KNm2nPoeiW0xU4OHx9YRhi4JhU/NjPD67ni2pfawVtVXAENcLaNpuZAWqSjqBQiAVWo0KgdFEjaXRYlm8Zom5V77RTSifvmodr+wpc7IxSiihE2iUvRgPzW8HKdGUgILRoObHAI1UMoGlxlEJGBKTHCyneLOUx/EknbqNq8RJJhL8/MeG6fWOY5fqP5Itfsu2kIw6xv/9/vmwtNr803xRitUO/+ue1/9BZw0/9qTwe7/3e4yOjnLXXXd1/279+vUf+POO4+A4TvfP9Xr9A3/2h8VK+Olz5a08eDiO/fpxss/ex5dvu5QLWt+j/N7jyCBAqCp79Vt5bGYdrY6LlNBoOWzulTiLUxiE+DKGqURWkUnVpeIlWIYdLkfNi9EILDKGx9qN21ASV/D2S0+gCB8VDxHCwmJIOqFTa/mYho6pqTiuR7HS5PV9B9g4cjUAOa2FJTxqnkUuBjUHYoqHL5e8hhWNtcN9TC5G8tdr4nUWbAtNEYQhdKTFK9WN9OcTmNLF80OmivXoAV6CjcZ6o370r3IP62Jl/vrYWvpiHeKKS8U1CGTU7orh4aB2x6grDX3CUPLUU0/Tm3+mm3zr9R2E4Sl0VczSue3Wa5daJBEvYL4T9ew/sbXNgDbPAX2ARDpHv6zgtFsRPNaP0bTWf6CKZ/HN7+G1KyAlad/FEhuo+XEyisN8sYiGIGe63ZbEpcHjXPbL/7472Fx+yE5vKbqNBZ45dpIjFQsJZPUOKiFzThIh5VKrTcH1QlRFwTBUepIa/2zdAa7YnGCq6bLYUmjVF/nq2IV0vIgPAhK5ROr6UfDolbIjHwRXXFllFE4jnF107e1dOZGDBw6w7+nnSbkJRjIBMvTx7TpCKKugub3ZBP/1T58gaC6Qt1ymmimqHYVvvzDNU4cDvnzbpQz1pSnXGlRrbRTpYQlBR6o0bRdNU0jHNPJJjZMLHQxdJWZqWEYfE7MKd954AVuKAXveilj608VGV3srVtjcfR7n6n003E2kNA831MhoNkU3xaKtsV7VVh0SDF0lFTdpd1w830ATHqbqowsfxUgw1YqzMFEmq7UZsuoU376ftTf8G44cO8m+cmTGFKEDNaqeih3oGCJgKFZDEZCzAkLS/PoXb2SoL0Vl8n3+72/NIVSNgbhPtRM9v7987RDbejvExr/K+KNn50CtTN6KZuG1Fqn5g3S8cNXhcjl8qUAgmZiLhDP/45c/9iP3vZ9E/NiTwgMPPMDu3bv53Oc+x3PPPcfw8DC//uu/zq/+6q+e9ef/+3//7/zX//pf/87vu5yV5/x+HjySiLTbLZuWY/PV7zzFv+x/kaEYKGaCqbrG947Z6MkSw4Ve5qo+jVaHSa9OnwVOaKAR4oQaoXTw5KnLdLabqQgFPZGnWO3g2i0GTI+SG8cPBBKfUXWBSthD6EtCFALPRUpB8c17mc4fp/jW9ymEZXYX4PH5Dcy1dDRV5bzUJFU/TocYawd6u7DC6WKVSkfDD5WIvKQs9UBDsOIxRhMxTs5WaXc8bNfjX3zmojM2xMarz/Lw1DguFpZ0sQMDhWhQ6oYCTYRYukBXfaodDRQVRVVQgOffmeWKiw3WF3IcOgxtJ8DSNXRdw/dDHDfgrcOzbBzJc8f1O9hekBx+4ynM0j6GEy2EiDSNkjN17EpINqZQ9WLElJBkZwy7NH5GYmhMHcBrLiJUHRTBkNXgpr7DPFHZSdGOY2Bzy/AUa7ICvxORvHy7wmiyg6kPd30kVvIFlt/jBy+O8wcHL6PimgBkNZthq8ack0IIiU4kHx4QscMHepP8q1s3sbP0Cl7bYSSZp18pc8BNYVkGO4cyuH6IoSmUau2ufMXZ4NGNqdVEqI0j+SVjnOOrWqBnrTKW5icrf+7ep97lru+/QnVxA5YYYffACa4bmiN024jTNthrLlrPxHWD3P3QLNOtBFVHJWMFjMTb2IHP3Q+/w69crhC2FnE9A0sJQNWwwoCYHnLdpZs5Otuh0rBRVYVMyqLa6HByrkoYSv7imSKu65KLKfRmEyzWHe76/ststObQi0cxskMgVI5Nm1S8GItuHF0JSKoOGd2hx7DpOf8Lq+Q5ZhYaZFMW2aRFzNJptVqYqmTH9V/i2Ue+z0Mn8tiBRkz12T1wnJuPvYi96zYqXpyOL7pKwGLJvbAT6jioHGv20Z/wyGYHyOjmKR5GbZ5OqNFv2SjCIK3bzHsm/RmF2Ph9P5IDlVp7CYsHHsG3awBIvxch5ZIE/bJd6OoIJXzniXf5/A07/kGqhR97Ujhx4gR//Md/zFe+8hX+03/6T+zdu5d//a//NYZh8Eu/9Etn/Px//I//ka985SvdP9frdUZHR//W72uk+gg9h+nZGdqdfvqsJgQKCWaZa+kspjWG4hHOuOzFsQOVtDuDXSyTUU1iAgI/YL6lY2khV+THmbBzFN0UQkSndqkYBFLBC0JUQgYSNhlTUg1zvHTcoc87jiUcpBCsjdeougaaCLl1Q4mp99JUHI3ADwBBPhayJdui+Nb3cesLCM3g+tEFNqcWeWZ+lLcaa3izsZYD3jkQi9GQ6VOwwoyF7NjUPSCEhNphoWMSSMnYVImeTIIgkChCoCpnSkPHetex67Jr+MTrvx8Jr7kJNBHQY7SxdImBg6cko6SghCx2FAghCCM9pJqjUpc9CMVFM2KARFEEuqoSSgjCAK9Zoja2l8b0AcJDT7PBbSNSKplNp3R4Pl96kLsfmqToJInpkk9sqjNonGnBCF3YOZIoCQNc0zvGjtE4VT9GTm8zoBRpzTW6rBA9nuPhd1p8+/kPxoYfnyrz1QfepuoZqIQIIan5FqoT0qO3QESVQ4skodXHFz9+Ibsv28TGkTzFt+tniPcliw7tjr9qjtGfT2JYYffUOOf3U6x2yEgV8crdSHmKCAUszU5qKKpGz/mfpGfbdV1/g0K2wICc725Apw9h7374HXy3TcGoU3VNHp9dx+bYLMNJ6N35yTPIU5+74TwKc/fx2kycRyYG6TU6NAODVMyk3GjRPv4m1w1pfPfEGjqhhiZC0qYkrbvc+dFekiPnMV9u8tTeEzz+yjGOT5dRFYV1w1na9RrFqkMmVaPdDjCBYifBu0+9zLnJIvH+rYwvODy5MIKUggBBEGr4UuWGwlF2XHwlI1f9CrB65ud6ATKUBDIkEY9z563nk147xOPz++kEVeKqR8M3uG92B72Z4wxMHSDhuFhqsAJ1dwpKLBH4CKZbFoHl8X986RTZcHT9RlLpLNVWmWzYoepFvhf9uQTB2AdzoIpvP8Cbz95PseqSDkJGsymsnrXkpjXiqkMr1FBFCFKcZq0bRbXR4X/95aP87q9d+feOSvqxJ4UwDLn44ov53d/9XQAuuOAC3n33Xf7kT/7krEnBNE1M0/zxvLkQ5HUbS/WpuSYZvUMj0IkbCnnDRnodAqGQU3xiikc9TJL2WlQbHnld8Pmht9EUSd7yGLLqzLZT1I3haOZwfAuOnkaoKuV6B0Uo9A8MMVvxqNgedz/8Dkm1w5pYhWOtHupegpji8ImB97kg5/KFc1J873CGtq+RNFU+e06d9YUE7XmXlbMKoWq81xwklkgzMNBPpQ3Vpo3j+d3e+G9+6aOslYf41oOv8PJMikU3gSIgrzs0fJ25xYjpPFJIg4A/v2/fGT3KWO+6yED92fuZKzXJKhWOtQd4bG4Dtm8RVyIhvj0nYt3fUUTEm235Gq1GGS/tst6U5MwM9cCg1fEIZUjGhNzY3YydLOK1FpmTw7StjaTFIsr4Xgq7Iq2i0203B7R5hDg7jyQ5fB56qpf/f3v/HSbned734p+3T2+7O1uxBb0DJEBQLCJYwCZW2RQjmaaaE52TUCeSdX65ZCVH8UliW7ZzkuiyJcuWnEiRLLFYEnvvFCtIgCABEkRdYLF1dnZ6fdvz++PdHewCi0KJEERpPtfFi8Bgd+fZmXnf+3nu8v3apQyu64CsICHRZWTpi7vEll/O5PafI9W8S360GuJANsnDO3fi9wfpbY/P2w10ZPAAhVIFhIKuONPKswoVR2dD7AhD1QQF249ftfjMVd18+pZNjTXN19n2aWnXcZIH3u6/QLj/PH7+7B4ePhyl5iTwKZ1cNzDFtcvxgsUrPwIJ7HrFm+q2LcZ+8Y888Oo4P9/h+Rt4wdNgc2LPccHzyOABb7ZGSiOpGlFRJ1UPkjF99BoKj+/XuO/e4wPkkoW91DIv8ZDdxr5aCFlWkCp54gGZqFzkowNRxvJH2Fnw3peI5nL9wsx0G2WCN/eM8vo7I173nICuthCdUY1UbpJxESFbU9GNCnnbj1+XSPhtXh8PMj4OObuFnOVDlRwMWWC5Mi4yLQFoW3c9ML8SqWnb/KubNzZ29C+/PUS6rlOxQ0zUpIbfyN+/u4hd2We5PDnE5kSQn46txnGZ3jYcDQxeilCZHg4NNh5f1JPg9mtW8aPH3mHKdAnFg3z2pk0sXRziwK75Z6De3bmTf/z+87yR6sNFwaCPqzsGMUoxHj7Y0misMCQHn2IzZfqPm3cBwUtvHeKZ//Uw6y/YQvdHP3/698FfkQ88KHR2drJy5co5j61YsYKf/exnH/RTzcEsTiKrOr2tsCl9hOfT/YzaEXyaxKbuKpLqBwoIs0KXT3B19xGenFzKRMWHXza5Krmf9dGxxs+TJB89UQvX2sNzmT6ypk6pXJveqUI07CNVgmzZIhH1s7gnQSqdZVemCxV7zvyyVZzkAiPNwlXt5EnQEhQMJINYlQyqPwpI2PUiWDWmagFqrsFASxTNF6RVF1TqJl/4+NxBNFhNX6vBj+78OXceXEybXiKg2qRqPkZqMaJBmXSuhO16dYB/fmoXf3JMjjK5/kY296xl7/7DHHjnDVZMbWN5y7tkajoJn0nWDmLai1FxvUGtaYE4XQUqk1TGJ0gqCp89bwX/e5ePTL4KkkB2qrwzodLZ5+fZAwt4cGI5NeEnoMW5oWs/nx7eSXH4bVJv3DPHdlOKtp9wjsTf2k/3JV9g/JUf4dTLKEaQltXXooXbGqcIWdUJdK3kyYMhHhqMk6vJ5K0aXaE8ccOkNdZ+nPBaXKsQUGwKkoLpeMZAtpBxHY3dxXZWRqdYEUmzJJxh84ar513X7PXOVxuYSf0czggePrwM2QjRGwswMTHBo0NdrOlJ0xNKUJ08gOvYuHbVq1IrGiNFg58fNhFIJP0VCpafB/cEWLohztJZwTO14wFq2+5HrfeQcSDul71gpjgkDIvRepw7nz2EHu2eEyBXJgVuah9aOImsaGBLCNcF2UVSdF5Lt/PKWJyqLWPIdc6NjnH10hobt3ziOGe0hV1x3q5MMDpZIqrWqJqCmFZFVQQpM4xftvhY7xj3Dy/m+cMBHOF1wDlCQpUd5GllXiFk9FC8sTmYrTXWUKitWHS1hRvvo2k5FCsOjuN9Wj2RFYlMXefBw51sS7fSoUzikywqkj7dVQfg6ZXNWM3mSzW+9u0nuf1j6/g3t5xPascDrE3fwxcXCvJumCUbt3De9Elzf/Q6dm7fSreRZ1OPRHLjrTz8Volv/+hJhrPtSEC7r4grwYOji5BTOqpssyhuk3Fi1CtVNif28+D4ckrObMMngYILwmEiXWT0xX9ESDROTWeaDzwoXHTRRezZs2fOY3v37qWvr++Dfqo56OE2nFqZJw+F2ZrtxhYydUfBFoKXhzTelM/hquReLm09CMCliX1ElRLD5SA9vizrY+MgZEZroWl9nTpdwTITbgcPT63DdBR02Znu5BBEfArXXrSUh1/a17AFDIWC7Bv202qU6fUVyZkaT0wuY1m0QLe/RE/E4txzLpoezMqh6AHaL7gdgPFXf0S9kKJFr+FTbcZGh2mN5ykRI+g7muOcTbhnDSva7iE6VPWsMG1B1VaRcckWaqiS8C50WeGZNwb5xHSOcvY8xpt7Svzg/gPk0jX8ygou6q2zJDSJrEksWnkRwd1jFC08A/bpC8m0XfYV45zTLZA1HwvrB4n42wn4IoTJMZWp8bMDndSrJe4dWUbeNpCERL4ucffBflY89mO6AiVUf5RA+1Hbze7N/5r4kotO+B4fuzP3Asvd3gCUrODaJkNZl4cPteHaVdoMm4LtY7xsEEpPQF0n6JvbQtjbonJz/wh3HVhApm5gC2/oLqLWyNgBfpEOsa+U4KbeIS5T9TnrOZHb1qKexJwW1JkCc0ntouYqtEt5VC1GzOcyUXGZKsu0yxkUIwhWFbuaZbTifQ73lRPkaipdrQFkJ09EKTNh+Ruqq7OfozsouGFJiQf2+Bkvq/hl2xMONLK8WwhRqQvaA9K8cxsH68twJYW+qIXsmoRae0iVJJ6bHEAj53krmxp73BX8H1df2ShqHysd3dcRY3A0y2jOJiTBJxbsYWk0x1RJkNAr5PQlPH84iABCfo2K6WDbYAkNF++kFtOqrFt0tE4y00I7YziVq8kosoyW2gp40u+v7DzieZQLmO2mJ4PnBVJTGbJ6UCQXTXJQZZeKo3o1Po76jQsB6VyFv737NaxSlits771b1O2dBqRD91FNb+T/vXMPD7wwiW33oshwFSH+z/MH+MH9W6lVy0joKJLLVD1Irz9L0Q6BK9EXtfDHOukPt3N4dJKlmxax4LUc4wWXXMlqbCUjWp2watESBOG6TL31IC3LL/+1pJI+8KDwx3/8x1x44YX8xV/8Bbfeeitbt27lu9/9Lt/97nc/6Kc6juGynydSS3GBhFbmoNUCrrcbLNg+fjq6hphWZX10jHtHlvPYxCJMRyGsmXzc2gUc7Vf2KzZXJfeRDFhULM9MxlAswMF0FcqFDO1iiHj4qOxEKlsBIGbYyJKET7aZtKMclleypMuTwgj1rJkzmDXzJmvBFoae+P8YCKtc56Z5+GCCIxMFAnqJP7hiYF6deT3cxqr1G7n6yMv888gqclYEEKjYmK6KLIPkWnQlVCrVKs+8cZDHX9nHY6/sp1wzkYVDuVIj4veK8kcqYe5810/cFyak1PgXYcFN/SP8074+MnXvhqjhEFRMnk8PMDBS5qIVUSbTDrZtsSAZYehQiYwVwHIV7jmykoKlo0sOumJjOQpZy8/Tox1cEnmHJYv907IGHdTzI8jH3HRnfte9+w/PGr7qP6EHMaLCVFmiYjq0aVVkSaLDKDJWCzNRUmgzStx2xcLj5Jk3t06wUBvkufRinpvooS0sM1LwebtWCRxJ5/GJRXxs1uTqydy2Zr9HZuGoS9qMI1iuJuMXEmWlDb+aJWSPIkkS7RfcTmViH3c//ApPpJaSNgNUHB1XSJQmJXqTPai6IBZSG6qrMLf18ZplNotDQ4xPZEho3uzFmN3KZM2bNp/MFGhXdbIVz5K1NSjx9JE27jvkJ1eTKdQ0OoMuqi2jqRIWfrq7EuBaBGWNkazZGNaaKfwqsty4BjRVoa8zxueu7Cf8zrdISiNemk/1Ts9vZVUcIRHyeXpePsnCRiGk1FFlQdCAm/rHaTULjYaDRT0Jfn9DgB89up8JRyOgK1zbO4r/0B6q6Y2M1iI8t20QVZFRZYn6tOAjgFdSE9Qdzy9Bl10k1QBZJixshGNSstTpgq+EoSsEfN7A2s9f2MeiRTUGumNz6gbPvLaH+557DyHAp0Ldsnl8R4549fvks53ElDJ5WcN1PQXWnO0jFNBRfVFqhk4k7J3UQsEgl1x5LeFeb+6IiTzlqolPqpHQa1zTNUSXLw9ouI49b63tTPCBB4XzzjuPe++9l6997Wv85//8nxkYGOCb3/wmt9122wf9VHMwi5PknTBVVydplCjbGpIEtitzuJqYtlqU+LuDF7A8nGJrrreRxyvXDb5/eCNtvgqq5BDVTHKWj4fGV/CHC94ioDrk6wqW44nBCUkioNgkJx/h9zd8gn9+Lcuh4YLX0qbXqbsqFTfCSNlz9Prh7g6mKiku7BZkh2HBQIRFA/1z1i+rOkgSqi/CJZFdLFwaJFPTaU8E6HP2Uk1/tFHAmt2FElt+Oat7dB5KgSqViGpVSrbBRC1EWKnRalSYyoUpOAbf++lLFGoQD6r0RmocmawyWTWIU6QuJEqm150R1uq4Qubet12+OFDmkz1v8ZPDawirVWxXJmcHKNV9/GBwNUV5jFXtgqDfYGSySKriwxESmuQg4XVbMX1h2qjYQuLZsU7emgzxMWeS61a7J9SkSu14gJ/8/ClPH8lVCUdi/NEnNnPLFavnHYByrSq+BZuQ9xRI121ajQqqAh1Gkes73mVlu0A79BaP/Hyc/iWrcKeDSrBjOQOBMbRQjr3SOu+9FgUUHGRJEPc5jWaClDnI2PAQ//Ph3RiGTm97nCNjab71kxeISCWuuvwjc96jkUqQdClAW71Mb7zK1V0lHj3SzWjOIhSM88lrV3PxumsaG4S3Xn2eJ9J56gJMV0WSBJLw5gMGJ8oMdMX5wk0b5mwSjtX46o06dGlg11yeHV/K4+OLqDoqlitTzxcpl0uEIzE+cX6EsVf+Nw8f7kcRJp0+l4lakNFKgIGEwi2XL+exV/aTrUBrLNoonMekPD+860HueXmSqi1hWg6Vqkml7gXIL3zc8+hI9eUZf/VH2LUSqi9Ey6prOa/QzV2H36PmCHS7Ts2RUCSXixIH6Q3mWd2ls6inhXq+Mqdouz73Q6J9RbJumPbWKH0tKmYuw8S2n/Ps4TD5fJ2uthCT2QqO62I5XvMDskpUqTBV170GBEXHZ+iUKnVa9Qr/ctUhjpgd3LsnRMlS8eve/IUmudTKJVL5Ou3Su+iJHkarIbL1JI++lKZueecL2xaokif6WKi66G6JmqvQqlcYrwcRwlNf/dRGHV9LO/e8PMm+oQl0zWhMni/qSXDOsi6ODB7g4NAY6SP7iGbe4ZzoGOB5RSiaj3p+fN7OvA+aMzLRfP3113P99defiR99QvRwG20xnYAmyFs+DMnEne5o8IZrADzZhtdzPccVdmpCY7IeJKmXOFwP4wivk+bdQhs3dB/gnkOLyNZ1QCKmm1zf8R6t9f0kR77JF9piZO0gLT6b9zIBHhpbzpGSxozM/FRN5p/2dPHoaC+RvbsI+vYet7NsXNjlKYTr0OUv0ROQ8Le3YVcyc+ShZ++Oc+89g931UZxtKdqNoidfLNuUHANddsmYAQq2QdSw8TsVpqwgmVyNuD1FRJaYxCBbUwlqNtZMK6oiCMfbmKjp1Fs2sCT7EC1GhZKlkrMCuHg3fQXBo0e6ueSKlXx2zXL+x49fpO56goAdQQu/XKdQ8OEIhZoLtvB0n7qCVWqWwqNHulke30NfQjquljAjxf3wYD/IMkmtQr5k84P7vcGeYx3DrEqGp4YSPDoyQbGiUnWClByDFr3K9R17uDR5mJfrF/LIe61Utx4gHJniykSIj63SGiJsPWKEZV1BHn1zCssBW1Joi2hkCZOtWvzdP2+lWqujYVFzJLqCdaqFKcaLAtOR+U/fe5rD773JBfpLjXmZB97zU7XAp9hc3baHS9sGWbo8hbLyXxwnXwHw7gTkbT8hxUJICrIQWMhMOz5wzrKO46ZdZ2t81aYOISkq8eWX8d7ud3licgHIkFS9wSxXDvDxRWMsDb9HRzbFjrSPmu2dohRFobW9i/Eijan1ZCI4p3B+8xqXoae/yQ/f6EVIMu1treQVg7pp8kdXL2XThjWN36nYejGZVZ3EtQpLprV9uoEXDsL9z+2mYiuAQJdsXs328XbBImcPk7HKtIW8msnMiRBZoTtSp8upIGpjlEdBODZ3P/wyD42vYKoeIVus090eb6RgNq3u5vUdeykXPMc+v2LhYlAq15CEw+b4PtYYB9nYUUKwmDvfiVKu2eiqTFCpEdFd2tviCHuKx3dLPDHVT0GEyZQnpu8m3n+mkFFwWW4cprNV58GJ5VQdlYhaZ0lwkjXRCYxxh9rwC3SYfUyWkghfiMde3k8y7lnjhtMvsuPJoxuggH4+ZWWQyzpHAeHNBL38fVK/BlvP3xrtI3+rNxl8feYpHjwQp2D5CcgmRceHi4SEl0t0kRvyxsdiugrjZnR6h+hpA20vdHPV4r38f+f6eHP3IRzbZqFykE5tCoTArRVpp0i7qiAJhbaoS0FE+FGhF6bltAUyLhK5KvR1ylSq5cbNDZjOS3uCbuOv/sizUZQEWqIH16o2dtEnkgLvW72ccKRGvlAjqtbI2wYtWoVbu99iuBbj8dQy/KrMRNnAFRJ1VNK1AEHNIqZXUbDJmzqKohIL6cS7uqfTC9CeCKIGy/T6s7xYGcASXldHVLfpao8yUgmwo9SPZZfRNB1J8k4bjmVSlQUtehVF9jqWXFulO1gloAmiiQ7Gywr6+gtYdO6SeadBJ4suVVumTcsjuYKwVCeTP6r/P3uAa6Qc5NEj3QhZYnHCYqxQQwiZTy0ZYq0xxKjZyiOHkyDLtGtlyiLGo8PdrGgbbBT9x8w4+ya8/HjVtJjIlMmWvc9CNOyjUq3jOjbWtADdaNnwHNpQ0BXvxnP3yyk6V5kYsR4e2OPHcSzatAp52+DxicUsCWfoDoyhDP5PEmsWAEdrKD99ehc/eOoQBcsgX/cuTVsogISmqQgheHPPOAeGM/PKcZulNFNvPYjr2Ly3+11eTyUo1GW6fHlkBDHDJm3LdMZ8dDCBVcmR0OP4FIe87SdKlVrNojUWa4gdzi6cz0hcv1UNUhcGSV8FM3cEnySTr/gQu+/EaDlA3loz3Qo8Miu91sItV3hr/av/62quWBXlsfvu4qnhVmquTsnxZlXuObKC1rRFIh6j9FaJKxdWj37mJYV6dgRh1xCyymg1xBOppaiyS4dRYMIMM5zK09kSYPMSjWsWHOGi7FOkiy77Si1szfZQcmxUTeKyrgluSh5EOA717Agf73FwrQX8Irccy7LxWSY3LKuxuCfOocl1PJ5OUhJ+8hUb252pWRy9j2iSQ3ugRt72gfCkY+quynarhzdyC1AlB1soOEJGkwUdagHHCjWK/UPTGyBJ8WYicnWNpwrn8tErrkLb/UOQJdTp0/CZtvX8rQkK4F0Y/0fPWi7bf5iD77xBas+LfH9wHel6AHlaxdIVTHcbHI82/cZJkqd62aLXqQk/+0oJtpTe5PevvJyJ1+7ELk8dP8GGAEkBHPZlfY2TiIt89KMjXIqThwkpJhM1Pz/48b28NeGbK+h2y38l9eb95Pe/6HkbqPqcXfSxu+MxM47PCnDtRct48MksKVNtOJOtj46RNMo8N7mQsXIYBRdVmjYAsoMYSoFP9OxhaTBFUe8m0/tJnn57alreWueTl3QTmfxHDtHDUDVBXCuTt/04qJREgH05g2rN5H89sJ1csUY8qNEdrDJeNhgzI3QYRa5IHqCzLUG6Inh+OIE/0oJ/2vMhFISFKzc0hMtmo4fbaPHbGFTJWwYRrUbB8qGrBbTU61TT7pzC88ibB6lt30dnCGRJoSNoM1YCzTWRZIUCLdRshaS/giwpJFtjDI25ZOs6XdNzBm7vlVT3Vult95QsO1vCHBjOoCgyXa1h9hyq4pMdTKGSMBzSVQVTKPgUQUfIpcUPY3mZrBWAqTyVeoSkXva61VRPtiRr+emyM9j2FIce/QZW+Qsk19/IgeEM37tvG5VSnjajymTNE1X0ur1kFFmiuy2K5ThzuqdmqKYPkXvvGWQ9wPMTvTzwnp9CzTt1CEml28hQqKn4dIeINIWk6OC6dGpTXNX2Hk+klpKqB4kGmaXI6jHz54Pv7sHMCJIxT64kbxqERIWiGyagK4TdKcZ+8Y+8RQ/f370GxR+nt6ubVDrL93/+MiuTAiPuDRIuWrqUFSuW8eDhEqrkpelMFAQykVgI1R/1bpifW9v4zOvhJFYlh2vXUPxRMjmNqquR1EsoikxQNRmut1LNT/LUGzYvbbe4KqlxaetBVoXG2BQfJmv5aA1rLF3Yg1nsop4fRVgmuDZf/INL+UzrxRwZPEBt29/THawh3ATpskvJ1imY3qT60QFWr1tKwSGimewvJnhofBlVG0yhYSNNp60FllBQcBrfN1nVaVFc8jWTkbFxJosuNVejI2AjSzoxt0bGdBk+coTuwgRIMnY5gxbtAPfM1hd+q4ICeCeGda39rPvIZoZfjFN84EXuPthPzvJhC4mYVmN1ZJzXMj1U3KOFzaBcJ2HUsKXp3a5lMmUGEcjcd7AH17a5/bw2JFUHSQZx/CyiEIL7RlayLdMx9/HGHxxUyaXgBFFweOHtcUKJTrrjBunczOnhZrrOuYlAciFCeB1Gs4X9Zu+Onx3v4bHxRdTfeQNV1Vi1uJu++usMyPvpMvIgKXT5S5wTHeHR1HJcZDRF0KqUMV2Z6zt3sySQI2sHWXbeRdx+0zVcP1sp1jrAoUcrlH2LMOUgC2I1nJxN1tKomS51s0os7CMZDzGVr1KomPT7TcItEuNFhSWhDFszPdSzAQKaxJJoljG5ncFUDU2VueXylSec2PS39jeK6I+nljBZD+FTXa5q2Y2y6zUOHLq3cYz2t/bTX/Lh1/aSqUAiIJGzdAKGYOWln6DLyDO17SUMqU6urtHe1kq2ApFYgvXX3UF3qObl9GsRgi8+2iiaVus2LbEAkgSVqoWiyNRsxTPfUV2SfhvbdjB0iRa/J6Xs12HRuotIv/0QfrmdvO0jqtbJ2wZ+2SKuFGh4TQjR2PX981NDnua/Y6HKGm0Bl4rlIiMIxxK0t8ao1Gx0TZlXgG3mFJmS+nlofwQh2XT5c4i6RsHSkaUEIbnCNR0HWRA2CS24zEtFOjaXth5gaWiSjB3i3Ju+zDkXzU1PzRTVS+UyTmklG5I5Luwu8+JhldF6BE3TuLIrT4cyjrBdckoLVVsmWp8iNeZALUeuJvO97/1PdtcGsNQIQZ/OioGFSPI73ushzcwNSLiKv9EdlRNRFk9/5svj7+HUiyBJuLUCCd2zZs3bPqJSnaJtYDkCQ7VoMSrkTW1aVDLtGTQZGboM0ELJRpA5UtTIuCrxBbdQltfSDlz60fNIhcca15lpJXAkHcv1PNVtVzROcKrkEFBsVFXizfIixqqeHLozLTg5G2V6itp1QUJiqlAn5NdoDUqMyD5c1yFVVmn1VchZBn6/jDG1DWTZkxcXAjMzjBHvPqO2nr91QWE2PRd/nj9qX8aKe7/N7rSOsE2WBCbp8hf4eP8R7hxazbvZIAoucb3mDZhEO/j5/lZGKyEkyaU7WEORPN30c9/eQaA0BcyTfhKCsUqQ5zOLAAgYMpW6y8wHI6DYBBXPyMWvCc7rMXn1iE6IHNVUHr/jMFHz8+ZDf0dVfa9RSAYxVy10ene8d/9hHvtfO7CqBVxHMFTxc3hcoa/jPG7q66LbeZTReoys5Wddh82OUg1XCxGVi9RMQUCY5N043z68BkuNEn0+wKdDni7N0XbKAooeIFKfQpFaOFIwKNsqqupdvMIFy3ZAAl2VPbEyW8c0QVcE+0oJ72gftMjWZA6Xw1y4qZ1f7Mpg2Q6PvbIfq5JlZadCd2fHcYqgyfU3cc2+F1nVdYCcGyVYOUhXoIQRXYFr1+Yco1euWcOnLtvBnc8eYqwAfg0+ddkA5235fQASKy4n1bGTe16eZKImEfTREMibYREc57f7hY9vADwFVr+he0FArqNh8vGlU+iRdu5+EwazEkFN8JktvbRLB5molVgVHufNfDcpMzTXVxpAUTEiHdjVLHv3H+aZNw5Nt096OkvpqkJn0OGj7aNsr7WQzlfmDMMdy0xNKjVZpmolSRp1cCR6Q2VGqiGu60uxoXWK8668lVD3GsziJJl3HseaNrPp8hXoksskqu8AWxo/d/YcgmYYjE4GeHBQp9NfpSdYo2L5sF3BSyNBApUuLuscpS2kYAmVfTkNCROBn5Bi8sZEBE2epL0dSqKVN/eMk4gFyRWr1GZZyI1NelLeLRFPTDDZc2OjO08NxACJwbEcGUvlvPgQr2f7mKyHsGUfmuwSUusoktQ4nWVM/xzHPuHa2JUcTw6GeXR4GRkrTGXnQXTtMAGfxscuWsr/76a1SJLEPz+5k5/vtambNo7QKVugyw665DR2/xVHw8Fl64QP1/VSxl4mYu59wpk24PL+LEE9yxUdwzz/+C4eHV5IxXaoVBXytQCdrWE++dEuujNlkHqwCuPgOgjhEl188RktNv9WBwWA+JKLOO+qKfreuAerUkRWQkQWX0PgyJv8+87DjNaijE1MEWOKTl8RSTmE27eeH+/tpk0vEjRkhKyRtuMMD+1kieSpZQoH77QgSUiSAopGzoxjCxkVGxxBUBFUHYWwWuffDLxC0ihTUDrp6urEruXYMdpPOlsk5hMUnCA+2UQdfQmnM3pSPRV/az/Z3ZOUSiWiusOhShBZEggczLrJw4fa2KNeyLZ0Cy4qYc1iWaLCWuirdwAATA9JREFUmNJDpR7CH4TNS1Se3Z1Ej+gsaG+fd9p35mTy1M+fomI6jT5+Q5HpToaZzFaoWw6I6WG+TJmRcgBwCSoWkuRnIFBAciFmKIxbLfxiV4agX6c1FmD3/iH+7r5RYrpJxHD51GU7+Pznbp/ze3ZccDu88iM6yvtwfCWMWB+SLCNJMlYlN0c76POfu52PbNzJyNj4cUHG39rPpz/Zz0UXzz9bMMOJhOlmHjMtBypp4lqFpYv7ePitEvqBV6hX6ugBA0UP8bNn3+Px8QuoOgoKLhuiR7i8zZuP2VVoJ6FX6W8PeWkQPUDaCuC4Lr3JIMMTJq7rTY6f05LiX6zI8qnzLzhO1O9YZt6rlufu905ElkFLOMJUsU5IqXNeR5FzL/0EbetuaHyP6o9i1wog60iSV/3KT2sFzZaqLtdMWiIBDh3Komoqkitj6wG252w6ozIJKU2uKvF4agkr210MRUc4LhKeBwmAIyQqjk5MqlDMTpHoaWUk63LT5hU88ep+hlMFJAkU2eu0yuSr3Hb12sbvO9OdZ0Q6ePJQmAcOBamYDqFQiCvPC1CTIjz7bpFMusCBcpwOo4wiecoFCb169IWSVRQjxGg1zJOZNYiATj1bpW7aVOs2+VKd/3X/dna/9hRXdAzxT+8tRFEklrc57EvXKFue7HZcq7M8OsWb2Q4UWcIIJziUtlBUGRkXy54xaD06JCdLEFBMIqrJxmSOqxaVUH0x/vrlOC41Vg10MZazcJH56r+6kvP7JA7cF0AIgT+5BKs8haxqJM+56WS3vF+Z3/qgAPPLEcy0DbaLIySCUyiBOIqRwMwMMyDtI+brwPV14EtEGc/bSMKiWq4ghSSEfVTVNdC5AqdWwKlXiVWyRDQLZI1SHUxXRpNcPta+h/WxCRAuXXIFrZ5DUhRuXN7OA+8ZpKoBFBk2tJXBcZE13yk9peNaBZ9skzN92K6EIoEkXEL2OIdzIfbaXZ7/gSJwhcqw08NXP38Zuqagpbay742nKBZ6aA9aWEWOm/ad6bNPKwM8lVtPa5tNUlHZO1wEoC0WpG46ZApVMoUqIb+OHXEJ+DRaggrZYpWRTJ2C0UpHVCVbERiahGV7Dl7lUpFCuY4rJGJ+CduBO589xEc27jzeQ0DCC7ySNN37P4awLYRwGX722yhGoKEdtHL9jfN6EMww0wI4n+jcsV9z4sc81V9vF/0SPl+Ano5W0rkK//uZIazSEjQFkkaZvKXzbrGDoGryen4hNUfFJ5t8zJ3g6sXV6XrRIoK+vQihs6glSzpfRpUcNkd34U9exKJZv898fiGzP+ebe9Y2TkRTtoQ/Lrj1wjY2b/nMcRuL6OKLqW290wuysoIe6UBM56tHa5FGEAz6dCZzZWzHRVFkVEUhFDSYLJiEQxHCkRb8Zp0jE3kKchonnUVXW1jRqlEtZpGcGqO1GHlTJWsaKBVBzMnSmYxz65bVLFnQwn//8UssaI8iSRI102YqX2H9dLEbjp6EBlNlHtzb5bmfhRxq/hjPHlIQwiISDqEKk+GpGmO1MB1Gges7dtPlL02LZqnIioZihJjKqtQcmYBSp1ozZzWfeAIYr47H2JMNkjNVdNlBVVx6IjbDecHFLYe5vGOYjBVgR7YDRZYZywscBxxcwkEd0zFxhWcwFFLrXNpykFWRCfKWV29cGs7QqUXZU2+l5mokjRKyotDbnWBoIucpzrb2NtLFdjWL6gudtnPkr8LvRFCA4+UIZgJFdt+LTLx+N/6Wfs8b2BehLzfKHyxayH07JfaMFSlW6gQ1l7sGF5FJOlzacoCZHVA9O4zqj6IG45DNsCo8zo5SH5IAxa1zSesBbu58t5FelBQNx6zimlXO5xl6+8I8n1/Bm7luXhuPsIOPcB0ZPrby+P792RO0Sxf3cf3CKe49kMQVKghIaFWGykFKtve2esdYhZKjI6oq6VyF69YFObD1PuKGTkBXyNUF5MbIzpr2nd1n/04hSam0ioG+HmRZwkLh0EiOIxN5WmNBbrt2LeuXdjI6WeQ7P9vamGwNRyLkqyPYts1oThAKBrnlksU88ot3mEhNIrkWliuhyWCogoghMVaAkbHxxk19ph1RUnQCHcuoTOzFKqVBVpEUFckRONUCRrznfXVlzKc4+su0+E1kSpTKZbpiGsL2poRTUzKOo9Gi55ARRNUao7UoL0wtwpAdOoImZaWVZ4q9XHv+BSTXrCGJl7b6wf1byZUtgrrMdQuzDHRGqab2NXrTT2fdp3siAkiecxP5Ay/i2hZasAXXriFJ+nEigisGWtmxdxzX9YxWuyIStdwEstDJTo6gOHFydgAjFGf9dXdQnthLeGQcS/ETb5E4NJKjZGsN6QkXmCyYbFx1VKaiNRYkW6gR8GtUqhbxsH9O7WTmJPT2Y49QMR3agzb+WCeRcJx3DqZwHJdFPQmS/QuIx/McGc/x+SuWcVlXjF3bZSYyZRJamS5/hdrkQeJqD35dJjWZxRGztddmSsGetamOg+NKDBdVkDQAdhR76fGXWBr2mhDGayFUTULXFUzToVA2UXHo8FVxhYsmO1zePsSeYoInJpd4Kq4pi6uKe1ndPYxPDpOzDG84MFVAuJ5sB3j3qbQywNj06Td5kg3PB8XvTFCYj5mbR+adxxodPa5VRQsl+NQNF7NwreBPv/UQfr1Eq14iW5N5YmIxS4OphkuXU83jmjWeSw/w+Pj5VB0VTXO5MJnmkvCOOblMAOFYIBwkVZ/uYhC8PRVFkWsEdZesFeK+gwbLou+xIGwSWXwxMP8E7Yyg3eMHIzw7kiRlhnBmtdsKwHTAdFwst8r37nuDymSCddN2lDcsLfLg3jATZYmoYfPp6zbR5StwYNYsRLxeRrNzpNJBkq1xdEWlvys2R4wMvIA12+lsbHSEuJTlUz2D+Hw6SzZuoa91AnPnDh462ELRUpHRCWk2hiLIlB18CrQGj67/uBbcSBKrksWIdyOrOvXMEYQQCMc66alqNqfyNTjZ9x03hZ7ailKdYKzsEvO5lJU2opEIdbdA3jKm24N9qDI4sp+4L48R7cKvhxjNWXNsHG+5YjVLglO8/eQv6GiN0xsD4XY0fic4fkblZOue77RzLP7Wfjo+cntjJ6roAar9N3PXIyNzxOd2D6b52mcv4dWdR3j6tT1UcxP4FJvNPTV2pALsGq4gSXXa4gFefWMHm5zHuTIR4v7DPRyxQpTN8LQakYc8HRh2HkhxYDhDl6/AohbBo2/mpp3dZG68ZNm8bbfrlQGiR16hJqtEwnHePZQiW6wihODt/RP0dUURDgRDEQbWXsQbuTL/azhEPj2BTza5uuMAlyYPe54cao29Ne3Er49SJ6hITNX9mKiouPS1qGh6K89UL+SyG3q4skvnn54+iDs9CyVL4AiBJINhaASkKhMVH09PLWfbVAsSrneCtD31hWXh1/hYb4wnplax+0iRUtUkHDD47z9+mXSuDMAPH357+rpP8enrpDPuyvY7HRTg+I6emR2Yv7Ufdr+OUy/QHqijyD6iToFUPUTGDEwHBY/RWojHxxfiCkHSKFF0Q+zMxtmc8CMpVYRjN75WVg2E66CoOgLIOWFqro6mGQwWJVxXwkHh2cmFfDryHpndT7Hrzdf4x/3n42oxQn6Das1TZT3nK9ey+Q/X8u7PtlEZHkKIuY22swf0oiEDXVW55+VJkgvjdE/bUS4OjE+7dt3EyjWryQ++zuGMp9PT4roMJOHanhGezrc3iq//6uYNDTvOGWZ7Dh8encQp5diQLLCg3VM/FfvuZnw/XLFAZ1WnSipXZveEwqvpDkbz4JMsrukeRtu9j1SwQnL9jcdN6rpWDVlRkWQZRQ82dC4lRTvpqWr2zeVEsx4nCybz7dDDPWvxH7qPj/XFeXSoi4mKi1/N8oeXdJPdM8GDB+KkTE8uZXPyMK/n+shbOlJ+gpyZOU67B2Dp4j6UXRZCTCDcucqbv8y6T4djU6sPv1UmnXuZnmRkjkaSrin8yWcv4aLgdva9/hoJo44kq7w3dT6tWp24YVGvF/jxU4LOjTpqII7lSlTqtteqPbsRR/JuoHXLYc/WJ9g39CQ7d/eS1FX0YISirfPy20d4btsgl26Ya9C1cs0aPvd7Ej98+C3e2jdOtujJmWiqjOM47B/KoKkykaCPb/zgBcoVE0MRBDSXuvDz5NQqysYCnj0cZKxigiRQhDPdLTRzvXifq8l6GE120BSB7bosbIGoksM1vaaQyYLFH9x4Gb94N0OlapHJl1BkcKenVoeLGhIatguPjS3Edl102UGg0u4rM1IJ8WZ5IddffwXnxM/lP//jc8TDfrqTEdK5Ct+7bxtCgKGpp/T8/iD5nQ8KMH/NAY7m7QuWn5jPoeiGpgtXlTnfP1VVqToKSb2I5o/SGe9leKpKxd+HEQ0CMo5ZBgS4LnYlh2ObSEBcr6DIMFbwDHNkGVwXXhuSuCRq06nlmJiC8akSpuSArHkFK5/uGcckIjy0owCSTNCAUt2ZFQy8/6uKRN10pj2DTdzeK5EyD1GbOkSXrrJ24w10Tx9LH36rzPd3LadqywQ0mWt7R7lqYYlrTqPYOVOk/dYPH+GlHRIvj7ewK+tJPX809BYCQaBtMb2yw4KIzuroCB+77FwOvPUiCb/Noq74cTvg5MZb2f7c/UyOl2gLR1iyajXV1D7sahYtEAdJwp6+eVb7b+bNUZkdz73GYy/vn1eX6NhAcyKJjRlOdLIACcescO3yOGt60kyVZUL2KOcsHGAyP8yqTpWJTJGQOUyXlqE1JPPocA8TNX/jdZ3R7jlRy/GcDQrHz6icbN3vh5nU6k+f3sV3793GVL5CplClryuKrqgosszoZJF3d+4kOvUSCV+dfaVW3s0nKJgKHUYRv+KiuzVS9RC7UyqPjUW8eR9JICuCmsuskiuoikwsICMPPclUVaUuDBTJZmiyhulaAPy7v3mcP/74cq5bF5xzXc64xn3t20+iyBJ+Q8NxBRISluPQEguydEELh8ayjGfK6Aq4ThAZgaZKPHkoinBMpJm5HRRkYWOj4JNskCQsV8Ge9ndQJIjpFo5p4k43hfgVG3noSbou+Qhf+PgG/vafnsW0bHTZwa/aVGwNC2/SWZW9dJRApu5KjNWCZE0DF5nHxxfy8s+yLBt4B8t26euJNYLxnsNphGuRbPc30pPHqvyeCZpBYZpjaw5AI2//8GAb4yUNQ7K5MrmfrmANCQ3hmAAkfDb+6anQuGV6ht6RKEs2bkE5dB+OWQHX9iSJhdemKswqQpboCatcsEjn57sAV0ZVBF3BOqYlkS65dMYlbMVP1dEQOAQDGlVTUKzUMS1vkMmadvlCUvAbUqMVVpOm20UVFdtxmcyVCQcMlm26CuNQpTH9mt3zDFq4lWLrxdz1wgiKP077tBrlI4eTXLx5M+edZi7z8Vf28ej2KRzbQJNdXCF4cE+AxWtb6AnXjrupaUHvxq6Hkkiyc9wO+IWphfzg4EWUq3WCfoPPrtnEdTeHGgEcvN3/w2+VueuRESZzjzGVrxIP+Vi5MHnc7upUN95jOXaHLmt+zNwoVinduEnPOK9JkoS/dQBFD9AhJljQn6BeCIHr45OXXsTyl5/yTmBBl54QHBgRjG3fx8KVkRNahZ5uwDgZJytOz/zbSMnHDx9+G0NTGeiKc3g8x6GRHLGwD11T+M7PtuKTLDrdAd7OxEhXddzpTUfJMujyF1FlgV+2sCo5KnWXqG6SlQMIV6AgezaYyKiyTHs8yO2bO+jMZFGMfhQZRos+LFdCnt7T5AsVvnX3y4xvPczyRIVV6zc2DJp0zfM+cFxBuepdh0ieAVMooFOtW4QCBo7jYkkyQV2lUrexTFBUl6RRJW/5p33IJbwVeu2mJcdAkxwM2cVyFVwUPrLIYM+wSaoa8DwtllXo1L124lY9wA3d+7i31k7NUamYKjN2PiHFpCr06XoMzBj8VF2NqGai+4McTpUZHN+PIku4wmXpAq9pwS/XsOt5xkacRnoyGIzPO6fyQdIMCidhthHNZNGlxW/TqVeQtQXImo96dhinWqDLyHFV2x6emFzKeFkjouT43M1Xcd4Vq3l35zLee+kB1MxzdBoFJFkBWfOOAwJcs8LFvtd4xX8ONgpxn0PNdPErNnGljCSraHitdaZQqZkOmqri01V0TSEm5YnoDm5A9UbwHVAlF01xiBsCTbYYL/sQioSuKXz6unVe3WB6+tWYvkGn3riH9LJOTwa5qxthJ/CbdUZzFlZy06lfLLyUzU+feRfXFQR0Gct2KNUlJBRYdB0dCwNzbmpblav5+QN5cunF+BWXG5ZVuKx9qLEDnumRlxSD/p7ZJjnXzhEUHK1FuOuFR5kqVMgVa5iWw2SuwuHxLH0d8eN2Vye68c7HSMnHO4Uk8XqZLn8JMzOMEC5Tux4h2OWdWmbfpONLLsIqTx1z876dcM9a+t57GiFG0QIJHn0PHjm8HOfAIKHHUnNOM/NtUN7vumc4WXH62IaCQu5oQ0E0ZDA4kvU+YyFvmOzIWJoXxtumP7oz/nZgIzFaC9PpL3F90puQN0SFYk0lpNTJWX6QIaZZLI+XueG6K+ns6YVKmrHxON3BCc7rCPHzQgQASZIwNJl63SJV0fnJ/n6iSpmrj7zMNftepL7kX7Aj10ulZqIqMo7jejabAiRFMDiSZUSV8RsaiiKhqwqmAN1QUCUHnxDUXZVWvcRYPYwtZDRsOn0lKo6K43hdg4okITQNW8hcfME53DD4Q6aqKslYkA51gqeP9PDUTw5QrtZRqi30xxzeGNNxxYw6AlRcT5jTnQk9kpiecoaSpVGYsmc8d1AVhalchf1Shqhf4oaufQghGulJRcpx0foza0EAzaBwSmba/OZq+N+DY5bRQ62YkoJbL3FZ5yjL4iUydZ2O1giXrfs9T8vm/tfJTQoMNnFV214ubT3Q+NmSaiDJKu1ighsXDPLoSC/ZsoRfsbi64yBdvjyuqRDXNFp8dUzhEE8mqdkyPkNFS23FPXQfV0RDPFrsBl+Umqog6lWEpDBVUwhoMu3+Kpd/pJfbf/9KFvUkyA++flx++sBIhszIxBwZ5HxJEArqp7UzqaYPcfDdfdRKOVRhYdmgSoKq0PCHoyzbdBXJnsRRWYqSj/u+/zaSYtDbkWBiMs0D7/kIO37C7QNUd2yjbPTO0eo/0fF5IlMiW6yRL9aQJW+nKYRgLF1ClZWGJeZsZm68Xmvq6/PeZL3i/tsUcqtQzSxXtbzDpR1gxHuRFI1qah/dm/81sqrP+f4T3byTG29l/JUfsf/QGA8PrkUNxunpajtprvjY2siJAsZ83xOT8gydwMYTvMK1Y9VQ9CBRpTSnoaBSswkFDCzHpTUWQJYlFM3Adj0pF6nhFigh4RBQLG7oeI/NrYcYq0cxdJXBXMj7dwl8ikBXZVIVja27jnDg+WHKNRPdPZerk3u4tO0ALw2vZLLmR1EULNvGQUKTBG1agbqr8nhqCQUlx2uv7KYkpzAtx2uRVRVkyevYiYd81C0H03Kw7Dot0QDRoA9ZlihW6/gVh48E9vPKeJw6CjGtRsXWWBDIEdAEFVshYwVxJA1L8aaWk1E/mzasIdx30/S1P8lIOc7jqWWofoMFSYORoTSDOU9IL65XMCSHouNjvBZGlQQW3o3fEfK0HprUOE3MyGbUTAdFhp5kmD+8MApvP8a+WgcXduXZl9XZl9F57JVBXt9XOE5Q84OkGRROg9kXor+1f84Fn3rzfia23okE9ATKDHSEQZTZu/8wP3x4GNexSRplr3OpMXLvmXhLiuYZ0Vs1LmsfZlk0T7okEdeKdBkFhJBAlukyclzdtocnplZQKJaIxBJ88pJu/If+ESEEH1ulsaJtkL25IA+MrQTZJmZUmaz6sB2Hzy0f4pO3fbqhMXRsXv3ornUUy5XnyCCfaIJ2NjM7zvqkid9eiqX5Kds6VUdBlhw+fnHfnIE4f2s/77w9NOuGH6TbH+GdAxN8791eeMfC//ybXNDxNLq7inROP87zeDbtiRCq5GBaNkGfiuMq0zcFB9txT/g7nGwXPXuSd6Cvh7FRmcfTy1m3KEF/TEe4bsMDYrZP8nyfmTlIMGXq1ByZ3qDSCHaHRyc5+O42unxHxQFP5dkwH7O/p1ouY1cXYmhKw8ZzkT7E2PZ9JCM6dn4C166B65KUZa5OqjxbPdpQcMuWlTz28n7SuQqW7TA4kp7uIvIE4eTp0SxFlohqdZYEUjyX6ufusXMa/hvgGdeYDrQYVQqmyqNvTtHbHpsunuo8lVvPZR9bxBeXCv76nnfIlY7OATkuVByNuF5lrBrm2bFOfJKJpns7bMt28ekKPkPz3N+6PcOrXLFGJl/l0g39PL/9EFO5KkiQjBq0tit8uW0Pk/k64xWDe0dXM1UPIUlV6o5Mi69OINKK5UqEAgZf+Pi0VHnPUTWBwQMmpXeGWDwdMNvbWjkwksGn2AhUdMVCFYIOX5HfWzjOoXKYl8ZbydY0DFWg4PlIw9wavOvCG7tH2XdwmFptPXXXk993p09mulmnbk+e0YJzMyj8Esy+4E/U6522ApRrJt3xINWaPD1yHyJj+hpBwWtPFQgEwrVJimGSfsdzqZcNJEeA46CGW1kXaUGPppGkKa685QtY5Qxv7tS89kXZYSAZJF0q4QrobGvFzB0hIWdIWSEUt0Zx+O1589MHRjI8fGgZsh6kpzVItsJx/rcnY3Yhtr/N4OrkPh5PLUFRFFQZLu0Y4bOXXHrc9824aaXSWeIBibFMlVLNwWfYJH1VcpaPV8YTXNi1lzetdQxNHB+kZnbEWmorH429x52pTgplB0NVaIsFCQZ0/uO/vPS4DpZj131siyfAwXf3USqX6etqQ5Ylkq0xDhZzpMsufS1zZ0hOlrM/9vkkRaerox3/QcHEZJpuf4RUOotSzWLueJ4DQ56MeLH14uN8iU91I5gdyOIBmZEJC9fRWRIoYwqDf3o7gl9biXJgEJ8quFRv5dK2w8iaD9eqsbllL1dc8odUw0sbJ5NkPMh3793GobEsruNMt5POiD166ZC4bnJD1z5A4qHxZRTM428rtpDI1WTUQAS76uL3abNOfyblwADnbwwRf+wg5ZpXaLZsFxcYrwZxhYQig2U5hPUaY4UamqJi2t7XOa5JKKCTK9aQFDg8lkcIwdOvHyRXqCJJMrqqYLsyPz+yhM8vtsiIOveO9ZOx/DjITFl+WvQKn95Q52O3f2Le7rWH3yrxw4eHyRarpHOVRg2gKCK0tMpsMHbySqqNtB3HoMoNHXu5os+l4yPX8/K+Mn/9031IwiaimuwvJ7CFOicoaKqMJAlyZQcHfVrZWQG8U1ndlTBLDs545owVnJtB4Vdkvl7v2VOq2QoEw0mmKpP4FZsWv4OshxBOHYSLcCzPp1nyulkAEHhT07IKwuWFqcU8MtRB1ZIwpDqHHniLfRPmcbn4trAPVdUYydcJ2gp1N0jQp9EW0+d09BwYzjAhryd2/gDmG09Ts0u0axmqqTzhcAcTjm+O/+3JmF2Ide0al3UdYmk4Qzm0mIRRZ0HYnLdDZlFPgpvXuNz57AiH0p7ctl+RSBpVZFkmpptMVP0sCaW55dpFlAMDcy7Q2SJtSnWC/pBBxHDJ1RRM20aVXf7NLefNCQgH5oj9zd/imdrhKdTWplzkyjrGRk06p6XEw5EYLf6D1POTjff5aDrx5INws1+nXtnhhmUVHnjPx9BYBs3O8bG+VMPycU595xSps9nMSFK0+2pMTU6C40cSAssW6HKVrBnGCBos7GpjIjXJ46klLI3k6Ja8Wte43YqvLFjYd/R19k4mEn/5/Wcolupokjd+VnM1grLJDT0H2NQyRnegzDuF9mmnuPk/KxNVP1LdKw6PZ4okIv45p7+JTIm6aaOpCn5dpWbaVOoWNhqOpLE5sZ+t2R4KbsQrELsOsqQghMC2BbW6zdBEzmu80BQ6W8KMpIs4LkSCKvXpWpMsw/cOrMOybApuHU2yUCUHZ9oXYYD3vNmJtf1zPjem5TSC7uKeFtxpOY79UoZ42Mfnf+8iLmnp5KKZGqTPZtX6C0me4xXHr+45xOCOX/Dw4SRFN0rC51A0BRXn6KyEQCAc0Rj0mzEKnXlJZ/5cqtqNAbcPmmZQ+ACYL4c8M6X6w4ffYrIeQQ/DVS3v0t9moAaSxJZfjhFuQwjvYDD60veRVB9mbtg7bwvBuN3K3lyIB8dbMHRI+iukKvrR43dHgiPjU9y1K0hEimDF11LI5chUBBAmptf5g6WjDCSD1PO56S6dUiO94FcF5/qG8KtxCk6QiFxlYjKNP949bx1hvh3xsakoxReh282iBYZRA9ETdshU04fY5DxO5zk6BdFCuZjlx+91kDMNYnqdnOXzgmjApdNXINzlNtJfB4Yz/OD+rbiOTUfI5UhB8OxIC2HdoSdkYTkOfj3c8KuA41Mxn7ykm7XHtHhKksLU249g14t0yBJXteo8kVrK4VGdUDDIH31iM5vXXTen8+nAff/PaQ2UHfs6XdY+xNKQD9G3HHffqyzqTjBc0pkqdxGyR+nRKnOGAU+UOptNeyKEX/VOID7FRUgzLclQkNuQFIfO9vbpIBPkYNagqHXha2v1xOGOdOIcOb7wfc6yToKGQq4oocu2p3813Xq5KJCiU8sgyUFianl6Ylmed322kPApEj5Do1Cqs3/Yu5nOPv2FAgbZYo267SBJoKkK7Ykg//dVXfSOvERHLsG9B0LYNQlHSKiKl2LyOo8kgkGDbL7KkgUJFEVhNF0ECeqmgzlt06kqCpKkki15NShdcRBCwkSm5uq8NmzQvmMb523pn/O5ES6UqiarFiaRZYmlva3sH57i09et4/KNCwHYn4nQe8UAF8wo7876HJjFSS7vHmd1j49MXcW04HtvhilLAcp1l5rpYNkCBXe63nA0OMwwExyCfq/R5EzQDAofEPPlkI8VV+vyFeZNM1TTh1D0ALIQEOvBKozxXKqfJ6ZWUXACZKuCTirIqkM4HGJ8UuD3aWStIFnHom46/MPupdj1KUJKhXjAJmf7AbArGfYdtulLKNNth0dTEhOpSV4ejXJxX52XR1RS1QCGVOfWC9uO242eKP9+bKukHowT2/D7hLvXnDSdMrNzHkjGkWQTOwFThcM8NtrPRC2AX7G5pusIXb4CYy9/n1HHIdC5grZ1N7Bn5xFy6THafVWsOuTqQWwhka2r5OoQN0x8yI1d9ey0ykwq5q4XRljysZvxH7qv0SUU6F7D1M5HvFqPqnNZ+zBLg2n0c/8lyzZdOacuAsxbsJ9voGwmmMaXXU52zzON5zv30psI96zlwNSDPPoePDrUSsVy8asRPrdUHKfYeqr6zqKeBLde2MYPHzpCwfIRM7yW5IKp4QtrtCf8VOs2Qb/eOPm0hWAo4/LokU5sLUY0HKJSteakqhb1JLhpUzv/8GiJmquhSi5BxcRQbDJ2lLFajS6pBBgoMiiSmDNZfxQJ23aRZRe/oTVupjO/06KeBF/4+Aa++ZNXmMx5p+b2RJAvffIjXL0uxIH7HuLy4AQr2+GHO/y8Mh5HlhVs18VveGmYRNhPvlijWLFoi3nSGrIk4QjPS0WWoKstTFssyES25NU7XGXaulei5Oo8PL6UN346zg3Z13jslf2Nz81IqkCxUmckVWgMmMXDfi7fuJA394zOU/+Z+9lvdLIZOdYlg2wbMnGJsqo/Qb4G7w5OYtkukiRQhTfb4IjjA6yERDIROWOtqc2gcIaZKzeQmPcmOfvGKisyaWMpz5TPwYjH6A8Gye8dYaIaIKTZZMplEH7G0p4mk+sKDE3GMUvkTJ2WQIGAalN2HMbrEe4aWkFsvM7H+iZYkXznmJREkINZlZgyyY2LbWyzzPJEhc1bPjMn1dLlK5xUYuGXaZWcvXN2HQszM8wlcYvF/jFyTpjWkES3v4waaMUspbGLaQbH8mS3voOt+PErayg4QYR1tGA3o0iZrRtEUBsXzZHBAxSLBRYcM6VrJT/K6vUbG+sujexkaucjjVKqC3T5iwwsCtDWkBM/elqabxBOkpQ5XrrzeWofGzCr/TfzyAu7cV2T9oDXj37XCyP8j6+snVex9WR8YssakuP3NVon7VquMbH+bkqaE2RmTj4vbt9Hduce6mWYKE6hyBI+XZ2TqvrXv7+B3L4XeGooju3KXreMo3H/2AqCwXO5um0vbUYFQ5NYFJXZn3LmOTFI2C7YNRvLdlmyoOW432lmI/XmnjGAOXWtmWskKQ5x24o4I04HpvCTKVRwXdBUCdcVJBNBNFVmcDSLEAJpOueiyBKt0QB9HV57c3s8iGVZTOU9fSOBhIKg5urkazI/feZdLNthIOnHqeXpiGlkizq2684J1MAp6z+zO9k0O8e1PSOsTNqEI57hlKJIyJJEwJBp10r4qDBlBeg28rxV8PxZZmoLAOeeRr3vl6UZFH5DmH1jzQ6DdXAXna0xhF2l019hpOxjqBymbksIHFLZcuN740GduFsmW49NnxCqTNTDSAjajBKWFOCxkT5adj+PXz2vkZLIVsBRQtx7oBPHFfi1IJGB/ukU00uNXc8tmyKsO8WO2N/a7ylrjpZorx1vF3ksM4Fw/JUfUc8cYVqvgu5AhW7JsyC1qwUUfwS7NMV9Yyt5Lr0QR8iE1ToLExUOVyKkqj4ANNkrgE6Pf7BmcZJFPQlSOx6gtu1+lGovI0Np2tu8ouBMKsbfOjdQa+FW7FIGx6x6vePhVkLd3uDevKelWack1zY9X41pL93Y8svJvffMcZ7aLcsvn/OcVnITjj9DV0xD1Q0iqr9RP7hwbe/7uvhnbGlnWieVcIANl91Mcs0aVsKcIAPw5miJtGinXNuNEBDwqVRqNrZjzslZ+1v7+eIfXsGmR37EuxMSD44vR1dl2tvbKIoIz5Tj/OuLu4llRihVLVS5gOXO7ayZjeO4pHOVef9tPt2mmTpYaWESyS7S29nBv1njBTnTdihW6vh0FZ+h8oXf20BrLNiQjYiFfUzmylTrFpGgr3FD//IfXMDuQ5P89Ikd5KvO9OfIRVJ1ijUHV7LQqTM4OI5ftqm6Kq2ROF/9l5c2zI4W9SR4eU4n3fH1n2M72VLpIE/n27nmUxfwR9O/w1S+4s2H+CXiSpVsVSGs1NBlqxFcFdlr75UkiY0ru0/7M/F+aQaF3yBmUlALtAxB317SuQpR3USRHJJ+m4Ile7IO7tyj+VTRRNNUYloVTXKZNL3+8E6jQECxEVKZSTuB4ta49cI2frq1wNBEDscR2LKBZviI+SRqtsRd21yk7dvQ1aN6K7P1kk4ksXCy9slje+0bf2+9mMSaKcZf/ScmnCSpbJW4XqVTTWM7FrgO9dwo944u597R1V7f+nRT5MG8y2fXZ9k3aXHX3i5kVSOgaVTrFrIs8fuXr2p0/HQHBTcur/HgngBDY1OEoy63X7PquBvPaC3CWM8fwoGH6dSmUIwgHRfc3phnmO+0tOjmPyPcs5bSyE7GXvkhkqI3XqOptx5EODa+lv459YIFx6SX2hMhQsEgeRNaA/7Tqh+cjJOd3GZuuMfmylVFRghBzXRQFYmATz8uZ51cfyNX9KxFfuE1HnkoRXdnAs0XxHAFQxMm8QUr+OxN3Xz33m0glT1ncklgi6O6QjMyLrKEp3h7GsysdSx9VDCuo8Wre/yPr1zbKAIfe6OWJOiePh0G/TpDEzm+8PGNdLWFaU+EePyVffzksZ3YtjTtpg6mUAmrumfyExZ0SRNsy0ZxhA9FEiwIjTE2PIQWam28P6bl1Spmp5Vmv38zDQAzQSPZ6g1UpnI1lgQrfGpzD1qolZEjR3jomddJ1YIYUo1NsSFenOpHlVwc4flMSBK0JwIND+0zQTMo/AYyW1xuNGehyDIrozmeG2mdTpHMDQqWI6grKrd0vc3SUJq9pRYeGl+JInuTnnnLwKfUSBh1LtyQ4KKLL+Kep3bxyEt7yeSrCOEdX326iizVCRgKi9p9s/RWjuolzSexMF/Ofub4fGyudcVAK7sH09ODSxWuankHq9TK46lFVB2l4VB2eecYAomRosEL6UW4SPhlC1solCwDWbahNsStSy1ygRU8+U6NSt1qKGxeumFgTs7/6kUVFhkjTExmSUYN+tOvkNpRaHQKzb5J+tXLuPXCNj6x5agV6skE6aID52EWJxGugx5OIMky43Y7Y5OTtAQc9h5TL8gvLfMHA/O/36dbPzgVJxtyO/b9GkkVsB2XZCJELOSjWrPwGeq8Qcnf2s+yTREiLz5KtgKtuiCVzuKTbGJSnguvWMM5y7q456ldPPPaXgrlGpmihe14MqLC9dJ8YbVOfPCHpHbkG+9BNX2I0sjOhg0twN79h/nB/QcwHYWaaSMEVGomtbrd+IxduLb3uHXOtDwfW6ifSUfNTN87rsDQFexpcSZXeMVkXVP46Ioor2wfpyNk41MFkxWFrRNRXv/BdmRZpi0W4KL1veweTFMs1ylVTXKlGh0tocb7d2A4w+hkcc5QaDpXQXcrPPPgnbw8GqVoaxj+MJtXt3FtzzCOWWaxPsy+UgsVR6PNqJC1/LiSgkDips0rmtpHv4vMLlJrqa28/IvneW6kBSFgdlDQZHCFy5b2g1za6rl7eXLdkmfGbobxyzZXte2hQ5li5PnvUO2/mVferiPLMq7rdTjgMu2i5hCkxtiINUdvZdmmq+jyfWTe3efsnVC5VETY3o3g5Zde5u6XUt7U8vTN54EX9rAgGSXulxkbzXFndgHQg0GdpF4ibxs8NLESRTVIRAMMVaDsaMjT5uea5FATOr5QkLVXfpZFi/v4m9Z+nts2yL4jUyxZ0NJoQ52d85dVH232fpIxCHStnOO/MFqLHBfUfrq1wEUXR1g0/TueSkhv9r8/O9HLg3sCVJ0WNF+QSrlKSJtbLzh/49wU24kc384Ex+5cu5MRssUqiixRqtZPGZRmB7HBw8ONHLn72guknFtZtP5GvvbZS7h1y2omMiV27B3jzsd3Mj5VxHUcoprFZ9cX6Q56lqppZYDX3niLg2+/TNhNszScRVIN8sRIm0Fy6V6ikSiOKwj4PKkXv0+jVK2fsEX3VIF2RjNMQlCp29PXlYcsS1x6bj9XnNfJs28coD1QxcKgYsnYQsYnS8iKzHimzM+eeZeetiirF7U3gutXbruQSzcMzNlomJbTGAr1q4LzIgd4ZSxOwdYp1SXS1Tr/9PwoIbWfpF6k1x9mf7mVgu1DsgWtvjp6JIpu+Lh1S1M6+3eWo7nVXoLty7j78AtMFS2wjvrZSrJEQqlyXnxkWqLYy41e2nqQpaE0B8wekBRWJFWCHcuxKhn2vfEUpfK5CPdoIdALDg4hzeQjHVl2ZRJMlB18yhSfuqR7eh3zF8pndmXvHThCvlibFjUTPPf0U+RKbfR2JJDlIAG/hm07lAoZRlKCWl3HG4cCv6KhyN45aLwe5PuH1mG7EpIkqDuKJwwgJCxJRZUFl53TSzkwwGgtxCLg0g0Dxw2pze2MGgXXRW/pRTWCCM3f2OlPFOVTzgScSpButqLrA+/5EBL0diQYq/jI5qGnq41wKDCnXnByd7czx3y76M7WMF+57cI5KZiTccsVq1mZFOx4+NvEDZOBZBCrIuY0IMz8Pheu7eXqjyzh5RdfZvLtB1mzIEhvzEG4CR55x+KnLzzLRN7EEYuQWUhAMfErFpos0HQd05YoFHLIUoRKzUZVJKo165QptpMF2vZEiIBPxRXMEqsDVYautggjk0UIrCEciZErZ1CEheUagBcQqjWrUS8ZSRfw+1TiER9HJvKkc5V5T88zQ6FLgmnefvIXPHEkSaHu1cFc4TWgmkKlaGu8nOmnzSjRYRQYr0eYqAVoC8CtVy8/45+RZlD4kLByzRq+crvE9+7bxsRUmUrdwq+rtEUUrgm/RU+4hmvJeJNvAjWYYCxwGU/vj1LMZ3kipXCDWeTyrgqVUolatcZk0YZpoa7pSi9hzeLapQ5bKnuYSOeJy0UGcjtI7VBO6E62qCfBFWtb+Lv7R3GFhCY7BGSTd7IxhARHxtL0qTq5VAZcwWRBTHf3zExqgiWmJ1clT1vHmfYpth31aB4aF1mC9f1Btg+W+MXup08p/zCTXy8O72T8lR96/tru3Inkdm3+VMOxN5xTdVkl19+Ir9iJ884bLEhG0HxBkkadkck86YJJMOAn+yvWCz4ITrSLnm/y+2R0h2pYkdRpeTws6knQtWU1B0p3IUQJ4SYYTJW5//Ai0hUbL7vknVpLjk7dUVgUmsKSFCRFRxIWPlWi7AoCPh2foZ5Wiu1EgXZRT4JLNwxwaDSHpshYjouueVajEb9EIZehcngr11ywiHtfVCnWTVTVQXKhUrPn/CzLdtk/nEGengv53n1vcNmGgTkbDb+hMpX3CutLF/cx9qpMzYKao0Dj+hMIIVBlgY2MIdvYQsEV4ADpXJU7H99JMh48o0Y7zaDwIWL2zmemsBaT8rivvYhjtaNofqxqHllWcNffwWM/m0CSi7T7q+RMnft3+xgdddma6SNfq2BNp2WYKbMJlw2tUyQZwbTGaQ07SIoCcuyU7mQruxRiuknUcNDcCkXbYKwaRJcdbFOldGCChF5mVaTOO4X2hhOXIVnY0yJhllCRJIn2qJ+pko0igW26BHw6lmXTEfdTtWCy5ifoO335h6P5dXHcTh+g1TrAJy/p5q4XRk6Z0z+VIN2CgUWEw3sb+fZ8ZpKYWkVUixwczBKOxPijT2z+tZwITsYHka56v94Ux562svUkVdfAdR1mSr3u9OZEIOEIhZhhU3dkfn/JJOu2XAuB1tM+zZyKW7es5v7nd5POVQGwLBdcl9zEEXRMfvHUNl7P92GpLYSCYTasaOGN3aONGQo4OmFs2d6GZUlfC7qi8swbg6iKV0cwHZvDo57sxnfvfQPYQN/qa5Fe3NsIhDM/TUbgShoqLmVHJ1v3406rTGkKTGY9850zabTTDAofMubb+aScWxvKrZo/QnLjreyXl1LI7aZFTiMJh7BUZLQW5vlUL4bisMCf5UApgZBkOgNVbMdFlWwuazuEXSnhWnUkVUULtmJEOk/p8tXd2UHEcHFcgTK965cQ9AbyFGwDIWRu7dpB0ijzV3s3U3E0aq6KkGQMGSJaHcetoyoSlbKGaR+VS6jWbfyGim4EkVUXyz6q3Pl+jEeS629EC7ZQTQ/ibx3AKk9x4L7/B8essFYPsORjN2MlP9qYzTiReuqp3p/ZDnRKNcunlqZY3aWRypVp8R9k87rrTvvnnUl+1XTVL+PxMPu05Y7m8e98DVnSsaeHtTxmZKZdchXwqy4XfnQz5330eOHBXxVVlqf1hsB2XBzXBddmU+soWzM9uDh0qClqaoiRySJfue1CvnnnK0zlK9PGPjTqEYauEg/58RsaQxM5tmxaxHPbBjk0mkOWJfo747iu4O/++XVu2bIKv/8IuEXKjg9nelBNwSEo11mRGOW9UhILxTMlmrbpcYWgWDbPqNFOMyj8FjBfWiO9cyeqlSXnysQDfoqmd5HZrkK7XkWWoMNXZLweoWpBVLPY1DJKXkpARdAuFcF1sMppXMdED8ZP6vK1cs0aPnXZDu589hCTlXCjJdav2BiyTaoeRJVc9pZacVCoujqOkJCRMHSHoGJydec+SkYPd+/tAOEiS14ro+O6qIonF37NhYsbyp2nK/8A04J007pGwnWQJAXHrKAGYo0WU/+h+1i9fiPF4Rc5cBp6RidiZhd+8N1tmDueZ1F3Amnaba6en/yVLTR/k/hlBhdnTlsLeZ2b+o5w9+AA6Yoy/XlwCaoOAc2lJMKEo3Fuv2YV52259IQWq78sE5kShqGydnE7pu1SLxdITaa5oXMvyZDLC2mNpFFCclVPtLFo0tcZ49/dfhF/+YNfkM57JwxD81JAriuomTblqlfvuHXLapYsaOGvfvgLWqIBTMtmYqpMzbT5+59tpVIV4PqRcPHJNn7VYm10jK6oxAb/bj5SP8LfHryQkmNgo2CbAnBwhXtG04/NoPBbwrFpjeD4M1yVeIfHU0sYK2j4Nbi0ZZCtuQXkbR9RtYYqe4Hhho73yDphXs/384uMhiG6uLY7xubWgwjbwqlkiW34/RNqGM3cED7/udv5yMadbHv3MD94chCqZVwBBduPX3GwhScfHlJrtOgl8pYfZJV/sXySfmc33eEa+0SCuM8mpNTwxbtRfSHGp0r80U3nNiQRkvFgIx/uVwWfuLCNRHU3+cG5vgazVVS19/4JMzcKsoIRX4DrmFilKfRIx5x8eHF450mnt0+XRT0JunxLODAknRELzd8kTsfjYT70cBtXLSyxom0P+8vtpNI5IlKWFUkX1R/G7b2SZZuuOm6u4nRlxE/FTMG9UrNpjQVI1arEDIel4QzICj7ZImcZJDTIVgRBn0F7IsSFa3tpjQX5+t8/jSuguzXMSLpAJl9lKu9JX8ykHx9/ZR+likmuWMOyvQYRCSiWzelkmYRAxXJVTFfmhalFiCl4RO3iquQedNkBZ24b+uxOqTNBMyj8FlJNHyK//0Uuax9haaxA1vQR18osiDjEh00en1hMqjZtK9g7xrKwxDff7UNSNJJqiWxV4vHUUtb2h+n05XEqOcLdx9txzjfhu3L9jaxcswZ/6y7+8c4nSBXAr9hc3XEQVZGpuhodARNZ1ggYJqmaRouUpTtYBskgUDlEUGrBdSGsVik5QZLxIJdvXDid0jnAdevaOGfZtezZ+gTy0JO0Hhlk34EKihHEiHWS3HgrP93fzk+fehfTquOrj3Nli86lLbY3EJc9ghHvAeFSL4wDHVjlKWTVc8k6HT2j0+FXsdD8XWDm9eGNe+gy9qB0BIgvu4pQz5rjgvv7lRE/HY4vuBtctWkBhUySiD3B1cl9PJFezpRoJaIZc+pMl24Y4Euf/Ig3jVyo0BIJcNvVa1m/rHPOkOZjr+wnEfUzOUuBQFMlTNtT8VNwUSSbutCw0Kbv+BJZy8/D4ytQZIEmuZ6RkOJ5USuy1EwfNXl/mMVJhHDQEz305MfpMvIgXFrXf4rbzg+z6pWnyFQU2mI65156E28crFDbdYB2vYwsScT9Dqk6ZE0/nUYWNRA9bnd7Mj8Cf2t/o2Vx+/3fJK5V6G8PMjhqeV7WlkHML6gobcTCAdZe81Ei+TdIb/8ZXXqVqzsGeSK1mCOpErHWMJ+5aRPh9NyUTnzZ5fRmnqHuTmLXCiBc7IqFJKt86yfPcc/BPk8RU3bxuzJPTCxmaTBFl6+AsOvUpg4DAis/gVWYAElBj7Sx79A4h6btNweSQQZTZbL1JFrJR/SXeC9+mfTK7xKn8/ocO1fxQRrYzy6479gzxmOv7KdUvgRDsvjE+VH+ZuM6ciI6b8rqVMX6mXUvXdCKT1M5OJI9TvbDRkKIuZPjMyqpZUcnrjlIjgSug6R4E82hgNFMHzV5f8x0hQgh8LcvxSqlkRWtYXqeWHH5nItwWWuG2HP3UXVsWmNBUuksfidLyB5FkqR5d7cnm/Cd+dqVa9bQ6ng6PHYlQ38ywCc/2s197yhkbQgFg3z6unWs+8hq8oMB8nueQwnEuL7HzzmVIuPpLGuvvJili0McuG9uAEq//SCOWcWpF73dlaSAcBnKCp4aiuO6LqGAQb1Wo+zoyJIgYwamB/vwBNL8UZxKFoRAUnWeHmnn8TfGMeXl6G6RvmCRw+UklhpDH97O5RuzfGLL6vd9I/pl0yu/K5zq9TnRdPIHdWOceT9nFFH7pi1S79sJm6/s5sJTKNOeyELVtJw56x6ayGPbLqY9OzRIDZlspv0T3BkfBUliRavJvoxOpqrgWDbJRPioE9wZohkUfguZnbawKxlUX+i4Qatj9XA+e9MmfvjwW4xkTYLBOJ+8djUXr7vmhLu3021HPHYnuLq1n8vnKRjq4TbUQBQhXGTVoEOdoLNTYtHivnkDUK1aAElCOA5I0/MZSGTqBo6Q0VUZy3bRVImyJaNKLgm9ykwToRZpw6nkplcpMVoN8ehQJ8gOCzqjjOeDvJgK09MWxKcZHB7P8f0H3+TZbYP8q5s3nNE+8SZzORMyILM5MJzhiee3kcnmWdgV/ZVOI8fWPmZkXdJ5T5W1XLcolOq4LnjTB177rTe3I+Z6JwjBUE5iY2QQNeoSDfu54ZpLOO8Mf/aaQeG3lPebtni/fevvJ18+XxA69uef6ucdG4DUQJTggnNIb/8Z7nQBD1ki4asTj4ZQ3QD5Yo2K5UkSb249RFegAqielDISQkx/nySRtcJUHZVOv4WqGwSDBk6qjKobjKQKKIp32c64b53JPvEmx3OmZEB++vQu/uc/P08mlydX0zAreRZ3xyiKCH5VEKwM8u7O/AlTSLOZr/axezDNF69fhGQX6e7sIGWG+Nq3niSdrxDyadTqFrYDQb/G6v44uw5lKVS9GZ0uX4lyXeKpykJiuk2k4pJ44QVWr994Rk+ezaDwW8z7TVu83771DzpffqKfd6KAkVx/I3og3kglKbqfjetu4F/WvVOPLHk96NeskLhGq+DUW1CMIMHu1ZRHd2GXBMgKSDJxxWufLSltRFQ/1VoBVZEpVkwcVyBLnpJoWyzIVKFyRgt9Tebng5YBmXHwM8sZegJ1XDdIvq5ycDRHLGJyTccBnn5gK48Od3spxECEc5Z3cN6Knjk+DzMdeEeGOa72MXh4mPTWX7AqksIdCrBy463cft06/vbu1yjXpqXJJYlSzeX1vRk0TUYGkkaVoFwh5cRxhERILuE4Og8dbOGy/YdZ1wwKTX5T+aDz5Sf6eScKGN0f/fxxNZJb4LhdZTV96ZyvqaYPkXrTm1twrRoDMZVPdnXz4P5II0Vx4yXLeHPPOOlsGVeS6OuKeM5lZ1mmoskHw0SmRLlaJ66UwXHo8dUZccNc3THEpq4KKSvC/9zfj4SN7OQZzNrsG5ri58/spj0e5Mt/cAGXtBxsdODVzDi6ey7pnO61uKazaHaOuGHOacb43M1/Rmk0ws9eHmOqqiFJAlnyLEJdx0USDpM1DVnXsIWMhouhOOhSkbQdJ2sFzujrcsaDwl/+5V/yta99jS996Ut885vfPNNP1+S3mBMFjPkeP3ZXeezX+Fv76bvyS1TPuakRLNbNU+84MJzhnqd28dy2QWzbxVD5QPPZTc4s8/mKzzwWk3z4dZlcSSWi2hScAGHN5JzQYXanF3DfSD/jZRVVVrDdmZy/d2KcKlT5h5++QmjZq3QHvQaI7kqG8yIH+EVuOblSjYjucG3PCAPJ4HGzMB8LPIW+NMaP9ywgoJpMVHz4dY2a6RI36mTrBkXbQEYQ0urokk3e9hHw6ywYWHTS3/lX5YwGhddff51/+Id/YO3atWfyaZo0+aU5Vb1jUU9ijgz0mZa1bvLBMd8cDTDnsRuXbuCfX5OZNEP4ZJurOweRNB+PHepDcupoEliujC28qWUZgSY52KgUihUmslUWRP1IssyzE728POrD1CwMQ+OqTd1cYb2AVRFzmjFmZmFWdSaJD7nUbRUJQbXuoKoyhuzS4StwQ/u7ZK0AW7MLPAl8xea2LUs/vCqppVKJ2267je9973v82Z/92Zl6miZNfi38umStm3wwzDdHM/7Kjxgu+8haQZKxJB1iggv1l+k918dUTaMtJNNp1Hkn342phGiVx5CFzXgtiI0XFBRJYNsWLgJDKRN1JimPl5lUF/PgnlaEBIu6PN/lp9+a4sKP3Yz/0H1zamGh7jUoeoAOMcH1iw0e3BPAp0pUhYTf0An6olwefJXNicMgXDbFj5AxA/QtW8OW2z5+xl+7MxYU7rjjDq677jq2bNly0qBQr9ep1+uNvxcKhTO1pCZNmvyOMNPGrPrj2LUCsurjsX0+HhnpwcTvTfMvNtic2MOq9RspHvJc+hQtwJKNWwgfyZDP5onrZRwBRdvzAq+4BpYDMaPKxxenGOiOY2bKTExmqdoSvZ2esVKrLhiayGElP8rq9RuPS2HNNE5sTuxh6YY4bu+VBPrObyjA+gbDpN+u4dRK9EVUzllxBf1X/9+/ltfujASFu+66i+3bt/P666+f8mu/8Y1v8J/+0386E8to0qTJ7yh6uA3XqlPO70ZCYqQa5JGRC0CSSfoqFCw/D+4JsHRDnKXrbyK5/iaKwzu9ieHuNdw68SY/fGiIVD2MX7a4oedNlobSHBJLEJLM0nCWxb3tSHInqi9CUuQIF+IURQTDFXMG7Pytx5tTzW6cWDpf517P8Q0Uvy4+8KBw5MgRvvSlL/Hkk0/i8/lO+fVf+9rX+MpXvtL4e6FQYMGCBR/0spo0afK7hiQhTTuaZet+ao7Kgo4ITjlDWCowYfmphlfib+0/rv5waf95JFa9Q6pgk1CLjUn43uAhOjZ9iuyeZxpzM65Vpb/dx+2rVp2WJ8cMp+rcO1uT8B94UNi2bRupVIpzzz238ZjjOLzwwgt861vfol6voyhHtT4Mw8AwjA96GU2aNPkdxixOIqs6ga6VCMeiKxzEP+JSsPzIwsdUWUKVbVJ7XuTuv5ki6k40uogGU2WmXnubuOZjTWwQbwreQAgXxQiQWHE5Wrj1uLmZP1h/Kedv/GDlvc8GH3hQuOKKK9i5c+ecxz73uc+xfPlyvvrVr84JCE2aNGlyJpiRYXGtKlogQZeb4fqFKncfipHOq4CKJjv83f6NGAdtwno3Ny4tI2sGD+7tomI6BHwaWyIul3UMI8kKWqQDhI1ZnDzh3MxvQ0PCBx4UwuEwq1fP1eYIBoO0tLQc93iTJk2anAnmm4K/6JJLeGBkhBa9hCMU0maAChqGZOEKk5/uDiIpGppi0x60qeqtPJFZxaoumf5kANeuIUl6Q9/rt1XosDnR3KRJk99Kjt3Nvzkq40oPEdfrHCzHEdMWNwKvq8i2ZFRH0Bep44/1EAm3M1izyIsodjX1O+OH8WsJCs8999yv42maNGnSZA6zd/PttQyRSJSpWguu8HygATQZTKEQ1gWGXKesdRIJt5POVYjEEqy/7g66Q7XfGT8M+WwvoEmTJk1+HcxIcIfiSSRFQ5E9SXVTKMgSXN2b4veWTKEafoYmckiSJ2mycs0aogPn/U4EBGimj5o0afI7xIwE9z8/tYtn3hikXMyDWeSyrnFuXZYlufFWbmi9+EPfQfSrIAlxpm2g3x+FQoFoNEo+nycSiZzt5TRp0uS3lBmHtJiU/51ID53uvbV5UmjSpMnvJL8N7aNngmZNoUmTJk2aNGgGhSZNmjRp0qAZFJo0adKkSYNmUGjSpEmTJg1+4wrNM81QTV+FJk2aNPngmLmnnqrh9DcuKBSLRYCmfHaTJk2anAGKxSLRaPSE//4bN6fgui6jo6OEw2EkSTrby3lfzHhBHDly5EM5Y9Fc/9nlw7z+D/Pa4Xdj/UIIisUiXV1dyPKJKwe/cScFWZbp6ek528v4lYhEIh/KD9YMzfWfXT7M6/8wrx1++9d/shPCDM1Cc5MmTZo0adAMCk2aNGnSpEEzKHyAGIbBn/7pn35o7UWb6z+7fJjX/2FeOzTXP5vfuEJzkyZNmjQ5ezRPCk2aNGnSpEEzKDRp0qRJkwbNoNCkSZMmTRo0g0KTJk2aNGnQDApNmjRp0qRBMyh8gHz729+mv78fn8/H+eefz9atW8/2kk7JN77xDc477zzC4TDJZJKbb76ZPXv2nO1l/dL85V/+JZIk8eUvf/lsL+W0GRkZ4Q//8A9paWnB7/ezZs0a3njjjbO9rNPCcRy+/vWvMzAwgN/vZ9GiRfyX//JfTim6drZ44YUXuOGGG+jq6kKSJO677745/y6E4D/+x/9IZ2cnfr+fLVu2sG/fvrOz2Hk42foty+KrX/0qa9asIRgM0tXVxac//WlGR0ff13M0g8IHxN13381XvvIV/vRP/5Tt27ezbt06rr76alKp1Nle2kl5/vnnueOOO3j11Vd58sknsSyLq666inK5fLaX9r55/fXX+Yd/+AfWrl17tpdy2mSzWS666CI0TePRRx/l3Xff5b/9t/9GPB4/20s7Lf7qr/6K73znO3zrW99i9+7d/NVf/RV//dd/zd/+7d+e7aXNS7lcZt26dXz729+e99//+q//mr/5m7/h7//+73nttdcIBoNcffXV1Gq1X/NK5+dk669UKmzfvp2vf/3rbN++nZ///Ofs2bOHG2+88f09iWjygbBp0yZxxx13NP7uOI7o6uoS3/jGN87iqt4/qVRKAOL5558/20t5XxSLRbFkyRLx5JNPis2bN4svfelLZ3tJp8VXv/pVcfHFF5/tZfzSXHfddeLzn//8nMd+7/d+T9x2221naUWnDyDuvffext9d1xUdHR3iv/7X/9p4LJfLCcMwxJ133nkWVnhyjl3/fGzdulUA4vDhw6f9c5snhQ8A0zTZtm0bW7ZsaTwmyzJbtmzhlVdeOYsre//k83kAEokPl6H5HXfcwXXXXTfnPfgw8MADD7Bx40Y+8YlPkEwmOeecc/je9753tpd12lx44YU8/fTT7N27F4C33nqLF198kWuvvfYsr+z9Mzg4yPj4+JzPUDQa5fzzz//QXccz5PN5JEkiFoud9vf8xqmkfhhJp9M4jkN7e/ucx9vb23nvvffO0qreP67r8uUvf5mLLrqI1atXn+3lnDZ33XUX27dv5/XXXz/bS3nfHDx4kO985zt85Stf4d//+3/P66+/zr/9t/8WXdf5zGc+c7aXd0r+5E/+hEKhwPLly1EUBcdx+PM//3Nuu+22s7209834+DjAvNfxzL99mKjVanz1q1/lU5/61PtSfm0GhSYN7rjjDnbt2sWLL754tpdy2hw5coQvfelLPPnkk/h8vrO9nPeN67ps3LiRv/iLvwDgnHPOYdeuXfz93//9hyIo3HPPPfz4xz/mJz/5CatWrWLHjh18+ctfpqur60Ox/t9WLMvi1ltvRQjBd77znff1vc300QdAa2sriqIwMTEx5/GJiQk6OjrO0qreH1/84hd56KGHePbZZz9Ufhbbtm0jlUpx7rnnoqoqqqry/PPP8zd/8zeoqorjOGd7iSels7OTlStXznlsxYoVDA0NnaUVvT/+3b/7d/zJn/wJn/zkJ1mzZg233347f/zHf8w3vvGNs720983Mtfphvo7haEA4fPgwTz755Pv2h2gGhQ8AXdfZsGEDTz/9dOMx13V5+umnueCCC87iyk6NEIIvfvGL3HvvvTzzzDMMDAyc7SW9L6644gp27tzJjh07Gv9t3LiR2267jR07dqAoytle4km56KKLjmsB3rt3L319fWdpRe+PSqVynIuXoii4rnuWVvTLMzAwQEdHx5zruFAo8Nprr/3GX8czzASEffv28dRTT9HS0vK+f0YzffQB8ZWvfIXPfOYzbNy4kU2bNvHNb36TcrnM5z73ubO9tJNyxx138JOf/IT777+fcDjcyJ1Go1H8fv9ZXt2pCYfDx9U/gsEgLS0tH4q6yB//8R9z4YUX8hd/8RfceuutbN26le9+97t897vfPdtLOy1uuOEG/vzP/5ze3l5WrVrFm2++yX//7/+dz3/+82d7afNSKpXYv39/4++Dg4Ps2LGDRCJBb28vX/7yl/mzP/szlixZwsDAAF//+tfp6uri5ptvPnuLnsXJ1t/Z2cktt9zC9u3beeihh3Acp3E9JxIJdF0/vSf5lXqimszhb//2b0Vvb6/QdV1s2rRJvPrqq2d7SacEmPe/73//+2d7ab80H6aWVCGEePDBB8Xq1auFYRhi+fLl4rvf/e7ZXtJpUygUxJe+9CXR29srfD6fWLhwofgP/+E/iHq9fraXNi/PPvvsvJ/3z3zmM0IIry3161//umhvbxeGYYgrrrhC7Nmz5+wuehYnW//g4OAJr+dnn332tJ+j6afQpEmTJk0aNGsKTZo0adKkQTMoNGnSpEmTBs2g0KRJkyZNGjSDQpMmTZo0adAMCk2aNGnSpEEzKDRp0qRJkwbNoNCkSZMmTRo0g0KTJk2aNGnQDApNmjRp0qRBMyg0adKkSZMGzaDQpEmTJk0a/P8B9Ga6+R5Kr08AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"Vem\"\n",
    "X_pre_replicate_1, X_post_replicate_1 = prepare_pair_from_mat('SKMEL19', 'DMSO','24h', drug, '72h', 1)\n",
    "X_pre_replicate_2, X_post_replicate_2 = prepare_pair_from_mat('SKMEL19', 'DMSO','24h', drug, '72h', 2) \n",
    "\n",
    "jfe_indices = [1, 6, 0, 5, 4, 7, 8, 2, 3, 19]  \n",
    "\n",
    "\n",
    "X_tr_pre = X_pre_replicate_1\n",
    "Y_tr_post = X_post_replicate_1\n",
    "X_te_pre = X_pre_replicate_2\n",
    "Y_te_post = X_post_replicate_2\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 = run_cellot_pair(X_tr_pre[:, jfe_indices], Y_tr_post[:, jfe_indices], X_te_pre[:, jfe_indices], Y_te_post[:, jfe_indices], n_epochs=2000)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post[:, jfe_indices], median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post[:, jfe_indices]\n",
    "target = Y_te_post[:, jfe_indices]\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#C88131\")\n",
    "ax.scatter(y_pred_umap[:, 0], y_pred_umap[:, 1], s=10, alpha=0.7, label='predicted cells', color=\"#1F4D8D\")\n",
    "\n",
    "ax.set_title(f'{drug}')\n",
    "# ax.set_xlabel('UMAP 1')\n",
    "# ax.set_ylabel('UMAP 2')\n",
    "ax.set_aspect('equal', 'box')\n",
    "# Add a legend to distinguish the points\n",
    "ax.legend()\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "# Display the plot\n",
    "plt.savefig(f\"./plots/cellot_on_4i_drug_{drug}.png\", dpi=300)"
   ]
  },
  {
   "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"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.25"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
