{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b9e2d729",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "True\n",
      "11.7\n",
      "NVIDIA RTX 6000 Ada Generation\n",
      "2\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "48"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "print(torch.cuda.is_available())   # should be True\n",
    "print(torch.version.cuda)          # CUDA version PyTorch is built with\n",
    "print(torch.cuda.get_device_name(0)) if torch.cuda.is_available() else None\n",
    "print(torch.cuda.device_count())\n",
    "import os\n",
    "os.cpu_count()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fe4f5248",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AnnData object with n_obs × n_vars = 119479 × 78\n",
      "    obs: 'drug'\n",
      "    var: 'cell_part', 'measurement', 'stat', 'feature', 'original'\n",
      "    uns: 'source'\n",
      "Shape: (119479, 78)\n",
      "Observation columns: ['drug']\n",
      "Feature columns: ['morphology-nuclei-area', 'morphology-nuclei-circularity', 'morphology-nuclei-convexity', 'morphology-nuclei-eccentricity', 'morphology-nuclei-elongation', 'morphology-nuclei-equivalent_diameter', 'morphology-nuclei-extent', 'morphology-nuclei-major_axis_length', 'morphology-nuclei-mean_radius', 'morphology-nuclei-perimeter']\n",
      "Unique conditions: ['ixazomib', 'everolimus', 'olaparib', 'paclitaxel', 'vemurafenib_cobimetinib', ..., 'ixazomib_lenalidomide_dexamethasone', 'melphalan', 'ulixertinib', 'dasatinib', 'sec.abcl']\n",
      "Length: 38\n",
      "Categories (38, object): ['cisplatin', 'cisplatin_olaparib', 'cl', 'control', ..., 'trametinib_panobinostat', 'ulixertinib', 'vemurafenib_cobimetinib', 'vindesine']\n",
      "Number of cells per condition:\n",
      "cl                                        18332\n",
      "control                                   10995\n",
      "sec.abcl                                   3399\n",
      "trametinib_dabrafenib                      2958\n",
      "ulixertinib                                2858\n",
      "dexamethasone                              2796\n",
      "sorafenib                                  2763\n",
      "hydroxyurea                                2715\n",
      "vemurafenib_cobimetinib                    2695\n",
      "cisplatin                                  2693\n",
      "dabrafenib                                 2675\n",
      "decitabine                                 2648\n",
      "trametinib                                 2637\n",
      "paclitaxel                                 2636\n",
      "imatinib                                   2631\n",
      "everolimus                                 2592\n",
      "pomalidomide_carfilzomib_dexamethasone     2545\n",
      "olaparib                                   2540\n",
      "lenalidomide                               2524\n",
      "regorafenib                                2524\n",
      "ixazomib_lenalidomide_dexamethasone        2522\n",
      "ixazomib                                   2514\n",
      "temozolomide                               2513\n",
      "panobinostat                               2492\n",
      "dacarbazine                                2485\n",
      "trametinib_erlotinib                       2452\n",
      "midostaurin                                2425\n",
      "erlotinib                                  2406\n",
      "trametinib_panobinostat                    2377\n",
      "mln2480                                    2367\n",
      "melphalan                                  2352\n",
      "palbociclib                                2322\n",
      "dasatinib                                  2250\n",
      "cisplatin_olaparib                         2245\n",
      "trametinib_midostaurin                     2211\n",
      "vindesine                                  2102\n",
      "crizotinib                                 1978\n",
      "staurosporine                              1310\n",
      "Name: drug, dtype: int64\n"
     ]
    }
   ],
   "source": [
    "import scanpy as sc\n",
    "\n",
    "# Load your dataset\n",
    "adata_4i = sc.read_h5ad(\"4i/8h.h5ad\")\n",
    "\n",
    "# Basic overview\n",
    "print(adata_4i)\n",
    "print(\"Shape:\", adata_4i.shape)\n",
    "\n",
    "# View column names (metadata about each cell)\n",
    "print(\"Observation columns:\", adata_4i.obs.columns.tolist()[:10])\n",
    "print(\"Feature columns:\", adata_4i.var_names[:10].tolist())\n",
    "\n",
    "# How many drugs (conditions)?\n",
    "print(\"Unique conditions:\", adata_4i.obs['drug'].unique())\n",
    "print(\"Number of cells per condition:\")\n",
    "print(adata_4i.obs['drug'].value_counts())\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c25979ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "features_4i = [\n",
    "    \"intensity-cell-CD45-mean\",\n",
    "    \"intensity-cell-ClCasp3-mean\",\n",
    "    \"intensity-cell-DAPI-sum\",\n",
    "    \"intensity-cell-Ki67-mean\",\n",
    "    \"intensity-cell-MelA-mean\",\n",
    "    \"intensity-cell-PCNA-mean\",\n",
    "    \"intensity-cell-Sox9-mean\",\n",
    "    \"intensity-cell-aTUB-mean\",\n",
    "    \"intensity-cell-pAKT-mean\",\n",
    "    \"intensity-cell-pEGFR-mean\",\n",
    "    \"intensity-cell-pERK-mean\",\n",
    "    \"intensity-cell-pMET-mean\",\n",
    "    \"intensity-cell-pS6k1-mean\",\n",
    "    \"intensity-nuclei-CD45-mean\",\n",
    "    \"intensity-nuclei-ClCasp3-mean\",\n",
    "    \"intensity-nuclei-DAPI-sum\",\n",
    "    \"intensity-nuclei-Ki67-mean\",\n",
    "    \"intensity-nuclei-MelA-mean\",\n",
    "    \"intensity-nuclei-PCNA-mean\",\n",
    "    \"intensity-nuclei-Sox9-mean\",\n",
    "    \"intensity-nuclei-aTUB-mean\",\n",
    "    \"intensity-nuclei-pAKT-mean\",\n",
    "    \"intensity-nuclei-pEGFR-mean\",\n",
    "    \"intensity-nuclei-pERK-mean\",\n",
    "    \"intensity-nuclei-pMET-mean\",\n",
    "    \"intensity-nuclei-pS6k1-mean\",\n",
    "    \"morphology-cell-area\",\n",
    "    \"morphology-cell-circularity\",\n",
    "    \"morphology-cell-convexity\",\n",
    "    \"morphology-cell-eccentricity\",\n",
    "    \"morphology-cell-elongation\",\n",
    "    \"morphology-cell-equivalent_diameter\",\n",
    "    \"morphology-cell-extent\",\n",
    "    \"morphology-cell-major_axis_length\",\n",
    "    \"morphology-cell-mean_radius\",\n",
    "    \"morphology-cell-perimeter\",\n",
    "    \"morphology-cell-roundness\",\n",
    "    \"morphology-nuclei-area\",\n",
    "    \"morphology-nuclei-circularity\",\n",
    "    \"morphology-nuclei-convexity\",\n",
    "    \"morphology-nuclei-eccentricity\",\n",
    "    \"morphology-nuclei-elongation\",\n",
    "    \"morphology-nuclei-equivalent_diameter\",\n",
    "    \"morphology-nuclei-extent\",\n",
    "    \"morphology-nuclei-major_axis_length\",\n",
    "    \"morphology-nuclei-mean_radius\",\n",
    "    \"morphology-nuclei-perimeter\",\n",
    "    \"morphology-nuclei-roundness\"\n",
    "]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "75d3cecc",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import json\n",
    "import logging\n",
    "import argparse\n",
    "import geomloss\n",
    "import random\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import TensorDataset, DataLoader\n",
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "from typing import Dict, Tuple, List, Optional\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "from sklearn.preprocessing import StandardScaler, MinMaxScaler\n",
    "from sklearn.metrics.pairwise import rbf_kernel\n",
    "from typing import Dict, Tuple, List\n",
    "from scipy.stats import ks_2samp\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.metrics import r2_score\n",
    "\n",
    "import gc\n",
    "gc.collect()\n",
    "\n",
    "def median_heuristic_gamma(X: np.ndarray, Y: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    Median heuristic for RBF bandwidth: gamma = 1 / median(||x - y||^2).\n",
    "    Uses the median of pairwise distances in the pooled set.\n",
    "    \"\"\"\n",
    "    Z = np.vstack([X, Y])\n",
    "    # Sample if too large for efficiency\n",
    "    max_samples = 5000\n",
    "    if Z.shape[0] > max_samples:\n",
    "        idx = np.random.choice(Z.shape[0], size=max_samples, replace=False)\n",
    "        Z = Z[idx]\n",
    "    D2 = cdist(Z, Z, metric='sqeuclidean')\n",
    "    # Use upper triangular without diagonal\n",
    "    triu = D2[np.triu_indices_from(D2, k=1)]\n",
    "    med = np.median(triu[triu > 0]) if np.any(triu > 0) else 1.0\n",
    "    return 1.0 / max(med, 1e-12)\n",
    "\n",
    "def mmd_distance(X: np.ndarray, Y: np.ndarray, gamma: float) -> float:\n",
    "    \"\"\"\n",
    "    Unbiased MMD^2 estimator using Gaussian (RBF) kernel, sklearn backend.\n",
    "\n",
    "    Args:\n",
    "        X: (n_samples, n_features) first sample\n",
    "        Y: (m_samples, n_features) second sample\n",
    "        gamma: RBF kernel bandwidth; if None, uses median heuristic\n",
    "\n",
    "    Returns:\n",
    "        Unbiased MMD^2 value\n",
    "    \"\"\"\n",
    "    n = X.shape[0]\n",
    "    m = Y.shape[0]\n",
    "\n",
    "    # Kernel matrices\n",
    "    Kxx = rbf_kernel(X, X, gamma=gamma)\n",
    "    Kyy = rbf_kernel(Y, Y, gamma=gamma)\n",
    "    Kxy = rbf_kernel(X, Y, gamma=gamma)\n",
    "\n",
    "    # Unbiased: exclude diagonal entries\n",
    "    np.fill_diagonal(Kxx, 0.0)\n",
    "    np.fill_diagonal(Kyy, 0.0)\n",
    "\n",
    "    term_xx = Kxx.sum() / (n * (n - 1)) if n > 1 else 0.0\n",
    "    term_yy = Kyy.sum() / (m * (m - 1)) if m > 1 else 0.0\n",
    "    term_xy = 2.0 * Kxy.mean()\n",
    "\n",
    "    mmd2 = term_xx + term_yy - term_xy\n",
    "    mmd2 = max(mmd2, 0.0)  # Numerical stability\n",
    "    return float(mmd2)\n",
    "\n",
    "def r2_feature_means(y_true: np.ndarray, y_pred: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    R^2 computed across features between mean vectors of y_true and y_pred.\n",
    "    \"\"\"\n",
    "    mu_true = y_true.mean(axis=0)\n",
    "    mu_pred = y_pred.mean(axis=0)\n",
    "    ss_res = float(np.sum((mu_true - mu_pred) ** 2))\n",
    "    ss_tot = float(np.sum((mu_true - mu_true.mean()) ** 2))\n",
    "    if ss_tot <= 1e-12:\n",
    "        return 1.0 if ss_res <= 1e-12 else 0.0\n",
    "    return 1.0 - ss_res / ss_tot\n",
    "\n",
    "def wasserstein_pointcloud(\n",
    "    X,\n",
    "    Y,\n",
    "    p: int = 2,\n",
    "    a=None,\n",
    "    b=None,\n",
    "    method: str = \"emd\",          # \"emd\" (exact) or \"sinkhorn\" (approx)\n",
    "    reg: float = 1e-1,            # Sinkhorn regularization (only used if method=\"sinkhorn\")\n",
    "    return_plan: bool = False,\n",
    "):\n",
    "    \"\"\"\n",
    "    Compute Wasserstein distance W_p between two empirical distributions supported on point sets X and Y.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    X : (n, d) array-like\n",
    "        Source points.\n",
    "    Y : (m, d) array-like\n",
    "        Target points.\n",
    "    p : int\n",
    "        Order of the Wasserstein distance (commonly 1 or 2).\n",
    "    a : (n,) array-like or None\n",
    "        Weights for X; if None, uniform weights.\n",
    "    b : (m,) array-like or None\n",
    "        Weights for Y; if None, uniform weights.\n",
    "    method : str\n",
    "        \"emd\" for exact optimal transport (requires POT),\n",
    "        \"sinkhorn\" for entropic approximation (requires POT).\n",
    "    reg : float\n",
    "        Entropic regularization strength for Sinkhorn.\n",
    "    return_plan : bool\n",
    "        If True, also return the optimal transport plan.\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    Wp : float\n",
    "        Wasserstein distance of order p.\n",
    "    plan : (n, m) ndarray, optional\n",
    "        Optimal transport plan (only if return_plan=True).\n",
    "    \"\"\"\n",
    "    X = np.asarray(X, dtype=np.float64)\n",
    "    Y = np.asarray(Y, dtype=np.float64)\n",
    "    if X.ndim != 2 or Y.ndim != 2:\n",
    "        raise ValueError(\"X and Y must be 2D arrays with shape (n, d) and (m, d).\")\n",
    "    if X.shape[1] != Y.shape[1]:\n",
    "        raise ValueError(f\"Dimension mismatch: X has d={X.shape[1]}, Y has d={Y.shape[1]}.\")\n",
    "\n",
    "    n, d = X.shape\n",
    "    m, _ = Y.shape\n",
    "\n",
    "    if a is None:\n",
    "        a = np.full(n, 1.0 / n, dtype=np.float64)\n",
    "    else:\n",
    "        a = np.asarray(a, dtype=np.float64)\n",
    "        a = a / a.sum()\n",
    "\n",
    "    if b is None:\n",
    "        b = np.full(m, 1.0 / m, dtype=np.float64)\n",
    "    else:\n",
    "        b = np.asarray(b, dtype=np.float64)\n",
    "        b = b / b.sum()\n",
    "\n",
    "    # Cost matrix: C_ij = ||x_i - y_j||^p\n",
    "    # Compute squared Euclidean via (x-y)^2 = x^2 + y^2 - 2xy for speed\n",
    "    X2 = np.sum(X * X, axis=1, keepdims=True)          # (n, 1)\n",
    "    Y2 = np.sum(Y * Y, axis=1, keepdims=True).T        # (1, m)\n",
    "    sq = np.maximum(X2 + Y2 - 2.0 * (X @ Y.T), 0.0)     # (n, m)\n",
    "    if p == 2:\n",
    "        C = sq\n",
    "    else:\n",
    "        C = sq ** (p / 2.0)\n",
    "\n",
    "    try:\n",
    "        import ot  # POT: Python Optimal Transport\n",
    "    except ImportError as e:\n",
    "        raise ImportError(\n",
    "            \"This function requires the POT library. Install with: pip install pot\"\n",
    "        ) from e\n",
    "\n",
    "    method = method.lower()\n",
    "    if method == \"emd\":\n",
    "        # exact OT: minimizes <P, C>\n",
    "        P = ot.emd(a, b, C)\n",
    "        cost = float(np.sum(P * C))\n",
    "    elif method == \"sinkhorn\":\n",
    "        # entropic OT approximation\n",
    "        P = ot.sinkhorn(a, b, C, reg=reg)\n",
    "        cost = float(np.sum(P * C))\n",
    "    else:\n",
    "        raise ValueError('method must be either \"emd\" or \"sinkhorn\".')\n",
    "\n",
    "    Wp = cost ** (1.0 / p)\n",
    "\n",
    "    if return_plan:\n",
    "        return Wp, P\n",
    "    return Wp\n",
    "\n",
    "def summarize_metrics(y_true: np.ndarray, y_pred: np.ndarray, median_gamma: float) -> dict:\n",
    "    \"\"\"\n",
    "    Compute a standard set of metrics: MMD^2 (RBF), R^2 of feature means, median KS across features, and Wasserstein distance.\n",
    "    \"\"\"\n",
    "    # Drop any samples that contain NaNs in either true or pred\n",
    "    mask = (~np.isnan(y_true).any(axis=1)) & (~np.isnan(y_pred).any(axis=1))\n",
    "    if mask.sum() < len(y_true):\n",
    "        print(f\"[summarize_metrics] Dropping {len(y_true) - mask.sum()} samples with NaNs.\")\n",
    "    \n",
    "    y_true = y_true[mask]\n",
    "    y_pred = y_pred[mask]\n",
    "\n",
    "    out = {}\n",
    "\n",
    "    out['mmd2_gamma_median'] = mmd_distance(y_true, y_pred, gamma=median_gamma)\n",
    "    out['mmd2_gamma_0.5'] = mmd_distance(y_true, y_pred, gamma=0.5)\n",
    "    out['mmd2_gamma_1.0'] = mmd_distance(y_true, y_pred, gamma=1.0)\n",
    "    out['wasserstein_distance'] = wasserstein_pointcloud(y_true, y_pred, p=2, method=\"emd\")\n",
    "    out['R2_feature_means'] = r2_feature_means(y_true, y_pred)\n",
    "    return out\n",
    "\n",
    "def split_train_test(X: np.ndarray, Y: np.ndarray, train_fraction: float, seed: int = 42) -> Tuple[np.ndarray, np.ndarray, np.ndarray, np.ndarray]:\n",
    "    if X.shape[0] != Y.shape[0]:\n",
    "        min_len = min(len(X), len(Y))\n",
    "        X = X[:min_len]\n",
    "        Y = Y[:min_len]\n",
    "\n",
    "    n = X.shape[0]\n",
    "    n_train = max(1, int(n * train_fraction))\n",
    "    rng = np.random.default_rng(seed)\n",
    "    idx = rng.permutation(n)\n",
    "    tr_idx, te_idx = idx[:n_train], idx[n_train:]\n",
    "    return X[tr_idx], X[te_idx], Y[tr_idx], Y[te_idx]\n",
    "\n",
    "def topk_markers(adata, drug: str, k: int = 50, rank_key: str = \"marker_genes-drug-rank\"):\n",
    "    R = adata.varm[rank_key]\n",
    "\n",
    "    # --- get the rank vector for this drug ---\n",
    "    if hasattr(R, \"columns\") and hasattr(R, \"iloc\"):  # pandas DataFrame\n",
    "        if drug in R.columns:\n",
    "            r = R[drug].to_numpy()\n",
    "        else:\n",
    "            # fallback: interpret columns as ordered groups; try to map via rank_genes_groups names\n",
    "            names = adata.uns[\"rank_genes_groups\"][\"names\"]\n",
    "            groups = list(names.dtype.names) if (hasattr(names, \"dtype\") and names.dtype.names is not None) else list(names.columns)\n",
    "            r = R.iloc[:, groups.index(drug)].to_numpy()\n",
    "    else:  # numpy array (or array-like)\n",
    "        names = adata.uns[\"rank_genes_groups\"][\"names\"]\n",
    "        groups = list(names.dtype.names) if (hasattr(names, \"dtype\") and names.dtype.names is not None) else list(names.columns)\n",
    "        r = np.asarray(R)[:, groups.index(drug)]\n",
    "\n",
    "    # smaller rank => stronger marker\n",
    "    idx = np.argsort(r)[:k]\n",
    "    gene_ids = adata.var_names[idx].to_list()\n",
    "    gene_short = (adata.var.iloc[idx][\"gene_short_name\"].to_list()\n",
    "                  if \"gene_short_name\" in adata.var.columns else None)\n",
    "    return gene_ids, gene_short, idx\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c533daf9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "eb96ecaa",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "import torch\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.decomposition import PCA\n",
    "from cellot.models.cellot import load_networks, compute_loss_f, compute_loss_g\n",
    "\n",
    "from sklearn.metrics.pairwise import rbf_kernel\n",
    "\n",
    "\n",
    "def mmd_distance(x, y, gamma):\n",
    "    xx = rbf_kernel(x, x, gamma)\n",
    "    xy = rbf_kernel(x, y, gamma)\n",
    "    yy = rbf_kernel(y, y, gamma)\n",
    "\n",
    "    return xx.mean() + yy.mean() - 2 * xy.mean()\n",
    "\n",
    "def compute_mmd_loss(lhs, rhs, gammas):\n",
    "    return np.mean([mmd_distance(lhs, rhs, g) for g in gammas])\n",
    "\n",
    "from cellot.losses.mmd import mmd_distance\n",
    "\n",
    "def run_cellot_pair(train_pre: np.ndarray, train_post: np.ndarray,\n",
    "                    test_pre: np.ndarray, test_post: np.ndarray,\n",
    "                    layers: Optional[List[int]] = [32, 32, 32],\n",
    "                    n_epochs: int = 5000,\n",
    "                    feature_subset: Optional[List[int]] = None,) -> Dict:\n",
    "    \n",
    "    device = 'cuda'\n",
    "    print(f\"VERS torch={torch.__version__} (CellOT), device={device}\", file=sys.stderr, flush=True)\n",
    "\n",
    "\n",
    "    # Apply feature subset if specified\n",
    "    if feature_subset is not None:\n",
    "        print(f\"Using feature subset of size {len(feature_subset)}\", file=sys.stderr, flush=True)\n",
    "        train_pre = train_pre[:, feature_subset]\n",
    "        train_post = train_post[:, feature_subset]\n",
    "        test_pre = test_pre[:, feature_subset]\n",
    "        test_post = test_post[:, feature_subset]\n",
    "\n",
    "    # Preprocess: standardize jointly and optionally apply PCA for stability\n",
    "    X_all = np.vstack([train_pre, train_post])\n",
    "    scaler = StandardScaler()\n",
    "    X_all_s = scaler.fit_transform(X_all)\n",
    "    d = X_all_s.shape[1]\n",
    "    pca_dims = min(50, d)\n",
    "    if pca_dims < d:\n",
    "        pca = PCA(n_components=pca_dims, svd_solver='full', random_state=42)\n",
    "        X_all_p = pca.fit_transform(X_all_s)\n",
    "        tr_pre_p = X_all_p[:len(train_pre)]\n",
    "        tr_post_p = X_all_p[len(train_pre):]\n",
    "        te_pre_p = pca.transform(scaler.transform(test_pre))\n",
    "        use_pca = True\n",
    "    else:\n",
    "        tr_pre_p = X_all_s[:len(train_pre)]\n",
    "        tr_post_p = X_all_s[len(train_pre):]\n",
    "        te_pre_p = scaler.transform(test_pre)\n",
    "        use_pca = False\n",
    "\n",
    "    # Networks - Using official CellOT configuration\n",
    "    input_dim = tr_pre_p.shape[1]\n",
    "    config = {\n",
    "        'model': {\n",
    "            'name': 'cellot',\n",
    "            'hidden_units': layers,\n",
    "            'kernel_init_fxn': {'name': 'uniform', 'a': -0.01, 'b': 0.01},\n",
    "            'activation': 'relu',\n",
    "            'softplus_W_kernels': True,\n",
    "            'f': {},\n",
    "            'g': {}\n",
    "        }\n",
    "    }\n",
    "    f, g = load_networks(config, input_dim=input_dim)\n",
    "    f = f.to(device).float()\n",
    "    g = g.to(device).float()\n",
    "\n",
    "    # Data tensors\n",
    "    src = torch.tensor(tr_pre_p, dtype=torch.float32, device=device)\n",
    "    tgt = torch.tensor(tr_post_p, dtype=torch.float32, device=device)\n",
    "    te_src = torch.tensor(te_pre_p, dtype=torch.float32, device=device)\n",
    "\n",
    "    # Optimizers matching official config\n",
    "    lr = 1e-4\n",
    "    optim_f = torch.optim.Adam(f.parameters(), lr=lr, betas=(0.5, 0.9), weight_decay=0)\n",
    "    optim_g = torch.optim.Adam(g.parameters(), lr=lr, betas=(0.5, 0.9), weight_decay=0)\n",
    "\n",
    "    # No schedulers in official config\n",
    "    # n_epochs = 1200  # More epochs for better convergence\n",
    "    n_epochs = n_epochs + 1  \n",
    "    # Training loop following official CellOT implementation\n",
    "    f.train(); g.train()\n",
    "    batch_size = 256  # Official config\n",
    "    n_inner_iters = 10  # Official config\n",
    "\n",
    "\n",
    "    for epoch in range(n_epochs):\n",
    "        f.train(); g.train()\n",
    "        perm_t = torch.randperm(len(tgt), device=device)[:batch_size]\n",
    "        yt = tgt[perm_t]\n",
    "        \n",
    "        # Multiple g updates per iteration (official implementation)\n",
    "        for _ in range(n_inner_iters):\n",
    "            perm_s = torch.randperm(len(src), device=device)[:batch_size]\n",
    "            xs = src[perm_s].detach().clone().requires_grad_(True)\n",
    "            \n",
    "            optim_g.zero_grad()\n",
    "            g_loss = compute_loss_g(f, g, xs).mean()\n",
    "            g_loss.backward()\n",
    "            torch.nn.utils.clip_grad_norm_(g.parameters(), max_norm=0.5)\n",
    "            optim_g.step()\n",
    "        \n",
    "        # Single f update (official implementation)\n",
    "        perm_s = torch.randperm(len(src), device=device)[:batch_size]\n",
    "        xs = src[perm_s].detach().clone().requires_grad_(True)\n",
    "        \n",
    "        optim_f.zero_grad()\n",
    "        f_loss = compute_loss_f(f, g, xs, yt).mean()\n",
    "        f_loss.backward()\n",
    "        optim_f.step()\n",
    "        \n",
    "        # Clamp weights for f (official implementation)\n",
    "        if hasattr(f, 'clamp_w'):\n",
    "            f.clamp_w()\n",
    "        \n",
    "        \n",
    "        # ---- Evaluate train MMD and early-stop ----\n",
    "        if epoch % 50 == 0: \n",
    "            f.eval()\n",
    "            g.eval()\n",
    "\n",
    "\n",
    "            # Transport a fixed subset of training PRE (in preprocessed space)\n",
    "            tr_src_eval = src.requires_grad_(True)\n",
    "            tr_pred_p = g.transport(tr_src_eval).detach().cpu().numpy()\n",
    "            # Invert preprocessing to original space (so MMD is comparable to your final eval)\n",
    "            if use_pca:\n",
    "                tr_pred = scaler.inverse_transform(pca.inverse_transform(tr_pred_p))\n",
    "            else:\n",
    "                tr_pred = scaler.inverse_transform(tr_pred_p)\n",
    "            train_mmd_min = mmd_distance(train_post, tr_pred, gamma=1.0)\n",
    "\n",
    "\n",
    "            te_src_full = te_src.detach().clone().requires_grad_(True)\n",
    "            te_pred_full = g.transport(te_src_full).detach().cpu().numpy()\n",
    "            if use_pca:\n",
    "                te_pred_inv_full = scaler.inverse_transform(pca.inverse_transform(te_pred_full))\n",
    "            else:\n",
    "                te_pred_inv_full = scaler.inverse_transform(te_pred_full)\n",
    "            test_metrics = mmd_distance(test_post, te_pred_inv_full, gamma=median_gamma)\n",
    "\n",
    "            print(\n",
    "                f\"[CellOT] epoch={epoch} f_loss={f_loss.item():.4f} g_loss={g_loss.item():.4f} | \"\n",
    "                f\"train mmd={train_mmd_min:.4f} | \"\n",
    "                f\"test_mmd={test_metrics:.4f}\",\n",
    "                file=sys.stderr,\n",
    "                flush=True,\n",
    "            )\n",
    "\n",
    "                \n",
    "            \n",
    "\n",
    "    # Inference (CellOT transport requires gradients for autodiff)\n",
    "    f.eval(); g.eval()\n",
    "    # CellOT needs gradients even in eval mode for transport computation\n",
    "    te_src_for_transport = te_src.detach().clone().requires_grad_(True)\n",
    "    te_tx = g.transport(te_src_for_transport).detach().cpu().numpy()\n",
    "\n",
    "    # Inverse preprocess\n",
    "    if use_pca:\n",
    "        te_tx_inv = scaler.inverse_transform(pca.inverse_transform(te_tx))\n",
    "    else:\n",
    "        te_tx_inv = scaler.inverse_transform(te_tx)\n",
    "    # Final evaluation\n",
    "    metrics = summarize_metrics(test_post[:len(te_tx_inv)], te_tx_inv, median_gamma)\n",
    "\n",
    "    gammas = np.logspace(1, -3, num=50)\n",
    "    mmd = compute_mmd_loss(test_post[:len(te_tx_inv)], te_tx_inv, gammas=gammas)\n",
    "    print(f\"[CellOT] Final CellOT MMD: {mmd:.4f}\", file=sys.stderr, flush=True)\n",
    "    \n",
    "    return {'y_pred': te_tx_inv, 'metrics': metrics}\n",
    "    \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b2a6a182",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (10995, 48)\n",
      "X_post cells: (2637, 48)\n",
      "(2109, 48)\n",
      "(528, 48)\n",
      "(2109, 48)\n",
      "(528, 48)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.08064887236416649\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=2.6851 g_loss=-27.1132 | train mmd=0.0264 | test_mmd=0.2325\n",
      "[CellOT] epoch=50 f_loss=-46.1256 g_loss=-53.3312 | train mmd=0.0158 | test_mmd=0.4378\n",
      "[CellOT] epoch=100 f_loss=-31.3883 g_loss=-32.6367 | train mmd=0.0158 | test_mmd=0.4147\n",
      "[CellOT] epoch=150 f_loss=-8.8425 g_loss=-22.0010 | train mmd=0.0157 | test_mmd=0.2323\n",
      "[CellOT] epoch=200 f_loss=-9.1484 g_loss=-19.3172 | train mmd=0.0141 | test_mmd=0.0694\n",
      "[CellOT] epoch=250 f_loss=0.0339 g_loss=-18.3367 | train mmd=0.0111 | test_mmd=0.0254\n",
      "[CellOT] epoch=300 f_loss=-0.9615 g_loss=-21.2505 | train mmd=0.0085 | test_mmd=0.0139\n",
      "[CellOT] epoch=350 f_loss=-2.8605 g_loss=-19.4390 | train mmd=0.0067 | test_mmd=0.0151\n",
      "[CellOT] epoch=400 f_loss=-2.5204 g_loss=-17.2976 | train mmd=0.0065 | test_mmd=0.0130\n",
      "[CellOT] epoch=450 f_loss=-0.1204 g_loss=-15.9278 | train mmd=0.0045 | test_mmd=0.0064\n",
      "[CellOT] epoch=500 f_loss=2.8224 g_loss=-17.6602 | train mmd=0.0054 | test_mmd=0.0136\n",
      "[CellOT] epoch=550 f_loss=-1.0918 g_loss=-19.7359 | train mmd=0.0053 | test_mmd=0.0098\n",
      "[CellOT] epoch=600 f_loss=3.1121 g_loss=-16.3677 | train mmd=0.0056 | test_mmd=0.0108\n",
      "[CellOT] epoch=650 f_loss=-0.0356 g_loss=-15.6130 | train mmd=0.0051 | test_mmd=0.0093\n",
      "[CellOT] epoch=700 f_loss=0.3170 g_loss=-16.1519 | train mmd=0.0055 | test_mmd=0.0111\n",
      "[CellOT] epoch=750 f_loss=-0.9225 g_loss=-16.6762 | train mmd=0.0042 | test_mmd=0.0072\n",
      "[CellOT] epoch=800 f_loss=-2.7620 g_loss=-16.5553 | train mmd=0.0038 | test_mmd=0.0057\n",
      "[CellOT] epoch=850 f_loss=0.4820 g_loss=-17.1014 | train mmd=0.0042 | test_mmd=0.0054\n",
      "[CellOT] epoch=900 f_loss=2.1788 g_loss=-16.8296 | train mmd=0.0035 | test_mmd=0.0075\n",
      "[CellOT] epoch=950 f_loss=2.7217 g_loss=-17.2202 | train mmd=0.0057 | test_mmd=0.0134\n",
      "[CellOT] epoch=1000 f_loss=0.7917 g_loss=-18.9009 | train mmd=0.0056 | test_mmd=0.0087\n",
      "[CellOT] Final CellOT MMD: 0.0054\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=7.4808 g_loss=-27.4605 | train mmd=0.0361 | test_mmd=0.2592\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.008655770565777932, 'mmd2_gamma_0.5': 0.011748747168152829, 'mmd2_gamma_1.0': 0.008045261350054785, 'wasserstein_distance': 2.2155815046730405, 'R2_feature_means': 0.9538888927663388}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-64.5885 g_loss=-42.9022 | train mmd=0.0158 | test_mmd=0.4389\n",
      "[CellOT] epoch=100 f_loss=-35.5397 g_loss=-30.0777 | train mmd=0.0158 | test_mmd=0.4363\n",
      "[CellOT] epoch=150 f_loss=-15.8137 g_loss=-21.5662 | train mmd=0.0158 | test_mmd=0.3160\n",
      "[CellOT] epoch=200 f_loss=-6.5358 g_loss=-20.5437 | train mmd=0.0153 | test_mmd=0.1353\n",
      "[CellOT] epoch=250 f_loss=-3.8272 g_loss=-17.3215 | train mmd=0.0122 | test_mmd=0.0437\n",
      "[CellOT] epoch=300 f_loss=-2.0397 g_loss=-15.8126 | train mmd=0.0103 | test_mmd=0.0298\n",
      "[CellOT] epoch=350 f_loss=2.4408 g_loss=-18.9485 | train mmd=0.0076 | test_mmd=0.0172\n",
      "[CellOT] epoch=400 f_loss=-2.6122 g_loss=-16.5473 | train mmd=0.0070 | test_mmd=0.0142\n",
      "[CellOT] epoch=450 f_loss=-0.9843 g_loss=-17.7322 | train mmd=0.0075 | test_mmd=0.0119\n",
      "[CellOT] epoch=500 f_loss=-0.7192 g_loss=-14.0198 | train mmd=0.0066 | test_mmd=0.0138\n",
      "[CellOT] epoch=550 f_loss=-3.0211 g_loss=-15.9286 | train mmd=0.0054 | test_mmd=0.0087\n",
      "[CellOT] epoch=600 f_loss=-0.3182 g_loss=-15.9260 | train mmd=0.0050 | test_mmd=0.0158\n",
      "[CellOT] epoch=650 f_loss=0.9393 g_loss=-16.4452 | train mmd=0.0050 | test_mmd=0.0103\n",
      "[CellOT] epoch=700 f_loss=-0.4975 g_loss=-14.3580 | train mmd=0.0058 | test_mmd=0.0088\n",
      "[CellOT] epoch=750 f_loss=-1.7409 g_loss=-17.1498 | train mmd=0.0042 | test_mmd=0.0061\n",
      "[CellOT] epoch=800 f_loss=0.9725 g_loss=-16.2104 | train mmd=0.0047 | test_mmd=0.0093\n",
      "[CellOT] epoch=850 f_loss=-1.9815 g_loss=-15.8622 | train mmd=0.0048 | test_mmd=0.0067\n",
      "[CellOT] epoch=900 f_loss=-2.0659 g_loss=-14.2986 | train mmd=0.0052 | test_mmd=0.0070\n",
      "[CellOT] epoch=950 f_loss=-0.3892 g_loss=-14.7093 | train mmd=0.0050 | test_mmd=0.0116\n",
      "[CellOT] epoch=1000 f_loss=-0.5953 g_loss=-16.7784 | train mmd=0.0042 | test_mmd=0.0089\n",
      "[CellOT] Final CellOT MMD: 0.0055\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=4.6928 g_loss=-28.2502 | train mmd=0.0267 | test_mmd=0.3651\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.008857619319058818, 'mmd2_gamma_0.5': 0.010736486697960956, 'mmd2_gamma_1.0': 0.007694744983114413, 'wasserstein_distance': 1.9823601997785294, 'R2_feature_means': 0.9306088772524677}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-59.4445 g_loss=-59.3505 | train mmd=0.0158 | test_mmd=0.4388\n",
      "[CellOT] epoch=100 f_loss=-39.5068 g_loss=-29.9210 | train mmd=0.0158 | test_mmd=0.4378\n",
      "[CellOT] epoch=150 f_loss=-19.9927 g_loss=-19.1312 | train mmd=0.0158 | test_mmd=0.3429\n",
      "[CellOT] epoch=200 f_loss=-4.8755 g_loss=-20.8747 | train mmd=0.0151 | test_mmd=0.1152\n",
      "[CellOT] epoch=250 f_loss=-1.5905 g_loss=-20.4845 | train mmd=0.0128 | test_mmd=0.0412\n",
      "[CellOT] epoch=300 f_loss=1.6804 g_loss=-16.4995 | train mmd=0.0101 | test_mmd=0.0179\n",
      "[CellOT] epoch=350 f_loss=-1.2833 g_loss=-14.9408 | train mmd=0.0088 | test_mmd=0.0155\n",
      "[CellOT] epoch=400 f_loss=3.0860 g_loss=-18.9709 | train mmd=0.0077 | test_mmd=0.0144\n",
      "[CellOT] epoch=450 f_loss=-1.8910 g_loss=-14.6707 | train mmd=0.0061 | test_mmd=0.0104\n",
      "[CellOT] epoch=500 f_loss=2.3013 g_loss=-18.0747 | train mmd=0.0054 | test_mmd=0.0100\n",
      "[CellOT] epoch=550 f_loss=3.4562 g_loss=-15.9699 | train mmd=0.0038 | test_mmd=0.0060\n",
      "[CellOT] epoch=600 f_loss=1.3183 g_loss=-17.3748 | train mmd=0.0054 | test_mmd=0.0140\n",
      "[CellOT] epoch=650 f_loss=-0.6902 g_loss=-17.2858 | train mmd=0.0043 | test_mmd=0.0076\n",
      "[CellOT] epoch=700 f_loss=-2.8092 g_loss=-15.8106 | train mmd=0.0044 | test_mmd=0.0111\n",
      "[CellOT] epoch=750 f_loss=-2.7357 g_loss=-15.7417 | train mmd=0.0040 | test_mmd=0.0093\n",
      "[CellOT] epoch=800 f_loss=3.8345 g_loss=-18.8104 | train mmd=0.0053 | test_mmd=0.0112\n",
      "[CellOT] epoch=850 f_loss=1.2948 g_loss=-13.3649 | train mmd=0.0045 | test_mmd=0.0074\n",
      "[CellOT] epoch=900 f_loss=3.7958 g_loss=-15.6669 | train mmd=0.0047 | test_mmd=0.0096\n",
      "[CellOT] epoch=950 f_loss=1.8837 g_loss=-15.7459 | train mmd=0.0042 | test_mmd=0.0064\n",
      "[CellOT] epoch=1000 f_loss=-1.6677 g_loss=-16.9127 | train mmd=0.0046 | test_mmd=0.0058\n",
      "[CellOT] Final CellOT MMD: 0.0042\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=-0.6416 g_loss=-27.2634 | train mmd=0.0413 | test_mmd=0.2257\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.005763628279538913, 'mmd2_gamma_0.5': 0.009438273002653666, 'mmd2_gamma_1.0': 0.007194545304111122, 'wasserstein_distance': 2.0146778754156096, 'R2_feature_means': 0.9719348253041002}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-62.7530 g_loss=-63.0157 | train mmd=0.0158 | test_mmd=0.4385\n",
      "[CellOT] epoch=100 f_loss=-33.3131 g_loss=-31.4989 | train mmd=0.0158 | test_mmd=0.4222\n",
      "[CellOT] epoch=150 f_loss=-12.9183 g_loss=-22.2974 | train mmd=0.0158 | test_mmd=0.3064\n",
      "[CellOT] epoch=200 f_loss=-8.0860 g_loss=-17.0635 | train mmd=0.0155 | test_mmd=0.1504\n",
      "[CellOT] epoch=250 f_loss=-6.3757 g_loss=-19.0636 | train mmd=0.0142 | test_mmd=0.0644\n",
      "[CellOT] epoch=300 f_loss=0.1884 g_loss=-17.8968 | train mmd=0.0116 | test_mmd=0.0278\n",
      "[CellOT] epoch=350 f_loss=1.8350 g_loss=-14.2737 | train mmd=0.0099 | test_mmd=0.0195\n",
      "[CellOT] epoch=400 f_loss=-1.7680 g_loss=-14.9610 | train mmd=0.0082 | test_mmd=0.0196\n",
      "[CellOT] epoch=450 f_loss=-1.3403 g_loss=-14.2656 | train mmd=0.0059 | test_mmd=0.0075\n",
      "[CellOT] epoch=500 f_loss=1.6440 g_loss=-13.6627 | train mmd=0.0062 | test_mmd=0.0130\n",
      "[CellOT] epoch=550 f_loss=-3.2048 g_loss=-15.5711 | train mmd=0.0049 | test_mmd=0.0092\n",
      "[CellOT] epoch=600 f_loss=-0.8477 g_loss=-16.5187 | train mmd=0.0049 | test_mmd=0.0085\n",
      "[CellOT] epoch=650 f_loss=-2.1484 g_loss=-14.9927 | train mmd=0.0046 | test_mmd=0.0086\n",
      "[CellOT] epoch=700 f_loss=-2.7192 g_loss=-16.0749 | train mmd=0.0035 | test_mmd=0.0059\n",
      "[CellOT] epoch=750 f_loss=0.2145 g_loss=-14.9360 | train mmd=0.0036 | test_mmd=0.0106\n",
      "[CellOT] epoch=800 f_loss=-2.4422 g_loss=-13.8615 | train mmd=0.0040 | test_mmd=0.0073\n",
      "[CellOT] epoch=850 f_loss=0.2486 g_loss=-16.5732 | train mmd=0.0042 | test_mmd=0.0068\n",
      "[CellOT] epoch=900 f_loss=-0.6012 g_loss=-15.8555 | train mmd=0.0033 | test_mmd=0.0060\n",
      "[CellOT] epoch=950 f_loss=0.4830 g_loss=-13.7984 | train mmd=0.0038 | test_mmd=0.0083\n",
      "[CellOT] epoch=1000 f_loss=0.2864 g_loss=-15.9143 | train mmd=0.0035 | test_mmd=0.0045\n",
      "[CellOT] Final CellOT MMD: 0.0036\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=4.7748 g_loss=-27.9165 | train mmd=0.0364 | test_mmd=0.3873\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.004535904286233072, 'mmd2_gamma_0.5': 0.007900803763534053, 'mmd2_gamma_1.0': 0.00647333610497269, 'wasserstein_distance': 1.8592769433603187, 'R2_feature_means': 0.978431366907745}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-74.4212 g_loss=-55.3362 | train mmd=0.0158 | test_mmd=0.4390\n",
      "[CellOT] epoch=100 f_loss=-36.8646 g_loss=-24.8581 | train mmd=0.0158 | test_mmd=0.4197\n",
      "[CellOT] epoch=150 f_loss=-14.4979 g_loss=-18.2376 | train mmd=0.0157 | test_mmd=0.2174\n",
      "[CellOT] epoch=200 f_loss=-6.5415 g_loss=-19.1674 | train mmd=0.0148 | test_mmd=0.0946\n",
      "[CellOT] epoch=250 f_loss=-5.1331 g_loss=-18.3846 | train mmd=0.0121 | test_mmd=0.0375\n",
      "[CellOT] epoch=300 f_loss=-0.7682 g_loss=-19.9005 | train mmd=0.0100 | test_mmd=0.0202\n",
      "[CellOT] epoch=350 f_loss=0.9027 g_loss=-19.8831 | train mmd=0.0087 | test_mmd=0.0178\n",
      "[CellOT] epoch=400 f_loss=-2.0828 g_loss=-16.0914 | train mmd=0.0075 | test_mmd=0.0177\n",
      "[CellOT] epoch=450 f_loss=-4.7772 g_loss=-14.6313 | train mmd=0.0065 | test_mmd=0.0112\n",
      "[CellOT] epoch=500 f_loss=0.9590 g_loss=-14.6401 | train mmd=0.0054 | test_mmd=0.0121\n",
      "[CellOT] epoch=550 f_loss=-0.3104 g_loss=-14.9529 | train mmd=0.0050 | test_mmd=0.0083\n",
      "[CellOT] epoch=600 f_loss=0.8534 g_loss=-14.7478 | train mmd=0.0054 | test_mmd=0.0133\n",
      "[CellOT] epoch=650 f_loss=2.6526 g_loss=-15.9283 | train mmd=0.0054 | test_mmd=0.0121\n",
      "[CellOT] epoch=700 f_loss=-3.5863 g_loss=-15.3251 | train mmd=0.0045 | test_mmd=0.0094\n",
      "[CellOT] epoch=750 f_loss=2.0754 g_loss=-14.4436 | train mmd=0.0047 | test_mmd=0.0090\n",
      "[CellOT] epoch=800 f_loss=0.1063 g_loss=-13.2418 | train mmd=0.0038 | test_mmd=0.0058\n",
      "[CellOT] epoch=850 f_loss=-1.4055 g_loss=-15.6177 | train mmd=0.0035 | test_mmd=0.0080\n",
      "[CellOT] epoch=900 f_loss=-0.5577 g_loss=-14.3364 | train mmd=0.0044 | test_mmd=0.0104\n",
      "[CellOT] epoch=950 f_loss=-3.3901 g_loss=-15.1741 | train mmd=0.0053 | test_mmd=0.0074\n",
      "[CellOT] epoch=1000 f_loss=-1.6103 g_loss=-15.1093 | train mmd=0.0043 | test_mmd=0.0065\n",
      "[CellOT] Final CellOT MMD: 0.0045\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=5.4304 g_loss=-26.7777 | train mmd=0.0362 | test_mmd=0.2927\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.006509312330936989, 'mmd2_gamma_0.5': 0.010277457344981589, 'mmd2_gamma_1.0': 0.007344298633061248, 'wasserstein_distance': 2.0480208253592056, 'R2_feature_means': 0.9683554598315196}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-75.9789 g_loss=-50.6127 | train mmd=0.0158 | test_mmd=0.4386\n",
      "[CellOT] epoch=100 f_loss=-41.7467 g_loss=-32.3861 | train mmd=0.0158 | test_mmd=0.4348\n",
      "[CellOT] epoch=150 f_loss=-21.4963 g_loss=-18.0300 | train mmd=0.0158 | test_mmd=0.3089\n",
      "[CellOT] epoch=200 f_loss=-5.1158 g_loss=-17.9538 | train mmd=0.0154 | test_mmd=0.1331\n",
      "[CellOT] epoch=250 f_loss=-1.3775 g_loss=-15.5897 | train mmd=0.0138 | test_mmd=0.0570\n",
      "[CellOT] epoch=300 f_loss=-0.8550 g_loss=-16.2738 | train mmd=0.0110 | test_mmd=0.0282\n",
      "[CellOT] epoch=350 f_loss=-2.3162 g_loss=-15.3213 | train mmd=0.0081 | test_mmd=0.0160\n",
      "[CellOT] epoch=400 f_loss=-2.4496 g_loss=-15.0551 | train mmd=0.0068 | test_mmd=0.0168\n",
      "[CellOT] epoch=450 f_loss=-1.2513 g_loss=-14.9367 | train mmd=0.0059 | test_mmd=0.0098\n",
      "[CellOT] epoch=500 f_loss=-2.8113 g_loss=-16.0000 | train mmd=0.0052 | test_mmd=0.0088\n",
      "[CellOT] epoch=550 f_loss=-1.9058 g_loss=-13.4394 | train mmd=0.0056 | test_mmd=0.0089\n",
      "[CellOT] epoch=600 f_loss=-2.6369 g_loss=-14.6485 | train mmd=0.0054 | test_mmd=0.0077\n",
      "[CellOT] epoch=650 f_loss=-0.4532 g_loss=-15.4797 | train mmd=0.0053 | test_mmd=0.0089\n",
      "[CellOT] epoch=700 f_loss=-0.1870 g_loss=-15.0647 | train mmd=0.0047 | test_mmd=0.0127\n",
      "[CellOT] epoch=750 f_loss=0.1670 g_loss=-16.3312 | train mmd=0.0043 | test_mmd=0.0088\n",
      "[CellOT] epoch=800 f_loss=-3.0905 g_loss=-15.8472 | train mmd=0.0039 | test_mmd=0.0096\n",
      "[CellOT] epoch=850 f_loss=2.1008 g_loss=-18.9040 | train mmd=0.0047 | test_mmd=0.0053\n",
      "[CellOT] epoch=900 f_loss=0.7536 g_loss=-15.4491 | train mmd=0.0045 | test_mmd=0.0056\n",
      "[CellOT] epoch=950 f_loss=0.6865 g_loss=-13.6156 | train mmd=0.0039 | test_mmd=0.0104\n",
      "[CellOT] epoch=1000 f_loss=-0.1269 g_loss=-17.9936 | train mmd=0.0064 | test_mmd=0.0096\n",
      "[CellOT] Final CellOT MMD: 0.0059\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.009634206757025865, 'mmd2_gamma_0.5': 0.013276378687518714, 'mmd2_gamma_1.0': 0.009058465632131866, 'wasserstein_distance': 1.9258156209405521, 'R2_feature_means': 0.9585975892489145}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=2.9062 g_loss=-23.2155 | train mmd=0.0284 | test_mmd=0.2410\n",
      "[CellOT] epoch=50 f_loss=-57.5840 g_loss=-47.6582 | train mmd=0.0158 | test_mmd=0.4387\n",
      "[CellOT] epoch=100 f_loss=-23.4487 g_loss=-32.9564 | train mmd=0.0158 | test_mmd=0.4059\n",
      "[CellOT] epoch=150 f_loss=-18.8588 g_loss=-17.3377 | train mmd=0.0158 | test_mmd=0.2894\n",
      "[CellOT] epoch=200 f_loss=-5.4061 g_loss=-16.9042 | train mmd=0.0147 | test_mmd=0.0876\n",
      "[CellOT] epoch=250 f_loss=-2.2387 g_loss=-17.0153 | train mmd=0.0123 | test_mmd=0.0400\n",
      "[CellOT] epoch=300 f_loss=-0.7880 g_loss=-14.7230 | train mmd=0.0103 | test_mmd=0.0212\n",
      "[CellOT] epoch=350 f_loss=-5.0200 g_loss=-18.4129 | train mmd=0.0091 | test_mmd=0.0188\n",
      "[CellOT] epoch=400 f_loss=-0.4540 g_loss=-15.6861 | train mmd=0.0081 | test_mmd=0.0138\n",
      "[CellOT] epoch=450 f_loss=-3.2333 g_loss=-14.5247 | train mmd=0.0070 | test_mmd=0.0122\n",
      "[CellOT] epoch=500 f_loss=-2.4793 g_loss=-15.3783 | train mmd=0.0060 | test_mmd=0.0102\n",
      "[CellOT] epoch=550 f_loss=1.0788 g_loss=-16.0961 | train mmd=0.0064 | test_mmd=0.0148\n",
      "[CellOT] epoch=600 f_loss=0.4044 g_loss=-14.1797 | train mmd=0.0053 | test_mmd=0.0111\n",
      "[CellOT] epoch=650 f_loss=3.9564 g_loss=-15.5779 | train mmd=0.0039 | test_mmd=0.0084\n",
      "[CellOT] epoch=700 f_loss=-0.6709 g_loss=-15.0453 | train mmd=0.0037 | test_mmd=0.0075\n",
      "[CellOT] epoch=750 f_loss=-1.7620 g_loss=-16.5648 | train mmd=0.0039 | test_mmd=0.0084\n",
      "[CellOT] epoch=800 f_loss=-0.3234 g_loss=-16.0049 | train mmd=0.0032 | test_mmd=0.0049\n",
      "[CellOT] epoch=850 f_loss=-2.8910 g_loss=-13.8884 | train mmd=0.0044 | test_mmd=0.0066\n",
      "[CellOT] epoch=900 f_loss=-1.1693 g_loss=-15.1294 | train mmd=0.0036 | test_mmd=0.0077\n",
      "[CellOT] epoch=950 f_loss=0.0303 g_loss=-13.9821 | train mmd=0.0037 | test_mmd=0.0085\n",
      "[CellOT] epoch=1000 f_loss=0.5057 g_loss=-16.0679 | train mmd=0.0037 | test_mmd=0.0075\n",
      "[CellOT] Final CellOT MMD: 0.0048\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.007477101213095971, 'mmd2_gamma_0.5': 0.00890480342141274, 'mmd2_gamma_1.0': 0.006841671649598504, 'wasserstein_distance': 1.8965507470744036, 'R2_feature_means': 0.922460899127793}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=5.7488 g_loss=-27.9354 | train mmd=0.0363 | test_mmd=0.2557\n",
      "[CellOT] epoch=50 f_loss=-57.3141 g_loss=-49.7914 | train mmd=0.0158 | test_mmd=0.4378\n",
      "[CellOT] epoch=100 f_loss=-36.4583 g_loss=-31.9502 | train mmd=0.0158 | test_mmd=0.4308\n",
      "[CellOT] epoch=150 f_loss=-14.3496 g_loss=-23.8388 | train mmd=0.0157 | test_mmd=0.2512\n",
      "[CellOT] epoch=200 f_loss=-4.3763 g_loss=-17.1562 | train mmd=0.0146 | test_mmd=0.0835\n",
      "[CellOT] epoch=250 f_loss=-2.7956 g_loss=-20.5489 | train mmd=0.0128 | test_mmd=0.0437\n",
      "[CellOT] epoch=300 f_loss=-7.0180 g_loss=-19.3343 | train mmd=0.0110 | test_mmd=0.0270\n",
      "[CellOT] epoch=350 f_loss=-2.1532 g_loss=-16.5294 | train mmd=0.0089 | test_mmd=0.0170\n",
      "[CellOT] epoch=400 f_loss=0.3093 g_loss=-19.1766 | train mmd=0.0075 | test_mmd=0.0113\n",
      "[CellOT] epoch=450 f_loss=-1.9641 g_loss=-17.1378 | train mmd=0.0060 | test_mmd=0.0118\n",
      "[CellOT] epoch=500 f_loss=-1.5750 g_loss=-18.2586 | train mmd=0.0056 | test_mmd=0.0068\n",
      "[CellOT] epoch=550 f_loss=1.0076 g_loss=-15.9660 | train mmd=0.0050 | test_mmd=0.0092\n",
      "[CellOT] epoch=600 f_loss=-2.2636 g_loss=-16.3031 | train mmd=0.0048 | test_mmd=0.0118\n",
      "[CellOT] epoch=650 f_loss=-1.1788 g_loss=-14.2892 | train mmd=0.0045 | test_mmd=0.0052\n",
      "[CellOT] epoch=700 f_loss=-0.9869 g_loss=-14.3426 | train mmd=0.0042 | test_mmd=0.0075\n",
      "[CellOT] epoch=750 f_loss=2.7300 g_loss=-18.7742 | train mmd=0.0049 | test_mmd=0.0114\n",
      "[CellOT] epoch=800 f_loss=-1.7135 g_loss=-14.9874 | train mmd=0.0056 | test_mmd=0.0068\n",
      "[CellOT] epoch=850 f_loss=1.4425 g_loss=-15.5218 | train mmd=0.0046 | test_mmd=0.0057\n",
      "[CellOT] epoch=900 f_loss=2.8659 g_loss=-19.0216 | train mmd=0.0044 | test_mmd=0.0058\n",
      "[CellOT] epoch=950 f_loss=-2.0886 g_loss=-17.9973 | train mmd=0.0040 | test_mmd=0.0052\n",
      "[CellOT] epoch=1000 f_loss=-1.5986 g_loss=-15.6570 | train mmd=0.0050 | test_mmd=0.0086\n",
      "[CellOT] Final CellOT MMD: 0.0054\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=4.7907 g_loss=-25.6053 | train mmd=0.0333 | test_mmd=0.2136\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.00864291085733282, 'mmd2_gamma_0.5': 0.011805588422069899, 'mmd2_gamma_1.0': 0.00805695845114919, 'wasserstein_distance': 1.8564328331755346, 'R2_feature_means': 0.955255126201127}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-62.7701 g_loss=-60.3537 | train mmd=0.0158 | test_mmd=0.4390\n",
      "[CellOT] epoch=100 f_loss=-34.3335 g_loss=-27.7905 | train mmd=0.0158 | test_mmd=0.4199\n",
      "[CellOT] epoch=150 f_loss=-22.1158 g_loss=-20.0770 | train mmd=0.0158 | test_mmd=0.3148\n",
      "[CellOT] epoch=200 f_loss=-5.8685 g_loss=-20.6087 | train mmd=0.0146 | test_mmd=0.0856\n",
      "[CellOT] epoch=250 f_loss=-2.6253 g_loss=-18.7626 | train mmd=0.0121 | test_mmd=0.0431\n",
      "[CellOT] epoch=300 f_loss=-0.0606 g_loss=-15.5406 | train mmd=0.0098 | test_mmd=0.0203\n",
      "[CellOT] epoch=350 f_loss=0.5888 g_loss=-15.9716 | train mmd=0.0077 | test_mmd=0.0148\n",
      "[CellOT] epoch=400 f_loss=-0.4083 g_loss=-17.1282 | train mmd=0.0062 | test_mmd=0.0120\n",
      "[CellOT] epoch=450 f_loss=-5.2857 g_loss=-16.0633 | train mmd=0.0058 | test_mmd=0.0140\n",
      "[CellOT] epoch=500 f_loss=-2.8852 g_loss=-15.3591 | train mmd=0.0047 | test_mmd=0.0087\n",
      "[CellOT] epoch=550 f_loss=1.5337 g_loss=-16.1150 | train mmd=0.0042 | test_mmd=0.0087\n",
      "[CellOT] epoch=600 f_loss=-2.4819 g_loss=-15.8847 | train mmd=0.0048 | test_mmd=0.0095\n",
      "[CellOT] epoch=650 f_loss=-1.3830 g_loss=-14.4657 | train mmd=0.0046 | test_mmd=0.0058\n",
      "[CellOT] epoch=700 f_loss=-0.6076 g_loss=-14.6453 | train mmd=0.0056 | test_mmd=0.0110\n",
      "[CellOT] epoch=750 f_loss=-5.1649 g_loss=-15.2306 | train mmd=0.0043 | test_mmd=0.0072\n",
      "[CellOT] epoch=800 f_loss=0.6414 g_loss=-16.7726 | train mmd=0.0046 | test_mmd=0.0092\n",
      "[CellOT] epoch=850 f_loss=-1.2146 g_loss=-13.7942 | train mmd=0.0044 | test_mmd=0.0067\n",
      "[CellOT] epoch=900 f_loss=-0.3347 g_loss=-13.4688 | train mmd=0.0053 | test_mmd=0.0111\n",
      "[CellOT] epoch=950 f_loss=-0.9340 g_loss=-15.0825 | train mmd=0.0041 | test_mmd=0.0076\n",
      "[CellOT] epoch=1000 f_loss=0.3163 g_loss=-12.7357 | train mmd=0.0052 | test_mmd=0.0081\n",
      "[CellOT] Final CellOT MMD: 0.0053\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=6.1976 g_loss=-25.9318 | train mmd=0.0302 | test_mmd=0.2640\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.008144609830836425, 'mmd2_gamma_0.5': 0.012023827775998114, 'mmd2_gamma_1.0': 0.008220668540919792, 'wasserstein_distance': 1.8779459635621891, 'R2_feature_means': 0.9631142487249358}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-61.8323 g_loss=-52.9836 | train mmd=0.0158 | test_mmd=0.4380\n",
      "[CellOT] epoch=100 f_loss=-29.8699 g_loss=-25.3736 | train mmd=0.0158 | test_mmd=0.4148\n",
      "[CellOT] epoch=150 f_loss=-12.9723 g_loss=-22.6137 | train mmd=0.0158 | test_mmd=0.2219\n",
      "[CellOT] epoch=200 f_loss=-3.9369 g_loss=-23.0650 | train mmd=0.0148 | test_mmd=0.0799\n",
      "[CellOT] epoch=250 f_loss=-6.7002 g_loss=-17.5007 | train mmd=0.0126 | test_mmd=0.0402\n",
      "[CellOT] epoch=300 f_loss=-4.1365 g_loss=-16.8006 | train mmd=0.0101 | test_mmd=0.0192\n",
      "[CellOT] epoch=350 f_loss=1.8947 g_loss=-19.2808 | train mmd=0.0091 | test_mmd=0.0184\n",
      "[CellOT] epoch=400 f_loss=-0.1917 g_loss=-17.2448 | train mmd=0.0078 | test_mmd=0.0135\n",
      "[CellOT] epoch=450 f_loss=0.9770 g_loss=-16.3620 | train mmd=0.0092 | test_mmd=0.0212\n",
      "[CellOT] epoch=500 f_loss=1.4848 g_loss=-19.1056 | train mmd=0.0066 | test_mmd=0.0144\n",
      "[CellOT] epoch=550 f_loss=-1.5436 g_loss=-15.9493 | train mmd=0.0052 | test_mmd=0.0073\n",
      "[CellOT] epoch=600 f_loss=-2.2143 g_loss=-15.2660 | train mmd=0.0050 | test_mmd=0.0091\n",
      "[CellOT] epoch=650 f_loss=1.7541 g_loss=-18.2624 | train mmd=0.0049 | test_mmd=0.0108\n",
      "[CellOT] epoch=700 f_loss=0.0185 g_loss=-16.7093 | train mmd=0.0055 | test_mmd=0.0073\n",
      "[CellOT] epoch=750 f_loss=-0.3066 g_loss=-17.4528 | train mmd=0.0043 | test_mmd=0.0090\n",
      "[CellOT] epoch=800 f_loss=0.0871 g_loss=-15.5814 | train mmd=0.0036 | test_mmd=0.0088\n",
      "[CellOT] epoch=850 f_loss=-1.2407 g_loss=-15.6954 | train mmd=0.0036 | test_mmd=0.0103\n",
      "[CellOT] epoch=900 f_loss=0.9275 g_loss=-17.3988 | train mmd=0.0058 | test_mmd=0.0086\n",
      "[CellOT] epoch=950 f_loss=-0.1479 g_loss=-16.6173 | train mmd=0.0043 | test_mmd=0.0063\n",
      "[CellOT] epoch=1000 f_loss=-3.0823 g_loss=-18.5948 | train mmd=0.0041 | test_mmd=0.0076\n",
      "[CellOT] Final CellOT MMD: 0.0046\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.007599399158209508, 'mmd2_gamma_0.5': 0.009228337412555729, 'mmd2_gamma_1.0': 0.006942665991114615, 'wasserstein_distance': 1.963102149620601, 'R2_feature_means': 0.9740436406953892}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0076  0.0016\n",
      "mmd2_gamma_0.5        0.0105  0.0017\n",
      "mmd2_gamma_1.0        0.0076  0.0008\n",
      "wasserstein_distance  1.9640  0.1102\n",
      "R2_feature_means      0.9577  0.0184\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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wwRJFCgrtIMg0BkTEYDFde2MKxKweUsBeHjZC/z4kU7+3DyH3zedwJqOKtRED4aWwdBVZFcRpmkitjyLUzYJRpIo3nJStkq8Ph+nnvk5vnLJPGxuP2GpGkdBJV+++FTKj/88T+8uQ9ezlLuySE4//3ipLWcOCqx/gqZl/0nzittoWvafBNY/MeQZvLu1g+5IEkkScdpkJEmkO5Lk3a0dOXmzZdOmT4WZ6VO5Yxir4+pg8R//8R888sgj/PWvf2XcuHH86le/YuHChezYsYOiog9XEjfddBO/+93vqKio4Pvf/z7nnnsu27ZtQ1EUrr32WrLZLC+99BJut5stW7bg8XiAPkFz+umnc80113DHHXeQSqX43ve+x6WXXsrzzz+fu/5f//pXvvnNb/Lqq68CsGPHDi655BLi8XjuWitXriSZTHLBBRcAcNttt/G///u/3HPPPUycOJGXXnqJ/+//+/8oLS1l3rx57NmzhwsvvJBrr72Wr33ta6xbt45/+7d/G/V5vPXWW5SVlXH//fezaNGivPj6HTt28Mgjj/Doo4/m3r/kkktwOp2sWLGCgoIC7r33Xs444wy2bdtGUVER8Xics846i5/97GfY7XYefPBBzj33XLZu3UpdXR2PPvoos2bN4mtf+xpf/epXc/dqampi0aJF3HrrrfzlL3+hu7ub6667juuuu477778f6LPvt7e3s2bNGhRF4frrr89lE4/E3XffzY033sgvfvELFi9eTG9vb+6Zj2U+o9HR0cHll1/Or371Ky644AJisRgvv/wypmmOet6hxllSz8Q5C3Bv+oBYVkYzBRBkECR8Pg+lHjCyCQw1A4JA+6v3I9lcLKg/nzWVhaiaQZnfRTKt4bEZnFe9mwnuUC5iyFlST1NriIee3YZhGFQVSIRTTp4NH8WkwihVRg96JomWCKEUVFBpS3Hp3FKWro2ya3crihbhhNIA77+8hYlzFnDHjYvzci5e29iC7gxRVagg2+z4ZCctXRHe3drBnl1NpN9+nGp3n09DTYbyHOhDME0Q9v4LxFrepWnXM6za6WFFazWqXIivsGhISO8niU+dYkgFm/McV/v8kj8iiUSCu+++mwceeIDFixcDcN999/Hss8/yP//zP9x00025Y3/84x/z2c9+FugT4jU1NTz22GNceumltLS0cNFFFzFjxgwAxo8fnzvvD3/4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r32t6rMvfOEL5h133HGCVnTkAOajjz5a/m/DMMyWlhbzv//3/17+LBaLmXa73fzlL395Ala4cCafWy22bdtmAmZfX9/xWdRRYrpzGxgYMNvb2829e/eaixYtMv/X//pfC/r+k3rHMJl4PA5AIBA4wSs5Otx9991s2rSJjRs3nuilHDUef/xx1q9fz2233UYwGOScc87hxz/+8Yle1lHh4osv5sUXX+STTz4B4P333+f111/nhhtuOMErO3r09PQwMjJS9UzW1dVxwQUX8NZbb53AlR0b4vE4giDg9/tP9FKOGMMwuPPOO/nTP/1TzjrrrCP6ruPeXXWhGIbBN77xDS655BJWr159opdzxDzwwAPs3LmTd99990Qv5ajy6aefcs899/DNb36Tv/iLv+Ddd9/lj//4j7HZbHz1q1890cs7Iv7sz/6MRCLBqlWrkCQJXdf567/+a+64444TvbSjxsjICADNzc1Vnzc3N5f/drqQy+X41re+xW/+5m+eFh1Xv/e97yHLMn/8x398xN91yiiGu+++m7179/L666+f6KUcMYcOHeLrX/86zz//PA6H40Qv56hiGAbr16/nb/7mbwA455xz2Lt3Lz/84Q9PecXw4IMP8vOf/5xf/OIXnHXWWezatYtvfOMbtLW1nfLn9llDVVVuv/12TNPknnvuOdHLOWJ27NjBP/zDP7Bz5845z7mZiVPClfSHf/iHPPnkk7z88ssLnuVwMrFjxw5CoRDnnnsusiwjyzJbt27lH//xH5FlGV3XT/QSF0xraytnnnlm1WdnnHEG/f39J2hFR48//dM/5c/+7M/40pe+xJo1a7jzzjv5kz/5E7773e+e6KUdNVpaWgAYHR2t+nx0dLT8t1OdklLo6+vj+eefPy12C6+99hqhUIiurq6yTOnr6+M//af/RHd397y/76TeMZimyR/90R/x6KOP8sorr7B48eITvaSjwtVXX82ePXuqPrvrrrtYtWoV3/rWt5Ak6QSt7Mi55JJLpqQUf/LJJyxatOgErejokclkpky+kiQJwzBO0IqOPosXL6alpYUXX3yRdevWAcUJYe+88w6///u/f2IXdxQoKYX9+/fz8ssv09DQcKKXdFS48847p8Qqr7vuOu68807uuuuueX/fSa0Y7r77bn7xi1/w2GOP4fV6yz7Ouro6nE7nCV7dwvF6vVPiJG63m4aGhlM+fvInf/InXHzxxfzN3/wNt99+O9u2bePee+/l3nvvPdFLO2Juuukm/vqv/5quri7OOuss3nvvPf7+7/+er33tayd6afMilUpx4MCB8n/39PSwa9cuAoEAXV1dfOMb3+A73/kOy5cvZ/HixXz729+mra2NzZs3n7hFz5GZzq21tZVbb72VnTt38uSTT6LrelmmBAIBbDbbiVr2nJjtvk1Wcoqi0NLSwsqVK+f/Y0eSMnWsAWr+77777jvRSzvqnC7pqqZpmk888YS5evVq0263m6tWrTLvvffeE72ko0IikTC//vWvm11dXabD4TCXLFli/uf//J/NfD5/opc2L15++eWa79VXv/pV0zSLKavf/va3zebmZtNut5tXX321uW/fvhO76Dky07n19PRMK1NefvnlE730WZntvk3mSNJVrXkMFhYWFhZVnBLBZwsLCwuL44elGCwsLCwsqrAUg4WFhYVFFZZisLCwsLCowlIMFhYWFhZVWIrBwsLCwqIKSzFYWFhYWFRhKQYLCwsLiyosxWBhYWFhUYWlGCwsLCwsqrAUg4WFhYVFFf8fnUkj1cosMSkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"trametinib\"\n",
    "X_pre = adata_4i[adata_4i.obs[\"drug\"] == \"control\"].copy().to_df()[features_4i]\n",
    "X_post  = adata_4i[adata_4i.obs[\"drug\"] == drug].copy().to_df()[features_4i]\n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "X_tr_pre, X_te_pre, Y_tr_post, Y_te_post = split_train_test(X_pre.values, X_post.values, 0.8)\n",
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "# Compute median heuristic gamma on training data\n",
    "median_gamma = median_heuristic_gamma(X_tr_pre, Y_tr_post)\n",
    "print(\"Median heuristic gamma:\", median_gamma)\n",
    "\n",
    "\n",
    "all_metrics = []\n",
    "for run in range(10):\n",
    "    print(f\"**************** Run: {run} ****************\")\n",
    "    seed = 1234 + run\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "\n",
    "    out = run_cellot_pair(X_tr_pre, Y_tr_post, X_te_pre, Y_te_post, n_epochs=1000)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post, median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post\n",
    "target = Y_te_post\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#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": null,
   "id": "31734785",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9747cc38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "5056be31",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (10995, 48)\n",
      "X_post cells: (2631, 48)\n",
      "(2104, 48)\n",
      "(527, 48)\n",
      "(2104, 48)\n",
      "(527, 48)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=4.8688 g_loss=-24.2287 | train mmd=0.0125 | test_mmd=0.1206\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.05748945574198288\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-38.5015 g_loss=-47.4504 | train mmd=0.0076 | test_mmd=0.3673\n",
      "[CellOT] epoch=100 f_loss=-21.1453 g_loss=-32.8385 | train mmd=0.0076 | test_mmd=0.3193\n",
      "[CellOT] epoch=150 f_loss=-5.6375 g_loss=-23.6190 | train mmd=0.0076 | test_mmd=0.1641\n",
      "[CellOT] epoch=200 f_loss=0.4531 g_loss=-19.9940 | train mmd=0.0067 | test_mmd=0.0395\n",
      "[CellOT] epoch=250 f_loss=-2.6327 g_loss=-24.1723 | train mmd=0.0063 | test_mmd=0.0230\n",
      "[CellOT] epoch=300 f_loss=-6.2283 g_loss=-21.5640 | train mmd=0.0059 | test_mmd=0.0173\n",
      "[CellOT] epoch=350 f_loss=-3.1856 g_loss=-17.9153 | train mmd=0.0059 | test_mmd=0.0189\n",
      "[CellOT] epoch=400 f_loss=-2.8536 g_loss=-18.6189 | train mmd=0.0049 | test_mmd=0.0133\n",
      "[CellOT] epoch=450 f_loss=-1.9457 g_loss=-18.8383 | train mmd=0.0046 | test_mmd=0.0083\n",
      "[CellOT] epoch=500 f_loss=-3.4331 g_loss=-21.8376 | train mmd=0.0046 | test_mmd=0.0129\n",
      "[CellOT] epoch=550 f_loss=0.4733 g_loss=-18.4269 | train mmd=0.0036 | test_mmd=0.0096\n",
      "[CellOT] epoch=600 f_loss=-3.7478 g_loss=-19.9846 | train mmd=0.0035 | test_mmd=0.0084\n",
      "[CellOT] epoch=650 f_loss=-5.8075 g_loss=-15.7238 | train mmd=0.0037 | test_mmd=0.0102\n",
      "[CellOT] epoch=700 f_loss=1.5241 g_loss=-21.2868 | train mmd=0.0038 | test_mmd=0.0073\n",
      "[CellOT] epoch=750 f_loss=-0.2774 g_loss=-16.2243 | train mmd=0.0034 | test_mmd=0.0067\n",
      "[CellOT] epoch=800 f_loss=-1.0588 g_loss=-19.4978 | train mmd=0.0036 | test_mmd=0.0087\n",
      "[CellOT] epoch=850 f_loss=-0.7220 g_loss=-17.9940 | train mmd=0.0030 | test_mmd=0.0075\n",
      "[CellOT] epoch=900 f_loss=1.8765 g_loss=-19.3519 | train mmd=0.0026 | test_mmd=0.0052\n",
      "[CellOT] epoch=950 f_loss=-0.1130 g_loss=-18.3340 | train mmd=0.0029 | test_mmd=0.0068\n",
      "[CellOT] epoch=1000 f_loss=-0.3912 g_loss=-17.2141 | train mmd=0.0037 | test_mmd=0.0094\n",
      "[CellOT] Final CellOT MMD: 0.0059\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.009413500346489578, 'mmd2_gamma_0.5': 0.010724426211362673, 'mmd2_gamma_1.0': 0.006506324849323338, 'wasserstein_distance': 2.135676376521827, 'R2_feature_means': 0.9514483128676121}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=6.6818 g_loss=-24.1162 | train mmd=0.0182 | test_mmd=0.3723\n",
      "[CellOT] epoch=50 f_loss=-47.8036 g_loss=-50.1871 | train mmd=0.0076 | test_mmd=0.3734\n",
      "[CellOT] epoch=100 f_loss=-22.7268 g_loss=-30.5348 | train mmd=0.0076 | test_mmd=0.3332\n",
      "[CellOT] epoch=150 f_loss=-8.3992 g_loss=-27.8571 | train mmd=0.0076 | test_mmd=0.2096\n",
      "[CellOT] epoch=200 f_loss=-7.0949 g_loss=-22.2740 | train mmd=0.0072 | test_mmd=0.0704\n",
      "[CellOT] epoch=250 f_loss=-2.4357 g_loss=-18.6700 | train mmd=0.0068 | test_mmd=0.0395\n",
      "[CellOT] epoch=300 f_loss=-2.3662 g_loss=-17.7995 | train mmd=0.0062 | test_mmd=0.0277\n",
      "[CellOT] epoch=350 f_loss=2.8592 g_loss=-22.4996 | train mmd=0.0057 | test_mmd=0.0224\n",
      "[CellOT] epoch=400 f_loss=-0.6075 g_loss=-20.5016 | train mmd=0.0054 | test_mmd=0.0152\n",
      "[CellOT] epoch=450 f_loss=0.3771 g_loss=-17.2770 | train mmd=0.0051 | test_mmd=0.0150\n",
      "[CellOT] epoch=500 f_loss=-1.3785 g_loss=-16.8191 | train mmd=0.0046 | test_mmd=0.0086\n",
      "[CellOT] epoch=550 f_loss=-6.6960 g_loss=-20.3402 | train mmd=0.0045 | test_mmd=0.0080\n",
      "[CellOT] epoch=600 f_loss=-2.5002 g_loss=-20.2451 | train mmd=0.0044 | test_mmd=0.0108\n",
      "[CellOT] epoch=650 f_loss=2.7268 g_loss=-18.3729 | train mmd=0.0043 | test_mmd=0.0093\n",
      "[CellOT] epoch=700 f_loss=-1.2487 g_loss=-17.6373 | train mmd=0.0040 | test_mmd=0.0094\n",
      "[CellOT] epoch=750 f_loss=1.1087 g_loss=-18.9836 | train mmd=0.0037 | test_mmd=0.0079\n",
      "[CellOT] epoch=800 f_loss=-1.1733 g_loss=-17.7943 | train mmd=0.0037 | test_mmd=0.0083\n",
      "[CellOT] epoch=850 f_loss=-0.5067 g_loss=-16.5698 | train mmd=0.0043 | test_mmd=0.0086\n",
      "[CellOT] epoch=900 f_loss=1.8567 g_loss=-19.3508 | train mmd=0.0036 | test_mmd=0.0060\n",
      "[CellOT] epoch=950 f_loss=0.1299 g_loss=-19.2758 | train mmd=0.0036 | test_mmd=0.0079\n",
      "[CellOT] epoch=1000 f_loss=-7.5658 g_loss=-20.3439 | train mmd=0.0042 | test_mmd=0.0081\n",
      "[CellOT] Final CellOT MMD: 0.0059\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=5.8267 g_loss=-19.3172 | train mmd=0.0228 | test_mmd=0.1903\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.008110158649315524, 'mmd2_gamma_0.5': 0.012405421844432683, 'mmd2_gamma_1.0': 0.007189070208239071, 'wasserstein_distance': 2.1323766767185695, 'R2_feature_means': 0.9715598615883252}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-44.0779 g_loss=-51.3911 | train mmd=0.0076 | test_mmd=0.3754\n",
      "[CellOT] epoch=100 f_loss=-22.9608 g_loss=-27.8825 | train mmd=0.0076 | test_mmd=0.3462\n",
      "[CellOT] epoch=150 f_loss=-6.5113 g_loss=-31.7748 | train mmd=0.0076 | test_mmd=0.3160\n",
      "[CellOT] epoch=200 f_loss=-7.2250 g_loss=-20.4205 | train mmd=0.0075 | test_mmd=0.0824\n",
      "[CellOT] epoch=250 f_loss=-1.6339 g_loss=-21.9560 | train mmd=0.0071 | test_mmd=0.0517\n",
      "[CellOT] epoch=300 f_loss=-5.3288 g_loss=-19.2703 | train mmd=0.0059 | test_mmd=0.0186\n",
      "[CellOT] epoch=350 f_loss=-1.1994 g_loss=-20.7216 | train mmd=0.0053 | test_mmd=0.0141\n",
      "[CellOT] epoch=400 f_loss=-4.1191 g_loss=-19.9737 | train mmd=0.0047 | test_mmd=0.0109\n",
      "[CellOT] epoch=450 f_loss=-3.0656 g_loss=-19.4212 | train mmd=0.0045 | test_mmd=0.0123\n",
      "[CellOT] epoch=500 f_loss=-1.9068 g_loss=-19.5735 | train mmd=0.0036 | test_mmd=0.0077\n",
      "[CellOT] epoch=550 f_loss=-2.1944 g_loss=-21.8902 | train mmd=0.0039 | test_mmd=0.0090\n",
      "[CellOT] epoch=600 f_loss=-3.6956 g_loss=-18.9139 | train mmd=0.0037 | test_mmd=0.0103\n",
      "[CellOT] epoch=650 f_loss=6.0272 g_loss=-15.7278 | train mmd=0.0037 | test_mmd=0.0066\n",
      "[CellOT] epoch=700 f_loss=-0.7443 g_loss=-20.1265 | train mmd=0.0038 | test_mmd=0.0077\n",
      "[CellOT] epoch=750 f_loss=-3.4121 g_loss=-17.4068 | train mmd=0.0036 | test_mmd=0.0100\n",
      "[CellOT] epoch=800 f_loss=-1.3934 g_loss=-21.0744 | train mmd=0.0031 | test_mmd=0.0070\n",
      "[CellOT] epoch=850 f_loss=-1.2583 g_loss=-21.9153 | train mmd=0.0054 | test_mmd=0.0225\n",
      "[CellOT] epoch=900 f_loss=-1.6655 g_loss=-17.3523 | train mmd=0.0037 | test_mmd=0.0121\n",
      "[CellOT] epoch=950 f_loss=1.7235 g_loss=-18.3124 | train mmd=0.0026 | test_mmd=0.0056\n",
      "[CellOT] epoch=1000 f_loss=-2.0917 g_loss=-16.9220 | train mmd=0.0031 | test_mmd=0.0074\n",
      "[CellOT] Final CellOT MMD: 0.0052\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.0073955870437280025, 'mmd2_gamma_0.5': 0.00990388723443756, 'mmd2_gamma_1.0': 0.006200414303829938, 'wasserstein_distance': 2.109027991790988, 'R2_feature_means': 0.9706590612477096}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=7.2145 g_loss=-25.3191 | train mmd=0.0211 | test_mmd=0.3101\n",
      "[CellOT] epoch=50 f_loss=-46.1745 g_loss=-47.6204 | train mmd=0.0076 | test_mmd=0.3744\n",
      "[CellOT] epoch=100 f_loss=-32.1899 g_loss=-30.6577 | train mmd=0.0076 | test_mmd=0.3395\n",
      "[CellOT] epoch=150 f_loss=-14.1934 g_loss=-21.9893 | train mmd=0.0076 | test_mmd=0.2234\n",
      "[CellOT] epoch=200 f_loss=-7.1657 g_loss=-21.8450 | train mmd=0.0073 | test_mmd=0.0698\n",
      "[CellOT] epoch=250 f_loss=-0.7690 g_loss=-19.1948 | train mmd=0.0066 | test_mmd=0.0281\n",
      "[CellOT] epoch=300 f_loss=0.6410 g_loss=-18.3304 | train mmd=0.0058 | test_mmd=0.0164\n",
      "[CellOT] epoch=350 f_loss=-5.1579 g_loss=-18.6072 | train mmd=0.0055 | test_mmd=0.0121\n",
      "[CellOT] epoch=400 f_loss=-3.8522 g_loss=-17.0456 | train mmd=0.0052 | test_mmd=0.0144\n",
      "[CellOT] epoch=450 f_loss=-2.6072 g_loss=-18.3137 | train mmd=0.0047 | test_mmd=0.0110\n",
      "[CellOT] epoch=500 f_loss=-1.0421 g_loss=-18.6727 | train mmd=0.0042 | test_mmd=0.0103\n",
      "[CellOT] epoch=550 f_loss=1.8686 g_loss=-17.1377 | train mmd=0.0038 | test_mmd=0.0092\n",
      "[CellOT] epoch=600 f_loss=0.1200 g_loss=-20.2320 | train mmd=0.0037 | test_mmd=0.0069\n",
      "[CellOT] epoch=650 f_loss=1.0449 g_loss=-16.8151 | train mmd=0.0039 | test_mmd=0.0072\n",
      "[CellOT] epoch=700 f_loss=-3.8336 g_loss=-18.3652 | train mmd=0.0034 | test_mmd=0.0079\n",
      "[CellOT] epoch=750 f_loss=2.7064 g_loss=-16.8941 | train mmd=0.0035 | test_mmd=0.0071\n",
      "[CellOT] epoch=800 f_loss=-0.5870 g_loss=-20.9890 | train mmd=0.0030 | test_mmd=0.0060\n",
      "[CellOT] epoch=850 f_loss=2.2255 g_loss=-16.4796 | train mmd=0.0029 | test_mmd=0.0057\n",
      "[CellOT] epoch=900 f_loss=-2.0682 g_loss=-16.2504 | train mmd=0.0036 | test_mmd=0.0089\n",
      "[CellOT] epoch=950 f_loss=1.5234 g_loss=-17.1456 | train mmd=0.0036 | test_mmd=0.0076\n",
      "[CellOT] epoch=1000 f_loss=-1.1325 g_loss=-18.9760 | train mmd=0.0048 | test_mmd=0.0169\n",
      "[CellOT] Final CellOT MMD: 0.0097\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=6.3320 g_loss=-22.0846 | train mmd=0.0297 | test_mmd=0.2392\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.016902077590637443, 'mmd2_gamma_0.5': 0.016124385187441442, 'mmd2_gamma_1.0': 0.007934235283313128, 'wasserstein_distance': 2.227217057418074, 'R2_feature_means': 0.9231268776823658}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-60.1077 g_loss=-74.4190 | train mmd=0.0076 | test_mmd=0.3731\n",
      "[CellOT] epoch=100 f_loss=-26.4804 g_loss=-28.3670 | train mmd=0.0076 | test_mmd=0.3323\n",
      "[CellOT] epoch=150 f_loss=-8.7458 g_loss=-26.9415 | train mmd=0.0075 | test_mmd=0.1507\n",
      "[CellOT] epoch=200 f_loss=0.0640 g_loss=-21.9987 | train mmd=0.0072 | test_mmd=0.0461\n",
      "[CellOT] epoch=250 f_loss=2.9813 g_loss=-17.5641 | train mmd=0.0062 | test_mmd=0.0205\n",
      "[CellOT] epoch=300 f_loss=0.0479 g_loss=-19.7539 | train mmd=0.0055 | test_mmd=0.0183\n",
      "[CellOT] epoch=350 f_loss=-0.3403 g_loss=-18.5633 | train mmd=0.0051 | test_mmd=0.0130\n",
      "[CellOT] epoch=400 f_loss=2.7203 g_loss=-19.3391 | train mmd=0.0050 | test_mmd=0.0122\n",
      "[CellOT] epoch=450 f_loss=-0.4031 g_loss=-20.6899 | train mmd=0.0044 | test_mmd=0.0098\n",
      "[CellOT] epoch=500 f_loss=-4.9088 g_loss=-18.8384 | train mmd=0.0040 | test_mmd=0.0084\n",
      "[CellOT] epoch=550 f_loss=-1.0891 g_loss=-16.7771 | train mmd=0.0041 | test_mmd=0.0085\n",
      "[CellOT] epoch=600 f_loss=1.2376 g_loss=-17.5706 | train mmd=0.0035 | test_mmd=0.0073\n",
      "[CellOT] epoch=650 f_loss=-2.6128 g_loss=-15.5579 | train mmd=0.0034 | test_mmd=0.0071\n",
      "[CellOT] epoch=700 f_loss=-3.8525 g_loss=-18.6785 | train mmd=0.0037 | test_mmd=0.0099\n",
      "[CellOT] epoch=750 f_loss=0.5604 g_loss=-17.3921 | train mmd=0.0029 | test_mmd=0.0068\n",
      "[CellOT] epoch=800 f_loss=4.7700 g_loss=-20.0798 | train mmd=0.0030 | test_mmd=0.0072\n",
      "[CellOT] epoch=850 f_loss=6.8876 g_loss=-16.0868 | train mmd=0.0027 | test_mmd=0.0076\n",
      "[CellOT] epoch=900 f_loss=0.6956 g_loss=-20.7679 | train mmd=0.0033 | test_mmd=0.0085\n",
      "[CellOT] epoch=950 f_loss=0.2136 g_loss=-15.8625 | train mmd=0.0027 | test_mmd=0.0068\n",
      "[CellOT] epoch=1000 f_loss=1.9708 g_loss=-19.1234 | train mmd=0.0022 | test_mmd=0.0047\n",
      "[CellOT] Final CellOT MMD: 0.0038\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.004696367387539646, 'mmd2_gamma_0.5': 0.007104275267745097, 'mmd2_gamma_1.0': 0.005144223707761181, 'wasserstein_distance': 2.155696491658973, 'R2_feature_means': 0.9697157360536397}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=6.4802 g_loss=-23.1221 | train mmd=0.0213 | test_mmd=0.2297\n",
      "[CellOT] epoch=50 f_loss=-52.8387 g_loss=-38.3139 | train mmd=0.0076 | test_mmd=0.3746\n",
      "[CellOT] epoch=100 f_loss=-27.6637 g_loss=-34.4393 | train mmd=0.0076 | test_mmd=0.3658\n",
      "[CellOT] epoch=150 f_loss=-9.4643 g_loss=-19.1434 | train mmd=0.0076 | test_mmd=0.1548\n",
      "[CellOT] epoch=200 f_loss=-7.2627 g_loss=-19.4526 | train mmd=0.0071 | test_mmd=0.0453\n",
      "[CellOT] epoch=250 f_loss=0.4235 g_loss=-19.5093 | train mmd=0.0062 | test_mmd=0.0253\n",
      "[CellOT] epoch=300 f_loss=-3.5672 g_loss=-17.9407 | train mmd=0.0059 | test_mmd=0.0188\n",
      "[CellOT] epoch=350 f_loss=-3.9406 g_loss=-19.0663 | train mmd=0.0058 | test_mmd=0.0150\n",
      "[CellOT] epoch=400 f_loss=0.2899 g_loss=-19.2201 | train mmd=0.0055 | test_mmd=0.0151\n",
      "[CellOT] epoch=450 f_loss=0.1867 g_loss=-18.1017 | train mmd=0.0052 | test_mmd=0.0121\n",
      "[CellOT] epoch=500 f_loss=1.9898 g_loss=-18.1474 | train mmd=0.0039 | test_mmd=0.0085\n",
      "[CellOT] epoch=550 f_loss=2.8303 g_loss=-17.4316 | train mmd=0.0037 | test_mmd=0.0073\n",
      "[CellOT] epoch=600 f_loss=0.1483 g_loss=-17.6105 | train mmd=0.0034 | test_mmd=0.0091\n",
      "[CellOT] epoch=650 f_loss=6.5688 g_loss=-17.9150 | train mmd=0.0036 | test_mmd=0.0074\n",
      "[CellOT] epoch=700 f_loss=-4.3452 g_loss=-16.4001 | train mmd=0.0033 | test_mmd=0.0077\n",
      "[CellOT] epoch=750 f_loss=-0.3001 g_loss=-15.5824 | train mmd=0.0034 | test_mmd=0.0079\n",
      "[CellOT] epoch=800 f_loss=-2.0535 g_loss=-17.4838 | train mmd=0.0028 | test_mmd=0.0058\n",
      "[CellOT] epoch=850 f_loss=1.4427 g_loss=-20.6209 | train mmd=0.0026 | test_mmd=0.0077\n",
      "[CellOT] epoch=900 f_loss=-0.8870 g_loss=-20.0181 | train mmd=0.0048 | test_mmd=0.0204\n",
      "[CellOT] epoch=950 f_loss=-1.9224 g_loss=-20.5220 | train mmd=0.0025 | test_mmd=0.0068\n",
      "[CellOT] epoch=1000 f_loss=5.6918 g_loss=-17.1343 | train mmd=0.0024 | test_mmd=0.0064\n",
      "[CellOT] Final CellOT MMD: 0.0045\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.0063626159685084005, 'mmd2_gamma_0.5': 0.008362876648295721, 'mmd2_gamma_1.0': 0.00565267878439798, 'wasserstein_distance': 2.153492259445744, 'R2_feature_means': 0.9633849692006053}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=8.2242 g_loss=-25.3029 | train mmd=0.0142 | test_mmd=0.1865\n",
      "[CellOT] epoch=50 f_loss=-61.9220 g_loss=-62.3702 | train mmd=0.0076 | test_mmd=0.3741\n",
      "[CellOT] epoch=100 f_loss=-24.3540 g_loss=-32.7055 | train mmd=0.0076 | test_mmd=0.3423\n",
      "[CellOT] epoch=150 f_loss=-11.7453 g_loss=-28.4750 | train mmd=0.0076 | test_mmd=0.1550\n",
      "[CellOT] epoch=200 f_loss=-7.0986 g_loss=-18.1051 | train mmd=0.0071 | test_mmd=0.0556\n",
      "[CellOT] epoch=250 f_loss=-2.2680 g_loss=-21.5870 | train mmd=0.0064 | test_mmd=0.0282\n",
      "[CellOT] epoch=300 f_loss=-2.5808 g_loss=-21.0843 | train mmd=0.0063 | test_mmd=0.0257\n",
      "[CellOT] epoch=350 f_loss=-2.2799 g_loss=-17.8669 | train mmd=0.0056 | test_mmd=0.0127\n",
      "[CellOT] epoch=400 f_loss=2.8573 g_loss=-17.5746 | train mmd=0.0054 | test_mmd=0.0137\n",
      "[CellOT] epoch=450 f_loss=-1.0000 g_loss=-18.8821 | train mmd=0.0049 | test_mmd=0.0122\n",
      "[CellOT] epoch=500 f_loss=1.1286 g_loss=-17.7484 | train mmd=0.0048 | test_mmd=0.0158\n",
      "[CellOT] epoch=550 f_loss=1.4163 g_loss=-18.6961 | train mmd=0.0038 | test_mmd=0.0096\n",
      "[CellOT] epoch=600 f_loss=2.4254 g_loss=-18.5140 | train mmd=0.0044 | test_mmd=0.0135\n",
      "[CellOT] epoch=650 f_loss=-2.1040 g_loss=-20.4120 | train mmd=0.0031 | test_mmd=0.0071\n",
      "[CellOT] epoch=700 f_loss=-0.8653 g_loss=-16.8376 | train mmd=0.0030 | test_mmd=0.0052\n",
      "[CellOT] epoch=750 f_loss=-1.5766 g_loss=-15.4135 | train mmd=0.0029 | test_mmd=0.0076\n",
      "[CellOT] epoch=800 f_loss=2.0645 g_loss=-16.5259 | train mmd=0.0027 | test_mmd=0.0063\n",
      "[CellOT] epoch=850 f_loss=3.5903 g_loss=-19.2517 | train mmd=0.0027 | test_mmd=0.0065\n",
      "[CellOT] epoch=900 f_loss=-0.9648 g_loss=-16.8978 | train mmd=0.0028 | test_mmd=0.0055\n",
      "[CellOT] epoch=950 f_loss=-1.1147 g_loss=-20.0622 | train mmd=0.0028 | test_mmd=0.0070\n",
      "[CellOT] epoch=1000 f_loss=-4.8347 g_loss=-17.4771 | train mmd=0.0028 | test_mmd=0.0052\n",
      "[CellOT] Final CellOT MMD: 0.0041\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.0051656008915351714, 'mmd2_gamma_0.5': 0.008001221558608038, 'mmd2_gamma_1.0': 0.005626455960524093, 'wasserstein_distance': 2.10971381543389, 'R2_feature_means': 0.981004317210134}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=6.8621 g_loss=-23.0891 | train mmd=0.0261 | test_mmd=0.2108\n",
      "[CellOT] epoch=50 f_loss=-56.6643 g_loss=-49.6896 | train mmd=0.0076 | test_mmd=0.3746\n",
      "[CellOT] epoch=100 f_loss=-18.7629 g_loss=-31.9852 | train mmd=0.0076 | test_mmd=0.2985\n",
      "[CellOT] epoch=150 f_loss=-10.0186 g_loss=-21.9066 | train mmd=0.0076 | test_mmd=0.1312\n",
      "[CellOT] epoch=200 f_loss=-5.5337 g_loss=-20.5168 | train mmd=0.0072 | test_mmd=0.0521\n",
      "[CellOT] epoch=250 f_loss=-3.4067 g_loss=-20.0483 | train mmd=0.0068 | test_mmd=0.0340\n",
      "[CellOT] epoch=300 f_loss=-7.2211 g_loss=-19.4418 | train mmd=0.0062 | test_mmd=0.0222\n",
      "[CellOT] epoch=350 f_loss=-0.2674 g_loss=-18.7206 | train mmd=0.0057 | test_mmd=0.0150\n",
      "[CellOT] epoch=400 f_loss=0.6337 g_loss=-19.5047 | train mmd=0.0054 | test_mmd=0.0098\n",
      "[CellOT] epoch=450 f_loss=-2.1414 g_loss=-16.9596 | train mmd=0.0048 | test_mmd=0.0093\n",
      "[CellOT] epoch=500 f_loss=-6.3096 g_loss=-21.7479 | train mmd=0.0040 | test_mmd=0.0104\n",
      "[CellOT] epoch=550 f_loss=3.0476 g_loss=-17.9429 | train mmd=0.0044 | test_mmd=0.0121\n",
      "[CellOT] epoch=600 f_loss=-1.6582 g_loss=-18.4516 | train mmd=0.0033 | test_mmd=0.0073\n",
      "[CellOT] epoch=650 f_loss=1.3113 g_loss=-16.4071 | train mmd=0.0038 | test_mmd=0.0084\n",
      "[CellOT] epoch=700 f_loss=3.1769 g_loss=-17.6017 | train mmd=0.0038 | test_mmd=0.0130\n",
      "[CellOT] epoch=750 f_loss=2.7185 g_loss=-19.7838 | train mmd=0.0042 | test_mmd=0.0114\n",
      "[CellOT] epoch=800 f_loss=4.1206 g_loss=-16.4787 | train mmd=0.0033 | test_mmd=0.0056\n",
      "[CellOT] epoch=850 f_loss=-0.4885 g_loss=-16.5180 | train mmd=0.0029 | test_mmd=0.0057\n",
      "[CellOT] epoch=900 f_loss=-0.1540 g_loss=-16.3064 | train mmd=0.0029 | test_mmd=0.0061\n",
      "[CellOT] epoch=950 f_loss=-2.3749 g_loss=-17.0316 | train mmd=0.0035 | test_mmd=0.0102\n",
      "[CellOT] epoch=1000 f_loss=0.5123 g_loss=-17.7330 | train mmd=0.0030 | test_mmd=0.0055\n",
      "[CellOT] Final CellOT MMD: 0.0043\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.005469986475939881, 'mmd2_gamma_0.5': 0.00860008118165425, 'mmd2_gamma_1.0': 0.005813358030349509, 'wasserstein_distance': 2.0958206489187927, 'R2_feature_means': 0.9795697639007283}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=6.3761 g_loss=-21.1099 | train mmd=0.0192 | test_mmd=0.2387\n",
      "[CellOT] epoch=50 f_loss=-58.1013 g_loss=-52.0046 | train mmd=0.0076 | test_mmd=0.3753\n",
      "[CellOT] epoch=100 f_loss=-21.4246 g_loss=-31.4612 | train mmd=0.0076 | test_mmd=0.3601\n",
      "[CellOT] epoch=150 f_loss=-18.0607 g_loss=-23.1458 | train mmd=0.0076 | test_mmd=0.2660\n",
      "[CellOT] epoch=200 f_loss=-5.7292 g_loss=-23.9702 | train mmd=0.0074 | test_mmd=0.0754\n",
      "[CellOT] epoch=250 f_loss=-4.4945 g_loss=-22.9465 | train mmd=0.0068 | test_mmd=0.0341\n",
      "[CellOT] epoch=300 f_loss=-1.3224 g_loss=-19.7411 | train mmd=0.0065 | test_mmd=0.0204\n",
      "[CellOT] epoch=350 f_loss=-0.8811 g_loss=-19.0464 | train mmd=0.0061 | test_mmd=0.0191\n",
      "[CellOT] epoch=400 f_loss=-3.2340 g_loss=-18.4728 | train mmd=0.0059 | test_mmd=0.0144\n",
      "[CellOT] epoch=450 f_loss=-4.3790 g_loss=-18.6850 | train mmd=0.0055 | test_mmd=0.0127\n",
      "[CellOT] epoch=500 f_loss=1.0099 g_loss=-19.4200 | train mmd=0.0052 | test_mmd=0.0097\n",
      "[CellOT] epoch=550 f_loss=-1.2551 g_loss=-17.7432 | train mmd=0.0054 | test_mmd=0.0129\n",
      "[CellOT] epoch=600 f_loss=0.0671 g_loss=-15.5224 | train mmd=0.0044 | test_mmd=0.0077\n",
      "[CellOT] epoch=650 f_loss=-1.1735 g_loss=-19.5786 | train mmd=0.0040 | test_mmd=0.0094\n",
      "[CellOT] epoch=700 f_loss=1.8118 g_loss=-18.5845 | train mmd=0.0042 | test_mmd=0.0112\n",
      "[CellOT] epoch=750 f_loss=-2.2352 g_loss=-19.1557 | train mmd=0.0038 | test_mmd=0.0095\n",
      "[CellOT] epoch=800 f_loss=-4.4322 g_loss=-19.9379 | train mmd=0.0037 | test_mmd=0.0068\n",
      "[CellOT] epoch=850 f_loss=-3.8250 g_loss=-18.7117 | train mmd=0.0033 | test_mmd=0.0060\n",
      "[CellOT] epoch=900 f_loss=-0.0697 g_loss=-16.9796 | train mmd=0.0039 | test_mmd=0.0081\n",
      "[CellOT] epoch=950 f_loss=1.9800 g_loss=-19.2893 | train mmd=0.0030 | test_mmd=0.0060\n",
      "[CellOT] epoch=1000 f_loss=3.4019 g_loss=-16.4245 | train mmd=0.0029 | test_mmd=0.0092\n",
      "[CellOT] Final CellOT MMD: 0.0058\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.009168443652517788, 'mmd2_gamma_0.5': 0.00931574637041506, 'mmd2_gamma_1.0': 0.0059296488130115505, 'wasserstein_distance': 2.2238331301493104, 'R2_feature_means': 0.9075409391173254}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=7.3397 g_loss=-26.5089 | train mmd=0.0159 | test_mmd=0.3532\n",
      "[CellOT] epoch=50 f_loss=-62.4902 g_loss=-42.6937 | train mmd=0.0076 | test_mmd=0.3762\n",
      "[CellOT] epoch=100 f_loss=-25.3248 g_loss=-28.5324 | train mmd=0.0076 | test_mmd=0.3342\n",
      "[CellOT] epoch=150 f_loss=-7.1261 g_loss=-21.9195 | train mmd=0.0076 | test_mmd=0.2557\n",
      "[CellOT] epoch=200 f_loss=-1.7536 g_loss=-22.7073 | train mmd=0.0072 | test_mmd=0.0515\n",
      "[CellOT] epoch=250 f_loss=-3.5423 g_loss=-20.6801 | train mmd=0.0066 | test_mmd=0.0245\n",
      "[CellOT] epoch=300 f_loss=-3.6970 g_loss=-19.5108 | train mmd=0.0058 | test_mmd=0.0153\n",
      "[CellOT] epoch=350 f_loss=-1.8881 g_loss=-18.9415 | train mmd=0.0054 | test_mmd=0.0134\n",
      "[CellOT] epoch=400 f_loss=2.6197 g_loss=-17.8608 | train mmd=0.0051 | test_mmd=0.0117\n",
      "[CellOT] epoch=450 f_loss=-1.7078 g_loss=-19.0063 | train mmd=0.0048 | test_mmd=0.0093\n",
      "[CellOT] epoch=500 f_loss=0.9084 g_loss=-18.6649 | train mmd=0.0048 | test_mmd=0.0131\n",
      "[CellOT] epoch=550 f_loss=1.0250 g_loss=-16.3355 | train mmd=0.0047 | test_mmd=0.0121\n",
      "[CellOT] epoch=600 f_loss=0.5536 g_loss=-17.8612 | train mmd=0.0045 | test_mmd=0.0113\n",
      "[CellOT] epoch=650 f_loss=-1.7773 g_loss=-17.4456 | train mmd=0.0037 | test_mmd=0.0081\n",
      "[CellOT] epoch=700 f_loss=0.6432 g_loss=-18.1709 | train mmd=0.0037 | test_mmd=0.0087\n",
      "[CellOT] epoch=750 f_loss=-0.7971 g_loss=-17.5590 | train mmd=0.0031 | test_mmd=0.0075\n",
      "[CellOT] epoch=800 f_loss=0.3564 g_loss=-18.6892 | train mmd=0.0033 | test_mmd=0.0075\n",
      "[CellOT] epoch=850 f_loss=1.0247 g_loss=-17.0885 | train mmd=0.0032 | test_mmd=0.0058\n",
      "[CellOT] epoch=900 f_loss=-2.6626 g_loss=-17.1139 | train mmd=0.0038 | test_mmd=0.0086\n",
      "[CellOT] epoch=950 f_loss=2.9665 g_loss=-14.6201 | train mmd=0.0039 | test_mmd=0.0090\n",
      "[CellOT] epoch=1000 f_loss=-1.9772 g_loss=-16.3265 | train mmd=0.0028 | test_mmd=0.0068\n",
      "[CellOT] Final CellOT MMD: 0.0047\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.006776566344147805, 'mmd2_gamma_0.5': 0.008826019686424658, 'mmd2_gamma_1.0': 0.005751747614548962, 'wasserstein_distance': 2.14737280016523, 'R2_feature_means': 0.9680225503219301}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0079  0.0035\n",
      "mmd2_gamma_0.5        0.0099  0.0026\n",
      "mmd2_gamma_1.0        0.0062  0.0008\n",
      "wasserstein_distance  2.1490  0.0450\n",
      "R2_feature_means      0.9586  0.0245\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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zhvQhKI4aEy4EXqUq88eeFTLbXfzpUcM06ZNY926dSxZsmS/7X76059mCYyEw+FeMQ7dc4o9h4ZHkmeffZbrr7+e5cuXs2LFCm666Sb69+/PjTfemGnz29/+lvvuu4/7778/3ccusfoHH3yQZ555hubm5oyBmTlzJpAWq6+rq2PRokVomsZtt922X7H6SCTC+PHjKS8v57XXXqOkpIRVq1ZhWRZXXnkl69at45133mHBggUA5OTkAGkBe7fbzdtvv01OTg5PPfUUEydOZNOmTeTl5fH3v/+dBx54gN///vecfvrp/OUvf+Gxxx7L0qbendraWs4880wmTJjAwoULCQQCLF26FMNIvwk+99xz3HfffRlN69WrV3PjjTfi9Xr53ve+d8BzPm3aNFKpFO+//z5er5cNGzbsVf7Upu/T7RgWAo6tKqSpPYamyowcXMRr721EksHpUEFWWbiihmjcoLbTk3b+ks48znPEQZJoSzhI6DKlXgVDVXFoCrGEzqYdrViWQJYlPl61gYCxdwngukSAnTXV5Goxhg4ehb9iFK89/Qoh3UKRDBQBQtIIxQwcsiBh9ny/lmjX3TgNAwlByiDdRjdRMDMRU91Kk+cOz2VkRQutURmfUcfpo6cchbO/J1/KMEyfPp033niD999/n4qKiv22dTqdR0wmcl90a6n2prB2v379ePTRR5EkiWHDhrF27VoeffTRLMNw9tlnc/fdd2c+33DDDYddrP7555+nubmZjz/+ODPF11PBzOfzoapq1vTTwQjY/+53v+P666/PiA89+OCDLFiwYL+jht///vfk5OTwwgsvZFTjuvWpAe6//34efvhhLrnkEgCqqqrYsGEDTz311EEZhh07dnDppZcycuRIgP0aKZu+TU9/Q0soht+T9gW8tHADkizhdzvQDSs9ZZOIkUrGEZb0hR+ia3Au9AR5zgQu1aItalJcpOF2akTiKQzTxKFIBH0O5n28g8EDBIPK87IkgP+xYC1/W7yDznAHLtngWwNb8ZYcw8urU5hCwxQKugVgIUkSKHtOuggkEkJDwkIIiZQlockmZ+ZuxN+yBCouSFdOFYJkuIGKQAnFchuSJB11p3M3h2QYhBD88Ic/ZPbs2SxevLhPatBW72rLaKn2Lw72mrD2N77xjfSN0sW4ceN4+OGHMU0TRUmH35144olZ6xwJsfo1a9Yw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qL+vw8H+jiMWi7Fq1SruvfdeVq1axSuvvMLGjRu54IILDrjdQ7k3Dxvia8ZvfvMbUVVVtd8248ePF7fffnvvdGgfnHzyyWLatGmZz6ZpirKyMjFjxoy9tr/iiivE+eefn/XdKaecIm6++eYj2s9DoampSQDivffe22ebmTNnipycnN7r1EFw//33i9GjRx90+6/CtRBCiNtvv10MGjRIWJa11+V98VoAYvbs2ZnPlmWJkpIS8T//8z+Z7zo6OoTT6RR/+9vf9rmdQ/19HW52P469sXz5cgGI7du377PNod6bh4uv9Ihhb4RCIfLy9i3D181zzz1HQUEBxx13HD/96U+JxWK90Ls0qVSKlStXMmnSpMx3siwzadIkPvzww72u8+GHH2a1B5g8efI+2x8NQqEQwAHPfyQSYcCAAfTr148LL7yQ9evX90b39svmzZspKytj4MCBXHPNNezYsWOfbb8K1yKVSvHXv/6VH/zgB/utYtwXr0VPampqaGhoyDrfOTk5nHLKKfs831/m93U0CIVCSJJEMBjcb7tDuTcPF18rw7BlyxYef/xxbr755v22u/rqq/nrX//KokWL+OlPf8pf/vIXvvOd7/RSL6GlpQXTNCkuLs76vri4mIaGhr2u09DQcEjtexvLsrjjjjs47bTTOO644/bZbtiwYTzzzDPMmTOHv/71r1iWxamnnsquXbt6sbfZnHLKKcyaNYt33nmHJ554gpqaGs4444yMdsju9PVrAfDqq6/S0dHBddddt882ffFa7E73OT2U8/1lfl+9TSKR4J577uGqq67ab1XVQ703Dxe9Xnb7YPjJT37Cr3/96/22+eyzz7KcMLW1tUyZMoXLL7+cG2+8cb/r3nTTTZn/jxw5ktLSUiZOnEh1dTWDBg361zr/b8q0adNYt27dAec/x40bx7hx4zKfTz31VI455hieeuopfvnLXx7pbu6Vc889N/P/UaNGccoppzBgwAD+/ve/c/311x+VPv2r/OlPf+Lcc8+lrKxsn2364rX4d0DXda644gqEEDzxxBP7bXu07s0+aRjuvvvu/b7pAAwcODDz/7q6Os466yxOPfVU/vCHPxzy/k455RQgPeLoDcNQUFCAoig0NjZmfd/Y2EhJScle1ykpKTmk9r3J9OnTeeONN3j//fcPWWtD0zTGjh3Lli1bjlDvDp1gMMjQoUP32ae+fC0Atm/fzoIFC3jllVcOab2+eC26z2ljYyOlpaWZ7xsbGxkzZsxe1/kyv6/eotsobN++nYULFx6yBsOB7s3DRZ+cSiosLGT48OH7/XM4HEB6pDBhwgROOOEEZs6ceUBlor2xZs0agKwb70jicDg44YQTePfddzPfWZbFu+++m/UG15Nx48ZltQeYP3/+Ptv3BkIIpk+fzuzZs1m4cCFVVVWHvA3TNFm7dm2vnfuDIRKJUF1dvc8+9cVr0ZOZM2dSVFTE+eeff0jr9cVrUVVVRUlJSdb5DofDLFu2bJ/n+8v8vnqDbqOwefNmFixYQH5+/iFv40D35mGj193dh5Fdu3aJwYMHi4kTJ4pdu3aJ+vr6zF/PNsOGDRPLli0TQgixZcsW8Ytf/EKsWLFC1NTUiDlz5oiBAweKM888s1f7/sILLwin0ylmzZolNmzYIG666SYRDAZFQ0ODEEKIa6+9VvzkJz/JtF+6dKlQVVX89re/FZ999pm4//77haZpYu3atb3a757ceuutIicnRyxevDjr3MdisUyb3Y/j5z//uZg7d66orq4WK1euFN/+9reFy+US69evPxqHIIQQ4u677xaLFy8WNTU1YunSpWLSpEmioKBANDU1CSG+GteiG9M0Rf/+/cU999yzx7K+ei06OzvF6tWrxerVqwUgHnnkEbF69epMtM5DDz0kgsGgmDNnjvj000/FhRdeKKqqqkQ8Hs9s4+yzzxaPP/545vOBfl+9fRypVEpccMEFoqKiQqxZsybr95JMJvd5HAe6N48UX2nDMHPmTAHs9a+bmpoaAYhFixYJIYTYsWOHOPPMM0VeXp5wOp1i8ODB4sc//rEIhUK93v/HH39c9O/fXzgcDnHyySeLjz76KLNs/Pjx4nvf+15W+7///e9i6NChwuFwiBEjRog333yzl3uczb7O/cyZMzNtdj+OO+64I3PMxcXF4rzzzhOrVq3q/c734MorrxSlpaXC4XCI8vJyceWVV4otW7Zkln8VrkU3c+fOFYDYuHHjHsv66rVYtGjRXu+j7r5aliXuvfdeUVxcLJxOp5g4ceIexzdgwABx//33Z323v99Xbx9H93Nob3/dz6a9HceB7s0jha3HYGNjY2OTRZ/0MdjY2NjYHD1sw2BjY2Njk4VtGGxsbGxssrANg42NjY1NFrZhsLGxsbHJwjYMNjY2NjZZ2IbBxsbGxiYL2zDY2NjY2GRhGwYbGxsbmyxsw2BjY2Njk4VtGGxsbGxssvj/AeJNW03Qe/biAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"imatinib\"\n",
    "X_pre = adata_4i[adata_4i.obs[\"drug\"] == \"control\"].copy().to_df()[features_4i]\n",
    "X_post  = adata_4i[adata_4i.obs[\"drug\"] == drug].copy().to_df()[features_4i]\n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "X_tr_pre, X_te_pre, Y_tr_post, Y_te_post = split_train_test(X_pre.values, X_post.values, 0.8)\n",
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "# Compute median heuristic gamma on training data\n",
    "median_gamma = median_heuristic_gamma(X_tr_pre, Y_tr_post)\n",
    "print(\"Median heuristic gamma:\", median_gamma)\n",
    "\n",
    "\n",
    "all_metrics = []\n",
    "for run in range(10):\n",
    "    print(f\"**************** Run: {run} ****************\")\n",
    "    seed = 1234 + run\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "\n",
    "    out = run_cellot_pair(X_tr_pre, Y_tr_post, X_te_pre, Y_te_post, n_epochs=1000)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post, median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post\n",
    "target = Y_te_post\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#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": 14,
   "id": "b9c7dd83",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (10995, 48)\n",
      "X_post cells: (2693, 48)\n",
      "(2154, 48)\n",
      "(539, 48)\n",
      "(2154, 48)\n",
      "(539, 48)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=3.3159 g_loss=-21.7215 | train mmd=0.0160 | test_mmd=0.0844\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.07603466947967093\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-48.2577 g_loss=-38.7750 | train mmd=0.0095 | test_mmd=0.3636\n",
      "[CellOT] epoch=100 f_loss=-20.0057 g_loss=-33.7148 | train mmd=0.0095 | test_mmd=0.3496\n",
      "[CellOT] epoch=150 f_loss=-10.8176 g_loss=-25.1844 | train mmd=0.0095 | test_mmd=0.1951\n",
      "[CellOT] epoch=200 f_loss=-10.2784 g_loss=-21.0652 | train mmd=0.0088 | test_mmd=0.0746\n",
      "[CellOT] epoch=250 f_loss=-6.8755 g_loss=-18.8583 | train mmd=0.0082 | test_mmd=0.0448\n",
      "[CellOT] epoch=300 f_loss=-4.5686 g_loss=-17.8782 | train mmd=0.0072 | test_mmd=0.0328\n",
      "[CellOT] epoch=350 f_loss=-2.0252 g_loss=-19.4419 | train mmd=0.0068 | test_mmd=0.0231\n",
      "[CellOT] epoch=400 f_loss=0.4705 g_loss=-15.9351 | train mmd=0.0064 | test_mmd=0.0224\n",
      "[CellOT] epoch=450 f_loss=2.0063 g_loss=-17.5192 | train mmd=0.0056 | test_mmd=0.0155\n",
      "[CellOT] epoch=500 f_loss=0.4453 g_loss=-20.0226 | train mmd=0.0053 | test_mmd=0.0138\n",
      "[CellOT] epoch=550 f_loss=0.2584 g_loss=-21.4809 | train mmd=0.0049 | test_mmd=0.0133\n",
      "[CellOT] epoch=600 f_loss=-2.0381 g_loss=-16.1908 | train mmd=0.0047 | test_mmd=0.0101\n",
      "[CellOT] epoch=650 f_loss=-0.2191 g_loss=-15.8912 | train mmd=0.0038 | test_mmd=0.0075\n",
      "[CellOT] epoch=700 f_loss=0.9932 g_loss=-17.8575 | train mmd=0.0038 | test_mmd=0.0080\n",
      "[CellOT] epoch=750 f_loss=-4.9282 g_loss=-15.8185 | train mmd=0.0037 | test_mmd=0.0100\n",
      "[CellOT] epoch=800 f_loss=-1.3064 g_loss=-15.1400 | train mmd=0.0028 | test_mmd=0.0069\n",
      "[CellOT] epoch=850 f_loss=1.4791 g_loss=-15.9217 | train mmd=0.0030 | test_mmd=0.0067\n",
      "[CellOT] epoch=900 f_loss=1.5788 g_loss=-17.1991 | train mmd=0.0036 | test_mmd=0.0082\n",
      "[CellOT] epoch=950 f_loss=-2.0261 g_loss=-17.3238 | train mmd=0.0034 | test_mmd=0.0078\n",
      "[CellOT] epoch=1000 f_loss=2.7724 g_loss=-15.5211 | train mmd=0.0027 | test_mmd=0.0072\n",
      "[CellOT] Final CellOT MMD: 0.0043\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.007220623834779838, 'mmd2_gamma_0.5': 0.0078386512206065, 'mmd2_gamma_1.0': 0.005609477475135087, 'wasserstein_distance': 2.113060761498865, 'R2_feature_means': 0.8106539727653876}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=7.7479 g_loss=-20.8179 | train mmd=0.0240 | test_mmd=0.1860\n",
      "[CellOT] epoch=50 f_loss=-56.4459 g_loss=-45.5349 | train mmd=0.0095 | test_mmd=0.3703\n",
      "[CellOT] epoch=100 f_loss=-27.6070 g_loss=-44.9866 | train mmd=0.0095 | test_mmd=0.3459\n",
      "[CellOT] epoch=150 f_loss=-24.6467 g_loss=-28.3145 | train mmd=0.0095 | test_mmd=0.2703\n",
      "[CellOT] epoch=200 f_loss=-8.4538 g_loss=-22.1819 | train mmd=0.0094 | test_mmd=0.1263\n",
      "[CellOT] epoch=250 f_loss=-4.2341 g_loss=-24.2638 | train mmd=0.0091 | test_mmd=0.0752\n",
      "[CellOT] epoch=300 f_loss=-0.9043 g_loss=-19.8120 | train mmd=0.0082 | test_mmd=0.0430\n",
      "[CellOT] epoch=350 f_loss=-1.5394 g_loss=-21.7934 | train mmd=0.0078 | test_mmd=0.0340\n",
      "[CellOT] epoch=400 f_loss=-4.8410 g_loss=-18.4605 | train mmd=0.0076 | test_mmd=0.0296\n",
      "[CellOT] epoch=450 f_loss=0.1780 g_loss=-21.3202 | train mmd=0.0070 | test_mmd=0.0246\n",
      "[CellOT] epoch=500 f_loss=-0.2420 g_loss=-16.4525 | train mmd=0.0061 | test_mmd=0.0183\n",
      "[CellOT] epoch=550 f_loss=-1.0766 g_loss=-15.3853 | train mmd=0.0056 | test_mmd=0.0161\n",
      "[CellOT] epoch=600 f_loss=-1.4825 g_loss=-17.3390 | train mmd=0.0049 | test_mmd=0.0105\n",
      "[CellOT] epoch=650 f_loss=0.9201 g_loss=-14.1428 | train mmd=0.0049 | test_mmd=0.0114\n",
      "[CellOT] epoch=700 f_loss=1.2726 g_loss=-13.7066 | train mmd=0.0046 | test_mmd=0.0107\n",
      "[CellOT] epoch=750 f_loss=1.1894 g_loss=-15.2074 | train mmd=0.0034 | test_mmd=0.0079\n",
      "[CellOT] epoch=800 f_loss=1.0183 g_loss=-16.2299 | train mmd=0.0029 | test_mmd=0.0078\n",
      "[CellOT] epoch=850 f_loss=-0.8412 g_loss=-15.7711 | train mmd=0.0031 | test_mmd=0.0067\n",
      "[CellOT] epoch=900 f_loss=-1.4719 g_loss=-16.3212 | train mmd=0.0031 | test_mmd=0.0067\n",
      "[CellOT] epoch=950 f_loss=3.3988 g_loss=-16.3335 | train mmd=0.0028 | test_mmd=0.0061\n",
      "[CellOT] epoch=1000 f_loss=-0.2013 g_loss=-15.5076 | train mmd=0.0030 | test_mmd=0.0071\n",
      "[CellOT] Final CellOT MMD: 0.0043\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.0071247766301419935, 'mmd2_gamma_0.5': 0.007735035304956603, 'mmd2_gamma_1.0': 0.005645686609212065, 'wasserstein_distance': 2.1479292905717884, 'R2_feature_means': 0.742619829531756}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=5.9499 g_loss=-20.7807 | train mmd=0.0267 | test_mmd=0.1794\n",
      "[CellOT] epoch=50 f_loss=-59.0547 g_loss=-66.2872 | train mmd=0.0095 | test_mmd=0.3702\n",
      "[CellOT] epoch=100 f_loss=-32.9249 g_loss=-40.8108 | train mmd=0.0095 | test_mmd=0.3652\n",
      "[CellOT] epoch=150 f_loss=-13.2179 g_loss=-28.3362 | train mmd=0.0095 | test_mmd=0.2455\n",
      "[CellOT] epoch=200 f_loss=-3.3880 g_loss=-19.5084 | train mmd=0.0092 | test_mmd=0.0922\n",
      "[CellOT] epoch=250 f_loss=-3.1357 g_loss=-22.8250 | train mmd=0.0087 | test_mmd=0.0490\n",
      "[CellOT] epoch=300 f_loss=-4.9784 g_loss=-19.4641 | train mmd=0.0081 | test_mmd=0.0373\n",
      "[CellOT] epoch=350 f_loss=-0.4349 g_loss=-18.4475 | train mmd=0.0074 | test_mmd=0.0228\n",
      "[CellOT] epoch=400 f_loss=0.6855 g_loss=-19.3897 | train mmd=0.0063 | test_mmd=0.0136\n",
      "[CellOT] epoch=450 f_loss=-4.5082 g_loss=-17.3205 | train mmd=0.0056 | test_mmd=0.0142\n",
      "[CellOT] epoch=500 f_loss=-1.2714 g_loss=-18.0425 | train mmd=0.0051 | test_mmd=0.0226\n",
      "[CellOT] epoch=550 f_loss=0.4076 g_loss=-19.6992 | train mmd=0.0046 | test_mmd=0.0139\n",
      "[CellOT] epoch=600 f_loss=0.8534 g_loss=-15.7648 | train mmd=0.0041 | test_mmd=0.0092\n",
      "[CellOT] epoch=650 f_loss=-1.2345 g_loss=-15.3221 | train mmd=0.0041 | test_mmd=0.0109\n",
      "[CellOT] epoch=700 f_loss=0.0883 g_loss=-15.6199 | train mmd=0.0038 | test_mmd=0.0079\n",
      "[CellOT] epoch=750 f_loss=-4.0316 g_loss=-18.3617 | train mmd=0.0035 | test_mmd=0.0087\n",
      "[CellOT] epoch=800 f_loss=-4.0530 g_loss=-13.0999 | train mmd=0.0032 | test_mmd=0.0066\n",
      "[CellOT] epoch=850 f_loss=-0.4463 g_loss=-17.9255 | train mmd=0.0030 | test_mmd=0.0077\n",
      "[CellOT] epoch=900 f_loss=4.3609 g_loss=-18.3788 | train mmd=0.0032 | test_mmd=0.0087\n",
      "[CellOT] epoch=950 f_loss=-2.4539 g_loss=-13.4349 | train mmd=0.0034 | test_mmd=0.0086\n",
      "[CellOT] epoch=1000 f_loss=-1.2606 g_loss=-15.6802 | train mmd=0.0029 | test_mmd=0.0069\n",
      "[CellOT] Final CellOT MMD: 0.0042\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.006869146991935082, 'mmd2_gamma_0.5': 0.007486152300621149, 'mmd2_gamma_1.0': 0.005367611468487755, 'wasserstein_distance': 2.09998502560941, 'R2_feature_means': 0.8289726685554124}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=3.5182 g_loss=-20.8917 | train mmd=0.0277 | test_mmd=0.1777\n",
      "[CellOT] epoch=50 f_loss=-64.5388 g_loss=-72.1375 | train mmd=0.0095 | test_mmd=0.3705\n",
      "[CellOT] epoch=100 f_loss=-34.3255 g_loss=-25.0427 | train mmd=0.0095 | test_mmd=0.3578\n",
      "[CellOT] epoch=150 f_loss=-18.1022 g_loss=-25.2516 | train mmd=0.0095 | test_mmd=0.2646\n",
      "[CellOT] epoch=200 f_loss=-4.3298 g_loss=-20.5302 | train mmd=0.0091 | test_mmd=0.0852\n",
      "[CellOT] epoch=250 f_loss=-2.9118 g_loss=-20.4545 | train mmd=0.0082 | test_mmd=0.0434\n",
      "[CellOT] epoch=300 f_loss=-0.5698 g_loss=-21.5453 | train mmd=0.0072 | test_mmd=0.0244\n",
      "[CellOT] epoch=350 f_loss=-1.3680 g_loss=-19.4673 | train mmd=0.0065 | test_mmd=0.0179\n",
      "[CellOT] epoch=400 f_loss=-2.5391 g_loss=-22.2170 | train mmd=0.0057 | test_mmd=0.0127\n",
      "[CellOT] epoch=450 f_loss=4.2909 g_loss=-15.3568 | train mmd=0.0054 | test_mmd=0.0112\n",
      "[CellOT] epoch=500 f_loss=-1.1799 g_loss=-17.9316 | train mmd=0.0052 | test_mmd=0.0143\n",
      "[CellOT] epoch=550 f_loss=-4.0083 g_loss=-18.2980 | train mmd=0.0040 | test_mmd=0.0102\n",
      "[CellOT] epoch=600 f_loss=-1.7247 g_loss=-19.4918 | train mmd=0.0037 | test_mmd=0.0091\n",
      "[CellOT] epoch=650 f_loss=-1.5868 g_loss=-16.3712 | train mmd=0.0032 | test_mmd=0.0074\n",
      "[CellOT] epoch=700 f_loss=-0.4771 g_loss=-16.1392 | train mmd=0.0033 | test_mmd=0.0081\n",
      "[CellOT] epoch=750 f_loss=-3.5544 g_loss=-18.5686 | train mmd=0.0030 | test_mmd=0.0059\n",
      "[CellOT] epoch=800 f_loss=-0.3508 g_loss=-14.6259 | train mmd=0.0032 | test_mmd=0.0084\n",
      "[CellOT] epoch=850 f_loss=3.2886 g_loss=-16.7719 | train mmd=0.0034 | test_mmd=0.0069\n",
      "[CellOT] epoch=900 f_loss=0.9385 g_loss=-17.4770 | train mmd=0.0033 | test_mmd=0.0061\n",
      "[CellOT] epoch=950 f_loss=-2.3145 g_loss=-16.8776 | train mmd=0.0030 | test_mmd=0.0076\n",
      "[CellOT] epoch=1000 f_loss=-2.5968 g_loss=-15.0200 | train mmd=0.0028 | test_mmd=0.0085\n",
      "[CellOT] Final CellOT MMD: 0.0049\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.008509365936021251, 'mmd2_gamma_0.5': 0.008989719628964013, 'mmd2_gamma_1.0': 0.006125543474962719, 'wasserstein_distance': 2.180708761497051, 'R2_feature_means': 0.821691373526414}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=5.0943 g_loss=-24.3878 | train mmd=0.0365 | test_mmd=0.2135\n",
      "[CellOT] epoch=50 f_loss=-60.6971 g_loss=-62.5792 | train mmd=0.0095 | test_mmd=0.3705\n",
      "[CellOT] epoch=100 f_loss=-28.0261 g_loss=-27.5821 | train mmd=0.0095 | test_mmd=0.3517\n",
      "[CellOT] epoch=150 f_loss=-14.7175 g_loss=-25.0875 | train mmd=0.0094 | test_mmd=0.1665\n",
      "[CellOT] epoch=200 f_loss=-6.6589 g_loss=-23.4661 | train mmd=0.0087 | test_mmd=0.0658\n",
      "[CellOT] epoch=250 f_loss=-5.0176 g_loss=-24.9793 | train mmd=0.0082 | test_mmd=0.0430\n",
      "[CellOT] epoch=300 f_loss=-2.5622 g_loss=-16.3097 | train mmd=0.0073 | test_mmd=0.0276\n",
      "[CellOT] epoch=350 f_loss=0.6063 g_loss=-18.2134 | train mmd=0.0067 | test_mmd=0.0194\n",
      "[CellOT] epoch=400 f_loss=-1.0054 g_loss=-18.7181 | train mmd=0.0063 | test_mmd=0.0205\n",
      "[CellOT] epoch=450 f_loss=-6.4049 g_loss=-19.6349 | train mmd=0.0061 | test_mmd=0.0223\n",
      "[CellOT] epoch=500 f_loss=-0.3273 g_loss=-15.2080 | train mmd=0.0055 | test_mmd=0.0150\n",
      "[CellOT] epoch=550 f_loss=-1.3615 g_loss=-17.5276 | train mmd=0.0046 | test_mmd=0.0139\n",
      "[CellOT] epoch=600 f_loss=-1.8562 g_loss=-18.1619 | train mmd=0.0043 | test_mmd=0.0151\n",
      "[CellOT] epoch=650 f_loss=0.4010 g_loss=-15.7117 | train mmd=0.0036 | test_mmd=0.0089\n",
      "[CellOT] epoch=700 f_loss=0.7086 g_loss=-16.1543 | train mmd=0.0033 | test_mmd=0.0089\n",
      "[CellOT] epoch=750 f_loss=2.4440 g_loss=-14.6637 | train mmd=0.0032 | test_mmd=0.0079\n",
      "[CellOT] epoch=800 f_loss=-2.9051 g_loss=-13.6850 | train mmd=0.0033 | test_mmd=0.0087\n",
      "[CellOT] epoch=850 f_loss=-0.2437 g_loss=-16.2000 | train mmd=0.0035 | test_mmd=0.0090\n",
      "[CellOT] epoch=900 f_loss=-1.3362 g_loss=-14.8512 | train mmd=0.0030 | test_mmd=0.0096\n",
      "[CellOT] epoch=950 f_loss=-2.7825 g_loss=-15.5753 | train mmd=0.0031 | test_mmd=0.0069\n",
      "[CellOT] epoch=1000 f_loss=-5.5636 g_loss=-13.5432 | train mmd=0.0029 | test_mmd=0.0058\n",
      "[CellOT] Final CellOT MMD: 0.0039\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=5.5313 g_loss=-21.8284 | train mmd=0.0288 | test_mmd=0.1729\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.005785896152188497, 'mmd2_gamma_0.5': 0.008006067759292218, 'mmd2_gamma_1.0': 0.005748659399461566, 'wasserstein_distance': 2.17153751502047, 'R2_feature_means': 0.857630173705636}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-66.0462 g_loss=-65.6294 | train mmd=0.0095 | test_mmd=0.3699\n",
      "[CellOT] epoch=100 f_loss=-37.1215 g_loss=-34.4084 | train mmd=0.0095 | test_mmd=0.3553\n",
      "[CellOT] epoch=150 f_loss=-9.2543 g_loss=-24.7397 | train mmd=0.0095 | test_mmd=0.2448\n",
      "[CellOT] epoch=200 f_loss=-8.1011 g_loss=-23.4162 | train mmd=0.0091 | test_mmd=0.0927\n",
      "[CellOT] epoch=250 f_loss=-6.8900 g_loss=-20.6722 | train mmd=0.0082 | test_mmd=0.0506\n",
      "[CellOT] epoch=300 f_loss=-2.4104 g_loss=-19.4542 | train mmd=0.0075 | test_mmd=0.0347\n",
      "[CellOT] epoch=350 f_loss=-2.2850 g_loss=-25.8367 | train mmd=0.0067 | test_mmd=0.0227\n",
      "[CellOT] epoch=400 f_loss=-0.0836 g_loss=-18.2567 | train mmd=0.0061 | test_mmd=0.0147\n",
      "[CellOT] epoch=450 f_loss=-0.9699 g_loss=-18.3214 | train mmd=0.0048 | test_mmd=0.0108\n",
      "[CellOT] epoch=500 f_loss=-10.3739 g_loss=-19.1378 | train mmd=0.0045 | test_mmd=0.0109\n",
      "[CellOT] epoch=550 f_loss=-2.4364 g_loss=-15.9621 | train mmd=0.0047 | test_mmd=0.0108\n",
      "[CellOT] epoch=600 f_loss=-2.3942 g_loss=-18.8511 | train mmd=0.0037 | test_mmd=0.0094\n",
      "[CellOT] epoch=650 f_loss=-0.4348 g_loss=-15.7602 | train mmd=0.0030 | test_mmd=0.0060\n",
      "[CellOT] epoch=700 f_loss=-1.7809 g_loss=-19.9861 | train mmd=0.0032 | test_mmd=0.0107\n",
      "[CellOT] epoch=750 f_loss=-0.4139 g_loss=-16.8959 | train mmd=0.0042 | test_mmd=0.0106\n",
      "[CellOT] epoch=800 f_loss=-2.5428 g_loss=-17.8397 | train mmd=0.0030 | test_mmd=0.0075\n",
      "[CellOT] epoch=850 f_loss=-0.5476 g_loss=-17.4902 | train mmd=0.0028 | test_mmd=0.0084\n",
      "[CellOT] epoch=900 f_loss=-1.7734 g_loss=-16.1118 | train mmd=0.0029 | test_mmd=0.0064\n",
      "[CellOT] epoch=950 f_loss=3.5123 g_loss=-20.3902 | train mmd=0.0027 | test_mmd=0.0066\n",
      "[CellOT] epoch=1000 f_loss=1.3674 g_loss=-16.2443 | train mmd=0.0025 | test_mmd=0.0048\n",
      "[CellOT] Final CellOT MMD: 0.0035\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.004777820439936575, 'mmd2_gamma_0.5': 0.00699266111962471, 'mmd2_gamma_1.0': 0.005464505774328967, 'wasserstein_distance': 2.061278627965276, 'R2_feature_means': 0.8894562138074461}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=7.0584 g_loss=-26.7836 | train mmd=0.0175 | test_mmd=0.1128\n",
      "[CellOT] epoch=50 f_loss=-56.6846 g_loss=-53.8972 | train mmd=0.0095 | test_mmd=0.3702\n",
      "[CellOT] epoch=100 f_loss=-23.9141 g_loss=-30.0034 | train mmd=0.0095 | test_mmd=0.3324\n",
      "[CellOT] epoch=150 f_loss=-16.9719 g_loss=-21.5293 | train mmd=0.0095 | test_mmd=0.2565\n",
      "[CellOT] epoch=200 f_loss=-4.3006 g_loss=-25.0904 | train mmd=0.0092 | test_mmd=0.0997\n",
      "[CellOT] epoch=250 f_loss=-1.1919 g_loss=-18.3977 | train mmd=0.0084 | test_mmd=0.0460\n",
      "[CellOT] epoch=300 f_loss=-2.5991 g_loss=-17.8277 | train mmd=0.0081 | test_mmd=0.0385\n",
      "[CellOT] epoch=350 f_loss=1.2060 g_loss=-15.4926 | train mmd=0.0071 | test_mmd=0.0216\n",
      "[CellOT] epoch=400 f_loss=-0.4102 g_loss=-16.7296 | train mmd=0.0069 | test_mmd=0.0206\n",
      "[CellOT] epoch=450 f_loss=-3.7693 g_loss=-18.8976 | train mmd=0.0061 | test_mmd=0.0178\n",
      "[CellOT] epoch=500 f_loss=1.9918 g_loss=-15.0133 | train mmd=0.0057 | test_mmd=0.0135\n",
      "[CellOT] epoch=550 f_loss=2.1055 g_loss=-16.9100 | train mmd=0.0052 | test_mmd=0.0129\n",
      "[CellOT] epoch=600 f_loss=-0.8931 g_loss=-16.0464 | train mmd=0.0051 | test_mmd=0.0124\n",
      "[CellOT] epoch=650 f_loss=0.9136 g_loss=-16.3645 | train mmd=0.0046 | test_mmd=0.0097\n",
      "[CellOT] epoch=700 f_loss=7.6080 g_loss=-14.7729 | train mmd=0.0040 | test_mmd=0.0072\n",
      "[CellOT] epoch=750 f_loss=-0.2099 g_loss=-13.5747 | train mmd=0.0039 | test_mmd=0.0089\n",
      "[CellOT] epoch=800 f_loss=1.2045 g_loss=-14.7682 | train mmd=0.0038 | test_mmd=0.0073\n",
      "[CellOT] epoch=850 f_loss=-3.6731 g_loss=-18.2333 | train mmd=0.0033 | test_mmd=0.0072\n",
      "[CellOT] epoch=900 f_loss=-0.4800 g_loss=-16.7537 | train mmd=0.0033 | test_mmd=0.0049\n",
      "[CellOT] epoch=950 f_loss=-0.7771 g_loss=-15.9535 | train mmd=0.0029 | test_mmd=0.0071\n",
      "[CellOT] epoch=1000 f_loss=-2.1449 g_loss=-14.4312 | train mmd=0.0029 | test_mmd=0.0084\n",
      "[CellOT] Final CellOT MMD: 0.0050\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=6.5066 g_loss=-20.2516 | train mmd=0.0350 | test_mmd=0.1393\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.008403741960581246, 'mmd2_gamma_0.5': 0.007955602983182042, 'mmd2_gamma_1.0': 0.0056543036052734315, 'wasserstein_distance': 2.163880780137212, 'R2_feature_means': 0.6182751980494932}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-48.0094 g_loss=-45.9718 | train mmd=0.0095 | test_mmd=0.3706\n",
      "[CellOT] epoch=100 f_loss=-32.0841 g_loss=-27.4575 | train mmd=0.0095 | test_mmd=0.3466\n",
      "[CellOT] epoch=150 f_loss=-10.8391 g_loss=-25.9652 | train mmd=0.0095 | test_mmd=0.2019\n",
      "[CellOT] epoch=200 f_loss=-6.7875 g_loss=-26.5817 | train mmd=0.0091 | test_mmd=0.0795\n",
      "[CellOT] epoch=250 f_loss=-4.5433 g_loss=-21.8971 | train mmd=0.0084 | test_mmd=0.0422\n",
      "[CellOT] epoch=300 f_loss=-1.7119 g_loss=-18.5274 | train mmd=0.0076 | test_mmd=0.0294\n",
      "[CellOT] epoch=350 f_loss=-2.4469 g_loss=-21.5312 | train mmd=0.0071 | test_mmd=0.0272\n",
      "[CellOT] epoch=400 f_loss=-2.2806 g_loss=-17.4907 | train mmd=0.0059 | test_mmd=0.0189\n",
      "[CellOT] epoch=450 f_loss=-0.1841 g_loss=-16.9375 | train mmd=0.0054 | test_mmd=0.0133\n",
      "[CellOT] epoch=500 f_loss=-2.3736 g_loss=-16.6206 | train mmd=0.0042 | test_mmd=0.0112\n",
      "[CellOT] epoch=550 f_loss=-3.6008 g_loss=-16.8030 | train mmd=0.0037 | test_mmd=0.0104\n",
      "[CellOT] epoch=600 f_loss=-1.6688 g_loss=-16.9572 | train mmd=0.0037 | test_mmd=0.0123\n",
      "[CellOT] epoch=650 f_loss=-0.6131 g_loss=-19.0252 | train mmd=0.0029 | test_mmd=0.0061\n",
      "[CellOT] epoch=700 f_loss=-2.1051 g_loss=-17.2237 | train mmd=0.0033 | test_mmd=0.0087\n",
      "[CellOT] epoch=750 f_loss=-3.1908 g_loss=-15.8055 | train mmd=0.0029 | test_mmd=0.0068\n",
      "[CellOT] epoch=800 f_loss=-1.0786 g_loss=-15.1185 | train mmd=0.0028 | test_mmd=0.0097\n",
      "[CellOT] epoch=850 f_loss=-3.8480 g_loss=-14.3904 | train mmd=0.0029 | test_mmd=0.0066\n",
      "[CellOT] epoch=900 f_loss=-2.9245 g_loss=-17.1823 | train mmd=0.0027 | test_mmd=0.0060\n",
      "[CellOT] epoch=950 f_loss=-1.3324 g_loss=-17.2927 | train mmd=0.0035 | test_mmd=0.0110\n",
      "[CellOT] epoch=1000 f_loss=-1.3786 g_loss=-17.0342 | train mmd=0.0026 | test_mmd=0.0081\n",
      "[CellOT] Final CellOT MMD: 0.0047\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.008120804393337289, 'mmd2_gamma_0.5': 0.008119823928471936, 'mmd2_gamma_1.0': 0.005582890072574809, 'wasserstein_distance': 2.1892549922020668, 'R2_feature_means': 0.7628051225783309}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=5.8871 g_loss=-21.6512 | train mmd=0.0246 | test_mmd=0.1671\n",
      "[CellOT] epoch=50 f_loss=-62.3196 g_loss=-64.5159 | train mmd=0.0095 | test_mmd=0.3692\n",
      "[CellOT] epoch=100 f_loss=-32.9324 g_loss=-26.2483 | train mmd=0.0095 | test_mmd=0.3312\n",
      "[CellOT] epoch=150 f_loss=-11.6596 g_loss=-22.7081 | train mmd=0.0095 | test_mmd=0.2369\n",
      "[CellOT] epoch=200 f_loss=-7.4476 g_loss=-20.7892 | train mmd=0.0091 | test_mmd=0.0854\n",
      "[CellOT] epoch=250 f_loss=-3.4701 g_loss=-22.6656 | train mmd=0.0083 | test_mmd=0.0462\n",
      "[CellOT] epoch=300 f_loss=-2.0672 g_loss=-16.9873 | train mmd=0.0073 | test_mmd=0.0265\n",
      "[CellOT] epoch=350 f_loss=0.5190 g_loss=-19.2762 | train mmd=0.0064 | test_mmd=0.0166\n",
      "[CellOT] epoch=400 f_loss=2.1668 g_loss=-22.3089 | train mmd=0.0060 | test_mmd=0.0130\n",
      "[CellOT] epoch=450 f_loss=-2.2061 g_loss=-18.2902 | train mmd=0.0058 | test_mmd=0.0141\n",
      "[CellOT] epoch=500 f_loss=-2.4035 g_loss=-14.2093 | train mmd=0.0053 | test_mmd=0.0114\n",
      "[CellOT] epoch=550 f_loss=-2.9723 g_loss=-16.0099 | train mmd=0.0049 | test_mmd=0.0131\n",
      "[CellOT] epoch=600 f_loss=-0.6764 g_loss=-18.2569 | train mmd=0.0041 | test_mmd=0.0095\n",
      "[CellOT] epoch=650 f_loss=1.5856 g_loss=-16.3497 | train mmd=0.0037 | test_mmd=0.0072\n",
      "[CellOT] epoch=700 f_loss=-1.0292 g_loss=-17.2525 | train mmd=0.0034 | test_mmd=0.0069\n",
      "[CellOT] epoch=750 f_loss=0.0549 g_loss=-19.1386 | train mmd=0.0041 | test_mmd=0.0108\n",
      "[CellOT] epoch=800 f_loss=-1.3465 g_loss=-14.2426 | train mmd=0.0038 | test_mmd=0.0087\n",
      "[CellOT] epoch=850 f_loss=-0.3764 g_loss=-16.8257 | train mmd=0.0037 | test_mmd=0.0141\n",
      "[CellOT] epoch=900 f_loss=0.9525 g_loss=-15.4112 | train mmd=0.0036 | test_mmd=0.0098\n",
      "[CellOT] epoch=950 f_loss=2.2073 g_loss=-16.4194 | train mmd=0.0030 | test_mmd=0.0051\n",
      "[CellOT] epoch=1000 f_loss=-0.1960 g_loss=-17.6137 | train mmd=0.0041 | test_mmd=0.0103\n",
      "[CellOT] Final CellOT MMD: 0.0057\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.010334802729173309, 'mmd2_gamma_0.5': 0.01060856723906585, 'mmd2_gamma_1.0': 0.0066433727941816855, 'wasserstein_distance': 2.081819017954443, 'R2_feature_means': 0.7285301848558274}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=8.3565 g_loss=-23.5279 | train mmd=0.0216 | test_mmd=0.1969\n",
      "[CellOT] epoch=50 f_loss=-57.3623 g_loss=-60.3008 | train mmd=0.0095 | test_mmd=0.3685\n",
      "[CellOT] epoch=100 f_loss=-34.2652 g_loss=-26.6876 | train mmd=0.0095 | test_mmd=0.3395\n",
      "[CellOT] epoch=150 f_loss=-15.0490 g_loss=-19.6227 | train mmd=0.0095 | test_mmd=0.1703\n",
      "[CellOT] epoch=200 f_loss=-6.6132 g_loss=-19.9317 | train mmd=0.0091 | test_mmd=0.0710\n",
      "[CellOT] epoch=250 f_loss=-3.1630 g_loss=-18.3360 | train mmd=0.0082 | test_mmd=0.0349\n",
      "[CellOT] epoch=300 f_loss=-2.7045 g_loss=-19.8036 | train mmd=0.0071 | test_mmd=0.0237\n",
      "[CellOT] epoch=350 f_loss=-3.4189 g_loss=-20.6863 | train mmd=0.0066 | test_mmd=0.0186\n",
      "[CellOT] epoch=400 f_loss=-1.5280 g_loss=-17.4300 | train mmd=0.0064 | test_mmd=0.0180\n",
      "[CellOT] epoch=450 f_loss=-0.7515 g_loss=-17.4974 | train mmd=0.0066 | test_mmd=0.0214\n",
      "[CellOT] epoch=500 f_loss=-0.2141 g_loss=-15.9060 | train mmd=0.0049 | test_mmd=0.0106\n",
      "[CellOT] epoch=550 f_loss=-0.6598 g_loss=-17.4758 | train mmd=0.0043 | test_mmd=0.0094\n",
      "[CellOT] epoch=600 f_loss=0.3750 g_loss=-15.1593 | train mmd=0.0049 | test_mmd=0.0132\n",
      "[CellOT] epoch=650 f_loss=-0.5753 g_loss=-15.9907 | train mmd=0.0039 | test_mmd=0.0067\n",
      "[CellOT] epoch=700 f_loss=1.9365 g_loss=-14.2355 | train mmd=0.0036 | test_mmd=0.0060\n",
      "[CellOT] epoch=750 f_loss=-1.6351 g_loss=-15.1201 | train mmd=0.0041 | test_mmd=0.0091\n",
      "[CellOT] epoch=800 f_loss=-2.5834 g_loss=-15.5874 | train mmd=0.0032 | test_mmd=0.0068\n",
      "[CellOT] epoch=850 f_loss=1.9251 g_loss=-15.7193 | train mmd=0.0038 | test_mmd=0.0072\n",
      "[CellOT] epoch=900 f_loss=0.8019 g_loss=-17.6689 | train mmd=0.0036 | test_mmd=0.0063\n",
      "[CellOT] epoch=950 f_loss=0.4881 g_loss=-15.0266 | train mmd=0.0029 | test_mmd=0.0048\n",
      "[CellOT] epoch=1000 f_loss=-1.2951 g_loss=-17.7976 | train mmd=0.0030 | test_mmd=0.0088\n",
      "[CellOT] Final CellOT MMD: 0.0051\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.008782038596824804, 'mmd2_gamma_0.5': 0.00825642735004884, 'mmd2_gamma_1.0': 0.00597267570620299, 'wasserstein_distance': 2.259459476476999, 'R2_feature_means': 0.6810118998277157}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0076  0.0016\n",
      "mmd2_gamma_0.5        0.0082  0.0010\n",
      "mmd2_gamma_1.0        0.0058  0.0004\n",
      "wasserstein_distance  2.1469  0.0591\n",
      "R2_feature_means      0.7742  0.0837\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": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAEMCAYAAADAqxFbAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAADfT0lEQVR4nOz9d5xc5X33D79PnV53drZqtatVo6gh0UQHgRCY4hgTjBPbSW7HiZP4Trhz/+4UJ7/HjpO8/CSxnSe5bcexA4aAbcC2KKKKapolAWoItZVWq62zs9Prqc8fox3talcNJFQ479eLl72jM2euOXPO9b2ub/l8Bdu2bRwcHBwcHA4gnuoBODg4ODicXjiGwcHBwcFhEo5hcHBwcHCYhGMYHBwcHBwm4RgGBwcHB4dJOIbBwcHBwWESjmFwcHBwcJiEYxgcHBwcHCbhGAYHBwcHh0k4hsHhrOHll19GEARefvnlk3L+++67D0EQ6O3tPWHn7O3tRRAE7rvvvhN2TgeHD4tjGBwcPgIeeughvvOd75zqYTg4HBPyqR6Ag8OJ4sorr6RcLqOq6qkeyhQeeughtm7dyp/+6Z9Oen3mzJmUy2UURTk1A3NwmAbHMDicNYiiiNvtPtXDOC4EQTjjxuxw9uO4khzOKAYGBvi93/s9WltbcblcdHV18Yd/+IdomjZtjGHXrl186lOform5GbfbTXt7O3fddRfZbLZ+jCAI/PEf/zEPPvgg8+bNw+12s3TpUl599dWjjuexxx7j5ptvro+nu7ubv/u7v8M0zfoxV199NWvWrGHfvn0IgoAgCHR2dgLTxxi+8IUv4Pf7GRgY4Pbbb8fv99PY2Mif//mfTzqvg8PJwtkxOJwxDA4OctFFF5HJZPj93/995s+fz8DAAI8++iilUmnK8ZqmsXLlSqrVKn/yJ39Cc3MzAwMDPPnkk2QyGUKhUP3YV155hZ/97Gd85StfweVy8d3vfpcbb7yRdevWcf755x92TPfddx9+v5977rkHv9/Piy++yN/+7d+Sy+X4p3/6JwD++q//mmw2S39/P9/+9rcB8Pv9R/yupmmycuVKLr74Yv75n/+ZtWvX8i//8i90d3fzh3/4hx/k8jk4HDu2g8MZwuc+9zlbFEV7/fr1U/7Nsiz7pZdesgH7pZdesm3btt99910bsB955JEjnhewAXvDhg311/bt22e73W77k5/8ZP21e++91wbsvXv31l8rlUpTzvelL33J9nq9dqVSqb9288032zNnzpxy7N69e23Avvfee+uvff7zn7cB++tf//qkY5csWWIvXbr0iN/FweFE4LiSHM4ILMti9erV3HLLLSxbtmzKvwuCMOW18R3Bs88+O+2OYiKXXnopS5curf/d0dHBbbfdxrPPPntE943H46n//3w+TzKZ5IorrqBUKrF9+/ajfq8j8Qd/8AeT/r7iiivYs2fPhzqng8Ox4BgGhzOC0dFRcrncEd06h9LV1cU999zDD3/4Q2KxGCtXruT//t//Oym+MM6cOXOmvDZ37lxKpRKjo6OH/Yz33nuPT37yk4RCIYLBII2NjfzWb/0WwLSfc6y43W4aGxsnvRaJREin0x/4nA4Ox4pjGBzOav7lX/6FzZs381d/9VeUy2W+8pWvcN5559Hf3/+hz53JZLjqqqvYtGkTX//613niiSd4/vnn+eY3vwnUdjkfFEmSPvT4HBw+KE7w2eGMoLGxkWAwyNatW4/7vQsWLGDBggV89atf5Y033uCyyy7j+9//Pt/4xjfqx+zatWvK+3bu3InX652ych/n5ZdfZmxsjF/84hdceeWV9df37t075djpXF0ODqcrzo7B4YxAFEVuv/12nnjiCTZs2DDl323bnvJaLpfDMIxJry1YsABRFKlWq5Nef/PNN3nnnXfqf+/fv5/HHnuMG2644bCr9/HXJ362pml897vfnXKsz+f7UK4lB4ePEmfH4HDG8A//8A8899xzXHXVVfz+7/8+55xzDkNDQzzyyCO89tprU45/8cUX+eM//mM+/elPM3fuXAzD4IEHHkCSJD71qU9NOvb8889n5cqVk9JVAb72ta8ddjzLly8nEonw+c9/nq985SsIgsADDzwwrZFaunQpP/vZz7jnnnu48MIL8fv93HLLLR/yijg4nBwcw+BwxtDW1savf/1r/uZv/oYHH3yQXC5HW1sbq1atwuv1Tjl+0aJFrFy5kieeeIKBgQG8Xi+LFi3i6aef5pJLLpl07FVXXcWll17K1772Nfr6+jj33HO57777WLhw4WHH09DQwJNPPsn/+l//i69+9atEIhF+67d+i+uuu46VK1dOOvbLX/4yGzdu5N577+Xb3/42M2fOdAyDw2mLYE+3vHFw+BghCAJ/9Ed/xL//+7+f6qE4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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"cisplatin\"\n",
    "X_pre = adata_4i[adata_4i.obs[\"drug\"] == \"control\"].copy().to_df()[features_4i]\n",
    "X_post  = adata_4i[adata_4i.obs[\"drug\"] == drug].copy().to_df()[features_4i]\n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "X_tr_pre, X_te_pre, Y_tr_post, Y_te_post = split_train_test(X_pre.values, X_post.values, 0.8)\n",
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "# Compute median heuristic gamma on training data\n",
    "median_gamma = median_heuristic_gamma(X_tr_pre, Y_tr_post)\n",
    "print(\"Median heuristic gamma:\", median_gamma)\n",
    "\n",
    "\n",
    "all_metrics = []\n",
    "for run in range(10):\n",
    "    print(f\"**************** Run: {run} ****************\")\n",
    "    seed = 1234 + run\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "\n",
    "    out = run_cellot_pair(X_tr_pre, Y_tr_post, X_te_pre, Y_te_post, n_epochs=1000)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post, median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post\n",
    "target = Y_te_post\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#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": 15,
   "id": "07d396d9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (10995, 48)\n",
      "X_post cells: (2796, 48)\n",
      "(2236, 48)\n",
      "(560, 48)\n",
      "(2236, 48)\n",
      "(560, 48)\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=4.2520 g_loss=-22.1461 | train mmd=0.0169 | test_mmd=0.1379\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Median heuristic gamma: 0.074449069228528\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-50.8781 g_loss=-45.3711 | train mmd=0.0089 | test_mmd=0.3743\n",
      "[CellOT] epoch=100 f_loss=-34.0888 g_loss=-38.9261 | train mmd=0.0089 | test_mmd=0.3653\n",
      "[CellOT] epoch=150 f_loss=-13.6125 g_loss=-21.3325 | train mmd=0.0088 | test_mmd=0.1967\n",
      "[CellOT] epoch=200 f_loss=-4.3906 g_loss=-26.1326 | train mmd=0.0079 | test_mmd=0.0509\n",
      "[CellOT] epoch=250 f_loss=-3.2497 g_loss=-18.5222 | train mmd=0.0069 | test_mmd=0.0237\n",
      "[CellOT] epoch=300 f_loss=-1.7336 g_loss=-18.5779 | train mmd=0.0063 | test_mmd=0.0265\n",
      "[CellOT] epoch=350 f_loss=-0.2465 g_loss=-19.0863 | train mmd=0.0057 | test_mmd=0.0148\n",
      "[CellOT] epoch=400 f_loss=-2.1454 g_loss=-19.5254 | train mmd=0.0060 | test_mmd=0.0205\n",
      "[CellOT] epoch=450 f_loss=-2.6862 g_loss=-18.4395 | train mmd=0.0055 | test_mmd=0.0133\n",
      "[CellOT] epoch=500 f_loss=0.0147 g_loss=-18.9072 | train mmd=0.0048 | test_mmd=0.0120\n",
      "[CellOT] epoch=550 f_loss=-1.8500 g_loss=-16.4567 | train mmd=0.0043 | test_mmd=0.0099\n",
      "[CellOT] epoch=600 f_loss=-2.2499 g_loss=-16.4235 | train mmd=0.0043 | test_mmd=0.0109\n",
      "[CellOT] epoch=650 f_loss=-1.1256 g_loss=-14.7479 | train mmd=0.0039 | test_mmd=0.0056\n",
      "[CellOT] epoch=700 f_loss=-7.3834 g_loss=-19.4889 | train mmd=0.0039 | test_mmd=0.0078\n",
      "[CellOT] epoch=750 f_loss=1.3993 g_loss=-18.5222 | train mmd=0.0038 | test_mmd=0.0062\n",
      "[CellOT] epoch=800 f_loss=-0.3742 g_loss=-15.8554 | train mmd=0.0056 | test_mmd=0.0174\n",
      "[CellOT] epoch=850 f_loss=-1.7930 g_loss=-15.3465 | train mmd=0.0044 | test_mmd=0.0078\n",
      "[CellOT] epoch=900 f_loss=-0.9871 g_loss=-16.0289 | train mmd=0.0047 | test_mmd=0.0067\n",
      "[CellOT] epoch=950 f_loss=1.9156 g_loss=-19.0457 | train mmd=0.0050 | test_mmd=0.0102\n",
      "[CellOT] epoch=1000 f_loss=-0.5505 g_loss=-15.3561 | train mmd=0.0035 | test_mmd=0.0042\n",
      "[CellOT] Final CellOT MMD: 0.0036\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=5.8960 g_loss=-21.4546 | train mmd=0.0274 | test_mmd=0.1607\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 0 metrics: {'mmd2_gamma_median': 0.0042129061187768935, 'mmd2_gamma_0.5': 0.008491672101164222, 'mmd2_gamma_1.0': 0.006443584865053514, 'wasserstein_distance': 2.132184245024767, 'R2_feature_means': 0.9451230702537583}\n",
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-60.6897 g_loss=-56.7986 | train mmd=0.0089 | test_mmd=0.3769\n",
      "[CellOT] epoch=100 f_loss=-29.2930 g_loss=-32.1089 | train mmd=0.0089 | test_mmd=0.3720\n",
      "[CellOT] epoch=150 f_loss=-18.9722 g_loss=-29.2917 | train mmd=0.0088 | test_mmd=0.2618\n",
      "[CellOT] epoch=200 f_loss=-8.9338 g_loss=-19.8803 | train mmd=0.0086 | test_mmd=0.1108\n",
      "[CellOT] epoch=250 f_loss=-6.6646 g_loss=-18.7304 | train mmd=0.0076 | test_mmd=0.0455\n",
      "[CellOT] epoch=300 f_loss=-2.6128 g_loss=-17.7890 | train mmd=0.0069 | test_mmd=0.0318\n",
      "[CellOT] epoch=350 f_loss=-4.4107 g_loss=-20.4546 | train mmd=0.0067 | test_mmd=0.0250\n",
      "[CellOT] epoch=400 f_loss=-2.4330 g_loss=-16.0538 | train mmd=0.0057 | test_mmd=0.0199\n",
      "[CellOT] epoch=450 f_loss=-2.6302 g_loss=-18.8404 | train mmd=0.0051 | test_mmd=0.0168\n",
      "[CellOT] epoch=500 f_loss=-0.7161 g_loss=-17.0594 | train mmd=0.0047 | test_mmd=0.0138\n",
      "[CellOT] epoch=550 f_loss=-0.1826 g_loss=-15.5745 | train mmd=0.0049 | test_mmd=0.0119\n",
      "[CellOT] epoch=600 f_loss=4.2987 g_loss=-12.3989 | train mmd=0.0044 | test_mmd=0.0084\n",
      "[CellOT] epoch=650 f_loss=-0.2766 g_loss=-13.3673 | train mmd=0.0044 | test_mmd=0.0085\n",
      "[CellOT] epoch=700 f_loss=2.0001 g_loss=-12.3308 | train mmd=0.0050 | test_mmd=0.0160\n",
      "[CellOT] epoch=750 f_loss=0.8641 g_loss=-15.9291 | train mmd=0.0048 | test_mmd=0.0106\n",
      "[CellOT] epoch=800 f_loss=2.3906 g_loss=-14.9699 | train mmd=0.0040 | test_mmd=0.0118\n",
      "[CellOT] epoch=850 f_loss=3.8390 g_loss=-14.4752 | train mmd=0.0055 | test_mmd=0.0113\n",
      "[CellOT] epoch=900 f_loss=2.6245 g_loss=-14.5858 | train mmd=0.0053 | test_mmd=0.0108\n",
      "[CellOT] epoch=950 f_loss=1.2025 g_loss=-17.1350 | train mmd=0.0050 | test_mmd=0.0094\n",
      "[CellOT] epoch=1000 f_loss=1.9411 g_loss=-16.6420 | train mmd=0.0051 | test_mmd=0.0087\n",
      "[CellOT] Final CellOT MMD: 0.0058\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=6.6862 g_loss=-23.7971 | train mmd=0.0234 | test_mmd=0.2083\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 1 metrics: {'mmd2_gamma_median': 0.008721874283657227, 'mmd2_gamma_0.5': 0.013082934781538873, 'mmd2_gamma_1.0': 0.00831674959611371, 'wasserstein_distance': 2.2334120617493705, 'R2_feature_means': 0.898184742674494}\n",
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-51.8394 g_loss=-53.2496 | train mmd=0.0089 | test_mmd=0.3768\n",
      "[CellOT] epoch=100 f_loss=-26.4215 g_loss=-33.2276 | train mmd=0.0089 | test_mmd=0.3664\n",
      "[CellOT] epoch=150 f_loss=-9.4990 g_loss=-25.1309 | train mmd=0.0088 | test_mmd=0.2823\n",
      "[CellOT] epoch=200 f_loss=-12.1088 g_loss=-22.0019 | train mmd=0.0085 | test_mmd=0.0896\n",
      "[CellOT] epoch=250 f_loss=-8.1825 g_loss=-20.7665 | train mmd=0.0078 | test_mmd=0.0388\n",
      "[CellOT] epoch=300 f_loss=-4.0997 g_loss=-17.7461 | train mmd=0.0073 | test_mmd=0.0243\n",
      "[CellOT] epoch=350 f_loss=-7.0473 g_loss=-20.2878 | train mmd=0.0070 | test_mmd=0.0264\n",
      "[CellOT] epoch=400 f_loss=0.0142 g_loss=-22.7047 | train mmd=0.0062 | test_mmd=0.0158\n",
      "[CellOT] epoch=450 f_loss=-1.1094 g_loss=-15.7158 | train mmd=0.0060 | test_mmd=0.0166\n",
      "[CellOT] epoch=500 f_loss=-1.1971 g_loss=-15.5253 | train mmd=0.0051 | test_mmd=0.0111\n",
      "[CellOT] epoch=550 f_loss=0.6402 g_loss=-16.1537 | train mmd=0.0049 | test_mmd=0.0096\n",
      "[CellOT] epoch=600 f_loss=-3.1501 g_loss=-17.8186 | train mmd=0.0038 | test_mmd=0.0074\n",
      "[CellOT] epoch=650 f_loss=0.9136 g_loss=-17.7553 | train mmd=0.0044 | test_mmd=0.0064\n",
      "[CellOT] epoch=700 f_loss=-2.0530 g_loss=-17.7444 | train mmd=0.0047 | test_mmd=0.0104\n",
      "[CellOT] epoch=750 f_loss=0.9300 g_loss=-16.4947 | train mmd=0.0049 | test_mmd=0.0079\n",
      "[CellOT] epoch=800 f_loss=-0.3418 g_loss=-15.3111 | train mmd=0.0041 | test_mmd=0.0150\n",
      "[CellOT] epoch=850 f_loss=-1.2397 g_loss=-15.0051 | train mmd=0.0050 | test_mmd=0.0074\n",
      "[CellOT] epoch=900 f_loss=0.3149 g_loss=-14.9742 | train mmd=0.0057 | test_mmd=0.0126\n",
      "[CellOT] epoch=950 f_loss=-1.0122 g_loss=-15.1062 | train mmd=0.0035 | test_mmd=0.0096\n",
      "[CellOT] epoch=1000 f_loss=2.2026 g_loss=-16.9756 | train mmd=0.0038 | test_mmd=0.0062\n",
      "[CellOT] Final CellOT MMD: 0.0044\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=2.4626 g_loss=-26.9314 | train mmd=0.0268 | test_mmd=0.1686\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 2 metrics: {'mmd2_gamma_median': 0.0062120338322980695, 'mmd2_gamma_0.5': 0.009176520055779555, 'mmd2_gamma_1.0': 0.0066528157960730385, 'wasserstein_distance': 2.2376603794236325, 'R2_feature_means': 0.8629168976359332}\n",
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-58.4390 g_loss=-50.3687 | train mmd=0.0089 | test_mmd=0.3760\n",
      "[CellOT] epoch=100 f_loss=-38.0451 g_loss=-28.6233 | train mmd=0.0089 | test_mmd=0.3703\n",
      "[CellOT] epoch=150 f_loss=-13.9307 g_loss=-27.6979 | train mmd=0.0088 | test_mmd=0.2275\n",
      "[CellOT] epoch=200 f_loss=-4.7743 g_loss=-18.9301 | train mmd=0.0083 | test_mmd=0.0784\n",
      "[CellOT] epoch=250 f_loss=-3.0198 g_loss=-21.2465 | train mmd=0.0075 | test_mmd=0.0323\n",
      "[CellOT] epoch=300 f_loss=-0.2423 g_loss=-19.5428 | train mmd=0.0064 | test_mmd=0.0221\n",
      "[CellOT] epoch=350 f_loss=1.1588 g_loss=-21.6519 | train mmd=0.0062 | test_mmd=0.0196\n",
      "[CellOT] epoch=400 f_loss=-2.9091 g_loss=-16.0366 | train mmd=0.0058 | test_mmd=0.0127\n",
      "[CellOT] epoch=450 f_loss=-2.0218 g_loss=-16.6140 | train mmd=0.0050 | test_mmd=0.0096\n",
      "[CellOT] epoch=500 f_loss=-0.0721 g_loss=-15.5469 | train mmd=0.0048 | test_mmd=0.0075\n",
      "[CellOT] epoch=550 f_loss=-0.8173 g_loss=-15.0605 | train mmd=0.0052 | test_mmd=0.0154\n",
      "[CellOT] epoch=600 f_loss=-3.1648 g_loss=-21.9678 | train mmd=0.0048 | test_mmd=0.0094\n",
      "[CellOT] epoch=650 f_loss=-5.1595 g_loss=-12.8943 | train mmd=0.0047 | test_mmd=0.0081\n",
      "[CellOT] epoch=700 f_loss=-0.9057 g_loss=-15.9338 | train mmd=0.0042 | test_mmd=0.0083\n",
      "[CellOT] epoch=750 f_loss=3.0399 g_loss=-16.4102 | train mmd=0.0039 | test_mmd=0.0048\n",
      "[CellOT] epoch=800 f_loss=1.1781 g_loss=-14.1597 | train mmd=0.0045 | test_mmd=0.0065\n",
      "[CellOT] epoch=850 f_loss=-2.0000 g_loss=-13.9541 | train mmd=0.0043 | test_mmd=0.0075\n",
      "[CellOT] epoch=900 f_loss=-0.4616 g_loss=-15.3511 | train mmd=0.0035 | test_mmd=0.0047\n",
      "[CellOT] epoch=950 f_loss=0.4478 g_loss=-16.8045 | train mmd=0.0048 | test_mmd=0.0077\n",
      "[CellOT] epoch=1000 f_loss=-1.3270 g_loss=-16.7497 | train mmd=0.0037 | test_mmd=0.0066\n",
      "[CellOT] Final CellOT MMD: 0.0046\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=6.6436 g_loss=-33.3212 | train mmd=0.0336 | test_mmd=0.2566\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 3 metrics: {'mmd2_gamma_median': 0.006594109119681613, 'mmd2_gamma_0.5': 0.009629882249926128, 'mmd2_gamma_1.0': 0.0066679422699341614, 'wasserstein_distance': 2.168001482945618, 'R2_feature_means': 0.8831578182165795}\n",
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-75.0853 g_loss=-68.9521 | train mmd=0.0089 | test_mmd=0.3772\n",
      "[CellOT] epoch=100 f_loss=-32.1061 g_loss=-34.4650 | train mmd=0.0089 | test_mmd=0.3557\n",
      "[CellOT] epoch=150 f_loss=-12.9640 g_loss=-21.1755 | train mmd=0.0088 | test_mmd=0.2550\n",
      "[CellOT] epoch=200 f_loss=-9.6213 g_loss=-24.7320 | train mmd=0.0083 | test_mmd=0.0785\n",
      "[CellOT] epoch=250 f_loss=-5.7229 g_loss=-20.9107 | train mmd=0.0077 | test_mmd=0.0433\n",
      "[CellOT] epoch=300 f_loss=-2.6050 g_loss=-22.8251 | train mmd=0.0070 | test_mmd=0.0283\n",
      "[CellOT] epoch=350 f_loss=-0.7698 g_loss=-15.9523 | train mmd=0.0066 | test_mmd=0.0196\n",
      "[CellOT] epoch=400 f_loss=-0.2278 g_loss=-16.2914 | train mmd=0.0065 | test_mmd=0.0190\n",
      "[CellOT] epoch=450 f_loss=-1.7515 g_loss=-16.0633 | train mmd=0.0061 | test_mmd=0.0169\n",
      "[CellOT] epoch=500 f_loss=-2.8833 g_loss=-17.5657 | train mmd=0.0056 | test_mmd=0.0133\n",
      "[CellOT] epoch=550 f_loss=0.2538 g_loss=-15.2557 | train mmd=0.0054 | test_mmd=0.0136\n",
      "[CellOT] epoch=600 f_loss=-1.5397 g_loss=-14.6145 | train mmd=0.0058 | test_mmd=0.0147\n",
      "[CellOT] epoch=650 f_loss=-0.2043 g_loss=-15.9393 | train mmd=0.0054 | test_mmd=0.0099\n",
      "[CellOT] epoch=700 f_loss=-1.1551 g_loss=-16.2125 | train mmd=0.0048 | test_mmd=0.0080\n",
      "[CellOT] epoch=750 f_loss=2.4489 g_loss=-19.1332 | train mmd=0.0051 | test_mmd=0.0060\n",
      "[CellOT] epoch=800 f_loss=2.3229 g_loss=-15.8248 | train mmd=0.0039 | test_mmd=0.0077\n",
      "[CellOT] epoch=850 f_loss=0.1572 g_loss=-13.7664 | train mmd=0.0045 | test_mmd=0.0080\n",
      "[CellOT] epoch=900 f_loss=1.5834 g_loss=-15.1725 | train mmd=0.0053 | test_mmd=0.0084\n",
      "[CellOT] epoch=950 f_loss=1.7251 g_loss=-18.3093 | train mmd=0.0050 | test_mmd=0.0078\n",
      "[CellOT] epoch=1000 f_loss=2.7104 g_loss=-14.9884 | train mmd=0.0041 | test_mmd=0.0089\n",
      "[CellOT] Final CellOT MMD: 0.0057\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=6.0821 g_loss=-22.7006 | train mmd=0.0283 | test_mmd=0.1808\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 4 metrics: {'mmd2_gamma_median': 0.008942412711925862, 'mmd2_gamma_0.5': 0.011272141305860392, 'mmd2_gamma_1.0': 0.007491939426555183, 'wasserstein_distance': 2.2986252947587276, 'R2_feature_means': 0.8125849422978098}\n",
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-62.4547 g_loss=-57.7220 | train mmd=0.0089 | test_mmd=0.3770\n",
      "[CellOT] epoch=100 f_loss=-35.7483 g_loss=-31.5802 | train mmd=0.0089 | test_mmd=0.3627\n",
      "[CellOT] epoch=150 f_loss=-10.7584 g_loss=-20.8285 | train mmd=0.0088 | test_mmd=0.1855\n",
      "[CellOT] epoch=200 f_loss=-6.6450 g_loss=-19.7644 | train mmd=0.0085 | test_mmd=0.0803\n",
      "[CellOT] epoch=250 f_loss=1.7400 g_loss=-18.1173 | train mmd=0.0079 | test_mmd=0.0425\n",
      "[CellOT] epoch=300 f_loss=3.0158 g_loss=-17.0742 | train mmd=0.0068 | test_mmd=0.0205\n",
      "[CellOT] epoch=350 f_loss=-0.2854 g_loss=-21.0021 | train mmd=0.0064 | test_mmd=0.0187\n",
      "[CellOT] epoch=400 f_loss=0.3954 g_loss=-17.5638 | train mmd=0.0059 | test_mmd=0.0154\n",
      "[CellOT] epoch=450 f_loss=1.7705 g_loss=-20.5123 | train mmd=0.0051 | test_mmd=0.0105\n",
      "[CellOT] epoch=500 f_loss=0.0636 g_loss=-20.2841 | train mmd=0.0046 | test_mmd=0.0083\n",
      "[CellOT] epoch=550 f_loss=-1.3829 g_loss=-18.1761 | train mmd=0.0047 | test_mmd=0.0156\n",
      "[CellOT] epoch=600 f_loss=2.0790 g_loss=-15.8189 | train mmd=0.0037 | test_mmd=0.0093\n",
      "[CellOT] epoch=650 f_loss=0.5855 g_loss=-19.7837 | train mmd=0.0036 | test_mmd=0.0051\n",
      "[CellOT] epoch=700 f_loss=-1.6167 g_loss=-15.8369 | train mmd=0.0035 | test_mmd=0.0087\n",
      "[CellOT] epoch=750 f_loss=-0.0176 g_loss=-14.6754 | train mmd=0.0040 | test_mmd=0.0080\n",
      "[CellOT] epoch=800 f_loss=-0.0006 g_loss=-16.3680 | train mmd=0.0046 | test_mmd=0.0099\n",
      "[CellOT] epoch=850 f_loss=3.4650 g_loss=-16.8115 | train mmd=0.0042 | test_mmd=0.0084\n",
      "[CellOT] epoch=900 f_loss=1.5719 g_loss=-18.3840 | train mmd=0.0036 | test_mmd=0.0074\n",
      "[CellOT] epoch=950 f_loss=-2.0388 g_loss=-15.6166 | train mmd=0.0046 | test_mmd=0.0104\n",
      "[CellOT] epoch=1000 f_loss=-0.3044 g_loss=-17.1002 | train mmd=0.0040 | test_mmd=0.0049\n",
      "[CellOT] Final CellOT MMD: 0.0041\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=5.7539 g_loss=-22.2842 | train mmd=0.0181 | test_mmd=0.1423\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 5 metrics: {'mmd2_gamma_median': 0.004947956666874087, 'mmd2_gamma_0.5': 0.00990302153176166, 'mmd2_gamma_1.0': 0.007079072452098052, 'wasserstein_distance': 2.1261938340610635, 'R2_feature_means': 0.9435916531319659}\n",
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-54.5982 g_loss=-54.7954 | train mmd=0.0089 | test_mmd=0.3773\n",
      "[CellOT] epoch=100 f_loss=-23.6541 g_loss=-34.5338 | train mmd=0.0089 | test_mmd=0.3264\n",
      "[CellOT] epoch=150 f_loss=-10.6246 g_loss=-20.2740 | train mmd=0.0088 | test_mmd=0.2082\n",
      "[CellOT] epoch=200 f_loss=-3.9078 g_loss=-19.3562 | train mmd=0.0084 | test_mmd=0.0650\n",
      "[CellOT] epoch=250 f_loss=-2.6304 g_loss=-19.2087 | train mmd=0.0076 | test_mmd=0.0380\n",
      "[CellOT] epoch=300 f_loss=-6.5237 g_loss=-19.2597 | train mmd=0.0071 | test_mmd=0.0305\n",
      "[CellOT] epoch=350 f_loss=-2.6220 g_loss=-17.2169 | train mmd=0.0064 | test_mmd=0.0202\n",
      "[CellOT] epoch=400 f_loss=-3.1116 g_loss=-20.1282 | train mmd=0.0054 | test_mmd=0.0105\n",
      "[CellOT] epoch=450 f_loss=-2.0564 g_loss=-19.8479 | train mmd=0.0052 | test_mmd=0.0117\n",
      "[CellOT] epoch=500 f_loss=-0.4904 g_loss=-21.7151 | train mmd=0.0045 | test_mmd=0.0127\n",
      "[CellOT] epoch=550 f_loss=-0.9715 g_loss=-14.6167 | train mmd=0.0049 | test_mmd=0.0082\n",
      "[CellOT] epoch=600 f_loss=2.5740 g_loss=-14.4595 | train mmd=0.0047 | test_mmd=0.0081\n",
      "[CellOT] epoch=650 f_loss=-4.9342 g_loss=-16.0695 | train mmd=0.0044 | test_mmd=0.0114\n",
      "[CellOT] epoch=700 f_loss=0.0149 g_loss=-15.6460 | train mmd=0.0041 | test_mmd=0.0116\n",
      "[CellOT] epoch=750 f_loss=2.0848 g_loss=-17.3245 | train mmd=0.0045 | test_mmd=0.0076\n",
      "[CellOT] epoch=800 f_loss=-1.1406 g_loss=-17.1512 | train mmd=0.0043 | test_mmd=0.0081\n",
      "[CellOT] epoch=850 f_loss=1.8690 g_loss=-17.8541 | train mmd=0.0046 | test_mmd=0.0128\n",
      "[CellOT] epoch=900 f_loss=0.5660 g_loss=-16.2585 | train mmd=0.0035 | test_mmd=0.0118\n",
      "[CellOT] epoch=950 f_loss=3.6837 g_loss=-14.3017 | train mmd=0.0041 | test_mmd=0.0086\n",
      "[CellOT] epoch=1000 f_loss=-2.4091 g_loss=-17.0050 | train mmd=0.0043 | test_mmd=0.0080\n",
      "[CellOT] Final CellOT MMD: 0.0053\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 6 metrics: {'mmd2_gamma_median': 0.00800798748918441, 'mmd2_gamma_0.5': 0.01207085104705223, 'mmd2_gamma_1.0': 0.007692279417491569, 'wasserstein_distance': 2.2600931170840255, 'R2_feature_means': 0.9244163832868278}\n",
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=6.5419 g_loss=-25.9349 | train mmd=0.0317 | test_mmd=0.1691\n",
      "[CellOT] epoch=50 f_loss=-61.6099 g_loss=-44.1236 | train mmd=0.0089 | test_mmd=0.3761\n",
      "[CellOT] epoch=100 f_loss=-23.3608 g_loss=-33.7429 | train mmd=0.0089 | test_mmd=0.3321\n",
      "[CellOT] epoch=150 f_loss=-7.5232 g_loss=-23.6364 | train mmd=0.0088 | test_mmd=0.1739\n",
      "[CellOT] epoch=200 f_loss=-6.9662 g_loss=-18.4036 | train mmd=0.0082 | test_mmd=0.0696\n",
      "[CellOT] epoch=250 f_loss=-2.9928 g_loss=-21.2349 | train mmd=0.0079 | test_mmd=0.0454\n",
      "[CellOT] epoch=300 f_loss=-1.7212 g_loss=-20.7896 | train mmd=0.0069 | test_mmd=0.0267\n",
      "[CellOT] epoch=350 f_loss=0.4803 g_loss=-17.3029 | train mmd=0.0069 | test_mmd=0.0264\n",
      "[CellOT] epoch=400 f_loss=-0.5721 g_loss=-15.9576 | train mmd=0.0061 | test_mmd=0.0207\n",
      "[CellOT] epoch=450 f_loss=-1.3969 g_loss=-15.7217 | train mmd=0.0056 | test_mmd=0.0187\n",
      "[CellOT] epoch=500 f_loss=-4.1110 g_loss=-16.8508 | train mmd=0.0050 | test_mmd=0.0220\n",
      "[CellOT] epoch=550 f_loss=-0.0073 g_loss=-15.3843 | train mmd=0.0051 | test_mmd=0.0118\n",
      "[CellOT] epoch=600 f_loss=-3.4848 g_loss=-14.8708 | train mmd=0.0057 | test_mmd=0.0124\n",
      "[CellOT] epoch=650 f_loss=0.8756 g_loss=-16.9093 | train mmd=0.0040 | test_mmd=0.0078\n",
      "[CellOT] epoch=700 f_loss=0.2135 g_loss=-17.8151 | train mmd=0.0047 | test_mmd=0.0127\n",
      "[CellOT] epoch=750 f_loss=-1.4683 g_loss=-15.4189 | train mmd=0.0039 | test_mmd=0.0172\n",
      "[CellOT] epoch=800 f_loss=-1.3064 g_loss=-18.7867 | train mmd=0.0043 | test_mmd=0.0068\n",
      "[CellOT] epoch=850 f_loss=-0.8785 g_loss=-18.0640 | train mmd=0.0041 | test_mmd=0.0109\n",
      "[CellOT] epoch=900 f_loss=-1.0357 g_loss=-14.6704 | train mmd=0.0049 | test_mmd=0.0100\n",
      "[CellOT] epoch=950 f_loss=-1.7000 g_loss=-19.6573 | train mmd=0.0042 | test_mmd=0.0094\n",
      "[CellOT] epoch=1000 f_loss=3.0234 g_loss=-16.3801 | train mmd=0.0046 | test_mmd=0.0106\n",
      "[CellOT] Final CellOT MMD: 0.0062\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 7 metrics: {'mmd2_gamma_median': 0.010601580723117454, 'mmd2_gamma_0.5': 0.012154754600786855, 'mmd2_gamma_1.0': 0.00779975612784474, 'wasserstein_distance': 2.2906804821340945, 'R2_feature_means': 0.8713982464785729}\n",
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=0 f_loss=4.6580 g_loss=-21.8326 | train mmd=0.0219 | test_mmd=0.1455\n",
      "[CellOT] epoch=50 f_loss=-65.4934 g_loss=-52.1490 | train mmd=0.0089 | test_mmd=0.3767\n",
      "[CellOT] epoch=100 f_loss=-31.0241 g_loss=-27.0149 | train mmd=0.0089 | test_mmd=0.3373\n",
      "[CellOT] epoch=150 f_loss=-13.7294 g_loss=-26.2777 | train mmd=0.0088 | test_mmd=0.1896\n",
      "[CellOT] epoch=200 f_loss=-5.8855 g_loss=-20.8037 | train mmd=0.0083 | test_mmd=0.0705\n",
      "[CellOT] epoch=250 f_loss=-2.2535 g_loss=-19.1383 | train mmd=0.0073 | test_mmd=0.0340\n",
      "[CellOT] epoch=300 f_loss=-2.7002 g_loss=-18.0102 | train mmd=0.0063 | test_mmd=0.0219\n",
      "[CellOT] epoch=350 f_loss=-6.6498 g_loss=-16.1733 | train mmd=0.0061 | test_mmd=0.0161\n",
      "[CellOT] epoch=400 f_loss=0.1476 g_loss=-17.2348 | train mmd=0.0057 | test_mmd=0.0137\n",
      "[CellOT] epoch=450 f_loss=0.3810 g_loss=-17.3651 | train mmd=0.0057 | test_mmd=0.0150\n",
      "[CellOT] epoch=500 f_loss=0.0558 g_loss=-17.5904 | train mmd=0.0044 | test_mmd=0.0093\n",
      "[CellOT] epoch=550 f_loss=-5.7483 g_loss=-15.7316 | train mmd=0.0045 | test_mmd=0.0104\n",
      "[CellOT] epoch=600 f_loss=-0.6930 g_loss=-15.9956 | train mmd=0.0049 | test_mmd=0.0106\n",
      "[CellOT] epoch=650 f_loss=-3.0825 g_loss=-15.4430 | train mmd=0.0044 | test_mmd=0.0078\n",
      "[CellOT] epoch=700 f_loss=0.8105 g_loss=-16.8904 | train mmd=0.0053 | test_mmd=0.0117\n",
      "[CellOT] epoch=750 f_loss=-2.9355 g_loss=-14.9067 | train mmd=0.0042 | test_mmd=0.0072\n",
      "[CellOT] epoch=800 f_loss=-3.2107 g_loss=-18.9796 | train mmd=0.0046 | test_mmd=0.0090\n",
      "[CellOT] epoch=850 f_loss=0.5824 g_loss=-19.0118 | train mmd=0.0042 | test_mmd=0.0078\n",
      "[CellOT] epoch=900 f_loss=-3.8934 g_loss=-19.4407 | train mmd=0.0050 | test_mmd=0.0124\n",
      "[CellOT] epoch=950 f_loss=-0.2178 g_loss=-14.2898 | train mmd=0.0038 | test_mmd=0.0050\n",
      "[CellOT] epoch=1000 f_loss=-2.1163 g_loss=-14.3371 | train mmd=0.0041 | test_mmd=0.0092\n",
      "[CellOT] Final CellOT MMD: 0.0056\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "[CellOT] epoch=0 f_loss=7.0801 g_loss=-24.1978 | train mmd=0.0217 | test_mmd=0.1836\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Run 8 metrics: {'mmd2_gamma_median': 0.009196663237056923, 'mmd2_gamma_0.5': 0.010901824787408254, 'mmd2_gamma_1.0': 0.0070163511245948, 'wasserstein_distance': 2.1768455525980834, 'R2_feature_means': 0.8258174173741041}\n",
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[CellOT] epoch=50 f_loss=-86.3235 g_loss=-44.4271 | train mmd=0.0089 | test_mmd=0.3769\n",
      "[CellOT] epoch=100 f_loss=-28.3695 g_loss=-35.2738 | train mmd=0.0089 | test_mmd=0.3438\n",
      "[CellOT] epoch=150 f_loss=-9.6978 g_loss=-21.1459 | train mmd=0.0088 | test_mmd=0.1939\n",
      "[CellOT] epoch=200 f_loss=-5.3140 g_loss=-22.9129 | train mmd=0.0083 | test_mmd=0.0663\n",
      "[CellOT] epoch=250 f_loss=-1.3158 g_loss=-20.0230 | train mmd=0.0073 | test_mmd=0.0345\n",
      "[CellOT] epoch=300 f_loss=-4.1403 g_loss=-15.3555 | train mmd=0.0070 | test_mmd=0.0235\n",
      "[CellOT] epoch=350 f_loss=0.4090 g_loss=-22.7968 | train mmd=0.0068 | test_mmd=0.0229\n",
      "[CellOT] epoch=400 f_loss=-0.1186 g_loss=-17.6655 | train mmd=0.0066 | test_mmd=0.0240\n",
      "[CellOT] epoch=450 f_loss=-1.3333 g_loss=-18.2843 | train mmd=0.0054 | test_mmd=0.0166\n",
      "[CellOT] epoch=500 f_loss=1.9370 g_loss=-17.0234 | train mmd=0.0054 | test_mmd=0.0127\n",
      "[CellOT] epoch=550 f_loss=-2.5331 g_loss=-16.3311 | train mmd=0.0048 | test_mmd=0.0129\n",
      "[CellOT] epoch=600 f_loss=-3.8429 g_loss=-15.2503 | train mmd=0.0042 | test_mmd=0.0081\n",
      "[CellOT] epoch=650 f_loss=-1.8055 g_loss=-16.3374 | train mmd=0.0040 | test_mmd=0.0074\n",
      "[CellOT] epoch=700 f_loss=-0.4690 g_loss=-15.7336 | train mmd=0.0040 | test_mmd=0.0074\n",
      "[CellOT] epoch=750 f_loss=0.1564 g_loss=-20.5638 | train mmd=0.0045 | test_mmd=0.0098\n",
      "[CellOT] epoch=800 f_loss=-1.5402 g_loss=-19.0078 | train mmd=0.0044 | test_mmd=0.0054\n",
      "[CellOT] epoch=850 f_loss=2.0464 g_loss=-18.4673 | train mmd=0.0041 | test_mmd=0.0057\n",
      "[CellOT] epoch=900 f_loss=-1.5969 g_loss=-16.7188 | train mmd=0.0048 | test_mmd=0.0071\n",
      "[CellOT] epoch=950 f_loss=-0.8756 g_loss=-18.5796 | train mmd=0.0051 | test_mmd=0.0106\n",
      "[CellOT] epoch=1000 f_loss=-0.0274 g_loss=-16.7467 | train mmd=0.0043 | test_mmd=0.0073\n",
      "[CellOT] Final CellOT MMD: 0.0049\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.0073104804948731505, 'mmd2_gamma_0.5': 0.010410235808543444, 'mmd2_gamma_1.0': 0.007040817623447271, 'wasserstein_distance': 2.2373903390523258, 'R2_feature_means': 0.8977655263425794}\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0075  0.0020\n",
      "mmd2_gamma_0.5        0.0107  0.0015\n",
      "mmd2_gamma_1.0        0.0072  0.0006\n",
      "wasserstein_distance  2.2161  0.0619\n",
      "R2_feature_means      0.8865  0.0451\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": "iVBORw0KGgoAAAANSUhEUgAAAYYAAAF8CAYAAADLiRyaAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAADyEElEQVR4nOydeXxU1d3/3/fe2SeTTCaTPYEgm4IgKK6gqKDgQqVWrcvPrVpbq7XWpz6tTzetttintfrU2lZtxaUuRVRQEQH3IiqgbAqyhATIQibLTGZf7/n9ETJmspFAkADn/XrROnfu3Hvuncn53vNdPl9FCCGQSCQSiWQP6sEegEQikUgGF9IwSCQSiSQDaRgkEolEkoE0DBKJRCLJQBoGiUQikWQgDYNEIpFIMpCGQSKRSCQZSMMgkUgkkgykYZBIJBJJBtIwSA4Id999N4qiHOxhDAoUReHWW2892MOQSPqMNAwSyQCwYsUK7r77bnw+38EeikSy30jDIJEMACtWrOCee+6RhkFyWCANg0QikUgykIZBst8sX76cE088EYvFwvDhw3n00Ue73e9f//oXJ5xwAlarFZfLxeWXX86uXbvS78+dOxdFUXjiiScyPve73/0ORVF444030tv++Mc/ctppp5GXl4fVauWEE05g/vz5Xc7Z7t9/8cUXGTNmDFarlVNPPZUNGzYA8OijjzJixAgsFgtnnnkm1dXVXY7xySefMHPmTHJycrDZbEydOpUPP/ww/f7dd9/NnXfeCcCwYcNQFAVFUboca8GCBRx77LGYzWbGjh3Lm2++mfH+jh07+MEPfsDo0aOxWq3k5eVx6aWXdjlOIpHgnnvuYeTIkVgsFvLy8pgyZQrLli3L2O+dd97h9NNPx26343Q6ueiii9i0aVPGPu2xoG3btnHdddfhdDrJycnh+uuvJxwOd7kXe/sOJYcJQiLZD9avXy+sVqsYMmSImDNnjrj33ntFYWGhGD9+vOj487rvvvuEoiji29/+tvjrX/8q7rnnHuF2u0VFRYXwer3p/S688EKRk5Mjdu7cmT6+yWQSN9xwQ8Z5y8rKxA9+8APxl7/8RfzpT38SJ510kgDE66+/nrEfIMaPHy/Ky8vF/fffL+6//36Rk5MjhgwZIv7yl7+IMWPGiAceeED84he/ECaTSZx11lkZn3/77beFyWQSp556qnjggQfEgw8+KMaPHy9MJpP45JNPhBBCrFu3TlxxxRUCEA8++KB45plnxDPPPCOCwWB6DMcdd5woLi4W9957r3jooYfEUUcdJWw2m2hqakqf68UXXxTHHXec+NWvfiUee+wx8T//8z8iNzdXDB06VIRCofR+//M//yMURRHf/e53xeOPPy4eeOABccUVV4j7778/vc+yZcuEwWAQo0aNEv/7v/+bvt+5ubmiqqoqvd+vf/1rAYiJEyeKiy++WPz1r38VN954owDEf//3f2fci75+h5JDH2kYJPvF7NmzhcViETt27Ehv27hxo9A0LW0YqqurhaZp4re//W3GZzds2CAMBkPG9vr6euFyucQ555wjYrGYmDhxohgyZIhobW3N+Gw4HM54HY/HxbHHHivOPvvsjO2AMJvNGZPho48+KgBRVFQk/H5/evtdd90lgPS+uq6LkSNHihkzZghd1zPOPWzYMHHOOeekt/3hD3/I+GznMZhMJrFt27b0tnXr1glAPPzwwz1ekxBCfPTRRwIQTz/9dHrbcccdJy644IIu+3ZkwoQJoqCgQDQ3N2ecU1VVcc0116S3tRuG73znOxmf/+Y3vyny8vLSr/vzHUoOfaQrSbLPpFIplixZwuzZsxkyZEh6+zHHHMOMGTPSr19++WV0Xeeyyy6jqakp/a+oqIiRI0fy7rvvpvctKirikUceYdmyZZx++umsXbuWJ554guzs7IxzW63W9H97vV5aW1s5/fTT+eyzz7qMc9q0aVRUVKRfn3zyyQB861vfwuFwdNm+fft2ANauXcvWrVu58soraW5uTo87FAoxbdo0PvjgA3Rd79O9mj59OsOHD0+/Hj9+PNnZ2elzdb6mRCJBc3MzI0aMwOl0ZlyX0+nkiy++YOvWrd2eq76+nrVr13LdddfhcrkyznnOOedkuOTa+f73v5/x+vTTT6e5uRm/3w/07zuUHPoYDvYAJIcujY2NRCIRRo4c2eW90aNHpyegrVu3IoTodj8Ao9GY8fryyy/nX//6F4sWLeKmm25i2rRpXT7z+uuvc99997F27VpisVh6e3e1Ex2NFkBOTg4A5eXl3W73er3pcQNce+213Y4boLW1ldzc3B7f72kMALm5uelzAUQiEebMmcPcuXOpra1FdGiu2Nramv7v3/zmN1x00UWMGjWKY489lpkzZ3L11Vczfvx4oC1WAW3f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f7z//vtAW5+Uiy++mFmzZrF27VpuvPFGfvazn/V6P9qN4ty5c6mvr88wktu2beOll17i5ZdfZu3atQBceumleDweFi9ezKeffsrxxx/PtGnT0vcvGAxy/vnn8/bbb7NmzRpmzpzJrFmz2LlzJwAvv/wyZWVl/OY3v6G+vp76+nqgzaDMnDmTb33rW6xfv55///vfLF++PGMSv+6669i1axfvvvsu8+fP569//Wu6aKwn/va3v3HLLbdw0003sWHDBl599VVGjBiRfn9v19Mb9fX1XHHFFXznO99h06ZNvPfee1x88cWI9mX/gUL0k0AgINasWSPWrFkjAPGnP/1JrFmzRuzYsUMIIcT9998vnE6nWLhwoVi/fr246KKLxLBhw0QkEunT8VtbWwUgWltb+zs0iRDCt32lWPvIN8Wmf90q1v3922LlnCnik3tPEmv/Mls0rFmYsW+4sUpsW3iPeOUX08U/77xQvPKrmWLl788UK393qvj0wZli5e9OFat+f6b45HeniY/vmSg+vud48dmfLxLrH7tSbHj8KhFurDqg1xKJRMTGjRv7/NvpiYY1C8WGx68Sax/5ptjw+FVd7sNAEgwGhdFoFM8++2x6WzweFyUlJeJ///d/hRBCvPvuuwIQL7zwQnqf5uZmYbVaxb///W8hhBDjxo0Td999d7fnuPfee8W5556bsW3Xrl0CEJs3bxZCCDF16lQxceLEjH0SiYRwu93i6aefTm+74oorxLe//W0hhBDRaFTYbDaxYsWKjM/dcMMN4oorrhBCCHHXXXeJMWPGZLz/05/+VADC6/X2eF8A8corr2Rs+/Wvfy2MRqPweDzpbf/5z39Edna2iEajGfsOHz5cPProoz0ef+zYseLhhx9Ovx46dKh48MEHu1zHTTfdlLHtP//5j1BVVUQiEbF582YBiJUrV6bf37RpkwC6HKsjJSUl4uc//3m37/Xlen7961+L4447Lv3etddeKy666CIhhBCffvqpAER1dXWP5+9Ib38z/Zlb+x1jWL16NWeddVb6dXt84Nprr+XJJ5/kv//7vwmFQtx00034fD6mTJnCm2++mV4mSg4sJkc+mslGzL+beOtuhJ5CMZpA1fCsnoejbHw65mB1VzD8G7/C7HqC5nWvkYonSEVjaGYHxiw3IpkgGfaCakAxmBGpFAn/bjRjOYWnXN0ldjEY6byCSoRbutyHgaSyspJEIsHkyZPT24xGIyeddBKbNm3K2LfjKtrlcjF69Oj0Prfddhs333wzS5cuZfr06XzrW99i/PjxAKxbt4533303vYLofP5Ro0YBcMIJJ2S8ZzAYuOyyy3j22We5+uqrCYVCLFy4kBdeeAFoe3oPh8Occ845GZ+Lx+NMnDgRgE2bNnHyySf3eB39ZejQoeTn56dfr1u3jmAw2KXSPRKJUFlZCbStGO6++24WLVpEfX09yWSSSCSSXjH0xLp161i/fn2Ge0gIga7rVFVVsWXLFgwGQ8Z9O/roo3E6nT0e0+PxUFdXx7Rp03o8596upzeOO+44pk2bxrhx45gxYwbnnnsul1xyCbm5uXv97P7Qb8Nw5pln9rqMURSF3/zmN/zmN7/Zr4FJ9g2ru4KCSZdR/+FcRDKOYjRhzinB5Cgg1lpLPNDYZUIsm/Id8o4+G+/W5dR/OJdUPEyqcXvb96woWHJLMWblIYQg1rKTnBGn4ygbf3AusJ/EA42k4mHMOaUoqorR5urxPgwmbrzxRmbMmMGiRYtYunQpc+bM4YEHHuCHP/whwWCQWbNm8fvf/77L5zpq5Njt9i7vX3XVVUydOhWPx8OyZcuwWq3MnDkTIO1iWrRoEaWlpRmfM5vNA3l5PY4xGAxSXFzMe++912Xf9gn6Jz/5CcuWLeOPf/wjI0aMwGq1cskllxCPx3s9VzAY5Hvf+x633XZbl/eGDBnCli1b+j3+dhmK3s65t+vpDU3TWLZsGStWrGDp0qU8/PDD/PznP+eTTz5h2LBh/R5vXznoWUmS/adzBlLBhG9gtOexc+kfQdUwOQpIhFvQTDZMjvxuj2F1VxD11qInIggBqtGCSIRBCHQ9hWqwEGnaTioWpGXjMgLVKw+JzKT2FVQi3ILR5trrfdhfhg8fnvbrDx06FGgL8K5atYrbb789Y9+PP/6YIUOGAOD1etmyZQvHHHNM+v3y8nK+//3v8/3vf5+77rqLxx9/nB/+8Iccf/zxvPTSS1RUVGAw9O9P+LTTTqO8vJx///vfLF68mEsvvRSj0QjAmDFjMJvN7Ny5k6lTp3b7+WOOOYZXX81MZvj444/3el6j0Ugqldrrfscffzy7d+/GYDCkg9Sd+fDDD7nuuuvScZFgMNglAG4ymbqc7/jjj2fjxo0Z/v+OHH300SSTST799FNOPPFEADZv3txrfYbD4aCiooK33347w5PSn+vZG4qiMHnyZCZPnsyvfvUrhg4dyiuvvJKRzTnQyEY9hyCVNS2sWL+TypqWdAbS8hf+wPy/3s2KhY8DkDtyMsWTr0czWoi11qIoCgWTLuv1KVk1mFBNdhRNQyRjKJoRxWRDVVWizdUkw140Wy7WvIpDJjOpfQWlKEqf78P+YLfbufnmm7nzzjt588032bhxI9/97ncJh8PccMMNGfv+5je/4e233+bzzz/nuuuuw+12pwubbr/9dpYsWUJVVRWfffYZ7777btpo3HLLLbS0tHDFFVewatUqKisrWbJkCddff32fJt8rr7ySv//97yxbtoyrrroqvd3hcPCTn/yEH//4xzz11FNUVlby2Wef8fDDD/PUU08B8P3vf5+tW7dy5513snnzZp577jmefPLJvZ6zffLcvXs3Xq+3x/2mT5/OqaeeyuzZs1m6dCnV1dWsWLGCn//856xevRqAkSNHpoPV69at48orr0TX9S7n++CDD6itrU1na/30pz9lxYoV3Hrrraxdu5atW7eycOHCdPB59OjRzJw5k+9973t88sknfPrpp9x44417XRXcfffdPPDAA/z5z39m69at6XvW1+vpjU8++YTf/e53rF69mp07d/Lyyy/T2NiY8QBxIJArhkOISFM1L761gXkrGokkFawGwXTnWlIxM2/srCCSMmDdtINv1/2Nm26+mYIJ38BRNr7HeobOmBz5mHMKSSWiaEYrqUQEzWihdOrNRJqqaFj1b6x5FYeUSwbo933YX+6//350Xefqq68mEAgwadIklixZ0sUvfP/99/OjH/2IrVu3MmHCBF577bV0Hn8qleKWW26hpqaG7OxsZs6cyYMPPghASUkJH374IT/96U8599xzicViDB06lJkzZ6Kqe3/Wu+qqq/jtb3/L0KFDM2IhAPfeey/5+fnMmTOH7du343Q6Of744/mf//kfoM3l8tJLL/HjH/+Yhx9+mJNOOonf/e53fOc73+n1nA888AB33HEHjz/+OKWlpT2muCqKwhtvvMHPf/5zrr/+ehobGykqKuKMM85IF87+6U9/4jvf+Q6nnXYabrebn/70p10UE37zm9/wve99j+HDhxOLxRBCMH78eN5//31+/vOfc/rppyOEYPjw4RkpvHPnzuXGG29k6tSpFBYWct999/HL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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "drug = \"dexamethasone\"\n",
    "X_pre = adata_4i[adata_4i.obs[\"drug\"] == \"control\"].copy().to_df()[features_4i]\n",
    "X_post  = adata_4i[adata_4i.obs[\"drug\"] == drug].copy().to_df()[features_4i]\n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "X_tr_pre, X_te_pre, Y_tr_post, Y_te_post = split_train_test(X_pre.values, X_post.values, 0.8)\n",
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "# Compute median heuristic gamma on training data\n",
    "median_gamma = median_heuristic_gamma(X_tr_pre, Y_tr_post)\n",
    "print(\"Median heuristic gamma:\", median_gamma)\n",
    "\n",
    "\n",
    "all_metrics = []\n",
    "for run in range(10):\n",
    "    print(f\"**************** Run: {run} ****************\")\n",
    "    seed = 1234 + run\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "\n",
    "    out = run_cellot_pair(X_tr_pre, Y_tr_post, X_te_pre, Y_te_post, n_epochs=1000)\n",
    "    metrics = summarize_metrics(out[\"y_pred\"], Y_te_post, median_gamma)\n",
    "    print(f\"Run {run} metrics: {metrics}\")\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))\n",
    "\n",
    "\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = Y_tr_post\n",
    "target = Y_te_post\n",
    "predicted = out.get('y_pred') \n",
    "\n",
    "# Instantiate UMAP\n",
    "umap_model = UMAP(n_components=2, random_state=42)\n",
    "\n",
    "all_sample_umap = umap_model.fit_transform(np.vstack([source, target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "y_pred_umap = umap_model.transform(predicted)\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#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": "610e4869",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3cc05c34",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6856ea1b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2061ee67",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "711c8633",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3847dd9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "258f2758",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d698f206",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
