{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b9e2d729",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "True\n",
      "11.7\n",
      "NVIDIA RTX 6000 Ada Generation\n",
      "2\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "48"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "print(torch.cuda.is_available())   # should be True\n",
    "print(torch.version.cuda)          # CUDA version PyTorch is built with\n",
    "print(torch.cuda.get_device_name(0)) if torch.cuda.is_available() else None\n",
    "print(torch.cuda.device_count())\n",
    "import os\n",
    "os.cpu_count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fe4f5248",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "from typing import Dict, Tuple, List, Optional\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import logging\n",
    "logger = logging.getLogger(__name__)\n",
    "\n",
    "def load_ap1_data_from_csv(csv_filepath: str, replicate: Optional[int] = None) -> Dict[str, np.ndarray]:\n",
    "    \"\"\"\n",
    "    Loads AP1 single-cell data from CSV or Excel file.\n",
    "\n",
    "    Args:\n",
    "        csv_filepath: Path to the CSV or Excel file\n",
    "\n",
    "    Returns:\n",
    "        Dictionary with condition identifiers as keys and feature matrices as values\n",
    "    \"\"\"\n",
    "    logger.info(f\"Loading data from: {csv_filepath}\")\n",
    "\n",
    "    # Load the data based on file extension\n",
    "    if csv_filepath.endswith('.csv'):\n",
    "        df = pd.read_csv(csv_filepath)\n",
    "    elif csv_filepath.endswith('.xlsx'):\n",
    "        df = pd.read_excel(csv_filepath)\n",
    "    else:\n",
    "        raise ValueError(\"Unsupported file format. Please provide a .csv or .xlsx file.\")\n",
    "    \n",
    "    replacement_map = {\n",
    "                        '0.316 uM Vemurafenib': 'Vem',\n",
    "                        '0.316 uM Vem + 0.0316 uM Tram': 'Vem+Tram'\n",
    "                        }\n",
    "    df['condition'] = df['condition'].replace(replacement_map)\n",
    "\n",
    "    print(df['condition'].unique())\n",
    "\n",
    "    # Define AP1 protein features (these are in log space already)\n",
    "    ap1_features = [\n",
    "        'cFOS (log a.u.)', 'p-cFOS (log a.u.)', 'FRA1 (log a.u.)', 'p-FRA1 (log a.u.)', 'FRA2 (log a.u.)',\n",
    "        'cJUN (log a.u.)', 'p-cJUN (log a.u.)', 'JUNB (log a.u.)', 'JUND (log a.u.)', 'p-ATF1 (log a.u.)',\n",
    "        'ATF2 (log a.u.)',\t 'p-ATF2 (log a.u.)', 'ATF3 (log a.u.)', 'ATF4 (log a.u.)', 'p-ATF4 (log a.u.)',\n",
    "        'ATF5 (log a.u.)', 'ATF6 (log a.u.)', 'MITF (log a.u.)', 'NGFR (log a.u.)', 'p-ERK (log a.u.)',\n",
    "    ]\n",
    "\n",
    "    # Check if all features exist\n",
    "    missing_features = [f for f in ap1_features if f not in df.columns]\n",
    "    if missing_features:\n",
    "        logger.warning(f\"Missing features: {missing_features}\")\n",
    "        ap1_features = [f for f in ap1_features if f in df.columns]\n",
    "\n",
    "    logger.info(f\"Using {len(ap1_features)} AP1 features\")\n",
    "\n",
    "    # Create condition-based data dictionary\n",
    "    data_dict = {}\n",
    "\n",
    "    if replicate is not None:\n",
    "        # Group by condition, time, and cell line\n",
    "        for (condition, time, cell_line, replicate_id), group in df.groupby(['condition', 'time', 'cell_line', 'replicate_id']):\n",
    "            # Create condition identifier\n",
    "            condition_id = f\"{cell_line}_{condition}_{time.replace(' ', '')}_rep{replicate_id}\"\n",
    "\n",
    "            # Extract feature matrix\n",
    "            feature_matrix = group[ap1_features].values\n",
    "\n",
    "            # Remove rows with any NaN values\n",
    "            valid_rows = ~np.isnan(feature_matrix).any(axis=1)\n",
    "            feature_matrix = feature_matrix[valid_rows]\n",
    "\n",
    "            if len(feature_matrix) > 0:\n",
    "                data_dict[condition_id] = feature_matrix\n",
    "                logger.info(f\"Loaded {condition_id}: {feature_matrix.shape}\")\n",
    "            else:\n",
    "                logger.warning(f\"No valid data for {condition_id}\")\n",
    "    else:\n",
    "        # Group by condition, time, and cell line\n",
    "        for (condition, time, cell_line), group in df.groupby(['condition', 'time', 'cell_line']):\n",
    "            # Create condition identifier\n",
    "            condition_id = f\"{cell_line}_{condition}_{time.replace(' ', '')}\"\n",
    "\n",
    "            # Extract feature matrix\n",
    "            feature_matrix = group[ap1_features].values\n",
    "\n",
    "            # Remove rows with any NaN values\n",
    "            valid_rows = ~np.isnan(feature_matrix).any(axis=1)\n",
    "            feature_matrix = feature_matrix[valid_rows]\n",
    "\n",
    "            if len(feature_matrix) > 0:\n",
    "                data_dict[condition_id] = feature_matrix\n",
    "                logger.info(f\"Loaded {condition_id}: {feature_matrix.shape}\")\n",
    "            else:\n",
    "                logger.warning(f\"No valid data for {condition_id}\")\n",
    "\n",
    "    return data_dict\n",
    "\n",
    "def prepare_pair_from_mat(cell_line: str,\n",
    "                          baseline_condition: str, baseline_time: str,\n",
    "                          target_condition: str, target_time: str,\n",
    "                          replicate: Optional[int] = None) -> Tuple[np.ndarray, np.ndarray]:\n",
    "    print(\"Cell line: \", cell_line)\n",
    "    raw_data_dict = load_ap1_data_from_csv('mmc5.xlsx', replicate)\n",
    "\n",
    "    if replicate is not None:\n",
    "        pre_key = f\"{cell_line}_{baseline_condition}_{baseline_time}_rep{replicate}\"\n",
    "        post_key = f\"{cell_line}_{target_condition}_{target_time}_rep{replicate}\"\n",
    "    else:\n",
    "        pre_key = f\"{cell_line}_{baseline_condition}_{baseline_time}\"\n",
    "        post_key = f\"{cell_line}_{target_condition}_{target_time}\"\n",
    "\n",
    "    if pre_key not in raw_data_dict or post_key not in raw_data_dict:\n",
    "        raise ValueError(f\"Pair not found: {pre_key}, {post_key}\")\n",
    "\n",
    "    # Equalize N\n",
    "    n = min(len(raw_data_dict[pre_key]), len(raw_data_dict[post_key]))\n",
    "    X_pre_raw = raw_data_dict[pre_key][:n]\n",
    "    X_post_raw = raw_data_dict[post_key][:n]\n",
    "    return X_pre_raw, X_post_raw\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "75d3cecc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import json\n",
    "import logging\n",
    "import argparse\n",
    "import geomloss\n",
    "import random\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import TensorDataset, DataLoader\n",
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "from typing import Dict, Tuple, List, Optional\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "from sklearn.preprocessing import StandardScaler, MinMaxScaler\n",
    "from sklearn.metrics.pairwise import rbf_kernel\n",
    "from typing import Dict, Tuple, List\n",
    "from scipy.stats import ks_2samp\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.metrics import r2_score\n",
    "\n",
    "import gc\n",
    "gc.collect()\n",
    "\n",
    "def median_heuristic_gamma(X: np.ndarray, Y: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    Median heuristic for RBF bandwidth: gamma = 1 / median(||x - y||^2).\n",
    "    Uses the median of pairwise distances in the pooled set.\n",
    "    \"\"\"\n",
    "    Z = np.vstack([X, Y])\n",
    "    # Sample if too large for efficiency\n",
    "    max_samples = 5000\n",
    "    if Z.shape[0] > max_samples:\n",
    "        idx = np.random.choice(Z.shape[0], size=max_samples, replace=False)\n",
    "        Z = Z[idx]\n",
    "    D2 = cdist(Z, Z, metric='sqeuclidean')\n",
    "    # Use upper triangular without diagonal\n",
    "    triu = D2[np.triu_indices_from(D2, k=1)]\n",
    "    med = np.median(triu[triu > 0]) if np.any(triu > 0) else 1.0\n",
    "    return 1.0 / max(med, 1e-12)\n",
    "\n",
    "def mmd_distance(X: np.ndarray, Y: np.ndarray, gamma: float) -> float:\n",
    "    \"\"\"\n",
    "    Unbiased MMD^2 estimator using Gaussian (RBF) kernel, sklearn backend.\n",
    "\n",
    "    Args:\n",
    "        X: (n_samples, n_features) first sample\n",
    "        Y: (m_samples, n_features) second sample\n",
    "        gamma: RBF kernel bandwidth; if None, uses median heuristic\n",
    "\n",
    "    Returns:\n",
    "        Unbiased MMD^2 value\n",
    "    \"\"\"\n",
    "    n = X.shape[0]\n",
    "    m = Y.shape[0]\n",
    "\n",
    "    # Kernel matrices\n",
    "    Kxx = rbf_kernel(X, X, gamma=gamma)\n",
    "    Kyy = rbf_kernel(Y, Y, gamma=gamma)\n",
    "    Kxy = rbf_kernel(X, Y, gamma=gamma)\n",
    "\n",
    "    # Unbiased: exclude diagonal entries\n",
    "    np.fill_diagonal(Kxx, 0.0)\n",
    "    np.fill_diagonal(Kyy, 0.0)\n",
    "\n",
    "    term_xx = Kxx.sum() / (n * (n - 1)) if n > 1 else 0.0\n",
    "    term_yy = Kyy.sum() / (m * (m - 1)) if m > 1 else 0.0\n",
    "    term_xy = 2.0 * Kxy.mean()\n",
    "\n",
    "    mmd2 = term_xx + term_yy - term_xy\n",
    "    mmd2 = max(mmd2, 0.0)  # Numerical stability\n",
    "    return float(mmd2)\n",
    "\n",
    "def r2_feature_means(y_true: np.ndarray, y_pred: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    R^2 computed across features between mean vectors of y_true and y_pred.\n",
    "    \"\"\"\n",
    "    mu_true = y_true.mean(axis=0)\n",
    "    mu_pred = y_pred.mean(axis=0)\n",
    "    ss_res = float(np.sum((mu_true - mu_pred) ** 2))\n",
    "    ss_tot = float(np.sum((mu_true - mu_true.mean()) ** 2))\n",
    "    if ss_tot <= 1e-12:\n",
    "        return 1.0 if ss_res <= 1e-12 else 0.0\n",
    "    return 1.0 - ss_res / ss_tot\n",
    "\n",
    "def wasserstein_pointcloud(\n",
    "    X,\n",
    "    Y,\n",
    "    p: int = 2,\n",
    "    a=None,\n",
    "    b=None,\n",
    "    method: str = \"emd\",          # \"emd\" (exact) or \"sinkhorn\" (approx)\n",
    "    reg: float = 1e-1,            # Sinkhorn regularization (only used if method=\"sinkhorn\")\n",
    "    return_plan: bool = False,\n",
    "):\n",
    "    \"\"\"\n",
    "    Compute Wasserstein distance W_p between two empirical distributions supported on point sets X and Y.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    X : (n, d) array-like\n",
    "        Source points.\n",
    "    Y : (m, d) array-like\n",
    "        Target points.\n",
    "    p : int\n",
    "        Order of the Wasserstein distance (commonly 1 or 2).\n",
    "    a : (n,) array-like or None\n",
    "        Weights for X; if None, uniform weights.\n",
    "    b : (m,) array-like or None\n",
    "        Weights for Y; if None, uniform weights.\n",
    "    method : str\n",
    "        \"emd\" for exact optimal transport (requires POT),\n",
    "        \"sinkhorn\" for entropic approximation (requires POT).\n",
    "    reg : float\n",
    "        Entropic regularization strength for Sinkhorn.\n",
    "    return_plan : bool\n",
    "        If True, also return the optimal transport plan.\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    Wp : float\n",
    "        Wasserstein distance of order p.\n",
    "    plan : (n, m) ndarray, optional\n",
    "        Optimal transport plan (only if return_plan=True).\n",
    "    \"\"\"\n",
    "    X = np.asarray(X, dtype=np.float64)\n",
    "    Y = np.asarray(Y, dtype=np.float64)\n",
    "    if X.ndim != 2 or Y.ndim != 2:\n",
    "        raise ValueError(\"X and Y must be 2D arrays with shape (n, d) and (m, d).\")\n",
    "    if X.shape[1] != Y.shape[1]:\n",
    "        raise ValueError(f\"Dimension mismatch: X has d={X.shape[1]}, Y has d={Y.shape[1]}.\")\n",
    "\n",
    "    n, d = X.shape\n",
    "    m, _ = Y.shape\n",
    "\n",
    "    if a is None:\n",
    "        a = np.full(n, 1.0 / n, dtype=np.float64)\n",
    "    else:\n",
    "        a = np.asarray(a, dtype=np.float64)\n",
    "        a = a / a.sum()\n",
    "\n",
    "    if b is None:\n",
    "        b = np.full(m, 1.0 / m, dtype=np.float64)\n",
    "    else:\n",
    "        b = np.asarray(b, dtype=np.float64)\n",
    "        b = b / b.sum()\n",
    "\n",
    "    # Cost matrix: C_ij = ||x_i - y_j||^p\n",
    "    # Compute squared Euclidean via (x-y)^2 = x^2 + y^2 - 2xy for speed\n",
    "    X2 = np.sum(X * X, axis=1, keepdims=True)          # (n, 1)\n",
    "    Y2 = np.sum(Y * Y, axis=1, keepdims=True).T        # (1, m)\n",
    "    sq = np.maximum(X2 + Y2 - 2.0 * (X @ Y.T), 0.0)     # (n, m)\n",
    "    if p == 2:\n",
    "        C = sq\n",
    "    else:\n",
    "        C = sq ** (p / 2.0)\n",
    "\n",
    "    try:\n",
    "        import ot  # POT: Python Optimal Transport\n",
    "    except ImportError as e:\n",
    "        raise ImportError(\n",
    "            \"This function requires the POT library. Install with: pip install pot\"\n",
    "        ) from e\n",
    "\n",
    "    method = method.lower()\n",
    "    if method == \"emd\":\n",
    "        # exact OT: minimizes <P, C>\n",
    "        P = ot.emd(a, b, C)\n",
    "        cost = float(np.sum(P * C))\n",
    "    elif method == \"sinkhorn\":\n",
    "        # entropic OT approximation\n",
    "        P = ot.sinkhorn(a, b, C, reg=reg)\n",
    "        cost = float(np.sum(P * C))\n",
    "    else:\n",
    "        raise ValueError('method must be either \"emd\" or \"sinkhorn\".')\n",
    "\n",
    "    Wp = cost ** (1.0 / p)\n",
    "\n",
    "    if return_plan:\n",
    "        return Wp, P\n",
    "    return Wp\n",
    "\n",
    "def summarize_metrics(y_true: np.ndarray, y_pred: np.ndarray, median_gamma: float) -> dict:\n",
    "    \"\"\"\n",
    "    Compute a standard set of metrics: MMD^2 (RBF), R^2 of feature means, median KS across features, and Wasserstein distance.\n",
    "    \"\"\"\n",
    "    # Drop any samples that contain NaNs in either true or pred\n",
    "    mask = (~np.isnan(y_true).any(axis=1)) & (~np.isnan(y_pred).any(axis=1))\n",
    "    if mask.sum() < len(y_true):\n",
    "        print(f\"[summarize_metrics] Dropping {len(y_true) - mask.sum()} samples with NaNs.\")\n",
    "    \n",
    "    y_true = y_true[mask]\n",
    "    y_pred = y_pred[mask]\n",
    "\n",
    "    out = {}\n",
    "\n",
    "    out['mmd2_gamma_median'] = mmd_distance(y_true, y_pred, gamma=median_gamma)\n",
    "    out['mmd2_gamma_0.5'] = mmd_distance(y_true, y_pred, gamma=0.5)\n",
    "    out['mmd2_gamma_1.0'] = mmd_distance(y_true, y_pred, gamma=1.0)\n",
    "    out['wasserstein_distance'] = wasserstein_pointcloud(y_true, y_pred, p=2, method=\"emd\")\n",
    "    out['R2_feature_means'] = r2_feature_means(y_true, y_pred)\n",
    "    return out\n",
    "\n",
    "def split_train_test(X: np.ndarray, Y: np.ndarray, train_fraction: float, seed: int = 42) -> Tuple[np.ndarray, np.ndarray, np.ndarray, np.ndarray]:\n",
    "    if X.shape[0] != Y.shape[0]:\n",
    "        min_len = min(len(X), len(Y))\n",
    "        X = X[:min_len]\n",
    "        Y = Y[:min_len]\n",
    "\n",
    "    n = X.shape[0]\n",
    "    n_train = max(1, int(n * train_fraction))\n",
    "    rng = np.random.default_rng(seed)\n",
    "    idx = rng.permutation(n)\n",
    "    tr_idx, te_idx = idx[:n_train], idx[n_train:]\n",
    "    return X[tr_idx], X[te_idx], Y[tr_idx], Y[te_idx]\n",
    "\n",
    "def topk_markers(adata, drug: str, k: int = 50, rank_key: str = \"marker_genes-drug-rank\"):\n",
    "    R = adata.varm[rank_key]\n",
    "\n",
    "    # --- get the rank vector for this drug ---\n",
    "    if hasattr(R, \"columns\") and hasattr(R, \"iloc\"):  # pandas DataFrame\n",
    "        if drug in R.columns:\n",
    "            r = R[drug].to_numpy()\n",
    "        else:\n",
    "            # fallback: interpret columns as ordered groups; try to map via rank_genes_groups names\n",
    "            names = adata.uns[\"rank_genes_groups\"][\"names\"]\n",
    "            groups = list(names.dtype.names) if (hasattr(names, \"dtype\") and names.dtype.names is not None) else list(names.columns)\n",
    "            r = R.iloc[:, groups.index(drug)].to_numpy()\n",
    "    else:  # numpy array (or array-like)\n",
    "        names = adata.uns[\"rank_genes_groups\"][\"names\"]\n",
    "        groups = list(names.dtype.names) if (hasattr(names, \"dtype\") and names.dtype.names is not None) else list(names.columns)\n",
    "        r = np.asarray(R)[:, groups.index(drug)]\n",
    "\n",
    "    # smaller rank => stronger marker\n",
    "    idx = np.argsort(r)[:k]\n",
    "    gene_ids = adata.var_names[idx].to_list()\n",
    "    gene_short = (adata.var.iloc[idx][\"gene_short_name\"].to_list()\n",
    "                  if \"gene_short_name\" in adata.var.columns else None)\n",
    "    return gene_ids, gene_short, idx\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c533daf9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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]] = [64, 64 ,64 ,64],\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": 5,
   "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=-3677094.2500 g_loss=4173217.7500 | train mmd=0.1185 | test_mmd=0.8107\n",
      "[CellOT] epoch=50 f_loss=-100.3197 g_loss=343.7159 | train mmd=0.5145 | test_mmd=0.6096\n",
      "[CellOT] epoch=100 f_loss=-327.3106 g_loss=398.6413 | train mmd=1.0944 | test_mmd=0.4080\n",
      "[CellOT] epoch=150 f_loss=-558.2965 g_loss=615.8595 | train mmd=1.0473 | test_mmd=0.3619\n",
      "[CellOT] epoch=200 f_loss=-644.7821 g_loss=704.8708 | train mmd=0.8213 | test_mmd=0.2995\n",
      "[CellOT] epoch=250 f_loss=-861.2479 g_loss=955.0323 | train mmd=0.9296 | test_mmd=0.2643\n",
      "[CellOT] epoch=300 f_loss=-1004.6982 g_loss=1143.6012 | train mmd=0.9112 | test_mmd=0.2276\n",
      "[CellOT] epoch=350 f_loss=-1154.2510 g_loss=1339.4684 | train mmd=1.0089 | test_mmd=0.2349\n",
      "[CellOT] epoch=400 f_loss=-1152.5311 g_loss=1249.0269 | train mmd=0.7848 | test_mmd=0.1725\n",
      "[CellOT] epoch=450 f_loss=-1346.6107 g_loss=1384.5261 | train mmd=0.8936 | test_mmd=0.1778\n",
      "[CellOT] epoch=500 f_loss=-1508.5465 g_loss=1720.3706 | train mmd=0.9640 | test_mmd=0.1716\n",
      "[CellOT] epoch=550 f_loss=-1468.1315 g_loss=1619.9305 | train mmd=0.8494 | test_mmd=0.1408\n",
      "[CellOT] epoch=600 f_loss=-1547.7317 g_loss=1939.9161 | train mmd=0.8373 | test_mmd=0.1153\n",
      "[CellOT] epoch=650 f_loss=-1592.3533 g_loss=2065.2622 | train mmd=0.8742 | test_mmd=0.1123\n",
      "[CellOT] epoch=700 f_loss=-1376.9249 g_loss=1684.6057 | train mmd=0.6162 | test_mmd=0.0795\n",
      "[CellOT] epoch=750 f_loss=-1285.0244 g_loss=2002.2675 | train mmd=0.6842 | test_mmd=0.0653\n",
      "[CellOT] epoch=800 f_loss=-1613.1689 g_loss=2277.3042 | train mmd=0.8173 | test_mmd=0.0723\n",
      "[CellOT] epoch=850 f_loss=-1213.2191 g_loss=2152.1108 | train mmd=0.6465 | test_mmd=0.0431\n",
      "[CellOT] epoch=900 f_loss=-1463.1842 g_loss=2366.8457 | train mmd=0.7334 | test_mmd=0.0477\n",
      "[CellOT] epoch=950 f_loss=-1290.9988 g_loss=2154.3853 | train mmd=0.6140 | test_mmd=0.0276\n",
      "[CellOT] epoch=1000 f_loss=-991.5713 g_loss=2173.7183 | train mmd=0.5702 | test_mmd=0.0266\n",
      "[CellOT] epoch=1050 f_loss=-1283.7028 g_loss=2420.5586 | train mmd=0.7213 | test_mmd=0.0353\n",
      "[CellOT] epoch=1100 f_loss=-1056.1780 g_loss=2274.3496 | train mmd=0.6340 | test_mmd=0.0275\n",
      "[CellOT] epoch=1150 f_loss=-522.6279 g_loss=1983.8000 | train mmd=0.3590 | test_mmd=0.0101\n",
      "[CellOT] epoch=1200 f_loss=779.1179 g_loss=1603.3538 | train mmd=0.1766 | test_mmd=0.0221\n",
      "[CellOT] epoch=1250 f_loss=-433.2015 g_loss=1926.6270 | train mmd=0.4730 | test_mmd=0.0136\n",
      "[CellOT] epoch=1300 f_loss=-442.8589 g_loss=1717.2651 | train mmd=0.5153 | test_mmd=0.0136\n",
      "[CellOT] epoch=1350 f_loss=335.6469 g_loss=1276.1246 | train mmd=0.2308 | test_mmd=0.0158\n",
      "[CellOT] epoch=1400 f_loss=359.1583 g_loss=1358.9004 | train mmd=0.3014 | test_mmd=0.0102\n",
      "[CellOT] epoch=1450 f_loss=257.7782 g_loss=1277.7246 | train mmd=0.3305 | test_mmd=0.0108\n",
      "[CellOT] epoch=1500 f_loss=578.3958 g_loss=1135.4139 | train mmd=0.2596 | test_mmd=0.0169\n",
      "[CellOT] epoch=1550 f_loss=376.6373 g_loss=1270.0182 | train mmd=0.3649 | test_mmd=0.0143\n",
      "[CellOT] epoch=1600 f_loss=545.8730 g_loss=1104.9602 | train mmd=0.5216 | test_mmd=0.0177\n",
      "[CellOT] epoch=1650 f_loss=603.3854 g_loss=1144.5366 | train mmd=0.2937 | test_mmd=0.0732\n",
      "[CellOT] epoch=1700 f_loss=237.8763 g_loss=2282.0623 | train mmd=0.2448 | test_mmd=0.1590\n",
      "[CellOT] epoch=1750 f_loss=222.3855 g_loss=3102.0801 | train mmd=0.3006 | test_mmd=0.0233\n",
      "[CellOT] epoch=1800 f_loss=-374.2977 g_loss=3346.0703 | train mmd=0.6832 | test_mmd=0.1020\n",
      "[CellOT] epoch=1850 f_loss=232.2218 g_loss=4348.9453 | train mmd=0.4250 | test_mmd=0.0816\n",
      "[CellOT] epoch=1900 f_loss=161.1927 g_loss=4606.6660 | train mmd=0.3594 | test_mmd=0.0571\n",
      "[CellOT] epoch=1950 f_loss=-40.4426 g_loss=4534.3667 | train mmd=0.2390 | test_mmd=0.1830\n",
      "[CellOT] epoch=2000 f_loss=-602.7961 g_loss=5043.1782 | train mmd=0.6656 | test_mmd=0.0811\n",
      "[CellOT] Final CellOT MMD: 0.2684\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-2324233.5000 g_loss=2679419.5000 | train mmd=0.1185 | test_mmd=0.8107\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.08105187313998852, 'mmd2_gamma_0.5': 0.575145644922252, 'mmd2_gamma_1.0': 0.6872777024470895, 'wasserstein_distance': 1.741497467909301, 'R2_feature_means': 0.853614581569434}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=303.8091 g_loss=171.0980 | train mmd=1.0879 | test_mmd=0.4483\n",
      "[CellOT] epoch=100 f_loss=-277.8917 g_loss=360.8237 | train mmd=1.1044 | test_mmd=0.4180\n",
      "[CellOT] epoch=150 f_loss=-474.4824 g_loss=533.7657 | train mmd=1.0136 | test_mmd=0.3465\n",
      "[CellOT] epoch=200 f_loss=-626.6830 g_loss=688.9919 | train mmd=0.9222 | test_mmd=0.3001\n",
      "[CellOT] epoch=250 f_loss=-692.5547 g_loss=842.3895 | train mmd=0.8733 | test_mmd=0.2573\n",
      "[CellOT] epoch=300 f_loss=-886.8157 g_loss=970.4067 | train mmd=0.9453 | test_mmd=0.2416\n",
      "[CellOT] epoch=350 f_loss=-974.3636 g_loss=1077.6558 | train mmd=0.9189 | test_mmd=0.2086\n",
      "[CellOT] epoch=400 f_loss=-1104.8962 g_loss=1305.4836 | train mmd=1.0210 | test_mmd=0.2134\n",
      "[CellOT] epoch=450 f_loss=-1155.4453 g_loss=1367.9696 | train mmd=0.9602 | test_mmd=0.1763\n",
      "[CellOT] epoch=500 f_loss=-1150.8087 g_loss=1406.0037 | train mmd=0.8808 | test_mmd=0.1346\n",
      "[CellOT] epoch=550 f_loss=-1282.0300 g_loss=1537.7867 | train mmd=0.9414 | test_mmd=0.1335\n",
      "[CellOT] epoch=600 f_loss=-1208.0065 g_loss=1479.7815 | train mmd=0.8359 | test_mmd=0.0948\n",
      "[CellOT] epoch=650 f_loss=-1087.5176 g_loss=1597.5953 | train mmd=0.8573 | test_mmd=0.0854\n",
      "[CellOT] epoch=700 f_loss=-876.9586 g_loss=1247.1246 | train mmd=0.5166 | test_mmd=0.0483\n",
      "[CellOT] epoch=750 f_loss=-863.8400 g_loss=1490.9932 | train mmd=0.6671 | test_mmd=0.0384\n",
      "[CellOT] epoch=800 f_loss=-900.7125 g_loss=1478.5173 | train mmd=0.6600 | test_mmd=0.0405\n",
      "[CellOT] epoch=850 f_loss=-624.4161 g_loss=1253.1389 | train mmd=0.4622 | test_mmd=0.0142\n",
      "[CellOT] epoch=900 f_loss=-519.7402 g_loss=1120.5723 | train mmd=0.5534 | test_mmd=0.0222\n",
      "[CellOT] epoch=950 f_loss=-485.8232 g_loss=1260.7351 | train mmd=0.5905 | test_mmd=0.0182\n",
      "[CellOT] epoch=1000 f_loss=503.2373 g_loss=351.3359 | train mmd=0.2192 | test_mmd=0.0233\n",
      "[CellOT] epoch=1050 f_loss=381.0557 g_loss=298.4694 | train mmd=0.2363 | test_mmd=0.1539\n",
      "[CellOT] epoch=1100 f_loss=187.8645 g_loss=572.0627 | train mmd=0.2360 | test_mmd=0.0368\n",
      "[CellOT] epoch=1150 f_loss=121.5907 g_loss=763.2773 | train mmd=0.1595 | test_mmd=0.0248\n",
      "[CellOT] epoch=1200 f_loss=69.7245 g_loss=904.7379 | train mmd=0.2076 | test_mmd=0.0976\n",
      "[CellOT] epoch=1250 f_loss=116.2798 g_loss=1054.2607 | train mmd=0.2337 | test_mmd=0.0406\n",
      "[CellOT] epoch=1300 f_loss=57.9609 g_loss=1153.8730 | train mmd=0.2444 | test_mmd=0.0693\n",
      "[CellOT] epoch=1350 f_loss=36.1895 g_loss=1262.4338 | train mmd=0.2160 | test_mmd=0.0338\n",
      "[CellOT] epoch=1400 f_loss=39.7963 g_loss=1378.0424 | train mmd=0.6681 | test_mmd=0.1755\n",
      "[CellOT] epoch=1450 f_loss=32.2577 g_loss=1462.5533 | train mmd=0.4213 | test_mmd=0.0491\n",
      "[CellOT] epoch=1500 f_loss=15.5073 g_loss=1521.5813 | train mmd=0.2334 | test_mmd=0.0426\n",
      "[CellOT] epoch=1550 f_loss=28.6353 g_loss=1589.4998 | train mmd=0.2544 | test_mmd=0.0798\n",
      "[CellOT] epoch=1600 f_loss=22.2261 g_loss=1602.5391 | train mmd=0.3142 | test_mmd=0.0480\n",
      "[CellOT] epoch=1650 f_loss=18.5031 g_loss=1674.3300 | train mmd=0.1815 | test_mmd=0.0408\n",
      "[CellOT] epoch=1700 f_loss=14.5828 g_loss=1726.8073 | train mmd=0.3810 | test_mmd=0.0574\n",
      "[CellOT] epoch=1750 f_loss=17.1835 g_loss=1751.9445 | train mmd=0.4791 | test_mmd=0.1033\n",
      "[CellOT] epoch=1800 f_loss=15.5153 g_loss=1774.5176 | train mmd=0.2656 | test_mmd=0.0549\n",
      "[CellOT] epoch=1850 f_loss=15.2835 g_loss=1776.2990 | train mmd=0.5205 | test_mmd=0.1521\n",
      "[CellOT] epoch=1900 f_loss=6.0762 g_loss=1778.7446 | train mmd=0.3909 | test_mmd=0.0850\n",
      "[CellOT] epoch=1950 f_loss=16.3039 g_loss=1765.4923 | train mmd=0.6313 | test_mmd=0.1920\n",
      "[CellOT] epoch=2000 f_loss=21.3773 g_loss=1722.9323 | train mmd=0.2841 | test_mmd=0.0866\n",
      "[CellOT] Final CellOT MMD: 0.1312\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-3265547.2500 g_loss=3730213.7500 | train mmd=0.1185 | test_mmd=0.8107\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.08656765533266153, 'mmd2_gamma_0.5': 0.24405653595045307, 'mmd2_gamma_1.0': 0.251829173809679, 'wasserstein_distance': 3.6276415788660485, 'R2_feature_means': 0.8462408633222762}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=360.9406 g_loss=162.2585 | train mmd=1.0894 | test_mmd=0.4419\n",
      "[CellOT] epoch=100 f_loss=-275.0431 g_loss=357.4458 | train mmd=1.1057 | test_mmd=0.4203\n",
      "[CellOT] epoch=150 f_loss=-493.6023 g_loss=553.8702 | train mmd=1.0999 | test_mmd=0.3844\n",
      "[CellOT] epoch=200 f_loss=-652.1652 g_loss=703.0369 | train mmd=1.0180 | test_mmd=0.3231\n",
      "[CellOT] epoch=250 f_loss=-790.0827 g_loss=846.0006 | train mmd=0.9918 | test_mmd=0.2798\n",
      "[CellOT] epoch=300 f_loss=-893.3445 g_loss=1023.1106 | train mmd=1.0173 | test_mmd=0.2709\n",
      "[CellOT] epoch=350 f_loss=-1087.4126 g_loss=1180.7158 | train mmd=1.0605 | test_mmd=0.2563\n",
      "[CellOT] epoch=400 f_loss=-1066.5775 g_loss=1290.0812 | train mmd=0.8964 | test_mmd=0.2196\n",
      "[CellOT] epoch=450 f_loss=-1151.4209 g_loss=1331.1055 | train mmd=0.9251 | test_mmd=0.1789\n",
      "[CellOT] epoch=500 f_loss=-1215.2239 g_loss=1401.1520 | train mmd=0.8737 | test_mmd=0.1458\n",
      "[CellOT] epoch=550 f_loss=-1197.4363 g_loss=1399.8059 | train mmd=0.8577 | test_mmd=0.1440\n",
      "[CellOT] epoch=600 f_loss=-1225.3643 g_loss=1651.5398 | train mmd=0.7977 | test_mmd=0.1374\n",
      "[CellOT] epoch=650 f_loss=-1283.3398 g_loss=1736.8773 | train mmd=0.9586 | test_mmd=0.1311\n",
      "[CellOT] epoch=700 f_loss=-1360.1975 g_loss=1768.5854 | train mmd=0.9021 | test_mmd=0.1082\n",
      "[CellOT] epoch=750 f_loss=-1155.4083 g_loss=1724.6050 | train mmd=0.7156 | test_mmd=0.0616\n",
      "[CellOT] epoch=800 f_loss=-1285.4360 g_loss=1902.2190 | train mmd=0.8853 | test_mmd=0.0841\n",
      "[CellOT] epoch=850 f_loss=-1127.1226 g_loss=1849.5723 | train mmd=0.6973 | test_mmd=0.0528\n",
      "[CellOT] epoch=900 f_loss=-1101.0471 g_loss=1838.9718 | train mmd=0.7777 | test_mmd=0.0560\n",
      "[CellOT] epoch=950 f_loss=-1029.0625 g_loss=1920.1672 | train mmd=0.7395 | test_mmd=0.0434\n",
      "[CellOT] epoch=1000 f_loss=-844.7022 g_loss=1670.7058 | train mmd=0.6501 | test_mmd=0.0281\n",
      "[CellOT] epoch=1050 f_loss=-746.5891 g_loss=1781.0940 | train mmd=0.6698 | test_mmd=0.0288\n",
      "[CellOT] epoch=1100 f_loss=-496.2255 g_loss=1579.8423 | train mmd=0.5110 | test_mmd=0.0190\n",
      "[CellOT] epoch=1150 f_loss=-170.5612 g_loss=1504.5243 | train mmd=0.4040 | test_mmd=0.0106\n",
      "[CellOT] epoch=1200 f_loss=-27.5322 g_loss=1391.0808 | train mmd=0.4730 | test_mmd=0.0116\n",
      "[CellOT] epoch=1250 f_loss=68.1405 g_loss=1256.7268 | train mmd=0.5408 | test_mmd=0.0150\n",
      "[CellOT] epoch=1300 f_loss=217.5210 g_loss=864.3302 | train mmd=0.3051 | test_mmd=0.0146\n",
      "[CellOT] epoch=1350 f_loss=187.3617 g_loss=1804.5085 | train mmd=0.4659 | test_mmd=0.2136\n",
      "[CellOT] epoch=1400 f_loss=563.6375 g_loss=940.2535 | train mmd=0.5826 | test_mmd=0.2497\n",
      "[CellOT] epoch=1450 f_loss=321.1044 g_loss=1283.0859 | train mmd=0.2780 | test_mmd=0.0688\n",
      "[CellOT] epoch=1500 f_loss=194.5014 g_loss=1827.8909 | train mmd=0.3594 | test_mmd=0.0614\n",
      "[CellOT] epoch=1550 f_loss=20.8877 g_loss=1924.5273 | train mmd=0.2259 | test_mmd=0.0903\n",
      "[CellOT] epoch=1600 f_loss=144.0632 g_loss=2165.7324 | train mmd=0.7861 | test_mmd=0.1089\n",
      "[CellOT] epoch=1650 f_loss=115.2702 g_loss=2387.5142 | train mmd=0.3572 | test_mmd=0.0311\n",
      "[CellOT] epoch=1700 f_loss=81.4237 g_loss=2578.4495 | train mmd=0.2754 | test_mmd=0.0620\n",
      "[CellOT] epoch=1750 f_loss=47.5760 g_loss=2715.7324 | train mmd=0.2729 | test_mmd=0.0357\n",
      "[CellOT] epoch=1800 f_loss=64.3238 g_loss=2803.9482 | train mmd=0.2914 | test_mmd=0.0577\n",
      "[CellOT] epoch=1850 f_loss=39.2787 g_loss=2911.8682 | train mmd=0.2905 | test_mmd=0.0300\n",
      "[CellOT] epoch=1900 f_loss=35.3556 g_loss=3016.4592 | train mmd=0.2373 | test_mmd=0.0612\n",
      "[CellOT] epoch=1950 f_loss=21.8921 g_loss=3106.7021 | train mmd=0.9963 | test_mmd=0.6605\n",
      "[CellOT] epoch=2000 f_loss=59.4945 g_loss=3192.4910 | train mmd=0.2705 | test_mmd=0.1266\n",
      "[CellOT] Final CellOT MMD: 0.1665\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-3826990.5000 g_loss=4464524.0000 | train mmd=0.1185 | test_mmd=0.8107\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.12655672212847224, 'mmd2_gamma_0.5': 0.3408364115148649, 'mmd2_gamma_1.0': 0.32240376308067276, 'wasserstein_distance': 2.273515412904402, 'R2_feature_means': 0.7774619699447589}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=258.3149 g_loss=262.7303 | train mmd=1.0702 | test_mmd=0.4315\n",
      "[CellOT] epoch=100 f_loss=-412.5266 g_loss=521.7009 | train mmd=1.1052 | test_mmd=0.4082\n",
      "[CellOT] epoch=150 f_loss=-636.1173 g_loss=704.6564 | train mmd=0.8962 | test_mmd=0.3314\n",
      "[CellOT] epoch=200 f_loss=-897.9877 g_loss=965.4341 | train mmd=0.9502 | test_mmd=0.2954\n",
      "[CellOT] epoch=250 f_loss=-1019.3483 g_loss=1177.0471 | train mmd=0.9024 | test_mmd=0.2307\n",
      "[CellOT] epoch=300 f_loss=-1168.4377 g_loss=1317.6637 | train mmd=0.9260 | test_mmd=0.2346\n",
      "[CellOT] epoch=350 f_loss=-1200.1592 g_loss=1514.2122 | train mmd=0.8095 | test_mmd=0.1656\n",
      "[CellOT] epoch=400 f_loss=-1507.2281 g_loss=1699.9161 | train mmd=0.9730 | test_mmd=0.1936\n",
      "[CellOT] epoch=450 f_loss=-1529.8811 g_loss=1772.1997 | train mmd=0.8941 | test_mmd=0.1425\n",
      "[CellOT] epoch=500 f_loss=-866.0265 g_loss=1411.0854 | train mmd=0.4192 | test_mmd=0.0824\n",
      "[CellOT] epoch=550 f_loss=-1543.0881 g_loss=2070.3760 | train mmd=0.9353 | test_mmd=0.1297\n",
      "[CellOT] epoch=600 f_loss=-1531.8733 g_loss=2061.3369 | train mmd=0.8409 | test_mmd=0.0973\n",
      "[CellOT] epoch=650 f_loss=-1238.8489 g_loss=1843.7727 | train mmd=0.6717 | test_mmd=0.0671\n",
      "[CellOT] epoch=700 f_loss=-1272.5779 g_loss=1985.5612 | train mmd=0.6518 | test_mmd=0.0506\n",
      "[CellOT] epoch=750 f_loss=-1253.2896 g_loss=2078.4358 | train mmd=0.7311 | test_mmd=0.0478\n",
      "[CellOT] epoch=800 f_loss=-797.8718 g_loss=1591.2346 | train mmd=0.4271 | test_mmd=0.0189\n",
      "[CellOT] epoch=850 f_loss=-893.2378 g_loss=1866.1711 | train mmd=0.6358 | test_mmd=0.0273\n",
      "[CellOT] epoch=900 f_loss=-545.7070 g_loss=1669.2800 | train mmd=0.5122 | test_mmd=0.0173\n",
      "[CellOT] epoch=950 f_loss=-306.4243 g_loss=1280.2107 | train mmd=0.3862 | test_mmd=0.0082\n",
      "[CellOT] epoch=1000 f_loss=-295.3909 g_loss=1420.3473 | train mmd=0.5428 | test_mmd=0.0154\n",
      "[CellOT] epoch=1050 f_loss=284.3788 g_loss=920.0104 | train mmd=0.3827 | test_mmd=0.0188\n",
      "[CellOT] epoch=1100 f_loss=303.6537 g_loss=300.8178 | train mmd=0.3862 | test_mmd=0.0176\n",
      "[CellOT] epoch=1150 f_loss=172.5563 g_loss=535.1458 | train mmd=0.4280 | test_mmd=0.0178\n",
      "[CellOT] epoch=1200 f_loss=117.3842 g_loss=654.4287 | train mmd=0.2024 | test_mmd=0.0279\n",
      "[CellOT] epoch=1250 f_loss=144.6626 g_loss=766.1390 | train mmd=0.2425 | test_mmd=0.0558\n",
      "[CellOT] epoch=1300 f_loss=120.4629 g_loss=848.4752 | train mmd=0.2198 | test_mmd=0.0809\n",
      "[CellOT] epoch=1350 f_loss=46.9078 g_loss=933.5051 | train mmd=0.1924 | test_mmd=0.0331\n",
      "[CellOT] epoch=1400 f_loss=57.1264 g_loss=1004.6482 | train mmd=0.2705 | test_mmd=0.1257\n",
      "[CellOT] epoch=1450 f_loss=16.0469 g_loss=1053.4318 | train mmd=0.2139 | test_mmd=0.0377\n",
      "[CellOT] epoch=1500 f_loss=72.3044 g_loss=1083.6849 | train mmd=0.1886 | test_mmd=0.0482\n",
      "[CellOT] epoch=1550 f_loss=24.4140 g_loss=1152.3618 | train mmd=0.2166 | test_mmd=0.1398\n",
      "[CellOT] epoch=1600 f_loss=33.1913 g_loss=1335.3428 | train mmd=0.4508 | test_mmd=0.2178\n",
      "[CellOT] epoch=1650 f_loss=33.2501 g_loss=1264.8013 | train mmd=0.2129 | test_mmd=0.0888\n",
      "[CellOT] epoch=1700 f_loss=14.5636 g_loss=1289.0509 | train mmd=0.3400 | test_mmd=0.2496\n",
      "[CellOT] epoch=1750 f_loss=25.8480 g_loss=1334.8936 | train mmd=0.3803 | test_mmd=0.1292\n",
      "[CellOT] epoch=1800 f_loss=4.0968 g_loss=1367.0815 | train mmd=0.7469 | test_mmd=0.2024\n",
      "[CellOT] epoch=1850 f_loss=4.6174 g_loss=1401.7063 | train mmd=0.6728 | test_mmd=0.3666\n",
      "[CellOT] epoch=1900 f_loss=12.3991 g_loss=1405.3083 | train mmd=0.1822 | test_mmd=0.0900\n",
      "[CellOT] epoch=1950 f_loss=12.4698 g_loss=1425.5726 | train mmd=0.3002 | test_mmd=0.0750\n",
      "[CellOT] epoch=2000 f_loss=12.5151 g_loss=1437.3577 | train mmd=0.5925 | test_mmd=0.4042\n",
      "[CellOT] Final CellOT MMD: 0.3540\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-3148391.7500 g_loss=3864236.2500 | train mmd=0.1185 | test_mmd=0.8107\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.4041883747873243, 'mmd2_gamma_0.5': 0.7330247001320613, 'mmd2_gamma_1.0': 0.5751148714131511, 'wasserstein_distance': 3.230718867941373, 'R2_feature_means': 0.27976571065813427}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=361.9175 g_loss=233.4784 | train mmd=1.0774 | test_mmd=0.4280\n",
      "[CellOT] epoch=100 f_loss=-344.1245 g_loss=476.2168 | train mmd=1.1059 | test_mmd=0.4194\n",
      "[CellOT] epoch=150 f_loss=-649.5817 g_loss=709.6061 | train mmd=1.1026 | test_mmd=0.3846\n",
      "[CellOT] epoch=200 f_loss=-777.0615 g_loss=835.7913 | train mmd=0.9125 | test_mmd=0.3086\n",
      "[CellOT] epoch=250 f_loss=-996.6824 g_loss=1107.5410 | train mmd=0.9713 | test_mmd=0.2710\n",
      "[CellOT] epoch=300 f_loss=-1126.5688 g_loss=1305.3416 | train mmd=0.9995 | test_mmd=0.2518\n",
      "[CellOT] epoch=350 f_loss=-1270.0300 g_loss=1439.8595 | train mmd=1.0009 | test_mmd=0.2296\n",
      "[CellOT] epoch=400 f_loss=-1221.0146 g_loss=1474.1882 | train mmd=0.8198 | test_mmd=0.1705\n",
      "[CellOT] epoch=450 f_loss=-1418.7656 g_loss=1721.5216 | train mmd=0.9047 | test_mmd=0.1659\n",
      "[CellOT] epoch=500 f_loss=-1434.8358 g_loss=1770.6479 | train mmd=0.8563 | test_mmd=0.1481\n",
      "[CellOT] epoch=550 f_loss=-1141.8425 g_loss=1658.0574 | train mmd=0.6427 | test_mmd=0.0795\n",
      "[CellOT] epoch=600 f_loss=-1181.3511 g_loss=1641.3092 | train mmd=0.6027 | test_mmd=0.0679\n",
      "[CellOT] epoch=650 f_loss=-1459.8364 g_loss=1967.1042 | train mmd=0.7715 | test_mmd=0.0703\n",
      "[CellOT] epoch=700 f_loss=-1147.6691 g_loss=1837.6753 | train mmd=0.6634 | test_mmd=0.0560\n",
      "[CellOT] epoch=750 f_loss=-1203.8035 g_loss=2004.1796 | train mmd=0.7557 | test_mmd=0.0531\n",
      "[CellOT] epoch=800 f_loss=-911.1627 g_loss=1938.3330 | train mmd=0.6708 | test_mmd=0.0353\n",
      "[CellOT] epoch=850 f_loss=-843.0502 g_loss=1793.0920 | train mmd=0.5899 | test_mmd=0.0206\n",
      "[CellOT] epoch=900 f_loss=79.7040 g_loss=736.7812 | train mmd=0.1792 | test_mmd=0.0167\n",
      "[CellOT] epoch=950 f_loss=-65.5741 g_loss=1150.0737 | train mmd=0.2667 | test_mmd=0.0147\n",
      "[CellOT] epoch=1000 f_loss=-34.1465 g_loss=760.6853 | train mmd=0.3853 | test_mmd=0.0132\n",
      "[CellOT] epoch=1050 f_loss=359.5219 g_loss=419.8990 | train mmd=0.3040 | test_mmd=0.0264\n",
      "[CellOT] epoch=1100 f_loss=270.5034 g_loss=256.3932 | train mmd=0.1845 | test_mmd=0.0579\n",
      "[CellOT] epoch=1150 f_loss=92.0289 g_loss=318.7379 | train mmd=0.2450 | test_mmd=0.1130\n",
      "[CellOT] epoch=1200 f_loss=104.0767 g_loss=390.8454 | train mmd=0.2116 | test_mmd=0.0197\n",
      "[CellOT] epoch=1250 f_loss=91.2638 g_loss=479.0664 | train mmd=0.2613 | test_mmd=0.1092\n",
      "[CellOT] epoch=1300 f_loss=58.6740 g_loss=536.0248 | train mmd=0.2493 | test_mmd=0.0203\n",
      "[CellOT] epoch=1350 f_loss=31.0195 g_loss=604.9402 | train mmd=0.3276 | test_mmd=0.0396\n",
      "[CellOT] epoch=1400 f_loss=71.5874 g_loss=651.4805 | train mmd=0.1759 | test_mmd=0.0371\n",
      "[CellOT] epoch=1450 f_loss=51.7844 g_loss=694.3952 | train mmd=0.2292 | test_mmd=0.0450\n",
      "[CellOT] epoch=1500 f_loss=30.6834 g_loss=750.0839 | train mmd=0.3371 | test_mmd=0.0693\n",
      "[CellOT] epoch=1550 f_loss=15.5755 g_loss=771.8663 | train mmd=0.1538 | test_mmd=0.0251\n",
      "[CellOT] epoch=1600 f_loss=10.1117 g_loss=815.8341 | train mmd=0.5410 | test_mmd=0.3682\n",
      "[CellOT] epoch=1650 f_loss=24.2005 g_loss=837.6396 | train mmd=0.2759 | test_mmd=0.0556\n",
      "[CellOT] epoch=1700 f_loss=8.1852 g_loss=850.0194 | train mmd=0.3121 | test_mmd=0.0326\n",
      "[CellOT] epoch=1750 f_loss=7.4533 g_loss=892.1967 | train mmd=0.1843 | test_mmd=0.0366\n",
      "[CellOT] epoch=1800 f_loss=16.7476 g_loss=896.5623 | train mmd=0.1761 | test_mmd=0.0444\n",
      "[CellOT] epoch=1850 f_loss=6.1019 g_loss=915.0181 | train mmd=0.2809 | test_mmd=0.1152\n",
      "[CellOT] epoch=1900 f_loss=6.5319 g_loss=899.5922 | train mmd=0.2155 | test_mmd=0.0318\n",
      "[CellOT] epoch=1950 f_loss=14.8675 g_loss=907.7104 | train mmd=0.3046 | test_mmd=0.0674\n",
      "[CellOT] epoch=2000 f_loss=19.6136 g_loss=891.0522 | train mmd=0.3400 | test_mmd=0.0989\n",
      "[CellOT] Final CellOT MMD: 0.1479\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-3236739.0000 g_loss=3572216.0000 | train mmd=0.1185 | test_mmd=0.8107\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.09890271112131033, 'mmd2_gamma_0.5': 0.30397502764607726, 'mmd2_gamma_1.0': 0.3143948183136407, 'wasserstein_distance': 5.152044457569864, 'R2_feature_means': 0.7631735945653746}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=487.0291 g_loss=152.5450 | train mmd=1.1076 | test_mmd=0.4490\n",
      "[CellOT] epoch=100 f_loss=-246.2160 g_loss=325.2534 | train mmd=1.1051 | test_mmd=0.4103\n",
      "[CellOT] epoch=150 f_loss=-416.1497 g_loss=471.6201 | train mmd=0.8955 | test_mmd=0.3204\n",
      "[CellOT] epoch=200 f_loss=-545.7430 g_loss=630.5722 | train mmd=0.9399 | test_mmd=0.2989\n",
      "[CellOT] epoch=250 f_loss=-703.9050 g_loss=723.9735 | train mmd=0.9678 | test_mmd=0.2638\n",
      "[CellOT] epoch=300 f_loss=-848.0034 g_loss=963.0684 | train mmd=1.0495 | test_mmd=0.2714\n",
      "[CellOT] epoch=350 f_loss=-903.2957 g_loss=1064.4080 | train mmd=0.9773 | test_mmd=0.2307\n",
      "[CellOT] epoch=400 f_loss=-1033.4915 g_loss=1181.3201 | train mmd=1.0281 | test_mmd=0.2218\n",
      "[CellOT] epoch=450 f_loss=-1105.2458 g_loss=1274.0232 | train mmd=0.9775 | test_mmd=0.1863\n",
      "[CellOT] epoch=500 f_loss=-1160.0001 g_loss=1372.1027 | train mmd=0.9843 | test_mmd=0.1707\n",
      "[CellOT] epoch=550 f_loss=-1055.1682 g_loss=1365.6296 | train mmd=0.8605 | test_mmd=0.1220\n",
      "[CellOT] epoch=600 f_loss=-1218.0967 g_loss=1482.3372 | train mmd=0.9156 | test_mmd=0.1297\n",
      "[CellOT] epoch=650 f_loss=-1057.0132 g_loss=1415.4720 | train mmd=0.7963 | test_mmd=0.0972\n",
      "[CellOT] epoch=700 f_loss=-1127.9865 g_loss=1518.5063 | train mmd=0.8620 | test_mmd=0.0919\n",
      "[CellOT] epoch=750 f_loss=-1167.2441 g_loss=1623.7266 | train mmd=0.8574 | test_mmd=0.0842\n",
      "[CellOT] epoch=800 f_loss=-1074.7095 g_loss=1610.9821 | train mmd=0.7523 | test_mmd=0.0571\n",
      "[CellOT] epoch=850 f_loss=-960.3635 g_loss=1571.4213 | train mmd=0.7559 | test_mmd=0.0583\n",
      "[CellOT] epoch=900 f_loss=-476.9858 g_loss=1315.3674 | train mmd=0.3562 | test_mmd=0.0344\n",
      "[CellOT] epoch=950 f_loss=-676.3582 g_loss=1376.7007 | train mmd=0.5192 | test_mmd=0.0200\n",
      "[CellOT] epoch=1000 f_loss=-720.0054 g_loss=1484.7609 | train mmd=0.6152 | test_mmd=0.0266\n",
      "[CellOT] epoch=1050 f_loss=-120.4173 g_loss=665.4510 | train mmd=0.3298 | test_mmd=0.1160\n",
      "[CellOT] epoch=1100 f_loss=-648.4625 g_loss=1567.3442 | train mmd=0.6241 | test_mmd=0.0246\n",
      "[CellOT] epoch=1150 f_loss=-265.8860 g_loss=1135.1731 | train mmd=0.4518 | test_mmd=0.0194\n",
      "[CellOT] epoch=1200 f_loss=-264.8714 g_loss=1501.0400 | train mmd=0.5643 | test_mmd=0.0176\n",
      "[CellOT] epoch=1250 f_loss=-220.1277 g_loss=1353.5920 | train mmd=0.4944 | test_mmd=0.0126\n",
      "[CellOT] epoch=1300 f_loss=633.0797 g_loss=947.1430 | train mmd=0.3827 | test_mmd=0.5856\n",
      "[CellOT] epoch=1350 f_loss=269.5563 g_loss=1103.4042 | train mmd=0.3855 | test_mmd=0.0117\n",
      "[CellOT] epoch=1400 f_loss=413.4144 g_loss=991.6377 | train mmd=0.2602 | test_mmd=0.0179\n",
      "[CellOT] epoch=1450 f_loss=540.4830 g_loss=1117.0939 | train mmd=0.4201 | test_mmd=0.2306\n",
      "[CellOT] epoch=1500 f_loss=162.0385 g_loss=2041.8135 | train mmd=0.2401 | test_mmd=0.0289\n",
      "[CellOT] epoch=1550 f_loss=111.6069 g_loss=2846.8267 | train mmd=0.2205 | test_mmd=0.0779\n",
      "[CellOT] epoch=1600 f_loss=104.6242 g_loss=3166.0083 | train mmd=0.2429 | test_mmd=0.0404\n",
      "[CellOT] epoch=1650 f_loss=50.6377 g_loss=3635.1184 | train mmd=0.5168 | test_mmd=0.3337\n",
      "[CellOT] epoch=1700 f_loss=77.5797 g_loss=3737.3335 | train mmd=0.2943 | test_mmd=0.0951\n",
      "[CellOT] epoch=1750 f_loss=63.8404 g_loss=3996.6875 | train mmd=0.2563 | test_mmd=0.0324\n",
      "[CellOT] epoch=1800 f_loss=64.4753 g_loss=4236.7891 | train mmd=0.2613 | test_mmd=0.1403\n",
      "[CellOT] epoch=1850 f_loss=28.9911 g_loss=4424.5737 | train mmd=0.3381 | test_mmd=0.1818\n",
      "[CellOT] epoch=1900 f_loss=54.1563 g_loss=4561.9551 | train mmd=0.2323 | test_mmd=0.0844\n",
      "[CellOT] epoch=1950 f_loss=64.2318 g_loss=4767.0767 | train mmd=0.3259 | test_mmd=0.0459\n",
      "[CellOT] epoch=2000 f_loss=12.8923 g_loss=4970.2842 | train mmd=0.2535 | test_mmd=0.0435\n",
      "[CellOT] Final CellOT MMD: 0.1330\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-2507988.5000 g_loss=2861253.2500 | train mmd=0.1185 | test_mmd=0.8107\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.04347213626237556, 'mmd2_gamma_0.5': 0.21310874899970556, 'mmd2_gamma_1.0': 0.26581803159852774, 'wasserstein_distance': 1.6992011293707114, 'R2_feature_means': 0.9309967832606462}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=405.4868 g_loss=167.4688 | train mmd=1.1064 | test_mmd=0.4424\n",
      "[CellOT] epoch=100 f_loss=-277.1944 g_loss=339.4249 | train mmd=1.1034 | test_mmd=0.4075\n",
      "[CellOT] epoch=150 f_loss=-447.6073 g_loss=508.3021 | train mmd=0.9922 | test_mmd=0.3336\n",
      "[CellOT] epoch=200 f_loss=-606.7750 g_loss=675.0961 | train mmd=1.0059 | test_mmd=0.3140\n",
      "[CellOT] epoch=250 f_loss=-720.4741 g_loss=805.8103 | train mmd=1.0092 | test_mmd=0.2679\n",
      "[CellOT] epoch=300 f_loss=-849.8708 g_loss=925.4035 | train mmd=0.9919 | test_mmd=0.2447\n",
      "[CellOT] epoch=350 f_loss=-793.8552 g_loss=1071.4226 | train mmd=0.7620 | test_mmd=0.1834\n",
      "[CellOT] epoch=400 f_loss=-843.4696 g_loss=668.1621 | train mmd=0.5925 | test_mmd=0.2128\n",
      "[CellOT] epoch=450 f_loss=-1036.6726 g_loss=1277.2020 | train mmd=0.9699 | test_mmd=0.1799\n",
      "[CellOT] epoch=500 f_loss=-1185.4167 g_loss=1355.4891 | train mmd=0.9992 | test_mmd=0.1746\n",
      "[CellOT] epoch=550 f_loss=-1119.9958 g_loss=1326.8462 | train mmd=0.8487 | test_mmd=0.1201\n",
      "[CellOT] epoch=600 f_loss=-1114.4030 g_loss=1477.2631 | train mmd=0.8870 | test_mmd=0.1206\n",
      "[CellOT] epoch=650 f_loss=-1232.4092 g_loss=1577.1852 | train mmd=0.9285 | test_mmd=0.1181\n",
      "[CellOT] epoch=700 f_loss=-1217.6587 g_loss=1694.1953 | train mmd=0.9111 | test_mmd=0.1034\n",
      "[CellOT] epoch=750 f_loss=-1225.6696 g_loss=1727.7162 | train mmd=0.8603 | test_mmd=0.0944\n",
      "[CellOT] epoch=800 f_loss=-1111.5337 g_loss=1767.6296 | train mmd=0.8416 | test_mmd=0.0782\n",
      "[CellOT] epoch=850 f_loss=-948.4614 g_loss=1688.9313 | train mmd=0.7310 | test_mmd=0.0519\n",
      "[CellOT] epoch=900 f_loss=-1129.5399 g_loss=1799.4421 | train mmd=0.7847 | test_mmd=0.0553\n",
      "[CellOT] epoch=950 f_loss=-1002.0483 g_loss=1747.5118 | train mmd=0.7710 | test_mmd=0.0463\n",
      "[CellOT] epoch=1000 f_loss=-772.9463 g_loss=1581.2362 | train mmd=0.6107 | test_mmd=0.0238\n",
      "[CellOT] epoch=1050 f_loss=-771.4091 g_loss=1683.7015 | train mmd=0.6809 | test_mmd=0.0319\n",
      "[CellOT] epoch=1100 f_loss=-538.8252 g_loss=1656.4385 | train mmd=0.5852 | test_mmd=0.0185\n",
      "[CellOT] epoch=1150 f_loss=-644.0994 g_loss=1664.0587 | train mmd=0.6314 | test_mmd=0.0209\n",
      "[CellOT] epoch=1200 f_loss=-446.4331 g_loss=1429.5552 | train mmd=0.6101 | test_mmd=0.0176\n",
      "[CellOT] epoch=1250 f_loss=-16.5226 g_loss=1255.1436 | train mmd=0.3828 | test_mmd=0.0108\n",
      "[CellOT] epoch=1300 f_loss=-122.8197 g_loss=1279.8164 | train mmd=0.5149 | test_mmd=0.0131\n",
      "[CellOT] epoch=1350 f_loss=89.3626 g_loss=1184.9371 | train mmd=0.5128 | test_mmd=0.0148\n",
      "[CellOT] epoch=1400 f_loss=413.9984 g_loss=859.5957 | train mmd=0.2913 | test_mmd=0.0155\n",
      "[CellOT] epoch=1450 f_loss=470.9344 g_loss=859.0602 | train mmd=0.2445 | test_mmd=0.0453\n",
      "[CellOT] epoch=1500 f_loss=379.1389 g_loss=1119.9081 | train mmd=0.3844 | test_mmd=0.0264\n",
      "[CellOT] epoch=1550 f_loss=-44.7018 g_loss=1767.6411 | train mmd=0.3810 | test_mmd=0.1174\n",
      "[CellOT] epoch=1600 f_loss=134.5357 g_loss=2533.3267 | train mmd=0.2788 | test_mmd=0.0443\n",
      "[CellOT] epoch=1650 f_loss=100.6769 g_loss=2958.4604 | train mmd=0.3178 | test_mmd=0.1634\n",
      "[CellOT] epoch=1700 f_loss=84.3169 g_loss=3486.2168 | train mmd=0.4590 | test_mmd=0.0196\n",
      "[CellOT] epoch=1750 f_loss=74.4838 g_loss=3670.9329 | train mmd=0.2478 | test_mmd=0.0645\n",
      "[CellOT] epoch=1800 f_loss=79.9976 g_loss=3897.4175 | train mmd=0.3698 | test_mmd=0.0177\n",
      "[CellOT] epoch=1850 f_loss=80.7391 g_loss=4257.2021 | train mmd=0.2231 | test_mmd=0.0682\n",
      "[CellOT] epoch=1900 f_loss=67.3442 g_loss=4397.0605 | train mmd=0.5439 | test_mmd=0.1585\n",
      "[CellOT] epoch=1950 f_loss=47.5572 g_loss=4725.2520 | train mmd=0.6861 | test_mmd=0.1103\n",
      "[CellOT] epoch=2000 f_loss=77.6005 g_loss=4765.6230 | train mmd=0.3586 | test_mmd=0.0514\n",
      "[CellOT] Final CellOT MMD: 0.1396\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-4213625.0000 g_loss=4525700.0000 | train mmd=0.1185 | test_mmd=0.8107\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.05137373265026257, 'mmd2_gamma_0.5': 0.3056502428197091, 'mmd2_gamma_1.0': 0.3567929890665314, 'wasserstein_distance': 3.1238175011323683, 'R2_feature_means': 0.910306099717158}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=247.8600 g_loss=221.7559 | train mmd=1.0891 | test_mmd=0.4349\n",
      "[CellOT] epoch=100 f_loss=-379.7336 g_loss=441.6958 | train mmd=1.1045 | test_mmd=0.4067\n",
      "[CellOT] epoch=150 f_loss=-596.9872 g_loss=662.2936 | train mmd=1.0060 | test_mmd=0.3465\n",
      "[CellOT] epoch=200 f_loss=-788.8937 g_loss=870.7578 | train mmd=1.0176 | test_mmd=0.3251\n",
      "[CellOT] epoch=250 f_loss=-932.2701 g_loss=1027.5007 | train mmd=0.9335 | test_mmd=0.2613\n",
      "[CellOT] epoch=300 f_loss=-766.6112 g_loss=1193.0459 | train mmd=0.3601 | test_mmd=0.1625\n",
      "[CellOT] epoch=350 f_loss=-1276.9941 g_loss=1473.5573 | train mmd=0.9936 | test_mmd=0.2407\n",
      "[CellOT] epoch=400 f_loss=-1078.8759 g_loss=1630.8850 | train mmd=0.6459 | test_mmd=0.2050\n",
      "[CellOT] epoch=450 f_loss=-1632.2537 g_loss=1771.1567 | train mmd=1.0385 | test_mmd=0.2229\n",
      "[CellOT] epoch=500 f_loss=-1574.7159 g_loss=1918.3818 | train mmd=0.8801 | test_mmd=0.1893\n",
      "[CellOT] epoch=550 f_loss=-919.5488 g_loss=2143.1948 | train mmd=0.3561 | test_mmd=0.5652\n",
      "[CellOT] epoch=600 f_loss=-1703.3831 g_loss=1711.2150 | train mmd=0.8594 | test_mmd=0.1272\n",
      "[CellOT] epoch=650 f_loss=-631.2380 g_loss=1275.2412 | train mmd=0.3019 | test_mmd=0.0804\n",
      "[CellOT] epoch=700 f_loss=-1713.8138 g_loss=2315.0854 | train mmd=0.4583 | test_mmd=0.1843\n",
      "[CellOT] epoch=750 f_loss=-781.8440 g_loss=2292.8933 | train mmd=0.3859 | test_mmd=0.1742\n",
      "[CellOT] epoch=800 f_loss=-1547.8594 g_loss=2583.0288 | train mmd=0.6754 | test_mmd=0.0612\n",
      "[CellOT] epoch=850 f_loss=-1721.4487 g_loss=2678.2424 | train mmd=0.7748 | test_mmd=0.0751\n",
      "[CellOT] epoch=900 f_loss=-1594.7397 g_loss=2494.5874 | train mmd=0.7104 | test_mmd=0.0528\n",
      "[CellOT] epoch=950 f_loss=-1662.0264 g_loss=2931.9443 | train mmd=0.6463 | test_mmd=0.0611\n",
      "[CellOT] epoch=1000 f_loss=-1607.3682 g_loss=2703.0964 | train mmd=0.7717 | test_mmd=0.0543\n",
      "[CellOT] epoch=1050 f_loss=-1315.1976 g_loss=2513.2629 | train mmd=0.5239 | test_mmd=0.0618\n",
      "[CellOT] epoch=1100 f_loss=-1628.4557 g_loss=2871.5398 | train mmd=0.7474 | test_mmd=0.0390\n",
      "[CellOT] epoch=1150 f_loss=-754.9382 g_loss=2244.8804 | train mmd=0.3249 | test_mmd=0.0161\n",
      "[CellOT] epoch=1200 f_loss=-878.6301 g_loss=2376.4355 | train mmd=0.5941 | test_mmd=0.0194\n",
      "[CellOT] epoch=1250 f_loss=-797.2093 g_loss=2289.5576 | train mmd=0.4967 | test_mmd=0.0151\n",
      "[CellOT] epoch=1300 f_loss=-252.4598 g_loss=1731.7407 | train mmd=0.2580 | test_mmd=0.0175\n",
      "[CellOT] epoch=1350 f_loss=-516.1512 g_loss=2219.5889 | train mmd=0.5874 | test_mmd=0.0162\n",
      "[CellOT] epoch=1400 f_loss=13.2852 g_loss=1732.5461 | train mmd=0.3273 | test_mmd=0.0140\n",
      "[CellOT] epoch=1450 f_loss=54.8380 g_loss=1779.5952 | train mmd=0.4310 | test_mmd=0.0119\n",
      "[CellOT] epoch=1500 f_loss=222.5132 g_loss=1566.1943 | train mmd=0.3270 | test_mmd=0.0157\n",
      "[CellOT] epoch=1550 f_loss=730.7355 g_loss=1162.3268 | train mmd=0.3685 | test_mmd=0.0275\n",
      "[CellOT] epoch=1600 f_loss=356.2205 g_loss=1677.9934 | train mmd=0.2087 | test_mmd=0.1850\n",
      "[CellOT] epoch=1650 f_loss=-253.4202 g_loss=1782.7062 | train mmd=0.2649 | test_mmd=0.2147\n",
      "[CellOT] epoch=1700 f_loss=-473.5537 g_loss=3754.2729 | train mmd=0.5865 | test_mmd=0.1069\n",
      "[CellOT] epoch=1750 f_loss=-766.1434 g_loss=5641.3857 | train mmd=0.5374 | test_mmd=0.3197\n",
      "[CellOT] epoch=1800 f_loss=238.5154 g_loss=2711.1406 | train mmd=0.1798 | test_mmd=0.0630\n",
      "[CellOT] epoch=1850 f_loss=299.7778 g_loss=3517.6748 | train mmd=0.4038 | test_mmd=0.0249\n",
      "[CellOT] epoch=1900 f_loss=224.5545 g_loss=4540.0312 | train mmd=0.3853 | test_mmd=0.0529\n",
      "[CellOT] epoch=1950 f_loss=141.2043 g_loss=4575.5571 | train mmd=0.2765 | test_mmd=0.0840\n",
      "[CellOT] epoch=2000 f_loss=272.6530 g_loss=5043.0137 | train mmd=0.2519 | test_mmd=0.0742\n",
      "[CellOT] Final CellOT MMD: 0.1304\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-2886774.5000 g_loss=3326428.5000 | train mmd=0.1185 | test_mmd=0.8107\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.07421138517591253, 'mmd2_gamma_0.5': 0.1669287534425148, 'mmd2_gamma_1.0': 0.23337519955985847, 'wasserstein_distance': 1.9678472865839698, 'R2_feature_means': 0.7298073351718868}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=245.6662 g_loss=238.0458 | train mmd=1.1071 | test_mmd=0.4399\n",
      "[CellOT] epoch=100 f_loss=-391.3844 g_loss=487.7002 | train mmd=1.1044 | test_mmd=0.4004\n",
      "[CellOT] epoch=150 f_loss=-645.7002 g_loss=685.3456 | train mmd=0.9263 | test_mmd=0.3231\n",
      "[CellOT] epoch=200 f_loss=-794.6005 g_loss=905.0718 | train mmd=0.9008 | test_mmd=0.2916\n",
      "[CellOT] epoch=250 f_loss=-954.6124 g_loss=1026.3502 | train mmd=0.9171 | test_mmd=0.2304\n",
      "[CellOT] epoch=300 f_loss=-1179.4114 g_loss=1226.3527 | train mmd=1.0025 | test_mmd=0.2393\n",
      "[CellOT] epoch=350 f_loss=-1323.4556 g_loss=1469.6667 | train mmd=0.9772 | test_mmd=0.2109\n",
      "[CellOT] epoch=400 f_loss=-1366.5129 g_loss=1605.2544 | train mmd=0.9022 | test_mmd=0.1665\n",
      "[CellOT] epoch=450 f_loss=-1346.1240 g_loss=1694.0427 | train mmd=0.7830 | test_mmd=0.1258\n",
      "[CellOT] epoch=500 f_loss=-1068.2063 g_loss=1623.4917 | train mmd=0.4948 | test_mmd=0.0938\n",
      "[CellOT] epoch=550 f_loss=-1665.9164 g_loss=2087.9343 | train mmd=0.9718 | test_mmd=0.1464\n",
      "[CellOT] epoch=600 f_loss=-1516.9655 g_loss=1887.9907 | train mmd=0.7845 | test_mmd=0.0941\n",
      "[CellOT] epoch=650 f_loss=-1594.3129 g_loss=2149.0706 | train mmd=0.8690 | test_mmd=0.1048\n",
      "[CellOT] epoch=700 f_loss=-1355.0922 g_loss=1805.3926 | train mmd=0.5283 | test_mmd=0.0609\n",
      "[CellOT] epoch=750 f_loss=-556.0911 g_loss=1986.2472 | train mmd=0.2895 | test_mmd=0.0424\n",
      "[CellOT] epoch=800 f_loss=-1460.5514 g_loss=2301.0854 | train mmd=0.7308 | test_mmd=0.0501\n",
      "[CellOT] epoch=850 f_loss=-938.9139 g_loss=1162.6946 | train mmd=0.4848 | test_mmd=0.0401\n",
      "[CellOT] epoch=900 f_loss=-1377.3303 g_loss=1819.2592 | train mmd=0.6410 | test_mmd=0.0364\n",
      "[CellOT] epoch=950 f_loss=-1274.7777 g_loss=2447.9355 | train mmd=0.7158 | test_mmd=0.0380\n",
      "[CellOT] epoch=1000 f_loss=-1209.0228 g_loss=2196.1138 | train mmd=0.6301 | test_mmd=0.0255\n",
      "[CellOT] epoch=1050 f_loss=-752.3320 g_loss=2260.6050 | train mmd=0.5942 | test_mmd=0.0227\n",
      "[CellOT] epoch=1100 f_loss=-671.4460 g_loss=2185.1013 | train mmd=0.6137 | test_mmd=0.0202\n",
      "[CellOT] epoch=1150 f_loss=-617.0885 g_loss=1966.3296 | train mmd=0.6066 | test_mmd=0.0190\n",
      "[CellOT] epoch=1200 f_loss=-456.5461 g_loss=2146.3394 | train mmd=0.5574 | test_mmd=0.0146\n",
      "[CellOT] epoch=1250 f_loss=-176.3312 g_loss=1959.1912 | train mmd=0.5223 | test_mmd=0.0150\n",
      "[CellOT] epoch=1300 f_loss=101.8783 g_loss=1639.7192 | train mmd=0.5314 | test_mmd=0.0151\n",
      "[CellOT] epoch=1350 f_loss=227.5127 g_loss=1438.5919 | train mmd=0.5057 | test_mmd=0.0165\n",
      "[CellOT] epoch=1400 f_loss=632.7687 g_loss=1325.2837 | train mmd=0.3075 | test_mmd=0.0223\n",
      "[CellOT] epoch=1450 f_loss=774.2883 g_loss=882.9651 | train mmd=0.2315 | test_mmd=0.0457\n",
      "[CellOT] epoch=1500 f_loss=-994.7198 g_loss=735.2195 | train mmd=0.2762 | test_mmd=0.1069\n",
      "[CellOT] epoch=1550 f_loss=332.0021 g_loss=1805.4993 | train mmd=0.2549 | test_mmd=0.0796\n",
      "[CellOT] epoch=1600 f_loss=297.6932 g_loss=2217.4917 | train mmd=0.3784 | test_mmd=0.0290\n",
      "[CellOT] epoch=1650 f_loss=173.6091 g_loss=2588.3606 | train mmd=0.3701 | test_mmd=0.0232\n",
      "[CellOT] epoch=1700 f_loss=208.7987 g_loss=2776.2988 | train mmd=0.3553 | test_mmd=0.0245\n",
      "[CellOT] epoch=1750 f_loss=241.4013 g_loss=2969.6323 | train mmd=0.2370 | test_mmd=0.0299\n",
      "[CellOT] epoch=1800 f_loss=260.0606 g_loss=3457.8157 | train mmd=0.3501 | test_mmd=0.1665\n",
      "[CellOT] epoch=1850 f_loss=-43.9305 g_loss=3826.5649 | train mmd=0.2897 | test_mmd=0.0917\n",
      "[CellOT] epoch=1900 f_loss=-253.9261 g_loss=4540.6025 | train mmd=0.8153 | test_mmd=0.2857\n",
      "[CellOT] epoch=1950 f_loss=-340.5716 g_loss=4627.4414 | train mmd=0.3162 | test_mmd=0.1097\n",
      "[CellOT] epoch=2000 f_loss=102.9020 g_loss=5281.1230 | train mmd=0.6476 | test_mmd=0.0374\n",
      "[CellOT] Final CellOT MMD: 0.2548\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.03743563584247167, 'mmd2_gamma_0.5': 0.43201789210206043, 'mmd2_gamma_1.0': 0.6191142970284261, 'wasserstein_distance': 1.8955396363020385, 'R2_feature_means': 0.955476833240327}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-2328122.7500 g_loss=2521260.7500 | train mmd=0.1185 | test_mmd=0.8107\n",
      "[CellOT] epoch=50 f_loss=188.5659 g_loss=226.3967 | train mmd=1.1066 | test_mmd=0.4374\n",
      "[CellOT] epoch=100 f_loss=-354.7953 g_loss=447.7141 | train mmd=1.1041 | test_mmd=0.3983\n",
      "[CellOT] epoch=150 f_loss=-526.5988 g_loss=582.7883 | train mmd=0.8551 | test_mmd=0.2986\n",
      "[CellOT] epoch=200 f_loss=-719.0788 g_loss=831.2445 | train mmd=0.8794 | test_mmd=0.2801\n",
      "[CellOT] epoch=250 f_loss=-957.3484 g_loss=1098.7130 | train mmd=1.0129 | test_mmd=0.2682\n",
      "[CellOT] epoch=300 f_loss=-1185.6322 g_loss=1278.3073 | train mmd=1.0547 | test_mmd=0.2568\n",
      "[CellOT] epoch=350 f_loss=-1240.6433 g_loss=1455.3107 | train mmd=1.0116 | test_mmd=0.2190\n",
      "[CellOT] epoch=400 f_loss=-1373.8350 g_loss=1585.3140 | train mmd=1.0112 | test_mmd=0.1979\n",
      "[CellOT] epoch=450 f_loss=-1418.2158 g_loss=1721.6987 | train mmd=0.9612 | test_mmd=0.1663\n",
      "[CellOT] epoch=500 f_loss=-1171.8536 g_loss=1361.1953 | train mmd=0.6254 | test_mmd=0.0990\n",
      "[CellOT] epoch=550 f_loss=-1273.1912 g_loss=1219.8064 | train mmd=0.7587 | test_mmd=0.1065\n",
      "[CellOT] epoch=600 f_loss=-1620.3103 g_loss=2057.1926 | train mmd=0.9182 | test_mmd=0.1136\n",
      "[CellOT] epoch=650 f_loss=-1562.0679 g_loss=2137.2290 | train mmd=0.8827 | test_mmd=0.0953\n",
      "[CellOT] epoch=700 f_loss=-1348.4045 g_loss=1991.9690 | train mmd=0.7444 | test_mmd=0.0703\n",
      "[CellOT] epoch=750 f_loss=-1612.1821 g_loss=2268.4182 | train mmd=0.8254 | test_mmd=0.0652\n",
      "[CellOT] epoch=800 f_loss=-993.5649 g_loss=1976.6199 | train mmd=0.6465 | test_mmd=0.0366\n",
      "[CellOT] epoch=850 f_loss=-76.5689 g_loss=1154.4631 | train mmd=0.2300 | test_mmd=0.5229\n",
      "[CellOT] epoch=900 f_loss=-900.1405 g_loss=2207.6350 | train mmd=0.6058 | test_mmd=0.0197\n",
      "[CellOT] epoch=950 f_loss=-511.1729 g_loss=1843.3516 | train mmd=0.4567 | test_mmd=0.0119\n",
      "[CellOT] epoch=1000 f_loss=-595.4777 g_loss=1966.2393 | train mmd=0.6122 | test_mmd=0.0178\n",
      "[CellOT] epoch=1050 f_loss=-531.3481 g_loss=1805.9972 | train mmd=0.5589 | test_mmd=0.0137\n",
      "[CellOT] epoch=1100 f_loss=-179.3153 g_loss=1893.4895 | train mmd=0.5621 | test_mmd=0.0134\n",
      "[CellOT] epoch=1150 f_loss=192.9076 g_loss=1621.2467 | train mmd=0.4926 | test_mmd=0.0129\n",
      "[CellOT] epoch=1200 f_loss=255.4419 g_loss=1166.9945 | train mmd=0.5000 | test_mmd=0.0158\n",
      "[CellOT] epoch=1250 f_loss=393.2974 g_loss=949.9042 | train mmd=0.1920 | test_mmd=0.1367\n",
      "[CellOT] epoch=1300 f_loss=221.0419 g_loss=1828.1753 | train mmd=0.7197 | test_mmd=0.1706\n",
      "[CellOT] epoch=1350 f_loss=208.6341 g_loss=2835.7546 | train mmd=0.2729 | test_mmd=0.0239\n",
      "[CellOT] epoch=1400 f_loss=242.2504 g_loss=3467.3821 | train mmd=0.4433 | test_mmd=0.0676\n",
      "[CellOT] epoch=1450 f_loss=224.5213 g_loss=3639.1255 | train mmd=0.2041 | test_mmd=0.0637\n",
      "[CellOT] epoch=1500 f_loss=105.6622 g_loss=4045.7480 | train mmd=0.6807 | test_mmd=0.0776\n",
      "[CellOT] epoch=1550 f_loss=175.8579 g_loss=4230.0596 | train mmd=0.2268 | test_mmd=0.0700\n",
      "[CellOT] epoch=1600 f_loss=181.0647 g_loss=4569.4980 | train mmd=0.3374 | test_mmd=0.3227\n",
      "[CellOT] epoch=1650 f_loss=162.2422 g_loss=4789.8574 | train mmd=0.2336 | test_mmd=0.0497\n",
      "[CellOT] epoch=1700 f_loss=83.1925 g_loss=5073.3438 | train mmd=0.5110 | test_mmd=0.1964\n",
      "[CellOT] epoch=1750 f_loss=73.0711 g_loss=5274.3389 | train mmd=0.5388 | test_mmd=0.1160\n",
      "[CellOT] epoch=1800 f_loss=108.9017 g_loss=5523.1172 | train mmd=0.2453 | test_mmd=0.0646\n",
      "[CellOT] epoch=1850 f_loss=107.7232 g_loss=5634.0645 | train mmd=0.3335 | test_mmd=0.0309\n",
      "[CellOT] epoch=1900 f_loss=49.5514 g_loss=5776.3149 | train mmd=0.2598 | test_mmd=0.0791\n",
      "[CellOT] epoch=1950 f_loss=80.3677 g_loss=5889.9766 | train mmd=0.6301 | test_mmd=0.0925\n",
      "[CellOT] epoch=2000 f_loss=107.4787 g_loss=6019.0459 | train mmd=0.3128 | test_mmd=0.1055\n",
      "[CellOT] Final CellOT MMD: 0.1576\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 metrics: {'mmd2_gamma_median': 0.10554215357501562, 'mmd2_gamma_0.5': 0.2675949330089795, 'mmd2_gamma_1.0': 0.2941804843164414, 'wasserstein_distance': 2.0639303756998744, 'R2_feature_means': 0.6488225659006475}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.1109  0.1068\n",
      "mmd2_gamma_0.5        0.3582  0.1757\n",
      "mmd2_gamma_1.0        0.3920  0.1682\n",
      "wasserstein_distance  2.6776  1.1065\n",
      "R2_feature_means      0.7696  0.1971\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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zz3o6gR7gkMyMBwILee7g4svvpizzjqLu+66i/vuu4+rr76a//zP/+QLX/gCyWSS8847j+9973tln5s1a5b/72g0Wvb+Rz7yEVauXElfXx/3338/4XCY8977YTRNwdRkofG231zPrLYWKdQXiGDn0wS0UqaS4q58XLqri2r9HaXwiq7REsmTZDLJrFmzePjhh8s+U19fD8A///M/c//99/ODH/yAxYsXEw6Hed/73kc+L/fjrVzGUiuy2J5Kpvj0pz/NF7/4RfcY8uTjvQhg7ty5bNi4qejzYxBYmVHyoz1lTXLhcLjsOCd7PtGA65fgMoy8wrhHFRaOharp3PmHX/L3Z57joade4Mc/vpavfeM/ePTePzNvTkdRX4ZqBNFtsVuqu4WDbm60l54npTFNYQ5fuLpLgsq18vFW51My3BkHkx2wJ+M2VzP7KIJ1bdhmVgZVM4M2hRTc6wWHZGDY1y3nixYt8vP68+bNA6Tu06pVq/wUhoenn36auXPnAjA8PMyGDRuK0hZz5szhM5/5DJ/5zGe44ooruO666/jCF77Asccey6233sr8+fOnLFz4pje9iTlz5vC73/2Oe+65h/e///0EI3LlceRRxxAMBukZynDmO072Z8dmegQz0Y9wLJYtWchd9z2M6vVAKCrPrlvvf381OqlhGL4/uJdqKiy6egPtscceS29vL7qu+0XqUjzxxBN87GMf4z3veQ8gB9+tW7eOHYMRJBAM4dh2ERtpxYpjeOnFdSycN8ef9ZvpDj/ttXTJIizL4oW1L/qpoFdeXMfIyGjVJrmamhrmz5/P3/72N9785jeXHetE5+OYObRgDFUz/GugqBqKLgOrsPOoisppZ76d0992Dl+99GMsO+4M7rjrXr74uU/5zY/TIVHiDbqZga30uZMpLRRzGVC2pDUrCkYVCuiBIAhX6VjGc5vzxgbPI+H1Xk+ohEMyMMC+5RZHo1E++9nP8pWvfIXGxkbmzp3L97//fdLpNJ/85CeLtv2P//gPmpqaaGtr49/+7d9obm72ef6XX345Z599NocddhjDw8M89NBDftD4/Oc/z3XXXceHP/xhvvrVr9LY2MimTZv47W9/y/XXX++btVTDP/zDP/DTn/6UDRs28NBDD/mv19TU8M///M98+StfBVXj1FNPZXR0lCeeeIJYJMw/fvh9fObzX+BHP/slX//+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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",
    "\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": 6,
   "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=-3293185.7500 g_loss=4001156.7500 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=313.6370 g_loss=298.8002 | train mmd=0.9477 | test_mmd=0.3697\n",
      "[CellOT] epoch=100 f_loss=-370.8302 g_loss=771.5830 | train mmd=1.0234 | test_mmd=0.3627\n",
      "[CellOT] epoch=150 f_loss=-598.0834 g_loss=592.2323 | train mmd=1.0381 | test_mmd=0.3329\n",
      "[CellOT] epoch=200 f_loss=-782.6732 g_loss=828.0439 | train mmd=0.9458 | test_mmd=0.2726\n",
      "[CellOT] epoch=250 f_loss=-907.7195 g_loss=977.7778 | train mmd=0.8622 | test_mmd=0.2427\n",
      "[CellOT] epoch=300 f_loss=-1139.2981 g_loss=1166.6775 | train mmd=0.9431 | test_mmd=0.2478\n",
      "[CellOT] epoch=350 f_loss=-1166.7469 g_loss=1317.4495 | train mmd=0.8211 | test_mmd=0.1946\n",
      "[CellOT] epoch=400 f_loss=-1434.6980 g_loss=1499.5068 | train mmd=0.8808 | test_mmd=0.1882\n",
      "[CellOT] epoch=450 f_loss=-1425.5786 g_loss=1625.4021 | train mmd=0.7927 | test_mmd=0.1661\n",
      "[CellOT] epoch=500 f_loss=-1566.7004 g_loss=2023.5413 | train mmd=0.7285 | test_mmd=0.1324\n",
      "[CellOT] epoch=550 f_loss=-1383.1436 g_loss=2353.3391 | train mmd=0.5498 | test_mmd=0.1211\n",
      "[CellOT] epoch=600 f_loss=-1707.4974 g_loss=1994.3936 | train mmd=0.6668 | test_mmd=0.1019\n",
      "[CellOT] epoch=650 f_loss=-1803.2227 g_loss=1957.5042 | train mmd=0.7150 | test_mmd=0.0916\n",
      "[CellOT] epoch=700 f_loss=-1695.1033 g_loss=2043.3317 | train mmd=0.5276 | test_mmd=0.0720\n",
      "[CellOT] epoch=750 f_loss=-1641.0349 g_loss=2058.0623 | train mmd=0.5394 | test_mmd=0.0657\n",
      "[CellOT] epoch=800 f_loss=-1791.3826 g_loss=2500.4956 | train mmd=0.5765 | test_mmd=0.0534\n",
      "[CellOT] epoch=850 f_loss=-2131.9663 g_loss=2417.4917 | train mmd=0.4883 | test_mmd=0.0448\n",
      "[CellOT] epoch=900 f_loss=-1634.2041 g_loss=2145.1318 | train mmd=0.4609 | test_mmd=0.0613\n",
      "[CellOT] epoch=950 f_loss=-1469.7360 g_loss=2602.5898 | train mmd=0.4674 | test_mmd=0.0306\n",
      "[CellOT] epoch=1000 f_loss=-1331.5989 g_loss=2199.4768 | train mmd=0.3816 | test_mmd=0.0220\n",
      "[CellOT] epoch=1050 f_loss=-1576.3174 g_loss=2014.7231 | train mmd=0.4301 | test_mmd=0.0258\n",
      "[CellOT] epoch=1100 f_loss=-1398.7097 g_loss=2164.0574 | train mmd=0.4057 | test_mmd=0.0243\n",
      "[CellOT] epoch=1150 f_loss=-665.0698 g_loss=1832.1941 | train mmd=0.3143 | test_mmd=0.0204\n",
      "[CellOT] epoch=1200 f_loss=-582.1789 g_loss=2081.4531 | train mmd=0.3388 | test_mmd=0.0185\n",
      "[CellOT] epoch=1250 f_loss=-544.7415 g_loss=1395.6277 | train mmd=0.3280 | test_mmd=0.0185\n",
      "[CellOT] epoch=1300 f_loss=-494.0707 g_loss=1255.1189 | train mmd=0.2896 | test_mmd=0.0195\n",
      "[CellOT] epoch=1350 f_loss=476.0347 g_loss=802.4150 | train mmd=0.1659 | test_mmd=0.0359\n",
      "[CellOT] epoch=1400 f_loss=304.2022 g_loss=797.1251 | train mmd=0.2625 | test_mmd=0.0218\n",
      "[CellOT] epoch=1450 f_loss=363.6730 g_loss=2229.5000 | train mmd=0.3882 | test_mmd=0.0640\n",
      "[CellOT] epoch=1500 f_loss=331.9918 g_loss=1124.6199 | train mmd=0.3585 | test_mmd=0.1300\n",
      "[CellOT] epoch=1550 f_loss=-388.2453 g_loss=811.2471 | train mmd=0.3511 | test_mmd=0.1835\n",
      "[CellOT] epoch=1600 f_loss=366.0040 g_loss=1015.8681 | train mmd=0.3573 | test_mmd=0.1944\n",
      "[CellOT] epoch=1650 f_loss=310.0618 g_loss=934.4562 | train mmd=0.2191 | test_mmd=0.1157\n",
      "[CellOT] epoch=1700 f_loss=255.9509 g_loss=1018.8375 | train mmd=0.2122 | test_mmd=0.0743\n",
      "[CellOT] epoch=1750 f_loss=160.4413 g_loss=1210.0945 | train mmd=0.3276 | test_mmd=0.0679\n",
      "[CellOT] epoch=1800 f_loss=180.6937 g_loss=1058.1133 | train mmd=0.3501 | test_mmd=0.1251\n",
      "[CellOT] epoch=1850 f_loss=74.1509 g_loss=1324.8516 | train mmd=0.2332 | test_mmd=0.1152\n",
      "[CellOT] epoch=1900 f_loss=162.2161 g_loss=1153.6140 | train mmd=0.2467 | test_mmd=0.0633\n",
      "[CellOT] epoch=1950 f_loss=46.8399 g_loss=1239.3926 | train mmd=0.3262 | test_mmd=0.1106\n",
      "[CellOT] epoch=2000 f_loss=26.8745 g_loss=1287.1382 | train mmd=0.4392 | test_mmd=0.1160\n",
      "[CellOT] Final CellOT MMD: 0.1553\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.11601236330802611, 'mmd2_gamma_0.5': 0.3485404976033265, 'mmd2_gamma_1.0': 0.3353862800875512, 'wasserstein_distance': 1.6419508836165098, 'R2_feature_means': 0.8571270240342516}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-2433932.5000 g_loss=2727337.7500 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=466.4554 g_loss=248.7774 | train mmd=0.9549 | test_mmd=0.3781\n",
      "[CellOT] epoch=100 f_loss=-316.3628 g_loss=384.7919 | train mmd=1.0800 | test_mmd=0.3636\n",
      "[CellOT] epoch=150 f_loss=-490.9431 g_loss=567.2449 | train mmd=0.8567 | test_mmd=0.2518\n",
      "[CellOT] epoch=200 f_loss=-724.0776 g_loss=760.9667 | train mmd=0.8456 | test_mmd=0.2821\n",
      "[CellOT] epoch=250 f_loss=-840.4196 g_loss=888.5850 | train mmd=0.7527 | test_mmd=0.2186\n",
      "[CellOT] epoch=300 f_loss=-913.6671 g_loss=1090.5935 | train mmd=0.7028 | test_mmd=0.1863\n",
      "[CellOT] epoch=350 f_loss=-1101.0652 g_loss=1209.5695 | train mmd=0.7564 | test_mmd=0.1786\n",
      "[CellOT] epoch=400 f_loss=-1410.7957 g_loss=1406.1963 | train mmd=0.8299 | test_mmd=0.1636\n",
      "[CellOT] epoch=450 f_loss=-1378.2089 g_loss=1522.6689 | train mmd=0.8320 | test_mmd=0.1552\n",
      "[CellOT] epoch=500 f_loss=-1789.2925 g_loss=1762.1350 | train mmd=0.4559 | test_mmd=0.2452\n",
      "[CellOT] epoch=550 f_loss=-1671.7628 g_loss=1667.6113 | train mmd=0.7556 | test_mmd=0.1123\n",
      "[CellOT] epoch=600 f_loss=-1789.3889 g_loss=1752.1224 | train mmd=0.7342 | test_mmd=0.0970\n",
      "[CellOT] epoch=650 f_loss=-1594.0371 g_loss=1956.5071 | train mmd=0.5538 | test_mmd=0.0815\n",
      "[CellOT] epoch=700 f_loss=-1417.8163 g_loss=1799.2419 | train mmd=0.5207 | test_mmd=0.0530\n",
      "[CellOT] epoch=750 f_loss=-1525.0708 g_loss=2308.5601 | train mmd=0.3816 | test_mmd=0.0611\n",
      "[CellOT] epoch=800 f_loss=-1716.1951 g_loss=2188.0886 | train mmd=0.5514 | test_mmd=0.0512\n",
      "[CellOT] epoch=850 f_loss=-1386.0034 g_loss=1681.9104 | train mmd=0.4759 | test_mmd=0.0395\n",
      "[CellOT] epoch=900 f_loss=-1466.1838 g_loss=2190.7104 | train mmd=0.3771 | test_mmd=0.0279\n",
      "[CellOT] epoch=950 f_loss=-966.9686 g_loss=2379.9695 | train mmd=0.3002 | test_mmd=0.0747\n",
      "[CellOT] epoch=1000 f_loss=-1259.1240 g_loss=2024.6912 | train mmd=0.4222 | test_mmd=0.0190\n",
      "[CellOT] epoch=1050 f_loss=-1094.6824 g_loss=2173.3872 | train mmd=0.3724 | test_mmd=0.0186\n",
      "[CellOT] epoch=1100 f_loss=-879.5077 g_loss=1855.5498 | train mmd=0.3053 | test_mmd=0.0178\n",
      "[CellOT] epoch=1150 f_loss=-640.2965 g_loss=2017.4231 | train mmd=0.2851 | test_mmd=0.0156\n",
      "[CellOT] epoch=1200 f_loss=-564.2725 g_loss=1802.5122 | train mmd=0.3301 | test_mmd=0.0211\n",
      "[CellOT] epoch=1250 f_loss=-36.4086 g_loss=1322.6804 | train mmd=0.2388 | test_mmd=0.0278\n",
      "[CellOT] epoch=1300 f_loss=240.1799 g_loss=739.7035 | train mmd=0.1943 | test_mmd=0.0360\n",
      "[CellOT] epoch=1350 f_loss=539.3593 g_loss=934.9984 | train mmd=0.1921 | test_mmd=0.0575\n",
      "[CellOT] epoch=1400 f_loss=-434.2458 g_loss=322.4733 | train mmd=0.2721 | test_mmd=0.0406\n",
      "[CellOT] epoch=1450 f_loss=286.0771 g_loss=358.5922 | train mmd=0.1611 | test_mmd=0.0862\n",
      "[CellOT] epoch=1500 f_loss=204.6957 g_loss=247.9815 | train mmd=0.2699 | test_mmd=0.1719\n",
      "[CellOT] epoch=1550 f_loss=171.1756 g_loss=252.9850 | train mmd=0.1907 | test_mmd=0.0769\n",
      "[CellOT] epoch=1600 f_loss=50.8750 g_loss=223.3136 | train mmd=0.2316 | test_mmd=0.0947\n",
      "[CellOT] epoch=1650 f_loss=52.4712 g_loss=220.1849 | train mmd=0.3026 | test_mmd=0.1258\n",
      "[CellOT] epoch=1700 f_loss=7.2666 g_loss=227.5421 | train mmd=0.3230 | test_mmd=0.0625\n",
      "[CellOT] epoch=1750 f_loss=23.1709 g_loss=239.3841 | train mmd=0.2919 | test_mmd=0.0696\n",
      "[CellOT] epoch=1800 f_loss=17.9358 g_loss=245.0127 | train mmd=0.2825 | test_mmd=0.2531\n",
      "[CellOT] epoch=1850 f_loss=8.7748 g_loss=256.6972 | train mmd=0.2485 | test_mmd=0.0652\n",
      "[CellOT] epoch=1900 f_loss=42.9110 g_loss=261.3045 | train mmd=0.3516 | test_mmd=0.0327\n",
      "[CellOT] epoch=1950 f_loss=26.3978 g_loss=273.8813 | train mmd=0.2967 | test_mmd=0.1432\n",
      "[CellOT] epoch=2000 f_loss=6.5786 g_loss=289.8936 | train mmd=0.2009 | test_mmd=0.0404\n",
      "[CellOT] Final CellOT MMD: 0.0738\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.040396087698039596, 'mmd2_gamma_0.5': 0.14685640000385947, 'mmd2_gamma_1.0': 0.1701485927787531, 'wasserstein_distance': 2.4303621553922277, 'R2_feature_means': 0.9428924425803737}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-3001315.0000 g_loss=3573052.0000 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=118.6887 g_loss=196.4749 | train mmd=0.5451 | test_mmd=0.4268\n",
      "[CellOT] epoch=100 f_loss=-271.7816 g_loss=340.0143 | train mmd=1.0590 | test_mmd=0.3472\n",
      "[CellOT] epoch=150 f_loss=-494.3539 g_loss=518.1091 | train mmd=1.0454 | test_mmd=0.3331\n",
      "[CellOT] epoch=200 f_loss=-557.4371 g_loss=721.1711 | train mmd=0.7373 | test_mmd=0.2358\n",
      "[CellOT] epoch=250 f_loss=-821.4548 g_loss=903.7213 | train mmd=0.8941 | test_mmd=0.2462\n",
      "[CellOT] epoch=300 f_loss=-1004.8481 g_loss=1027.8206 | train mmd=0.8686 | test_mmd=0.2206\n",
      "[CellOT] epoch=350 f_loss=-1090.1448 g_loss=1205.1404 | train mmd=0.8202 | test_mmd=0.1986\n",
      "[CellOT] epoch=400 f_loss=-1401.8542 g_loss=1364.4882 | train mmd=0.8605 | test_mmd=0.1926\n",
      "[CellOT] epoch=450 f_loss=-1415.7297 g_loss=1422.0640 | train mmd=0.7655 | test_mmd=0.1516\n",
      "[CellOT] epoch=500 f_loss=-1788.1355 g_loss=1986.2545 | train mmd=0.8099 | test_mmd=0.1525\n",
      "[CellOT] epoch=550 f_loss=-2185.4172 g_loss=2355.1807 | train mmd=0.8213 | test_mmd=0.1421\n",
      "[CellOT] epoch=600 f_loss=-2259.2227 g_loss=2389.6133 | train mmd=0.7027 | test_mmd=0.1122\n",
      "[CellOT] epoch=650 f_loss=-2089.3845 g_loss=2149.3035 | train mmd=0.5000 | test_mmd=0.0806\n",
      "[CellOT] epoch=700 f_loss=-2154.0618 g_loss=2511.4126 | train mmd=0.4571 | test_mmd=0.0720\n",
      "[CellOT] epoch=750 f_loss=-2528.3755 g_loss=2709.3535 | train mmd=0.4523 | test_mmd=0.1082\n",
      "[CellOT] epoch=800 f_loss=-967.0827 g_loss=2096.4290 | train mmd=0.2372 | test_mmd=0.2487\n",
      "[CellOT] epoch=850 f_loss=-1281.5812 g_loss=1756.7855 | train mmd=0.2241 | test_mmd=0.1971\n",
      "[CellOT] epoch=900 f_loss=-855.9709 g_loss=1201.1937 | train mmd=0.1836 | test_mmd=0.1809\n",
      "[CellOT] epoch=950 f_loss=-1875.0471 g_loss=2792.5710 | train mmd=0.3033 | test_mmd=0.1033\n",
      "[CellOT] epoch=1000 f_loss=-582.3041 g_loss=1173.0552 | train mmd=0.1472 | test_mmd=0.3059\n",
      "[CellOT] epoch=1050 f_loss=-371.9108 g_loss=1464.7207 | train mmd=0.1412 | test_mmd=0.3275\n",
      "[CellOT] epoch=1100 f_loss=110.8128 g_loss=43.9425 | train mmd=0.1722 | test_mmd=0.3840\n",
      "[CellOT] epoch=1150 f_loss=66.5228 g_loss=106.6505 | train mmd=0.1928 | test_mmd=0.2425\n",
      "[CellOT] epoch=1200 f_loss=113.3548 g_loss=14.0463 | train mmd=0.1792 | test_mmd=0.0675\n",
      "[CellOT] epoch=1250 f_loss=31.2083 g_loss=2.1628 | train mmd=0.1111 | test_mmd=0.0369\n",
      "[CellOT] epoch=1300 f_loss=48.6137 g_loss=7.0612 | train mmd=0.1282 | test_mmd=0.0440\n",
      "[CellOT] epoch=1350 f_loss=26.4298 g_loss=17.5129 | train mmd=0.1100 | test_mmd=0.0330\n",
      "[CellOT] epoch=1400 f_loss=3.0342 g_loss=2.1797 | train mmd=0.0936 | test_mmd=0.0280\n",
      "[CellOT] epoch=1450 f_loss=2.4445 g_loss=3.0320 | train mmd=0.1497 | test_mmd=0.0327\n",
      "[CellOT] epoch=1500 f_loss=1.4250 g_loss=4.6662 | train mmd=0.0392 | test_mmd=0.0131\n",
      "[CellOT] epoch=1550 f_loss=-0.0562 g_loss=6.0893 | train mmd=0.0762 | test_mmd=0.0194\n",
      "[CellOT] epoch=1600 f_loss=4.2122 g_loss=6.7169 | train mmd=0.0286 | test_mmd=0.0166\n",
      "[CellOT] epoch=1650 f_loss=-3.9119 g_loss=7.3768 | train mmd=0.1836 | test_mmd=0.0540\n",
      "[CellOT] epoch=1700 f_loss=1.2233 g_loss=7.1175 | train mmd=0.0867 | test_mmd=0.0205\n",
      "[CellOT] epoch=1750 f_loss=0.4185 g_loss=8.5698 | train mmd=0.0415 | test_mmd=0.0131\n",
      "[CellOT] epoch=1800 f_loss=0.0244 g_loss=8.8803 | train mmd=0.0616 | test_mmd=0.0113\n",
      "[CellOT] epoch=1850 f_loss=-0.7204 g_loss=9.0705 | train mmd=0.0784 | test_mmd=0.0183\n",
      "[CellOT] epoch=1900 f_loss=-0.2405 g_loss=10.3250 | train mmd=0.0579 | test_mmd=0.0202\n",
      "[CellOT] epoch=1950 f_loss=-3.8416 g_loss=11.1228 | train mmd=0.0771 | test_mmd=0.0243\n",
      "[CellOT] epoch=2000 f_loss=8.1395 g_loss=12.9767 | train mmd=0.0707 | test_mmd=0.0258\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.0273\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.025772830690538484, 'mmd2_gamma_0.5': 0.05563519446454546, 'mmd2_gamma_1.0': 0.06433591621266843, 'wasserstein_distance': 1.6673769695901608, 'R2_feature_means': 0.9466498244410881}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-3491096.0000 g_loss=4013566.2500 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=301.2227 g_loss=1111.2889 | train mmd=0.9855 | test_mmd=0.3346\n",
      "[CellOT] epoch=100 f_loss=-435.6528 g_loss=535.6312 | train mmd=1.0637 | test_mmd=0.3386\n",
      "[CellOT] epoch=150 f_loss=-731.9004 g_loss=727.8257 | train mmd=0.9196 | test_mmd=0.2987\n",
      "[CellOT] epoch=200 f_loss=-924.6926 g_loss=867.5835 | train mmd=0.8480 | test_mmd=0.2422\n",
      "[CellOT] epoch=250 f_loss=-1172.4475 g_loss=1073.8701 | train mmd=0.8451 | test_mmd=0.2143\n",
      "[CellOT] epoch=300 f_loss=-1406.4363 g_loss=1442.8232 | train mmd=0.6626 | test_mmd=0.1823\n",
      "[CellOT] epoch=350 f_loss=-1615.6409 g_loss=1649.9209 | train mmd=0.8633 | test_mmd=0.1812\n",
      "[CellOT] epoch=400 f_loss=-1755.6091 g_loss=1872.6418 | train mmd=0.8641 | test_mmd=0.1625\n",
      "[CellOT] epoch=450 f_loss=-1805.1624 g_loss=2109.8594 | train mmd=0.7340 | test_mmd=0.1335\n",
      "[CellOT] epoch=500 f_loss=-2033.4915 g_loss=2309.3394 | train mmd=0.7808 | test_mmd=0.1347\n",
      "[CellOT] epoch=550 f_loss=-1978.2484 g_loss=2363.5615 | train mmd=0.6969 | test_mmd=0.0919\n",
      "[CellOT] epoch=600 f_loss=-1686.5958 g_loss=2540.5190 | train mmd=0.5575 | test_mmd=0.1000\n",
      "[CellOT] epoch=650 f_loss=-1984.0005 g_loss=3101.5537 | train mmd=0.6192 | test_mmd=0.0734\n",
      "[CellOT] epoch=700 f_loss=-2180.3542 g_loss=2676.8892 | train mmd=0.6345 | test_mmd=0.0626\n",
      "[CellOT] epoch=750 f_loss=-2038.3337 g_loss=2834.4133 | train mmd=0.5704 | test_mmd=0.0505\n",
      "[CellOT] epoch=800 f_loss=-2048.3369 g_loss=2573.8250 | train mmd=0.5175 | test_mmd=0.0356\n",
      "[CellOT] epoch=850 f_loss=-1771.6100 g_loss=2766.3501 | train mmd=0.4879 | test_mmd=0.0317\n",
      "[CellOT] epoch=900 f_loss=-1292.7306 g_loss=3211.5928 | train mmd=0.3696 | test_mmd=0.1315\n",
      "[CellOT] epoch=950 f_loss=-1235.2563 g_loss=2482.3335 | train mmd=0.3868 | test_mmd=0.0540\n",
      "[CellOT] epoch=1000 f_loss=-1131.1436 g_loss=2612.6531 | train mmd=0.3331 | test_mmd=0.0271\n",
      "[CellOT] epoch=1050 f_loss=-1242.2969 g_loss=2330.2000 | train mmd=0.4164 | test_mmd=0.0175\n",
      "[CellOT] epoch=1100 f_loss=-627.3617 g_loss=3228.0562 | train mmd=0.2208 | test_mmd=0.0205\n",
      "[CellOT] epoch=1150 f_loss=-979.4132 g_loss=2001.4092 | train mmd=0.3930 | test_mmd=0.0232\n",
      "[CellOT] epoch=1200 f_loss=112.1419 g_loss=2535.4800 | train mmd=0.2614 | test_mmd=0.1088\n",
      "[CellOT] epoch=1250 f_loss=224.1492 g_loss=1576.5581 | train mmd=0.2987 | test_mmd=0.0246\n",
      "[CellOT] epoch=1300 f_loss=445.8596 g_loss=1060.6339 | train mmd=0.1994 | test_mmd=0.0195\n",
      "[CellOT] epoch=1350 f_loss=271.4614 g_loss=698.5884 | train mmd=0.2804 | test_mmd=0.1716\n",
      "[CellOT] epoch=1400 f_loss=596.7623 g_loss=1821.0009 | train mmd=0.2562 | test_mmd=0.0499\n",
      "[CellOT] epoch=1450 f_loss=-6.8224 g_loss=708.2256 | train mmd=0.1754 | test_mmd=0.0875\n",
      "[CellOT] epoch=1500 f_loss=198.6843 g_loss=758.6805 | train mmd=0.1894 | test_mmd=0.0390\n",
      "[CellOT] epoch=1550 f_loss=317.3555 g_loss=945.3239 | train mmd=0.2770 | test_mmd=0.0526\n",
      "[CellOT] epoch=1600 f_loss=78.0541 g_loss=2667.5591 | train mmd=0.2605 | test_mmd=0.1852\n",
      "[CellOT] epoch=1650 f_loss=146.9528 g_loss=838.8988 | train mmd=0.2753 | test_mmd=0.2090\n",
      "[CellOT] epoch=1700 f_loss=95.2325 g_loss=970.2410 | train mmd=0.2840 | test_mmd=0.0306\n",
      "[CellOT] epoch=1750 f_loss=41.4315 g_loss=1067.1284 | train mmd=0.3323 | test_mmd=0.1601\n",
      "[CellOT] epoch=1800 f_loss=27.6532 g_loss=1257.9307 | train mmd=0.3503 | test_mmd=0.2120\n",
      "[CellOT] epoch=1850 f_loss=17.0614 g_loss=1190.9043 | train mmd=0.3236 | test_mmd=0.0384\n",
      "[CellOT] epoch=1900 f_loss=22.0367 g_loss=1239.0973 | train mmd=0.2290 | test_mmd=0.0981\n",
      "[CellOT] epoch=1950 f_loss=9.5165 g_loss=1269.2487 | train mmd=0.2190 | test_mmd=0.1099\n",
      "[CellOT] epoch=2000 f_loss=15.8683 g_loss=1304.9907 | train mmd=0.1928 | test_mmd=0.0986\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.1107\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.09859717341351959, 'mmd2_gamma_0.5': 0.2391441241901041, 'mmd2_gamma_1.0': 0.24090902701418165, 'wasserstein_distance': 1.5215607495684818, 'R2_feature_means': 0.7952932503677504}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-3391368.5000 g_loss=3738142.5000 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=-490.7082 g_loss=324.0965 | train mmd=0.6209 | test_mmd=0.3108\n",
      "[CellOT] epoch=100 f_loss=-323.3399 g_loss=437.7556 | train mmd=1.0932 | test_mmd=0.3627\n",
      "[CellOT] epoch=150 f_loss=-604.2551 g_loss=653.9159 | train mmd=0.9546 | test_mmd=0.3103\n",
      "[CellOT] epoch=200 f_loss=-858.0798 g_loss=886.1056 | train mmd=0.9311 | test_mmd=0.2771\n",
      "[CellOT] epoch=250 f_loss=-1088.0378 g_loss=1067.0459 | train mmd=0.7657 | test_mmd=0.2071\n",
      "[CellOT] epoch=300 f_loss=-1099.7554 g_loss=1311.7988 | train mmd=0.6781 | test_mmd=0.1806\n",
      "[CellOT] epoch=350 f_loss=-1312.4611 g_loss=1528.1940 | train mmd=0.7565 | test_mmd=0.1754\n",
      "[CellOT] epoch=400 f_loss=-1463.3958 g_loss=1721.9969 | train mmd=0.7917 | test_mmd=0.1688\n",
      "[CellOT] epoch=450 f_loss=-1678.0862 g_loss=1907.8236 | train mmd=0.8356 | test_mmd=0.1581\n",
      "[CellOT] epoch=500 f_loss=-3750.4385 g_loss=1735.7281 | train mmd=0.5195 | test_mmd=0.1227\n",
      "[CellOT] epoch=550 f_loss=-2033.2196 g_loss=2320.7769 | train mmd=0.7690 | test_mmd=0.1288\n",
      "[CellOT] epoch=600 f_loss=-2087.6479 g_loss=2149.9478 | train mmd=0.5372 | test_mmd=0.1073\n",
      "[CellOT] epoch=650 f_loss=-1979.8672 g_loss=2521.0542 | train mmd=0.7159 | test_mmd=0.0921\n",
      "[CellOT] epoch=700 f_loss=-1820.6653 g_loss=2416.8574 | train mmd=0.5434 | test_mmd=0.0563\n",
      "[CellOT] epoch=750 f_loss=-2385.3120 g_loss=2780.7407 | train mmd=0.6925 | test_mmd=0.0807\n",
      "[CellOT] epoch=800 f_loss=-1909.7119 g_loss=2459.1592 | train mmd=0.5820 | test_mmd=0.0521\n",
      "[CellOT] epoch=850 f_loss=-2147.5234 g_loss=3102.3137 | train mmd=0.6792 | test_mmd=0.0636\n",
      "[CellOT] epoch=900 f_loss=-2106.7524 g_loss=2973.5884 | train mmd=0.5482 | test_mmd=0.0438\n",
      "[CellOT] epoch=950 f_loss=-1912.8152 g_loss=2995.9785 | train mmd=0.4276 | test_mmd=0.0300\n",
      "[CellOT] epoch=1000 f_loss=-1708.4269 g_loss=2911.9507 | train mmd=0.3697 | test_mmd=0.0224\n",
      "[CellOT] epoch=1050 f_loss=-1506.9376 g_loss=3040.5498 | train mmd=0.4373 | test_mmd=0.0177\n",
      "[CellOT] epoch=1100 f_loss=-1413.4246 g_loss=2320.7920 | train mmd=0.4007 | test_mmd=0.0206\n",
      "[CellOT] epoch=1150 f_loss=-1277.1777 g_loss=2468.5347 | train mmd=0.3392 | test_mmd=0.0169\n",
      "[CellOT] epoch=1200 f_loss=-773.9347 g_loss=2082.8940 | train mmd=0.2686 | test_mmd=0.0406\n",
      "[CellOT] epoch=1250 f_loss=-629.4187 g_loss=1998.1689 | train mmd=0.3457 | test_mmd=0.0157\n",
      "[CellOT] epoch=1300 f_loss=-107.1542 g_loss=1668.7642 | train mmd=0.2514 | test_mmd=0.0225\n",
      "[CellOT] epoch=1350 f_loss=134.7617 g_loss=2233.4297 | train mmd=0.2005 | test_mmd=0.0363\n",
      "[CellOT] epoch=1400 f_loss=-1052.5402 g_loss=433.0032 | train mmd=0.3621 | test_mmd=0.0793\n",
      "[CellOT] epoch=1450 f_loss=-399.5748 g_loss=546.2368 | train mmd=0.3702 | test_mmd=0.1117\n",
      "[CellOT] epoch=1500 f_loss=794.8655 g_loss=1029.2166 | train mmd=0.1669 | test_mmd=0.0508\n",
      "[CellOT] epoch=1550 f_loss=377.0802 g_loss=498.2284 | train mmd=0.2379 | test_mmd=0.0755\n",
      "[CellOT] epoch=1600 f_loss=344.3391 g_loss=874.3961 | train mmd=0.3328 | test_mmd=0.1224\n",
      "[CellOT] epoch=1650 f_loss=191.5512 g_loss=931.6778 | train mmd=0.2407 | test_mmd=0.0704\n",
      "[CellOT] epoch=1700 f_loss=-258.3755 g_loss=483.9762 | train mmd=0.2837 | test_mmd=0.0604\n",
      "[CellOT] epoch=1750 f_loss=92.0183 g_loss=617.4050 | train mmd=0.2520 | test_mmd=0.1240\n",
      "[CellOT] epoch=1800 f_loss=46.8546 g_loss=600.0344 | train mmd=0.3323 | test_mmd=0.0596\n",
      "[CellOT] epoch=1850 f_loss=24.6008 g_loss=678.7531 | train mmd=0.2853 | test_mmd=0.1709\n",
      "[CellOT] epoch=1900 f_loss=17.9198 g_loss=658.1897 | train mmd=0.3239 | test_mmd=0.0288\n",
      "[CellOT] epoch=1950 f_loss=25.9574 g_loss=702.2526 | train mmd=0.2291 | test_mmd=0.0871\n",
      "[CellOT] epoch=2000 f_loss=6.4336 g_loss=714.0991 | train mmd=0.5325 | test_mmd=0.1239\n",
      "[CellOT] Final CellOT MMD: 0.2357\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.12388895123753296, 'mmd2_gamma_0.5': 0.5153063580415634, 'mmd2_gamma_1.0': 0.5941475464448629, 'wasserstein_distance': 1.8348624600550538, 'R2_feature_means': 0.8608230976588512}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-3341222.2500 g_loss=3874176.2500 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=519.5032 g_loss=170.8512 | train mmd=0.9940 | test_mmd=0.3596\n",
      "[CellOT] epoch=100 f_loss=-263.5163 g_loss=367.1123 | train mmd=1.0523 | test_mmd=0.3669\n",
      "[CellOT] epoch=150 f_loss=-518.5708 g_loss=542.7747 | train mmd=0.8444 | test_mmd=0.2734\n",
      "[CellOT] epoch=200 f_loss=-638.7221 g_loss=791.7413 | train mmd=0.6581 | test_mmd=0.2145\n",
      "[CellOT] epoch=250 f_loss=-928.8272 g_loss=1008.1288 | train mmd=0.9052 | test_mmd=0.2490\n",
      "[CellOT] epoch=300 f_loss=-1097.9734 g_loss=1207.9375 | train mmd=0.7937 | test_mmd=0.2029\n",
      "[CellOT] epoch=350 f_loss=-1244.4335 g_loss=1474.1931 | train mmd=0.8112 | test_mmd=0.1811\n",
      "[CellOT] epoch=400 f_loss=-1447.2070 g_loss=1686.3018 | train mmd=0.7720 | test_mmd=0.1661\n",
      "[CellOT] epoch=450 f_loss=-1712.3157 g_loss=1856.2507 | train mmd=0.8704 | test_mmd=0.1744\n",
      "[CellOT] epoch=500 f_loss=-2067.5845 g_loss=2272.2417 | train mmd=0.8764 | test_mmd=0.1619\n",
      "[CellOT] epoch=550 f_loss=-2499.9919 g_loss=2627.6235 | train mmd=0.8244 | test_mmd=0.1491\n",
      "[CellOT] epoch=600 f_loss=-2502.2690 g_loss=2908.1987 | train mmd=0.8191 | test_mmd=0.1372\n",
      "[CellOT] epoch=650 f_loss=-1973.6501 g_loss=3111.5913 | train mmd=0.4804 | test_mmd=0.0912\n",
      "[CellOT] epoch=700 f_loss=-2657.3528 g_loss=2945.2839 | train mmd=0.6627 | test_mmd=0.1126\n",
      "[CellOT] epoch=750 f_loss=-2833.9331 g_loss=3271.0391 | train mmd=0.5781 | test_mmd=0.0805\n",
      "[CellOT] epoch=800 f_loss=-2581.8647 g_loss=3298.4624 | train mmd=0.4635 | test_mmd=0.0771\n",
      "[CellOT] epoch=850 f_loss=-2392.8081 g_loss=1969.6580 | train mmd=0.3976 | test_mmd=0.1184\n",
      "[CellOT] epoch=900 f_loss=-2611.3818 g_loss=3646.1528 | train mmd=0.4559 | test_mmd=0.1039\n",
      "[CellOT] epoch=950 f_loss=-2461.7676 g_loss=3672.0217 | train mmd=0.3224 | test_mmd=0.1347\n",
      "[CellOT] epoch=1000 f_loss=-2631.3813 g_loss=3774.7925 | train mmd=0.4119 | test_mmd=0.0462\n",
      "[CellOT] epoch=1050 f_loss=-1843.2943 g_loss=2898.1592 | train mmd=0.2888 | test_mmd=0.1376\n",
      "[CellOT] epoch=1100 f_loss=741.9277 g_loss=281.5590 | train mmd=0.1541 | test_mmd=0.6256\n",
      "[CellOT] epoch=1150 f_loss=-698.1392 g_loss=1932.5630 | train mmd=0.1687 | test_mmd=0.2644\n",
      "[CellOT] epoch=1200 f_loss=272.2357 g_loss=-3.7220 | train mmd=0.1786 | test_mmd=0.3832\n",
      "[CellOT] epoch=1250 f_loss=14.7055 g_loss=-2.6015 | train mmd=0.1703 | test_mmd=0.2086\n",
      "[CellOT] epoch=1300 f_loss=161.2019 g_loss=101.2629 | train mmd=0.1652 | test_mmd=0.1122\n",
      "[CellOT] epoch=1350 f_loss=116.3653 g_loss=72.9639 | train mmd=0.2014 | test_mmd=0.0747\n",
      "[CellOT] epoch=1400 f_loss=67.6394 g_loss=4.8485 | train mmd=0.1282 | test_mmd=0.0633\n",
      "[CellOT] epoch=1450 f_loss=101.7666 g_loss=93.1980 | train mmd=0.1027 | test_mmd=0.0454\n",
      "[CellOT] epoch=1500 f_loss=11.6406 g_loss=1.2536 | train mmd=0.0818 | test_mmd=0.0267\n",
      "[CellOT] epoch=1550 f_loss=-3.7545 g_loss=1.6937 | train mmd=0.1534 | test_mmd=0.0369\n",
      "[CellOT] epoch=1600 f_loss=2.2094 g_loss=3.8086 | train mmd=0.0776 | test_mmd=0.0178\n",
      "[CellOT] epoch=1650 f_loss=11.8941 g_loss=5.9354 | train mmd=0.0500 | test_mmd=0.0307\n",
      "[CellOT] epoch=1700 f_loss=6.0175 g_loss=6.4024 | train mmd=0.0506 | test_mmd=0.0149\n",
      "[CellOT] epoch=1750 f_loss=2.5239 g_loss=6.6197 | train mmd=0.0751 | test_mmd=0.0230\n",
      "[CellOT] epoch=1800 f_loss=2.3858 g_loss=6.1436 | train mmd=0.0429 | test_mmd=0.0226\n",
      "[CellOT] epoch=1850 f_loss=0.7304 g_loss=7.4170 | train mmd=0.0487 | test_mmd=0.0213\n",
      "[CellOT] epoch=1900 f_loss=0.9153 g_loss=7.8011 | train mmd=0.0418 | test_mmd=0.0173\n",
      "[CellOT] epoch=1950 f_loss=-0.0334 g_loss=8.0291 | train mmd=0.0317 | test_mmd=0.0134\n",
      "[CellOT] epoch=2000 f_loss=35.2131 g_loss=8.6020 | train mmd=0.0461 | test_mmd=0.0070\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.0183\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.007018340996846062, 'mmd2_gamma_0.5': 0.03904242154803361, 'mmd2_gamma_1.0': 0.05400336656928395, 'wasserstein_distance': 1.7548533315768677, 'R2_feature_means': 0.9884541557486963}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-2541007.7500 g_loss=2812581.7500 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=452.8047 g_loss=183.7379 | train mmd=1.0370 | test_mmd=0.3842\n",
      "[CellOT] epoch=100 f_loss=-274.2079 g_loss=325.2714 | train mmd=1.0714 | test_mmd=0.3502\n",
      "[CellOT] epoch=150 f_loss=-456.7864 g_loss=484.0266 | train mmd=0.9995 | test_mmd=0.3306\n",
      "[CellOT] epoch=200 f_loss=-598.1987 g_loss=633.0013 | train mmd=0.8706 | test_mmd=0.2749\n",
      "[CellOT] epoch=250 f_loss=-746.8466 g_loss=769.8098 | train mmd=0.8825 | test_mmd=0.2533\n",
      "[CellOT] epoch=300 f_loss=-871.1118 g_loss=959.4998 | train mmd=0.8623 | test_mmd=0.2248\n",
      "[CellOT] epoch=350 f_loss=-1004.7868 g_loss=1090.3364 | train mmd=0.7678 | test_mmd=0.1776\n",
      "[CellOT] epoch=400 f_loss=-1173.8887 g_loss=1260.7224 | train mmd=0.8312 | test_mmd=0.1841\n",
      "[CellOT] epoch=450 f_loss=-1224.3965 g_loss=1308.2775 | train mmd=0.7876 | test_mmd=0.1468\n",
      "[CellOT] epoch=500 f_loss=-1272.4919 g_loss=1476.1385 | train mmd=0.6829 | test_mmd=0.1212\n",
      "[CellOT] epoch=550 f_loss=-1255.8215 g_loss=1591.8225 | train mmd=0.5844 | test_mmd=0.1046\n",
      "[CellOT] epoch=600 f_loss=-1259.5282 g_loss=1584.5593 | train mmd=0.5980 | test_mmd=0.0901\n",
      "[CellOT] epoch=650 f_loss=-1254.5518 g_loss=1837.9858 | train mmd=0.5349 | test_mmd=0.0730\n",
      "[CellOT] epoch=700 f_loss=-1529.1494 g_loss=2010.9338 | train mmd=0.6335 | test_mmd=0.0766\n",
      "[CellOT] epoch=750 f_loss=-1448.9434 g_loss=1755.4768 | train mmd=0.5187 | test_mmd=0.0439\n",
      "[CellOT] epoch=800 f_loss=-824.7665 g_loss=1449.5654 | train mmd=0.3443 | test_mmd=0.0509\n",
      "[CellOT] epoch=850 f_loss=-1570.6699 g_loss=2250.4490 | train mmd=0.4485 | test_mmd=0.0475\n",
      "[CellOT] epoch=900 f_loss=-996.7622 g_loss=1904.5093 | train mmd=0.3371 | test_mmd=0.0275\n",
      "[CellOT] epoch=950 f_loss=-1173.3481 g_loss=2176.7397 | train mmd=0.4553 | test_mmd=0.0259\n",
      "[CellOT] epoch=1000 f_loss=-1086.6399 g_loss=1645.9814 | train mmd=0.3695 | test_mmd=0.0206\n",
      "[CellOT] epoch=1050 f_loss=-862.6685 g_loss=1442.0923 | train mmd=0.3105 | test_mmd=0.0688\n",
      "[CellOT] epoch=1100 f_loss=-834.2933 g_loss=1574.0471 | train mmd=0.3154 | test_mmd=0.0377\n",
      "[CellOT] epoch=1150 f_loss=-665.9496 g_loss=1521.7344 | train mmd=0.3146 | test_mmd=0.0236\n",
      "[CellOT] epoch=1200 f_loss=-225.4898 g_loss=1127.6877 | train mmd=0.2296 | test_mmd=0.0201\n",
      "[CellOT] epoch=1250 f_loss=-841.1512 g_loss=259.6731 | train mmd=0.3104 | test_mmd=0.0787\n",
      "[CellOT] epoch=1300 f_loss=42.8380 g_loss=604.4359 | train mmd=0.2540 | test_mmd=0.0214\n",
      "[CellOT] epoch=1350 f_loss=217.1888 g_loss=640.6984 | train mmd=0.2836 | test_mmd=0.0482\n",
      "[CellOT] epoch=1400 f_loss=207.8695 g_loss=423.5356 | train mmd=0.3100 | test_mmd=0.0466\n",
      "[CellOT] epoch=1450 f_loss=208.3322 g_loss=260.2668 | train mmd=0.1763 | test_mmd=0.0412\n",
      "[CellOT] epoch=1500 f_loss=74.3466 g_loss=244.7107 | train mmd=0.1904 | test_mmd=0.0615\n",
      "[CellOT] epoch=1550 f_loss=33.7107 g_loss=230.9646 | train mmd=0.1688 | test_mmd=0.0501\n",
      "[CellOT] epoch=1600 f_loss=47.5496 g_loss=284.6491 | train mmd=0.1766 | test_mmd=0.0532\n",
      "[CellOT] epoch=1650 f_loss=-7.7172 g_loss=264.6260 | train mmd=0.1413 | test_mmd=0.0455\n",
      "[CellOT] epoch=1700 f_loss=10.5375 g_loss=248.5862 | train mmd=0.1281 | test_mmd=0.0439\n",
      "[CellOT] epoch=1750 f_loss=16.1316 g_loss=277.4620 | train mmd=0.2134 | test_mmd=0.0372\n",
      "[CellOT] epoch=1800 f_loss=-34.0106 g_loss=293.1722 | train mmd=0.1469 | test_mmd=0.0811\n",
      "[CellOT] epoch=1850 f_loss=19.0501 g_loss=297.4430 | train mmd=0.1463 | test_mmd=0.0600\n",
      "[CellOT] epoch=1900 f_loss=34.5193 g_loss=296.4767 | train mmd=0.1605 | test_mmd=0.1399\n",
      "[CellOT] epoch=1950 f_loss=11.7088 g_loss=324.7166 | train mmd=0.1472 | test_mmd=0.0132\n",
      "[CellOT] epoch=2000 f_loss=18.0752 g_loss=340.7704 | train mmd=0.1793 | test_mmd=0.0546\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.0690\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.05463636951448314, 'mmd2_gamma_0.5': 0.1461715985949631, 'mmd2_gamma_1.0': 0.16192559452766742, 'wasserstein_distance': 1.906131293228314, 'R2_feature_means': 0.9009959019875399}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-4240904.0000 g_loss=4333344.0000 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=324.2232 g_loss=332.2641 | train mmd=1.0245 | test_mmd=0.3835\n",
      "[CellOT] epoch=100 f_loss=-414.6087 g_loss=461.4091 | train mmd=1.0993 | test_mmd=0.3662\n",
      "[CellOT] epoch=150 f_loss=-675.6973 g_loss=707.0941 | train mmd=0.9865 | test_mmd=0.3126\n",
      "[CellOT] epoch=200 f_loss=-823.1539 g_loss=927.7777 | train mmd=0.8516 | test_mmd=0.2397\n",
      "[CellOT] epoch=250 f_loss=-1128.0078 g_loss=1154.0037 | train mmd=0.9095 | test_mmd=0.2506\n",
      "[CellOT] epoch=300 f_loss=-1257.7839 g_loss=1250.3500 | train mmd=0.8569 | test_mmd=0.2150\n",
      "[CellOT] epoch=350 f_loss=-1613.2930 g_loss=1541.5566 | train mmd=0.9133 | test_mmd=0.2158\n",
      "[CellOT] epoch=400 f_loss=-1552.4821 g_loss=1715.5630 | train mmd=0.7543 | test_mmd=0.1393\n",
      "[CellOT] epoch=450 f_loss=-1580.0344 g_loss=2016.4146 | train mmd=0.6031 | test_mmd=0.1421\n",
      "[CellOT] epoch=500 f_loss=-1922.5408 g_loss=2054.5869 | train mmd=0.8028 | test_mmd=0.1476\n",
      "[CellOT] epoch=550 f_loss=-2131.0295 g_loss=2321.4595 | train mmd=0.8175 | test_mmd=0.1315\n",
      "[CellOT] epoch=600 f_loss=-2072.0691 g_loss=2429.4841 | train mmd=0.6062 | test_mmd=0.1060\n",
      "[CellOT] epoch=650 f_loss=-2170.6194 g_loss=2544.0239 | train mmd=0.6564 | test_mmd=0.0801\n",
      "[CellOT] epoch=700 f_loss=-3120.9819 g_loss=2683.4160 | train mmd=0.3716 | test_mmd=0.0828\n",
      "[CellOT] epoch=750 f_loss=-1971.4230 g_loss=2814.9307 | train mmd=0.5439 | test_mmd=0.0538\n",
      "[CellOT] epoch=800 f_loss=-2210.4199 g_loss=2977.6890 | train mmd=0.6046 | test_mmd=0.0445\n",
      "[CellOT] epoch=850 f_loss=-1656.2957 g_loss=2616.4695 | train mmd=0.4699 | test_mmd=0.0350\n",
      "[CellOT] epoch=900 f_loss=-5109.7671 g_loss=2386.9004 | train mmd=0.2097 | test_mmd=0.0591\n",
      "[CellOT] epoch=950 f_loss=-1924.8501 g_loss=3181.9268 | train mmd=0.4881 | test_mmd=0.0313\n",
      "[CellOT] epoch=1000 f_loss=-1832.8718 g_loss=2766.9956 | train mmd=0.4215 | test_mmd=0.0489\n",
      "[CellOT] epoch=1050 f_loss=-1967.0940 g_loss=3261.7651 | train mmd=0.5347 | test_mmd=0.0276\n",
      "[CellOT] epoch=1100 f_loss=-1750.6250 g_loss=3031.3267 | train mmd=0.4721 | test_mmd=0.0207\n",
      "[CellOT] epoch=1150 f_loss=-624.3655 g_loss=2073.2881 | train mmd=0.2034 | test_mmd=0.0285\n",
      "[CellOT] epoch=1200 f_loss=-2003.7897 g_loss=1365.9067 | train mmd=0.1203 | test_mmd=0.0304\n",
      "[CellOT] epoch=1250 f_loss=-394.5386 g_loss=1644.3328 | train mmd=0.2733 | test_mmd=0.0301\n",
      "[CellOT] epoch=1300 f_loss=-370.6615 g_loss=1296.5317 | train mmd=0.2070 | test_mmd=0.0211\n",
      "[CellOT] epoch=1350 f_loss=273.6949 g_loss=1084.4072 | train mmd=0.2530 | test_mmd=0.0306\n",
      "[CellOT] epoch=1400 f_loss=-1222.8901 g_loss=1566.5276 | train mmd=0.1870 | test_mmd=0.0577\n",
      "[CellOT] epoch=1450 f_loss=666.7611 g_loss=1033.6951 | train mmd=0.2330 | test_mmd=0.0275\n",
      "[CellOT] epoch=1500 f_loss=847.2711 g_loss=1431.5784 | train mmd=0.2874 | test_mmd=0.0385\n",
      "[CellOT] epoch=1550 f_loss=358.4408 g_loss=2838.0020 | train mmd=0.3508 | test_mmd=0.1335\n",
      "[CellOT] epoch=1600 f_loss=620.2005 g_loss=959.4349 | train mmd=0.3106 | test_mmd=0.0653\n",
      "[CellOT] epoch=1650 f_loss=389.2242 g_loss=867.3311 | train mmd=0.3157 | test_mmd=0.0600\n",
      "[CellOT] epoch=1700 f_loss=129.6566 g_loss=794.4403 | train mmd=0.1792 | test_mmd=0.0984\n",
      "[CellOT] epoch=1750 f_loss=117.7745 g_loss=807.6099 | train mmd=0.2538 | test_mmd=0.0524\n",
      "[CellOT] epoch=1800 f_loss=51.3191 g_loss=937.3280 | train mmd=0.3886 | test_mmd=0.1567\n",
      "[CellOT] epoch=1850 f_loss=26.3087 g_loss=1083.2073 | train mmd=0.3593 | test_mmd=0.0549\n",
      "[CellOT] epoch=1900 f_loss=-20.5784 g_loss=1234.3790 | train mmd=0.3728 | test_mmd=0.0719\n",
      "[CellOT] epoch=1950 f_loss=72.9231 g_loss=1057.6826 | train mmd=0.2279 | test_mmd=0.1438\n",
      "[CellOT] epoch=2000 f_loss=18.6629 g_loss=1156.9851 | train mmd=0.2268 | test_mmd=0.0520\n",
      "[CellOT] Final CellOT MMD: 0.1110\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.05197933473297911, 'mmd2_gamma_0.5': 0.1787595588616233, 'mmd2_gamma_1.0': 0.2187928890740367, 'wasserstein_distance': 1.404296197643564, 'R2_feature_means': 0.940549323421686}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-3358094.5000 g_loss=3539286.0000 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=351.8576 g_loss=224.1146 | train mmd=1.0561 | test_mmd=0.3809\n",
      "[CellOT] epoch=100 f_loss=-353.0914 g_loss=428.2126 | train mmd=1.0468 | test_mmd=0.3423\n",
      "[CellOT] epoch=150 f_loss=-604.8691 g_loss=626.7177 | train mmd=0.9649 | test_mmd=0.3173\n",
      "[CellOT] epoch=200 f_loss=-802.0527 g_loss=860.4946 | train mmd=0.8493 | test_mmd=0.2414\n",
      "[CellOT] epoch=250 f_loss=-1065.3607 g_loss=1041.3125 | train mmd=0.8853 | test_mmd=0.2263\n",
      "[CellOT] epoch=300 f_loss=-1133.1050 g_loss=1193.9086 | train mmd=0.8194 | test_mmd=0.1843\n",
      "[CellOT] epoch=350 f_loss=-1364.1075 g_loss=1482.7513 | train mmd=0.8855 | test_mmd=0.1969\n",
      "[CellOT] epoch=400 f_loss=-1478.5952 g_loss=1604.6884 | train mmd=0.7849 | test_mmd=0.1460\n",
      "[CellOT] epoch=450 f_loss=-1535.8420 g_loss=1874.3920 | train mmd=0.7797 | test_mmd=0.1449\n",
      "[CellOT] epoch=500 f_loss=-1703.7169 g_loss=2005.3879 | train mmd=0.7508 | test_mmd=0.1106\n",
      "[CellOT] epoch=550 f_loss=-1755.5161 g_loss=2002.5415 | train mmd=0.6926 | test_mmd=0.0969\n",
      "[CellOT] epoch=600 f_loss=-1405.3257 g_loss=2120.5369 | train mmd=0.4915 | test_mmd=0.1008\n",
      "[CellOT] epoch=650 f_loss=-1771.0986 g_loss=2194.7520 | train mmd=0.5939 | test_mmd=0.0674\n",
      "[CellOT] epoch=700 f_loss=-1507.1560 g_loss=2282.0225 | train mmd=0.3818 | test_mmd=0.0485\n",
      "[CellOT] epoch=750 f_loss=-1917.7053 g_loss=2393.6541 | train mmd=0.5830 | test_mmd=0.0511\n",
      "[CellOT] epoch=800 f_loss=-1003.8425 g_loss=1767.7845 | train mmd=0.2481 | test_mmd=0.0465\n",
      "[CellOT] epoch=850 f_loss=-1690.1614 g_loss=2242.5918 | train mmd=0.4558 | test_mmd=0.0266\n",
      "[CellOT] epoch=900 f_loss=-1490.1455 g_loss=1887.4119 | train mmd=0.2809 | test_mmd=0.1153\n",
      "[CellOT] epoch=950 f_loss=-1101.5927 g_loss=2148.4800 | train mmd=0.3019 | test_mmd=0.0266\n",
      "[CellOT] epoch=1000 f_loss=-1152.1311 g_loss=2077.7622 | train mmd=0.3217 | test_mmd=0.0175\n",
      "[CellOT] epoch=1050 f_loss=-1213.1194 g_loss=2105.8386 | train mmd=0.3644 | test_mmd=0.0180\n",
      "[CellOT] epoch=1100 f_loss=-146.2591 g_loss=1088.8049 | train mmd=0.1950 | test_mmd=0.0527\n",
      "[CellOT] epoch=1150 f_loss=119.6245 g_loss=1129.0549 | train mmd=0.2588 | test_mmd=0.1206\n",
      "[CellOT] epoch=1200 f_loss=232.1040 g_loss=1204.6405 | train mmd=0.2008 | test_mmd=0.0269\n",
      "[CellOT] epoch=1250 f_loss=-63.2868 g_loss=715.0161 | train mmd=0.2085 | test_mmd=0.0643\n",
      "[CellOT] epoch=1300 f_loss=520.1437 g_loss=499.7030 | train mmd=0.2237 | test_mmd=0.0209\n",
      "[CellOT] epoch=1350 f_loss=-1763.7592 g_loss=465.0860 | train mmd=0.3103 | test_mmd=0.0684\n",
      "[CellOT] epoch=1400 f_loss=154.1868 g_loss=784.6285 | train mmd=0.2119 | test_mmd=0.1333\n",
      "[CellOT] epoch=1450 f_loss=307.1487 g_loss=351.9178 | train mmd=0.2127 | test_mmd=0.0290\n",
      "[CellOT] epoch=1500 f_loss=150.2777 g_loss=370.1797 | train mmd=0.2122 | test_mmd=0.0902\n",
      "[CellOT] epoch=1550 f_loss=74.0942 g_loss=348.1954 | train mmd=0.1654 | test_mmd=0.1113\n",
      "[CellOT] epoch=1600 f_loss=61.4154 g_loss=347.1010 | train mmd=0.1911 | test_mmd=0.0504\n",
      "[CellOT] epoch=1650 f_loss=4.7904 g_loss=450.2933 | train mmd=0.5066 | test_mmd=0.1409\n",
      "[CellOT] epoch=1700 f_loss=20.9361 g_loss=373.3647 | train mmd=0.2134 | test_mmd=0.0571\n",
      "[CellOT] epoch=1750 f_loss=43.2456 g_loss=393.3458 | train mmd=0.2198 | test_mmd=0.0384\n",
      "[CellOT] epoch=1800 f_loss=13.2952 g_loss=409.1152 | train mmd=0.1799 | test_mmd=0.0528\n",
      "[CellOT] epoch=1850 f_loss=-14.3485 g_loss=423.2153 | train mmd=0.4745 | test_mmd=0.2714\n",
      "[CellOT] epoch=1900 f_loss=-0.0788 g_loss=442.8673 | train mmd=0.3664 | test_mmd=0.1038\n",
      "[CellOT] epoch=1950 f_loss=7.2434 g_loss=453.6690 | train mmd=0.3720 | test_mmd=0.0286\n",
      "[CellOT] epoch=2000 f_loss=4.9374 g_loss=458.3349 | train mmd=0.2394 | test_mmd=0.1530\n",
      "[CellOT] Final CellOT MMD: 0.1249\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.1530287158678496, 'mmd2_gamma_0.5': 0.2207021310253101, 'mmd2_gamma_1.0': 0.20951950880075823, 'wasserstein_distance': 2.4874783719267444, 'R2_feature_means': 0.8419592066936583}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=-1865408.3750 g_loss=2224163.0000 | train mmd=0.1683 | test_mmd=0.7865\n",
      "[CellOT] epoch=50 f_loss=-0.8162 g_loss=226.3992 | train mmd=0.7906 | test_mmd=0.2894\n",
      "[CellOT] epoch=100 f_loss=-390.4511 g_loss=445.0105 | train mmd=1.0630 | test_mmd=0.3414\n",
      "[CellOT] epoch=150 f_loss=-604.4287 g_loss=629.8723 | train mmd=0.9297 | test_mmd=0.2859\n",
      "[CellOT] epoch=200 f_loss=-771.5345 g_loss=881.4531 | train mmd=0.8357 | test_mmd=0.2348\n",
      "[CellOT] epoch=250 f_loss=-999.7784 g_loss=1020.9460 | train mmd=0.8325 | test_mmd=0.2315\n",
      "[CellOT] epoch=300 f_loss=-1124.3279 g_loss=1166.4102 | train mmd=0.8084 | test_mmd=0.1902\n",
      "[CellOT] epoch=350 f_loss=-1596.0208 g_loss=1342.5098 | train mmd=0.7102 | test_mmd=0.1922\n",
      "[CellOT] epoch=400 f_loss=-1466.4757 g_loss=1455.9624 | train mmd=0.8079 | test_mmd=0.1653\n",
      "[CellOT] epoch=450 f_loss=-1675.3624 g_loss=1749.9241 | train mmd=0.7859 | test_mmd=0.1349\n",
      "[CellOT] epoch=500 f_loss=-1605.8865 g_loss=1654.9534 | train mmd=0.7001 | test_mmd=0.1262\n",
      "[CellOT] epoch=550 f_loss=-1584.2697 g_loss=1992.4861 | train mmd=0.6648 | test_mmd=0.0984\n",
      "[CellOT] epoch=600 f_loss=-1711.2694 g_loss=2335.1279 | train mmd=0.6033 | test_mmd=0.0830\n",
      "[CellOT] epoch=650 f_loss=-2670.7288 g_loss=1922.8845 | train mmd=0.3947 | test_mmd=0.1255\n",
      "[CellOT] epoch=700 f_loss=-1421.0295 g_loss=2391.1194 | train mmd=0.4845 | test_mmd=0.1060\n",
      "[CellOT] epoch=750 f_loss=-1985.3466 g_loss=2548.5955 | train mmd=0.6148 | test_mmd=0.0650\n",
      "[CellOT] epoch=800 f_loss=-1835.4680 g_loss=2696.7451 | train mmd=0.5130 | test_mmd=0.0432\n",
      "[CellOT] epoch=850 f_loss=-1570.7686 g_loss=2345.8701 | train mmd=0.4066 | test_mmd=0.0430\n",
      "[CellOT] epoch=900 f_loss=-1462.1135 g_loss=2724.9053 | train mmd=0.3699 | test_mmd=0.0203\n",
      "[CellOT] epoch=950 f_loss=-1846.4771 g_loss=2942.3091 | train mmd=0.5115 | test_mmd=0.0349\n",
      "[CellOT] epoch=1000 f_loss=-1234.0709 g_loss=2470.7144 | train mmd=0.3359 | test_mmd=0.0198\n",
      "[CellOT] epoch=1050 f_loss=-1115.8381 g_loss=2502.0425 | train mmd=0.3324 | test_mmd=0.0325\n",
      "[CellOT] epoch=1100 f_loss=-1266.7256 g_loss=2377.7537 | train mmd=0.3445 | test_mmd=0.0149\n",
      "[CellOT] epoch=1150 f_loss=-798.3955 g_loss=2078.7339 | train mmd=0.3621 | test_mmd=0.0153\n",
      "[CellOT] epoch=1200 f_loss=-212.0375 g_loss=1460.6104 | train mmd=0.2540 | test_mmd=0.0211\n",
      "[CellOT] epoch=1250 f_loss=-64.6549 g_loss=1039.2343 | train mmd=0.1849 | test_mmd=0.0177\n",
      "[CellOT] epoch=1300 f_loss=598.8218 g_loss=667.3190 | train mmd=0.1576 | test_mmd=0.0502\n",
      "[CellOT] epoch=1350 f_loss=677.2010 g_loss=401.3219 | train mmd=0.2039 | test_mmd=0.0337\n",
      "[CellOT] epoch=1400 f_loss=-439.6945 g_loss=311.1557 | train mmd=0.2297 | test_mmd=0.0449\n",
      "[CellOT] epoch=1450 f_loss=319.7677 g_loss=729.6395 | train mmd=0.1754 | test_mmd=0.0724\n",
      "[CellOT] epoch=1500 f_loss=423.6405 g_loss=409.6954 | train mmd=0.1518 | test_mmd=0.0677\n",
      "[CellOT] epoch=1550 f_loss=215.6856 g_loss=386.9235 | train mmd=0.2735 | test_mmd=0.0359\n",
      "[CellOT] epoch=1600 f_loss=102.4045 g_loss=411.6476 | train mmd=0.1815 | test_mmd=0.0720\n",
      "[CellOT] epoch=1650 f_loss=98.4926 g_loss=356.1883 | train mmd=0.2907 | test_mmd=0.1564\n",
      "[CellOT] epoch=1700 f_loss=46.0339 g_loss=443.5584 | train mmd=0.2525 | test_mmd=0.0315\n",
      "[CellOT] epoch=1750 f_loss=80.7490 g_loss=469.0465 | train mmd=0.2242 | test_mmd=0.0341\n",
      "[CellOT] epoch=1800 f_loss=35.9678 g_loss=523.6364 | train mmd=0.3042 | test_mmd=0.0273\n",
      "[CellOT] epoch=1850 f_loss=18.9468 g_loss=603.5338 | train mmd=0.3655 | test_mmd=0.1214\n",
      "[CellOT] epoch=1900 f_loss=1.1378 g_loss=647.5856 | train mmd=0.1900 | test_mmd=0.0688\n",
      "[CellOT] epoch=1950 f_loss=36.0773 g_loss=608.4421 | train mmd=0.4610 | test_mmd=0.2848\n",
      "[CellOT] epoch=2000 f_loss=44.2734 g_loss=636.9116 | train mmd=0.2461 | test_mmd=0.0440\n",
      "[CellOT] Final CellOT MMD: 0.1273\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 9 metrics: {'mmd2_gamma_median': 0.04398130684713708, 'mmd2_gamma_0.5': 0.14540813735829483, 'mmd2_gamma_1.0': 0.24097819849547625, 'wasserstein_distance': 2.0586036429728094, 'R2_feature_means': 0.8823998699543126}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0715  0.0480\n",
      "mmd2_gamma_0.5        0.2036  0.1411\n",
      "mmd2_gamma_1.0        0.2290  0.1532\n",
      "wasserstein_distance  1.8707  0.3618\n",
      "R2_feature_means      0.8957  0.0590\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": "iVBORw0KGgoAAAANSUhEUgAAAYUAAADcCAYAAACf1b3DAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAADet0lEQVR4nOz9eZhdV3Xmj3/2PsOda55UJcmSLMnzFGywwWBjbBMSsAkJbghNOqF/CZ2E7s7TT5JO+iH5dqbmmzTph2/ShIROQmMTCGYItgEP4FkesI0tWx5kDVZJqirVcOvWnYcz7P37Y597qq6qSgNxgNj3fSjkuuM5597aa6+13vW+Qmut6aKLLrroogtA/qgPoIsuuuiiix8fdINCF1100UUXMbpBoYsuuuiiixjdoNBFF1100UWMblDooosuuugiRjcodNFFF110EaMbFLrooosuuojRDQpddNFFF13E6AaFLrrooosuYnSDQhdddNFFFzG6QaGL1yVuuOEG0uk0lUpl3cd86EMfwnVdFhcXf4hH1kUXP1p0g0IXr0t86EMfotFo8E//9E9r3l+v17ntttv4yZ/8SQYHB3/IR9dFFz86dINCF69L3HDDDeRyOb74xS+uef9tt91GrVbjQx/60A/5yLro4keLblDo4nWJVCrF+973Pu69917m5+dX3f/FL36RXC7HDTfcQLFY5Dd+4zfYtGkTiUSC7du386d/+qcopeLHT05OIoTgk5/8JJ/+9KfZtm0b6XSa66+/nqNHj6K15o/+6I/YuHEjqVSKG2+8kUKh8MM85S66OCXYP+oD6KKLHxU+9KEP8fnPf55bb72Vj33sY/HthUKBu+++mw9+8INorbnqqquYnp7mox/9KJs3b+bRRx/ld3/3dzl27Bif+tSnOl7zH/7hH/A8j//4H/8jhUKBP/uzP+Omm27immuu4YEHHuC//tf/yoEDB/jLv/xLfvM3f5O///u//yGfdRddnAS6iy5epwiCQG/YsEFfccUVHbf/9V//tQb03Xffrf/oj/5IZzIZvW/fvo7H/M7v/I62LEsfOXJEa631oUOHNKCHh4d1sViMH/e7v/u7GtAXXXSR9n0/vv2DH/ygdl1XN5vNf8Ez7KKL00e3fNTF6xaWZfGBD3yAxx57jMnJyfj2L37xi4yOjvKOd7yDr3zlK7z1rW+lv7+ffD4f/1x77bWEYchDDz3U8Zrvf//76e3tjX9/05veBMC//bf/Ftu2O273PI/p6el/2ZPsoovTRDcodPG6RruR3G44T01N8fDDD/OBD3wAy7LYv38/d911F8PDwx0/1157LcCqfsTmzZs7fm8HiE2bNq15+9LS0qt/Ul108c9At6fQxesab3jDGzj77LP50pe+xH/7b/+NL33pS2it42ChlOK6667jt3/7t9d8/s6dOzt+tyxrzcetd7vuuuF28WOGblDo4nWPD33oQ/ze7/0ezz33HF/84hfZsWMHl112GQBnnnkm1Wo1zgy66OK1jm75qIvXPdpZwe///u+ze/fujtmEm266iccee4y777571fOKxSJBEPzQjrOLLn4Y6GYKXbzusXXrVt785jdz2223AXQEhd/6rd/i9ttv593vfje/+Iu/yBve8AZqtRp79uzhq1/9KpOTkwwNDf2oDr2LLl51dINCF11gAsGjjz7KG9/4RrZv3x7fnk6nefDBB/kf/+N/8JWvfIWbb76Znp4edu7cyR/8wR90MI266OK1AKG7na4uuuiiiy4idHsKXXTRRRddxOgGhS666KKLLmJ0g0IXXXTRRRcxukGhiy666KKLGN2g0EUXXXTRRYxuUOiiiy666CLGj92cglKKmZkZcrkcQogf9eF00UUXXbwmoLWmUqkwPj6OlOvnAz92QWFmZmaVomQXXXTRRRevDo4ePcrGjRvXvf/HLijkcjnAHHhPT8+P+Gi66KKLLl4bKJfLbNq0KV5j18OPXVBol4x6enq6QaGLLrro4lXGycry3UZzF1100UUXMX7sMoUufnA08pN4lQXc3DCpoS0/6sPpoosu/hWiGxReI5jffTvzT91K6NWx3DQjl95EbuOF3SDRRRddnBa6QeHHBMfv8k9n19/ITzL/1K1orUn0TtAqz3L03r/ASmQRUsZBYuTiG344J9NFF138q0U3KPwLor2wNwtH4x18cmDTqoX++F1+amQHjfn9Hbv+Ey3oXmWB0KuT6J3Aqy7QKs6g/QZhs4rTO4ZuVpl9/BZyGy9cN8B0S09ddNEFdIPCvwga+Unmn7mN0oFdtMpzqFYN0IBAJjKkBjfHC/3qXf4xCi/cjds3QaJ3Ar9eYP6pW0+4oLu5YSw3Tas8i1eaRYcBINBa4y1NISwHtGb+mds447r/vOr5a5Wefpyyim7A6qKL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PYNAILCXWtw7fvnLX3Zr25gxY3o9Z198LgDDhw/v1hdFUbjyyiuzHr8vPZe3336bGTNmMHDgQBRF4dlnn834XgjBzTffzIABAwgGg5x00kmsW7euz+vu7G9ud6G3/pimyfXXX8+4ceMIhUIMHDiQCy+8sE/VyF15V3cn9jmj8Mknn+A4Dg888ACrV6/mrrvu4v777+fnP/95n+decskl7Nixw/v3u9/9bi+0OBN///vfufbaa7nllltYtmwZhxxyCNOnT6euri7r8e+88w7nnXceF110EcuXL+fMM8/kzDPPZNWqVXu55Zl46623uPLKK3nvvfd47bXXME2Tk08+mUgk0ut5hYWFGc9g8+bNe6nFfePggw/OaNuCBQt6PHZffS4AS5YsyejHa6+9BsA555zT4zn7ynOJRCIccsgh3HvvvVm//93vfsfdd9/N/fffz6JFiwiFQkyfPp14PN7jNXf2N7c70Vt/otEoy5Yt46abbmLZsmX861//Ys2aNXzjG9/o87o7867udogvAH73u9+JESNG9HrM1KlTxdVXX713GtQLjjjiCHHllVd6f9u2LQYOHChmz56d9fiZM2eK0047LeOzyZMni8suu2yPtnNnUVdXJwDx1ltv9XjMnDlzRDgc3nuN2gnccsst4pBDDun38V+U5yKEEFdffbUYOXKkcBwn6/f76nMBxDPPPOP97TiOqKqqEr///e+9z1paWoTf7xdPPPFEj9fZ2d/cnkLX/mTD4sWLBSA2b97c4zE7+67ubuxzO4VsaG1tpaSkpM/jHn/8ccrKyhg7diw33HAD0Wh0L7SuE8lkkvfff5+TTjrJ+0xVVU466STefffdrOe8++67GccDTJ8+vcfjPy+0trYC9PkcOjo6GDZsGEOGDOGMM85g9erVe6N5/cK6desYOHAg++23H+effz5btmzp8dgvynNJJpP89a9/5Yc//CGKovR43L78XFLYuHEjNTU1GeMeDoeZPHlyj+O+K7+5zxOtra0oikJRUVGvx+3Mu7q7sc8bhfXr13PPPfdw2WWX9Xrcd77zHf76178yf/58brjhBh577DG++93v7qVWSjQ0NGDbNpWVlRmfV1ZWUlNTk/WcmpqanTr+84DjOFxzzTUcffTRjB07tsfjRo8ezUMPPcRzzz3HX//6VxzH4aijjmLbtm17sbXZMXnyZB5++GFeeeUV7rvvPjZu3Mixxx7rUbV3xRfhuQA8++yztLS08P3vf7/HY/bl55KO1NjuzLjvym/u80I8Huf666/nvPPO65UIb2ff1d2NvcaS+rOf/Yzf/va3vR7z8ccfZwRUqqurOeWUUzjnnHO45JJLej330ksv9f4/btw4BgwYwIknnsiGDRsYOXLkZ2v8VxxXXnklq1at6tOvOWXKFKZMmeL9fdRRR3HggQfywAMPcNttt+3pZvaKU0891fv/+PHjmTx5MsOGDeOpp57ioosu+hxb9tnwl7/8hVNPPZWBAwf2eMy+/Fy+KjBNk5kzZyKE4L777uv12M/7Xd1rRuEnP/lJr6sZgP3228/7//bt2znhhBM46qij+NOf/rTT95s8eTIgdxp7yyiUlZWhaRq1tbUZn9fW1lJVVZX1nKqqqp06fm9j1qxZ/Pvf/+btt9/OSmneGwzDYOLEiaxfv34PtW7XUVRUxAEHHNBj2/b15wKwefNmXn/9df71r3/t1Hn76nNJjW1tbS0DBgzwPq+trWXChAlZz9mV39zeRsogbN68mXnz5u00XXZf7+ruxl5zH5WXlzNmzJhe//l8PkDuEI4//ngOO+ww5syZ06sgRE9YsWIFQMbLtafh8/k47LDDeOONN7zPHMfhjTfeyFippWPKlCkZxwO89tprPR6/tyCEYNasWTzzzDPMmzePESNG7PQ1bNtm5cqVe/UZ9BcdHR1s2LChx7btq88lHXPmzKGiooLTTjttp87bV5/LiBEjqKqqyhj3trY2Fi1a1OO478pvbm8iZRDWrVvH66+/Tmlp6U5fo693dbfjcwtx94Bt27aJUaNGiRNPPFFs27ZN7Nixw/uXfszo0aPFokWLhBBCrF+/XvzqV78SS5cuFRs3bhTPPfec2G+//cRxxx2319v/5JNPCr/fLx5++GHx0UcfiUsvvVQUFRWJmpoaIYQQF1xwgfjZz37mHb9w4UKh67q44447xMcffyxuueUWYRiGWLly5V5vezquuOIKEQ6HxZtvvpnxDKLRqHdM177ceuutYu7cuWLDhg3i/fffF9/+9rdFIBAQq1ev/jy6kIGf/OQn4s033xQbN24UCxcuFCeddJIoKysTdXV1QogvznNJwbZtMXToUHH99dd3+25ffi7t7e1i+fLlYvny5QIQf/jDH8Ty5cu9bJzf/OY3oqioSDz33HPiww8/FGeccYYYMWKEiMVi3jWmTZsm7rnnHu/vvn5zn1d/ksmk+MY3viEGDx4sVqxYkfE7SiQSPfanr3d1T2OfMwpz5swRQNZ/KWzcuFEAYv78+UIIIbZs2SKOO+44UVJSIvx+vxg1apS47rrrRGtr6+fSh3vuuUcMHTpU+Hw+ccQRR4j33nvP+27q1Knie9/7XsbxTz31lDjggAOEz+cTBx98sHjxxRf3cou7o6dnMGfOHO+Yrn255pprvH5XVlaKr3/962LZsmV7v/FZcO6554oBAwYIn88nBg0aJM4991yxfv167/svynNJYe7cuQIQa9as6fbdvvxc5s+fn/W9SrXXcRxx0003icrKSuH3+8WJJ57YrY/Dhg0Tt9xyS8Znvf3mPq/+pOapbP9Sc1e2/vT1ru5p5Kizc8ghhxxy8LDPp6TmkEMOOeSw95AzCjnkkEMOOXjIGYUccsghhxw85IxCDjnkkEMOHnJGIYcccsghBw85o5BDDjnkkIOHnFHIIYcccsjBQ84o5JBDDjnk4CFnFHLIIYcccvCQMwo55JBDDjl4yBmFHHLIIYccPOSMQg455JBDDh7+P4LZyLvZtrzpAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "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",
    "\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": 7,
   "id": "610e4869",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cell line:  SKMEL19\n",
      "['DMSO' 'Vem' 'Vem+Tram']\n",
      "Cell line:  SKMEL19\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['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=-4923884.0000 g_loss=5386631.0000 | train mmd=0.1295 | test_mmd=0.6883\n",
      "[CellOT] epoch=50 f_loss=-168.3289 g_loss=940.6224 | train mmd=0.5316 | test_mmd=0.3072\n",
      "[CellOT] epoch=100 f_loss=-73.6705 g_loss=326.1705 | train mmd=0.6572 | test_mmd=0.2033\n",
      "[CellOT] epoch=150 f_loss=-372.9241 g_loss=437.9910 | train mmd=0.6086 | test_mmd=0.1466\n",
      "[CellOT] epoch=200 f_loss=-599.6742 g_loss=567.1274 | train mmd=0.2689 | test_mmd=0.0837\n",
      "[CellOT] epoch=250 f_loss=-723.5936 g_loss=473.9569 | train mmd=0.4473 | test_mmd=0.0838\n",
      "[CellOT] epoch=300 f_loss=-1102.1606 g_loss=640.4041 | train mmd=0.2867 | test_mmd=0.1215\n",
      "[CellOT] epoch=350 f_loss=-1228.4021 g_loss=873.5383 | train mmd=0.3451 | test_mmd=0.1233\n",
      "[CellOT] epoch=400 f_loss=-652.1746 g_loss=1961.1274 | train mmd=0.4663 | test_mmd=0.0761\n",
      "[CellOT] epoch=450 f_loss=-4573.9072 g_loss=943.4496 | train mmd=0.6036 | test_mmd=0.4685\n",
      "[CellOT] epoch=500 f_loss=-3478.1860 g_loss=1000.4998 | train mmd=0.2514 | test_mmd=0.1059\n",
      "[CellOT] epoch=550 f_loss=-662.8609 g_loss=1079.2213 | train mmd=0.3839 | test_mmd=0.0502\n",
      "[CellOT] epoch=600 f_loss=-606.9725 g_loss=1160.0986 | train mmd=0.4191 | test_mmd=0.0452\n",
      "[CellOT] epoch=650 f_loss=-1590.2916 g_loss=1133.2750 | train mmd=0.3431 | test_mmd=0.1507\n",
      "[CellOT] epoch=700 f_loss=-346.9046 g_loss=857.3398 | train mmd=0.2788 | test_mmd=0.0214\n",
      "[CellOT] epoch=750 f_loss=-645.4619 g_loss=1084.9265 | train mmd=0.3629 | test_mmd=0.0311\n",
      "[CellOT] epoch=800 f_loss=-610.2581 g_loss=1508.1724 | train mmd=0.3339 | test_mmd=0.0293\n",
      "[CellOT] epoch=850 f_loss=-837.4226 g_loss=2166.7610 | train mmd=0.3400 | test_mmd=0.0820\n",
      "[CellOT] epoch=900 f_loss=-409.9183 g_loss=2207.4746 | train mmd=0.2083 | test_mmd=0.0239\n",
      "[CellOT] epoch=950 f_loss=-500.9435 g_loss=1840.5603 | train mmd=0.2958 | test_mmd=0.0225\n",
      "[CellOT] epoch=1000 f_loss=-1069.5149 g_loss=575.7097 | train mmd=0.2345 | test_mmd=0.1723\n",
      "[CellOT] epoch=1050 f_loss=-315.2426 g_loss=1406.6853 | train mmd=0.2192 | test_mmd=0.1218\n",
      "[CellOT] epoch=1100 f_loss=-1038.3838 g_loss=974.7986 | train mmd=0.1711 | test_mmd=0.1209\n",
      "[CellOT] epoch=1150 f_loss=-1285.5668 g_loss=1164.8083 | train mmd=0.1865 | test_mmd=0.1001\n",
      "[CellOT] epoch=1200 f_loss=-17.6458 g_loss=1837.8335 | train mmd=0.2298 | test_mmd=0.0280\n",
      "[CellOT] epoch=1250 f_loss=490.8182 g_loss=2240.3203 | train mmd=0.1974 | test_mmd=0.0195\n",
      "[CellOT] epoch=1300 f_loss=432.2202 g_loss=2097.8667 | train mmd=0.2722 | test_mmd=0.0317\n",
      "[CellOT] epoch=1350 f_loss=150.7552 g_loss=2306.9951 | train mmd=0.2908 | test_mmd=0.0327\n",
      "[CellOT] epoch=1400 f_loss=292.0953 g_loss=2350.0010 | train mmd=0.2386 | test_mmd=0.0734\n",
      "[CellOT] epoch=1450 f_loss=409.0439 g_loss=2616.5657 | train mmd=0.2851 | test_mmd=0.0363\n",
      "[CellOT] epoch=1500 f_loss=264.2454 g_loss=3021.1409 | train mmd=0.2537 | test_mmd=0.0246\n",
      "[CellOT] epoch=1550 f_loss=191.6115 g_loss=3315.7324 | train mmd=0.2697 | test_mmd=0.0486\n",
      "[CellOT] epoch=1600 f_loss=-352.9545 g_loss=3445.0205 | train mmd=0.3979 | test_mmd=0.1729\n",
      "[CellOT] epoch=1650 f_loss=160.1913 g_loss=3413.7864 | train mmd=0.2611 | test_mmd=0.0400\n",
      "[CellOT] epoch=1700 f_loss=104.0172 g_loss=3582.1284 | train mmd=0.1823 | test_mmd=0.0343\n",
      "[CellOT] epoch=1750 f_loss=55.0435 g_loss=3701.8638 | train mmd=0.2586 | test_mmd=0.0968\n",
      "[CellOT] epoch=1800 f_loss=84.7178 g_loss=3594.3525 | train mmd=0.2229 | test_mmd=0.0314\n",
      "[CellOT] epoch=1850 f_loss=112.8116 g_loss=3462.0332 | train mmd=0.2976 | test_mmd=0.0831\n",
      "[CellOT] epoch=1900 f_loss=126.4417 g_loss=3589.2258 | train mmd=0.2156 | test_mmd=0.1112\n",
      "[CellOT] epoch=1950 f_loss=116.2814 g_loss=3623.3125 | train mmd=0.2985 | test_mmd=0.1100\n",
      "[CellOT] epoch=2000 f_loss=153.1750 g_loss=3533.4360 | train mmd=0.2232 | test_mmd=0.0413\n",
      "[CellOT] Final CellOT MMD: 0.1102\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-4172586.2500 g_loss=4426543.0000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.04131882407764653, 'mmd2_gamma_0.5': 0.13236183579794802, 'mmd2_gamma_1.0': 0.2185310272930135, 'wasserstein_distance': 1.2634767647311742, 'R2_feature_means': 0.8959774558560318}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=355.5007 g_loss=647.8898 | train mmd=0.4637 | test_mmd=0.2568\n",
      "[CellOT] epoch=100 f_loss=8.9054 g_loss=324.0871 | train mmd=0.6955 | test_mmd=0.1912\n",
      "[CellOT] epoch=150 f_loss=-340.5828 g_loss=452.0273 | train mmd=0.6822 | test_mmd=0.1722\n",
      "[CellOT] epoch=200 f_loss=-472.9594 g_loss=666.3107 | train mmd=0.5652 | test_mmd=0.1087\n",
      "[CellOT] epoch=250 f_loss=-1017.3552 g_loss=708.0474 | train mmd=0.4028 | test_mmd=0.1327\n",
      "[CellOT] epoch=300 f_loss=-2512.4731 g_loss=822.8890 | train mmd=0.3958 | test_mmd=0.3723\n",
      "[CellOT] epoch=350 f_loss=-799.5443 g_loss=4091.3296 | train mmd=0.3431 | test_mmd=0.1585\n",
      "[CellOT] epoch=400 f_loss=-781.9858 g_loss=2797.3960 | train mmd=0.4062 | test_mmd=0.0695\n",
      "[CellOT] epoch=450 f_loss=-896.3654 g_loss=1149.3328 | train mmd=0.4147 | test_mmd=0.0687\n",
      "[CellOT] epoch=500 f_loss=-878.1649 g_loss=1222.8436 | train mmd=0.4158 | test_mmd=0.0489\n",
      "[CellOT] epoch=550 f_loss=-1080.1042 g_loss=1208.3215 | train mmd=0.3733 | test_mmd=0.0563\n",
      "[CellOT] epoch=600 f_loss=-869.5294 g_loss=1405.3320 | train mmd=0.4246 | test_mmd=0.0528\n",
      "[CellOT] epoch=650 f_loss=-910.1245 g_loss=1305.1421 | train mmd=0.3879 | test_mmd=0.0400\n",
      "[CellOT] epoch=700 f_loss=-924.0541 g_loss=935.8746 | train mmd=0.2276 | test_mmd=0.1299\n",
      "[CellOT] epoch=750 f_loss=-847.2988 g_loss=1751.8854 | train mmd=0.3289 | test_mmd=0.0323\n",
      "[CellOT] epoch=800 f_loss=-274.5828 g_loss=1373.3756 | train mmd=0.2124 | test_mmd=0.0156\n",
      "[CellOT] epoch=850 f_loss=-487.6290 g_loss=1514.8009 | train mmd=0.2668 | test_mmd=0.0424\n",
      "[CellOT] epoch=900 f_loss=-566.7531 g_loss=1640.6260 | train mmd=0.2700 | test_mmd=0.0161\n",
      "[CellOT] epoch=950 f_loss=-522.1078 g_loss=1147.0168 | train mmd=0.2083 | test_mmd=0.0157\n",
      "[CellOT] epoch=1000 f_loss=-708.0769 g_loss=1443.7349 | train mmd=0.2818 | test_mmd=0.0303\n",
      "[CellOT] epoch=1050 f_loss=-512.5862 g_loss=1473.7297 | train mmd=0.2393 | test_mmd=0.0265\n",
      "[CellOT] epoch=1100 f_loss=-321.4473 g_loss=1811.6552 | train mmd=0.2349 | test_mmd=0.0397\n",
      "[CellOT] epoch=1150 f_loss=107.6280 g_loss=1461.6511 | train mmd=0.1973 | test_mmd=0.0470\n",
      "[CellOT] epoch=1200 f_loss=90.8097 g_loss=1365.8933 | train mmd=0.1884 | test_mmd=0.0503\n",
      "[CellOT] epoch=1250 f_loss=-169.3506 g_loss=1178.1276 | train mmd=0.2341 | test_mmd=0.0368\n",
      "[CellOT] epoch=1300 f_loss=406.0183 g_loss=528.5279 | train mmd=0.2109 | test_mmd=0.1421\n",
      "[CellOT] epoch=1350 f_loss=242.5834 g_loss=1018.0159 | train mmd=0.2525 | test_mmd=0.0334\n",
      "[CellOT] epoch=1400 f_loss=402.5259 g_loss=526.6409 | train mmd=0.1650 | test_mmd=0.0390\n",
      "[CellOT] epoch=1450 f_loss=336.4901 g_loss=490.4360 | train mmd=0.2419 | test_mmd=0.0532\n",
      "[CellOT] epoch=1500 f_loss=415.2063 g_loss=400.4009 | train mmd=0.2479 | test_mmd=0.0562\n",
      "[CellOT] epoch=1550 f_loss=512.5988 g_loss=399.5493 | train mmd=0.2769 | test_mmd=0.0770\n",
      "[CellOT] epoch=1600 f_loss=381.0019 g_loss=547.0168 | train mmd=0.3424 | test_mmd=0.1341\n",
      "[CellOT] epoch=1650 f_loss=92.5663 g_loss=633.5668 | train mmd=0.4042 | test_mmd=0.2675\n",
      "[CellOT] epoch=1700 f_loss=109.2246 g_loss=769.2357 | train mmd=0.1631 | test_mmd=0.0998\n",
      "[CellOT] epoch=1750 f_loss=40.0463 g_loss=783.3966 | train mmd=0.1643 | test_mmd=0.0568\n",
      "[CellOT] epoch=1800 f_loss=63.1826 g_loss=836.8496 | train mmd=0.1942 | test_mmd=0.1059\n",
      "[CellOT] epoch=1850 f_loss=37.9146 g_loss=891.2196 | train mmd=0.2483 | test_mmd=0.1791\n",
      "[CellOT] epoch=1900 f_loss=27.8003 g_loss=914.8580 | train mmd=0.2435 | test_mmd=0.0374\n",
      "[CellOT] epoch=1950 f_loss=21.0923 g_loss=937.8892 | train mmd=0.1952 | test_mmd=0.1719\n",
      "[CellOT] epoch=2000 f_loss=26.2278 g_loss=959.9836 | train mmd=0.3752 | test_mmd=0.2202\n",
      "[CellOT] Final CellOT MMD: 0.1709\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-4456234.5000 g_loss=5046043.5000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.22015923368658474, 'mmd2_gamma_0.5': 0.3977127657825084, 'mmd2_gamma_1.0': 0.36170298699955505, 'wasserstein_distance': 1.62056832064252, 'R2_feature_means': 0.6353394966508377}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-1115.6506 g_loss=370.1937 | train mmd=0.6124 | test_mmd=0.7850\n",
      "[CellOT] epoch=100 f_loss=-27.4771 g_loss=373.7516 | train mmd=0.6816 | test_mmd=0.1829\n",
      "[CellOT] epoch=150 f_loss=-573.1951 g_loss=396.6979 | train mmd=0.5155 | test_mmd=0.1688\n",
      "[CellOT] epoch=200 f_loss=-780.2418 g_loss=759.1669 | train mmd=0.4762 | test_mmd=0.4603\n",
      "[CellOT] epoch=250 f_loss=-556.0473 g_loss=688.4796 | train mmd=0.5781 | test_mmd=0.1417\n",
      "[CellOT] epoch=300 f_loss=-698.6516 g_loss=858.9607 | train mmd=0.4987 | test_mmd=0.1008\n",
      "[CellOT] epoch=350 f_loss=-752.2567 g_loss=1174.4008 | train mmd=0.5984 | test_mmd=0.1215\n",
      "[CellOT] epoch=400 f_loss=-861.8123 g_loss=1110.2245 | train mmd=0.6020 | test_mmd=0.1072\n",
      "[CellOT] epoch=450 f_loss=-765.4240 g_loss=1163.7778 | train mmd=0.5697 | test_mmd=0.0984\n",
      "[CellOT] epoch=500 f_loss=-920.6763 g_loss=1353.3638 | train mmd=0.5119 | test_mmd=0.0795\n",
      "[CellOT] epoch=550 f_loss=-1189.2330 g_loss=1339.5826 | train mmd=0.4926 | test_mmd=0.0728\n",
      "[CellOT] epoch=600 f_loss=-987.1850 g_loss=1414.0875 | train mmd=0.4049 | test_mmd=0.0635\n",
      "[CellOT] epoch=650 f_loss=-1189.5627 g_loss=1378.1702 | train mmd=0.3590 | test_mmd=0.0560\n",
      "[CellOT] epoch=700 f_loss=-843.7545 g_loss=1426.0579 | train mmd=0.3405 | test_mmd=0.0702\n",
      "[CellOT] epoch=750 f_loss=-880.6320 g_loss=1196.4454 | train mmd=0.2763 | test_mmd=0.0375\n",
      "[CellOT] epoch=800 f_loss=-1298.5774 g_loss=909.9385 | train mmd=0.2620 | test_mmd=0.2222\n",
      "[CellOT] epoch=850 f_loss=-3608.0808 g_loss=1810.7302 | train mmd=0.2544 | test_mmd=0.0729\n",
      "[CellOT] epoch=900 f_loss=-4571.4434 g_loss=3068.8018 | train mmd=0.2432 | test_mmd=0.1066\n",
      "[CellOT] epoch=950 f_loss=-3421.0361 g_loss=3707.9419 | train mmd=0.2431 | test_mmd=0.0826\n",
      "[CellOT] epoch=1000 f_loss=-7777.1709 g_loss=3423.0701 | train mmd=0.2551 | test_mmd=0.0914\n",
      "[CellOT] epoch=1050 f_loss=-5795.1772 g_loss=3788.3923 | train mmd=0.2878 | test_mmd=0.0848\n",
      "[CellOT] epoch=1100 f_loss=-3018.6021 g_loss=3846.0120 | train mmd=0.2152 | test_mmd=0.0499\n",
      "[CellOT] epoch=1150 f_loss=-2871.7993 g_loss=5161.4238 | train mmd=0.2625 | test_mmd=0.0647\n",
      "[CellOT] epoch=1200 f_loss=-3278.4595 g_loss=5277.2329 | train mmd=0.1919 | test_mmd=0.0661\n",
      "[CellOT] epoch=1250 f_loss=-2005.7377 g_loss=3044.2021 | train mmd=0.2172 | test_mmd=0.0575\n",
      "[CellOT] epoch=1300 f_loss=-2073.7510 g_loss=4020.4937 | train mmd=0.2872 | test_mmd=0.0327\n",
      "[CellOT] epoch=1350 f_loss=-1338.0710 g_loss=5211.8369 | train mmd=0.2050 | test_mmd=0.1127\n",
      "[CellOT] epoch=1400 f_loss=172.9903 g_loss=3505.2937 | train mmd=0.2876 | test_mmd=0.0659\n",
      "[CellOT] epoch=1450 f_loss=1035.1587 g_loss=4083.1409 | train mmd=0.2922 | test_mmd=0.0347\n",
      "[CellOT] epoch=1500 f_loss=1225.0210 g_loss=3796.2583 | train mmd=0.2519 | test_mmd=0.0289\n",
      "[CellOT] epoch=1550 f_loss=204.6345 g_loss=3029.8806 | train mmd=0.3090 | test_mmd=0.0801\n",
      "[CellOT] epoch=1600 f_loss=956.8539 g_loss=4367.5723 | train mmd=0.2893 | test_mmd=0.0355\n",
      "[CellOT] epoch=1650 f_loss=394.4522 g_loss=4405.0469 | train mmd=0.2623 | test_mmd=0.1020\n",
      "[CellOT] epoch=1700 f_loss=641.3269 g_loss=5016.4121 | train mmd=0.2871 | test_mmd=0.2131\n",
      "[CellOT] epoch=1750 f_loss=485.2207 g_loss=4771.4702 | train mmd=0.2862 | test_mmd=0.0574\n",
      "[CellOT] epoch=1800 f_loss=287.0074 g_loss=4896.0537 | train mmd=0.3616 | test_mmd=0.0745\n",
      "[CellOT] epoch=1850 f_loss=358.1669 g_loss=4937.1865 | train mmd=0.3053 | test_mmd=0.0293\n",
      "[CellOT] epoch=1900 f_loss=357.8586 g_loss=4975.1992 | train mmd=0.3331 | test_mmd=0.1608\n",
      "[CellOT] epoch=1950 f_loss=123.3275 g_loss=4898.7407 | train mmd=0.2018 | test_mmd=0.0460\n",
      "[CellOT] epoch=2000 f_loss=71.5475 g_loss=4834.5947 | train mmd=0.3022 | test_mmd=0.1722\n",
      "[CellOT] Final CellOT MMD: 0.1486\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-5009771.5000 g_loss=5587510.5000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.172163850598539, 'mmd2_gamma_0.5': 0.3093164234883161, 'mmd2_gamma_1.0': 0.29765679207955553, 'wasserstein_distance': 1.4825435674620204, 'R2_feature_means': 0.7210545020731898}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=299.8949 g_loss=775.0764 | train mmd=0.5849 | test_mmd=0.2119\n",
      "[CellOT] epoch=100 f_loss=-87.3119 g_loss=532.8467 | train mmd=0.7250 | test_mmd=0.1968\n",
      "[CellOT] epoch=150 f_loss=-421.5994 g_loss=654.7762 | train mmd=0.5951 | test_mmd=0.1359\n",
      "[CellOT] epoch=200 f_loss=-690.5936 g_loss=785.4315 | train mmd=0.5759 | test_mmd=0.1238\n",
      "[CellOT] epoch=250 f_loss=-794.8002 g_loss=839.6892 | train mmd=0.5286 | test_mmd=0.1001\n",
      "[CellOT] epoch=300 f_loss=-969.0823 g_loss=946.3607 | train mmd=0.3954 | test_mmd=0.0745\n",
      "[CellOT] epoch=350 f_loss=-839.2352 g_loss=2265.7727 | train mmd=0.3642 | test_mmd=0.0669\n",
      "[CellOT] epoch=400 f_loss=-1417.1362 g_loss=1094.4060 | train mmd=0.3353 | test_mmd=0.0976\n",
      "[CellOT] epoch=450 f_loss=-826.1874 g_loss=1359.0461 | train mmd=0.4277 | test_mmd=0.0684\n",
      "[CellOT] epoch=500 f_loss=-2648.2578 g_loss=4004.0942 | train mmd=0.2768 | test_mmd=0.0913\n",
      "[CellOT] epoch=550 f_loss=-762.7321 g_loss=4101.1313 | train mmd=0.4066 | test_mmd=0.0958\n",
      "[CellOT] epoch=600 f_loss=-798.8822 g_loss=1828.9196 | train mmd=0.3538 | test_mmd=0.0362\n",
      "[CellOT] epoch=650 f_loss=-910.6758 g_loss=1623.6794 | train mmd=0.3784 | test_mmd=0.0467\n",
      "[CellOT] epoch=700 f_loss=-852.4239 g_loss=1511.3770 | train mmd=0.2749 | test_mmd=0.0365\n",
      "[CellOT] epoch=750 f_loss=-545.4988 g_loss=1712.9796 | train mmd=0.2934 | test_mmd=0.0261\n",
      "[CellOT] epoch=800 f_loss=-758.6598 g_loss=2524.0750 | train mmd=0.3271 | test_mmd=0.0295\n",
      "[CellOT] epoch=850 f_loss=-874.9249 g_loss=2192.6172 | train mmd=0.3078 | test_mmd=0.0248\n",
      "[CellOT] epoch=900 f_loss=-857.8707 g_loss=2399.6338 | train mmd=0.2890 | test_mmd=0.0336\n",
      "[CellOT] epoch=950 f_loss=-506.2780 g_loss=2357.8452 | train mmd=0.2753 | test_mmd=0.0320\n",
      "[CellOT] epoch=1000 f_loss=-559.5962 g_loss=2904.2129 | train mmd=0.2620 | test_mmd=0.0288\n",
      "[CellOT] epoch=1050 f_loss=-213.3602 g_loss=1966.1204 | train mmd=0.2116 | test_mmd=0.0276\n",
      "[CellOT] epoch=1100 f_loss=-37.2215 g_loss=1891.4626 | train mmd=0.1859 | test_mmd=0.0427\n",
      "[CellOT] epoch=1150 f_loss=-69.6156 g_loss=1489.8157 | train mmd=0.2173 | test_mmd=0.0427\n",
      "[CellOT] epoch=1200 f_loss=439.5257 g_loss=1025.8638 | train mmd=0.1628 | test_mmd=0.0728\n",
      "[CellOT] epoch=1250 f_loss=397.9033 g_loss=892.7841 | train mmd=0.1917 | test_mmd=0.0343\n",
      "[CellOT] epoch=1300 f_loss=629.2130 g_loss=801.5253 | train mmd=0.1577 | test_mmd=0.0708\n",
      "[CellOT] epoch=1350 f_loss=534.6961 g_loss=1835.3242 | train mmd=0.1872 | test_mmd=0.0575\n",
      "[CellOT] epoch=1400 f_loss=576.4061 g_loss=374.3488 | train mmd=0.3495 | test_mmd=0.1274\n",
      "[CellOT] epoch=1450 f_loss=260.4071 g_loss=947.3804 | train mmd=0.1680 | test_mmd=0.2205\n",
      "[CellOT] epoch=1500 f_loss=-170.2220 g_loss=1410.9867 | train mmd=0.2904 | test_mmd=0.1998\n",
      "[CellOT] epoch=1550 f_loss=371.6689 g_loss=2286.6719 | train mmd=0.2697 | test_mmd=0.1013\n",
      "[CellOT] epoch=1600 f_loss=148.0236 g_loss=2802.3574 | train mmd=0.1664 | test_mmd=0.0918\n",
      "[CellOT] epoch=1650 f_loss=268.1761 g_loss=3034.0522 | train mmd=0.2474 | test_mmd=0.1458\n",
      "[CellOT] epoch=1700 f_loss=231.2944 g_loss=2968.2417 | train mmd=0.1823 | test_mmd=0.0792\n",
      "[CellOT] epoch=1750 f_loss=99.7490 g_loss=3037.7917 | train mmd=0.4057 | test_mmd=0.1196\n",
      "[CellOT] epoch=1800 f_loss=73.8744 g_loss=3024.4854 | train mmd=0.3634 | test_mmd=0.1359\n",
      "[CellOT] epoch=1850 f_loss=217.6146 g_loss=3032.4285 | train mmd=0.2055 | test_mmd=0.0880\n",
      "[CellOT] epoch=1900 f_loss=206.1609 g_loss=2973.4395 | train mmd=0.2308 | test_mmd=0.0527\n",
      "[CellOT] epoch=1950 f_loss=174.7629 g_loss=3161.9734 | train mmd=0.1823 | test_mmd=0.3164\n",
      "[CellOT] epoch=2000 f_loss=189.0262 g_loss=3233.5681 | train mmd=0.2761 | test_mmd=0.0427\n",
      "[CellOT] Final CellOT MMD: 0.1234\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-4933086.5000 g_loss=5313367.0000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.04269136319101108, 'mmd2_gamma_0.5': 0.1616749922225199, 'mmd2_gamma_1.0': 0.25042981517322804, 'wasserstein_distance': 1.4647075322166554, 'R2_feature_means': 0.8861648632145088}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=160.3822 g_loss=1229.4119 | train mmd=0.4414 | test_mmd=0.3151\n",
      "[CellOT] epoch=100 f_loss=-97.5254 g_loss=364.5000 | train mmd=0.7477 | test_mmd=0.2088\n",
      "[CellOT] epoch=150 f_loss=-400.5852 g_loss=465.5980 | train mmd=0.5762 | test_mmd=0.1168\n",
      "[CellOT] epoch=200 f_loss=-701.0154 g_loss=650.9413 | train mmd=0.4504 | test_mmd=0.1362\n",
      "[CellOT] epoch=250 f_loss=-800.4095 g_loss=729.2701 | train mmd=0.4282 | test_mmd=0.1003\n",
      "[CellOT] epoch=300 f_loss=-462.3839 g_loss=908.6812 | train mmd=0.3032 | test_mmd=0.0623\n",
      "[CellOT] epoch=350 f_loss=-734.4634 g_loss=1137.0986 | train mmd=0.4914 | test_mmd=0.0904\n",
      "[CellOT] epoch=400 f_loss=-1210.3422 g_loss=1830.9775 | train mmd=0.2661 | test_mmd=0.0677\n",
      "[CellOT] epoch=450 f_loss=-584.7934 g_loss=2202.6418 | train mmd=0.3633 | test_mmd=0.0560\n",
      "[CellOT] epoch=500 f_loss=-604.3435 g_loss=2074.4897 | train mmd=0.3060 | test_mmd=0.0391\n",
      "[CellOT] epoch=550 f_loss=-972.6695 g_loss=3200.9131 | train mmd=0.2158 | test_mmd=0.1089\n",
      "[CellOT] epoch=600 f_loss=-1055.1727 g_loss=1178.2629 | train mmd=0.2318 | test_mmd=0.0338\n",
      "[CellOT] epoch=650 f_loss=-608.9850 g_loss=1190.7095 | train mmd=0.3235 | test_mmd=0.0595\n",
      "[CellOT] epoch=700 f_loss=-535.6109 g_loss=1423.0962 | train mmd=0.2959 | test_mmd=0.0309\n",
      "[CellOT] epoch=750 f_loss=-906.6827 g_loss=1417.9700 | train mmd=0.2337 | test_mmd=0.0495\n",
      "[CellOT] epoch=800 f_loss=-711.5460 g_loss=1619.4463 | train mmd=0.2830 | test_mmd=0.0280\n",
      "[CellOT] epoch=850 f_loss=-70.1195 g_loss=1134.9436 | train mmd=0.1584 | test_mmd=0.0687\n",
      "[CellOT] epoch=900 f_loss=-585.7684 g_loss=1802.3521 | train mmd=0.2764 | test_mmd=0.0232\n",
      "[CellOT] epoch=950 f_loss=-529.4153 g_loss=2103.6260 | train mmd=0.2747 | test_mmd=0.0229\n",
      "[CellOT] epoch=1000 f_loss=-123.5573 g_loss=2977.0645 | train mmd=0.2336 | test_mmd=0.0917\n",
      "[CellOT] epoch=1050 f_loss=-37.1820 g_loss=1985.6459 | train mmd=0.2352 | test_mmd=0.0249\n",
      "[CellOT] epoch=1100 f_loss=-196.5471 g_loss=1807.3306 | train mmd=0.2128 | test_mmd=0.0606\n",
      "[CellOT] epoch=1150 f_loss=-124.7394 g_loss=2150.6792 | train mmd=0.2378 | test_mmd=0.0176\n",
      "[CellOT] epoch=1200 f_loss=-275.9245 g_loss=2181.8884 | train mmd=0.2460 | test_mmd=0.0236\n",
      "[CellOT] epoch=1250 f_loss=180.5776 g_loss=1923.0779 | train mmd=0.2321 | test_mmd=0.0198\n",
      "[CellOT] epoch=1300 f_loss=357.4570 g_loss=1986.3942 | train mmd=0.2485 | test_mmd=0.0344\n",
      "[CellOT] epoch=1350 f_loss=247.9614 g_loss=1492.3943 | train mmd=0.1897 | test_mmd=0.0185\n",
      "[CellOT] epoch=1400 f_loss=630.9725 g_loss=1294.9283 | train mmd=0.1909 | test_mmd=0.0616\n",
      "[CellOT] epoch=1450 f_loss=552.5036 g_loss=1452.9749 | train mmd=0.2643 | test_mmd=0.0316\n",
      "[CellOT] epoch=1500 f_loss=477.3506 g_loss=1558.0801 | train mmd=0.2590 | test_mmd=0.0253\n",
      "[CellOT] epoch=1550 f_loss=629.2418 g_loss=1204.5471 | train mmd=0.1831 | test_mmd=0.0336\n",
      "[CellOT] epoch=1600 f_loss=335.0515 g_loss=2059.5059 | train mmd=0.2300 | test_mmd=0.0451\n",
      "[CellOT] epoch=1650 f_loss=-49.5881 g_loss=3024.2388 | train mmd=0.2201 | test_mmd=0.0700\n",
      "[CellOT] epoch=1700 f_loss=-154.3407 g_loss=3414.2415 | train mmd=0.3049 | test_mmd=0.1068\n",
      "[CellOT] epoch=1750 f_loss=58.8214 g_loss=3831.5352 | train mmd=0.1749 | test_mmd=0.0844\n",
      "[CellOT] epoch=1800 f_loss=45.5759 g_loss=3877.8020 | train mmd=0.1763 | test_mmd=0.0764\n",
      "[CellOT] epoch=1850 f_loss=-78.6325 g_loss=3988.2849 | train mmd=0.2129 | test_mmd=0.0775\n",
      "[CellOT] epoch=1900 f_loss=80.7531 g_loss=3979.0166 | train mmd=0.1420 | test_mmd=0.0467\n",
      "[CellOT] epoch=1950 f_loss=81.9095 g_loss=4131.6919 | train mmd=0.2410 | test_mmd=0.0270\n",
      "[CellOT] epoch=2000 f_loss=68.5589 g_loss=4098.1143 | train mmd=0.1948 | test_mmd=0.0474\n",
      "[CellOT] Final CellOT MMD: 0.1010\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-4074011.2500 g_loss=4790363.0000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.04740450646245087, 'mmd2_gamma_0.5': 0.11649832865716514, 'mmd2_gamma_1.0': 0.18823399744330827, 'wasserstein_distance': 1.3344331765855686, 'R2_feature_means': 0.867008219610105}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=545.3804 g_loss=2077.7612 | train mmd=0.6847 | test_mmd=0.1962\n",
      "[CellOT] epoch=100 f_loss=-21.2239 g_loss=306.0441 | train mmd=0.6533 | test_mmd=0.1795\n",
      "[CellOT] epoch=150 f_loss=-297.7610 g_loss=579.1567 | train mmd=0.6011 | test_mmd=0.1279\n",
      "[CellOT] epoch=200 f_loss=-381.4123 g_loss=2937.4233 | train mmd=0.3322 | test_mmd=0.1451\n",
      "[CellOT] epoch=250 f_loss=-491.7060 g_loss=698.3790 | train mmd=0.3338 | test_mmd=0.0753\n",
      "[CellOT] epoch=300 f_loss=-576.0157 g_loss=942.7263 | train mmd=0.4733 | test_mmd=0.0900\n",
      "[CellOT] epoch=350 f_loss=-574.2871 g_loss=871.5698 | train mmd=0.4518 | test_mmd=0.0524\n",
      "[CellOT] epoch=400 f_loss=-637.5424 g_loss=944.9729 | train mmd=0.4733 | test_mmd=0.0706\n",
      "[CellOT] epoch=450 f_loss=-701.7422 g_loss=2809.5300 | train mmd=0.2650 | test_mmd=0.1483\n",
      "[CellOT] epoch=500 f_loss=-1749.7391 g_loss=8478.9600 | train mmd=0.4295 | test_mmd=0.1646\n",
      "[CellOT] epoch=550 f_loss=-810.8086 g_loss=720.2666 | train mmd=0.3664 | test_mmd=0.0457\n",
      "[CellOT] epoch=600 f_loss=-823.6135 g_loss=1192.7388 | train mmd=0.4098 | test_mmd=0.0548\n",
      "[CellOT] epoch=650 f_loss=-738.7775 g_loss=2611.2422 | train mmd=0.3907 | test_mmd=0.0863\n",
      "[CellOT] epoch=700 f_loss=-5272.2705 g_loss=968.9080 | train mmd=0.4897 | test_mmd=0.3983\n",
      "[CellOT] epoch=750 f_loss=-654.1092 g_loss=1419.6449 | train mmd=0.3308 | test_mmd=0.0505\n",
      "[CellOT] epoch=800 f_loss=-689.8930 g_loss=1421.6702 | train mmd=0.3505 | test_mmd=0.0288\n",
      "[CellOT] epoch=850 f_loss=-579.3815 g_loss=1339.5610 | train mmd=0.2450 | test_mmd=0.0281\n",
      "[CellOT] epoch=900 f_loss=-308.4100 g_loss=1180.5525 | train mmd=0.2232 | test_mmd=0.0289\n",
      "[CellOT] epoch=950 f_loss=-1033.1652 g_loss=1244.9293 | train mmd=0.2308 | test_mmd=0.0540\n",
      "[CellOT] epoch=1000 f_loss=-415.2378 g_loss=1543.7416 | train mmd=0.2538 | test_mmd=0.0209\n",
      "[CellOT] epoch=1050 f_loss=-209.3911 g_loss=1425.0817 | train mmd=0.2631 | test_mmd=0.0201\n",
      "[CellOT] epoch=1100 f_loss=-334.7030 g_loss=1719.1450 | train mmd=0.2503 | test_mmd=0.0167\n",
      "[CellOT] epoch=1150 f_loss=-583.5308 g_loss=1196.3293 | train mmd=0.2375 | test_mmd=0.0497\n",
      "[CellOT] epoch=1200 f_loss=-89.0904 g_loss=1122.3452 | train mmd=0.2545 | test_mmd=0.0434\n",
      "[CellOT] epoch=1250 f_loss=-28.6258 g_loss=1332.7097 | train mmd=0.3038 | test_mmd=0.0617\n",
      "[CellOT] epoch=1300 f_loss=290.1519 g_loss=810.6522 | train mmd=0.2144 | test_mmd=0.0672\n",
      "[CellOT] epoch=1350 f_loss=847.3625 g_loss=769.4446 | train mmd=0.3634 | test_mmd=0.1041\n",
      "[CellOT] epoch=1400 f_loss=411.5812 g_loss=672.4767 | train mmd=0.1976 | test_mmd=0.0618\n",
      "[CellOT] epoch=1450 f_loss=439.2722 g_loss=998.1330 | train mmd=0.2613 | test_mmd=0.1150\n",
      "[CellOT] epoch=1500 f_loss=399.6724 g_loss=502.3808 | train mmd=0.1985 | test_mmd=0.1377\n",
      "[CellOT] epoch=1550 f_loss=235.2081 g_loss=492.5838 | train mmd=0.1537 | test_mmd=0.1029\n",
      "[CellOT] epoch=1600 f_loss=74.5054 g_loss=588.8877 | train mmd=0.2284 | test_mmd=0.0719\n",
      "[CellOT] epoch=1650 f_loss=67.3618 g_loss=640.8260 | train mmd=0.1463 | test_mmd=0.0608\n",
      "[CellOT] epoch=1700 f_loss=35.8956 g_loss=704.1852 | train mmd=0.1636 | test_mmd=0.0478\n",
      "[CellOT] epoch=1750 f_loss=26.5664 g_loss=758.9304 | train mmd=0.1366 | test_mmd=0.0927\n",
      "[CellOT] epoch=1800 f_loss=16.5617 g_loss=784.5945 | train mmd=0.2382 | test_mmd=0.4857\n",
      "[CellOT] epoch=1850 f_loss=11.3650 g_loss=792.0795 | train mmd=0.2192 | test_mmd=0.0933\n",
      "[CellOT] epoch=1900 f_loss=11.0077 g_loss=814.6588 | train mmd=0.2713 | test_mmd=0.1467\n",
      "[CellOT] epoch=1950 f_loss=7.8785 g_loss=833.0685 | train mmd=0.1470 | test_mmd=0.0650\n",
      "[CellOT] epoch=2000 f_loss=6.4130 g_loss=844.1359 | train mmd=0.1344 | test_mmd=0.0221\n",
      "[CellOT] Final CellOT MMD: 0.0706\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-4068899.5000 g_loss=4337618.0000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.02206519927762174, 'mmd2_gamma_0.5': 0.06457147245735795, 'mmd2_gamma_1.0': 0.12722016631105482, 'wasserstein_distance': 1.0890097804469965, 'R2_feature_means': 0.9573854946648893}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-348.2271 g_loss=1841.6987 | train mmd=0.6881 | test_mmd=1.1041\n",
      "[CellOT] epoch=100 f_loss=8.2899 g_loss=291.5644 | train mmd=0.7483 | test_mmd=0.2224\n",
      "[CellOT] epoch=150 f_loss=-350.8948 g_loss=426.5065 | train mmd=0.6853 | test_mmd=0.1734\n",
      "[CellOT] epoch=200 f_loss=-467.6814 g_loss=918.2676 | train mmd=0.4672 | test_mmd=0.1053\n",
      "[CellOT] epoch=250 f_loss=-574.1347 g_loss=992.4581 | train mmd=0.5310 | test_mmd=0.1022\n",
      "[CellOT] epoch=300 f_loss=-684.0635 g_loss=826.1993 | train mmd=0.5683 | test_mmd=0.1059\n",
      "[CellOT] epoch=350 f_loss=-690.5765 g_loss=1873.1569 | train mmd=0.2796 | test_mmd=0.0867\n",
      "[CellOT] epoch=400 f_loss=-1522.8080 g_loss=941.5109 | train mmd=0.3765 | test_mmd=0.1361\n",
      "[CellOT] epoch=450 f_loss=-575.2448 g_loss=1495.6072 | train mmd=0.4420 | test_mmd=0.1586\n",
      "[CellOT] epoch=500 f_loss=-821.6724 g_loss=1017.4138 | train mmd=0.3111 | test_mmd=0.0417\n",
      "[CellOT] epoch=550 f_loss=-1193.7507 g_loss=1882.0242 | train mmd=0.4723 | test_mmd=0.1321\n",
      "[CellOT] epoch=600 f_loss=-1129.7983 g_loss=1171.2274 | train mmd=0.4296 | test_mmd=0.0522\n",
      "[CellOT] epoch=650 f_loss=-1245.9160 g_loss=1385.4490 | train mmd=0.2971 | test_mmd=0.1323\n",
      "[CellOT] epoch=700 f_loss=-818.5064 g_loss=1332.5327 | train mmd=0.3460 | test_mmd=0.0338\n",
      "[CellOT] epoch=750 f_loss=-584.8264 g_loss=1642.0913 | train mmd=0.2603 | test_mmd=0.0571\n",
      "[CellOT] epoch=800 f_loss=-712.3273 g_loss=1452.5869 | train mmd=0.3654 | test_mmd=0.0401\n",
      "[CellOT] epoch=850 f_loss=-400.4631 g_loss=1371.1858 | train mmd=0.2684 | test_mmd=0.0331\n",
      "[CellOT] epoch=900 f_loss=-373.2097 g_loss=1438.3185 | train mmd=0.2627 | test_mmd=0.0832\n",
      "[CellOT] epoch=950 f_loss=-323.3356 g_loss=1235.9719 | train mmd=0.1824 | test_mmd=0.0515\n",
      "[CellOT] epoch=1000 f_loss=-261.7368 g_loss=581.2585 | train mmd=0.2482 | test_mmd=0.1925\n",
      "[CellOT] epoch=1050 f_loss=-148.7982 g_loss=1277.0044 | train mmd=0.2501 | test_mmd=0.0176\n",
      "[CellOT] epoch=1100 f_loss=-318.0382 g_loss=1149.1951 | train mmd=0.2313 | test_mmd=0.0247\n",
      "[CellOT] epoch=1150 f_loss=-531.7032 g_loss=1073.8575 | train mmd=0.2272 | test_mmd=0.0264\n",
      "[CellOT] epoch=1200 f_loss=-267.7585 g_loss=1103.3788 | train mmd=0.2502 | test_mmd=0.0632\n",
      "[CellOT] epoch=1250 f_loss=-75.3992 g_loss=989.7140 | train mmd=0.2533 | test_mmd=0.0292\n",
      "[CellOT] epoch=1300 f_loss=57.9230 g_loss=847.2332 | train mmd=0.2486 | test_mmd=0.0540\n",
      "[CellOT] epoch=1350 f_loss=560.1515 g_loss=714.0848 | train mmd=0.2141 | test_mmd=0.0580\n",
      "[CellOT] epoch=1400 f_loss=-60.6895 g_loss=772.3881 | train mmd=0.2509 | test_mmd=0.0272\n",
      "[CellOT] epoch=1450 f_loss=124.6187 g_loss=350.1435 | train mmd=0.2774 | test_mmd=0.1985\n",
      "[CellOT] epoch=1500 f_loss=425.9444 g_loss=673.4429 | train mmd=0.2536 | test_mmd=0.1173\n",
      "[CellOT] epoch=1550 f_loss=327.0893 g_loss=1040.9908 | train mmd=0.2246 | test_mmd=0.0945\n",
      "[CellOT] epoch=1600 f_loss=292.8501 g_loss=1554.8236 | train mmd=0.2241 | test_mmd=0.1482\n",
      "[CellOT] epoch=1650 f_loss=105.5602 g_loss=1778.1431 | train mmd=0.3377 | test_mmd=0.1521\n",
      "[CellOT] epoch=1700 f_loss=107.6519 g_loss=2003.3260 | train mmd=0.1804 | test_mmd=0.0786\n",
      "[CellOT] epoch=1750 f_loss=57.2101 g_loss=2083.5256 | train mmd=0.1550 | test_mmd=0.0514\n",
      "[CellOT] epoch=1800 f_loss=59.3955 g_loss=2136.7476 | train mmd=0.1781 | test_mmd=0.0417\n",
      "[CellOT] epoch=1850 f_loss=61.8109 g_loss=2174.2827 | train mmd=0.2488 | test_mmd=0.1161\n",
      "[CellOT] epoch=1900 f_loss=51.3505 g_loss=2259.6960 | train mmd=0.2615 | test_mmd=0.0891\n",
      "[CellOT] epoch=1950 f_loss=34.4512 g_loss=2315.1201 | train mmd=0.3283 | test_mmd=0.0617\n",
      "[CellOT] epoch=2000 f_loss=36.5151 g_loss=2371.9207 | train mmd=0.2577 | test_mmd=0.0351\n",
      "[CellOT] Final CellOT MMD: 0.1202\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-6104799.0000 g_loss=7399297.0000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.03506431669248844, 'mmd2_gamma_0.5': 0.13397807510138826, 'mmd2_gamma_1.0': 0.22629889934343156, 'wasserstein_distance': 1.437026481884518, 'R2_feature_means': 0.9414138413730001}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-167.1984 g_loss=667.8534 | train mmd=0.4551 | test_mmd=0.3351\n",
      "[CellOT] epoch=100 f_loss=-102.6142 g_loss=292.0359 | train mmd=0.6831 | test_mmd=0.1965\n",
      "[CellOT] epoch=150 f_loss=-366.0707 g_loss=443.6765 | train mmd=0.6840 | test_mmd=0.1877\n",
      "[CellOT] epoch=200 f_loss=-516.2714 g_loss=574.2479 | train mmd=0.5723 | test_mmd=0.1197\n",
      "[CellOT] epoch=250 f_loss=-2282.3970 g_loss=637.3135 | train mmd=0.3824 | test_mmd=0.3911\n",
      "[CellOT] epoch=300 f_loss=-1376.4172 g_loss=771.5316 | train mmd=0.3204 | test_mmd=0.1000\n",
      "[CellOT] epoch=350 f_loss=-762.4625 g_loss=1063.4507 | train mmd=0.5210 | test_mmd=0.0897\n",
      "[CellOT] epoch=400 f_loss=-780.4280 g_loss=948.3644 | train mmd=0.4872 | test_mmd=0.0761\n",
      "[CellOT] epoch=450 f_loss=-2767.3857 g_loss=4016.3782 | train mmd=0.2819 | test_mmd=0.0980\n",
      "[CellOT] epoch=500 f_loss=-842.7662 g_loss=1397.2771 | train mmd=0.4510 | test_mmd=0.0657\n",
      "[CellOT] epoch=550 f_loss=-771.9791 g_loss=1243.8049 | train mmd=0.4053 | test_mmd=0.0516\n",
      "[CellOT] epoch=600 f_loss=-692.7941 g_loss=1059.2844 | train mmd=0.3430 | test_mmd=0.0482\n",
      "[CellOT] epoch=650 f_loss=-645.8134 g_loss=1074.3127 | train mmd=0.3645 | test_mmd=0.0401\n",
      "[CellOT] epoch=700 f_loss=-699.5637 g_loss=2344.7444 | train mmd=0.3141 | test_mmd=0.0432\n",
      "[CellOT] epoch=750 f_loss=-346.1557 g_loss=1017.3545 | train mmd=0.2735 | test_mmd=0.0419\n",
      "[CellOT] epoch=800 f_loss=-665.6790 g_loss=1004.4791 | train mmd=0.2460 | test_mmd=0.0466\n",
      "[CellOT] epoch=850 f_loss=-1227.1958 g_loss=1014.2224 | train mmd=0.2222 | test_mmd=0.0447\n",
      "[CellOT] epoch=900 f_loss=-1040.0131 g_loss=906.9683 | train mmd=0.2667 | test_mmd=0.2020\n",
      "[CellOT] epoch=950 f_loss=-186.7611 g_loss=1100.2993 | train mmd=0.2327 | test_mmd=0.0188\n",
      "[CellOT] epoch=1000 f_loss=-230.9747 g_loss=1155.8743 | train mmd=0.2439 | test_mmd=0.0204\n",
      "[CellOT] epoch=1050 f_loss=-313.3858 g_loss=1099.3107 | train mmd=0.2384 | test_mmd=0.0215\n",
      "[CellOT] epoch=1100 f_loss=-153.3584 g_loss=978.5143 | train mmd=0.2308 | test_mmd=0.0200\n",
      "[CellOT] epoch=1150 f_loss=-66.2800 g_loss=1113.3167 | train mmd=0.1999 | test_mmd=0.0102\n",
      "[CellOT] epoch=1200 f_loss=-36.9390 g_loss=900.1506 | train mmd=0.2166 | test_mmd=0.0146\n",
      "[CellOT] epoch=1250 f_loss=-21.6182 g_loss=748.3025 | train mmd=0.1692 | test_mmd=0.0331\n",
      "[CellOT] epoch=1300 f_loss=-40.3089 g_loss=718.8756 | train mmd=0.2490 | test_mmd=0.0204\n",
      "[CellOT] epoch=1350 f_loss=497.3955 g_loss=446.0486 | train mmd=0.1557 | test_mmd=0.0564\n",
      "[CellOT] epoch=1400 f_loss=139.9750 g_loss=1054.5028 | train mmd=0.2391 | test_mmd=0.0304\n",
      "[CellOT] epoch=1450 f_loss=415.9845 g_loss=300.2819 | train mmd=0.1373 | test_mmd=0.0341\n",
      "[CellOT] epoch=1500 f_loss=412.6135 g_loss=447.5700 | train mmd=0.1683 | test_mmd=0.0388\n",
      "[CellOT] epoch=1550 f_loss=345.9479 g_loss=331.9227 | train mmd=0.1532 | test_mmd=0.0739\n",
      "[CellOT] epoch=1600 f_loss=197.2028 g_loss=410.0476 | train mmd=0.2045 | test_mmd=0.1032\n",
      "[CellOT] epoch=1650 f_loss=97.9720 g_loss=514.4346 | train mmd=0.1821 | test_mmd=0.2155\n",
      "[CellOT] epoch=1700 f_loss=62.7651 g_loss=612.3419 | train mmd=0.1352 | test_mmd=0.0658\n",
      "[CellOT] epoch=1750 f_loss=13.3094 g_loss=713.4133 | train mmd=0.4054 | test_mmd=0.2255\n",
      "[CellOT] epoch=1800 f_loss=53.5598 g_loss=714.6208 | train mmd=0.1343 | test_mmd=0.0468\n",
      "[CellOT] epoch=1850 f_loss=12.3073 g_loss=803.9913 | train mmd=0.2147 | test_mmd=0.0791\n",
      "[CellOT] epoch=1900 f_loss=19.5684 g_loss=840.5081 | train mmd=0.3114 | test_mmd=0.1726\n",
      "[CellOT] epoch=1950 f_loss=22.7090 g_loss=852.8555 | train mmd=0.3389 | test_mmd=0.2211\n",
      "[CellOT] epoch=2000 f_loss=18.1624 g_loss=917.3383 | train mmd=0.3199 | test_mmd=0.1491\n",
      "[CellOT] Final CellOT MMD: 0.1275\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-4747281.0000 g_loss=5062098.0000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.14912900262980133, 'mmd2_gamma_0.5': 0.2586949470931974, 'mmd2_gamma_1.0': 0.2701361482192334, 'wasserstein_distance': 1.4535299915791544, 'R2_feature_means': 0.7788546285129532}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=474.4604 g_loss=664.7349 | train mmd=0.7189 | test_mmd=0.2255\n",
      "[CellOT] epoch=100 f_loss=-22.6244 g_loss=343.7224 | train mmd=0.6713 | test_mmd=0.1861\n",
      "[CellOT] epoch=150 f_loss=-440.1357 g_loss=469.0575 | train mmd=0.7077 | test_mmd=0.2000\n",
      "[CellOT] epoch=200 f_loss=-491.7725 g_loss=866.3317 | train mmd=0.4298 | test_mmd=0.0836\n",
      "[CellOT] epoch=250 f_loss=-644.7627 g_loss=754.4441 | train mmd=0.5763 | test_mmd=0.1069\n",
      "[CellOT] epoch=300 f_loss=-845.6731 g_loss=617.6860 | train mmd=0.4561 | test_mmd=0.0757\n",
      "[CellOT] epoch=350 f_loss=-860.4346 g_loss=1044.5000 | train mmd=0.4839 | test_mmd=0.0724\n",
      "[CellOT] epoch=400 f_loss=-892.9375 g_loss=1093.3972 | train mmd=0.5443 | test_mmd=0.0880\n",
      "[CellOT] epoch=450 f_loss=-843.1953 g_loss=1214.5449 | train mmd=0.4359 | test_mmd=0.0506\n",
      "[CellOT] epoch=500 f_loss=-1347.3142 g_loss=1935.1488 | train mmd=0.3983 | test_mmd=0.0501\n",
      "[CellOT] epoch=550 f_loss=-929.3497 g_loss=1347.8683 | train mmd=0.4576 | test_mmd=0.0707\n",
      "[CellOT] epoch=600 f_loss=-549.4360 g_loss=1627.6869 | train mmd=0.2092 | test_mmd=0.1473\n",
      "[CellOT] epoch=650 f_loss=-681.4681 g_loss=1445.4161 | train mmd=0.3344 | test_mmd=0.0561\n",
      "[CellOT] epoch=700 f_loss=-528.6089 g_loss=1572.5402 | train mmd=0.3761 | test_mmd=0.0334\n",
      "[CellOT] epoch=750 f_loss=-606.1584 g_loss=1843.7178 | train mmd=0.3204 | test_mmd=0.0310\n",
      "[CellOT] epoch=800 f_loss=-586.0674 g_loss=1437.7561 | train mmd=0.3211 | test_mmd=0.0258\n",
      "[CellOT] epoch=850 f_loss=-453.3243 g_loss=1557.5493 | train mmd=0.2008 | test_mmd=0.0380\n",
      "[CellOT] epoch=900 f_loss=-394.5015 g_loss=1521.1377 | train mmd=0.2962 | test_mmd=0.0202\n",
      "[CellOT] epoch=950 f_loss=-247.9908 g_loss=1168.5403 | train mmd=0.1571 | test_mmd=0.1054\n",
      "[CellOT] epoch=1000 f_loss=-487.4099 g_loss=1386.2034 | train mmd=0.2225 | test_mmd=0.0240\n",
      "[CellOT] epoch=1050 f_loss=-119.2723 g_loss=1346.8673 | train mmd=0.2246 | test_mmd=0.0269\n",
      "[CellOT] epoch=1100 f_loss=-176.8581 g_loss=1222.5435 | train mmd=0.2561 | test_mmd=0.0241\n",
      "[CellOT] epoch=1150 f_loss=375.7362 g_loss=785.5009 | train mmd=0.1517 | test_mmd=0.0418\n",
      "[CellOT] epoch=1200 f_loss=191.4681 g_loss=1102.8438 | train mmd=0.2144 | test_mmd=0.0257\n",
      "[CellOT] epoch=1250 f_loss=620.3350 g_loss=478.9728 | train mmd=0.2940 | test_mmd=0.2531\n",
      "[CellOT] epoch=1300 f_loss=403.5799 g_loss=442.6908 | train mmd=0.1684 | test_mmd=0.1120\n",
      "[CellOT] epoch=1350 f_loss=377.1111 g_loss=706.6409 | train mmd=0.1812 | test_mmd=0.0455\n",
      "[CellOT] epoch=1400 f_loss=396.4757 g_loss=954.4884 | train mmd=0.1748 | test_mmd=0.1372\n",
      "[CellOT] epoch=1450 f_loss=54.3873 g_loss=1134.4135 | train mmd=0.3110 | test_mmd=0.1505\n",
      "[CellOT] epoch=1500 f_loss=129.7008 g_loss=1399.1354 | train mmd=0.3031 | test_mmd=0.1192\n",
      "[CellOT] epoch=1550 f_loss=70.6017 g_loss=1478.6538 | train mmd=0.3220 | test_mmd=0.0988\n",
      "[CellOT] epoch=1600 f_loss=38.0521 g_loss=1605.5239 | train mmd=0.3449 | test_mmd=0.0968\n",
      "[CellOT] epoch=1650 f_loss=37.0676 g_loss=1635.0542 | train mmd=0.4585 | test_mmd=0.2138\n",
      "[CellOT] epoch=1700 f_loss=37.4310 g_loss=1677.8370 | train mmd=0.2288 | test_mmd=0.0987\n",
      "[CellOT] epoch=1750 f_loss=24.8723 g_loss=1696.2321 | train mmd=0.1672 | test_mmd=0.0362\n",
      "[CellOT] epoch=1800 f_loss=30.9757 g_loss=1680.9705 | train mmd=0.2283 | test_mmd=0.0248\n",
      "[CellOT] epoch=1850 f_loss=28.3336 g_loss=1684.7218 | train mmd=0.2652 | test_mmd=0.1038\n",
      "[CellOT] epoch=1900 f_loss=17.3021 g_loss=1725.7932 | train mmd=0.1843 | test_mmd=0.0438\n",
      "[CellOT] epoch=1950 f_loss=12.3063 g_loss=1761.6069 | train mmd=0.2165 | test_mmd=0.0375\n",
      "[CellOT] epoch=2000 f_loss=10.8971 g_loss=1779.4375 | train mmd=0.1631 | test_mmd=0.0383\n",
      "[CellOT] Final CellOT MMD: 0.0924\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-3623698.0000 g_loss=3953691.0000 | train mmd=0.1295 | test_mmd=0.6883\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.038348169625573636, 'mmd2_gamma_0.5': 0.10283484145161503, 'mmd2_gamma_1.0': 0.17771617590346883, 'wasserstein_distance': 1.1960697893490078, 'R2_feature_means': 0.9136074568339576}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-650.6722 g_loss=421.4122 | train mmd=0.4885 | test_mmd=0.3795\n",
      "[CellOT] epoch=100 f_loss=-84.0149 g_loss=273.1636 | train mmd=0.7210 | test_mmd=0.1977\n",
      "[CellOT] epoch=150 f_loss=-348.8495 g_loss=397.1488 | train mmd=0.6400 | test_mmd=0.1493\n",
      "[CellOT] epoch=200 f_loss=-514.2339 g_loss=550.8160 | train mmd=0.5972 | test_mmd=0.1193\n",
      "[CellOT] epoch=250 f_loss=-989.4354 g_loss=696.6660 | train mmd=0.4339 | test_mmd=0.1520\n",
      "[CellOT] epoch=300 f_loss=-664.2625 g_loss=1526.2148 | train mmd=0.5074 | test_mmd=0.1448\n",
      "[CellOT] epoch=350 f_loss=-791.8000 g_loss=861.7194 | train mmd=0.3741 | test_mmd=0.0933\n",
      "[CellOT] epoch=400 f_loss=-799.9877 g_loss=1541.0670 | train mmd=0.5061 | test_mmd=0.0827\n",
      "[CellOT] epoch=450 f_loss=-770.0315 g_loss=686.3711 | train mmd=0.2587 | test_mmd=0.0708\n",
      "[CellOT] epoch=500 f_loss=-789.8694 g_loss=1680.9099 | train mmd=0.3728 | test_mmd=0.0597\n",
      "[CellOT] epoch=550 f_loss=-1599.5956 g_loss=6116.4751 | train mmd=0.4875 | test_mmd=0.2392\n",
      "[CellOT] epoch=600 f_loss=-1000.7018 g_loss=1041.2357 | train mmd=0.2878 | test_mmd=0.0574\n",
      "[CellOT] epoch=650 f_loss=-859.5483 g_loss=742.6470 | train mmd=0.2575 | test_mmd=0.0385\n",
      "[CellOT] epoch=700 f_loss=-316.9500 g_loss=940.4967 | train mmd=0.2056 | test_mmd=0.0491\n",
      "[CellOT] epoch=750 f_loss=-493.7882 g_loss=841.5765 | train mmd=0.3119 | test_mmd=0.0267\n",
      "[CellOT] epoch=800 f_loss=-277.2094 g_loss=1120.0922 | train mmd=0.2468 | test_mmd=0.0324\n",
      "[CellOT] epoch=850 f_loss=-606.1786 g_loss=1333.7810 | train mmd=0.2967 | test_mmd=0.0269\n",
      "[CellOT] epoch=900 f_loss=-516.8932 g_loss=1413.2645 | train mmd=0.2503 | test_mmd=0.0276\n",
      "[CellOT] epoch=950 f_loss=-522.2617 g_loss=1494.4004 | train mmd=0.2380 | test_mmd=0.0259\n",
      "[CellOT] epoch=1000 f_loss=-196.1044 g_loss=1382.2087 | train mmd=0.2251 | test_mmd=0.0399\n",
      "[CellOT] epoch=1050 f_loss=-191.0942 g_loss=1479.7855 | train mmd=0.2654 | test_mmd=0.0145\n",
      "[CellOT] epoch=1100 f_loss=196.2622 g_loss=1033.8560 | train mmd=0.1746 | test_mmd=0.1024\n",
      "[CellOT] epoch=1150 f_loss=-195.5301 g_loss=1152.4216 | train mmd=0.1786 | test_mmd=0.0452\n",
      "[CellOT] epoch=1200 f_loss=221.4529 g_loss=1265.2512 | train mmd=0.2629 | test_mmd=0.0408\n",
      "[CellOT] epoch=1250 f_loss=147.1546 g_loss=1145.9656 | train mmd=0.2211 | test_mmd=0.0212\n",
      "[CellOT] epoch=1300 f_loss=377.8057 g_loss=1047.6337 | train mmd=0.2194 | test_mmd=0.1321\n",
      "[CellOT] epoch=1350 f_loss=363.9871 g_loss=824.2169 | train mmd=0.2249 | test_mmd=0.0600\n",
      "[CellOT] epoch=1400 f_loss=451.7158 g_loss=948.5287 | train mmd=0.2351 | test_mmd=0.0242\n",
      "[CellOT] epoch=1450 f_loss=455.7415 g_loss=676.7969 | train mmd=0.2098 | test_mmd=0.0328\n",
      "[CellOT] epoch=1500 f_loss=528.3348 g_loss=817.5066 | train mmd=0.1591 | test_mmd=0.0244\n",
      "[CellOT] epoch=1550 f_loss=381.7678 g_loss=1329.9241 | train mmd=0.2257 | test_mmd=0.0670\n",
      "[CellOT] epoch=1600 f_loss=257.4198 g_loss=1610.5415 | train mmd=0.2265 | test_mmd=0.1205\n",
      "[CellOT] epoch=1650 f_loss=58.6235 g_loss=2065.2910 | train mmd=0.2204 | test_mmd=0.1365\n",
      "[CellOT] epoch=1700 f_loss=6.9170 g_loss=2077.3477 | train mmd=0.3427 | test_mmd=0.1733\n",
      "[CellOT] epoch=1750 f_loss=19.9478 g_loss=2248.9399 | train mmd=0.1952 | test_mmd=0.0712\n",
      "[CellOT] epoch=1800 f_loss=108.8933 g_loss=2391.9941 | train mmd=0.4459 | test_mmd=0.2850\n",
      "[CellOT] epoch=1850 f_loss=73.1441 g_loss=2471.8044 | train mmd=0.1902 | test_mmd=0.0623\n",
      "[CellOT] epoch=1900 f_loss=44.1130 g_loss=2474.5122 | train mmd=0.1696 | test_mmd=0.0505\n",
      "[CellOT] epoch=1950 f_loss=54.7695 g_loss=2529.1978 | train mmd=0.1954 | test_mmd=0.0541\n",
      "[CellOT] epoch=2000 f_loss=40.8184 g_loss=2606.0293 | train mmd=0.2002 | test_mmd=0.0804\n",
      "[CellOT] Final CellOT MMD: 0.1015\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.08040033179466821, 'mmd2_gamma_0.5': 0.19018335729589697, 'mmd2_gamma_1.0': 0.212673467841908, 'wasserstein_distance': 1.3089367733437118, 'R2_feature_means': 0.9300680004783706}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0849  0.0697\n",
      "mmd2_gamma_0.5        0.1868  0.1043\n",
      "mmd2_gamma_1.0        0.2331  0.0661\n",
      "wasserstein_distance  1.3650  0.1568\n",
      "R2_feature_means      0.8527  0.1063\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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cQXNzc3U1NRw8skns3r16tLxOjo6OPfcc2ltbSUUCnHEEUfw5JNPlrafdMqpbNvezbe+ez2BpukEW2YhbQszE2XZSys57dx/pmHagcyccwBXf+VqkskkQtEQQF//IJ/41JXUt8/moCNP4c6/3uccVAiE6kH1OgVmVjaBlY2j+Wvx1rdz+4NLOez4M6mfeiCzF53I175zfel6orE4X/r695h+8IeYNHsRp5/5kYr7GY+7776b+fPn4/f7aWxs5NRTTyWVSk34/S4u47FPG4fMQCexLSvIDHTu9XN985vf5J577uHmm2/m1VdfZfbs2ZxxxhlEIpGK/b7xjW/w05/+lBUrVtDc3MzZZ5+NYRgAfOlLXyKXy/Hcc8+xdu1afvzjH5cqX6PRKCeffDKLFi1i5cqVPPbYY+zcuZPzzz+/4vg333wzHo+HZcuW8dvf/paLL76Yhx56iGQyWdpnyZIlpNNpPvrRjwJOoeItt9zCb3/7W9544w3+9V//lU996lM8++yzgNN742Mf+xhnn302q1at4oorruDb3/72mM+jaBhvuukmenp6KgzlW2+9xT333MO9997LqlWrAPjkJz9JX18fjz76KK+88gqHHnoop5xySun5JZNJPvzhD/PUU0/x2muvceaZZ3L22Wezbds2AP5y659onzyJf//Gl+lY9Rwda5aBEGzespXzLvwM533kDF5+5lFu+f3/x7LlL/HVf/shshCQ/vzVX6drRw+P3HMrt/7+Rn7/59vo7x8EaaF4/Nj5TMlQSMDKxvndH/7El6++hiuvvJLXXvk7f73lt8yeNRtF9yIUlUs//1X6Bwa577bf8cLj97FwwfyK+xmLnp4eLrroIj772c/y5ptvsvSJxzn3nI9g5bPjvtfFZcLI9xmxWEwCMhaLjdiWyWTkunXrZCaTecfn2fnaA3LtHy6Wq371Ubn2DxfLna898I6PORrJZFLqui5vu+220mv5fF62tbXJ//qv/5JSSvn0009LQN55552lfQYHB6Xf75d/+ctfpJRSzp8/X/7gBz+oeo4f/ehH8vTTT694bfv27RKQGzZskFJKuXjxYrlo0aKKfQzDkE1NTfKWW24pvXbRRRfJCy64QEopZTablYFAQC5fvrzifZdffrm86KKLpJRSXnvttfLAAw+s2P6tb31LAnJoaGjU5wLI++67r+K173//+1LX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rm2Bt5ON5557Dtdddx0GBgZACMHPf/7zqr9TSvE3f/M3WLJkCcLhMK666iocOHBgcQbrg2bj13Ud99xzD9atW4doNIqBgQHceuutGB8fn/f3BMFhgfDjH/8Yd999N77whS9g9+7dOP/883H11VdjampqsYfWEtu3b8cdd9yBl156CU8//TR0XcfHP/5xlEqlxR7avLFr1y585zvfwXnnnbfYQ2kb2WwWmzZtgiiKeOqpp/Db3/4W//iP/4jOzs7FHlpb+OpXv4oHHngA3/zmN/HOO+/gq1/9Kr72ta/h/vvvX+yh+aJUKuH888/Ht771Ld+/f+1rX8M///M/49vf/jZefvllRKNRXH311VAU5SSP1B/Nxl8ul7F7927ce++92L17Nx599FHs27cP119//fy/iAZYEFx88cX0jjvucP9tmiYdGBig99133yKO6tgwNTVFAdDt27cv9lDmhUKhQNesWUOffvppesUVV9A777xzsYfUFu655x66efPmxR7GMePaa6+lt99+e9Vrv/d7v0dvvvnmRRpR+wBAf/azn7n/tiyL9vf303/4h39wX5udnaWyLNMf/vCHizDC5qgdvx9eeeUVCoAePnx4XscOdg4LAE3T8Nprr+Gqq65yX+M4DldddRV27ty5iCM7NuRyOQBAV1fXIo9kfrjjjjtw7bXXVl2HDwIef/xxbNiwAZ/+9KfR29uL9evX47vf/e5iD6ttXHrppXjmmWewf/9+AMAbb7yBHTt24Jprrlnkkc0fhw4dwuTkZNU9lEwm8aEPfegD+SwD7HkmhKCjo2Nen3vfqbJ+EJFOp2GaJvr6+qpe7+vrw969exdpVMcGy7Jw1113YdOmTTj33HMXezht40c/+hF2796NXbt2LfZQ5o2DBw/igQcewN13342//uu/xq5du/AXf/EXkCQJt91222IPryX+6q/+Cvl8HmvXrgXP8zBNE3//93+Pm2++ebGHNm9MTk4CgO+z7PztgwRFUXDPPffgj/7oj+atNBsEhwBVuOOOO/DWW29hx44diz2UtjEyMoI777wTTz/9NEKh0GIPZ96wLAsbNmzAl7/8ZQDA+vXr8dZbb+Hb3/72ByI4/OQnP8G//uu/4gc/+AHOOecc7NmzB3fddRcGBgY+EOM/VaHrOm666SZQSvHAAw/M+/NBWmkB0N3dDZ7ncfTo0arXjx49iv7+/kUa1fzx53/+53jyySexbdu2D5SnxmuvvYapqSlceOGFEAQBgiBg+/bt+Od//mcIggDTNBd7iE2xZMkSnH322VWvnXXWWThy5MgijWh++Mu//Ev81V/9Ff7wD/8Q69atwy233ILPfe5zuO+++xZ7aPOG87x+0J9lJzAcPnwYTz/99DH5UwTBYQEgSRIuuugiPPPMM+5rlmXhmWeewSWXXLKII2sPlFL8+Z//OX72s59h69atWLVq1WIPaV648sorMTQ0hD179rj/bdiwATfffDP27NkDnucXe4hNsWnTpjrq8P79+7FixYpFGtH8UC6X65zFeJ6HZVmLNKJjx6pVq9Df31/1LOfzebz88ssfiGcZmAsMBw4cwG9+8xukUqljOk6QVlog3H333bjtttuwYcMGXHzxxfjGN76BUqmEz3zmM4s9tJa444478IMf/ACPPfYY4vG4m1tNJpMIh8OLPLrWiMfjdfWRaDSKVCr1gaibfO5zn8Oll16KL3/5y7jpppvwyiuv4MEHH8SDDz642ENrC9dddx3+/u//HsuXL8c555yD119/Hf/0T/+E22+/fbGH5otisYh3333X/fehQ4ewZ88edHV1Yfny5bjrrrvwpS99CWvWrMGqVatw7733YmBgADfeeOPiDdqDZuNfsmQJfv/3fx+7d+/Gk08+CdM03ee5q6sLkiS1/0XHzKEKUIf777+fLl++nEqSRC+++GL60ksvLfaQ2gIA3/8eeuihxR7aMeODRGWllNInnniCnnvuuVSWZbp27Vr64IMPLvaQ2kY+n6d33nknXb58OQ2FQvS0006j/+N//A+qqupiD80X27Zt873fb7vtNkopo7Pee++9tK+vj8qyTK+88kq6b9++xR20B83Gf+jQoYbP87Zt2+b1PYGfQ4AAAQIEqENQcwgQIECAAHUIgkOAAAECBKhDEBwCBAgQIEAdguAQIECAAAHqEASHAAECBAhQhyA4BAgQIECAOgTBIUCAAAEC1CEIDgECBAgQoA5BcAgQIECAAHUIgkOAAAECBKhDEBwCBAgQIEAd/n8cxL074vx4GQAAAABJRU5ErkJggg==",
      "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
