{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b9e2d729",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "MPS available: False\n",
      "CUDA version: 11.7\n",
      "MPS not available — running on CPU instead.\n",
      "CPU cores: 48\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import sys\n",
    "import json\n",
    "import logging\n",
    "import argparse\n",
    "import torch\n",
    "\n",
    "print(\"MPS available:\", torch.backends.mps.is_available())\n",
    "print(\"CUDA version:\", torch.version.cuda)\n",
    "\n",
    "# Show MPS device info safely\n",
    "if torch.backends.mps.is_available():\n",
    "    print(\"MPS backend is active on macOS (Metal).\")\n",
    "    print(\"Device: Apple GPU via Metal Performance Shaders (MPS).\")\n",
    "else:\n",
    "    print(\"MPS not available — running on CPU instead.\")\n",
    "\n",
    "print(\"CPU cores:\", os.cpu_count())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "fe4f5248",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AnnData object with n_obs × n_vars = 762039 × 1000\n",
      "    obs: 'size_factor', 'cell_type', 'replicate', 'dose', 'drug_code', 'pathway_level_1', 'pathway_level_2', 'product_name', 'target', 'pathway', 'drug', 'drug-dose', 'drug_code-dose', 'n_genes'\n",
      "    var: 'gene_short_name', 'n_cells', 'highly_variable', 'means', 'dispersions', 'dispersions_norm'\n",
      "    uns: 'hvg', 'pca', 'rank_genes_groups'\n",
      "    obsm: 'X_pca'\n",
      "    varm: 'PCs', 'marker_genes-drug-rank', 'marker_genes-drug-score'\n",
      "Shape: (762039, 1000)\n",
      "Observation columns: ['size_factor', 'cell_type', 'replicate', 'dose', 'drug_code', 'pathway_level_1', 'pathway_level_2', 'product_name', 'target', 'pathway']\n",
      "Feature columns: ['ENSG00000243620.1', 'ENSG00000271503.5', 'ENSG00000259124.1', 'ENSG00000121101.15', 'ENSG00000160963.13', 'ENSG00000135346.8', 'ENSG00000143839.14', 'ENSG00000100867.14', 'ENSG00000140986.7', 'ENSG00000230666.5']\n",
      "Unique conditions: ['tak_901', 'ag_490', 'abexinostat', 'alisertib', 'busulfan', ..., 'ac480', 'cediranib', 'thiotepa', 'cerdulatinib', 'zileuton']\n",
      "Length: 189\n",
      "Categories (189, object): ['2_methoxyestradiol', '_jq1', 'a_366', 'abt_737', ..., 'xav_939', 'ym155', 'zm_447439', 'zileuton']\n",
      "Number of cells per condition:\n",
      "control              17565\n",
      "ellagic_acid          6255\n",
      "divalproex_sodium     6198\n",
      "ruxolitinib           6139\n",
      "mc1568                6120\n",
      "                     ...  \n",
      "alvespimycin_hcl      2085\n",
      "patupilone            1798\n",
      "flavopiridol_hcl      1703\n",
      "epothilone_a          1401\n",
      "ym155                  989\n",
      "Name: drug, Length: 189, dtype: int64\n"
     ]
    }
   ],
   "source": [
    "import scanpy as sc\n",
    "\n",
    "# Load your dataset\n",
    "adata_sc = sc.read_h5ad(\"./scrna-sciplex3/hvg.h5ad\")\n",
    "\n",
    "# Basic overview\n",
    "print(adata_sc)\n",
    "print(\"Shape:\", adata_sc.shape)\n",
    "\n",
    "# View column names (metadata about each cell)\n",
    "print(\"Observation columns:\", adata_sc.obs.columns.tolist()[:10])\n",
    "print(\"Feature columns:\", adata_sc.var_names[:10].tolist())\n",
    "\n",
    "# How many drugs (conditions)?\n",
    "print(\"Unique conditions:\", adata_sc.obs['drug'].unique())\n",
    "print(\"Number of cells per condition:\")\n",
    "print(adata_sc.obs['drug'].value_counts())\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b8b57557",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "import json\n",
    "import logging\n",
    "import argparse\n",
    "import geomloss\n",
    "import random\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "from torch.utils.data import TensorDataset, DataLoader\n",
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "from typing import Dict, Tuple, List, Optional\n",
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import linear_sum_assignment\n",
    "from sklearn.preprocessing import StandardScaler, MinMaxScaler\n",
    "from sklearn.metrics.pairwise import rbf_kernel\n",
    "from typing import Dict, Tuple, List\n",
    "from scipy.stats import ks_2samp\n",
    "from scipy.spatial.distance import cdist\n",
    "from sklearn.metrics import r2_score\n",
    "\n",
    "import gc\n",
    "gc.collect()\n",
    "\n",
    "def median_heuristic_gamma(X: np.ndarray, Y: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    Median heuristic for RBF bandwidth: gamma = 1 / median(||x - y||^2).\n",
    "    Uses the median of pairwise distances in the pooled set.\n",
    "    \"\"\"\n",
    "    Z = np.vstack([X, Y])\n",
    "    # Sample if too large for efficiency\n",
    "    max_samples = 5000\n",
    "    if Z.shape[0] > max_samples:\n",
    "        idx = np.random.choice(Z.shape[0], size=max_samples, replace=False)\n",
    "        Z = Z[idx]\n",
    "    D2 = cdist(Z, Z, metric='sqeuclidean')\n",
    "    # Use upper triangular without diagonal\n",
    "    triu = D2[np.triu_indices_from(D2, k=1)]\n",
    "    med = np.median(triu[triu > 0]) if np.any(triu > 0) else 1.0\n",
    "    return 1.0 / max(med, 1e-12)\n",
    "\n",
    "def mmd_distance(X: np.ndarray, Y: np.ndarray, gamma: float) -> float:\n",
    "    \"\"\"\n",
    "    Unbiased MMD^2 estimator using Gaussian (RBF) kernel, sklearn backend.\n",
    "\n",
    "    Args:\n",
    "        X: (n_samples, n_features) first sample\n",
    "        Y: (m_samples, n_features) second sample\n",
    "        gamma: RBF kernel bandwidth; if None, uses median heuristic\n",
    "\n",
    "    Returns:\n",
    "        Unbiased MMD^2 value\n",
    "    \"\"\"\n",
    "    n = X.shape[0]\n",
    "    m = Y.shape[0]\n",
    "\n",
    "    # Kernel matrices\n",
    "    Kxx = rbf_kernel(X, X, gamma=gamma)\n",
    "    Kyy = rbf_kernel(Y, Y, gamma=gamma)\n",
    "    Kxy = rbf_kernel(X, Y, gamma=gamma)\n",
    "\n",
    "    # Unbiased: exclude diagonal entries\n",
    "    np.fill_diagonal(Kxx, 0.0)\n",
    "    np.fill_diagonal(Kyy, 0.0)\n",
    "\n",
    "    term_xx = Kxx.sum() / (n * (n - 1)) if n > 1 else 0.0\n",
    "    term_yy = Kyy.sum() / (m * (m - 1)) if m > 1 else 0.0\n",
    "    term_xy = 2.0 * Kxy.mean()\n",
    "\n",
    "    mmd2 = term_xx + term_yy - term_xy\n",
    "    mmd2 = max(mmd2, 0.0)  # Numerical stability\n",
    "    return float(mmd2)\n",
    "\n",
    "def r2_feature_means(y_true: np.ndarray, y_pred: np.ndarray) -> float:\n",
    "    \"\"\"\n",
    "    R^2 computed across features between mean vectors of y_true and y_pred.\n",
    "    \"\"\"\n",
    "    mu_true = y_true.mean(axis=0)\n",
    "    mu_pred = y_pred.mean(axis=0)\n",
    "    ss_res = float(np.sum((mu_true - mu_pred) ** 2))\n",
    "    ss_tot = float(np.sum((mu_true - mu_true.mean()) ** 2))\n",
    "    if ss_tot <= 1e-12:\n",
    "        return 1.0 if ss_res <= 1e-12 else 0.0\n",
    "    return 1.0 - ss_res / ss_tot\n",
    "\n",
    "def wasserstein_pointcloud(\n",
    "    X,\n",
    "    Y,\n",
    "    p: int = 2,\n",
    "    a=None,\n",
    "    b=None,\n",
    "    method: str = \"emd\",          # \"emd\" (exact) or \"sinkhorn\" (approx)\n",
    "    reg: float = 1e-1,            # Sinkhorn regularization (only used if method=\"sinkhorn\")\n",
    "    return_plan: bool = False,\n",
    "):\n",
    "    \"\"\"\n",
    "    Compute Wasserstein distance W_p between two empirical distributions supported on point sets X and Y.\n",
    "\n",
    "    Parameters\n",
    "    ----------\n",
    "    X : (n, d) array-like\n",
    "        Source points.\n",
    "    Y : (m, d) array-like\n",
    "        Target points.\n",
    "    p : int\n",
    "        Order of the Wasserstein distance (commonly 1 or 2).\n",
    "    a : (n,) array-like or None\n",
    "        Weights for X; if None, uniform weights.\n",
    "    b : (m,) array-like or None\n",
    "        Weights for Y; if None, uniform weights.\n",
    "    method : str\n",
    "        \"emd\" for exact optimal transport (requires POT),\n",
    "        \"sinkhorn\" for entropic approximation (requires POT).\n",
    "    reg : float\n",
    "        Entropic regularization strength for Sinkhorn.\n",
    "    return_plan : bool\n",
    "        If True, also return the optimal transport plan.\n",
    "\n",
    "    Returns\n",
    "    -------\n",
    "    Wp : float\n",
    "        Wasserstein distance of order p.\n",
    "    plan : (n, m) ndarray, optional\n",
    "        Optimal transport plan (only if return_plan=True).\n",
    "    \"\"\"\n",
    "    X = np.asarray(X, dtype=np.float64)\n",
    "    Y = np.asarray(Y, dtype=np.float64)\n",
    "    if X.ndim != 2 or Y.ndim != 2:\n",
    "        raise ValueError(\"X and Y must be 2D arrays with shape (n, d) and (m, d).\")\n",
    "    if X.shape[1] != Y.shape[1]:\n",
    "        raise ValueError(f\"Dimension mismatch: X has d={X.shape[1]}, Y has d={Y.shape[1]}.\")\n",
    "\n",
    "    n, d = X.shape\n",
    "    m, _ = Y.shape\n",
    "\n",
    "    if a is None:\n",
    "        a = np.full(n, 1.0 / n, dtype=np.float64)\n",
    "    else:\n",
    "        a = np.asarray(a, dtype=np.float64)\n",
    "        a = a / a.sum()\n",
    "\n",
    "    if b is None:\n",
    "        b = np.full(m, 1.0 / m, dtype=np.float64)\n",
    "    else:\n",
    "        b = np.asarray(b, dtype=np.float64)\n",
    "        b = b / b.sum()\n",
    "\n",
    "    # Cost matrix: C_ij = ||x_i - y_j||^p\n",
    "    # Compute squared Euclidean via (x-y)^2 = x^2 + y^2 - 2xy for speed\n",
    "    X2 = np.sum(X * X, axis=1, keepdims=True)          # (n, 1)\n",
    "    Y2 = np.sum(Y * Y, axis=1, keepdims=True).T        # (1, m)\n",
    "    sq = np.maximum(X2 + Y2 - 2.0 * (X @ Y.T), 0.0)     # (n, m)\n",
    "    if p == 2:\n",
    "        C = sq\n",
    "    else:\n",
    "        C = sq ** (p / 2.0)\n",
    "\n",
    "    try:\n",
    "        import ot  # POT: Python Optimal Transport\n",
    "    except ImportError as e:\n",
    "        raise ImportError(\n",
    "            \"This function requires the POT library. Install with: pip install pot\"\n",
    "        ) from e\n",
    "\n",
    "    method = method.lower()\n",
    "    if method == \"emd\":\n",
    "        # exact OT: minimizes <P, C>\n",
    "        P = ot.emd(a, b, C)\n",
    "        cost = float(np.sum(P * C))\n",
    "    elif method == \"sinkhorn\":\n",
    "        # entropic OT approximation\n",
    "        P = ot.sinkhorn(a, b, C, reg=reg)\n",
    "        cost = float(np.sum(P * C))\n",
    "    else:\n",
    "        raise ValueError('method must be either \"emd\" or \"sinkhorn\".')\n",
    "\n",
    "    Wp = cost ** (1.0 / p)\n",
    "\n",
    "    if return_plan:\n",
    "        return Wp, P\n",
    "    return Wp\n",
    "\n",
    "def summarize_metrics(y_true: np.ndarray, y_pred: np.ndarray, median_gamma: float) -> dict:\n",
    "    \"\"\"\n",
    "    Compute a standard set of metrics: MMD^2 (RBF), R^2 of feature means, median KS across features, and Wasserstein distance.\n",
    "    \"\"\"\n",
    "    # Drop any samples that contain NaNs in either true or pred\n",
    "    mask = (~np.isnan(y_true).any(axis=1)) & (~np.isnan(y_pred).any(axis=1))\n",
    "    if mask.sum() < len(y_true):\n",
    "        print(f\"[summarize_metrics] Dropping {len(y_true) - mask.sum()} samples with NaNs.\")\n",
    "    \n",
    "    y_true = y_true[mask]\n",
    "    y_pred = y_pred[mask]\n",
    "\n",
    "    out = {}\n",
    "\n",
    "    out['mmd2_gamma_median'] = mmd_distance(y_true, y_pred, gamma=median_gamma)\n",
    "    out['mmd2_gamma_0.5'] = mmd_distance(y_true, y_pred, gamma=0.5)\n",
    "    out['mmd2_gamma_1.0'] = mmd_distance(y_true, y_pred, gamma=1.0)\n",
    "    out['wasserstein_distance'] = wasserstein_pointcloud(y_true, y_pred, p=2, method=\"emd\")\n",
    "    out['R2_feature_means'] = r2_feature_means(y_true, y_pred)\n",
    "    return out\n",
    "\n",
    "def split_train_test(X: np.ndarray, Y: np.ndarray, train_fraction: float, seed: int = 42) -> Tuple[np.ndarray, np.ndarray, np.ndarray, np.ndarray]:\n",
    "    if X.shape[0] != Y.shape[0]:\n",
    "        min_len = min(len(X), len(Y))\n",
    "        X = X[:min_len]\n",
    "        Y = Y[:min_len]\n",
    "\n",
    "    n = X.shape[0]\n",
    "    n_train = max(1, int(n * train_fraction))\n",
    "    rng = np.random.default_rng(seed)\n",
    "    idx = rng.permutation(n)\n",
    "    tr_idx, te_idx = idx[:n_train], idx[n_train:]\n",
    "    return X[tr_idx], X[te_idx], Y[tr_idx], Y[te_idx]\n",
    "\n",
    "def topk_markers(adata, drug: str, k: int = 50, rank_key: str = \"marker_genes-drug-rank\"):\n",
    "    R = adata.varm[rank_key]\n",
    "\n",
    "    # --- get the rank vector for this drug ---\n",
    "    if hasattr(R, \"columns\") and hasattr(R, \"iloc\"):  # pandas DataFrame\n",
    "        if drug in R.columns:\n",
    "            r = R[drug].to_numpy()\n",
    "        else:\n",
    "            # fallback: interpret columns as ordered groups; try to map via rank_genes_groups names\n",
    "            names = adata.uns[\"rank_genes_groups\"][\"names\"]\n",
    "            groups = list(names.dtype.names) if (hasattr(names, \"dtype\") and names.dtype.names is not None) else list(names.columns)\n",
    "            r = R.iloc[:, groups.index(drug)].to_numpy()\n",
    "    else:  # numpy array (or array-like)\n",
    "        names = adata.uns[\"rank_genes_groups\"][\"names\"]\n",
    "        groups = list(names.dtype.names) if (hasattr(names, \"dtype\") and names.dtype.names is not None) else list(names.columns)\n",
    "        r = np.asarray(R)[:, groups.index(drug)]\n",
    "\n",
    "    # smaller rank => stronger marker\n",
    "    idx = np.argsort(r)[:k]\n",
    "    gene_ids = adata.var_names[idx].to_list()\n",
    "    gene_short = (adata.var.iloc[idx][\"gene_short_name\"].to_list()\n",
    "                  if \"gene_short_name\" in adata.var.columns else None)\n",
    "    return gene_ids, gene_short, idx\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f75078ae",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (17565, 1000)\n",
      "X_post cells: (3277, 1000)\n",
      "(2621, 1000)\n",
      "(656, 1000)\n",
      "(2621, 1000)\n",
      "(656, 1000)\n",
      "Median heuristic gamma: 0.002284426999219219\n"
     ]
    }
   ],
   "source": [
    "drug = \"trametinib\"\n",
    "X_pre = adata_sc[adata_sc.obs[\"drug\"] == \"control\"].copy().to_df()\n",
    "X_post  = adata_sc[adata_sc.obs[\"drug\"] == drug].copy().to_df()\n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "top_genes_ids, top_genes_short, top_genes_idx = topk_markers(adata_sc, drug, k=100)\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",
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "eb96ecaa",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/pytorch_lightning/utilities/imports.py:22: UserWarning: pkg_resources is deprecated as an API. See https://setuptools.pypa.io/en/latest/pkg_resources.html. The pkg_resources package is slated for removal as early as 2025-11-30. Refrain from using this package or pin to Setuptools<81.\n",
      "  import pkg_resources\n",
      "Global seed set to 0\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/pytorch_lightning/utilities/warnings.py:53: LightningDeprecationWarning: pytorch_lightning.utilities.warnings.rank_zero_deprecation has been deprecated in v1.6 and will be removed in v1.8. Use the equivalent function from the pytorch_lightning.utilities.rank_zero module instead.\n",
      "  new_rank_zero_deprecation(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/pytorch_lightning/utilities/warnings.py:58: LightningDeprecationWarning: The `pytorch_lightning.loggers.base.rank_zero_experiment` is deprecated in v1.7 and will be removed in v1.9. Please use `pytorch_lightning.loggers.logger.rank_zero_experiment` instead.\n",
      "  return new_rank_zero_deprecation(*args, **kwargs)\n"
     ]
    }
   ],
   "source": [
    "import 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",
    "import sys\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "from typing import Optional, List, Dict\n",
    "\n",
    "from anndata import AnnData\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "\n",
    "import scgen  # pip/conda package \"scgen\"\n",
    "\n",
    "# -----------------------------\n",
    "# scGen AE utilities\n",
    "# -----------------------------\n",
    "def _make_scgen_adata(X: np.ndarray, condition: str, var_names: Optional[List[str]], cond_categories: List[str]) -> AnnData:\n",
    "    X = np.asarray(X, dtype=np.float32)\n",
    "    if var_names is None:\n",
    "        var_names = [f\"g{i}\" for i in range(X.shape[1])]\n",
    "    obs = pd.DataFrame({\n",
    "        \"condition\": pd.Categorical([condition] * X.shape[0], categories=cond_categories),\n",
    "        \"cell_type\": pd.Categorical([\"all\"] * X.shape[0], categories=[\"all\"]),\n",
    "    })\n",
    "    var = pd.DataFrame(index=pd.Index(var_names, name=\"gene\"))\n",
    "    return AnnData(X=X, obs=obs, var=var)\n",
    "\n",
    "def train_scgen_ae(\n",
    "    train_pre: np.ndarray,\n",
    "    train_post: np.ndarray,\n",
    "    latent_dim: int = 100,\n",
    "    n_hidden: int = 512,\n",
    "    n_layers: int = 2,\n",
    "    early_stopping_patience: int = 100,\n",
    "    dropout_rate: float = 0.0,\n",
    "    max_epochs: int = 500,\n",
    "    batch_size: int = 1024,\n",
    "    learning_rate: float = 1e-3,\n",
    "    weight_decay: float = 1e-5,\n",
    "    device: str = \"cuda\",\n",
    "    seed: int = 0,\n",
    "    var_names: Optional[List[str]] = None,\n",
    "    ctrl_label: str = \"control\",\n",
    "    stim_label: str = \"stim\",\n",
    "):\n",
    "    \"\"\"\n",
    "    Trains an scGen model as an autoencoder on gene space (no PCA).\n",
    "    Returns: model, var_names, cond_categories\n",
    "    \"\"\"\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    if torch.cuda.is_available():\n",
    "        torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "    cond_categories = [ctrl_label, stim_label]\n",
    "\n",
    "    X_train = np.vstack([train_pre, train_post]).astype(np.float32, copy=False)\n",
    "    conds = [ctrl_label] * len(train_pre) + [stim_label] * len(train_post)\n",
    "\n",
    "    if var_names is None:\n",
    "        var_names = [f\"g{i}\" for i in range(X_train.shape[1])]\n",
    "\n",
    "    adata_train = AnnData(\n",
    "        X=X_train,\n",
    "        obs=pd.DataFrame({\n",
    "            \"condition\": pd.Categorical(conds, categories=cond_categories),\n",
    "            \"cell_type\": pd.Categorical([\"all\"] * len(conds), categories=[\"all\"]),\n",
    "        }),\n",
    "        var=pd.DataFrame(index=pd.Index(var_names, name=\"gene\")),\n",
    "    )\n",
    "\n",
    "    scgen.SCGEN.setup_anndata(adata_train, batch_key=\"condition\", labels_key=\"cell_type\")\n",
    "\n",
    "    model = scgen.SCGEN(\n",
    "        adata_train,\n",
    "        n_hidden=n_hidden,\n",
    "        n_latent=latent_dim,\n",
    "        n_layers=n_layers,\n",
    "        dropout_rate=dropout_rate,\n",
    "    )\n",
    "\n",
    "    use_gpu = (device.startswith(\"cuda\") and torch.cuda.is_available())\n",
    "    model.train(\n",
    "        max_epochs=max_epochs,\n",
    "        batch_size=batch_size,\n",
    "        early_stopping=True,\n",
    "        use_gpu=use_gpu,\n",
    "        early_stopping_patience=int(early_stopping_patience),\n",
    "        plan_kwargs={\"lr\": float(learning_rate), \"weight_decay\": float(weight_decay)},\n",
    "    )\n",
    "    return model, var_names, cond_categories\n",
    "\n",
    "@torch.no_grad()\n",
    "def scgen_encode(model, X: np.ndarray, condition: str, var_names, cond_categories) -> np.ndarray:\n",
    "    ad = _make_scgen_adata(X, condition=condition, var_names=var_names, cond_categories=cond_categories)\n",
    "    z = model.get_latent_representation(ad)\n",
    "    return np.asarray(z, dtype=np.float32)\n",
    "\n",
    "@torch.no_grad()\n",
    "def scgen_decode_latent(model, Z: np.ndarray, batch_index: int = 1) -> np.ndarray:\n",
    "    \"\"\"\n",
    "    Decode arbitrary latent Z to gene space using the model's generative path.\n",
    "    batch_index=1 corresponds to the 'stim' condition if you used [control, stim] ordering.\n",
    "    \"\"\"\n",
    "    dev = next(model.module.parameters()).device\n",
    "    zt = torch.as_tensor(Z, dtype=torch.float32, device=dev)\n",
    "\n",
    "    # scvi-tools modules typically expect batch_index as (n, 1)\n",
    "    b = torch.full((zt.shape[0], 1), int(batch_index), dtype=torch.long, device=dev)\n",
    "\n",
    "    # Some scvi modules require \"library\" (log-library size). If required, use zeros as a safe default.\n",
    "    # (If you have raw counts + size factors, you can improve this; but this will run and is stable.)\n",
    "    lib = torch.zeros((zt.shape[0], 1), dtype=torch.float32, device=dev)\n",
    "\n",
    "    out = None\n",
    "    try:\n",
    "        out = model.module.generative(z=zt, batch_index=b, library=lib)\n",
    "    except TypeError:\n",
    "        # Older/newer signatures\n",
    "        try:\n",
    "            out = model.module.generative(z=zt, batch_index=b)\n",
    "        except TypeError:\n",
    "            out = model.module.generative(zt)\n",
    "\n",
    "    # Pick a sensible decoded mean-like output across scvi versions\n",
    "    if isinstance(out, dict):\n",
    "        for key in (\"px_rate\", \"px_scale\", \"px\"):\n",
    "            if key in out:\n",
    "                x_hat = out[key]\n",
    "                break\n",
    "        else:\n",
    "            raise KeyError(f\"Could not find px_rate/px_scale/px in generative outputs: {list(out.keys())}\")\n",
    "    else:\n",
    "        # Some implementations return tensor directly\n",
    "        x_hat = out\n",
    "\n",
    "    x_hat = x_hat.detach().cpu().numpy()\n",
    "    return np.asarray(x_hat, dtype=np.float32)\n",
    "\n",
    "\n",
    "# -----------------------------\n",
    "#  CellOT function with scGen AE\n",
    "# -----------------------------\n",
    "def run_cellot_pair(\n",
    "    train_pre: np.ndarray, train_post: np.ndarray,\n",
    "    test_pre: np.ndarray, test_post: np.ndarray,\n",
    "    layers: Optional[List[int]] = [64, 64, 64, 64],\n",
    "    n_epochs: int = 5000,\n",
    "    pca_dims: Optional[int] = None,              # kept for backward compatibility; now used as latent_dim if provided\n",
    "    top_feature_subset: Optional[List[int]] = None,\n",
    "    seed: int = 0,\n",
    "    # scGen knobs\n",
    "    scgen_max_epochs: int = 500,\n",
    "    scgen_batch_size: int = 256,\n",
    "    scgen_latent_dim_default: int = 100,\n",
    ") -> Dict:\n",
    "\n",
    "    device = \"cuda\"\n",
    "    print(f\"VERS torch={torch.__version__} (CellOT), device={device}\", file=sys.stderr, flush=True)\n",
    "\n",
    "    # ---- 1) Train scGen AE independently (replaces StandardScaler+PCA block) ----\n",
    "    latent_dim = int(pca_dims) if (pca_dims is not None) else int(scgen_latent_dim_default)\n",
    "\n",
    "    # Optional: if you have real gene IDs, pass them as var_names; otherwise it’s fine\n",
    "    var_names = None  # or list_of_gene_ids length=1000\n",
    "\n",
    "    scgen_model, var_names, cond_categories = train_scgen_ae(\n",
    "        train_pre=train_pre,\n",
    "        train_post=train_post,\n",
    "        latent_dim=latent_dim,\n",
    "        max_epochs=scgen_max_epochs,\n",
    "        batch_size=scgen_batch_size,\n",
    "        device=device,\n",
    "        seed=seed,\n",
    "        var_names=var_names,\n",
    "        ctrl_label=\"control\",\n",
    "        stim_label=\"stim\",\n",
    "    )\n",
    "\n",
    "    # Encode into latent space\n",
    "    tr_pre_z  = scgen_encode(scgen_model, train_pre, condition=\"control\", var_names=var_names, cond_categories=cond_categories)\n",
    "    tr_post_z = scgen_encode(scgen_model, train_post, condition=\"stim\",    var_names=var_names, cond_categories=cond_categories)\n",
    "    te_pre_z  = scgen_encode(scgen_model, test_pre,  condition=\"control\",  var_names=var_names, cond_categories=cond_categories)\n",
    "\n",
    "    # Standardize in latent space for CellOT stability (analogous role to your PCA)\n",
    "    z_scaler = StandardScaler()\n",
    "    Z_all = np.vstack([tr_pre_z, tr_post_z])\n",
    "    Z_all_s = z_scaler.fit_transform(Z_all)\n",
    "    tr_pre_p  = Z_all_s[:len(train_pre)]\n",
    "    tr_post_p = Z_all_s[len(train_pre):]\n",
    "    te_pre_p  = z_scaler.transform(te_pre_z)\n",
    "\n",
    "    # ---- 2) CellOT networks (unchanged from your code) ----\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",
    "    lr = 5e-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",
    "    n_epochs = n_epochs + 1\n",
    "    batch_size = 256\n",
    "    n_inner_iters = 10\n",
    "\n",
    "    # ---- helper: decode a transported latent (scaled) back to gene space ----\n",
    "    def _decode_from_cellot_latent(latent_scaled_np: np.ndarray) -> np.ndarray:\n",
    "        # invert latent standardization\n",
    "        z = z_scaler.inverse_transform(latent_scaled_np)\n",
    "        # decode as \"stim\" condition (batch_index=1 because we used [control, stim])\n",
    "        x_hat = scgen_decode_latent(scgen_model, z, batch_index=1)\n",
    "        return x_hat\n",
    "\n",
    "    # ---- 3) Training loop (same logic, but inverse-preprocess replaced by scGen decode) ----\n",
    "    for epoch in range(n_epochs):\n",
    "        f.train(); g.train()\n",
    "\n",
    "        perm_t = torch.randperm(len(tgt), device=device)[:batch_size]\n",
    "        yt = tgt[perm_t]\n",
    "\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",
    "        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",
    "        if hasattr(f, \"clamp_w\"):\n",
    "            f.clamp_w()\n",
    "\n",
    "        if epoch % 50 == 0:\n",
    "            f.eval(); g.eval()\n",
    "\n",
    "            # Transport training PRE (latent space), then decode to gene space\n",
    "            tr_src_eval = src.detach().clone().requires_grad_(True)\n",
    "            tr_pred_p = g.transport(tr_src_eval).detach().cpu().numpy()\n",
    "            tr_pred = _decode_from_cellot_latent(tr_pred_p)\n",
    "\n",
    "            train_mmd = mmd_distance(\n",
    "                train_post[:, top_feature_subset],\n",
    "                tr_pred[:, top_feature_subset],\n",
    "                median_gamma,\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",
    "            te_pred_inv_full = _decode_from_cellot_latent(te_pred_full)\n",
    "\n",
    "            test_mmd = mmd_distance(\n",
    "                test_post[:, top_feature_subset],\n",
    "                te_pred_inv_full[:, top_feature_subset],\n",
    "                median_gamma,\n",
    "            )\n",
    "            test_mmd_cellot = compute_mmd_loss(\n",
    "                test_post[:, top_feature_subset],\n",
    "                te_pred_inv_full[:, top_feature_subset],\n",
    "                np.logspace(1, -3, num=50),\n",
    "            )\n",
    "\n",
    "            print(\n",
    "                f\"[CellOT+scGen] epoch={epoch} f_loss={f_loss.item():.4f} g_loss={g_loss.item():.4f} | \"\n",
    "                f\"train_mmd={train_mmd:.4f} | test_mmd={test_mmd:.4f} | test_mmd_cellot={test_mmd_cellot:.4f}\",\n",
    "                file=sys.stderr,\n",
    "                flush=True,\n",
    "            )\n",
    "\n",
    "    # ---- 4) Inference ----\n",
    "    f.eval(); g.eval()\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",
    "    te_tx_inv = _decode_from_cellot_latent(te_tx)\n",
    "\n",
    "    mmd = compute_mmd_loss(\n",
    "        test_post[:len(te_tx_inv), top_feature_subset],\n",
    "        te_tx_inv[:, top_feature_subset],\n",
    "        gammas=np.logspace(1, -3, num=50),\n",
    "    )\n",
    "    print(f\"[CellOT+scGen] Final CellOT MMD: {mmd:.4f}\", file=sys.stderr, flush=True)\n",
    "\n",
    "    return {\"y_pred\": te_tx_inv}\n",
    "  \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b2a6a182",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2621, 1000)\n",
      "(656, 1000)\n",
      "(2621, 1000)\n",
      "(656, 1000)\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111/500:  22%|██████████████████████████████████████████████▌                                                                                                                                                                   | 111/500 [00:10<00:37, 10.24it/s, loss=28.4, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 282.157. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-339451.1562 g_loss=415092.8125 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=-5529655.5000 g_loss=11952138.0000 | train_mmd=0.7740 | test_mmd=0.7760 | test_mmd_cellot=0.2237\n",
      "[CellOT+scGen] epoch=100 f_loss=-262699.3438 g_loss=358267.9062 | train_mmd=0.8277 | test_mmd=0.8224 | test_mmd_cellot=0.2370\n",
      "[CellOT+scGen] epoch=150 f_loss=-75291.1250 g_loss=74922.2188 | train_mmd=0.7974 | test_mmd=0.7822 | test_mmd_cellot=0.2286\n",
      "[CellOT+scGen] epoch=200 f_loss=-31280.4883 g_loss=43487.1875 | train_mmd=0.7469 | test_mmd=0.7109 | test_mmd_cellot=0.2051\n",
      "[CellOT+scGen] epoch=250 f_loss=-12756.2148 g_loss=12556.4805 | train_mmd=0.3261 | test_mmd=0.3153 | test_mmd_cellot=0.1568\n",
      "[CellOT+scGen] epoch=300 f_loss=4274.7876 g_loss=6889.1255 | train_mmd=0.0330 | test_mmd=0.0332 | test_mmd_cellot=0.1191\n",
      "[CellOT+scGen] epoch=350 f_loss=2712.0369 g_loss=259.7809 | train_mmd=0.0612 | test_mmd=0.0687 | test_mmd_cellot=0.1726\n",
      "[CellOT+scGen] epoch=400 f_loss=172.7650 g_loss=4.1198 | train_mmd=0.0487 | test_mmd=0.0505 | test_mmd_cellot=0.0818\n",
      "[CellOT+scGen] epoch=450 f_loss=8.5889 g_loss=-42.9010 | train_mmd=0.0156 | test_mmd=0.0157 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=500 f_loss=2.7022 g_loss=-37.9019 | train_mmd=0.0162 | test_mmd=0.0156 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=550 f_loss=-0.0916 g_loss=-32.9249 | train_mmd=0.0130 | test_mmd=0.0125 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=600 f_loss=-0.9814 g_loss=-32.1406 | train_mmd=0.0105 | test_mmd=0.0098 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=650 f_loss=0.1229 g_loss=-29.4288 | train_mmd=0.0094 | test_mmd=0.0090 | test_mmd_cellot=0.0168\n",
      "[CellOT+scGen] epoch=700 f_loss=-1.2459 g_loss=-26.8729 | train_mmd=0.0113 | test_mmd=0.0104 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=750 f_loss=0.2238 g_loss=-24.4464 | train_mmd=0.0095 | test_mmd=0.0091 | test_mmd_cellot=0.0169\n",
      "[CellOT+scGen] epoch=800 f_loss=0.9501 g_loss=-22.5576 | train_mmd=0.0072 | test_mmd=0.0074 | test_mmd_cellot=0.0140\n",
      "[CellOT+scGen] epoch=850 f_loss=1.1508 g_loss=-22.7653 | train_mmd=0.0063 | test_mmd=0.0065 | test_mmd_cellot=0.0131\n",
      "[CellOT+scGen] epoch=900 f_loss=0.4987 g_loss=-20.7988 | train_mmd=0.0077 | test_mmd=0.0075 | test_mmd_cellot=0.0154\n",
      "[CellOT+scGen] epoch=950 f_loss=2.6211 g_loss=-19.9146 | train_mmd=0.0073 | test_mmd=0.0075 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1000 f_loss=-2.2018 g_loss=-18.4068 | train_mmd=0.0066 | test_mmd=0.0068 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=1050 f_loss=-0.6391 g_loss=-18.3507 | train_mmd=0.0080 | test_mmd=0.0084 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=1100 f_loss=-1.0545 g_loss=-16.9085 | train_mmd=0.0091 | test_mmd=0.0097 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1150 f_loss=-0.1012 g_loss=-19.2113 | train_mmd=0.0072 | test_mmd=0.0072 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=1200 f_loss=2.3551 g_loss=-18.0969 | train_mmd=0.0075 | test_mmd=0.0078 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=1250 f_loss=-0.0387 g_loss=-17.1587 | train_mmd=0.0094 | test_mmd=0.0097 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=1300 f_loss=-0.7740 g_loss=-15.6264 | train_mmd=0.0073 | test_mmd=0.0071 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=1350 f_loss=-0.0931 g_loss=-16.0743 | train_mmd=0.0065 | test_mmd=0.0071 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1400 f_loss=0.9087 g_loss=-15.2122 | train_mmd=0.0079 | test_mmd=0.0086 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1450 f_loss=1.0509 g_loss=-14.3495 | train_mmd=0.0077 | test_mmd=0.0081 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.1953 g_loss=-15.0158 | train_mmd=0.0082 | test_mmd=0.0078 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=1550 f_loss=-1.7776 g_loss=-14.8003 | train_mmd=0.0067 | test_mmd=0.0067 | test_mmd_cellot=0.0160\n",
      "[CellOT+scGen] epoch=1600 f_loss=3.6381 g_loss=-15.7654 | train_mmd=0.0076 | test_mmd=0.0079 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=1650 f_loss=-2.8629 g_loss=-15.1008 | train_mmd=0.0074 | test_mmd=0.0077 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1700 f_loss=-1.1250 g_loss=-15.2057 | train_mmd=0.0054 | test_mmd=0.0056 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=1750 f_loss=2.8779 g_loss=-13.7738 | train_mmd=0.0065 | test_mmd=0.0073 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=1800 f_loss=-0.0497 g_loss=-14.0296 | train_mmd=0.0063 | test_mmd=0.0070 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1850 f_loss=1.0171 g_loss=-12.1851 | train_mmd=0.0079 | test_mmd=0.0081 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1900 f_loss=1.0087 g_loss=-14.0024 | train_mmd=0.0084 | test_mmd=0.0086 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.1223 g_loss=-12.1639 | train_mmd=0.0059 | test_mmd=0.0059 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=2000 f_loss=-2.2460 g_loss=-11.7196 | train_mmd=0.0053 | test_mmd=0.0051 | test_mmd_cellot=0.0138\n",
      "[CellOT+scGen] epoch=2050 f_loss=2.4084 g_loss=-12.2073 | train_mmd=0.0084 | test_mmd=0.0088 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2100 f_loss=-0.0059 g_loss=-10.9055 | train_mmd=0.0066 | test_mmd=0.0069 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=2150 f_loss=-0.6886 g_loss=-11.0819 | train_mmd=0.0076 | test_mmd=0.0080 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=2200 f_loss=2.1258 g_loss=-9.1843 | train_mmd=0.0076 | test_mmd=0.0076 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=2250 f_loss=-0.9811 g_loss=-13.7825 | train_mmd=0.0057 | test_mmd=0.0061 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=2300 f_loss=-3.2960 g_loss=-12.6561 | train_mmd=0.0064 | test_mmd=0.0062 | test_mmd_cellot=0.0149\n",
      "[CellOT+scGen] epoch=2350 f_loss=-0.2400 g_loss=-9.8373 | train_mmd=0.0063 | test_mmd=0.0059 | test_mmd_cellot=0.0160\n",
      "[CellOT+scGen] epoch=2400 f_loss=-2.1096 g_loss=-13.3079 | train_mmd=0.0071 | test_mmd=0.0071 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.7009 g_loss=-13.1606 | train_mmd=0.0066 | test_mmd=0.0065 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=2500 f_loss=-1.9622 g_loss=-10.5480 | train_mmd=0.0087 | test_mmd=0.0084 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2550 f_loss=-1.2274 g_loss=-12.0045 | train_mmd=0.0075 | test_mmd=0.0072 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=2600 f_loss=-1.6434 g_loss=-12.7096 | train_mmd=0.0059 | test_mmd=0.0064 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=2650 f_loss=-2.4200 g_loss=-8.6598 | train_mmd=0.0070 | test_mmd=0.0068 | test_mmd_cellot=0.0168\n",
      "[CellOT+scGen] epoch=2700 f_loss=-1.1709 g_loss=-8.9888 | train_mmd=0.0079 | test_mmd=0.0084 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=2750 f_loss=0.6674 g_loss=-11.1043 | train_mmd=0.0074 | test_mmd=0.0078 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2800 f_loss=0.6092 g_loss=-10.2592 | train_mmd=0.0060 | test_mmd=0.0056 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=2850 f_loss=0.1812 g_loss=-11.2281 | train_mmd=0.0069 | test_mmd=0.0068 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=2900 f_loss=-0.5488 g_loss=-10.5514 | train_mmd=0.0059 | test_mmd=0.0059 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.0726 g_loss=-8.8194 | train_mmd=0.0067 | test_mmd=0.0062 | test_mmd_cellot=0.0165\n",
      "[CellOT+scGen] epoch=3000 f_loss=-1.2264 g_loss=-10.9862 | train_mmd=0.0065 | test_mmd=0.0061 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0159\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112/500:  22%|███████████████████████████████████████████████                                                                                                                                                                   | 112/500 [00:10<00:36, 10.77it/s, loss=28.2, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 285.154. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-527001.3750 g_loss=641916.8125 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=-120118.0469 g_loss=137499.0938 | train_mmd=0.8255 | test_mmd=0.8213 | test_mmd_cellot=0.2367\n",
      "[CellOT+scGen] epoch=100 f_loss=-7551.9150 g_loss=16800.0176 | train_mmd=0.7953 | test_mmd=0.7986 | test_mmd_cellot=0.2302\n",
      "[CellOT+scGen] epoch=150 f_loss=-23257.4961 g_loss=42190.8477 | train_mmd=0.8240 | test_mmd=0.8159 | test_mmd_cellot=0.2351\n",
      "[CellOT+scGen] epoch=200 f_loss=-17574.9180 g_loss=11353.9961 | train_mmd=0.7461 | test_mmd=0.7402 | test_mmd_cellot=0.2191\n",
      "[CellOT+scGen] epoch=250 f_loss=1138.3737 g_loss=6699.6914 | train_mmd=0.0378 | test_mmd=0.0380 | test_mmd_cellot=0.0884\n",
      "[CellOT+scGen] epoch=300 f_loss=-4993.8750 g_loss=9038.4336 | train_mmd=0.1185 | test_mmd=0.1176 | test_mmd_cellot=0.1864\n",
      "[CellOT+scGen] epoch=350 f_loss=1537.2898 g_loss=302.4000 | train_mmd=0.0939 | test_mmd=0.0807 | test_mmd_cellot=0.2234\n",
      "[CellOT+scGen] epoch=400 f_loss=87.9937 g_loss=-43.9919 | train_mmd=0.0240 | test_mmd=0.0240 | test_mmd_cellot=0.0275\n",
      "[CellOT+scGen] epoch=450 f_loss=4.3863 g_loss=-49.6504 | train_mmd=0.0186 | test_mmd=0.0171 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=500 f_loss=0.8887 g_loss=-41.6697 | train_mmd=0.0110 | test_mmd=0.0108 | test_mmd_cellot=0.0156\n",
      "[CellOT+scGen] epoch=550 f_loss=0.0238 g_loss=-33.1099 | train_mmd=0.0110 | test_mmd=0.0117 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=600 f_loss=5.2800 g_loss=-28.9380 | train_mmd=0.0135 | test_mmd=0.0123 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=650 f_loss=0.0550 g_loss=-28.4088 | train_mmd=0.0093 | test_mmd=0.0088 | test_mmd_cellot=0.0168\n",
      "[CellOT+scGen] epoch=700 f_loss=1.2565 g_loss=-28.0308 | train_mmd=0.0096 | test_mmd=0.0094 | test_mmd_cellot=0.0151\n",
      "[CellOT+scGen] epoch=750 f_loss=-0.9202 g_loss=-24.1967 | train_mmd=0.0075 | test_mmd=0.0081 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.9206 g_loss=-27.3357 | train_mmd=0.0101 | test_mmd=0.0103 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=850 f_loss=3.3778 g_loss=-23.0438 | train_mmd=0.0077 | test_mmd=0.0079 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=900 f_loss=-0.2933 g_loss=-19.6100 | train_mmd=0.0071 | test_mmd=0.0080 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=950 f_loss=-2.8459 g_loss=-15.7250 | train_mmd=0.0060 | test_mmd=0.0062 | test_mmd_cellot=0.0143\n",
      "[CellOT+scGen] epoch=1000 f_loss=4.3078 g_loss=-18.7019 | train_mmd=0.0095 | test_mmd=0.0101 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=1050 f_loss=-0.6607 g_loss=-15.7312 | train_mmd=0.0069 | test_mmd=0.0076 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1100 f_loss=-0.9305 g_loss=-18.6069 | train_mmd=0.0063 | test_mmd=0.0070 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=1150 f_loss=-0.3242 g_loss=-19.9989 | train_mmd=0.0076 | test_mmd=0.0080 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1200 f_loss=0.2490 g_loss=-16.4694 | train_mmd=0.0067 | test_mmd=0.0068 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=1250 f_loss=1.8995 g_loss=-13.6077 | train_mmd=0.0065 | test_mmd=0.0073 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=1300 f_loss=1.7580 g_loss=-16.0898 | train_mmd=0.0061 | test_mmd=0.0066 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=1350 f_loss=1.1259 g_loss=-16.8723 | train_mmd=0.0055 | test_mmd=0.0053 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=1400 f_loss=-0.2998 g_loss=-14.8380 | train_mmd=0.0081 | test_mmd=0.0081 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1450 f_loss=2.8629 g_loss=-15.9152 | train_mmd=0.0057 | test_mmd=0.0069 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1500 f_loss=5.3354 g_loss=-15.3907 | train_mmd=0.0051 | test_mmd=0.0055 | test_mmd_cellot=0.0173\n",
      "[CellOT+scGen] epoch=1550 f_loss=-1.0073 g_loss=-18.0725 | train_mmd=0.0064 | test_mmd=0.0063 | test_mmd_cellot=0.0148\n",
      "[CellOT+scGen] epoch=1600 f_loss=2.5345 g_loss=-15.8317 | train_mmd=0.0074 | test_mmd=0.0081 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1650 f_loss=-2.8044 g_loss=-16.3408 | train_mmd=0.0057 | test_mmd=0.0057 | test_mmd_cellot=0.0151\n",
      "[CellOT+scGen] epoch=1700 f_loss=-2.9133 g_loss=-15.6802 | train_mmd=0.0067 | test_mmd=0.0069 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1750 f_loss=2.2636 g_loss=-15.4440 | train_mmd=0.0049 | test_mmd=0.0053 | test_mmd_cellot=0.0151\n",
      "[CellOT+scGen] epoch=1800 f_loss=-1.3776 g_loss=-14.7909 | train_mmd=0.0051 | test_mmd=0.0053 | test_mmd_cellot=0.0140\n",
      "[CellOT+scGen] epoch=1850 f_loss=-0.4290 g_loss=-16.0597 | train_mmd=0.0056 | test_mmd=0.0058 | test_mmd_cellot=0.0165\n",
      "[CellOT+scGen] epoch=1900 f_loss=-0.2367 g_loss=-13.4529 | train_mmd=0.0073 | test_mmd=0.0071 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.0963 g_loss=-13.1093 | train_mmd=0.0064 | test_mmd=0.0074 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=2000 f_loss=1.0588 g_loss=-16.3495 | train_mmd=0.0086 | test_mmd=0.0086 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2050 f_loss=-2.4894 g_loss=-14.1090 | train_mmd=0.0066 | test_mmd=0.0070 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=2100 f_loss=1.0679 g_loss=-13.6658 | train_mmd=0.0076 | test_mmd=0.0079 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=2150 f_loss=-0.2392 g_loss=-13.5182 | train_mmd=0.0045 | test_mmd=0.0050 | test_mmd_cellot=0.0147\n",
      "[CellOT+scGen] epoch=2200 f_loss=1.0186 g_loss=-13.8700 | train_mmd=0.0068 | test_mmd=0.0072 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=2250 f_loss=0.1244 g_loss=-13.6379 | train_mmd=0.0059 | test_mmd=0.0063 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2300 f_loss=1.0865 g_loss=-12.7745 | train_mmd=0.0064 | test_mmd=0.0069 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=2350 f_loss=2.8112 g_loss=-12.2760 | train_mmd=0.0062 | test_mmd=0.0065 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=2400 f_loss=-1.7859 g_loss=-13.0107 | train_mmd=0.0059 | test_mmd=0.0059 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=2450 f_loss=-1.3903 g_loss=-14.4612 | train_mmd=0.0050 | test_mmd=0.0053 | test_mmd_cellot=0.0168\n",
      "[CellOT+scGen] epoch=2500 f_loss=1.1413 g_loss=-12.0180 | train_mmd=0.0072 | test_mmd=0.0080 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=2550 f_loss=0.0881 g_loss=-13.9625 | train_mmd=0.0057 | test_mmd=0.0062 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=2600 f_loss=0.9892 g_loss=-13.6963 | train_mmd=0.0068 | test_mmd=0.0075 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2650 f_loss=-1.7310 g_loss=-12.6156 | train_mmd=0.0068 | test_mmd=0.0074 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=2700 f_loss=1.1651 g_loss=-13.4221 | train_mmd=0.0061 | test_mmd=0.0065 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=2750 f_loss=-0.5008 g_loss=-14.6076 | train_mmd=0.0072 | test_mmd=0.0078 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=2800 f_loss=0.2069 g_loss=-11.6838 | train_mmd=0.0063 | test_mmd=0.0068 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=2850 f_loss=0.4961 g_loss=-12.4130 | train_mmd=0.0061 | test_mmd=0.0065 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=2900 f_loss=-0.2334 g_loss=-12.2682 | train_mmd=0.0061 | test_mmd=0.0068 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=2950 f_loss=-1.7350 g_loss=-12.0837 | train_mmd=0.0067 | test_mmd=0.0073 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=3000 f_loss=2.1710 g_loss=-11.9456 | train_mmd=0.0064 | test_mmd=0.0067 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0192\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111/500:  22%|██████████████████████████████████████████████▌                                                                                                                                                                   | 111/500 [00:10<00:36, 10.57it/s, loss=28.1, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 279.505. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-553427.5000 g_loss=704169.4375 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=-160782.1562 g_loss=126271.7188 | train_mmd=0.7927 | test_mmd=0.7788 | test_mmd_cellot=0.2266\n",
      "[CellOT+scGen] epoch=100 f_loss=-29109.0664 g_loss=56975.1328 | train_mmd=0.8146 | test_mmd=0.8147 | test_mmd_cellot=0.2355\n",
      "[CellOT+scGen] epoch=150 f_loss=-22003.1660 g_loss=22118.3164 | train_mmd=0.7298 | test_mmd=0.7336 | test_mmd_cellot=0.2134\n",
      "[CellOT+scGen] epoch=200 f_loss=-10463.5801 g_loss=21024.5430 | train_mmd=0.3273 | test_mmd=0.3314 | test_mmd_cellot=0.1213\n",
      "[CellOT+scGen] epoch=250 f_loss=2101.7156 g_loss=6862.9668 | train_mmd=0.0468 | test_mmd=0.0496 | test_mmd_cellot=0.0771\n",
      "[CellOT+scGen] epoch=300 f_loss=4723.7822 g_loss=6968.9404 | train_mmd=0.0180 | test_mmd=0.0188 | test_mmd_cellot=0.1244\n",
      "[CellOT+scGen] epoch=350 f_loss=625.4385 g_loss=1.0208 | train_mmd=0.1078 | test_mmd=0.0996 | test_mmd_cellot=0.1159\n",
      "[CellOT+scGen] epoch=400 f_loss=32.6537 g_loss=-48.7153 | train_mmd=0.0204 | test_mmd=0.0201 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=450 f_loss=3.0906 g_loss=-40.7139 | train_mmd=0.0160 | test_mmd=0.0151 | test_mmd_cellot=0.0165\n",
      "[CellOT+scGen] epoch=500 f_loss=5.0697 g_loss=-32.4268 | train_mmd=0.0131 | test_mmd=0.0118 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=550 f_loss=0.7123 g_loss=-30.0684 | train_mmd=0.0109 | test_mmd=0.0096 | test_mmd_cellot=0.0160\n",
      "[CellOT+scGen] epoch=600 f_loss=0.8712 g_loss=-27.7609 | train_mmd=0.0136 | test_mmd=0.0130 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=650 f_loss=-2.4201 g_loss=-23.5059 | train_mmd=0.0132 | test_mmd=0.0123 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=700 f_loss=3.3666 g_loss=-24.2066 | train_mmd=0.0101 | test_mmd=0.0103 | test_mmd_cellot=0.0145\n",
      "[CellOT+scGen] epoch=750 f_loss=2.0842 g_loss=-19.8191 | train_mmd=0.0104 | test_mmd=0.0103 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=800 f_loss=0.1877 g_loss=-19.0756 | train_mmd=0.0074 | test_mmd=0.0077 | test_mmd_cellot=0.0168\n",
      "[CellOT+scGen] epoch=850 f_loss=2.0821 g_loss=-17.6991 | train_mmd=0.0100 | test_mmd=0.0100 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=900 f_loss=-4.0019 g_loss=-18.9653 | train_mmd=0.0104 | test_mmd=0.0096 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=950 f_loss=3.0245 g_loss=-19.5222 | train_mmd=0.0085 | test_mmd=0.0089 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.6638 g_loss=-16.7726 | train_mmd=0.0069 | test_mmd=0.0072 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=1050 f_loss=1.7948 g_loss=-16.2550 | train_mmd=0.0104 | test_mmd=0.0105 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1100 f_loss=-1.8706 g_loss=-17.9281 | train_mmd=0.0081 | test_mmd=0.0079 | test_mmd_cellot=0.0165\n",
      "[CellOT+scGen] epoch=1150 f_loss=1.8011 g_loss=-16.5733 | train_mmd=0.0081 | test_mmd=0.0085 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1200 f_loss=0.1994 g_loss=-16.3497 | train_mmd=0.0104 | test_mmd=0.0105 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=1250 f_loss=1.2274 g_loss=-14.9870 | train_mmd=0.0054 | test_mmd=0.0060 | test_mmd_cellot=0.0138\n",
      "[CellOT+scGen] epoch=1300 f_loss=-1.5065 g_loss=-14.5162 | train_mmd=0.0063 | test_mmd=0.0065 | test_mmd_cellot=0.0149\n",
      "[CellOT+scGen] epoch=1350 f_loss=2.7601 g_loss=-15.6955 | train_mmd=0.0081 | test_mmd=0.0083 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=1400 f_loss=-1.7487 g_loss=-16.9464 | train_mmd=0.0075 | test_mmd=0.0081 | test_mmd_cellot=0.0146\n",
      "[CellOT+scGen] epoch=1450 f_loss=-1.9890 g_loss=-15.3574 | train_mmd=0.0067 | test_mmd=0.0069 | test_mmd_cellot=0.0155\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.0796 g_loss=-14.4380 | train_mmd=0.0075 | test_mmd=0.0076 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=1550 f_loss=0.4605 g_loss=-14.5404 | train_mmd=0.0065 | test_mmd=0.0071 | test_mmd_cellot=0.0152\n",
      "[CellOT+scGen] epoch=1600 f_loss=-2.7427 g_loss=-15.9289 | train_mmd=0.0070 | test_mmd=0.0072 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=1650 f_loss=-2.1617 g_loss=-12.4473 | train_mmd=0.0055 | test_mmd=0.0061 | test_mmd_cellot=0.0140\n",
      "[CellOT+scGen] epoch=1700 f_loss=-1.6929 g_loss=-14.0730 | train_mmd=0.0085 | test_mmd=0.0080 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=1750 f_loss=-1.1892 g_loss=-11.6461 | train_mmd=0.0092 | test_mmd=0.0091 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=1800 f_loss=0.3114 g_loss=-10.8279 | train_mmd=0.0075 | test_mmd=0.0078 | test_mmd_cellot=0.0168\n",
      "[CellOT+scGen] epoch=1850 f_loss=1.6791 g_loss=-11.4337 | train_mmd=0.0078 | test_mmd=0.0078 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1900 f_loss=-0.4341 g_loss=-13.0403 | train_mmd=0.0067 | test_mmd=0.0072 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.9205 g_loss=-12.7917 | train_mmd=0.0070 | test_mmd=0.0078 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=2000 f_loss=-0.3078 g_loss=-11.2979 | train_mmd=0.0074 | test_mmd=0.0077 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.1420 g_loss=-11.1014 | train_mmd=0.0066 | test_mmd=0.0071 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=2100 f_loss=-1.8523 g_loss=-10.1972 | train_mmd=0.0069 | test_mmd=0.0077 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=2150 f_loss=1.1617 g_loss=-10.5416 | train_mmd=0.0069 | test_mmd=0.0071 | test_mmd_cellot=0.0158\n",
      "[CellOT+scGen] epoch=2200 f_loss=-1.9193 g_loss=-11.9882 | train_mmd=0.0069 | test_mmd=0.0074 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=2250 f_loss=-0.9372 g_loss=-11.2410 | train_mmd=0.0086 | test_mmd=0.0084 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=2300 f_loss=1.2767 g_loss=-10.5867 | train_mmd=0.0067 | test_mmd=0.0071 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=2350 f_loss=-1.6486 g_loss=-9.3708 | train_mmd=0.0064 | test_mmd=0.0066 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=2400 f_loss=0.9579 g_loss=-9.4466 | train_mmd=0.0075 | test_mmd=0.0079 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2450 f_loss=-2.8150 g_loss=-11.1998 | train_mmd=0.0083 | test_mmd=0.0082 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=2500 f_loss=-2.1321 g_loss=-8.5870 | train_mmd=0.0077 | test_mmd=0.0079 | test_mmd_cellot=0.0168\n",
      "[CellOT+scGen] epoch=2550 f_loss=-2.2573 g_loss=-9.3481 | train_mmd=0.0072 | test_mmd=0.0078 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=2600 f_loss=-1.5655 g_loss=-9.4185 | train_mmd=0.0065 | test_mmd=0.0066 | test_mmd_cellot=0.0154\n",
      "[CellOT+scGen] epoch=2650 f_loss=0.5182 g_loss=-11.9015 | train_mmd=0.0065 | test_mmd=0.0061 | test_mmd_cellot=0.0148\n",
      "[CellOT+scGen] epoch=2700 f_loss=-0.8774 g_loss=-9.6592 | train_mmd=0.0080 | test_mmd=0.0084 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2750 f_loss=3.7333 g_loss=-9.2595 | train_mmd=0.0068 | test_mmd=0.0072 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=2800 f_loss=-1.6609 g_loss=-9.2250 | train_mmd=0.0074 | test_mmd=0.0077 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=2850 f_loss=-0.9781 g_loss=-10.0043 | train_mmd=0.0069 | test_mmd=0.0071 | test_mmd_cellot=0.0152\n",
      "[CellOT+scGen] epoch=2900 f_loss=-0.4164 g_loss=-10.0642 | train_mmd=0.0071 | test_mmd=0.0073 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=2950 f_loss=2.7836 g_loss=-8.0112 | train_mmd=0.0070 | test_mmd=0.0071 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=3000 f_loss=1.7148 g_loss=-8.1384 | train_mmd=0.0076 | test_mmd=0.0078 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0180\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▏                                                                                                                                                                   | 110/500 [00:10<00:36, 10.69it/s, loss=28.5, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 278.955. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-516489.9375 g_loss=580293.9375 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=6789.0996 g_loss=-2703.7837 | train_mmd=0.8234 | test_mmd=0.8221 | test_mmd_cellot=0.2369\n",
      "[CellOT+scGen] epoch=100 f_loss=-166061.7500 g_loss=137119.9688 | train_mmd=0.8277 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=150 f_loss=975.8632 g_loss=7303.2646 | train_mmd=0.8195 | test_mmd=0.8177 | test_mmd_cellot=0.2364\n",
      "[CellOT+scGen] epoch=200 f_loss=-31193.6953 g_loss=25988.7539 | train_mmd=0.7165 | test_mmd=0.7186 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=250 f_loss=-3635.1174 g_loss=9335.8096 | train_mmd=0.1648 | test_mmd=0.1557 | test_mmd_cellot=0.1003\n",
      "[CellOT+scGen] epoch=300 f_loss=3407.5796 g_loss=4545.5283 | train_mmd=0.0246 | test_mmd=0.0232 | test_mmd_cellot=0.1147\n",
      "[CellOT+scGen] epoch=350 f_loss=2064.9075 g_loss=865.6198 | train_mmd=0.0323 | test_mmd=0.0334 | test_mmd_cellot=0.1921\n",
      "[CellOT+scGen] epoch=400 f_loss=188.5099 g_loss=76.1232 | train_mmd=0.0306 | test_mmd=0.0319 | test_mmd_cellot=0.0424\n",
      "[CellOT+scGen] epoch=450 f_loss=50.9184 g_loss=-25.7712 | train_mmd=0.1340 | test_mmd=0.1304 | test_mmd_cellot=0.0738\n",
      "[CellOT+scGen] epoch=500 f_loss=8.0730 g_loss=-38.4027 | train_mmd=0.0231 | test_mmd=0.0218 | test_mmd_cellot=0.0254\n",
      "[CellOT+scGen] epoch=550 f_loss=1.6161 g_loss=-36.9215 | train_mmd=0.0161 | test_mmd=0.0151 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=600 f_loss=0.6815 g_loss=-32.5049 | train_mmd=0.0105 | test_mmd=0.0097 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=650 f_loss=-1.8473 g_loss=-27.9367 | train_mmd=0.0094 | test_mmd=0.0098 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=700 f_loss=-0.3237 g_loss=-25.4133 | train_mmd=0.0127 | test_mmd=0.0119 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=750 f_loss=-1.7062 g_loss=-25.2249 | train_mmd=0.0099 | test_mmd=0.0100 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=800 f_loss=-1.9621 g_loss=-22.7019 | train_mmd=0.0088 | test_mmd=0.0088 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=850 f_loss=-2.1892 g_loss=-23.3004 | train_mmd=0.0090 | test_mmd=0.0090 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=900 f_loss=1.8868 g_loss=-20.9824 | train_mmd=0.0083 | test_mmd=0.0084 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=950 f_loss=-0.5338 g_loss=-16.3012 | train_mmd=0.0100 | test_mmd=0.0104 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.2507 g_loss=-19.1211 | train_mmd=0.0083 | test_mmd=0.0086 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=1050 f_loss=-2.3643 g_loss=-15.8239 | train_mmd=0.0066 | test_mmd=0.0071 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1100 f_loss=-2.0443 g_loss=-19.2406 | train_mmd=0.0080 | test_mmd=0.0078 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=1150 f_loss=-0.9719 g_loss=-14.4669 | train_mmd=0.0084 | test_mmd=0.0084 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=1200 f_loss=0.7849 g_loss=-17.8025 | train_mmd=0.0065 | test_mmd=0.0065 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=1250 f_loss=-2.8638 g_loss=-17.4077 | train_mmd=0.0065 | test_mmd=0.0069 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=1300 f_loss=5.2513 g_loss=-17.1153 | train_mmd=0.0063 | test_mmd=0.0073 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=1350 f_loss=3.0286 g_loss=-17.1454 | train_mmd=0.0062 | test_mmd=0.0068 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=1400 f_loss=-2.3850 g_loss=-16.6697 | train_mmd=0.0074 | test_mmd=0.0078 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=1450 f_loss=1.1881 g_loss=-16.2210 | train_mmd=0.0067 | test_mmd=0.0071 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1500 f_loss=0.1204 g_loss=-17.5526 | train_mmd=0.0064 | test_mmd=0.0067 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=1550 f_loss=-1.0883 g_loss=-16.2077 | train_mmd=0.0076 | test_mmd=0.0080 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.1385 g_loss=-18.3512 | train_mmd=0.0057 | test_mmd=0.0067 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1650 f_loss=-0.8173 g_loss=-16.5879 | train_mmd=0.0063 | test_mmd=0.0065 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1700 f_loss=-2.6081 g_loss=-18.3702 | train_mmd=0.0088 | test_mmd=0.0092 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=1750 f_loss=-1.3601 g_loss=-19.2631 | train_mmd=0.0068 | test_mmd=0.0069 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1800 f_loss=-0.9371 g_loss=-17.3551 | train_mmd=0.0065 | test_mmd=0.0067 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1850 f_loss=-2.5301 g_loss=-16.7020 | train_mmd=0.0078 | test_mmd=0.0079 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1900 f_loss=3.8760 g_loss=-15.8133 | train_mmd=0.0082 | test_mmd=0.0083 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.1352 g_loss=-18.3746 | train_mmd=0.0070 | test_mmd=0.0071 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=2000 f_loss=-1.2957 g_loss=-15.9904 | train_mmd=0.0074 | test_mmd=0.0074 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2050 f_loss=1.3572 g_loss=-16.4500 | train_mmd=0.0065 | test_mmd=0.0069 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=2100 f_loss=-0.3128 g_loss=-16.6190 | train_mmd=0.0061 | test_mmd=0.0064 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=2150 f_loss=0.2610 g_loss=-16.1595 | train_mmd=0.0079 | test_mmd=0.0078 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.4242 g_loss=-16.6439 | train_mmd=0.0066 | test_mmd=0.0067 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=2250 f_loss=-0.1054 g_loss=-14.8871 | train_mmd=0.0080 | test_mmd=0.0081 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=2300 f_loss=-1.8085 g_loss=-17.2929 | train_mmd=0.0072 | test_mmd=0.0076 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=2350 f_loss=-0.0985 g_loss=-15.3085 | train_mmd=0.0071 | test_mmd=0.0074 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=2400 f_loss=-0.7101 g_loss=-15.8880 | train_mmd=0.0077 | test_mmd=0.0082 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=2450 f_loss=-0.5098 g_loss=-16.3270 | train_mmd=0.0069 | test_mmd=0.0074 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=2500 f_loss=2.7962 g_loss=-15.3846 | train_mmd=0.0071 | test_mmd=0.0078 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2550 f_loss=0.1158 g_loss=-17.7856 | train_mmd=0.0061 | test_mmd=0.0066 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=2600 f_loss=-0.7758 g_loss=-14.7783 | train_mmd=0.0075 | test_mmd=0.0080 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=2650 f_loss=-2.5246 g_loss=-14.8261 | train_mmd=0.0076 | test_mmd=0.0084 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2700 f_loss=0.8750 g_loss=-14.1044 | train_mmd=0.0067 | test_mmd=0.0068 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2750 f_loss=-3.6709 g_loss=-17.0806 | train_mmd=0.0073 | test_mmd=0.0075 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=2800 f_loss=-2.7142 g_loss=-16.0044 | train_mmd=0.0075 | test_mmd=0.0076 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=2850 f_loss=-2.2160 g_loss=-14.5426 | train_mmd=0.0072 | test_mmd=0.0072 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=2900 f_loss=-0.8498 g_loss=-13.6640 | train_mmd=0.0072 | test_mmd=0.0077 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.3645 g_loss=-13.6009 | train_mmd=0.0065 | test_mmd=0.0069 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=3000 f_loss=1.9202 g_loss=-13.6451 | train_mmd=0.0068 | test_mmd=0.0071 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0213\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▏                                                                                                                                                                   | 110/500 [00:10<00:36, 10.64it/s, loss=27.6, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 273.275. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-755734.0000 g_loss=820622.5625 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=-242635.8438 g_loss=286561.3125 | train_mmd=0.8272 | test_mmd=0.8230 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=100 f_loss=-65669.2188 g_loss=75587.0703 | train_mmd=0.8161 | test_mmd=0.8153 | test_mmd_cellot=0.2358\n",
      "[CellOT+scGen] epoch=150 f_loss=-33876.5234 g_loss=16528.7539 | train_mmd=0.6723 | test_mmd=0.6964 | test_mmd_cellot=0.2023\n",
      "[CellOT+scGen] epoch=200 f_loss=-13480.2812 g_loss=20471.9258 | train_mmd=0.3704 | test_mmd=0.3677 | test_mmd_cellot=0.1456\n",
      "[CellOT+scGen] epoch=250 f_loss=-979.3386 g_loss=7569.8584 | train_mmd=0.0574 | test_mmd=0.0568 | test_mmd_cellot=0.0875\n",
      "[CellOT+scGen] epoch=300 f_loss=5897.3584 g_loss=3986.1277 | train_mmd=0.1623 | test_mmd=0.1403 | test_mmd_cellot=0.1909\n",
      "[CellOT+scGen] epoch=350 f_loss=936.8691 g_loss=21.6010 | train_mmd=0.0545 | test_mmd=0.0560 | test_mmd_cellot=0.1523\n",
      "[CellOT+scGen] epoch=400 f_loss=35.5258 g_loss=-50.8242 | train_mmd=0.0412 | test_mmd=0.0387 | test_mmd_cellot=0.0315\n",
      "[CellOT+scGen] epoch=450 f_loss=3.0362 g_loss=-41.7498 | train_mmd=0.0156 | test_mmd=0.0142 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=500 f_loss=-0.7830 g_loss=-30.9127 | train_mmd=0.0138 | test_mmd=0.0135 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=550 f_loss=2.4446 g_loss=-30.8479 | train_mmd=0.0143 | test_mmd=0.0126 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=600 f_loss=0.6519 g_loss=-26.7199 | train_mmd=0.0132 | test_mmd=0.0127 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=650 f_loss=2.9230 g_loss=-23.6246 | train_mmd=0.0096 | test_mmd=0.0098 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=700 f_loss=0.0004 g_loss=-21.5554 | train_mmd=0.0107 | test_mmd=0.0102 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=750 f_loss=-1.8323 g_loss=-21.0328 | train_mmd=0.0123 | test_mmd=0.0121 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=800 f_loss=1.2451 g_loss=-21.5037 | train_mmd=0.0137 | test_mmd=0.0139 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=850 f_loss=0.1393 g_loss=-18.1244 | train_mmd=0.0080 | test_mmd=0.0084 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=900 f_loss=-0.0904 g_loss=-17.7745 | train_mmd=0.0092 | test_mmd=0.0095 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=950 f_loss=1.3328 g_loss=-17.2768 | train_mmd=0.0122 | test_mmd=0.0121 | test_mmd_cellot=0.0240\n",
      "[CellOT+scGen] epoch=1000 f_loss=-1.1601 g_loss=-15.7553 | train_mmd=0.0090 | test_mmd=0.0086 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1050 f_loss=2.4731 g_loss=-15.9711 | train_mmd=0.0094 | test_mmd=0.0092 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1100 f_loss=1.3812 g_loss=-15.3270 | train_mmd=0.0087 | test_mmd=0.0084 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=1150 f_loss=2.0489 g_loss=-14.7098 | train_mmd=0.0087 | test_mmd=0.0097 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=1200 f_loss=2.4776 g_loss=-15.9792 | train_mmd=0.0088 | test_mmd=0.0094 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1250 f_loss=1.7941 g_loss=-17.8671 | train_mmd=0.0085 | test_mmd=0.0084 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1300 f_loss=-2.2730 g_loss=-17.9868 | train_mmd=0.0075 | test_mmd=0.0078 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=1350 f_loss=3.2494 g_loss=-17.4821 | train_mmd=0.0091 | test_mmd=0.0089 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=1400 f_loss=-1.3758 g_loss=-16.6541 | train_mmd=0.0076 | test_mmd=0.0077 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=1450 f_loss=-2.3374 g_loss=-16.6932 | train_mmd=0.0088 | test_mmd=0.0088 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.5409 g_loss=-17.4495 | train_mmd=0.0090 | test_mmd=0.0092 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=1550 f_loss=-2.4548 g_loss=-16.4645 | train_mmd=0.0069 | test_mmd=0.0067 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.0594 g_loss=-16.9816 | train_mmd=0.0079 | test_mmd=0.0078 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=1650 f_loss=-1.3123 g_loss=-18.4456 | train_mmd=0.0080 | test_mmd=0.0082 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=1700 f_loss=1.6958 g_loss=-17.3906 | train_mmd=0.0085 | test_mmd=0.0088 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1750 f_loss=0.5010 g_loss=-17.5776 | train_mmd=0.0066 | test_mmd=0.0069 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1800 f_loss=-1.8452 g_loss=-14.4432 | train_mmd=0.0083 | test_mmd=0.0085 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=1850 f_loss=-2.2560 g_loss=-15.5025 | train_mmd=0.0073 | test_mmd=0.0079 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=1900 f_loss=-3.3584 g_loss=-16.0717 | train_mmd=0.0082 | test_mmd=0.0084 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=1950 f_loss=0.9666 g_loss=-14.7687 | train_mmd=0.0076 | test_mmd=0.0080 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=2000 f_loss=-1.1272 g_loss=-17.0722 | train_mmd=0.0091 | test_mmd=0.0092 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=2050 f_loss=1.9567 g_loss=-14.4510 | train_mmd=0.0083 | test_mmd=0.0092 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2100 f_loss=2.5784 g_loss=-15.3012 | train_mmd=0.0087 | test_mmd=0.0092 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=2150 f_loss=0.9662 g_loss=-15.8701 | train_mmd=0.0092 | test_mmd=0.0092 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=2200 f_loss=0.6845 g_loss=-15.1346 | train_mmd=0.0089 | test_mmd=0.0092 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=2250 f_loss=-0.1377 g_loss=-14.2145 | train_mmd=0.0080 | test_mmd=0.0079 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=2300 f_loss=2.7139 g_loss=-14.1776 | train_mmd=0.0088 | test_mmd=0.0090 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=2350 f_loss=-1.3663 g_loss=-15.3717 | train_mmd=0.0072 | test_mmd=0.0075 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=2400 f_loss=-0.3824 g_loss=-14.0827 | train_mmd=0.0089 | test_mmd=0.0092 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.5906 g_loss=-14.5002 | train_mmd=0.0079 | test_mmd=0.0082 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=2500 f_loss=-0.8205 g_loss=-15.1958 | train_mmd=0.0074 | test_mmd=0.0075 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=2550 f_loss=-2.0250 g_loss=-14.8801 | train_mmd=0.0082 | test_mmd=0.0081 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=2600 f_loss=1.1192 g_loss=-14.3051 | train_mmd=0.0094 | test_mmd=0.0098 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.2099 g_loss=-13.7467 | train_mmd=0.0081 | test_mmd=0.0082 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=2700 f_loss=0.8445 g_loss=-13.8641 | train_mmd=0.0062 | test_mmd=0.0061 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=2750 f_loss=-0.3480 g_loss=-14.4342 | train_mmd=0.0072 | test_mmd=0.0073 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=2800 f_loss=-2.7931 g_loss=-14.4751 | train_mmd=0.0098 | test_mmd=0.0101 | test_mmd_cellot=0.0244\n",
      "[CellOT+scGen] epoch=2850 f_loss=-3.5150 g_loss=-13.0458 | train_mmd=0.0082 | test_mmd=0.0086 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2900 f_loss=-0.1251 g_loss=-15.0071 | train_mmd=0.0085 | test_mmd=0.0091 | test_mmd_cellot=0.0241\n",
      "[CellOT+scGen] epoch=2950 f_loss=1.5075 g_loss=-14.3437 | train_mmd=0.0088 | test_mmd=0.0092 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=3000 f_loss=-2.0447 g_loss=-15.3608 | train_mmd=0.0077 | test_mmd=0.0079 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0227\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▏                                                                                                                                                                   | 110/500 [00:10<00:38, 10.25it/s, loss=28.2, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 284.170. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-836814.8750 g_loss=897365.6250 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=2382.5229 g_loss=12948.1885 | train_mmd=0.7324 | test_mmd=0.7405 | test_mmd_cellot=0.2130\n",
      "[CellOT+scGen] epoch=100 f_loss=-184756.6719 g_loss=145796.8125 | train_mmd=0.8277 | test_mmd=0.8230 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=150 f_loss=-71988.8047 g_loss=41694.1484 | train_mmd=0.8220 | test_mmd=0.8118 | test_mmd_cellot=0.2365\n",
      "[CellOT+scGen] epoch=200 f_loss=-7061.8687 g_loss=11276.8965 | train_mmd=0.6406 | test_mmd=0.6279 | test_mmd_cellot=0.1947\n",
      "[CellOT+scGen] epoch=250 f_loss=-7454.3223 g_loss=4912.4453 | train_mmd=0.0986 | test_mmd=0.0997 | test_mmd_cellot=0.1294\n",
      "[CellOT+scGen] epoch=300 f_loss=-259.4901 g_loss=1090.4083 | train_mmd=0.0800 | test_mmd=0.0791 | test_mmd_cellot=0.1692\n",
      "[CellOT+scGen] epoch=350 f_loss=957.5809 g_loss=7.7764 | train_mmd=0.0309 | test_mmd=0.0331 | test_mmd_cellot=0.1812\n",
      "[CellOT+scGen] epoch=400 f_loss=20.4283 g_loss=-33.2412 | train_mmd=0.0335 | test_mmd=0.0325 | test_mmd_cellot=0.0286\n",
      "[CellOT+scGen] epoch=450 f_loss=5.6271 g_loss=-40.9348 | train_mmd=0.0136 | test_mmd=0.0125 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=500 f_loss=3.3679 g_loss=-34.4842 | train_mmd=0.0108 | test_mmd=0.0095 | test_mmd_cellot=0.0160\n",
      "[CellOT+scGen] epoch=550 f_loss=2.6160 g_loss=-29.7962 | train_mmd=0.0103 | test_mmd=0.0101 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=600 f_loss=-0.1738 g_loss=-29.4001 | train_mmd=0.0131 | test_mmd=0.0119 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=650 f_loss=0.4198 g_loss=-24.8388 | train_mmd=0.0119 | test_mmd=0.0109 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=700 f_loss=-5.7579 g_loss=-23.8915 | train_mmd=0.0108 | test_mmd=0.0099 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=750 f_loss=1.5316 g_loss=-20.5254 | train_mmd=0.0120 | test_mmd=0.0107 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.4407 g_loss=-20.3742 | train_mmd=0.0107 | test_mmd=0.0110 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=850 f_loss=-0.0602 g_loss=-17.7271 | train_mmd=0.0081 | test_mmd=0.0082 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=900 f_loss=-4.6207 g_loss=-18.1397 | train_mmd=0.0121 | test_mmd=0.0117 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=950 f_loss=-2.6341 g_loss=-16.8326 | train_mmd=0.0083 | test_mmd=0.0079 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1000 f_loss=1.2812 g_loss=-16.3526 | train_mmd=0.0089 | test_mmd=0.0093 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=1050 f_loss=1.5571 g_loss=-16.1446 | train_mmd=0.0075 | test_mmd=0.0078 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1100 f_loss=-0.8975 g_loss=-17.4882 | train_mmd=0.0089 | test_mmd=0.0095 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=1150 f_loss=0.1137 g_loss=-15.3003 | train_mmd=0.0081 | test_mmd=0.0083 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=1200 f_loss=1.1338 g_loss=-14.5261 | train_mmd=0.0066 | test_mmd=0.0068 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1250 f_loss=-1.6818 g_loss=-16.7222 | train_mmd=0.0061 | test_mmd=0.0062 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=1300 f_loss=-1.0307 g_loss=-16.3412 | train_mmd=0.0058 | test_mmd=0.0060 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=1350 f_loss=0.9195 g_loss=-16.2051 | train_mmd=0.0079 | test_mmd=0.0078 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1400 f_loss=-1.6715 g_loss=-15.6371 | train_mmd=0.0067 | test_mmd=0.0068 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1450 f_loss=-2.6747 g_loss=-15.6707 | train_mmd=0.0079 | test_mmd=0.0081 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=1500 f_loss=-1.4568 g_loss=-12.6583 | train_mmd=0.0074 | test_mmd=0.0073 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=1550 f_loss=-1.0597 g_loss=-13.6291 | train_mmd=0.0072 | test_mmd=0.0074 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1600 f_loss=0.6519 g_loss=-15.0396 | train_mmd=0.0065 | test_mmd=0.0074 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=1650 f_loss=0.2298 g_loss=-14.5262 | train_mmd=0.0063 | test_mmd=0.0063 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1700 f_loss=0.3702 g_loss=-15.9311 | train_mmd=0.0072 | test_mmd=0.0068 | test_mmd_cellot=0.0158\n",
      "[CellOT+scGen] epoch=1750 f_loss=-2.8971 g_loss=-14.3149 | train_mmd=0.0077 | test_mmd=0.0073 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1800 f_loss=-2.0259 g_loss=-15.8711 | train_mmd=0.0074 | test_mmd=0.0079 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1850 f_loss=3.1342 g_loss=-14.9504 | train_mmd=0.0066 | test_mmd=0.0067 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=1900 f_loss=2.4106 g_loss=-14.1140 | train_mmd=0.0057 | test_mmd=0.0060 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1950 f_loss=2.6076 g_loss=-12.6613 | train_mmd=0.0065 | test_mmd=0.0072 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=2000 f_loss=1.3041 g_loss=-15.1541 | train_mmd=0.0060 | test_mmd=0.0064 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=2050 f_loss=-1.1627 g_loss=-14.1586 | train_mmd=0.0063 | test_mmd=0.0065 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=2100 f_loss=-2.7721 g_loss=-15.4632 | train_mmd=0.0073 | test_mmd=0.0075 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=2150 f_loss=-2.3709 g_loss=-12.3911 | train_mmd=0.0073 | test_mmd=0.0078 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=2200 f_loss=-3.3171 g_loss=-15.9826 | train_mmd=0.0078 | test_mmd=0.0081 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=2250 f_loss=-2.0450 g_loss=-13.6375 | train_mmd=0.0064 | test_mmd=0.0068 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=2300 f_loss=0.7852 g_loss=-13.7775 | train_mmd=0.0064 | test_mmd=0.0067 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=2350 f_loss=-0.1871 g_loss=-13.9897 | train_mmd=0.0067 | test_mmd=0.0074 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=2400 f_loss=0.2998 g_loss=-14.9052 | train_mmd=0.0062 | test_mmd=0.0066 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.0293 g_loss=-16.5128 | train_mmd=0.0064 | test_mmd=0.0064 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=2500 f_loss=3.0541 g_loss=-14.4181 | train_mmd=0.0075 | test_mmd=0.0081 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=2550 f_loss=0.3497 g_loss=-13.8003 | train_mmd=0.0066 | test_mmd=0.0072 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2600 f_loss=2.2760 g_loss=-14.7469 | train_mmd=0.0073 | test_mmd=0.0076 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.4558 g_loss=-13.4026 | train_mmd=0.0068 | test_mmd=0.0068 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2700 f_loss=0.3513 g_loss=-14.4506 | train_mmd=0.0083 | test_mmd=0.0082 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2750 f_loss=-2.1368 g_loss=-15.5598 | train_mmd=0.0072 | test_mmd=0.0071 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2800 f_loss=2.8256 g_loss=-15.2248 | train_mmd=0.0082 | test_mmd=0.0083 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=2850 f_loss=-3.0700 g_loss=-14.5892 | train_mmd=0.0073 | test_mmd=0.0075 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=2900 f_loss=-4.1832 g_loss=-14.5770 | train_mmd=0.0097 | test_mmd=0.0094 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2950 f_loss=-2.0151 g_loss=-14.1504 | train_mmd=0.0067 | test_mmd=0.0066 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=3000 f_loss=-4.0717 g_loss=-13.8783 | train_mmd=0.0069 | test_mmd=0.0069 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0199\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111/500:  22%|██████████████████████████████████████████████▌                                                                                                                                                                   | 111/500 [00:10<00:37, 10.29it/s, loss=28.5, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 285.985. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-1060828.2500 g_loss=948062.3125 | train_mmd=0.8276 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=-627155.5625 g_loss=700189.7500 | train_mmd=0.8217 | test_mmd=0.8087 | test_mmd_cellot=0.2336\n",
      "[CellOT+scGen] epoch=100 f_loss=-140716.5625 g_loss=195787.0938 | train_mmd=0.8263 | test_mmd=0.8230 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=150 f_loss=-14317.0254 g_loss=37130.8164 | train_mmd=0.8245 | test_mmd=0.8229 | test_mmd_cellot=0.2371\n",
      "[CellOT+scGen] epoch=200 f_loss=-1001861632.0000 g_loss=1176350464.0000 | train_mmd=0.7954 | test_mmd=0.7956 | test_mmd_cellot=0.2387\n",
      "[CellOT+scGen] epoch=250 f_loss=-400764064.0000 g_loss=414407488.0000 | train_mmd=0.7734 | test_mmd=0.7944 | test_mmd_cellot=0.2342\n",
      "[CellOT+scGen] epoch=300 f_loss=23172.6465 g_loss=-3453.4858 | train_mmd=0.7822 | test_mmd=0.7722 | test_mmd_cellot=0.2217\n",
      "[CellOT+scGen] epoch=350 f_loss=-3253.4907 g_loss=31958.8262 | train_mmd=0.8193 | test_mmd=0.8120 | test_mmd_cellot=0.2353\n",
      "[CellOT+scGen] epoch=400 f_loss=41097.2500 g_loss=-7887.1611 | train_mmd=0.8120 | test_mmd=0.7925 | test_mmd_cellot=0.2288\n",
      "[CellOT+scGen] epoch=450 f_loss=-35843096576.0000 g_loss=36763217920.0000 | train_mmd=0.8217 | test_mmd=0.8123 | test_mmd_cellot=0.2338\n",
      "[CellOT+scGen] epoch=500 f_loss=62273.2344 g_loss=-4703.9482 | train_mmd=0.8232 | test_mmd=0.8177 | test_mmd_cellot=0.2355\n",
      "[CellOT+scGen] epoch=550 f_loss=23096.9824 g_loss=28448.6055 | train_mmd=0.8271 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=600 f_loss=63569.7188 g_loss=-3628.1213 | train_mmd=0.8205 | test_mmd=0.8150 | test_mmd_cellot=0.2347\n",
      "[CellOT+scGen] epoch=650 f_loss=-3590050304.0000 g_loss=3647567104.0000 | train_mmd=0.8123 | test_mmd=0.8096 | test_mmd_cellot=0.2330\n",
      "[CellOT+scGen] epoch=700 f_loss=51652.3359 g_loss=-12387.2832 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=750 f_loss=-1522849.7500 g_loss=1529190.5000 | train_mmd=0.7915 | test_mmd=0.7804 | test_mmd_cellot=0.2242\n",
      "[CellOT+scGen] epoch=800 f_loss=-17564252.0000 g_loss=19835868.0000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=850 f_loss=86355.3750 g_loss=-1772.2113 | train_mmd=0.8271 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=900 f_loss=-4271722.0000 g_loss=4467893.5000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=950 f_loss=67295.4766 g_loss=-5978.5757 | train_mmd=0.8271 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1000 f_loss=-3118623.5000 g_loss=3246924.0000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1050 f_loss=95045.9375 g_loss=-3913.2783 | train_mmd=0.8271 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1100 f_loss=-12162539.0000 g_loss=9013346.0000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1150 f_loss=102685.6797 g_loss=-7404.8916 | train_mmd=0.8278 | test_mmd=0.8204 | test_mmd_cellot=0.2364\n",
      "[CellOT+scGen] epoch=1200 f_loss=-44255728.0000 g_loss=41213188.0000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1250 f_loss=-121006784.0000 g_loss=130935336.0000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1300 f_loss=151678.0312 g_loss=-2765.4175 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1350 f_loss=52222.8125 g_loss=42357.1719 | train_mmd=0.8216 | test_mmd=0.8204 | test_mmd_cellot=0.2363\n",
      "[CellOT+scGen] epoch=1400 f_loss=-9850114.0000 g_loss=10793280.0000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1450 f_loss=119783.7188 g_loss=-2146.7678 | train_mmd=0.8250 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1500 f_loss=-220426880.0000 g_loss=240903744.0000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1550 f_loss=120113.8359 g_loss=-1093.0703 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1600 f_loss=-20255.5508 g_loss=124029.7812 | train_mmd=0.8244 | test_mmd=0.8204 | test_mmd_cellot=0.2363\n",
      "[CellOT+scGen] epoch=1650 f_loss=22209.5273 g_loss=83743.0312 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1700 f_loss=86426.3984 g_loss=-1147.3047 | train_mmd=0.8257 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1750 f_loss=120808.5547 g_loss=3095.0129 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1800 f_loss=115624.7812 g_loss=12.3077 | train_mmd=0.8264 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1850 f_loss=-18217292.0000 g_loss=19693416.0000 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=1900 f_loss=-1051405.0000 g_loss=1230570.2500 | train_mmd=0.7855 | test_mmd=0.7797 | test_mmd_cellot=0.2218\n",
      "[CellOT+scGen] epoch=1950 f_loss=121053.0391 g_loss=-241.8725 | train_mmd=0.8111 | test_mmd=0.8086 | test_mmd_cellot=0.2314\n",
      "[CellOT+scGen] epoch=2000 f_loss=7635.2598 g_loss=4418.4175 | train_mmd=0.7608 | test_mmd=0.7641 | test_mmd_cellot=0.2189\n",
      "[CellOT+scGen] epoch=2050 f_loss=103004.9375 g_loss=-338.8129 | train_mmd=0.8249 | test_mmd=0.8165 | test_mmd_cellot=0.2348\n",
      "[CellOT+scGen] epoch=2100 f_loss=-75011752.0000 g_loss=79006400.0000 | train_mmd=0.8242 | test_mmd=0.8229 | test_mmd_cellot=0.2373\n",
      "[CellOT+scGen] epoch=2150 f_loss=81510.7969 g_loss=-270.4860 | train_mmd=0.8310 | test_mmd=0.8253 | test_mmd_cellot=0.2383\n",
      "[CellOT+scGen] epoch=2200 f_loss=-168622112.0000 g_loss=171398736.0000 | train_mmd=0.8314 | test_mmd=0.8273 | test_mmd_cellot=0.2387\n",
      "[CellOT+scGen] epoch=2250 f_loss=72745.8438 g_loss=-307.2848 | train_mmd=0.8323 | test_mmd=0.8308 | test_mmd_cellot=0.2374\n",
      "[CellOT+scGen] epoch=2300 f_loss=-52093448.0000 g_loss=52772328.0000 | train_mmd=0.8249 | test_mmd=0.8221 | test_mmd_cellot=0.2373\n",
      "[CellOT+scGen] epoch=2350 f_loss=73853.2031 g_loss=1237.7365 | train_mmd=0.6538 | test_mmd=0.6440 | test_mmd_cellot=0.1963\n",
      "[CellOT+scGen] epoch=2400 f_loss=39702.8516 g_loss=-64.5021 | train_mmd=0.8283 | test_mmd=0.8242 | test_mmd_cellot=0.2377\n",
      "[CellOT+scGen] epoch=2450 f_loss=69702.0625 g_loss=-180.5018 | train_mmd=0.7384 | test_mmd=0.7215 | test_mmd_cellot=0.2115\n",
      "[CellOT+scGen] epoch=2500 f_loss=19813.2090 g_loss=1090.8574 | train_mmd=0.8289 | test_mmd=0.8253 | test_mmd_cellot=0.2383\n",
      "[CellOT+scGen] epoch=2550 f_loss=80035.4297 g_loss=2179.3743 | train_mmd=0.5911 | test_mmd=0.5867 | test_mmd_cellot=0.1860\n",
      "[CellOT+scGen] epoch=2600 f_loss=36613.2500 g_loss=-244.2682 | train_mmd=0.8417 | test_mmd=0.8391 | test_mmd_cellot=0.2420\n",
      "[CellOT+scGen] epoch=2650 f_loss=-578949.7500 g_loss=626204.2500 | train_mmd=0.3668 | test_mmd=0.3685 | test_mmd_cellot=0.1435\n",
      "[CellOT+scGen] epoch=2700 f_loss=23793.3535 g_loss=-207.4039 | train_mmd=0.8177 | test_mmd=0.8072 | test_mmd_cellot=0.2277\n",
      "[CellOT+scGen] epoch=2750 f_loss=-449882.0625 g_loss=567598.6250 | train_mmd=0.2350 | test_mmd=0.2334 | test_mmd_cellot=0.1102\n",
      "[CellOT+scGen] epoch=2800 f_loss=32790.6914 g_loss=-46.7721 | train_mmd=0.1344 | test_mmd=0.1290 | test_mmd_cellot=0.0722\n",
      "[CellOT+scGen] epoch=2850 f_loss=1457.5164 g_loss=-66.8255 | train_mmd=0.6103 | test_mmd=0.5966 | test_mmd_cellot=0.1900\n",
      "[CellOT+scGen] epoch=2900 f_loss=28.4645 g_loss=-67.9173 | train_mmd=0.0641 | test_mmd=0.0597 | test_mmd_cellot=0.0446\n",
      "[CellOT+scGen] epoch=2950 f_loss=5.6047 g_loss=-53.0084 | train_mmd=0.0146 | test_mmd=0.0137 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=3000 f_loss=0.2372 g_loss=-43.9567 | train_mmd=0.0146 | test_mmd=0.0129 | test_mmd_cellot=0.0157\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0157\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▏                                                                                                                                                                   | 110/500 [00:10<00:36, 10.62it/s, loss=28.6, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 279.524. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-674851.7500 g_loss=821425.5625 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=-85568.6250 g_loss=97425.3672 | train_mmd=0.8208 | test_mmd=0.8094 | test_mmd_cellot=0.2339\n",
      "[CellOT+scGen] epoch=100 f_loss=-128240.8125 g_loss=75293.5469 | train_mmd=0.7992 | test_mmd=0.7796 | test_mmd_cellot=0.2273\n",
      "[CellOT+scGen] epoch=150 f_loss=-13425.6484 g_loss=73304.6250 | train_mmd=0.7055 | test_mmd=0.7303 | test_mmd_cellot=0.2096\n",
      "[CellOT+scGen] epoch=200 f_loss=-1832.8318 g_loss=10277.0986 | train_mmd=0.5723 | test_mmd=0.5535 | test_mmd_cellot=0.1739\n",
      "[CellOT+scGen] epoch=250 f_loss=-650.4160 g_loss=5351.7251 | train_mmd=0.0726 | test_mmd=0.0722 | test_mmd_cellot=0.0989\n",
      "[CellOT+scGen] epoch=300 f_loss=4019.6218 g_loss=2187.6370 | train_mmd=0.0329 | test_mmd=0.0368 | test_mmd_cellot=0.1251\n",
      "[CellOT+scGen] epoch=350 f_loss=763.8750 g_loss=-18.4066 | train_mmd=0.0454 | test_mmd=0.0479 | test_mmd_cellot=0.1192\n",
      "[CellOT+scGen] epoch=400 f_loss=11.4112 g_loss=-44.6908 | train_mmd=0.0096 | test_mmd=0.0084 | test_mmd_cellot=0.0134\n",
      "[CellOT+scGen] epoch=450 f_loss=0.7158 g_loss=-36.3440 | train_mmd=0.0124 | test_mmd=0.0108 | test_mmd_cellot=0.0158\n",
      "[CellOT+scGen] epoch=500 f_loss=3.8983 g_loss=-30.9876 | train_mmd=0.0107 | test_mmd=0.0104 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=550 f_loss=0.3731 g_loss=-27.9787 | train_mmd=0.0153 | test_mmd=0.0149 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=600 f_loss=1.9072 g_loss=-27.8393 | train_mmd=0.0107 | test_mmd=0.0104 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=650 f_loss=-1.2992 g_loss=-25.8983 | train_mmd=0.0102 | test_mmd=0.0097 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=700 f_loss=-2.9341 g_loss=-22.6914 | train_mmd=0.0108 | test_mmd=0.0104 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=750 f_loss=0.8042 g_loss=-22.2376 | train_mmd=0.0067 | test_mmd=0.0070 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=800 f_loss=0.1066 g_loss=-21.9714 | train_mmd=0.0074 | test_mmd=0.0081 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=850 f_loss=1.8260 g_loss=-20.3697 | train_mmd=0.0071 | test_mmd=0.0075 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=900 f_loss=-0.8372 g_loss=-16.2720 | train_mmd=0.0093 | test_mmd=0.0096 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=950 f_loss=-0.1174 g_loss=-18.3082 | train_mmd=0.0072 | test_mmd=0.0075 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1000 f_loss=3.5708 g_loss=-18.1015 | train_mmd=0.0069 | test_mmd=0.0077 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=1050 f_loss=-1.3416 g_loss=-17.5052 | train_mmd=0.0078 | test_mmd=0.0084 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=1100 f_loss=0.5359 g_loss=-16.6884 | train_mmd=0.0077 | test_mmd=0.0082 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1150 f_loss=0.5950 g_loss=-16.1358 | train_mmd=0.0075 | test_mmd=0.0081 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=1200 f_loss=0.5836 g_loss=-14.6545 | train_mmd=0.0075 | test_mmd=0.0080 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=1250 f_loss=-1.3035 g_loss=-15.3045 | train_mmd=0.0073 | test_mmd=0.0075 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=1300 f_loss=-0.2072 g_loss=-15.1177 | train_mmd=0.0086 | test_mmd=0.0092 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=1350 f_loss=1.3208 g_loss=-17.5764 | train_mmd=0.0109 | test_mmd=0.0116 | test_mmd_cellot=0.0269\n",
      "[CellOT+scGen] epoch=1400 f_loss=1.2191 g_loss=-14.7046 | train_mmd=0.0118 | test_mmd=0.0118 | test_mmd_cellot=0.0286\n",
      "[CellOT+scGen] epoch=1450 f_loss=-3.0904 g_loss=-14.3018 | train_mmd=0.0078 | test_mmd=0.0087 | test_mmd_cellot=0.0241\n",
      "[CellOT+scGen] epoch=1500 f_loss=-3.6203 g_loss=-13.4615 | train_mmd=0.0094 | test_mmd=0.0098 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=1550 f_loss=-0.1710 g_loss=-14.3699 | train_mmd=0.0103 | test_mmd=0.0103 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=1600 f_loss=1.5333 g_loss=-13.1074 | train_mmd=0.0112 | test_mmd=0.0117 | test_mmd_cellot=0.0295\n",
      "[CellOT+scGen] epoch=1650 f_loss=0.9209 g_loss=-15.9718 | train_mmd=0.0070 | test_mmd=0.0074 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=1700 f_loss=2.5791 g_loss=-13.3956 | train_mmd=0.0090 | test_mmd=0.0093 | test_mmd_cellot=0.0258\n",
      "[CellOT+scGen] epoch=1750 f_loss=-1.5147 g_loss=-11.5894 | train_mmd=0.0076 | test_mmd=0.0080 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=1800 f_loss=1.2184 g_loss=-12.1776 | train_mmd=0.0074 | test_mmd=0.0079 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=1850 f_loss=-0.4020 g_loss=-12.5697 | train_mmd=0.0100 | test_mmd=0.0105 | test_mmd_cellot=0.0262\n",
      "[CellOT+scGen] epoch=1900 f_loss=0.2555 g_loss=-9.8188 | train_mmd=0.0075 | test_mmd=0.0081 | test_mmd_cellot=0.0225\n",
      "[CellOT+scGen] epoch=1950 f_loss=0.4634 g_loss=-12.7580 | train_mmd=0.0090 | test_mmd=0.0093 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=2000 f_loss=-0.6834 g_loss=-12.0314 | train_mmd=0.0069 | test_mmd=0.0075 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2050 f_loss=-5.1009 g_loss=-12.9437 | train_mmd=0.0067 | test_mmd=0.0071 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2100 f_loss=-0.7149 g_loss=-10.1399 | train_mmd=0.0123 | test_mmd=0.0130 | test_mmd_cellot=0.0308\n",
      "[CellOT+scGen] epoch=2150 f_loss=2.0183 g_loss=-10.2536 | train_mmd=0.0119 | test_mmd=0.0132 | test_mmd_cellot=0.0326\n",
      "[CellOT+scGen] epoch=2200 f_loss=0.6122 g_loss=-11.5077 | train_mmd=0.0078 | test_mmd=0.0079 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=2250 f_loss=0.0491 g_loss=-9.9648 | train_mmd=0.0084 | test_mmd=0.0086 | test_mmd_cellot=0.0243\n",
      "[CellOT+scGen] epoch=2300 f_loss=0.7866 g_loss=-10.0986 | train_mmd=0.0077 | test_mmd=0.0079 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=2350 f_loss=-1.6478 g_loss=-12.4957 | train_mmd=0.0076 | test_mmd=0.0078 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2400 f_loss=1.9008 g_loss=-11.0925 | train_mmd=0.0090 | test_mmd=0.0094 | test_mmd_cellot=0.0272\n",
      "[CellOT+scGen] epoch=2450 f_loss=1.3001 g_loss=-10.9101 | train_mmd=0.0084 | test_mmd=0.0088 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2500 f_loss=2.1186 g_loss=-10.1264 | train_mmd=0.0101 | test_mmd=0.0105 | test_mmd_cellot=0.0286\n",
      "[CellOT+scGen] epoch=2550 f_loss=-3.5270 g_loss=-8.7767 | train_mmd=0.0059 | test_mmd=0.0066 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=2600 f_loss=-0.9708 g_loss=-10.2060 | train_mmd=0.0086 | test_mmd=0.0094 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=2650 f_loss=-1.8755 g_loss=-10.8677 | train_mmd=0.0078 | test_mmd=0.0082 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=2700 f_loss=-0.9016 g_loss=-9.3945 | train_mmd=0.0076 | test_mmd=0.0076 | test_mmd_cellot=0.0239\n",
      "[CellOT+scGen] epoch=2750 f_loss=-4.5679 g_loss=-12.3513 | train_mmd=0.0089 | test_mmd=0.0094 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2800 f_loss=-1.2216 g_loss=-13.0277 | train_mmd=0.0075 | test_mmd=0.0076 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=2850 f_loss=-0.7339 g_loss=-14.6167 | train_mmd=0.0063 | test_mmd=0.0068 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=2900 f_loss=0.8443 g_loss=-13.7255 | train_mmd=0.0058 | test_mmd=0.0063 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=2950 f_loss=0.9455 g_loss=-15.7715 | train_mmd=0.0067 | test_mmd=0.0069 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=3000 f_loss=-1.9234 g_loss=-13.4030 | train_mmd=0.0055 | test_mmd=0.0058 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0181\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111/500:  22%|██████████████████████████████████████████████▌                                                                                                                                                                   | 111/500 [00:10<00:37, 10.47it/s, loss=28.2, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 280.646. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-760225.6875 g_loss=1470949.3750 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=-79787.8906 g_loss=142615.9375 | train_mmd=0.8218 | test_mmd=0.8150 | test_mmd_cellot=0.2352\n",
      "[CellOT+scGen] epoch=100 f_loss=-43476.4922 g_loss=61939.6406 | train_mmd=0.8017 | test_mmd=0.8023 | test_mmd_cellot=0.2333\n",
      "[CellOT+scGen] epoch=150 f_loss=-53688.4258 g_loss=36610.0273 | train_mmd=0.6925 | test_mmd=0.6736 | test_mmd_cellot=0.2021\n",
      "[CellOT+scGen] epoch=200 f_loss=-11893.3535 g_loss=6450.8535 | train_mmd=0.2922 | test_mmd=0.2934 | test_mmd_cellot=0.1351\n",
      "[CellOT+scGen] epoch=250 f_loss=-4170.2925 g_loss=3500.9385 | train_mmd=0.0519 | test_mmd=0.0533 | test_mmd_cellot=0.1137\n",
      "[CellOT+scGen] epoch=300 f_loss=686.4918 g_loss=80.1494 | train_mmd=0.0410 | test_mmd=0.0414 | test_mmd_cellot=0.1407\n",
      "[CellOT+scGen] epoch=350 f_loss=127.7690 g_loss=-20.0315 | train_mmd=0.0503 | test_mmd=0.0516 | test_mmd_cellot=0.0960\n",
      "[CellOT+scGen] epoch=400 f_loss=-33.8348 g_loss=-43.3863 | train_mmd=0.0229 | test_mmd=0.0214 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=450 f_loss=0.2750 g_loss=-37.8046 | train_mmd=0.0115 | test_mmd=0.0114 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=500 f_loss=5.4284 g_loss=-31.1461 | train_mmd=0.0147 | test_mmd=0.0136 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=550 f_loss=3.2413 g_loss=-27.4983 | train_mmd=0.0148 | test_mmd=0.0142 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=600 f_loss=0.9128 g_loss=-25.4421 | train_mmd=0.0115 | test_mmd=0.0101 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=650 f_loss=2.6769 g_loss=-25.5331 | train_mmd=0.0084 | test_mmd=0.0078 | test_mmd_cellot=0.0150\n",
      "[CellOT+scGen] epoch=700 f_loss=-2.3043 g_loss=-22.3825 | train_mmd=0.0113 | test_mmd=0.0105 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=750 f_loss=-2.6512 g_loss=-20.7988 | train_mmd=0.0112 | test_mmd=0.0115 | test_mmd_cellot=0.0240\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.0122 g_loss=-19.1344 | train_mmd=0.0104 | test_mmd=0.0105 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=850 f_loss=-0.4296 g_loss=-18.6509 | train_mmd=0.0102 | test_mmd=0.0096 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=900 f_loss=3.6756 g_loss=-19.6325 | train_mmd=0.0087 | test_mmd=0.0097 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=950 f_loss=-1.2060 g_loss=-17.6298 | train_mmd=0.0088 | test_mmd=0.0080 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1000 f_loss=-1.7311 g_loss=-16.7183 | train_mmd=0.0082 | test_mmd=0.0072 | test_mmd_cellot=0.0140\n",
      "[CellOT+scGen] epoch=1050 f_loss=1.8208 g_loss=-13.1586 | train_mmd=0.0070 | test_mmd=0.0072 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1100 f_loss=3.4409 g_loss=-17.0632 | train_mmd=0.0085 | test_mmd=0.0080 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1150 f_loss=1.0127 g_loss=-13.8556 | train_mmd=0.0063 | test_mmd=0.0064 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=1200 f_loss=-0.5672 g_loss=-14.9922 | train_mmd=0.0082 | test_mmd=0.0082 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=1250 f_loss=1.2309 g_loss=-14.8855 | train_mmd=0.0058 | test_mmd=0.0057 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=1300 f_loss=-1.0835 g_loss=-17.2084 | train_mmd=0.0081 | test_mmd=0.0088 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=1350 f_loss=3.4721 g_loss=-14.5763 | train_mmd=0.0068 | test_mmd=0.0068 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=1400 f_loss=-0.0594 g_loss=-14.3032 | train_mmd=0.0073 | test_mmd=0.0071 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=1450 f_loss=0.2409 g_loss=-13.8559 | train_mmd=0.0090 | test_mmd=0.0088 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1500 f_loss=1.0301 g_loss=-12.0372 | train_mmd=0.0081 | test_mmd=0.0080 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=1550 f_loss=-1.6494 g_loss=-14.1372 | train_mmd=0.0088 | test_mmd=0.0086 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.2930 g_loss=-13.4135 | train_mmd=0.0074 | test_mmd=0.0074 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1650 f_loss=2.7216 g_loss=-12.2590 | train_mmd=0.0075 | test_mmd=0.0076 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=1700 f_loss=0.3103 g_loss=-13.1833 | train_mmd=0.0080 | test_mmd=0.0082 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=1750 f_loss=-0.0979 g_loss=-11.9627 | train_mmd=0.0082 | test_mmd=0.0078 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1800 f_loss=2.6630 g_loss=-11.8997 | train_mmd=0.0077 | test_mmd=0.0076 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=1850 f_loss=-1.3934 g_loss=-9.6049 | train_mmd=0.0079 | test_mmd=0.0077 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=1900 f_loss=-5.5835 g_loss=-10.2268 | train_mmd=0.0089 | test_mmd=0.0089 | test_mmd_cellot=0.0239\n",
      "[CellOT+scGen] epoch=1950 f_loss=1.3038 g_loss=-8.5187 | train_mmd=0.0116 | test_mmd=0.0107 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=2000 f_loss=0.6613 g_loss=-10.8551 | train_mmd=0.0080 | test_mmd=0.0078 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=2050 f_loss=1.0296 g_loss=-10.2325 | train_mmd=0.0095 | test_mmd=0.0092 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2100 f_loss=1.9750 g_loss=-10.6308 | train_mmd=0.0102 | test_mmd=0.0100 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=2150 f_loss=-1.1466 g_loss=-11.4173 | train_mmd=0.0087 | test_mmd=0.0081 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=2200 f_loss=3.6113 g_loss=-7.4707 | train_mmd=0.0088 | test_mmd=0.0085 | test_mmd_cellot=0.0239\n",
      "[CellOT+scGen] epoch=2250 f_loss=-0.4334 g_loss=-6.9678 | train_mmd=0.0091 | test_mmd=0.0091 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2300 f_loss=1.5330 g_loss=-7.9062 | train_mmd=0.0080 | test_mmd=0.0080 | test_mmd_cellot=0.0239\n",
      "[CellOT+scGen] epoch=2350 f_loss=-1.4114 g_loss=-6.9561 | train_mmd=0.0098 | test_mmd=0.0099 | test_mmd_cellot=0.0252\n",
      "[CellOT+scGen] epoch=2400 f_loss=-3.1805 g_loss=-8.4105 | train_mmd=0.0068 | test_mmd=0.0068 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=2450 f_loss=-2.0478 g_loss=-6.6970 | train_mmd=0.0096 | test_mmd=0.0089 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=2500 f_loss=0.4128 g_loss=-10.4064 | train_mmd=0.0088 | test_mmd=0.0083 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=2550 f_loss=-2.3549 g_loss=-7.6597 | train_mmd=0.0081 | test_mmd=0.0081 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=2600 f_loss=2.2945 g_loss=-7.1441 | train_mmd=0.0084 | test_mmd=0.0084 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2650 f_loss=-2.5441 g_loss=-6.6863 | train_mmd=0.0079 | test_mmd=0.0074 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=2700 f_loss=-0.8671 g_loss=-6.4965 | train_mmd=0.0088 | test_mmd=0.0090 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=2750 f_loss=0.0040 g_loss=-5.3408 | train_mmd=0.0093 | test_mmd=0.0094 | test_mmd_cellot=0.0261\n",
      "[CellOT+scGen] epoch=2800 f_loss=-0.1806 g_loss=-5.8874 | train_mmd=0.0085 | test_mmd=0.0084 | test_mmd_cellot=0.0252\n",
      "[CellOT+scGen] epoch=2850 f_loss=-1.4153 g_loss=-5.0911 | train_mmd=0.0092 | test_mmd=0.0093 | test_mmd_cellot=0.0244\n",
      "[CellOT+scGen] epoch=2900 f_loss=-2.2805 g_loss=-5.7411 | train_mmd=0.0087 | test_mmd=0.0083 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=2950 f_loss=-1.9412 g_loss=-7.6910 | train_mmd=0.0074 | test_mmd=0.0071 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=3000 f_loss=3.0957 g_loss=-5.7835 | train_mmd=0.0081 | test_mmd=0.0082 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0231\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▏                                                                                                                                                                   | 110/500 [00:10<00:37, 10.36it/s, loss=28.5, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 276.316. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-569758.7500 g_loss=649914.1250 | train_mmd=0.8278 | test_mmd=0.8231 | test_mmd_cellot=0.2372\n",
      "[CellOT+scGen] epoch=50 f_loss=-121410.2734 g_loss=40059.9414 | train_mmd=0.7719 | test_mmd=0.7788 | test_mmd_cellot=0.2259\n",
      "[CellOT+scGen] epoch=100 f_loss=-78816.8359 g_loss=128880.1953 | train_mmd=0.8121 | test_mmd=0.8059 | test_mmd_cellot=0.2334\n",
      "[CellOT+scGen] epoch=150 f_loss=-60310.8398 g_loss=44492.0469 | train_mmd=0.8505 | test_mmd=0.8455 | test_mmd_cellot=0.2405\n",
      "[CellOT+scGen] epoch=200 f_loss=-820.1595 g_loss=13762.1426 | train_mmd=0.3362 | test_mmd=0.3554 | test_mmd_cellot=0.1508\n",
      "[CellOT+scGen] epoch=250 f_loss=2791.2932 g_loss=6818.9023 | train_mmd=0.0572 | test_mmd=0.0572 | test_mmd_cellot=0.1015\n",
      "[CellOT+scGen] epoch=300 f_loss=-8930.0605 g_loss=479.5775 | train_mmd=0.0481 | test_mmd=0.0542 | test_mmd_cellot=0.1437\n",
      "[CellOT+scGen] epoch=350 f_loss=1199.4167 g_loss=54.5643 | train_mmd=0.0462 | test_mmd=0.0487 | test_mmd_cellot=0.2222\n",
      "[CellOT+scGen] epoch=400 f_loss=36.9909 g_loss=-51.3781 | train_mmd=0.0301 | test_mmd=0.0289 | test_mmd_cellot=0.0277\n",
      "[CellOT+scGen] epoch=450 f_loss=5.6416 g_loss=-39.9351 | train_mmd=0.0153 | test_mmd=0.0142 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=500 f_loss=1.2588 g_loss=-33.8343 | train_mmd=0.0140 | test_mmd=0.0134 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=550 f_loss=0.3427 g_loss=-31.8098 | train_mmd=0.0092 | test_mmd=0.0093 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=600 f_loss=3.1493 g_loss=-29.2695 | train_mmd=0.0120 | test_mmd=0.0124 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=650 f_loss=1.8357 g_loss=-25.7207 | train_mmd=0.0102 | test_mmd=0.0096 | test_mmd_cellot=0.0155\n",
      "[CellOT+scGen] epoch=700 f_loss=2.7131 g_loss=-26.3609 | train_mmd=0.0132 | test_mmd=0.0132 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=750 f_loss=1.8811 g_loss=-20.7990 | train_mmd=0.0137 | test_mmd=0.0145 | test_mmd_cellot=0.0274\n",
      "[CellOT+scGen] epoch=800 f_loss=-1.8207 g_loss=-21.8205 | train_mmd=0.0135 | test_mmd=0.0124 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=850 f_loss=-4.3587 g_loss=-20.5193 | train_mmd=0.0083 | test_mmd=0.0087 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=900 f_loss=0.2593 g_loss=-19.5947 | train_mmd=0.0076 | test_mmd=0.0082 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=950 f_loss=2.1973 g_loss=-19.6529 | train_mmd=0.0091 | test_mmd=0.0090 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.2691 g_loss=-20.6867 | train_mmd=0.0085 | test_mmd=0.0088 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=1050 f_loss=1.1091 g_loss=-19.3992 | train_mmd=0.0081 | test_mmd=0.0076 | test_mmd_cellot=0.0173\n",
      "[CellOT+scGen] epoch=1100 f_loss=-2.0523 g_loss=-19.4784 | train_mmd=0.0074 | test_mmd=0.0076 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1150 f_loss=1.3247 g_loss=-21.1812 | train_mmd=0.0082 | test_mmd=0.0086 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1200 f_loss=0.3847 g_loss=-20.0938 | train_mmd=0.0083 | test_mmd=0.0089 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1250 f_loss=1.6114 g_loss=-16.8312 | train_mmd=0.0066 | test_mmd=0.0071 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1300 f_loss=3.9909 g_loss=-18.7487 | train_mmd=0.0087 | test_mmd=0.0093 | test_mmd_cellot=0.0225\n",
      "[CellOT+scGen] epoch=1350 f_loss=2.4668 g_loss=-16.6165 | train_mmd=0.0102 | test_mmd=0.0110 | test_mmd_cellot=0.0242\n",
      "[CellOT+scGen] epoch=1400 f_loss=-3.6192 g_loss=-16.2194 | train_mmd=0.0090 | test_mmd=0.0095 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=1450 f_loss=2.1680 g_loss=-15.9266 | train_mmd=0.0062 | test_mmd=0.0069 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=1500 f_loss=1.0839 g_loss=-16.0221 | train_mmd=0.0085 | test_mmd=0.0095 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=1550 f_loss=0.1952 g_loss=-17.6868 | train_mmd=0.0083 | test_mmd=0.0087 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=1600 f_loss=-4.1213 g_loss=-19.1156 | train_mmd=0.0074 | test_mmd=0.0082 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=1650 f_loss=-0.8909 g_loss=-17.5757 | train_mmd=0.0087 | test_mmd=0.0092 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=1700 f_loss=-1.0566 g_loss=-17.0387 | train_mmd=0.0085 | test_mmd=0.0086 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1750 f_loss=-1.5997 g_loss=-15.6969 | train_mmd=0.0086 | test_mmd=0.0086 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=1800 f_loss=2.6690 g_loss=-18.0102 | train_mmd=0.0083 | test_mmd=0.0086 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1850 f_loss=-4.5196 g_loss=-16.5051 | train_mmd=0.0081 | test_mmd=0.0087 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=1900 f_loss=-3.9030 g_loss=-15.6823 | train_mmd=0.0074 | test_mmd=0.0077 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1950 f_loss=2.0644 g_loss=-17.5724 | train_mmd=0.0083 | test_mmd=0.0088 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=2000 f_loss=3.0414 g_loss=-15.9106 | train_mmd=0.0079 | test_mmd=0.0080 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.5857 g_loss=-16.8809 | train_mmd=0.0075 | test_mmd=0.0078 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=2100 f_loss=1.6026 g_loss=-14.2715 | train_mmd=0.0084 | test_mmd=0.0087 | test_mmd_cellot=0.0243\n",
      "[CellOT+scGen] epoch=2150 f_loss=-1.4670 g_loss=-15.0643 | train_mmd=0.0096 | test_mmd=0.0099 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.6319 g_loss=-16.3866 | train_mmd=0.0082 | test_mmd=0.0080 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2250 f_loss=1.3086 g_loss=-15.8499 | train_mmd=0.0079 | test_mmd=0.0083 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=2300 f_loss=0.4732 g_loss=-14.4662 | train_mmd=0.0090 | test_mmd=0.0096 | test_mmd_cellot=0.0244\n",
      "[CellOT+scGen] epoch=2350 f_loss=-2.2657 g_loss=-15.7262 | train_mmd=0.0073 | test_mmd=0.0074 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=2400 f_loss=4.4192 g_loss=-14.6481 | train_mmd=0.0086 | test_mmd=0.0089 | test_mmd_cellot=0.0251\n",
      "[CellOT+scGen] epoch=2450 f_loss=-1.5197 g_loss=-16.8967 | train_mmd=0.0089 | test_mmd=0.0093 | test_mmd_cellot=0.0241\n",
      "[CellOT+scGen] epoch=2500 f_loss=1.9144 g_loss=-16.2114 | train_mmd=0.0098 | test_mmd=0.0101 | test_mmd_cellot=0.0241\n",
      "[CellOT+scGen] epoch=2550 f_loss=0.2765 g_loss=-12.8042 | train_mmd=0.0081 | test_mmd=0.0084 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=2600 f_loss=0.6365 g_loss=-16.2818 | train_mmd=0.0113 | test_mmd=0.0117 | test_mmd_cellot=0.0286\n",
      "[CellOT+scGen] epoch=2650 f_loss=0.7845 g_loss=-14.4588 | train_mmd=0.0087 | test_mmd=0.0091 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=2700 f_loss=-2.0128 g_loss=-14.5074 | train_mmd=0.0088 | test_mmd=0.0092 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2750 f_loss=-0.0925 g_loss=-14.0138 | train_mmd=0.0085 | test_mmd=0.0088 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=2800 f_loss=0.9526 g_loss=-13.8641 | train_mmd=0.0071 | test_mmd=0.0078 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2850 f_loss=-1.1440 g_loss=-13.1202 | train_mmd=0.0089 | test_mmd=0.0095 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=2900 f_loss=-2.5592 g_loss=-13.1276 | train_mmd=0.0086 | test_mmd=0.0092 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.9933 g_loss=-14.6121 | train_mmd=0.0097 | test_mmd=0.0101 | test_mmd_cellot=0.0257\n",
      "[CellOT+scGen] epoch=3000 f_loss=-0.1574 g_loss=-13.7822 | train_mmd=0.0082 | test_mmd=0.0084 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0230\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=== Metrics Summary over Runs for top 100 genes ===\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0078  0.0020\n",
      "mmd2_gamma_0.5        0.0037  0.0002\n",
      "mmd2_gamma_1.0        0.0032  0.0000\n",
      "wasserstein_distance  5.9747  0.4286\n",
      "R2_feature_means      0.6593  0.1152\n"
     ]
    }
   ],
   "source": [
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "\n",
    "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=3000, top_feature_subset=top_genes_idx, seed=seed)\n",
    "  \n",
    "    metrics = summarize_metrics(out[\"y_pred\"][:, top_genes_idx], Y_te_post[:, top_genes_idx], median_gamma)\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "print(\"=== Metrics Summary over Runs for top 100 genes ===\")\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "281caf42",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/umap/umap_.py:1952: UserWarning: n_jobs value 1 overridden to 1 by setting random_state. Use no seed for parallelism.\n",
      "  warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/sklearn/utils/deprecation.py:151: FutureWarning: 'force_all_finite' was renamed to 'ensure_all_finite' in 1.6 and will be removed in 1.8.\n",
      "  warnings.warn(\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from umap import UMAP\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "source = out[\"y_pred\"][:, top_genes_idx]\n",
    "target = Y_te_post[:, top_genes_idx]\n",
    "\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([target]))\n",
    "source_umap = umap_model.transform(source)\n",
    "target_umap = umap_model.transform(target)\n",
    "\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 4))\n",
    "# ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='train_post', color='C2')\n",
    "ax.scatter(target_umap[:, 0], target_umap[:, 1], s=10, alpha=0.7, label='observed treated cells', color=\"#C331C8\")\n",
    "ax.scatter(source_umap[:, 0], source_umap[:, 1], s=10, alpha=0.7, label='predicted cells', color=\"#24A139\")\n",
    "\n",
    "ax.set_title(f'{drug}')\n",
    "# ax.set_xlabel('UMAP 1')\n",
    "# ax.set_ylabel('UMAP 2')\n",
    "ax.set_aspect('equal', 'box')\n",
    "# Add a legend to distinguish the points\n",
    "ax.legend()\n",
    "# Adjust layout\n",
    "plt.tight_layout()\n",
    "# Display the plot\n",
    "plt.savefig(f\"./plots/scgen_on_4i_drug_{drug}.png\", dpi=300)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a8c36eda",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7feb3ac",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f43120a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "266b076d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "027ab0f9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5bca690",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d4ef2b81",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d7a6c0f3",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "25fa718b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (17565, 1000)\n",
      "X_post cells: (3541, 1000)\n",
      "(2832, 1000)\n",
      "(709, 1000)\n",
      "(2832, 1000)\n",
      "(709, 1000)\n",
      "Median heuristic gamma: 0.0022147542823654246\n"
     ]
    }
   ],
   "source": [
    "drug = \"givinostat\"\n",
    "X_pre = adata_sc[adata_sc.obs[\"drug\"] == \"control\"].copy().to_df()\n",
    "X_post  = adata_sc[adata_sc.obs[\"drug\"] == drug].copy().to_df()\n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "top_genes_ids, top_genes_short, top_genes_idx = topk_markers(adata_sc, drug, k=100)\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",
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "03d0e181",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2832, 1000)\n",
      "(709, 1000)\n",
      "(2832, 1000)\n",
      "(709, 1000)\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111/500:  22%|██████████████████████████████████████████████▌                                                                                                                                                                   | 111/500 [00:10<00:36, 10.59it/s, loss=30.9, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 291.400. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-451428.5625 g_loss=561849.2500 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=-463607.6562 g_loss=769590.8125 | train_mmd=0.7592 | test_mmd=0.7555 | test_mmd_cellot=0.2045\n",
      "[CellOT+scGen] epoch=100 f_loss=6841.3096 g_loss=-4710.3457 | train_mmd=0.7580 | test_mmd=0.7573 | test_mmd_cellot=0.2046\n",
      "[CellOT+scGen] epoch=150 f_loss=-124334.4453 g_loss=159553.4375 | train_mmd=0.7294 | test_mmd=0.7291 | test_mmd_cellot=0.1960\n",
      "[CellOT+scGen] epoch=200 f_loss=5675.8555 g_loss=-2475.3860 | train_mmd=0.7174 | test_mmd=0.7324 | test_mmd_cellot=0.1971\n",
      "[CellOT+scGen] epoch=250 f_loss=14963.4385 g_loss=-5565.3574 | train_mmd=0.7720 | test_mmd=0.7737 | test_mmd_cellot=0.2129\n",
      "[CellOT+scGen] epoch=300 f_loss=-3562454016.0000 g_loss=4379934208.0000 | train_mmd=0.7663 | test_mmd=0.7704 | test_mmd_cellot=0.2080\n",
      "[CellOT+scGen] epoch=350 f_loss=16254.7617 g_loss=-12212.2676 | train_mmd=0.7604 | test_mmd=0.7632 | test_mmd_cellot=0.2140\n",
      "[CellOT+scGen] epoch=400 f_loss=30311.1094 g_loss=-3823.7646 | train_mmd=0.7661 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=450 f_loss=-13176213504.0000 g_loss=16569665536.0000 | train_mmd=0.7716 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=500 f_loss=21934.2891 g_loss=-12324.5117 | train_mmd=0.7706 | test_mmd=0.7680 | test_mmd_cellot=0.2073\n",
      "[CellOT+scGen] epoch=550 f_loss=-90746152.0000 g_loss=103764248.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=600 f_loss=47496.6289 g_loss=-4435.9893 | train_mmd=0.7703 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=650 f_loss=-269475232.0000 g_loss=314930496.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=700 f_loss=47982.1562 g_loss=-11256.9385 | train_mmd=0.7697 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=750 f_loss=-292004224.0000 g_loss=347797504.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=800 f_loss=67531.2188 g_loss=-3419.7764 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=850 f_loss=-1858658.0000 g_loss=1930208.7500 | train_mmd=0.7697 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=900 f_loss=80464.7891 g_loss=-4874.7852 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=950 f_loss=-103842.5391 g_loss=180607.4844 | train_mmd=0.7728 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=1000 f_loss=73506.3438 g_loss=-5357.8701 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1050 f_loss=-11249290.0000 g_loss=10792857.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1100 f_loss=-13925435.0000 g_loss=15880712.0000 | train_mmd=0.7722 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1150 f_loss=87290.3906 g_loss=-3488.3484 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1200 f_loss=-30568778.0000 g_loss=33445216.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1250 f_loss=87500.4375 g_loss=16295.4844 | train_mmd=0.7728 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1300 f_loss=106745.0391 g_loss=-2994.5374 | train_mmd=0.7716 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1350 f_loss=-4162894848.0000 g_loss=4148577536.0000 | train_mmd=0.7686 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=1400 f_loss=-31862.8867 g_loss=194771.8125 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1450 f_loss=120019.9531 g_loss=-1895.6653 | train_mmd=0.7722 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1500 f_loss=54791.2500 g_loss=111102.3047 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1550 f_loss=144400.5312 g_loss=-2348.6108 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1600 f_loss=-36632144.0000 g_loss=31289924.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1650 f_loss=-5027192.0000 g_loss=5542710.5000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1700 f_loss=148896.0938 g_loss=-509.2352 | train_mmd=0.7733 | test_mmd=0.7702 | test_mmd_cellot=0.2077\n",
      "[CellOT+scGen] epoch=1750 f_loss=63750.5156 g_loss=2838.1284 | train_mmd=0.7709 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=1800 f_loss=118158.0469 g_loss=-1606.8579 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1850 f_loss=-1317291520.0000 g_loss=1303890432.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1900 f_loss=-5650838.0000 g_loss=6047446.0000 | train_mmd=0.7732 | test_mmd=0.7725 | test_mmd_cellot=0.2082\n",
      "[CellOT+scGen] epoch=1950 f_loss=-23600.7969 g_loss=191874.3125 | train_mmd=0.7323 | test_mmd=0.7398 | test_mmd_cellot=0.1979\n",
      "[CellOT+scGen] epoch=2000 f_loss=97610.1406 g_loss=-432.5378 | train_mmd=0.7728 | test_mmd=0.7711 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=2050 f_loss=3023.9358 g_loss=6496.4565 | train_mmd=0.7243 | test_mmd=0.7237 | test_mmd_cellot=0.1934\n",
      "[CellOT+scGen] epoch=2100 f_loss=-603198.0000 g_loss=669311.6250 | train_mmd=0.2984 | test_mmd=0.2885 | test_mmd_cellot=0.1119\n",
      "[CellOT+scGen] epoch=2150 f_loss=28407.6250 g_loss=-180.6862 | train_mmd=0.7170 | test_mmd=0.7408 | test_mmd_cellot=0.1970\n",
      "[CellOT+scGen] epoch=2200 f_loss=-354.0105 g_loss=1539.4821 | train_mmd=0.6859 | test_mmd=0.7053 | test_mmd_cellot=0.1913\n",
      "[CellOT+scGen] epoch=2250 f_loss=13258.5137 g_loss=-90.1731 | train_mmd=0.4368 | test_mmd=0.4445 | test_mmd_cellot=0.1434\n",
      "[CellOT+scGen] epoch=2300 f_loss=-7973046.0000 g_loss=8385657.0000 | train_mmd=0.4667 | test_mmd=0.4716 | test_mmd_cellot=0.1481\n",
      "[CellOT+scGen] epoch=2350 f_loss=9046.0879 g_loss=-198.1557 | train_mmd=0.7947 | test_mmd=0.7892 | test_mmd_cellot=0.2079\n",
      "[CellOT+scGen] epoch=2400 f_loss=42148.8359 g_loss=-113.1972 | train_mmd=0.4344 | test_mmd=0.4184 | test_mmd_cellot=0.1356\n",
      "[CellOT+scGen] epoch=2450 f_loss=2780.7751 g_loss=628.2151 | train_mmd=0.8077 | test_mmd=0.8058 | test_mmd_cellot=0.2109\n",
      "[CellOT+scGen] epoch=2500 f_loss=46283.5117 g_loss=-59.4061 | train_mmd=0.4016 | test_mmd=0.4051 | test_mmd_cellot=0.1333\n",
      "[CellOT+scGen] epoch=2550 f_loss=2419.8289 g_loss=365.4624 | train_mmd=0.7887 | test_mmd=0.7959 | test_mmd_cellot=0.2076\n",
      "[CellOT+scGen] epoch=2600 f_loss=81.4484 g_loss=-63.6570 | train_mmd=0.1186 | test_mmd=0.1217 | test_mmd_cellot=0.0624\n",
      "[CellOT+scGen] epoch=2650 f_loss=25.9345 g_loss=-56.9228 | train_mmd=0.0191 | test_mmd=0.0183 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=2700 f_loss=7.9079 g_loss=-49.0297 | train_mmd=0.0187 | test_mmd=0.0174 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=2750 f_loss=4.4933 g_loss=-45.2348 | train_mmd=0.0163 | test_mmd=0.0159 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=2800 f_loss=-2.1774 g_loss=-43.6702 | train_mmd=0.0136 | test_mmd=0.0130 | test_mmd_cellot=0.0133\n",
      "[CellOT+scGen] epoch=2850 f_loss=-0.2283 g_loss=-39.9479 | train_mmd=0.0154 | test_mmd=0.0141 | test_mmd_cellot=0.0139\n",
      "[CellOT+scGen] epoch=2900 f_loss=56.4519 g_loss=-38.2499 | train_mmd=0.0115 | test_mmd=0.0116 | test_mmd_cellot=0.0118\n",
      "[CellOT+scGen] epoch=2950 f_loss=0.2496 g_loss=-37.6794 | train_mmd=0.0119 | test_mmd=0.0119 | test_mmd_cellot=0.0135\n",
      "[CellOT+scGen] epoch=3000 f_loss=-38.9252 g_loss=-37.8957 | train_mmd=0.0137 | test_mmd=0.0132 | test_mmd_cellot=0.0136\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0136\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n",
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 112/500:  22%|███████████████████████████████████████████████                                                                                                                                                                   | 112/500 [00:10<00:36, 10.66it/s, loss=31.2, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 299.752. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-525321.8750 g_loss=625502.3125 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=-235690.2812 g_loss=297704.9375 | train_mmd=0.7719 | test_mmd=0.7717 | test_mmd_cellot=0.2083\n",
      "[CellOT+scGen] epoch=100 f_loss=5903.2910 g_loss=-4273.2812 | train_mmd=0.7682 | test_mmd=0.7704 | test_mmd_cellot=0.2079\n",
      "[CellOT+scGen] epoch=150 f_loss=-53358.3477 g_loss=50151.8438 | train_mmd=0.7721 | test_mmd=0.7689 | test_mmd_cellot=0.2075\n",
      "[CellOT+scGen] epoch=200 f_loss=-66611.9219 g_loss=95601.1094 | train_mmd=0.7734 | test_mmd=0.7727 | test_mmd_cellot=0.2086\n",
      "[CellOT+scGen] epoch=250 f_loss=-22998.9492 g_loss=25214.9570 | train_mmd=0.6801 | test_mmd=0.6814 | test_mmd_cellot=0.1861\n",
      "[CellOT+scGen] epoch=300 f_loss=-2210.0103 g_loss=14248.7480 | train_mmd=0.1222 | test_mmd=0.1208 | test_mmd_cellot=0.0870\n",
      "[CellOT+scGen] epoch=350 f_loss=-9017.9551 g_loss=17113.5527 | train_mmd=0.2707 | test_mmd=0.2475 | test_mmd_cellot=0.1498\n",
      "[CellOT+scGen] epoch=400 f_loss=3548.6938 g_loss=21459.6523 | train_mmd=0.0425 | test_mmd=0.0445 | test_mmd_cellot=0.1536\n",
      "[CellOT+scGen] epoch=450 f_loss=1705.0525 g_loss=31.9157 | train_mmd=0.2781 | test_mmd=0.2685 | test_mmd_cellot=0.1595\n",
      "[CellOT+scGen] epoch=500 f_loss=224.3066 g_loss=-45.7897 | train_mmd=0.0309 | test_mmd=0.0311 | test_mmd_cellot=0.0250\n",
      "[CellOT+scGen] epoch=550 f_loss=8.3261 g_loss=-48.3319 | train_mmd=0.0158 | test_mmd=0.0147 | test_mmd_cellot=0.0135\n",
      "[CellOT+scGen] epoch=600 f_loss=0.1217 g_loss=-41.1036 | train_mmd=0.0176 | test_mmd=0.0160 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=650 f_loss=2.1419 g_loss=-35.0251 | train_mmd=0.0104 | test_mmd=0.0092 | test_mmd_cellot=0.0147\n",
      "[CellOT+scGen] epoch=700 f_loss=2.1942 g_loss=-32.6605 | train_mmd=0.0113 | test_mmd=0.0101 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=750 f_loss=-1.4813 g_loss=-32.6442 | train_mmd=0.0111 | test_mmd=0.0101 | test_mmd_cellot=0.0157\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.4456 g_loss=-31.8039 | train_mmd=0.0109 | test_mmd=0.0106 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=850 f_loss=-2.5715 g_loss=-26.7437 | train_mmd=0.0098 | test_mmd=0.0087 | test_mmd_cellot=0.0134\n",
      "[CellOT+scGen] epoch=900 f_loss=1.0163 g_loss=-25.4565 | train_mmd=0.0086 | test_mmd=0.0085 | test_mmd_cellot=0.0150\n",
      "[CellOT+scGen] epoch=950 f_loss=0.9006 g_loss=-24.4515 | train_mmd=0.0091 | test_mmd=0.0094 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1000 f_loss=-1.2962 g_loss=-20.2572 | train_mmd=0.0121 | test_mmd=0.0111 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=1050 f_loss=1.9720 g_loss=-21.6973 | train_mmd=0.0090 | test_mmd=0.0092 | test_mmd_cellot=0.0169\n",
      "[CellOT+scGen] epoch=1100 f_loss=1.9600 g_loss=-20.0948 | train_mmd=0.0105 | test_mmd=0.0100 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=1150 f_loss=2.5429 g_loss=-16.3776 | train_mmd=0.0092 | test_mmd=0.0093 | test_mmd_cellot=0.0151\n",
      "[CellOT+scGen] epoch=1200 f_loss=-2.3176 g_loss=-15.8417 | train_mmd=0.0085 | test_mmd=0.0082 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=1250 f_loss=0.5714 g_loss=-19.8974 | train_mmd=0.0109 | test_mmd=0.0111 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1300 f_loss=-2.2399 g_loss=-17.8432 | train_mmd=0.0100 | test_mmd=0.0096 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=1350 f_loss=-0.1849 g_loss=-16.8397 | train_mmd=0.0107 | test_mmd=0.0108 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=1400 f_loss=-3.9559 g_loss=-16.1179 | train_mmd=0.0122 | test_mmd=0.0111 | test_mmd_cellot=0.0156\n",
      "[CellOT+scGen] epoch=1450 f_loss=-3.1013 g_loss=-18.4608 | train_mmd=0.0087 | test_mmd=0.0088 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1500 f_loss=-2.3321 g_loss=-18.6692 | train_mmd=0.0088 | test_mmd=0.0089 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=1550 f_loss=-2.2145 g_loss=-17.8146 | train_mmd=0.0092 | test_mmd=0.0092 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.5024 g_loss=-16.3697 | train_mmd=0.0084 | test_mmd=0.0091 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1650 f_loss=-1.8303 g_loss=-18.6576 | train_mmd=0.0081 | test_mmd=0.0083 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=1700 f_loss=0.1928 g_loss=-15.9756 | train_mmd=0.0076 | test_mmd=0.0081 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=1750 f_loss=0.0317 g_loss=-15.8989 | train_mmd=0.0095 | test_mmd=0.0102 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=1800 f_loss=-0.3930 g_loss=-16.7637 | train_mmd=0.0093 | test_mmd=0.0094 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=1850 f_loss=-0.6089 g_loss=-17.4821 | train_mmd=0.0095 | test_mmd=0.0103 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1900 f_loss=-0.8778 g_loss=-16.6904 | train_mmd=0.0085 | test_mmd=0.0088 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=1950 f_loss=1.5850 g_loss=-17.1218 | train_mmd=0.0091 | test_mmd=0.0096 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=2000 f_loss=2.3117 g_loss=-15.1649 | train_mmd=0.0102 | test_mmd=0.0097 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=2050 f_loss=-2.7731 g_loss=-15.9633 | train_mmd=0.0090 | test_mmd=0.0086 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=2100 f_loss=2.6778 g_loss=-16.2523 | train_mmd=0.0089 | test_mmd=0.0093 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=2150 f_loss=-0.4534 g_loss=-15.9144 | train_mmd=0.0084 | test_mmd=0.0084 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.9305 g_loss=-16.4975 | train_mmd=0.0088 | test_mmd=0.0091 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2250 f_loss=2.0642 g_loss=-16.5669 | train_mmd=0.0094 | test_mmd=0.0095 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=2300 f_loss=-0.7984 g_loss=-15.7671 | train_mmd=0.0080 | test_mmd=0.0081 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=2350 f_loss=0.6585 g_loss=-16.1859 | train_mmd=0.0088 | test_mmd=0.0092 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=2400 f_loss=0.3657 g_loss=-16.4489 | train_mmd=0.0084 | test_mmd=0.0086 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=2450 f_loss=-0.2530 g_loss=-15.9719 | train_mmd=0.0091 | test_mmd=0.0095 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2500 f_loss=-1.8040 g_loss=-14.9255 | train_mmd=0.0078 | test_mmd=0.0081 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2550 f_loss=1.4055 g_loss=-16.3576 | train_mmd=0.0084 | test_mmd=0.0090 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2600 f_loss=0.4863 g_loss=-14.9071 | train_mmd=0.0088 | test_mmd=0.0089 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.1446 g_loss=-15.1201 | train_mmd=0.0096 | test_mmd=0.0093 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=2700 f_loss=-1.1442 g_loss=-15.2605 | train_mmd=0.0082 | test_mmd=0.0082 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=2750 f_loss=-0.9090 g_loss=-13.7840 | train_mmd=0.0079 | test_mmd=0.0081 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=2800 f_loss=-0.3487 g_loss=-14.3427 | train_mmd=0.0101 | test_mmd=0.0104 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=2850 f_loss=-1.3124 g_loss=-14.0328 | train_mmd=0.0088 | test_mmd=0.0088 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=2900 f_loss=-3.0688 g_loss=-15.8833 | train_mmd=0.0082 | test_mmd=0.0081 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.5734 g_loss=-16.5737 | train_mmd=0.0097 | test_mmd=0.0095 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=3000 f_loss=-1.5209 g_loss=-15.3871 | train_mmd=0.0087 | test_mmd=0.0090 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0200\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111/500:  22%|██████████████████████████████████████████████▌                                                                                                                                                                   | 111/500 [00:11<00:40,  9.65it/s, loss=31.3, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 294.259. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-416615.7812 g_loss=459000.8750 | train_mmd=0.7731 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=-266616.2500 g_loss=312683.5312 | train_mmd=0.7731 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=100 f_loss=-74706.7266 g_loss=115220.9375 | train_mmd=0.7677 | test_mmd=0.7673 | test_mmd_cellot=0.2072\n",
      "[CellOT+scGen] epoch=150 f_loss=-44327.2070 g_loss=35455.7891 | train_mmd=0.7787 | test_mmd=0.7887 | test_mmd_cellot=0.2107\n",
      "[CellOT+scGen] epoch=200 f_loss=-12118.4180 g_loss=27952.5605 | train_mmd=0.1274 | test_mmd=0.1254 | test_mmd_cellot=0.0655\n",
      "[CellOT+scGen] epoch=250 f_loss=2407.7739 g_loss=2062.2920 | train_mmd=0.0357 | test_mmd=0.0357 | test_mmd_cellot=0.0958\n",
      "[CellOT+scGen] epoch=300 f_loss=2017.7001 g_loss=1319.0468 | train_mmd=0.0846 | test_mmd=0.0762 | test_mmd_cellot=0.1770\n",
      "[CellOT+scGen] epoch=350 f_loss=474.3521 g_loss=25.3299 | train_mmd=0.0405 | test_mmd=0.0394 | test_mmd_cellot=0.1521\n",
      "[CellOT+scGen] epoch=400 f_loss=11.7992 g_loss=-51.2961 | train_mmd=0.0179 | test_mmd=0.0165 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=450 f_loss=2.0414 g_loss=-37.6102 | train_mmd=0.0105 | test_mmd=0.0093 | test_mmd_cellot=0.0127\n",
      "[CellOT+scGen] epoch=500 f_loss=2.0113 g_loss=-32.4073 | train_mmd=0.0086 | test_mmd=0.0081 | test_mmd_cellot=0.0139\n",
      "[CellOT+scGen] epoch=550 f_loss=0.0915 g_loss=-31.1334 | train_mmd=0.0202 | test_mmd=0.0189 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=600 f_loss=2.2921 g_loss=-26.6889 | train_mmd=0.0155 | test_mmd=0.0138 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=650 f_loss=-0.9985 g_loss=-25.2591 | train_mmd=0.0120 | test_mmd=0.0114 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=700 f_loss=-0.5633 g_loss=-25.5653 | train_mmd=0.0094 | test_mmd=0.0091 | test_mmd_cellot=0.0140\n",
      "[CellOT+scGen] epoch=750 f_loss=3.0774 g_loss=-16.2457 | train_mmd=0.0091 | test_mmd=0.0093 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=800 f_loss=5.5415 g_loss=-20.2562 | train_mmd=0.0087 | test_mmd=0.0095 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=850 f_loss=-0.7958 g_loss=-20.4790 | train_mmd=0.0101 | test_mmd=0.0097 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=900 f_loss=2.5730 g_loss=-18.3078 | train_mmd=0.0090 | test_mmd=0.0094 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=950 f_loss=1.0701 g_loss=-21.5636 | train_mmd=0.0085 | test_mmd=0.0080 | test_mmd_cellot=0.0149\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.5823 g_loss=-17.0306 | train_mmd=0.0103 | test_mmd=0.0101 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1050 f_loss=4.0121 g_loss=-13.3202 | train_mmd=0.0096 | test_mmd=0.0102 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1100 f_loss=0.3912 g_loss=-16.8610 | train_mmd=0.0085 | test_mmd=0.0083 | test_mmd_cellot=0.0151\n",
      "[CellOT+scGen] epoch=1150 f_loss=-0.2595 g_loss=-15.8585 | train_mmd=0.0093 | test_mmd=0.0088 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=1200 f_loss=-2.3520 g_loss=-16.7168 | train_mmd=0.0094 | test_mmd=0.0094 | test_mmd_cellot=0.0169\n",
      "[CellOT+scGen] epoch=1250 f_loss=-0.1440 g_loss=-14.2187 | train_mmd=0.0098 | test_mmd=0.0105 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1300 f_loss=-1.4936 g_loss=-17.2683 | train_mmd=0.0084 | test_mmd=0.0095 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=1350 f_loss=-0.1810 g_loss=-17.4745 | train_mmd=0.0084 | test_mmd=0.0088 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1400 f_loss=-0.2157 g_loss=-17.3864 | train_mmd=0.0082 | test_mmd=0.0087 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1450 f_loss=-3.4197 g_loss=-15.7801 | train_mmd=0.0088 | test_mmd=0.0091 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1500 f_loss=1.3391 g_loss=-14.0057 | train_mmd=0.0080 | test_mmd=0.0087 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1550 f_loss=-2.6191 g_loss=-13.3907 | train_mmd=0.0081 | test_mmd=0.0081 | test_mmd_cellot=0.0151\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.1869 g_loss=-16.1332 | train_mmd=0.0081 | test_mmd=0.0085 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1650 f_loss=1.1180 g_loss=-16.5282 | train_mmd=0.0088 | test_mmd=0.0091 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=1700 f_loss=-0.2310 g_loss=-16.4719 | train_mmd=0.0079 | test_mmd=0.0089 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=1750 f_loss=-0.3587 g_loss=-16.4752 | train_mmd=0.0085 | test_mmd=0.0084 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1800 f_loss=3.4700 g_loss=-16.6262 | train_mmd=0.0095 | test_mmd=0.0102 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1850 f_loss=-2.9288 g_loss=-15.1993 | train_mmd=0.0086 | test_mmd=0.0091 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1900 f_loss=2.1632 g_loss=-17.0857 | train_mmd=0.0098 | test_mmd=0.0107 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=1950 f_loss=-2.3618 g_loss=-14.3574 | train_mmd=0.0094 | test_mmd=0.0101 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2000 f_loss=-0.7127 g_loss=-14.3493 | train_mmd=0.0081 | test_mmd=0.0088 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=2050 f_loss=2.0086 g_loss=-15.5732 | train_mmd=0.0094 | test_mmd=0.0107 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=2100 f_loss=-0.6103 g_loss=-17.8821 | train_mmd=0.0089 | test_mmd=0.0090 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=2150 f_loss=0.1282 g_loss=-14.4125 | train_mmd=0.0092 | test_mmd=0.0099 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2200 f_loss=-1.6797 g_loss=-16.6379 | train_mmd=0.0089 | test_mmd=0.0091 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=2250 f_loss=-1.9943 g_loss=-14.9703 | train_mmd=0.0082 | test_mmd=0.0083 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=2300 f_loss=-5.2251 g_loss=-16.1108 | train_mmd=0.0088 | test_mmd=0.0094 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=2350 f_loss=2.8032 g_loss=-14.4737 | train_mmd=0.0093 | test_mmd=0.0097 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=2400 f_loss=-0.8158 g_loss=-14.9892 | train_mmd=0.0086 | test_mmd=0.0088 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.7391 g_loss=-13.7066 | train_mmd=0.0084 | test_mmd=0.0086 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=2500 f_loss=-1.0757 g_loss=-15.5373 | train_mmd=0.0096 | test_mmd=0.0104 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=2550 f_loss=-0.9786 g_loss=-15.5531 | train_mmd=0.0082 | test_mmd=0.0084 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=2600 f_loss=-0.6387 g_loss=-12.8257 | train_mmd=0.0085 | test_mmd=0.0087 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.0098 g_loss=-12.7784 | train_mmd=0.0091 | test_mmd=0.0094 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=2700 f_loss=-0.8501 g_loss=-12.7478 | train_mmd=0.0097 | test_mmd=0.0099 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2750 f_loss=0.9314 g_loss=-15.2636 | train_mmd=0.0088 | test_mmd=0.0093 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=2800 f_loss=2.1478 g_loss=-12.7724 | train_mmd=0.0089 | test_mmd=0.0093 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=2850 f_loss=1.3804 g_loss=-10.7875 | train_mmd=0.0082 | test_mmd=0.0087 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2900 f_loss=0.2558 g_loss=-12.6299 | train_mmd=0.0101 | test_mmd=0.0096 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.0878 g_loss=-14.4065 | train_mmd=0.0105 | test_mmd=0.0107 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=3000 f_loss=-0.9971 g_loss=-14.3525 | train_mmd=0.0109 | test_mmd=0.0108 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0227\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▏                                                                                                                                                                   | 110/500 [00:21<01:17,  5.00it/s, loss=31.3, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 289.863. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-584649.5000 g_loss=671409.8125 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=-96475.9297 g_loss=97430.1719 | train_mmd=0.7460 | test_mmd=0.7368 | test_mmd_cellot=0.1988\n",
      "[CellOT+scGen] epoch=100 f_loss=-40286.5859 g_loss=41282.4102 | train_mmd=0.7707 | test_mmd=0.7670 | test_mmd_cellot=0.2071\n",
      "[CellOT+scGen] epoch=150 f_loss=-17777.9219 g_loss=28054.0098 | train_mmd=0.7750 | test_mmd=0.7734 | test_mmd_cellot=0.2093\n",
      "[CellOT+scGen] epoch=200 f_loss=-19006.0156 g_loss=40046.8477 | train_mmd=0.5939 | test_mmd=0.5899 | test_mmd_cellot=0.1636\n",
      "[CellOT+scGen] epoch=250 f_loss=1060.9786 g_loss=4994.7119 | train_mmd=0.1041 | test_mmd=0.1038 | test_mmd_cellot=0.0995\n",
      "[CellOT+scGen] epoch=300 f_loss=220.8712 g_loss=14282.9092 | train_mmd=0.1893 | test_mmd=0.1929 | test_mmd_cellot=0.1873\n",
      "[CellOT+scGen] epoch=350 f_loss=3328.5459 g_loss=993.0854 | train_mmd=0.0653 | test_mmd=0.0685 | test_mmd_cellot=0.1773\n",
      "[CellOT+scGen] epoch=400 f_loss=219.8466 g_loss=-36.0456 | train_mmd=0.0346 | test_mmd=0.0353 | test_mmd_cellot=0.0348\n",
      "[CellOT+scGen] epoch=450 f_loss=5.8012 g_loss=-48.7647 | train_mmd=0.0172 | test_mmd=0.0164 | test_mmd_cellot=0.0149\n",
      "[CellOT+scGen] epoch=500 f_loss=1.0864 g_loss=-36.2935 | train_mmd=0.0130 | test_mmd=0.0131 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=550 f_loss=0.2732 g_loss=-37.0011 | train_mmd=0.0131 | test_mmd=0.0125 | test_mmd_cellot=0.0158\n",
      "[CellOT+scGen] epoch=600 f_loss=-0.0330 g_loss=-29.5703 | train_mmd=0.0111 | test_mmd=0.0103 | test_mmd_cellot=0.0160\n",
      "[CellOT+scGen] epoch=650 f_loss=0.9037 g_loss=-28.7294 | train_mmd=0.0101 | test_mmd=0.0105 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=700 f_loss=-1.8368 g_loss=-28.8083 | train_mmd=0.0090 | test_mmd=0.0096 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=750 f_loss=1.1552 g_loss=-26.7716 | train_mmd=0.0090 | test_mmd=0.0092 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=800 f_loss=1.2990 g_loss=-25.8773 | train_mmd=0.0100 | test_mmd=0.0104 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=850 f_loss=1.0963 g_loss=-23.4534 | train_mmd=0.0097 | test_mmd=0.0104 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=900 f_loss=0.1098 g_loss=-22.9828 | train_mmd=0.0095 | test_mmd=0.0106 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=950 f_loss=0.5440 g_loss=-21.1310 | train_mmd=0.0098 | test_mmd=0.0105 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.7097 g_loss=-18.4502 | train_mmd=0.0112 | test_mmd=0.0116 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=1050 f_loss=1.3707 g_loss=-16.9616 | train_mmd=0.0100 | test_mmd=0.0104 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=1100 f_loss=0.1627 g_loss=-18.9474 | train_mmd=0.0096 | test_mmd=0.0104 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1150 f_loss=0.1979 g_loss=-17.2139 | train_mmd=0.0123 | test_mmd=0.0126 | test_mmd_cellot=0.0245\n",
      "[CellOT+scGen] epoch=1200 f_loss=1.0824 g_loss=-17.6376 | train_mmd=0.0086 | test_mmd=0.0086 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1250 f_loss=-2.7366 g_loss=-18.4232 | train_mmd=0.0106 | test_mmd=0.0111 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=1300 f_loss=0.9517 g_loss=-16.1371 | train_mmd=0.0119 | test_mmd=0.0126 | test_mmd_cellot=0.0256\n",
      "[CellOT+scGen] epoch=1350 f_loss=0.4686 g_loss=-16.6226 | train_mmd=0.0132 | test_mmd=0.0142 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=1400 f_loss=1.4500 g_loss=-16.3127 | train_mmd=0.0102 | test_mmd=0.0107 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=1450 f_loss=-2.1398 g_loss=-16.7411 | train_mmd=0.0144 | test_mmd=0.0145 | test_mmd_cellot=0.0255\n",
      "[CellOT+scGen] epoch=1500 f_loss=-1.7160 g_loss=-17.0923 | train_mmd=0.0101 | test_mmd=0.0108 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=1550 f_loss=-0.4757 g_loss=-15.0146 | train_mmd=0.0097 | test_mmd=0.0105 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=1600 f_loss=2.7838 g_loss=-16.3177 | train_mmd=0.0114 | test_mmd=0.0124 | test_mmd_cellot=0.0262\n",
      "[CellOT+scGen] epoch=1650 f_loss=0.6850 g_loss=-14.3300 | train_mmd=0.0125 | test_mmd=0.0131 | test_mmd_cellot=0.0256\n",
      "[CellOT+scGen] epoch=1700 f_loss=0.5506 g_loss=-16.3282 | train_mmd=0.0118 | test_mmd=0.0124 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=1750 f_loss=-1.9850 g_loss=-16.3062 | train_mmd=0.0122 | test_mmd=0.0122 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=1800 f_loss=-2.1125 g_loss=-13.9285 | train_mmd=0.0098 | test_mmd=0.0101 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=1850 f_loss=-2.1339 g_loss=-13.6397 | train_mmd=0.0106 | test_mmd=0.0114 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=1900 f_loss=0.2566 g_loss=-12.8780 | train_mmd=0.0107 | test_mmd=0.0115 | test_mmd_cellot=0.0247\n",
      "[CellOT+scGen] epoch=1950 f_loss=0.5142 g_loss=-13.7426 | train_mmd=0.0119 | test_mmd=0.0126 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=2000 f_loss=2.6586 g_loss=-13.3007 | train_mmd=0.0123 | test_mmd=0.0130 | test_mmd_cellot=0.0261\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.1437 g_loss=-13.6623 | train_mmd=0.0101 | test_mmd=0.0109 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=2100 f_loss=-3.0519 g_loss=-14.0745 | train_mmd=0.0096 | test_mmd=0.0103 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=2150 f_loss=0.0755 g_loss=-14.6435 | train_mmd=0.0107 | test_mmd=0.0114 | test_mmd_cellot=0.0249\n",
      "[CellOT+scGen] epoch=2200 f_loss=2.8395 g_loss=-16.8584 | train_mmd=0.0115 | test_mmd=0.0125 | test_mmd_cellot=0.0247\n",
      "[CellOT+scGen] epoch=2250 f_loss=1.9352 g_loss=-18.5794 | train_mmd=0.0122 | test_mmd=0.0134 | test_mmd_cellot=0.0257\n",
      "[CellOT+scGen] epoch=2300 f_loss=-0.8889 g_loss=-18.0563 | train_mmd=0.0108 | test_mmd=0.0116 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2350 f_loss=-1.8248 g_loss=-17.2193 | train_mmd=0.0121 | test_mmd=0.0133 | test_mmd_cellot=0.0270\n",
      "[CellOT+scGen] epoch=2400 f_loss=-0.0228 g_loss=-18.8145 | train_mmd=0.0124 | test_mmd=0.0136 | test_mmd_cellot=0.0275\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.0941 g_loss=-16.6504 | train_mmd=0.0094 | test_mmd=0.0098 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2500 f_loss=-2.6757 g_loss=-18.2605 | train_mmd=0.0091 | test_mmd=0.0099 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2550 f_loss=1.5688 g_loss=-17.1689 | train_mmd=0.0107 | test_mmd=0.0110 | test_mmd_cellot=0.0225\n",
      "[CellOT+scGen] epoch=2600 f_loss=-1.1515 g_loss=-16.5472 | train_mmd=0.0097 | test_mmd=0.0104 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.3460 g_loss=-16.0968 | train_mmd=0.0104 | test_mmd=0.0115 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=2700 f_loss=-1.0556 g_loss=-16.2208 | train_mmd=0.0088 | test_mmd=0.0087 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=2750 f_loss=2.4690 g_loss=-16.3150 | train_mmd=0.0097 | test_mmd=0.0100 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=2800 f_loss=1.4902 g_loss=-15.7270 | train_mmd=0.0112 | test_mmd=0.0121 | test_mmd_cellot=0.0272\n",
      "[CellOT+scGen] epoch=2850 f_loss=-1.6491 g_loss=-18.3174 | train_mmd=0.0102 | test_mmd=0.0106 | test_mmd_cellot=0.0243\n",
      "[CellOT+scGen] epoch=2900 f_loss=0.8579 g_loss=-16.6458 | train_mmd=0.0098 | test_mmd=0.0108 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.8551 g_loss=-15.8134 | train_mmd=0.0108 | test_mmd=0.0119 | test_mmd_cellot=0.0243\n",
      "[CellOT+scGen] epoch=3000 f_loss=0.1158 g_loss=-16.0581 | train_mmd=0.0116 | test_mmd=0.0121 | test_mmd_cellot=0.0264\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0264\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 111/500:  22%|██████████████████████████████████████████████▌                                                                                                                                                                   | 111/500 [00:09<00:33, 11.66it/s, loss=30.5, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 288.554. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-758967.5000 g_loss=793851.7500 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=-201491.2188 g_loss=149633.5938 | train_mmd=0.7722 | test_mmd=0.7707 | test_mmd_cellot=0.2081\n",
      "[CellOT+scGen] epoch=100 f_loss=-99397.8438 g_loss=142928.2656 | train_mmd=0.7603 | test_mmd=0.7671 | test_mmd_cellot=0.2081\n",
      "[CellOT+scGen] epoch=150 f_loss=-38742.6016 g_loss=38511.0078 | train_mmd=0.7107 | test_mmd=0.7194 | test_mmd_cellot=0.1920\n",
      "[CellOT+scGen] epoch=200 f_loss=928.3079 g_loss=7708.0762 | train_mmd=0.2967 | test_mmd=0.2955 | test_mmd_cellot=0.1253\n",
      "[CellOT+scGen] epoch=250 f_loss=2480.3057 g_loss=3401.2634 | train_mmd=0.0729 | test_mmd=0.0730 | test_mmd_cellot=0.1245\n",
      "[CellOT+scGen] epoch=300 f_loss=875.2976 g_loss=81.4893 | train_mmd=0.0437 | test_mmd=0.0469 | test_mmd_cellot=0.1417\n",
      "[CellOT+scGen] epoch=350 f_loss=70.1314 g_loss=-39.7608 | train_mmd=0.0716 | test_mmd=0.0681 | test_mmd_cellot=0.0601\n",
      "[CellOT+scGen] epoch=400 f_loss=-15.2478 g_loss=-42.5989 | train_mmd=0.0180 | test_mmd=0.0165 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=450 f_loss=3.8554 g_loss=-34.4271 | train_mmd=0.0129 | test_mmd=0.0110 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=500 f_loss=0.6965 g_loss=-26.6502 | train_mmd=0.0167 | test_mmd=0.0162 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=550 f_loss=4.8614 g_loss=-25.6469 | train_mmd=0.0143 | test_mmd=0.0127 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=600 f_loss=4.8179 g_loss=-25.1542 | train_mmd=0.0125 | test_mmd=0.0117 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=650 f_loss=-1.3624 g_loss=-23.1357 | train_mmd=0.0107 | test_mmd=0.0097 | test_mmd_cellot=0.0151\n",
      "[CellOT+scGen] epoch=700 f_loss=-0.0751 g_loss=-23.2329 | train_mmd=0.0085 | test_mmd=0.0085 | test_mmd_cellot=0.0129\n",
      "[CellOT+scGen] epoch=750 f_loss=4.6891 g_loss=-17.6876 | train_mmd=0.0084 | test_mmd=0.0084 | test_mmd_cellot=0.0160\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.8215 g_loss=-20.2201 | train_mmd=0.0102 | test_mmd=0.0099 | test_mmd_cellot=0.0151\n",
      "[CellOT+scGen] epoch=850 f_loss=-2.9807 g_loss=-18.3771 | train_mmd=0.0099 | test_mmd=0.0099 | test_mmd_cellot=0.0142\n",
      "[CellOT+scGen] epoch=900 f_loss=-1.9246 g_loss=-16.0480 | train_mmd=0.0114 | test_mmd=0.0111 | test_mmd_cellot=0.0169\n",
      "[CellOT+scGen] epoch=950 f_loss=2.3571 g_loss=-18.9730 | train_mmd=0.0093 | test_mmd=0.0096 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=1000 f_loss=-0.7782 g_loss=-17.7375 | train_mmd=0.0121 | test_mmd=0.0125 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1050 f_loss=-2.4757 g_loss=-13.7661 | train_mmd=0.0116 | test_mmd=0.0114 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=1100 f_loss=1.8781 g_loss=-14.5454 | train_mmd=0.0110 | test_mmd=0.0113 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=1150 f_loss=-4.1405 g_loss=-13.9982 | train_mmd=0.0099 | test_mmd=0.0100 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=1200 f_loss=3.9609 g_loss=-12.8966 | train_mmd=0.0110 | test_mmd=0.0115 | test_mmd_cellot=0.0225\n",
      "[CellOT+scGen] epoch=1250 f_loss=0.4476 g_loss=-15.0123 | train_mmd=0.0087 | test_mmd=0.0085 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1300 f_loss=-2.6731 g_loss=-17.4050 | train_mmd=0.0107 | test_mmd=0.0106 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=1350 f_loss=1.7608 g_loss=-15.9000 | train_mmd=0.0081 | test_mmd=0.0085 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1400 f_loss=-4.1626 g_loss=-15.7453 | train_mmd=0.0096 | test_mmd=0.0092 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=1450 f_loss=-0.6739 g_loss=-16.3372 | train_mmd=0.0090 | test_mmd=0.0086 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.7442 g_loss=-16.7254 | train_mmd=0.0113 | test_mmd=0.0106 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=1550 f_loss=4.3275 g_loss=-16.4459 | train_mmd=0.0087 | test_mmd=0.0089 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1600 f_loss=-2.7022 g_loss=-15.4025 | train_mmd=0.0096 | test_mmd=0.0097 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=1650 f_loss=1.4211 g_loss=-14.9453 | train_mmd=0.0110 | test_mmd=0.0112 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=1700 f_loss=-0.8197 g_loss=-16.9871 | train_mmd=0.0087 | test_mmd=0.0089 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=1750 f_loss=0.3235 g_loss=-14.7476 | train_mmd=0.0106 | test_mmd=0.0103 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1800 f_loss=1.3149 g_loss=-16.3254 | train_mmd=0.0100 | test_mmd=0.0098 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=1850 f_loss=-1.0069 g_loss=-16.8852 | train_mmd=0.0093 | test_mmd=0.0088 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=1900 f_loss=-0.0724 g_loss=-15.8557 | train_mmd=0.0100 | test_mmd=0.0097 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=1950 f_loss=0.6604 g_loss=-13.7329 | train_mmd=0.0090 | test_mmd=0.0086 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2000 f_loss=0.5745 g_loss=-17.0563 | train_mmd=0.0110 | test_mmd=0.0108 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2050 f_loss=-1.2580 g_loss=-15.4515 | train_mmd=0.0110 | test_mmd=0.0108 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=2100 f_loss=0.9439 g_loss=-16.8199 | train_mmd=0.0096 | test_mmd=0.0097 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2150 f_loss=-0.0221 g_loss=-15.6423 | train_mmd=0.0087 | test_mmd=0.0089 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=2200 f_loss=1.5978 g_loss=-14.8842 | train_mmd=0.0100 | test_mmd=0.0101 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2250 f_loss=0.0500 g_loss=-14.1570 | train_mmd=0.0105 | test_mmd=0.0111 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=2300 f_loss=-2.1056 g_loss=-15.8919 | train_mmd=0.0096 | test_mmd=0.0094 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=2350 f_loss=-0.5209 g_loss=-12.3672 | train_mmd=0.0081 | test_mmd=0.0077 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=2400 f_loss=-0.8890 g_loss=-15.8258 | train_mmd=0.0108 | test_mmd=0.0107 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=2450 f_loss=-1.3119 g_loss=-14.9410 | train_mmd=0.0101 | test_mmd=0.0095 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=2500 f_loss=-5.5218 g_loss=-13.3750 | train_mmd=0.0112 | test_mmd=0.0109 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2550 f_loss=0.1615 g_loss=-13.6737 | train_mmd=0.0097 | test_mmd=0.0096 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=2600 f_loss=-0.3492 g_loss=-13.0716 | train_mmd=0.0092 | test_mmd=0.0091 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=2650 f_loss=1.1857 g_loss=-15.6974 | train_mmd=0.0092 | test_mmd=0.0087 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=2700 f_loss=-2.4054 g_loss=-13.8875 | train_mmd=0.0105 | test_mmd=0.0098 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=2750 f_loss=-0.0076 g_loss=-15.6188 | train_mmd=0.0114 | test_mmd=0.0110 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2800 f_loss=-2.3307 g_loss=-14.4548 | train_mmd=0.0096 | test_mmd=0.0091 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2850 f_loss=0.9128 g_loss=-13.1341 | train_mmd=0.0098 | test_mmd=0.0106 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=2900 f_loss=-0.7463 g_loss=-13.9383 | train_mmd=0.0097 | test_mmd=0.0095 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=2950 f_loss=1.7683 g_loss=-13.9300 | train_mmd=0.0108 | test_mmd=0.0111 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=3000 f_loss=-2.0176 g_loss=-13.6201 | train_mmd=0.0110 | test_mmd=0.0112 | test_mmd_cellot=0.0225\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0225\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109/500:  22%|█████████████████████████████████████████████▊                                                                                                                                                                    | 109/500 [00:12<00:45,  8.59it/s, loss=30.6, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 291.597. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-750200.8125 g_loss=814040.1250 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=5964.9004 g_loss=6717.7783 | train_mmd=0.7614 | test_mmd=0.7622 | test_mmd_cellot=0.2063\n",
      "[CellOT+scGen] epoch=100 f_loss=-39435.4609 g_loss=45946.0391 | train_mmd=0.7716 | test_mmd=0.7716 | test_mmd_cellot=0.2083\n",
      "[CellOT+scGen] epoch=150 f_loss=-21436.1445 g_loss=30540.2188 | train_mmd=0.7221 | test_mmd=0.7285 | test_mmd_cellot=0.1990\n",
      "[CellOT+scGen] epoch=200 f_loss=-17604.3223 g_loss=24682.4473 | train_mmd=0.3156 | test_mmd=0.3381 | test_mmd_cellot=0.1128\n",
      "[CellOT+scGen] epoch=250 f_loss=-11500.0898 g_loss=14114.6016 | train_mmd=0.1551 | test_mmd=0.1714 | test_mmd_cellot=0.1414\n",
      "[CellOT+scGen] epoch=300 f_loss=4501.5391 g_loss=2713.2598 | train_mmd=0.2424 | test_mmd=0.2376 | test_mmd_cellot=0.1836\n",
      "[CellOT+scGen] epoch=350 f_loss=1030.6909 g_loss=14.1806 | train_mmd=0.0360 | test_mmd=0.0366 | test_mmd_cellot=0.1178\n",
      "[CellOT+scGen] epoch=400 f_loss=509.6612 g_loss=-45.1729 | train_mmd=0.0594 | test_mmd=0.0558 | test_mmd_cellot=0.0432\n",
      "[CellOT+scGen] epoch=450 f_loss=6.9640 g_loss=-47.9840 | train_mmd=0.0147 | test_mmd=0.0139 | test_mmd_cellot=0.0121\n",
      "[CellOT+scGen] epoch=500 f_loss=2.5224 g_loss=-36.4023 | train_mmd=0.0153 | test_mmd=0.0135 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=550 f_loss=3.9704 g_loss=-32.7998 | train_mmd=0.0124 | test_mmd=0.0130 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=600 f_loss=0.8646 g_loss=-32.8894 | train_mmd=0.0114 | test_mmd=0.0119 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=650 f_loss=1.0992 g_loss=-29.0370 | train_mmd=0.0133 | test_mmd=0.0127 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=700 f_loss=-0.1426 g_loss=-24.0536 | train_mmd=0.0138 | test_mmd=0.0127 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=750 f_loss=-3.3290 g_loss=-23.8315 | train_mmd=0.0117 | test_mmd=0.0108 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=800 f_loss=-2.1757 g_loss=-22.9174 | train_mmd=0.0136 | test_mmd=0.0139 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=850 f_loss=1.3410 g_loss=-19.4743 | train_mmd=0.0092 | test_mmd=0.0094 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=900 f_loss=1.6131 g_loss=-20.2101 | train_mmd=0.0094 | test_mmd=0.0104 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=950 f_loss=1.0255 g_loss=-19.6938 | train_mmd=0.0101 | test_mmd=0.0109 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.6938 g_loss=-18.1163 | train_mmd=0.0102 | test_mmd=0.0106 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=1050 f_loss=-0.6569 g_loss=-19.3580 | train_mmd=0.0082 | test_mmd=0.0087 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1100 f_loss=-0.2312 g_loss=-17.0748 | train_mmd=0.0106 | test_mmd=0.0114 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=1150 f_loss=2.6533 g_loss=-17.0015 | train_mmd=0.0102 | test_mmd=0.0105 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=1200 f_loss=-1.8357 g_loss=-14.5696 | train_mmd=0.0103 | test_mmd=0.0105 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=1250 f_loss=-2.2034 g_loss=-15.8585 | train_mmd=0.0107 | test_mmd=0.0107 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=1300 f_loss=1.5551 g_loss=-16.8952 | train_mmd=0.0110 | test_mmd=0.0117 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=1350 f_loss=-2.5867 g_loss=-18.3502 | train_mmd=0.0092 | test_mmd=0.0091 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=1400 f_loss=0.9263 g_loss=-15.0746 | train_mmd=0.0098 | test_mmd=0.0098 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1450 f_loss=-0.7730 g_loss=-16.8761 | train_mmd=0.0099 | test_mmd=0.0107 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.2130 g_loss=-14.5085 | train_mmd=0.0113 | test_mmd=0.0115 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=1550 f_loss=-1.3426 g_loss=-16.7811 | train_mmd=0.0116 | test_mmd=0.0124 | test_mmd_cellot=0.0269\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.1123 g_loss=-15.3857 | train_mmd=0.0093 | test_mmd=0.0093 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=1650 f_loss=-2.8124 g_loss=-16.7649 | train_mmd=0.0108 | test_mmd=0.0104 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=1700 f_loss=2.5105 g_loss=-15.2673 | train_mmd=0.0099 | test_mmd=0.0110 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=1750 f_loss=2.3548 g_loss=-14.1380 | train_mmd=0.0111 | test_mmd=0.0120 | test_mmd_cellot=0.0251\n",
      "[CellOT+scGen] epoch=1800 f_loss=-1.7269 g_loss=-15.7023 | train_mmd=0.0107 | test_mmd=0.0113 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=1850 f_loss=0.7897 g_loss=-16.5017 | train_mmd=0.0091 | test_mmd=0.0097 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1900 f_loss=-0.2611 g_loss=-15.6019 | train_mmd=0.0113 | test_mmd=0.0118 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.9623 g_loss=-14.5326 | train_mmd=0.0086 | test_mmd=0.0094 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=2000 f_loss=-0.6215 g_loss=-15.1652 | train_mmd=0.0095 | test_mmd=0.0095 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.4865 g_loss=-13.5736 | train_mmd=0.0108 | test_mmd=0.0112 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=2100 f_loss=-0.8790 g_loss=-14.3687 | train_mmd=0.0097 | test_mmd=0.0104 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=2150 f_loss=0.9550 g_loss=-14.7854 | train_mmd=0.0099 | test_mmd=0.0110 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=2200 f_loss=1.1801 g_loss=-14.8871 | train_mmd=0.0100 | test_mmd=0.0104 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2250 f_loss=1.1899 g_loss=-14.2155 | train_mmd=0.0099 | test_mmd=0.0100 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=2300 f_loss=0.9077 g_loss=-14.0926 | train_mmd=0.0092 | test_mmd=0.0092 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=2350 f_loss=0.3197 g_loss=-14.0285 | train_mmd=0.0098 | test_mmd=0.0107 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2400 f_loss=1.0406 g_loss=-13.5989 | train_mmd=0.0097 | test_mmd=0.0098 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2450 f_loss=-5.7063 g_loss=-14.5910 | train_mmd=0.0107 | test_mmd=0.0110 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=2500 f_loss=1.1375 g_loss=-15.5280 | train_mmd=0.0102 | test_mmd=0.0103 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=2550 f_loss=-1.4845 g_loss=-13.5408 | train_mmd=0.0093 | test_mmd=0.0095 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2600 f_loss=0.5231 g_loss=-15.0842 | train_mmd=0.0104 | test_mmd=0.0111 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=2650 f_loss=-2.4004 g_loss=-13.2903 | train_mmd=0.0097 | test_mmd=0.0106 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=2700 f_loss=0.0062 g_loss=-15.5399 | train_mmd=0.0094 | test_mmd=0.0096 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=2750 f_loss=-1.4595 g_loss=-12.5716 | train_mmd=0.0112 | test_mmd=0.0113 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=2800 f_loss=-1.8448 g_loss=-13.8807 | train_mmd=0.0101 | test_mmd=0.0110 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2850 f_loss=2.4636 g_loss=-13.6018 | train_mmd=0.0126 | test_mmd=0.0136 | test_mmd_cellot=0.0255\n",
      "[CellOT+scGen] epoch=2900 f_loss=0.8355 g_loss=-11.6154 | train_mmd=0.0103 | test_mmd=0.0113 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=2950 f_loss=2.8630 g_loss=-13.5625 | train_mmd=0.0092 | test_mmd=0.0097 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=3000 f_loss=-1.5342 g_loss=-12.3974 | train_mmd=0.0094 | test_mmd=0.0096 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0205\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▏                                                                                                                                                                   | 110/500 [00:10<00:37, 10.36it/s, loss=31.5, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 291.821. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-383851.3125 g_loss=407849.5000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=-195893.4062 g_loss=204070.3438 | train_mmd=0.6470 | test_mmd=0.6444 | test_mmd_cellot=0.1723\n",
      "[CellOT+scGen] epoch=100 f_loss=-112672.7031 g_loss=132382.5781 | train_mmd=0.7705 | test_mmd=0.7689 | test_mmd_cellot=0.2076\n",
      "[CellOT+scGen] epoch=150 f_loss=-84940.6094 g_loss=108942.3750 | train_mmd=0.7675 | test_mmd=0.7668 | test_mmd_cellot=0.2077\n",
      "[CellOT+scGen] epoch=200 f_loss=-11039.9443 g_loss=25547.2090 | train_mmd=0.7622 | test_mmd=0.7569 | test_mmd_cellot=0.2002\n",
      "[CellOT+scGen] epoch=250 f_loss=721.8984 g_loss=14473.0332 | train_mmd=0.3886 | test_mmd=0.3994 | test_mmd_cellot=0.1618\n",
      "[CellOT+scGen] epoch=300 f_loss=2956.5791 g_loss=6989.5283 | train_mmd=0.0520 | test_mmd=0.0497 | test_mmd_cellot=0.1331\n",
      "[CellOT+scGen] epoch=350 f_loss=3977.8540 g_loss=-54.1147 | train_mmd=0.5127 | test_mmd=0.4742 | test_mmd_cellot=0.2792\n",
      "[CellOT+scGen] epoch=400 f_loss=1327.9253 g_loss=88.3151 | train_mmd=0.0419 | test_mmd=0.0434 | test_mmd_cellot=0.0485\n",
      "[CellOT+scGen] epoch=450 f_loss=9.5437 g_loss=-54.5809 | train_mmd=0.0181 | test_mmd=0.0184 | test_mmd_cellot=0.0158\n",
      "[CellOT+scGen] epoch=500 f_loss=4.9021 g_loss=-41.9302 | train_mmd=0.0128 | test_mmd=0.0117 | test_mmd_cellot=0.0144\n",
      "[CellOT+scGen] epoch=550 f_loss=1.2643 g_loss=-39.1281 | train_mmd=0.0136 | test_mmd=0.0127 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=600 f_loss=3.3102 g_loss=-38.3491 | train_mmd=0.0111 | test_mmd=0.0108 | test_mmd_cellot=0.0144\n",
      "[CellOT+scGen] epoch=650 f_loss=0.0825 g_loss=-32.9323 | train_mmd=0.0123 | test_mmd=0.0124 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=700 f_loss=-0.7834 g_loss=-27.8576 | train_mmd=0.0118 | test_mmd=0.0104 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=750 f_loss=1.7533 g_loss=-24.6420 | train_mmd=0.0130 | test_mmd=0.0123 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.9400 g_loss=-25.2007 | train_mmd=0.0096 | test_mmd=0.0093 | test_mmd_cellot=0.0154\n",
      "[CellOT+scGen] epoch=850 f_loss=3.8387 g_loss=-23.2809 | train_mmd=0.0107 | test_mmd=0.0113 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=900 f_loss=-1.6954 g_loss=-23.5908 | train_mmd=0.0100 | test_mmd=0.0092 | test_mmd_cellot=0.0157\n",
      "[CellOT+scGen] epoch=950 f_loss=-0.2364 g_loss=-19.8662 | train_mmd=0.0114 | test_mmd=0.0115 | test_mmd_cellot=0.0180\n",
      "[CellOT+scGen] epoch=1000 f_loss=-1.3920 g_loss=-18.4775 | train_mmd=0.0082 | test_mmd=0.0091 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=1050 f_loss=2.9749 g_loss=-19.7978 | train_mmd=0.0087 | test_mmd=0.0098 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1100 f_loss=-1.8839 g_loss=-19.8827 | train_mmd=0.0094 | test_mmd=0.0094 | test_mmd_cellot=0.0143\n",
      "[CellOT+scGen] epoch=1150 f_loss=-4.1181 g_loss=-17.9226 | train_mmd=0.0109 | test_mmd=0.0112 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1200 f_loss=1.1198 g_loss=-16.9851 | train_mmd=0.0089 | test_mmd=0.0097 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=1250 f_loss=2.6009 g_loss=-18.0707 | train_mmd=0.0107 | test_mmd=0.0110 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1300 f_loss=-0.5948 g_loss=-18.1034 | train_mmd=0.0096 | test_mmd=0.0105 | test_mmd_cellot=0.0165\n",
      "[CellOT+scGen] epoch=1350 f_loss=0.3062 g_loss=-19.1442 | train_mmd=0.0100 | test_mmd=0.0108 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=1400 f_loss=-1.0646 g_loss=-18.7520 | train_mmd=0.0091 | test_mmd=0.0099 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1450 f_loss=0.8392 g_loss=-18.4537 | train_mmd=0.0115 | test_mmd=0.0117 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=1500 f_loss=1.5210 g_loss=-15.8254 | train_mmd=0.0093 | test_mmd=0.0099 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=1550 f_loss=-1.5906 g_loss=-19.0759 | train_mmd=0.0102 | test_mmd=0.0113 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1600 f_loss=-1.6671 g_loss=-15.4798 | train_mmd=0.0101 | test_mmd=0.0115 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=1650 f_loss=2.1007 g_loss=-16.5742 | train_mmd=0.0082 | test_mmd=0.0084 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=1700 f_loss=-0.0378 g_loss=-16.3072 | train_mmd=0.0099 | test_mmd=0.0107 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=1750 f_loss=3.0973 g_loss=-16.3959 | train_mmd=0.0081 | test_mmd=0.0088 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=1800 f_loss=-0.4320 g_loss=-15.3911 | train_mmd=0.0092 | test_mmd=0.0097 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1850 f_loss=2.0903 g_loss=-14.2681 | train_mmd=0.0092 | test_mmd=0.0104 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1900 f_loss=-2.8887 g_loss=-15.7487 | train_mmd=0.0091 | test_mmd=0.0097 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1950 f_loss=-1.2152 g_loss=-14.4217 | train_mmd=0.0111 | test_mmd=0.0123 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=2000 f_loss=1.1190 g_loss=-13.7774 | train_mmd=0.0097 | test_mmd=0.0110 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.3366 g_loss=-14.7547 | train_mmd=0.0089 | test_mmd=0.0096 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=2100 f_loss=-2.4952 g_loss=-14.6068 | train_mmd=0.0096 | test_mmd=0.0097 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=2150 f_loss=-0.0923 g_loss=-15.3973 | train_mmd=0.0100 | test_mmd=0.0110 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.6291 g_loss=-14.2397 | train_mmd=0.0095 | test_mmd=0.0111 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=2250 f_loss=-1.8637 g_loss=-14.0745 | train_mmd=0.0084 | test_mmd=0.0093 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=2300 f_loss=0.7224 g_loss=-15.1895 | train_mmd=0.0097 | test_mmd=0.0097 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=2350 f_loss=1.8405 g_loss=-12.8516 | train_mmd=0.0096 | test_mmd=0.0109 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=2400 f_loss=-1.3613 g_loss=-12.5670 | train_mmd=0.0106 | test_mmd=0.0112 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=2450 f_loss=-2.2593 g_loss=-13.9277 | train_mmd=0.0086 | test_mmd=0.0092 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=2500 f_loss=-0.3498 g_loss=-16.2174 | train_mmd=0.0100 | test_mmd=0.0108 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2550 f_loss=1.4319 g_loss=-13.1264 | train_mmd=0.0100 | test_mmd=0.0108 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2600 f_loss=-1.4852 g_loss=-13.2094 | train_mmd=0.0104 | test_mmd=0.0111 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=2650 f_loss=-2.8653 g_loss=-13.1282 | train_mmd=0.0103 | test_mmd=0.0105 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=2700 f_loss=2.3096 g_loss=-12.6626 | train_mmd=0.0091 | test_mmd=0.0101 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=2750 f_loss=-3.3806 g_loss=-12.1463 | train_mmd=0.0119 | test_mmd=0.0124 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=2800 f_loss=1.1556 g_loss=-11.8739 | train_mmd=0.0122 | test_mmd=0.0138 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=2850 f_loss=-0.7854 g_loss=-11.1066 | train_mmd=0.0115 | test_mmd=0.0123 | test_mmd_cellot=0.0241\n",
      "[CellOT+scGen] epoch=2900 f_loss=1.9958 g_loss=-11.9357 | train_mmd=0.0097 | test_mmd=0.0104 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.8836 g_loss=-13.1815 | train_mmd=0.0100 | test_mmd=0.0105 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=3000 f_loss=-2.0371 g_loss=-12.8195 | train_mmd=0.0110 | test_mmd=0.0118 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0237\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▋                                                                                                                                                                     | 110/500 [00:10<00:37, 10.44it/s, loss=31, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 289.865. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-250286.9219 g_loss=331201.5625 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=-130160.9141 g_loss=185803.7812 | train_mmd=0.7646 | test_mmd=0.7697 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=100 f_loss=-175086.9688 g_loss=147589.0938 | train_mmd=0.7549 | test_mmd=0.7618 | test_mmd_cellot=0.2066\n",
      "[CellOT+scGen] epoch=150 f_loss=10794.3926 g_loss=-3907.0808 | train_mmd=0.7686 | test_mmd=0.7824 | test_mmd_cellot=0.2194\n",
      "[CellOT+scGen] epoch=200 f_loss=5874.9214 g_loss=-7111.3652 | train_mmd=0.9502 | test_mmd=0.9498 | test_mmd_cellot=0.3833\n",
      "[CellOT+scGen] epoch=250 f_loss=17340.4961 g_loss=-5565.2998 | train_mmd=0.7610 | test_mmd=0.7688 | test_mmd_cellot=0.2080\n",
      "[CellOT+scGen] epoch=300 f_loss=-2819.5447 g_loss=76799.7188 | train_mmd=0.7507 | test_mmd=0.7532 | test_mmd_cellot=0.2027\n",
      "[CellOT+scGen] epoch=350 f_loss=-653026752.0000 g_loss=801141760.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=400 f_loss=20098.7598 g_loss=-13361.5957 | train_mmd=0.7789 | test_mmd=0.7722 | test_mmd_cellot=0.2147\n",
      "[CellOT+scGen] epoch=450 f_loss=48356.2188 g_loss=19309.6367 | train_mmd=0.7600 | test_mmd=0.7605 | test_mmd_cellot=0.2049\n",
      "[CellOT+scGen] epoch=500 f_loss=44057.6836 g_loss=1159.9016 | train_mmd=0.7673 | test_mmd=0.7677 | test_mmd_cellot=0.2070\n",
      "[CellOT+scGen] epoch=550 f_loss=64243.8672 g_loss=-2138.8950 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=600 f_loss=55215.9258 g_loss=-2068.0168 | train_mmd=0.7728 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=650 f_loss=62150.3281 g_loss=-5370.0288 | train_mmd=0.7717 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=700 f_loss=-29878998.0000 g_loss=31902718.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=750 f_loss=74965.8281 g_loss=-3420.1821 | train_mmd=0.7679 | test_mmd=0.7629 | test_mmd_cellot=0.2056\n",
      "[CellOT+scGen] epoch=800 f_loss=80046.9141 g_loss=-4214.7061 | train_mmd=0.7715 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=850 f_loss=-486181280.0000 g_loss=528531840.0000 | train_mmd=0.7728 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=900 f_loss=91952.2969 g_loss=-2553.3828 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=950 f_loss=86929.6719 g_loss=-6725.9521 | train_mmd=0.7722 | test_mmd=0.7677 | test_mmd_cellot=0.2070\n",
      "[CellOT+scGen] epoch=1000 f_loss=-240608.8125 g_loss=422988.2188 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1050 f_loss=107377.5078 g_loss=-5443.9990 | train_mmd=0.7709 | test_mmd=0.7677 | test_mmd_cellot=0.2070\n",
      "[CellOT+scGen] epoch=1100 f_loss=-73717200.0000 g_loss=83441776.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1150 f_loss=129999.6875 g_loss=-2004.7936 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1200 f_loss=84479.9609 g_loss=4889.7876 | train_mmd=0.7728 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=1250 f_loss=-39236260.0000 g_loss=42983188.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1300 f_loss=91447.7188 g_loss=-2364.6567 | train_mmd=0.7673 | test_mmd=0.7653 | test_mmd_cellot=0.2063\n",
      "[CellOT+scGen] epoch=1350 f_loss=107221.6016 g_loss=10538.1602 | train_mmd=0.7734 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=1400 f_loss=62050.0859 g_loss=25519.0586 | train_mmd=0.7728 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1450 f_loss=140923.2031 g_loss=-2093.2148 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1500 f_loss=91745.0703 g_loss=14567.3047 | train_mmd=0.7722 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1550 f_loss=134197.8906 g_loss=-2119.5283 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1600 f_loss=-943303040.0000 g_loss=1051131904.0000 | train_mmd=0.7728 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=1650 f_loss=-1319694.0000 g_loss=1281341.6250 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1700 f_loss=105568.7344 g_loss=-1962.4423 | train_mmd=0.7728 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1750 f_loss=-239854976.0000 g_loss=255084896.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1800 f_loss=104845.7969 g_loss=-790.4932 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1850 f_loss=67208.1875 g_loss=2217.5186 | train_mmd=0.7722 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1900 f_loss=89348.0625 g_loss=7771.6924 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=1950 f_loss=69394.4297 g_loss=-720.4380 | train_mmd=0.7703 | test_mmd=0.7702 | test_mmd_cellot=0.2078\n",
      "[CellOT+scGen] epoch=2000 f_loss=-5920267.5000 g_loss=6057974.0000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=2050 f_loss=69195.6406 g_loss=-439.1127 | train_mmd=0.7692 | test_mmd=0.7713 | test_mmd_cellot=0.2079\n",
      "[CellOT+scGen] epoch=2100 f_loss=-144794128.0000 g_loss=141411904.0000 | train_mmd=0.7563 | test_mmd=0.7508 | test_mmd_cellot=0.2020\n",
      "[CellOT+scGen] epoch=2150 f_loss=79737.8984 g_loss=-420.3784 | train_mmd=0.7732 | test_mmd=0.7725 | test_mmd_cellot=0.2084\n",
      "[CellOT+scGen] epoch=2200 f_loss=102836.3203 g_loss=2728.8457 | train_mmd=0.7728 | test_mmd=0.7727 | test_mmd_cellot=0.2086\n",
      "[CellOT+scGen] epoch=2250 f_loss=-1099919.5000 g_loss=1487430.5000 | train_mmd=0.7663 | test_mmd=0.7654 | test_mmd_cellot=0.2052\n",
      "[CellOT+scGen] epoch=2300 f_loss=107804.5781 g_loss=-281.7292 | train_mmd=0.7688 | test_mmd=0.7685 | test_mmd_cellot=0.2056\n",
      "[CellOT+scGen] epoch=2350 f_loss=32311.3398 g_loss=709.9180 | train_mmd=0.7712 | test_mmd=0.7719 | test_mmd_cellot=0.2081\n",
      "[CellOT+scGen] epoch=2400 f_loss=-429850.8438 g_loss=481839.1875 | train_mmd=0.6659 | test_mmd=0.6661 | test_mmd_cellot=0.1828\n",
      "[CellOT+scGen] epoch=2450 f_loss=50353.3008 g_loss=-560.4866 | train_mmd=0.7768 | test_mmd=0.7769 | test_mmd_cellot=0.2101\n",
      "[CellOT+scGen] epoch=2500 f_loss=-2193.0488 g_loss=5126.2188 | train_mmd=0.7729 | test_mmd=0.7773 | test_mmd_cellot=0.2073\n",
      "[CellOT+scGen] epoch=2550 f_loss=-172916.4688 g_loss=300490.6875 | train_mmd=0.2483 | test_mmd=0.2342 | test_mmd_cellot=0.0977\n",
      "[CellOT+scGen] epoch=2600 f_loss=10543.2158 g_loss=-157.9543 | train_mmd=0.5905 | test_mmd=0.5923 | test_mmd_cellot=0.1706\n",
      "[CellOT+scGen] epoch=2650 f_loss=-4.7832 g_loss=198.3418 | train_mmd=0.0946 | test_mmd=0.0958 | test_mmd_cellot=0.0576\n",
      "[CellOT+scGen] epoch=2700 f_loss=34.1286 g_loss=-78.0006 | train_mmd=0.0406 | test_mmd=0.0365 | test_mmd_cellot=0.0274\n",
      "[CellOT+scGen] epoch=2750 f_loss=8.6943 g_loss=-53.3877 | train_mmd=0.0118 | test_mmd=0.0108 | test_mmd_cellot=0.0121\n",
      "[CellOT+scGen] epoch=2800 f_loss=2.0226 g_loss=-46.8776 | train_mmd=0.0097 | test_mmd=0.0096 | test_mmd_cellot=0.0110\n",
      "[CellOT+scGen] epoch=2850 f_loss=-3.0427 g_loss=-38.1120 | train_mmd=0.0111 | test_mmd=0.0100 | test_mmd_cellot=0.0123\n",
      "[CellOT+scGen] epoch=2900 f_loss=-2.7890 g_loss=-5.3378 | train_mmd=0.0105 | test_mmd=0.0104 | test_mmd_cellot=0.0128\n",
      "[CellOT+scGen] epoch=2950 f_loss=-4.8204 g_loss=-42.0490 | train_mmd=0.0077 | test_mmd=0.0075 | test_mmd_cellot=0.0102\n",
      "[CellOT+scGen] epoch=3000 f_loss=-4.0834 g_loss=-38.6531 | train_mmd=0.0093 | test_mmd=0.0088 | test_mmd_cellot=0.0116\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0116\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 109/500:  22%|█████████████████████████████████████████████▊                                                                                                                                                                    | 109/500 [00:11<00:42,  9.30it/s, loss=31.1, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 288.156. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-681732.8750 g_loss=674143.6250 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=5011.8896 g_loss=-2912.5317 | train_mmd=0.7669 | test_mmd=0.7663 | test_mmd_cellot=0.2069\n",
      "[CellOT+scGen] epoch=100 f_loss=-420800.1250 g_loss=422325.7500 | train_mmd=0.6086 | test_mmd=0.6320 | test_mmd_cellot=0.1707\n",
      "[CellOT+scGen] epoch=150 f_loss=-57088.5352 g_loss=70445.4844 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=200 f_loss=-429305.9688 g_loss=475281.2812 | train_mmd=0.7268 | test_mmd=0.7109 | test_mmd_cellot=0.1929\n",
      "[CellOT+scGen] epoch=250 f_loss=-13505.0869 g_loss=34459.0469 | train_mmd=0.7633 | test_mmd=0.7632 | test_mmd_cellot=0.2049\n",
      "[CellOT+scGen] epoch=300 f_loss=-3809.3010 g_loss=7236.4658 | train_mmd=0.3474 | test_mmd=0.3548 | test_mmd_cellot=0.1217\n",
      "[CellOT+scGen] epoch=350 f_loss=-5893.8115 g_loss=8999.1455 | train_mmd=0.0627 | test_mmd=0.0646 | test_mmd_cellot=0.1129\n",
      "[CellOT+scGen] epoch=400 f_loss=-67722.4844 g_loss=49409.3750 | train_mmd=0.1674 | test_mmd=0.1539 | test_mmd_cellot=0.1461\n",
      "[CellOT+scGen] epoch=450 f_loss=-21258.4004 g_loss=43607.3164 | train_mmd=0.1774 | test_mmd=0.1696 | test_mmd_cellot=0.1905\n",
      "[CellOT+scGen] epoch=500 f_loss=15160.6113 g_loss=610.9001 | train_mmd=0.0481 | test_mmd=0.0504 | test_mmd_cellot=0.2011\n",
      "[CellOT+scGen] epoch=550 f_loss=5053.9326 g_loss=25.4329 | train_mmd=0.7029 | test_mmd=0.7507 | test_mmd_cellot=0.3451\n",
      "[CellOT+scGen] epoch=600 f_loss=297.9347 g_loss=-37.1346 | train_mmd=0.0546 | test_mmd=0.0521 | test_mmd_cellot=0.0465\n",
      "[CellOT+scGen] epoch=650 f_loss=-1.7969 g_loss=-57.9623 | train_mmd=0.0276 | test_mmd=0.0265 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=700 f_loss=1.8964 g_loss=-45.8109 | train_mmd=0.0155 | test_mmd=0.0152 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=750 f_loss=2.2150 g_loss=-38.5592 | train_mmd=0.0133 | test_mmd=0.0132 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=800 f_loss=1.8081 g_loss=-35.7575 | train_mmd=0.0117 | test_mmd=0.0117 | test_mmd_cellot=0.0156\n",
      "[CellOT+scGen] epoch=850 f_loss=0.9796 g_loss=-33.2008 | train_mmd=0.0124 | test_mmd=0.0117 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=900 f_loss=1.6858 g_loss=-33.0772 | train_mmd=0.0122 | test_mmd=0.0125 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=950 f_loss=-1.0148 g_loss=-29.3990 | train_mmd=0.0107 | test_mmd=0.0108 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=1000 f_loss=-4.4755 g_loss=-29.1079 | train_mmd=0.0105 | test_mmd=0.0113 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1050 f_loss=-2.1041 g_loss=-25.8179 | train_mmd=0.0089 | test_mmd=0.0086 | test_mmd_cellot=0.0148\n",
      "[CellOT+scGen] epoch=1100 f_loss=4.3593 g_loss=-24.8143 | train_mmd=0.0104 | test_mmd=0.0122 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=1150 f_loss=-0.2139 g_loss=-24.1182 | train_mmd=0.0094 | test_mmd=0.0105 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=1200 f_loss=-0.1412 g_loss=-23.2747 | train_mmd=0.0095 | test_mmd=0.0105 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1250 f_loss=-0.0182 g_loss=-24.7790 | train_mmd=0.0095 | test_mmd=0.0106 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1300 f_loss=-2.2051 g_loss=-23.3997 | train_mmd=0.0095 | test_mmd=0.0105 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=1350 f_loss=0.8934 g_loss=-21.2516 | train_mmd=0.0100 | test_mmd=0.0117 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=1400 f_loss=0.1833 g_loss=-20.9997 | train_mmd=0.0112 | test_mmd=0.0139 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1450 f_loss=-0.1763 g_loss=-22.5005 | train_mmd=0.0094 | test_mmd=0.0101 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.2492 g_loss=-19.5025 | train_mmd=0.0110 | test_mmd=0.0128 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=1550 f_loss=0.2614 g_loss=-19.5814 | train_mmd=0.0101 | test_mmd=0.0115 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.8764 g_loss=-20.7537 | train_mmd=0.0084 | test_mmd=0.0090 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=1650 f_loss=-1.8349 g_loss=-18.1650 | train_mmd=0.0088 | test_mmd=0.0094 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1700 f_loss=1.0637 g_loss=-17.9327 | train_mmd=0.0105 | test_mmd=0.0119 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=1750 f_loss=-0.2660 g_loss=-20.4881 | train_mmd=0.0124 | test_mmd=0.0146 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=1800 f_loss=0.5281 g_loss=-20.2816 | train_mmd=0.0084 | test_mmd=0.0093 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=1850 f_loss=0.9625 g_loss=-17.9229 | train_mmd=0.0128 | test_mmd=0.0141 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=1900 f_loss=0.3107 g_loss=-17.5300 | train_mmd=0.0100 | test_mmd=0.0110 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.4947 g_loss=-19.1577 | train_mmd=0.0113 | test_mmd=0.0124 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2000 f_loss=-0.6668 g_loss=-16.6771 | train_mmd=0.0122 | test_mmd=0.0140 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.8918 g_loss=-17.0265 | train_mmd=0.0099 | test_mmd=0.0111 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=2100 f_loss=0.3326 g_loss=-18.2249 | train_mmd=0.0096 | test_mmd=0.0111 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=2150 f_loss=3.3913 g_loss=-16.8971 | train_mmd=0.0093 | test_mmd=0.0105 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.6334 g_loss=-16.2930 | train_mmd=0.0098 | test_mmd=0.0108 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=2250 f_loss=-1.3182 g_loss=-17.1383 | train_mmd=0.0112 | test_mmd=0.0127 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=2300 f_loss=-1.9192 g_loss=-18.3330 | train_mmd=0.0108 | test_mmd=0.0119 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=2350 f_loss=2.0136 g_loss=-14.8423 | train_mmd=0.0126 | test_mmd=0.0135 | test_mmd_cellot=0.0245\n",
      "[CellOT+scGen] epoch=2400 f_loss=-2.7647 g_loss=-17.0882 | train_mmd=0.0101 | test_mmd=0.0116 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.0858 g_loss=-16.0375 | train_mmd=0.0100 | test_mmd=0.0112 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=2500 f_loss=-1.2555 g_loss=-15.9914 | train_mmd=0.0120 | test_mmd=0.0135 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=2550 f_loss=1.7571 g_loss=-16.8714 | train_mmd=0.0121 | test_mmd=0.0137 | test_mmd_cellot=0.0249\n",
      "[CellOT+scGen] epoch=2600 f_loss=-0.9826 g_loss=-15.8499 | train_mmd=0.0098 | test_mmd=0.0108 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.9900 g_loss=-17.0843 | train_mmd=0.0093 | test_mmd=0.0107 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=2700 f_loss=0.9907 g_loss=-14.7338 | train_mmd=0.0102 | test_mmd=0.0114 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=2750 f_loss=1.3450 g_loss=-15.9851 | train_mmd=0.0113 | test_mmd=0.0128 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=2800 f_loss=-2.2365 g_loss=-17.2614 | train_mmd=0.0106 | test_mmd=0.0119 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=2850 f_loss=-0.5040 g_loss=-16.6477 | train_mmd=0.0114 | test_mmd=0.0124 | test_mmd_cellot=0.0249\n",
      "[CellOT+scGen] epoch=2900 f_loss=0.0784 g_loss=-16.7421 | train_mmd=0.0112 | test_mmd=0.0120 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=2950 f_loss=-1.4706 g_loss=-14.9857 | train_mmd=0.0105 | test_mmd=0.0121 | test_mmd_cellot=0.0239\n",
      "[CellOT+scGen] epoch=3000 f_loss=-1.5245 g_loss=-15.1053 | train_mmd=0.0108 | test_mmd=0.0117 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0227\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 110/500:  22%|██████████████████████████████████████████████▏                                                                                                                                                                   | 110/500 [00:11<00:39,  9.93it/s, loss=30.4, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 286.038. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-598497.8125 g_loss=640485.5000 | train_mmd=0.7734 | test_mmd=0.7726 | test_mmd_cellot=0.2085\n",
      "[CellOT+scGen] epoch=50 f_loss=-24595.8047 g_loss=39378.2148 | train_mmd=0.7496 | test_mmd=0.7479 | test_mmd_cellot=0.2025\n",
      "[CellOT+scGen] epoch=100 f_loss=-109394.8281 g_loss=98986.9141 | train_mmd=0.7719 | test_mmd=0.7678 | test_mmd_cellot=0.2077\n",
      "[CellOT+scGen] epoch=150 f_loss=-50698.0391 g_loss=52553.0703 | train_mmd=0.7951 | test_mmd=0.7663 | test_mmd_cellot=0.2065\n",
      "[CellOT+scGen] epoch=200 f_loss=-2689.3538 g_loss=8269.8125 | train_mmd=0.5320 | test_mmd=0.5220 | test_mmd_cellot=0.1625\n",
      "[CellOT+scGen] epoch=250 f_loss=4047.8203 g_loss=2099.7461 | train_mmd=0.1745 | test_mmd=0.1784 | test_mmd_cellot=0.1336\n",
      "[CellOT+scGen] epoch=300 f_loss=1983.0896 g_loss=624.9141 | train_mmd=0.0436 | test_mmd=0.0418 | test_mmd_cellot=0.1878\n",
      "[CellOT+scGen] epoch=350 f_loss=698.9648 g_loss=19.4576 | train_mmd=0.0682 | test_mmd=0.0752 | test_mmd_cellot=0.1542\n",
      "[CellOT+scGen] epoch=400 f_loss=9.0996 g_loss=-50.0208 | train_mmd=0.0142 | test_mmd=0.0132 | test_mmd_cellot=0.0142\n",
      "[CellOT+scGen] epoch=450 f_loss=2.3958 g_loss=-42.3921 | train_mmd=0.0212 | test_mmd=0.0195 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=500 f_loss=0.5253 g_loss=-36.8421 | train_mmd=0.0160 | test_mmd=0.0147 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=550 f_loss=4.1709 g_loss=-32.2000 | train_mmd=0.0116 | test_mmd=0.0116 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=600 f_loss=-0.3797 g_loss=-27.6914 | train_mmd=0.0147 | test_mmd=0.0138 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=650 f_loss=0.6275 g_loss=-26.1563 | train_mmd=0.0119 | test_mmd=0.0111 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=700 f_loss=-1.8861 g_loss=-26.0373 | train_mmd=0.0166 | test_mmd=0.0152 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=750 f_loss=2.1275 g_loss=-25.2243 | train_mmd=0.0117 | test_mmd=0.0130 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.4327 g_loss=-21.1624 | train_mmd=0.0102 | test_mmd=0.0102 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=850 f_loss=0.9752 g_loss=-21.0821 | train_mmd=0.0092 | test_mmd=0.0092 | test_mmd_cellot=0.0153\n",
      "[CellOT+scGen] epoch=900 f_loss=3.1201 g_loss=-18.8084 | train_mmd=0.0116 | test_mmd=0.0123 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=950 f_loss=-0.2615 g_loss=-20.4939 | train_mmd=0.0096 | test_mmd=0.0101 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1000 f_loss=2.0837 g_loss=-17.8253 | train_mmd=0.0117 | test_mmd=0.0130 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=1050 f_loss=-3.9556 g_loss=-17.2828 | train_mmd=0.0101 | test_mmd=0.0104 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=1100 f_loss=-0.1898 g_loss=-15.4770 | train_mmd=0.0129 | test_mmd=0.0128 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1150 f_loss=1.7990 g_loss=-17.0039 | train_mmd=0.0101 | test_mmd=0.0096 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=1200 f_loss=-0.9928 g_loss=-19.0725 | train_mmd=0.0108 | test_mmd=0.0109 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=1250 f_loss=-1.3809 g_loss=-16.7184 | train_mmd=0.0105 | test_mmd=0.0106 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=1300 f_loss=-1.8643 g_loss=-18.1688 | train_mmd=0.0139 | test_mmd=0.0142 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=1350 f_loss=3.0662 g_loss=-17.3870 | train_mmd=0.0101 | test_mmd=0.0103 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1400 f_loss=2.3093 g_loss=-16.9173 | train_mmd=0.0109 | test_mmd=0.0114 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1450 f_loss=-1.0020 g_loss=-17.6098 | train_mmd=0.0116 | test_mmd=0.0122 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1500 f_loss=0.3908 g_loss=-17.4539 | train_mmd=0.0097 | test_mmd=0.0101 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=1550 f_loss=0.4103 g_loss=-17.6178 | train_mmd=0.0152 | test_mmd=0.0149 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=1600 f_loss=-2.2270 g_loss=-14.8886 | train_mmd=0.0135 | test_mmd=0.0145 | test_mmd_cellot=0.0259\n",
      "[CellOT+scGen] epoch=1650 f_loss=-0.2930 g_loss=-19.3579 | train_mmd=0.0149 | test_mmd=0.0155 | test_mmd_cellot=0.0274\n",
      "[CellOT+scGen] epoch=1700 f_loss=-2.1830 g_loss=-15.2834 | train_mmd=0.0146 | test_mmd=0.0144 | test_mmd_cellot=0.0235\n",
      "[CellOT+scGen] epoch=1750 f_loss=-1.3665 g_loss=-17.9542 | train_mmd=0.0105 | test_mmd=0.0109 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1800 f_loss=0.6337 g_loss=-18.1855 | train_mmd=0.0102 | test_mmd=0.0106 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1850 f_loss=-1.2971 g_loss=-17.3621 | train_mmd=0.0104 | test_mmd=0.0105 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1900 f_loss=0.4824 g_loss=-14.8648 | train_mmd=0.0113 | test_mmd=0.0119 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=1950 f_loss=2.1803 g_loss=-18.0057 | train_mmd=0.0123 | test_mmd=0.0124 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2000 f_loss=1.2509 g_loss=-15.1987 | train_mmd=0.0121 | test_mmd=0.0131 | test_mmd_cellot=0.0242\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.4475 g_loss=-15.4332 | train_mmd=0.0119 | test_mmd=0.0130 | test_mmd_cellot=0.0250\n",
      "[CellOT+scGen] epoch=2100 f_loss=1.7364 g_loss=-16.0795 | train_mmd=0.0105 | test_mmd=0.0107 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=2150 f_loss=1.7261 g_loss=-16.4837 | train_mmd=0.0118 | test_mmd=0.0127 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.2376 g_loss=-16.5273 | train_mmd=0.0124 | test_mmd=0.0131 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=2250 f_loss=0.6259 g_loss=-17.3409 | train_mmd=0.0106 | test_mmd=0.0110 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=2300 f_loss=0.4040 g_loss=-13.4452 | train_mmd=0.0106 | test_mmd=0.0110 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=2350 f_loss=-2.9073 g_loss=-16.2922 | train_mmd=0.0166 | test_mmd=0.0160 | test_mmd_cellot=0.0254\n",
      "[CellOT+scGen] epoch=2400 f_loss=-1.5873 g_loss=-13.9591 | train_mmd=0.0123 | test_mmd=0.0130 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=2450 f_loss=1.0715 g_loss=-12.6038 | train_mmd=0.0124 | test_mmd=0.0132 | test_mmd_cellot=0.0249\n",
      "[CellOT+scGen] epoch=2500 f_loss=0.0062 g_loss=-15.2707 | train_mmd=0.0102 | test_mmd=0.0111 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2550 f_loss=-0.2246 g_loss=-16.7561 | train_mmd=0.0115 | test_mmd=0.0122 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=2600 f_loss=-1.4997 g_loss=-14.9728 | train_mmd=0.0113 | test_mmd=0.0114 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=2650 f_loss=0.6105 g_loss=-16.6347 | train_mmd=0.0106 | test_mmd=0.0106 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2700 f_loss=-0.5901 g_loss=-14.0249 | train_mmd=0.0109 | test_mmd=0.0113 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2750 f_loss=0.7231 g_loss=-14.2087 | train_mmd=0.0110 | test_mmd=0.0113 | test_mmd_cellot=0.0235\n",
      "[CellOT+scGen] epoch=2800 f_loss=0.5037 g_loss=-15.8012 | train_mmd=0.0116 | test_mmd=0.0119 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=2850 f_loss=-1.2380 g_loss=-14.7786 | train_mmd=0.0105 | test_mmd=0.0106 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=2900 f_loss=1.5859 g_loss=-13.7849 | train_mmd=0.0135 | test_mmd=0.0143 | test_mmd_cellot=0.0276\n",
      "[CellOT+scGen] epoch=2950 f_loss=-1.5065 g_loss=-12.9629 | train_mmd=0.0121 | test_mmd=0.0121 | test_mmd_cellot=0.0241\n",
      "[CellOT+scGen] epoch=3000 f_loss=-3.5173 g_loss=-13.3760 | train_mmd=0.0195 | test_mmd=0.0188 | test_mmd_cellot=0.0274\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0274\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=== Metrics Summary over Runs for top 100 genes ===\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0117  0.0029\n",
      "mmd2_gamma_0.5        0.0031  0.0002\n",
      "mmd2_gamma_1.0        0.0029  0.0000\n",
      "wasserstein_distance  7.0460  0.2342\n",
      "R2_feature_means      0.7263  0.1355\n"
     ]
    }
   ],
   "source": [
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "\n",
    "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=3000, top_feature_subset=top_genes_idx, seed=seed)\n",
    "  \n",
    "    metrics = summarize_metrics(out[\"y_pred\"][:, top_genes_idx], Y_te_post[:, top_genes_idx], median_gamma)\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "print(\"=== Metrics Summary over Runs for top 100 genes ===\")\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e385f159",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dcb8b4b2",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "5b0dc3fe",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_pre cells: (17565, 1000)\n",
      "X_post cells: (4505, 1000)\n",
      "(3604, 1000)\n",
      "(901, 1000)\n",
      "(3604, 1000)\n",
      "(901, 1000)\n",
      "Median heuristic gamma: 0.0021515925828798567\n"
     ]
    }
   ],
   "source": [
    "drug = \"abexinostat\"\n",
    "X_pre = adata_sc[adata_sc.obs[\"drug\"] == \"control\"].copy().to_df()\n",
    "X_post  = adata_sc[adata_sc.obs[\"drug\"] == drug].copy().to_df()\n",
    "\n",
    "print(\"X_pre cells:\", X_pre.shape)\n",
    "print(\"X_post cells:\", X_post.shape)\n",
    "\n",
    "top_genes_ids, top_genes_short, top_genes_idx = topk_markers(adata_sc, drug, k=100)\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",
    "\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "c9267d58",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(3604, 1000)\n",
      "(901, 1000)\n",
      "(3604, 1000)\n",
      "(901, 1000)\n",
      "**************** Run: 0 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108/500:  22%|█████████████████████████████████████████████▎                                                                                                                                                                    | 108/500 [00:13<00:48,  8.05it/s, loss=35.4, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 290.141. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-332769.3750 g_loss=401191.3125 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-27544.6230 g_loss=42753.5859 | train_mmd=0.7764 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=100 f_loss=213.1494 g_loss=-1023.6663 | train_mmd=0.7177 | test_mmd=0.7248 | test_mmd_cellot=0.1880\n",
      "[CellOT+scGen] epoch=150 f_loss=5.1382 g_loss=-3210.9897 | train_mmd=0.9156 | test_mmd=0.9112 | test_mmd_cellot=0.3338\n",
      "[CellOT+scGen] epoch=200 f_loss=-2001821.8750 g_loss=2017802.1250 | train_mmd=0.7079 | test_mmd=0.7239 | test_mmd_cellot=0.1843\n",
      "[CellOT+scGen] epoch=250 f_loss=-23466209280.0000 g_loss=25389637632.0000 | train_mmd=0.8038 | test_mmd=0.7972 | test_mmd_cellot=0.2166\n",
      "[CellOT+scGen] epoch=300 f_loss=40056.5938 g_loss=54.2237 | train_mmd=0.6620 | test_mmd=0.6655 | test_mmd_cellot=0.1677\n",
      "[CellOT+scGen] epoch=350 f_loss=52766.3203 g_loss=-3762.5786 | train_mmd=0.7689 | test_mmd=0.7636 | test_mmd_cellot=0.1914\n",
      "[CellOT+scGen] epoch=400 f_loss=-15280228.0000 g_loss=23138510.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=450 f_loss=9737.1289 g_loss=34693.0586 | train_mmd=0.7435 | test_mmd=0.7386 | test_mmd_cellot=0.1846\n",
      "[CellOT+scGen] epoch=500 f_loss=57239.3398 g_loss=-9014.7295 | train_mmd=0.7746 | test_mmd=0.7712 | test_mmd_cellot=0.1935\n",
      "[CellOT+scGen] epoch=550 f_loss=-186075776.0000 g_loss=214994848.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=600 f_loss=56358.5312 g_loss=-5701.0127 | train_mmd=0.7770 | test_mmd=0.7712 | test_mmd_cellot=0.1935\n",
      "[CellOT+scGen] epoch=650 f_loss=-69172984.0000 g_loss=77547040.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=700 f_loss=62493.3516 g_loss=490.7654 | train_mmd=0.7651 | test_mmd=0.7580 | test_mmd_cellot=0.1898\n",
      "[CellOT+scGen] epoch=750 f_loss=70877.5938 g_loss=-5492.4297 | train_mmd=0.7741 | test_mmd=0.7693 | test_mmd_cellot=0.1930\n",
      "[CellOT+scGen] epoch=800 f_loss=-1275619840.0000 g_loss=1281315840.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=850 f_loss=76619.7031 g_loss=-4722.8477 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=900 f_loss=55739.3438 g_loss=565.4606 | train_mmd=0.7647 | test_mmd=0.7675 | test_mmd_cellot=0.1925\n",
      "[CellOT+scGen] epoch=950 f_loss=80571.9531 g_loss=-3360.5552 | train_mmd=0.7775 | test_mmd=0.7731 | test_mmd_cellot=0.1941\n",
      "[CellOT+scGen] epoch=1000 f_loss=-753453.3750 g_loss=885412.1250 | train_mmd=0.7609 | test_mmd=0.7655 | test_mmd_cellot=0.1919\n",
      "[CellOT+scGen] epoch=1050 f_loss=77536.5781 g_loss=-5502.3018 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1100 f_loss=-446854464.0000 g_loss=507817696.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1150 f_loss=85203.1797 g_loss=-3184.0088 | train_mmd=0.7684 | test_mmd=0.7712 | test_mmd_cellot=0.1935\n",
      "[CellOT+scGen] epoch=1200 f_loss=-1793946624.0000 g_loss=1910660352.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1250 f_loss=93485.9766 g_loss=-6866.7852 | train_mmd=0.7775 | test_mmd=0.7731 | test_mmd_cellot=0.1941\n",
      "[CellOT+scGen] epoch=1300 f_loss=-12187481088.0000 g_loss=12855577600.0000 | train_mmd=0.7765 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1350 f_loss=96245.6641 g_loss=11637.3242 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1400 f_loss=93927.7266 g_loss=506.7547 | train_mmd=0.7770 | test_mmd=0.7731 | test_mmd_cellot=0.1941\n",
      "[CellOT+scGen] epoch=1450 f_loss=115494.4922 g_loss=-2998.8110 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1500 f_loss=-418132.4688 g_loss=526430.9375 | train_mmd=0.7751 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1550 f_loss=-8764717.0000 g_loss=9615156.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1600 f_loss=146979.1875 g_loss=-1411.9070 | train_mmd=0.7775 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1650 f_loss=-36088832.0000 g_loss=45630004.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1700 f_loss=142063.2188 g_loss=-3255.8506 | train_mmd=0.7779 | test_mmd=0.7732 | test_mmd_cellot=0.1941\n",
      "[CellOT+scGen] epoch=1750 f_loss=-1308456832.0000 g_loss=1393247744.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1800 f_loss=150683.1250 g_loss=-1126.2139 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1850 f_loss=-450900576.0000 g_loss=469116544.0000 | train_mmd=0.7775 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1900 f_loss=178987.9219 g_loss=-1576.0168 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=1950 f_loss=-773165248.0000 g_loss=793329024.0000 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=2000 f_loss=126268.5469 g_loss=17843.5977 | train_mmd=0.7765 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=2050 f_loss=131770.0625 g_loss=-352.1388 | train_mmd=0.7765 | test_mmd=0.7735 | test_mmd_cellot=0.1935\n",
      "[CellOT+scGen] epoch=2100 f_loss=56780.9844 g_loss=-1349.1022 | train_mmd=0.7524 | test_mmd=0.7712 | test_mmd_cellot=0.1935\n",
      "[CellOT+scGen] epoch=2150 f_loss=-310888256.0000 g_loss=321842528.0000 | train_mmd=0.7780 | test_mmd=0.7751 | test_mmd_cellot=0.1947\n",
      "[CellOT+scGen] epoch=2200 f_loss=69448.4141 g_loss=-318.2377 | train_mmd=0.7789 | test_mmd=0.7760 | test_mmd_cellot=0.1951\n",
      "[CellOT+scGen] epoch=2250 f_loss=88021.5234 g_loss=3470.2051 | train_mmd=0.7770 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=2300 f_loss=10673.2695 g_loss=4014.0264 | train_mmd=0.4858 | test_mmd=0.4875 | test_mmd_cellot=0.1380\n",
      "[CellOT+scGen] epoch=2350 f_loss=954.5350 g_loss=-121.7358 | train_mmd=0.5562 | test_mmd=0.5672 | test_mmd_cellot=0.1509\n",
      "[CellOT+scGen] epoch=2400 f_loss=5797.5908 g_loss=-210.1046 | train_mmd=0.8847 | test_mmd=0.8903 | test_mmd_cellot=0.2165\n",
      "[CellOT+scGen] epoch=2450 f_loss=27242.8750 g_loss=-159.5013 | train_mmd=0.5820 | test_mmd=0.5901 | test_mmd_cellot=0.1573\n",
      "[CellOT+scGen] epoch=2500 f_loss=-31758774.0000 g_loss=32165984.0000 | train_mmd=0.8218 | test_mmd=0.8259 | test_mmd_cellot=0.1988\n",
      "[CellOT+scGen] epoch=2550 f_loss=18924.0566 g_loss=-200.2387 | train_mmd=0.7899 | test_mmd=0.7950 | test_mmd_cellot=0.1922\n",
      "[CellOT+scGen] epoch=2600 f_loss=-225981.0469 g_loss=278082.7500 | train_mmd=0.5632 | test_mmd=0.5644 | test_mmd_cellot=0.1512\n",
      "[CellOT+scGen] epoch=2650 f_loss=17875.6211 g_loss=-248.0001 | train_mmd=0.8120 | test_mmd=0.8126 | test_mmd_cellot=0.2024\n",
      "[CellOT+scGen] epoch=2700 f_loss=50153.4141 g_loss=103.7198 | train_mmd=0.4101 | test_mmd=0.4126 | test_mmd_cellot=0.1237\n",
      "[CellOT+scGen] epoch=2750 f_loss=14055.0498 g_loss=545.0790 | train_mmd=0.8065 | test_mmd=0.8010 | test_mmd_cellot=0.1984\n",
      "[CellOT+scGen] epoch=2800 f_loss=24962.9805 g_loss=7.0269 | train_mmd=0.2135 | test_mmd=0.2207 | test_mmd_cellot=0.0825\n",
      "[CellOT+scGen] epoch=2850 f_loss=3141.5435 g_loss=0.3419 | train_mmd=0.6070 | test_mmd=0.6116 | test_mmd_cellot=0.1597\n",
      "[CellOT+scGen] epoch=2900 f_loss=30921.5938 g_loss=-83.4255 | train_mmd=0.2752 | test_mmd=0.2748 | test_mmd_cellot=0.0981\n",
      "[CellOT+scGen] epoch=2950 f_loss=403.6484 g_loss=19.3256 | train_mmd=0.4141 | test_mmd=0.4114 | test_mmd_cellot=0.1274\n",
      "[CellOT+scGen] epoch=3000 f_loss=25.7459 g_loss=-68.4530 | train_mmd=0.0283 | test_mmd=0.0301 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0188\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 1 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108/500:  22%|█████████████████████████████████████████████▊                                                                                                                                                                      | 108/500 [00:11<00:41,  9.48it/s, loss=36, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 291.968. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-808158.8750 g_loss=813693.0625 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-62014.8281 g_loss=92923.7188 | train_mmd=0.7774 | test_mmd=0.7749 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=100 f_loss=-23809.5723 g_loss=82149.5469 | train_mmd=0.7714 | test_mmd=0.7719 | test_mmd_cellot=0.1940\n",
      "[CellOT+scGen] epoch=150 f_loss=-17852.7012 g_loss=31222.5156 | train_mmd=0.7309 | test_mmd=0.7403 | test_mmd_cellot=0.1845\n",
      "[CellOT+scGen] epoch=200 f_loss=-5860.8916 g_loss=27074.5820 | train_mmd=0.4999 | test_mmd=0.5165 | test_mmd_cellot=0.1408\n",
      "[CellOT+scGen] epoch=250 f_loss=1182.9598 g_loss=8034.3896 | train_mmd=0.0474 | test_mmd=0.0486 | test_mmd_cellot=0.0842\n",
      "[CellOT+scGen] epoch=300 f_loss=1840.7230 g_loss=138.3479 | train_mmd=0.0400 | test_mmd=0.0394 | test_mmd_cellot=0.1980\n",
      "[CellOT+scGen] epoch=350 f_loss=387.9927 g_loss=-28.5438 | train_mmd=0.0403 | test_mmd=0.0441 | test_mmd_cellot=0.0800\n",
      "[CellOT+scGen] epoch=400 f_loss=8.6049 g_loss=-48.0311 | train_mmd=0.0128 | test_mmd=0.0135 | test_mmd_cellot=0.0127\n",
      "[CellOT+scGen] epoch=450 f_loss=4.8109 g_loss=-39.8628 | train_mmd=0.0096 | test_mmd=0.0099 | test_mmd_cellot=0.0125\n",
      "[CellOT+scGen] epoch=500 f_loss=2.0539 g_loss=-38.6409 | train_mmd=0.0110 | test_mmd=0.0117 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=550 f_loss=2.6794 g_loss=-38.3985 | train_mmd=0.0093 | test_mmd=0.0105 | test_mmd_cellot=0.0154\n",
      "[CellOT+scGen] epoch=600 f_loss=-0.7509 g_loss=-36.6593 | train_mmd=0.0131 | test_mmd=0.0129 | test_mmd_cellot=0.0158\n",
      "[CellOT+scGen] epoch=650 f_loss=1.1704 g_loss=-34.2877 | train_mmd=0.0105 | test_mmd=0.0113 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=700 f_loss=-2.4614 g_loss=-34.9263 | train_mmd=0.0101 | test_mmd=0.0104 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=750 f_loss=2.9244 g_loss=-31.3001 | train_mmd=0.0094 | test_mmd=0.0093 | test_mmd_cellot=0.0189\n",
      "[CellOT+scGen] epoch=800 f_loss=0.5030 g_loss=-29.9382 | train_mmd=0.0122 | test_mmd=0.0135 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=850 f_loss=-2.2335 g_loss=-30.7318 | train_mmd=0.0100 | test_mmd=0.0110 | test_mmd_cellot=0.0186\n",
      "[CellOT+scGen] epoch=900 f_loss=0.8014 g_loss=-28.4247 | train_mmd=0.0112 | test_mmd=0.0116 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=950 f_loss=0.4154 g_loss=-30.6996 | train_mmd=0.0089 | test_mmd=0.0094 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=1000 f_loss=4.3873 g_loss=-27.6664 | train_mmd=0.0101 | test_mmd=0.0111 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=1050 f_loss=-2.9848 g_loss=-27.4602 | train_mmd=0.0148 | test_mmd=0.0164 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=1100 f_loss=-0.9586 g_loss=-28.7857 | train_mmd=0.0139 | test_mmd=0.0138 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=1150 f_loss=2.5509 g_loss=-25.1599 | train_mmd=0.0104 | test_mmd=0.0111 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=1200 f_loss=4.6536 g_loss=-25.6313 | train_mmd=0.0096 | test_mmd=0.0101 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=1250 f_loss=-0.0100 g_loss=-26.6377 | train_mmd=0.0093 | test_mmd=0.0094 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=1300 f_loss=-2.5025 g_loss=-24.8747 | train_mmd=0.0086 | test_mmd=0.0091 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=1350 f_loss=-1.7036 g_loss=-23.7570 | train_mmd=0.0102 | test_mmd=0.0104 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1400 f_loss=0.0180 g_loss=-24.6710 | train_mmd=0.0111 | test_mmd=0.0124 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=1450 f_loss=0.6162 g_loss=-24.7113 | train_mmd=0.0106 | test_mmd=0.0113 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=1500 f_loss=-1.7697 g_loss=-23.7318 | train_mmd=0.0099 | test_mmd=0.0110 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=1550 f_loss=-0.7647 g_loss=-25.5041 | train_mmd=0.0073 | test_mmd=0.0084 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.2148 g_loss=-24.7641 | train_mmd=0.0082 | test_mmd=0.0095 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=1650 f_loss=-1.2375 g_loss=-25.4904 | train_mmd=0.0103 | test_mmd=0.0112 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=1700 f_loss=0.8085 g_loss=-25.3453 | train_mmd=0.0087 | test_mmd=0.0094 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=1750 f_loss=1.6719 g_loss=-24.5569 | train_mmd=0.0096 | test_mmd=0.0100 | test_mmd_cellot=0.0243\n",
      "[CellOT+scGen] epoch=1800 f_loss=1.0839 g_loss=-23.9731 | train_mmd=0.0116 | test_mmd=0.0122 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=1850 f_loss=0.2271 g_loss=-22.8939 | train_mmd=0.0070 | test_mmd=0.0071 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1900 f_loss=0.0530 g_loss=-22.1099 | train_mmd=0.0098 | test_mmd=0.0111 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=1950 f_loss=2.0176 g_loss=-22.7881 | train_mmd=0.0110 | test_mmd=0.0115 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2000 f_loss=-0.3989 g_loss=-20.7877 | train_mmd=0.0089 | test_mmd=0.0092 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=2050 f_loss=-3.5279 g_loss=-22.4391 | train_mmd=0.0110 | test_mmd=0.0118 | test_mmd_cellot=0.0252\n",
      "[CellOT+scGen] epoch=2100 f_loss=0.5496 g_loss=-22.0412 | train_mmd=0.0118 | test_mmd=0.0125 | test_mmd_cellot=0.0263\n",
      "[CellOT+scGen] epoch=2150 f_loss=-3.0184 g_loss=-22.3052 | train_mmd=0.0088 | test_mmd=0.0089 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=2200 f_loss=1.9638 g_loss=-23.7972 | train_mmd=0.0088 | test_mmd=0.0091 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=2250 f_loss=-1.5356 g_loss=-20.7790 | train_mmd=0.0092 | test_mmd=0.0100 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=2300 f_loss=0.0052 g_loss=-22.3833 | train_mmd=0.0085 | test_mmd=0.0094 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=2350 f_loss=-0.6763 g_loss=-19.8175 | train_mmd=0.0118 | test_mmd=0.0118 | test_mmd_cellot=0.0243\n",
      "[CellOT+scGen] epoch=2400 f_loss=0.3671 g_loss=-22.3258 | train_mmd=0.0115 | test_mmd=0.0125 | test_mmd_cellot=0.0260\n",
      "[CellOT+scGen] epoch=2450 f_loss=-0.8509 g_loss=-20.6873 | train_mmd=0.0167 | test_mmd=0.0179 | test_mmd_cellot=0.0321\n",
      "[CellOT+scGen] epoch=2500 f_loss=-2.5461 g_loss=-19.9969 | train_mmd=0.0082 | test_mmd=0.0084 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=2550 f_loss=-2.8278 g_loss=-21.1472 | train_mmd=0.0092 | test_mmd=0.0097 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2600 f_loss=3.2414 g_loss=-22.7117 | train_mmd=0.0092 | test_mmd=0.0099 | test_mmd_cellot=0.0246\n",
      "[CellOT+scGen] epoch=2650 f_loss=-2.4197 g_loss=-21.1561 | train_mmd=0.0097 | test_mmd=0.0104 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=2700 f_loss=1.0636 g_loss=-21.4690 | train_mmd=0.0132 | test_mmd=0.0142 | test_mmd_cellot=0.0271\n",
      "[CellOT+scGen] epoch=2750 f_loss=0.8899 g_loss=-23.4736 | train_mmd=0.0091 | test_mmd=0.0098 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=2800 f_loss=0.1566 g_loss=-20.8921 | train_mmd=0.0100 | test_mmd=0.0110 | test_mmd_cellot=0.0261\n",
      "[CellOT+scGen] epoch=2850 f_loss=0.0259 g_loss=-20.1813 | train_mmd=0.0108 | test_mmd=0.0113 | test_mmd_cellot=0.0247\n",
      "[CellOT+scGen] epoch=2900 f_loss=0.4089 g_loss=-19.9861 | train_mmd=0.0110 | test_mmd=0.0114 | test_mmd_cellot=0.0245\n",
      "[CellOT+scGen] epoch=2950 f_loss=1.5364 g_loss=-21.5218 | train_mmd=0.0120 | test_mmd=0.0129 | test_mmd_cellot=0.0257\n",
      "[CellOT+scGen] epoch=3000 f_loss=2.7922 g_loss=-20.7826 | train_mmd=0.0110 | test_mmd=0.0117 | test_mmd_cellot=0.0267\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0267\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 2 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108/500:  22%|█████████████████████████████████████████████▎                                                                                                                                                                    | 108/500 [00:11<00:41,  9.35it/s, loss=35.5, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 283.609. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-621919.8125 g_loss=758875.3125 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-25161.8359 g_loss=25598.9883 | train_mmd=0.7135 | test_mmd=0.7238 | test_mmd_cellot=0.1811\n",
      "[CellOT+scGen] epoch=100 f_loss=-125094.2891 g_loss=121553.4375 | train_mmd=0.7393 | test_mmd=0.7380 | test_mmd_cellot=0.1866\n",
      "[CellOT+scGen] epoch=150 f_loss=1163.0593 g_loss=1434.9067 | train_mmd=0.8848 | test_mmd=0.8855 | test_mmd_cellot=0.3151\n",
      "[CellOT+scGen] epoch=200 f_loss=-54150.5703 g_loss=53951.2109 | train_mmd=0.7671 | test_mmd=0.7686 | test_mmd_cellot=0.1931\n",
      "[CellOT+scGen] epoch=250 f_loss=-3006.9014 g_loss=15219.9453 | train_mmd=0.2913 | test_mmd=0.2840 | test_mmd_cellot=0.0963\n",
      "[CellOT+scGen] epoch=300 f_loss=-1945.8401 g_loss=3750.8120 | train_mmd=0.1241 | test_mmd=0.1181 | test_mmd_cellot=0.1118\n",
      "[CellOT+scGen] epoch=350 f_loss=-12483.4824 g_loss=7627.7842 | train_mmd=0.0753 | test_mmd=0.0801 | test_mmd_cellot=0.1935\n",
      "[CellOT+scGen] epoch=400 f_loss=7024.3105 g_loss=-53.1598 | train_mmd=0.4387 | test_mmd=0.4179 | test_mmd_cellot=0.1856\n",
      "[CellOT+scGen] epoch=450 f_loss=1964.4675 g_loss=-24.3012 | train_mmd=0.0318 | test_mmd=0.0312 | test_mmd_cellot=0.0488\n",
      "[CellOT+scGen] epoch=500 f_loss=298.5690 g_loss=-57.8330 | train_mmd=0.0466 | test_mmd=0.0446 | test_mmd_cellot=0.0276\n",
      "[CellOT+scGen] epoch=550 f_loss=120.3634 g_loss=-60.3858 | train_mmd=0.0636 | test_mmd=0.0676 | test_mmd_cellot=0.0389\n",
      "[CellOT+scGen] epoch=600 f_loss=5.7631 g_loss=-53.6506 | train_mmd=0.0144 | test_mmd=0.0156 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=650 f_loss=-0.1520 g_loss=-47.7983 | train_mmd=0.0118 | test_mmd=0.0127 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=700 f_loss=2.7019 g_loss=-46.6939 | train_mmd=0.0152 | test_mmd=0.0160 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=750 f_loss=1.5609 g_loss=-44.8606 | train_mmd=0.0097 | test_mmd=0.0106 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.0389 g_loss=-42.6453 | train_mmd=0.0171 | test_mmd=0.0190 | test_mmd_cellot=0.0262\n",
      "[CellOT+scGen] epoch=850 f_loss=-0.7356 g_loss=-44.0610 | train_mmd=0.0129 | test_mmd=0.0148 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=900 f_loss=-1.6123 g_loss=-40.3390 | train_mmd=0.0112 | test_mmd=0.0129 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=950 f_loss=1.4756 g_loss=-36.7960 | train_mmd=0.0136 | test_mmd=0.0149 | test_mmd_cellot=0.0255\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.5913 g_loss=-36.8621 | train_mmd=0.0127 | test_mmd=0.0149 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=1050 f_loss=-1.6703 g_loss=-38.2372 | train_mmd=0.0145 | test_mmd=0.0155 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=1100 f_loss=0.0551 g_loss=-39.9207 | train_mmd=0.0105 | test_mmd=0.0106 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=1150 f_loss=-0.3806 g_loss=-35.9704 | train_mmd=0.0123 | test_mmd=0.0128 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=1200 f_loss=-0.5434 g_loss=-36.4329 | train_mmd=0.0121 | test_mmd=0.0137 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=1250 f_loss=2.3649 g_loss=-33.8756 | train_mmd=0.0096 | test_mmd=0.0097 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=1300 f_loss=-1.2158 g_loss=-33.5688 | train_mmd=0.0148 | test_mmd=0.0169 | test_mmd_cellot=0.0273\n",
      "[CellOT+scGen] epoch=1350 f_loss=-0.2457 g_loss=-32.4992 | train_mmd=0.0133 | test_mmd=0.0145 | test_mmd_cellot=0.0263\n",
      "[CellOT+scGen] epoch=1400 f_loss=3.7157 g_loss=-32.4058 | train_mmd=0.0114 | test_mmd=0.0110 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=1450 f_loss=0.0154 g_loss=-31.7012 | train_mmd=0.0127 | test_mmd=0.0132 | test_mmd_cellot=0.0257\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.3098 g_loss=-32.1972 | train_mmd=0.0113 | test_mmd=0.0127 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1550 f_loss=2.9015 g_loss=-30.8212 | train_mmd=0.0097 | test_mmd=0.0107 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=1600 f_loss=1.3586 g_loss=-31.0791 | train_mmd=0.0125 | test_mmd=0.0144 | test_mmd_cellot=0.0265\n",
      "[CellOT+scGen] epoch=1650 f_loss=2.1663 g_loss=-31.4351 | train_mmd=0.0134 | test_mmd=0.0135 | test_mmd_cellot=0.0256\n",
      "[CellOT+scGen] epoch=1700 f_loss=1.7878 g_loss=-33.7036 | train_mmd=0.0115 | test_mmd=0.0125 | test_mmd_cellot=0.0240\n",
      "[CellOT+scGen] epoch=1750 f_loss=-0.7268 g_loss=-27.9976 | train_mmd=0.0108 | test_mmd=0.0123 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=1800 f_loss=-1.1705 g_loss=-31.4928 | train_mmd=0.0089 | test_mmd=0.0093 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1850 f_loss=-0.6853 g_loss=-29.8787 | train_mmd=0.0148 | test_mmd=0.0166 | test_mmd_cellot=0.0303\n",
      "[CellOT+scGen] epoch=1900 f_loss=0.5385 g_loss=-26.8262 | train_mmd=0.0115 | test_mmd=0.0127 | test_mmd_cellot=0.0266\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.3357 g_loss=-27.9667 | train_mmd=0.0158 | test_mmd=0.0162 | test_mmd_cellot=0.0288\n",
      "[CellOT+scGen] epoch=2000 f_loss=-0.5013 g_loss=-29.1974 | train_mmd=0.0097 | test_mmd=0.0099 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=2050 f_loss=0.3144 g_loss=-25.7717 | train_mmd=0.0123 | test_mmd=0.0130 | test_mmd_cellot=0.0271\n",
      "[CellOT+scGen] epoch=2100 f_loss=2.8611 g_loss=-30.8180 | train_mmd=0.0134 | test_mmd=0.0150 | test_mmd_cellot=0.0284\n",
      "[CellOT+scGen] epoch=2150 f_loss=-0.0132 g_loss=-25.6189 | train_mmd=0.0131 | test_mmd=0.0147 | test_mmd_cellot=0.0283\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.1330 g_loss=-26.3341 | train_mmd=0.0089 | test_mmd=0.0096 | test_mmd_cellot=0.0244\n",
      "[CellOT+scGen] epoch=2250 f_loss=0.4879 g_loss=-26.7373 | train_mmd=0.0110 | test_mmd=0.0116 | test_mmd_cellot=0.0252\n",
      "[CellOT+scGen] epoch=2300 f_loss=-1.7188 g_loss=-26.5597 | train_mmd=0.0112 | test_mmd=0.0119 | test_mmd_cellot=0.0274\n",
      "[CellOT+scGen] epoch=2350 f_loss=-1.4226 g_loss=-28.6748 | train_mmd=0.0098 | test_mmd=0.0101 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=2400 f_loss=1.2609 g_loss=-26.5649 | train_mmd=0.0119 | test_mmd=0.0127 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.7804 g_loss=-24.2208 | train_mmd=0.0108 | test_mmd=0.0112 | test_mmd_cellot=0.0249\n",
      "[CellOT+scGen] epoch=2500 f_loss=0.1340 g_loss=-27.4754 | train_mmd=0.0114 | test_mmd=0.0120 | test_mmd_cellot=0.0266\n",
      "[CellOT+scGen] epoch=2550 f_loss=3.1386 g_loss=-26.2442 | train_mmd=0.0111 | test_mmd=0.0116 | test_mmd_cellot=0.0271\n",
      "[CellOT+scGen] epoch=2600 f_loss=-1.8037 g_loss=-26.1479 | train_mmd=0.0133 | test_mmd=0.0147 | test_mmd_cellot=0.0262\n",
      "[CellOT+scGen] epoch=2650 f_loss=0.1744 g_loss=-25.7595 | train_mmd=0.0120 | test_mmd=0.0142 | test_mmd_cellot=0.0275\n",
      "[CellOT+scGen] epoch=2700 f_loss=-0.0004 g_loss=-25.8329 | train_mmd=0.0112 | test_mmd=0.0120 | test_mmd_cellot=0.0271\n",
      "[CellOT+scGen] epoch=2750 f_loss=-1.7467 g_loss=-25.4923 | train_mmd=0.0110 | test_mmd=0.0120 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=2800 f_loss=-0.6617 g_loss=-27.5070 | train_mmd=0.0117 | test_mmd=0.0115 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=2850 f_loss=0.7785 g_loss=-25.0447 | train_mmd=0.0103 | test_mmd=0.0110 | test_mmd_cellot=0.0247\n",
      "[CellOT+scGen] epoch=2900 f_loss=0.5269 g_loss=-25.4229 | train_mmd=0.0115 | test_mmd=0.0130 | test_mmd_cellot=0.0266\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.1107 g_loss=-25.8712 | train_mmd=0.0150 | test_mmd=0.0161 | test_mmd_cellot=0.0315\n",
      "[CellOT+scGen] epoch=3000 f_loss=-1.8806 g_loss=-27.8254 | train_mmd=0.0130 | test_mmd=0.0147 | test_mmd_cellot=0.0277\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0277\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 3 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107/500:  21%|█████████████████████████████████████████████▎                                                                                                                                                                      | 107/500 [00:14<00:52,  7.42it/s, loss=36, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 286.706. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-485406.7188 g_loss=559700.3750 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-82919.6875 g_loss=88767.5156 | train_mmd=0.7768 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=100 f_loss=-13441.7637 g_loss=31934.8379 | train_mmd=0.7748 | test_mmd=0.7726 | test_mmd_cellot=0.1944\n",
      "[CellOT+scGen] epoch=150 f_loss=-25283.0234 g_loss=27138.1953 | train_mmd=0.7762 | test_mmd=0.7817 | test_mmd_cellot=0.1937\n",
      "[CellOT+scGen] epoch=200 f_loss=-11243.2383 g_loss=21537.2773 | train_mmd=0.5869 | test_mmd=0.6123 | test_mmd_cellot=0.1629\n",
      "[CellOT+scGen] epoch=250 f_loss=1117.2507 g_loss=19634.8594 | train_mmd=0.0522 | test_mmd=0.0517 | test_mmd_cellot=0.1022\n",
      "[CellOT+scGen] epoch=300 f_loss=4219.0337 g_loss=-129.0673 | train_mmd=0.7919 | test_mmd=0.7630 | test_mmd_cellot=0.3231\n",
      "[CellOT+scGen] epoch=350 f_loss=482.3606 g_loss=181.8461 | train_mmd=0.0541 | test_mmd=0.0548 | test_mmd_cellot=0.1061\n",
      "[CellOT+scGen] epoch=400 f_loss=69.3688 g_loss=-52.0846 | train_mmd=0.0460 | test_mmd=0.0444 | test_mmd_cellot=0.0289\n",
      "[CellOT+scGen] epoch=450 f_loss=6.4416 g_loss=-51.8889 | train_mmd=0.0154 | test_mmd=0.0154 | test_mmd_cellot=0.0124\n",
      "[CellOT+scGen] epoch=500 f_loss=0.8537 g_loss=-50.5700 | train_mmd=0.0081 | test_mmd=0.0089 | test_mmd_cellot=0.0114\n",
      "[CellOT+scGen] epoch=550 f_loss=-1.6219 g_loss=-45.4311 | train_mmd=0.0078 | test_mmd=0.0086 | test_mmd_cellot=0.0118\n",
      "[CellOT+scGen] epoch=600 f_loss=-0.4325 g_loss=-43.5247 | train_mmd=0.0108 | test_mmd=0.0126 | test_mmd_cellot=0.0173\n",
      "[CellOT+scGen] epoch=650 f_loss=-0.6509 g_loss=-43.7292 | train_mmd=0.0123 | test_mmd=0.0130 | test_mmd_cellot=0.0165\n",
      "[CellOT+scGen] epoch=700 f_loss=1.6661 g_loss=-43.5983 | train_mmd=0.0100 | test_mmd=0.0106 | test_mmd_cellot=0.0157\n",
      "[CellOT+scGen] epoch=750 f_loss=0.1596 g_loss=-41.7012 | train_mmd=0.0072 | test_mmd=0.0081 | test_mmd_cellot=0.0142\n",
      "[CellOT+scGen] epoch=800 f_loss=1.5010 g_loss=-41.5367 | train_mmd=0.0095 | test_mmd=0.0103 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=850 f_loss=2.1935 g_loss=-40.6402 | train_mmd=0.0091 | test_mmd=0.0097 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=900 f_loss=1.8533 g_loss=-38.0293 | train_mmd=0.0110 | test_mmd=0.0122 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=950 f_loss=0.6994 g_loss=-40.6941 | train_mmd=0.0105 | test_mmd=0.0115 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.0337 g_loss=-38.2104 | train_mmd=0.0106 | test_mmd=0.0116 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=1050 f_loss=0.2862 g_loss=-37.5422 | train_mmd=0.0089 | test_mmd=0.0099 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=1100 f_loss=1.6854 g_loss=-42.2947 | train_mmd=0.0080 | test_mmd=0.0088 | test_mmd_cellot=0.0148\n",
      "[CellOT+scGen] epoch=1150 f_loss=-0.8060 g_loss=-40.2585 | train_mmd=0.0082 | test_mmd=0.0088 | test_mmd_cellot=0.0133\n",
      "[CellOT+scGen] epoch=1200 f_loss=-1.8592 g_loss=-38.7824 | train_mmd=0.0089 | test_mmd=0.0102 | test_mmd_cellot=0.0152\n",
      "[CellOT+scGen] epoch=1250 f_loss=0.0357 g_loss=-38.2931 | train_mmd=0.0102 | test_mmd=0.0114 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=1300 f_loss=0.4729 g_loss=-36.5564 | train_mmd=0.0080 | test_mmd=0.0095 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=1350 f_loss=-1.3413 g_loss=-39.6762 | train_mmd=0.0072 | test_mmd=0.0079 | test_mmd_cellot=0.0143\n",
      "[CellOT+scGen] epoch=1400 f_loss=-4.1158 g_loss=-38.1585 | train_mmd=0.0090 | test_mmd=0.0103 | test_mmd_cellot=0.0156\n",
      "[CellOT+scGen] epoch=1450 f_loss=2.0614 g_loss=-37.3059 | train_mmd=0.0069 | test_mmd=0.0077 | test_mmd_cellot=0.0143\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.6749 g_loss=-37.2293 | train_mmd=0.0075 | test_mmd=0.0083 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=1550 f_loss=-0.5453 g_loss=-37.0755 | train_mmd=0.0069 | test_mmd=0.0078 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=1600 f_loss=1.5709 g_loss=-37.7225 | train_mmd=0.0062 | test_mmd=0.0065 | test_mmd_cellot=0.0135\n",
      "[CellOT+scGen] epoch=1650 f_loss=-1.5589 g_loss=-36.6210 | train_mmd=0.0088 | test_mmd=0.0101 | test_mmd_cellot=0.0155\n",
      "[CellOT+scGen] epoch=1700 f_loss=3.3016 g_loss=-34.1379 | train_mmd=0.0080 | test_mmd=0.0087 | test_mmd_cellot=0.0175\n",
      "[CellOT+scGen] epoch=1750 f_loss=1.0597 g_loss=-33.8588 | train_mmd=0.0067 | test_mmd=0.0069 | test_mmd_cellot=0.0156\n",
      "[CellOT+scGen] epoch=1800 f_loss=1.3319 g_loss=-36.5570 | train_mmd=0.0081 | test_mmd=0.0091 | test_mmd_cellot=0.0177\n",
      "[CellOT+scGen] epoch=1850 f_loss=-1.5866 g_loss=-34.3591 | train_mmd=0.0078 | test_mmd=0.0082 | test_mmd_cellot=0.0160\n",
      "[CellOT+scGen] epoch=1900 f_loss=1.1606 g_loss=-34.6940 | train_mmd=0.0075 | test_mmd=0.0081 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=1950 f_loss=1.9453 g_loss=-34.6077 | train_mmd=0.0075 | test_mmd=0.0075 | test_mmd_cellot=0.0160\n",
      "[CellOT+scGen] epoch=2000 f_loss=-0.5143 g_loss=-35.5309 | train_mmd=0.0078 | test_mmd=0.0088 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=2050 f_loss=1.8246 g_loss=-33.6665 | train_mmd=0.0079 | test_mmd=0.0086 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=2100 f_loss=-0.9377 g_loss=-34.2976 | train_mmd=0.0088 | test_mmd=0.0091 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=2150 f_loss=0.9650 g_loss=-30.6841 | train_mmd=0.0084 | test_mmd=0.0089 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.3386 g_loss=-35.7964 | train_mmd=0.0076 | test_mmd=0.0079 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=2250 f_loss=4.3861 g_loss=-33.8780 | train_mmd=0.0077 | test_mmd=0.0082 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=2300 f_loss=-1.9527 g_loss=-32.0384 | train_mmd=0.0061 | test_mmd=0.0067 | test_mmd_cellot=0.0147\n",
      "[CellOT+scGen] epoch=2350 f_loss=-1.5849 g_loss=-36.2741 | train_mmd=0.0064 | test_mmd=0.0070 | test_mmd_cellot=0.0158\n",
      "[CellOT+scGen] epoch=2400 f_loss=-1.5305 g_loss=-33.7896 | train_mmd=0.0069 | test_mmd=0.0074 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.2390 g_loss=-31.9121 | train_mmd=0.0073 | test_mmd=0.0083 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=2500 f_loss=1.9870 g_loss=-31.5048 | train_mmd=0.0077 | test_mmd=0.0083 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2550 f_loss=0.5523 g_loss=-34.0411 | train_mmd=0.0063 | test_mmd=0.0075 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=2600 f_loss=0.0712 g_loss=-29.9415 | train_mmd=0.0080 | test_mmd=0.0093 | test_mmd_cellot=0.0184\n",
      "[CellOT+scGen] epoch=2650 f_loss=-2.8332 g_loss=-30.4658 | train_mmd=0.0067 | test_mmd=0.0075 | test_mmd_cellot=0.0167\n",
      "[CellOT+scGen] epoch=2700 f_loss=0.9240 g_loss=-33.2452 | train_mmd=0.0069 | test_mmd=0.0075 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=2750 f_loss=-1.3081 g_loss=-30.2855 | train_mmd=0.0078 | test_mmd=0.0087 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=2800 f_loss=1.1420 g_loss=-28.5342 | train_mmd=0.0081 | test_mmd=0.0087 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=2850 f_loss=1.1425 g_loss=-31.1630 | train_mmd=0.0067 | test_mmd=0.0073 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=2900 f_loss=2.2048 g_loss=-28.7919 | train_mmd=0.0072 | test_mmd=0.0078 | test_mmd_cellot=0.0173\n",
      "[CellOT+scGen] epoch=2950 f_loss=-2.6133 g_loss=-27.3039 | train_mmd=0.0072 | test_mmd=0.0082 | test_mmd_cellot=0.0173\n",
      "[CellOT+scGen] epoch=3000 f_loss=-1.4565 g_loss=-26.9864 | train_mmd=0.0086 | test_mmd=0.0097 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0196\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 4 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108/500:  22%|█████████████████████████████████████████████▎                                                                                                                                                                    | 108/500 [00:14<00:52,  7.47it/s, loss=35.7, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 286.705. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-518605.0938 g_loss=546904.8750 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-211504.1250 g_loss=296538.5938 | train_mmd=0.7736 | test_mmd=0.7709 | test_mmd_cellot=0.1937\n",
      "[CellOT+scGen] epoch=100 f_loss=-103436.8984 g_loss=128629.2031 | train_mmd=0.7524 | test_mmd=0.7506 | test_mmd_cellot=0.1892\n",
      "[CellOT+scGen] epoch=150 f_loss=-19125.4492 g_loss=31350.2109 | train_mmd=0.7118 | test_mmd=0.7160 | test_mmd_cellot=0.1781\n",
      "[CellOT+scGen] epoch=200 f_loss=-1463.2305 g_loss=10277.9307 | train_mmd=0.4197 | test_mmd=0.4161 | test_mmd_cellot=0.1357\n",
      "[CellOT+scGen] epoch=250 f_loss=-15.5451 g_loss=5275.0557 | train_mmd=0.0824 | test_mmd=0.0821 | test_mmd_cellot=0.1174\n",
      "[CellOT+scGen] epoch=300 f_loss=2476.1028 g_loss=1357.7253 | train_mmd=0.0428 | test_mmd=0.0420 | test_mmd_cellot=0.1570\n",
      "[CellOT+scGen] epoch=350 f_loss=282.4591 g_loss=-41.0512 | train_mmd=0.0562 | test_mmd=0.0570 | test_mmd_cellot=0.0543\n",
      "[CellOT+scGen] epoch=400 f_loss=10.1549 g_loss=43.0691 | train_mmd=0.0138 | test_mmd=0.0134 | test_mmd_cellot=0.0143\n",
      "[CellOT+scGen] epoch=450 f_loss=0.1677 g_loss=-45.3127 | train_mmd=0.0120 | test_mmd=0.0119 | test_mmd_cellot=0.0134\n",
      "[CellOT+scGen] epoch=500 f_loss=4.0692 g_loss=-44.3663 | train_mmd=0.0095 | test_mmd=0.0103 | test_mmd_cellot=0.0176\n",
      "[CellOT+scGen] epoch=550 f_loss=1.9688 g_loss=-40.0577 | train_mmd=0.0171 | test_mmd=0.0169 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=600 f_loss=0.5711 g_loss=-34.0779 | train_mmd=0.0097 | test_mmd=0.0107 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=650 f_loss=0.3808 g_loss=-37.3713 | train_mmd=0.0096 | test_mmd=0.0105 | test_mmd_cellot=0.0164\n",
      "[CellOT+scGen] epoch=700 f_loss=-1.4463 g_loss=-33.3922 | train_mmd=0.0176 | test_mmd=0.0181 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=750 f_loss=2.0199 g_loss=-36.2793 | train_mmd=0.0147 | test_mmd=0.0142 | test_mmd_cellot=0.0209\n",
      "[CellOT+scGen] epoch=800 f_loss=0.4075 g_loss=-34.4268 | train_mmd=0.0123 | test_mmd=0.0144 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=850 f_loss=-2.8034 g_loss=-34.2338 | train_mmd=0.0135 | test_mmd=0.0156 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=900 f_loss=0.2317 g_loss=-27.2133 | train_mmd=0.0097 | test_mmd=0.0115 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=950 f_loss=-1.7021 g_loss=-33.8884 | train_mmd=0.0109 | test_mmd=0.0118 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1000 f_loss=1.5074 g_loss=-31.7651 | train_mmd=0.0126 | test_mmd=0.0132 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1050 f_loss=-0.2607 g_loss=-29.1491 | train_mmd=0.0137 | test_mmd=0.0145 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=1100 f_loss=1.4703 g_loss=-31.6347 | train_mmd=0.0112 | test_mmd=0.0114 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=1150 f_loss=-4.5898 g_loss=-28.3739 | train_mmd=0.0103 | test_mmd=0.0108 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1200 f_loss=0.3700 g_loss=-27.8745 | train_mmd=0.0096 | test_mmd=0.0105 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=1250 f_loss=-1.0334 g_loss=-29.5788 | train_mmd=0.0085 | test_mmd=0.0092 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1300 f_loss=0.5662 g_loss=-27.6419 | train_mmd=0.0114 | test_mmd=0.0114 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=1350 f_loss=2.6275 g_loss=-26.3692 | train_mmd=0.0101 | test_mmd=0.0101 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=1400 f_loss=0.1884 g_loss=-26.0618 | train_mmd=0.0101 | test_mmd=0.0110 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=1450 f_loss=1.0021 g_loss=-28.2407 | train_mmd=0.0123 | test_mmd=0.0141 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.5714 g_loss=-27.0205 | train_mmd=0.0133 | test_mmd=0.0144 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=1550 f_loss=1.5252 g_loss=-27.0084 | train_mmd=0.0112 | test_mmd=0.0119 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=1600 f_loss=-1.5229 g_loss=-26.3349 | train_mmd=0.0103 | test_mmd=0.0117 | test_mmd_cellot=0.0231\n",
      "[CellOT+scGen] epoch=1650 f_loss=-1.0097 g_loss=-27.0363 | train_mmd=0.0124 | test_mmd=0.0144 | test_mmd_cellot=0.0254\n",
      "[CellOT+scGen] epoch=1700 f_loss=0.3780 g_loss=-26.2150 | train_mmd=0.0098 | test_mmd=0.0109 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=1750 f_loss=1.8746 g_loss=-26.9831 | train_mmd=0.0099 | test_mmd=0.0107 | test_mmd_cellot=0.0240\n",
      "[CellOT+scGen] epoch=1800 f_loss=0.9862 g_loss=-26.6431 | train_mmd=0.0085 | test_mmd=0.0096 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=1850 f_loss=1.3690 g_loss=-24.8021 | train_mmd=0.0130 | test_mmd=0.0130 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=1900 f_loss=-0.2483 g_loss=-26.0510 | train_mmd=0.0099 | test_mmd=0.0118 | test_mmd_cellot=0.0247\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.5128 g_loss=-25.4827 | train_mmd=0.0092 | test_mmd=0.0107 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2000 f_loss=0.3103 g_loss=-24.5598 | train_mmd=0.0101 | test_mmd=0.0109 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.9398 g_loss=-21.7889 | train_mmd=0.0087 | test_mmd=0.0093 | test_mmd_cellot=0.0235\n",
      "[CellOT+scGen] epoch=2100 f_loss=3.1186 g_loss=-27.4626 | train_mmd=0.0097 | test_mmd=0.0100 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=2150 f_loss=-0.8668 g_loss=-26.3059 | train_mmd=0.0097 | test_mmd=0.0102 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2200 f_loss=1.9471 g_loss=-24.6393 | train_mmd=0.0109 | test_mmd=0.0122 | test_mmd_cellot=0.0260\n",
      "[CellOT+scGen] epoch=2250 f_loss=-0.1467 g_loss=-23.9182 | train_mmd=0.0106 | test_mmd=0.0113 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=2300 f_loss=-2.8039 g_loss=-23.7836 | train_mmd=0.0100 | test_mmd=0.0108 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=2350 f_loss=-3.3984 g_loss=-20.6492 | train_mmd=0.0102 | test_mmd=0.0115 | test_mmd_cellot=0.0242\n",
      "[CellOT+scGen] epoch=2400 f_loss=-0.3405 g_loss=-26.0861 | train_mmd=0.0091 | test_mmd=0.0100 | test_mmd_cellot=0.0235\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.8432 g_loss=-23.9134 | train_mmd=0.0130 | test_mmd=0.0142 | test_mmd_cellot=0.0245\n",
      "[CellOT+scGen] epoch=2500 f_loss=-0.9847 g_loss=-22.1262 | train_mmd=0.0088 | test_mmd=0.0099 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=2550 f_loss=1.1599 g_loss=-22.5535 | train_mmd=0.0108 | test_mmd=0.0111 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=2600 f_loss=-0.4625 g_loss=-22.8687 | train_mmd=0.0116 | test_mmd=0.0121 | test_mmd_cellot=0.0240\n",
      "[CellOT+scGen] epoch=2650 f_loss=1.7272 g_loss=-23.9978 | train_mmd=0.0110 | test_mmd=0.0121 | test_mmd_cellot=0.0247\n",
      "[CellOT+scGen] epoch=2700 f_loss=0.6186 g_loss=-26.6235 | train_mmd=0.0120 | test_mmd=0.0131 | test_mmd_cellot=0.0225\n",
      "[CellOT+scGen] epoch=2750 f_loss=-1.9728 g_loss=-22.6402 | train_mmd=0.0114 | test_mmd=0.0121 | test_mmd_cellot=0.0261\n",
      "[CellOT+scGen] epoch=2800 f_loss=0.6829 g_loss=-23.8012 | train_mmd=0.0090 | test_mmd=0.0099 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2850 f_loss=2.7451 g_loss=-23.4513 | train_mmd=0.0094 | test_mmd=0.0104 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2900 f_loss=-3.3528 g_loss=-23.0386 | train_mmd=0.0089 | test_mmd=0.0096 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=2950 f_loss=1.3063 g_loss=-23.3368 | train_mmd=0.0116 | test_mmd=0.0129 | test_mmd_cellot=0.0281\n",
      "[CellOT+scGen] epoch=3000 f_loss=-1.0064 g_loss=-22.0656 | train_mmd=0.0094 | test_mmd=0.0105 | test_mmd_cellot=0.0242\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0242\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 5 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108/500:  22%|█████████████████████████████████████████████▎                                                                                                                                                                    | 108/500 [00:14<00:51,  7.62it/s, loss=35.6, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 285.690. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-641073.8125 g_loss=750043.8750 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-225476.3281 g_loss=201212.9688 | train_mmd=0.7602 | test_mmd=0.7589 | test_mmd_cellot=0.1906\n",
      "[CellOT+scGen] epoch=100 f_loss=-65638.6641 g_loss=98887.9375 | train_mmd=0.7523 | test_mmd=0.7486 | test_mmd_cellot=0.1886\n",
      "[CellOT+scGen] epoch=150 f_loss=-54138.6016 g_loss=45216.6211 | train_mmd=0.7626 | test_mmd=0.7689 | test_mmd_cellot=0.1900\n",
      "[CellOT+scGen] epoch=200 f_loss=-5015.4238 g_loss=15851.8105 | train_mmd=0.4447 | test_mmd=0.4241 | test_mmd_cellot=0.1413\n",
      "[CellOT+scGen] epoch=250 f_loss=4810.9004 g_loss=7665.3984 | train_mmd=0.0629 | test_mmd=0.0598 | test_mmd_cellot=0.0942\n",
      "[CellOT+scGen] epoch=300 f_loss=-9196.4268 g_loss=5322.7378 | train_mmd=0.2497 | test_mmd=0.2298 | test_mmd_cellot=0.2755\n",
      "[CellOT+scGen] epoch=350 f_loss=402.1396 g_loss=2.5366 | train_mmd=0.0295 | test_mmd=0.0309 | test_mmd_cellot=0.0480\n",
      "[CellOT+scGen] epoch=400 f_loss=10.1643 g_loss=-32.4509 | train_mmd=0.0136 | test_mmd=0.0134 | test_mmd_cellot=0.0111\n",
      "[CellOT+scGen] epoch=450 f_loss=3.2136 g_loss=-46.2889 | train_mmd=0.0112 | test_mmd=0.0110 | test_mmd_cellot=0.0142\n",
      "[CellOT+scGen] epoch=500 f_loss=-0.9048 g_loss=-44.1744 | train_mmd=0.0119 | test_mmd=0.0129 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=550 f_loss=0.7203 g_loss=-42.7540 | train_mmd=0.0085 | test_mmd=0.0090 | test_mmd_cellot=0.0141\n",
      "[CellOT+scGen] epoch=600 f_loss=-2.8048 g_loss=-39.4789 | train_mmd=0.0221 | test_mmd=0.0232 | test_mmd_cellot=0.0263\n",
      "[CellOT+scGen] epoch=650 f_loss=-0.8463 g_loss=-39.0084 | train_mmd=0.0101 | test_mmd=0.0105 | test_mmd_cellot=0.0142\n",
      "[CellOT+scGen] epoch=700 f_loss=-0.6829 g_loss=-37.2885 | train_mmd=0.0093 | test_mmd=0.0101 | test_mmd_cellot=0.0171\n",
      "[CellOT+scGen] epoch=750 f_loss=2.0382 g_loss=-35.5233 | train_mmd=0.0154 | test_mmd=0.0159 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.3290 g_loss=-36.1220 | train_mmd=0.0082 | test_mmd=0.0084 | test_mmd_cellot=0.0154\n",
      "[CellOT+scGen] epoch=850 f_loss=-1.6325 g_loss=-34.3883 | train_mmd=0.0090 | test_mmd=0.0096 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=900 f_loss=-0.3635 g_loss=-36.5793 | train_mmd=0.0123 | test_mmd=0.0117 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=950 f_loss=1.5033 g_loss=-34.3011 | train_mmd=0.0090 | test_mmd=0.0090 | test_mmd_cellot=0.0157\n",
      "[CellOT+scGen] epoch=1000 f_loss=-1.3385 g_loss=-33.6761 | train_mmd=0.0107 | test_mmd=0.0107 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=1050 f_loss=1.6229 g_loss=-32.5777 | train_mmd=0.0074 | test_mmd=0.0078 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=1100 f_loss=1.6235 g_loss=-30.1643 | train_mmd=0.0117 | test_mmd=0.0119 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1150 f_loss=1.1795 g_loss=-32.7688 | train_mmd=0.0087 | test_mmd=0.0089 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=1200 f_loss=-1.7062 g_loss=-32.9971 | train_mmd=0.0071 | test_mmd=0.0074 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=1250 f_loss=2.8054 g_loss=-31.7063 | train_mmd=0.0084 | test_mmd=0.0084 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=1300 f_loss=-1.1023 g_loss=-31.8059 | train_mmd=0.0090 | test_mmd=0.0094 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1350 f_loss=1.0190 g_loss=-31.8173 | train_mmd=0.0096 | test_mmd=0.0102 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1400 f_loss=1.0919 g_loss=-29.4271 | train_mmd=0.0098 | test_mmd=0.0107 | test_mmd_cellot=0.0204\n",
      "[CellOT+scGen] epoch=1450 f_loss=0.6483 g_loss=-32.3412 | train_mmd=0.0119 | test_mmd=0.0129 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1500 f_loss=-0.2840 g_loss=-30.7313 | train_mmd=0.0099 | test_mmd=0.0103 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=1550 f_loss=-0.8308 g_loss=-29.1714 | train_mmd=0.0093 | test_mmd=0.0094 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=1600 f_loss=-0.5317 g_loss=-30.8599 | train_mmd=0.0097 | test_mmd=0.0092 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=1650 f_loss=-0.2724 g_loss=-29.9400 | train_mmd=0.0111 | test_mmd=0.0117 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=1700 f_loss=0.5979 g_loss=-28.0655 | train_mmd=0.0081 | test_mmd=0.0093 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=1750 f_loss=0.9760 g_loss=-30.5428 | train_mmd=0.0099 | test_mmd=0.0099 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=1800 f_loss=0.1894 g_loss=-28.2256 | train_mmd=0.0097 | test_mmd=0.0103 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1850 f_loss=2.8059 g_loss=-28.0079 | train_mmd=0.0101 | test_mmd=0.0109 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=1900 f_loss=1.4210 g_loss=-28.2275 | train_mmd=0.0116 | test_mmd=0.0122 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.5988 g_loss=-31.2796 | train_mmd=0.0086 | test_mmd=0.0093 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2000 f_loss=2.2084 g_loss=-29.8013 | train_mmd=0.0122 | test_mmd=0.0125 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.7043 g_loss=-28.9192 | train_mmd=0.0106 | test_mmd=0.0111 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=2100 f_loss=-1.9147 g_loss=-27.8362 | train_mmd=0.0109 | test_mmd=0.0117 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=2150 f_loss=0.0528 g_loss=-28.0479 | train_mmd=0.0082 | test_mmd=0.0091 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.9751 g_loss=-27.3092 | train_mmd=0.0095 | test_mmd=0.0097 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=2250 f_loss=0.0333 g_loss=-28.9925 | train_mmd=0.0091 | test_mmd=0.0097 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=2300 f_loss=-0.0617 g_loss=-31.5416 | train_mmd=0.0106 | test_mmd=0.0112 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=2350 f_loss=-1.6471 g_loss=-28.8720 | train_mmd=0.0096 | test_mmd=0.0101 | test_mmd_cellot=0.0226\n",
      "[CellOT+scGen] epoch=2400 f_loss=-0.7494 g_loss=-26.5300 | train_mmd=0.0090 | test_mmd=0.0099 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=2450 f_loss=-1.7228 g_loss=-28.7269 | train_mmd=0.0084 | test_mmd=0.0090 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=2500 f_loss=0.3910 g_loss=-27.0620 | train_mmd=0.0085 | test_mmd=0.0087 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2550 f_loss=1.3263 g_loss=-28.1215 | train_mmd=0.0092 | test_mmd=0.0101 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2600 f_loss=-0.4919 g_loss=-27.0001 | train_mmd=0.0081 | test_mmd=0.0084 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.6135 g_loss=-26.8237 | train_mmd=0.0087 | test_mmd=0.0095 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2700 f_loss=0.4025 g_loss=-28.5714 | train_mmd=0.0133 | test_mmd=0.0136 | test_mmd_cellot=0.0239\n",
      "[CellOT+scGen] epoch=2750 f_loss=0.7467 g_loss=-26.0514 | train_mmd=0.0095 | test_mmd=0.0099 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=2800 f_loss=0.3779 g_loss=-27.0863 | train_mmd=0.0099 | test_mmd=0.0109 | test_mmd_cellot=0.0261\n",
      "[CellOT+scGen] epoch=2850 f_loss=0.7152 g_loss=-26.4286 | train_mmd=0.0100 | test_mmd=0.0100 | test_mmd_cellot=0.0216\n",
      "[CellOT+scGen] epoch=2900 f_loss=-0.0973 g_loss=-28.6627 | train_mmd=0.0081 | test_mmd=0.0087 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.6199 g_loss=-30.5785 | train_mmd=0.0113 | test_mmd=0.0118 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=3000 f_loss=-0.0772 g_loss=-25.2446 | train_mmd=0.0075 | test_mmd=0.0080 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0205\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 6 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107/500:  21%|████████████████████████████████████████████▉                                                                                                                                                                     | 107/500 [00:14<00:53,  7.33it/s, loss=36.4, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 295.276. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-1061669.1250 g_loss=1037959.5625 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-16344.3574 g_loss=11232.4746 | train_mmd=0.7771 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=100 f_loss=-15107.6104 g_loss=25150.2812 | train_mmd=0.7698 | test_mmd=0.7649 | test_mmd_cellot=0.1928\n",
      "[CellOT+scGen] epoch=150 f_loss=-26477.6328 g_loss=50780.4727 | train_mmd=0.7013 | test_mmd=0.7096 | test_mmd_cellot=0.1775\n",
      "[CellOT+scGen] epoch=200 f_loss=-1078.7437 g_loss=7255.8584 | train_mmd=0.4130 | test_mmd=0.4115 | test_mmd_cellot=0.1240\n",
      "[CellOT+scGen] epoch=250 f_loss=1093.5552 g_loss=5834.7559 | train_mmd=0.0542 | test_mmd=0.0518 | test_mmd_cellot=0.1142\n",
      "[CellOT+scGen] epoch=300 f_loss=2133.2715 g_loss=-11.7262 | train_mmd=0.0609 | test_mmd=0.0622 | test_mmd_cellot=0.1502\n",
      "[CellOT+scGen] epoch=350 f_loss=192.6531 g_loss=88.0263 | train_mmd=0.0371 | test_mmd=0.0389 | test_mmd_cellot=0.0499\n",
      "[CellOT+scGen] epoch=400 f_loss=5.3397 g_loss=-52.6584 | train_mmd=0.0189 | test_mmd=0.0198 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=450 f_loss=5.5335 g_loss=-42.9918 | train_mmd=0.0163 | test_mmd=0.0186 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=500 f_loss=-0.3327 g_loss=-41.8909 | train_mmd=0.0107 | test_mmd=0.0106 | test_mmd_cellot=0.0154\n",
      "[CellOT+scGen] epoch=550 f_loss=-0.8790 g_loss=-39.6463 | train_mmd=0.0110 | test_mmd=0.0122 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=600 f_loss=-0.6209 g_loss=-38.7667 | train_mmd=0.0072 | test_mmd=0.0086 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=650 f_loss=-0.2594 g_loss=-37.9510 | train_mmd=0.0116 | test_mmd=0.0118 | test_mmd_cellot=0.0170\n",
      "[CellOT+scGen] epoch=700 f_loss=1.2996 g_loss=-35.0857 | train_mmd=0.0120 | test_mmd=0.0133 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=750 f_loss=-1.0052 g_loss=-33.5108 | train_mmd=0.0118 | test_mmd=0.0121 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.6038 g_loss=-29.2464 | train_mmd=0.0103 | test_mmd=0.0107 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=850 f_loss=1.3807 g_loss=-31.2535 | train_mmd=0.0082 | test_mmd=0.0099 | test_mmd_cellot=0.0199\n",
      "[CellOT+scGen] epoch=900 f_loss=2.7038 g_loss=-27.0415 | train_mmd=0.0146 | test_mmd=0.0147 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=950 f_loss=-1.3631 g_loss=-28.5307 | train_mmd=0.0103 | test_mmd=0.0116 | test_mmd_cellot=0.0207\n",
      "[CellOT+scGen] epoch=1000 f_loss=-1.4581 g_loss=-27.6429 | train_mmd=0.0128 | test_mmd=0.0136 | test_mmd_cellot=0.0259\n",
      "[CellOT+scGen] epoch=1050 f_loss=2.0059 g_loss=-26.9345 | train_mmd=0.0093 | test_mmd=0.0098 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=1100 f_loss=-1.2898 g_loss=-24.8898 | train_mmd=0.0094 | test_mmd=0.0112 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=1150 f_loss=1.1201 g_loss=-26.7069 | train_mmd=0.0101 | test_mmd=0.0112 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=1200 f_loss=-0.1352 g_loss=-24.9198 | train_mmd=0.0135 | test_mmd=0.0153 | test_mmd_cellot=0.0272\n",
      "[CellOT+scGen] epoch=1250 f_loss=-0.1413 g_loss=-25.3035 | train_mmd=0.0106 | test_mmd=0.0120 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=1300 f_loss=1.4165 g_loss=-23.8512 | train_mmd=0.0099 | test_mmd=0.0109 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=1350 f_loss=1.2430 g_loss=-24.4037 | train_mmd=0.0100 | test_mmd=0.0109 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1400 f_loss=-4.3794 g_loss=-24.3493 | train_mmd=0.0099 | test_mmd=0.0106 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=1450 f_loss=-1.1323 g_loss=-24.0412 | train_mmd=0.0113 | test_mmd=0.0114 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=1500 f_loss=-1.4048 g_loss=-24.8716 | train_mmd=0.0083 | test_mmd=0.0091 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1550 f_loss=-1.2176 g_loss=-22.4432 | train_mmd=0.0124 | test_mmd=0.0124 | test_mmd_cellot=0.0247\n",
      "[CellOT+scGen] epoch=1600 f_loss=3.5899 g_loss=-24.2663 | train_mmd=0.0093 | test_mmd=0.0096 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1650 f_loss=-3.2068 g_loss=-22.3066 | train_mmd=0.0112 | test_mmd=0.0119 | test_mmd_cellot=0.0262\n",
      "[CellOT+scGen] epoch=1700 f_loss=-0.8813 g_loss=-20.5000 | train_mmd=0.0123 | test_mmd=0.0137 | test_mmd_cellot=0.0282\n",
      "[CellOT+scGen] epoch=1750 f_loss=-3.7327 g_loss=-22.9341 | train_mmd=0.0148 | test_mmd=0.0167 | test_mmd_cellot=0.0298\n",
      "[CellOT+scGen] epoch=1800 f_loss=-1.8591 g_loss=-23.0682 | train_mmd=0.0111 | test_mmd=0.0121 | test_mmd_cellot=0.0264\n",
      "[CellOT+scGen] epoch=1850 f_loss=3.0775 g_loss=-23.2397 | train_mmd=0.0115 | test_mmd=0.0121 | test_mmd_cellot=0.0257\n",
      "[CellOT+scGen] epoch=1900 f_loss=3.6407 g_loss=-21.4785 | train_mmd=0.0117 | test_mmd=0.0118 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=1950 f_loss=0.0077 g_loss=-20.8435 | train_mmd=0.0124 | test_mmd=0.0137 | test_mmd_cellot=0.0292\n",
      "[CellOT+scGen] epoch=2000 f_loss=-2.6714 g_loss=-22.7330 | train_mmd=0.0176 | test_mmd=0.0190 | test_mmd_cellot=0.0351\n",
      "[CellOT+scGen] epoch=2050 f_loss=-1.6386 g_loss=-24.0807 | train_mmd=0.0122 | test_mmd=0.0141 | test_mmd_cellot=0.0274\n",
      "[CellOT+scGen] epoch=2100 f_loss=1.4514 g_loss=-22.3167 | train_mmd=0.0097 | test_mmd=0.0107 | test_mmd_cellot=0.0259\n",
      "[CellOT+scGen] epoch=2150 f_loss=-0.5597 g_loss=-19.9016 | train_mmd=0.0113 | test_mmd=0.0127 | test_mmd_cellot=0.0308\n",
      "[CellOT+scGen] epoch=2200 f_loss=0.0534 g_loss=-20.5008 | train_mmd=0.0112 | test_mmd=0.0117 | test_mmd_cellot=0.0258\n",
      "[CellOT+scGen] epoch=2250 f_loss=-2.0749 g_loss=-21.4470 | train_mmd=0.0102 | test_mmd=0.0108 | test_mmd_cellot=0.0243\n",
      "[CellOT+scGen] epoch=2300 f_loss=-2.5346 g_loss=-21.0309 | train_mmd=0.0101 | test_mmd=0.0106 | test_mmd_cellot=0.0254\n",
      "[CellOT+scGen] epoch=2350 f_loss=1.2337 g_loss=-20.9877 | train_mmd=0.0102 | test_mmd=0.0107 | test_mmd_cellot=0.0260\n",
      "[CellOT+scGen] epoch=2400 f_loss=-0.6858 g_loss=-19.9505 | train_mmd=0.0126 | test_mmd=0.0123 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.1772 g_loss=-20.6845 | train_mmd=0.0089 | test_mmd=0.0101 | test_mmd_cellot=0.0262\n",
      "[CellOT+scGen] epoch=2500 f_loss=-1.2849 g_loss=-20.1696 | train_mmd=0.0115 | test_mmd=0.0130 | test_mmd_cellot=0.0292\n",
      "[CellOT+scGen] epoch=2550 f_loss=-1.2610 g_loss=-18.8216 | train_mmd=0.0113 | test_mmd=0.0124 | test_mmd_cellot=0.0281\n",
      "[CellOT+scGen] epoch=2600 f_loss=1.6777 g_loss=-19.8315 | train_mmd=0.0092 | test_mmd=0.0099 | test_mmd_cellot=0.0268\n",
      "[CellOT+scGen] epoch=2650 f_loss=-3.6288 g_loss=-19.2506 | train_mmd=0.0088 | test_mmd=0.0100 | test_mmd_cellot=0.0254\n",
      "[CellOT+scGen] epoch=2700 f_loss=-3.6247 g_loss=-21.1918 | train_mmd=0.0127 | test_mmd=0.0145 | test_mmd_cellot=0.0299\n",
      "[CellOT+scGen] epoch=2750 f_loss=-2.1250 g_loss=-18.8158 | train_mmd=0.0094 | test_mmd=0.0106 | test_mmd_cellot=0.0267\n",
      "[CellOT+scGen] epoch=2800 f_loss=-0.6685 g_loss=-18.3029 | train_mmd=0.0099 | test_mmd=0.0107 | test_mmd_cellot=0.0273\n",
      "[CellOT+scGen] epoch=2850 f_loss=0.8378 g_loss=-19.3813 | train_mmd=0.0098 | test_mmd=0.0107 | test_mmd_cellot=0.0272\n",
      "[CellOT+scGen] epoch=2900 f_loss=-2.6499 g_loss=-20.7614 | train_mmd=0.0110 | test_mmd=0.0129 | test_mmd_cellot=0.0291\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.1778 g_loss=-20.8700 | train_mmd=0.0107 | test_mmd=0.0114 | test_mmd_cellot=0.0256\n",
      "[CellOT+scGen] epoch=3000 f_loss=0.2040 g_loss=-18.4801 | train_mmd=0.0116 | test_mmd=0.0125 | test_mmd_cellot=0.0269\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0269\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 7 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107/500:  21%|█████████████████████████████████████████████▎                                                                                                                                                                      | 107/500 [00:14<00:52,  7.48it/s, loss=36, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 282.174. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-724772.0000 g_loss=774096.7500 | train_mmd=0.7779 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-4231.1245 g_loss=14532.1768 | train_mmd=0.7699 | test_mmd=0.7687 | test_mmd_cellot=0.1932\n",
      "[CellOT+scGen] epoch=100 f_loss=-219248.5625 g_loss=210865.8125 | train_mmd=0.7665 | test_mmd=0.7683 | test_mmd_cellot=0.1931\n",
      "[CellOT+scGen] epoch=150 f_loss=-7315.7329 g_loss=13450.3105 | train_mmd=0.6445 | test_mmd=0.6460 | test_mmd_cellot=0.1667\n",
      "[CellOT+scGen] epoch=200 f_loss=-9120.8701 g_loss=17737.4355 | train_mmd=0.5765 | test_mmd=0.5684 | test_mmd_cellot=0.1548\n",
      "[CellOT+scGen] epoch=250 f_loss=3957.5774 g_loss=10043.6309 | train_mmd=0.0922 | test_mmd=0.0873 | test_mmd_cellot=0.1299\n",
      "[CellOT+scGen] epoch=300 f_loss=2158.0781 g_loss=381.0544 | train_mmd=0.0395 | test_mmd=0.0397 | test_mmd_cellot=0.1419\n",
      "[CellOT+scGen] epoch=350 f_loss=472.2874 g_loss=-20.5999 | train_mmd=0.0603 | test_mmd=0.0602 | test_mmd_cellot=0.1272\n",
      "[CellOT+scGen] epoch=400 f_loss=14.2565 g_loss=-47.6855 | train_mmd=0.0129 | test_mmd=0.0131 | test_mmd_cellot=0.0110\n",
      "[CellOT+scGen] epoch=450 f_loss=-0.8044 g_loss=-42.7891 | train_mmd=0.0115 | test_mmd=0.0120 | test_mmd_cellot=0.0134\n",
      "[CellOT+scGen] epoch=500 f_loss=-0.3081 g_loss=-44.5968 | train_mmd=0.0119 | test_mmd=0.0118 | test_mmd_cellot=0.0135\n",
      "[CellOT+scGen] epoch=550 f_loss=-0.5630 g_loss=-41.3776 | train_mmd=0.0126 | test_mmd=0.0122 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=600 f_loss=-1.2746 g_loss=-41.9404 | train_mmd=0.0093 | test_mmd=0.0093 | test_mmd_cellot=0.0128\n",
      "[CellOT+scGen] epoch=650 f_loss=0.6201 g_loss=-38.8471 | train_mmd=0.0101 | test_mmd=0.0104 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=700 f_loss=-2.2387 g_loss=-38.9736 | train_mmd=0.0113 | test_mmd=0.0122 | test_mmd_cellot=0.0159\n",
      "[CellOT+scGen] epoch=750 f_loss=-1.2495 g_loss=-36.5486 | train_mmd=0.0081 | test_mmd=0.0087 | test_mmd_cellot=0.0145\n",
      "[CellOT+scGen] epoch=800 f_loss=0.4795 g_loss=-35.7274 | train_mmd=0.0110 | test_mmd=0.0112 | test_mmd_cellot=0.0181\n",
      "[CellOT+scGen] epoch=850 f_loss=0.4035 g_loss=-34.1731 | train_mmd=0.0113 | test_mmd=0.0119 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=900 f_loss=-1.8357 g_loss=-32.6119 | train_mmd=0.0115 | test_mmd=0.0124 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=950 f_loss=-0.3168 g_loss=-32.7817 | train_mmd=0.0095 | test_mmd=0.0100 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1000 f_loss=0.0888 g_loss=-28.3173 | train_mmd=0.0088 | test_mmd=0.0086 | test_mmd_cellot=0.0155\n",
      "[CellOT+scGen] epoch=1050 f_loss=-1.2829 g_loss=-30.4672 | train_mmd=0.0119 | test_mmd=0.0127 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1100 f_loss=-2.1395 g_loss=-30.1457 | train_mmd=0.0102 | test_mmd=0.0108 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=1150 f_loss=-2.4551 g_loss=-30.6931 | train_mmd=0.0085 | test_mmd=0.0090 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=1200 f_loss=-1.5834 g_loss=-27.1452 | train_mmd=0.0085 | test_mmd=0.0091 | test_mmd_cellot=0.0179\n",
      "[CellOT+scGen] epoch=1250 f_loss=0.3668 g_loss=-28.4106 | train_mmd=0.0083 | test_mmd=0.0083 | test_mmd_cellot=0.0153\n",
      "[CellOT+scGen] epoch=1300 f_loss=-0.1211 g_loss=-29.3245 | train_mmd=0.0105 | test_mmd=0.0106 | test_mmd_cellot=0.0198\n",
      "[CellOT+scGen] epoch=1350 f_loss=-1.6657 g_loss=-23.1819 | train_mmd=0.0096 | test_mmd=0.0101 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=1400 f_loss=1.0186 g_loss=-26.2035 | train_mmd=0.0114 | test_mmd=0.0119 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=1450 f_loss=-1.9822 g_loss=-27.8844 | train_mmd=0.0114 | test_mmd=0.0133 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=1500 f_loss=-1.8658 g_loss=-24.7473 | train_mmd=0.0106 | test_mmd=0.0118 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=1550 f_loss=-0.8864 g_loss=-25.0252 | train_mmd=0.0085 | test_mmd=0.0098 | test_mmd_cellot=0.0191\n",
      "[CellOT+scGen] epoch=1600 f_loss=1.9804 g_loss=-26.2505 | train_mmd=0.0096 | test_mmd=0.0099 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1650 f_loss=-0.9114 g_loss=-24.9574 | train_mmd=0.0117 | test_mmd=0.0126 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=1700 f_loss=-1.2756 g_loss=-26.4739 | train_mmd=0.0081 | test_mmd=0.0086 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=1750 f_loss=-1.1732 g_loss=-25.1092 | train_mmd=0.0083 | test_mmd=0.0090 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=1800 f_loss=-0.2893 g_loss=-24.2713 | train_mmd=0.0120 | test_mmd=0.0124 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] epoch=1850 f_loss=-0.5739 g_loss=-26.0372 | train_mmd=0.0120 | test_mmd=0.0111 | test_mmd_cellot=0.0192\n",
      "[CellOT+scGen] epoch=1900 f_loss=-1.9718 g_loss=-21.0028 | train_mmd=0.0091 | test_mmd=0.0095 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1950 f_loss=-1.0567 g_loss=-25.1355 | train_mmd=0.0093 | test_mmd=0.0107 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=2000 f_loss=0.3453 g_loss=-24.6822 | train_mmd=0.0104 | test_mmd=0.0105 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=2050 f_loss=-4.6479 g_loss=-23.7002 | train_mmd=0.0089 | test_mmd=0.0099 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=2100 f_loss=-1.1749 g_loss=-21.8834 | train_mmd=0.0100 | test_mmd=0.0111 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] epoch=2150 f_loss=-3.4688 g_loss=-24.9237 | train_mmd=0.0088 | test_mmd=0.0087 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=2200 f_loss=1.1838 g_loss=-22.8698 | train_mmd=0.0086 | test_mmd=0.0094 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2250 f_loss=-1.2422 g_loss=-23.0572 | train_mmd=0.0115 | test_mmd=0.0128 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=2300 f_loss=-0.2196 g_loss=-22.7669 | train_mmd=0.0107 | test_mmd=0.0115 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=2350 f_loss=-0.3920 g_loss=-20.2790 | train_mmd=0.0097 | test_mmd=0.0107 | test_mmd_cellot=0.0242\n",
      "[CellOT+scGen] epoch=2400 f_loss=0.3565 g_loss=-24.0653 | train_mmd=0.0096 | test_mmd=0.0108 | test_mmd_cellot=0.0221\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.2868 g_loss=-21.2744 | train_mmd=0.0096 | test_mmd=0.0099 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2500 f_loss=-1.0950 g_loss=-23.1775 | train_mmd=0.0108 | test_mmd=0.0113 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2550 f_loss=-3.0078 g_loss=-24.5674 | train_mmd=0.0103 | test_mmd=0.0106 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=2600 f_loss=0.0272 g_loss=-23.0863 | train_mmd=0.0075 | test_mmd=0.0080 | test_mmd_cellot=0.0178\n",
      "[CellOT+scGen] epoch=2650 f_loss=0.8365 g_loss=-23.2461 | train_mmd=0.0111 | test_mmd=0.0122 | test_mmd_cellot=0.0254\n",
      "[CellOT+scGen] epoch=2700 f_loss=-0.5319 g_loss=-21.1309 | train_mmd=0.0075 | test_mmd=0.0086 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=2750 f_loss=1.2441 g_loss=-25.4907 | train_mmd=0.0078 | test_mmd=0.0084 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=2800 f_loss=-1.4178 g_loss=-20.8859 | train_mmd=0.0091 | test_mmd=0.0092 | test_mmd_cellot=0.0201\n",
      "[CellOT+scGen] epoch=2850 f_loss=0.9056 g_loss=-22.3565 | train_mmd=0.0078 | test_mmd=0.0087 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2900 f_loss=1.3146 g_loss=-22.5408 | train_mmd=0.0083 | test_mmd=0.0088 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=2950 f_loss=-1.1159 g_loss=-22.3400 | train_mmd=0.0105 | test_mmd=0.0112 | test_mmd_cellot=0.0229\n",
      "[CellOT+scGen] epoch=3000 f_loss=0.3062 g_loss=-22.3388 | train_mmd=0.0088 | test_mmd=0.0089 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0205\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 8 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 108/500:  22%|█████████████████████████████████████████████▎                                                                                                                                                                    | 108/500 [00:14<00:51,  7.66it/s, loss=35.7, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 286.794. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-585809.5625 g_loss=692317.8750 | train_mmd=0.7747 | test_mmd=0.7693 | test_mmd_cellot=0.1934\n",
      "[CellOT+scGen] epoch=50 f_loss=-144475.1250 g_loss=146564.6875 | train_mmd=0.7605 | test_mmd=0.7536 | test_mmd_cellot=0.1897\n",
      "[CellOT+scGen] epoch=100 f_loss=-17818.6035 g_loss=18959.5488 | train_mmd=0.7750 | test_mmd=0.7684 | test_mmd_cellot=0.1935\n",
      "[CellOT+scGen] epoch=150 f_loss=-43916.3828 g_loss=35844.1992 | train_mmd=0.8083 | test_mmd=0.7968 | test_mmd_cellot=0.1978\n",
      "[CellOT+scGen] epoch=200 f_loss=-7721.1016 g_loss=14379.2578 | train_mmd=0.3961 | test_mmd=0.3801 | test_mmd_cellot=0.1080\n",
      "[CellOT+scGen] epoch=250 f_loss=2524.1060 g_loss=32916.3125 | train_mmd=0.1404 | test_mmd=0.1537 | test_mmd_cellot=0.1760\n",
      "[CellOT+scGen] epoch=300 f_loss=431.3757 g_loss=276.3498 | train_mmd=0.0298 | test_mmd=0.0325 | test_mmd_cellot=0.1474\n",
      "[CellOT+scGen] epoch=350 f_loss=1987.1475 g_loss=-9.7673 | train_mmd=0.0825 | test_mmd=0.0803 | test_mmd_cellot=0.1126\n",
      "[CellOT+scGen] epoch=400 f_loss=209.2651 g_loss=295.6829 | train_mmd=0.0618 | test_mmd=0.0659 | test_mmd_cellot=0.0433\n",
      "[CellOT+scGen] epoch=450 f_loss=61.8779 g_loss=-51.8375 | train_mmd=0.0123 | test_mmd=0.0132 | test_mmd_cellot=0.0118\n",
      "[CellOT+scGen] epoch=500 f_loss=9.0166 g_loss=-48.2475 | train_mmd=0.0127 | test_mmd=0.0131 | test_mmd_cellot=0.0135\n",
      "[CellOT+scGen] epoch=550 f_loss=4.0565 g_loss=-36.7283 | train_mmd=0.0136 | test_mmd=0.0146 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=600 f_loss=0.0971 g_loss=-42.9182 | train_mmd=0.0088 | test_mmd=0.0100 | test_mmd_cellot=0.0130\n",
      "[CellOT+scGen] epoch=650 f_loss=0.9826 g_loss=-38.3900 | train_mmd=0.0090 | test_mmd=0.0091 | test_mmd_cellot=0.0146\n",
      "[CellOT+scGen] epoch=700 f_loss=-4.2920 g_loss=-40.7739 | train_mmd=0.0119 | test_mmd=0.0137 | test_mmd_cellot=0.0163\n",
      "[CellOT+scGen] epoch=750 f_loss=-0.3790 g_loss=-39.8167 | train_mmd=0.0121 | test_mmd=0.0127 | test_mmd_cellot=0.0166\n",
      "[CellOT+scGen] epoch=800 f_loss=-0.3004 g_loss=-38.2496 | train_mmd=0.0107 | test_mmd=0.0122 | test_mmd_cellot=0.0165\n",
      "[CellOT+scGen] epoch=850 f_loss=0.5391 g_loss=-37.2301 | train_mmd=0.0099 | test_mmd=0.0116 | test_mmd_cellot=0.0168\n",
      "[CellOT+scGen] epoch=900 f_loss=-1.2588 g_loss=-30.8195 | train_mmd=0.0121 | test_mmd=0.0135 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=950 f_loss=1.8007 g_loss=-34.4210 | train_mmd=0.0123 | test_mmd=0.0129 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=1000 f_loss=-1.0595 g_loss=-33.6917 | train_mmd=0.0119 | test_mmd=0.0134 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1050 f_loss=4.0302 g_loss=-31.0415 | train_mmd=0.0080 | test_mmd=0.0086 | test_mmd_cellot=0.0162\n",
      "[CellOT+scGen] epoch=1100 f_loss=-2.6884 g_loss=-31.2263 | train_mmd=0.0102 | test_mmd=0.0119 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1150 f_loss=-2.8539 g_loss=-29.2796 | train_mmd=0.0125 | test_mmd=0.0139 | test_mmd_cellot=0.0220\n",
      "[CellOT+scGen] epoch=1200 f_loss=-2.1167 g_loss=-33.8747 | train_mmd=0.0153 | test_mmd=0.0175 | test_mmd_cellot=0.0260\n",
      "[CellOT+scGen] epoch=1250 f_loss=1.3297 g_loss=-29.8727 | train_mmd=0.0090 | test_mmd=0.0105 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=1300 f_loss=-1.7694 g_loss=-30.5655 | train_mmd=0.0105 | test_mmd=0.0117 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=1350 f_loss=-3.4077 g_loss=-28.2675 | train_mmd=0.0096 | test_mmd=0.0108 | test_mmd_cellot=0.0200\n",
      "[CellOT+scGen] epoch=1400 f_loss=0.2679 g_loss=-30.5342 | train_mmd=0.0140 | test_mmd=0.0153 | test_mmd_cellot=0.0243\n",
      "[CellOT+scGen] epoch=1450 f_loss=-1.8162 g_loss=-29.8476 | train_mmd=0.0098 | test_mmd=0.0112 | test_mmd_cellot=0.0218\n",
      "[CellOT+scGen] epoch=1500 f_loss=2.0710 g_loss=-26.1749 | train_mmd=0.0100 | test_mmd=0.0116 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=1550 f_loss=0.4140 g_loss=-27.3692 | train_mmd=0.0112 | test_mmd=0.0117 | test_mmd_cellot=0.0185\n",
      "[CellOT+scGen] epoch=1600 f_loss=2.9028 g_loss=-29.7020 | train_mmd=0.0112 | test_mmd=0.0118 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=1650 f_loss=-0.0492 g_loss=-29.1555 | train_mmd=0.0107 | test_mmd=0.0116 | test_mmd_cellot=0.0217\n",
      "[CellOT+scGen] epoch=1700 f_loss=3.6897 g_loss=-29.6064 | train_mmd=0.0120 | test_mmd=0.0132 | test_mmd_cellot=0.0235\n",
      "[CellOT+scGen] epoch=1750 f_loss=0.2565 g_loss=-25.4960 | train_mmd=0.0131 | test_mmd=0.0138 | test_mmd_cellot=0.0251\n",
      "[CellOT+scGen] epoch=1800 f_loss=0.0700 g_loss=-27.7076 | train_mmd=0.0114 | test_mmd=0.0131 | test_mmd_cellot=0.0245\n",
      "[CellOT+scGen] epoch=1850 f_loss=1.4651 g_loss=-26.6204 | train_mmd=0.0123 | test_mmd=0.0135 | test_mmd_cellot=0.0249\n",
      "[CellOT+scGen] epoch=1900 f_loss=-0.2164 g_loss=-25.0636 | train_mmd=0.0115 | test_mmd=0.0124 | test_mmd_cellot=0.0240\n",
      "[CellOT+scGen] epoch=1950 f_loss=2.3978 g_loss=-24.3673 | train_mmd=0.0082 | test_mmd=0.0091 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=2000 f_loss=0.6781 g_loss=-27.6322 | train_mmd=0.0117 | test_mmd=0.0129 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=2050 f_loss=0.5510 g_loss=-26.0028 | train_mmd=0.0107 | test_mmd=0.0111 | test_mmd_cellot=0.0240\n",
      "[CellOT+scGen] epoch=2100 f_loss=0.2937 g_loss=-26.0305 | train_mmd=0.0127 | test_mmd=0.0139 | test_mmd_cellot=0.0259\n",
      "[CellOT+scGen] epoch=2150 f_loss=1.7843 g_loss=-24.6340 | train_mmd=0.0130 | test_mmd=0.0149 | test_mmd_cellot=0.0257\n",
      "[CellOT+scGen] epoch=2200 f_loss=-1.4015 g_loss=-26.5553 | train_mmd=0.0129 | test_mmd=0.0145 | test_mmd_cellot=0.0285\n",
      "[CellOT+scGen] epoch=2250 f_loss=-1.0234 g_loss=-25.2038 | train_mmd=0.0098 | test_mmd=0.0110 | test_mmd_cellot=0.0202\n",
      "[CellOT+scGen] epoch=2300 f_loss=-0.5514 g_loss=-26.9601 | train_mmd=0.0115 | test_mmd=0.0126 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=2350 f_loss=-2.4686 g_loss=-23.3899 | train_mmd=0.0134 | test_mmd=0.0153 | test_mmd_cellot=0.0252\n",
      "[CellOT+scGen] epoch=2400 f_loss=1.5050 g_loss=-26.3444 | train_mmd=0.0118 | test_mmd=0.0130 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=2450 f_loss=0.7041 g_loss=-24.6270 | train_mmd=0.0137 | test_mmd=0.0161 | test_mmd_cellot=0.0256\n",
      "[CellOT+scGen] epoch=2500 f_loss=0.2255 g_loss=-22.4741 | train_mmd=0.0112 | test_mmd=0.0124 | test_mmd_cellot=0.0242\n",
      "[CellOT+scGen] epoch=2550 f_loss=1.2388 g_loss=-24.9729 | train_mmd=0.0134 | test_mmd=0.0144 | test_mmd_cellot=0.0260\n",
      "[CellOT+scGen] epoch=2600 f_loss=0.5826 g_loss=-21.8169 | train_mmd=0.0092 | test_mmd=0.0103 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.2406 g_loss=-22.2526 | train_mmd=0.0083 | test_mmd=0.0088 | test_mmd_cellot=0.0205\n",
      "[CellOT+scGen] epoch=2700 f_loss=-3.5741 g_loss=-20.3131 | train_mmd=0.0142 | test_mmd=0.0148 | test_mmd_cellot=0.0242\n",
      "[CellOT+scGen] epoch=2750 f_loss=-0.5405 g_loss=-23.4870 | train_mmd=0.0116 | test_mmd=0.0115 | test_mmd_cellot=0.0228\n",
      "[CellOT+scGen] epoch=2800 f_loss=-0.1183 g_loss=-22.9492 | train_mmd=0.0094 | test_mmd=0.0103 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=2850 f_loss=-2.7257 g_loss=-23.4982 | train_mmd=0.0108 | test_mmd=0.0121 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=2900 f_loss=0.4474 g_loss=-21.2310 | train_mmd=0.0125 | test_mmd=0.0138 | test_mmd_cellot=0.0257\n",
      "[CellOT+scGen] epoch=2950 f_loss=0.1082 g_loss=-22.3558 | train_mmd=0.0126 | test_mmd=0.0141 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=3000 f_loss=-0.8717 g_loss=-21.4351 | train_mmd=0.0119 | test_mmd=0.0127 | test_mmd_cellot=0.0227\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0227\n",
      "VERS torch=1.13.1+cu117 (CellOT), device=cuda\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "**************** Run: 9 ****************\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "GPU available: True (cuda), used: True\n",
      "TPU available: False, using: 0 TPU cores\n",
      "IPU available: False, using: 0 IPUs\n",
      "HPU available: False, using: 0 HPUs\n",
      "LOCAL_RANK: 0 - CUDA_VISIBLE_DEVICES: [0,1]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 107/500:  21%|████████████████████████████████████████████▉                                                                                                                                                                     | 107/500 [00:13<00:49,  7.90it/s, loss=35.4, v_num=1]\n",
      "Monitored metric elbo_validation did not improve in the last 100 records. Best score: 279.837. Signaling Trainer to stop.\n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n",
      "\u001b[34mINFO    \u001b[0m Input AnnData not setup with scvi-tools. attempting to transfer AnnData setup                             \n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/u/jrp5td/here/miniconda3/envs/scgen-env/lib/python3.9/site-packages/anndata/_core/anndata.py:121: ImplicitModificationWarning: Transforming to str index.\n",
      "  warnings.warn(\"Transforming to str index.\", ImplicitModificationWarning)\n",
      "[CellOT+scGen] epoch=0 f_loss=-565391.7500 g_loss=794418.3125 | train_mmd=0.7776 | test_mmd=0.7750 | test_mmd_cellot=0.1946\n",
      "[CellOT+scGen] epoch=50 f_loss=-146001.6875 g_loss=145786.9219 | train_mmd=0.6075 | test_mmd=0.6104 | test_mmd_cellot=0.1555\n",
      "[CellOT+scGen] epoch=100 f_loss=-81192.5781 g_loss=100275.7969 | train_mmd=0.7245 | test_mmd=0.7314 | test_mmd_cellot=0.1847\n",
      "[CellOT+scGen] epoch=150 f_loss=-45712.7812 g_loss=89077.0625 | train_mmd=0.7349 | test_mmd=0.7390 | test_mmd_cellot=0.1845\n",
      "[CellOT+scGen] epoch=200 f_loss=1899.7690 g_loss=6165.4072 | train_mmd=0.3251 | test_mmd=0.3177 | test_mmd_cellot=0.0975\n",
      "[CellOT+scGen] epoch=250 f_loss=-3070.1182 g_loss=5362.3442 | train_mmd=0.0969 | test_mmd=0.0954 | test_mmd_cellot=0.1006\n",
      "[CellOT+scGen] epoch=300 f_loss=-7375.2349 g_loss=920.1874 | train_mmd=0.0342 | test_mmd=0.0350 | test_mmd_cellot=0.1648\n",
      "[CellOT+scGen] epoch=350 f_loss=1456.0345 g_loss=-26.1551 | train_mmd=0.0896 | test_mmd=0.0944 | test_mmd_cellot=0.1948\n",
      "[CellOT+scGen] epoch=400 f_loss=316.8804 g_loss=-48.6119 | train_mmd=0.0634 | test_mmd=0.0642 | test_mmd_cellot=0.0489\n",
      "[CellOT+scGen] epoch=450 f_loss=15.2871 g_loss=-56.3135 | train_mmd=0.0233 | test_mmd=0.0230 | test_mmd_cellot=0.0153\n",
      "[CellOT+scGen] epoch=500 f_loss=4.6201 g_loss=-44.4003 | train_mmd=0.0139 | test_mmd=0.0140 | test_mmd_cellot=0.0161\n",
      "[CellOT+scGen] epoch=550 f_loss=-5.1810 g_loss=-45.4863 | train_mmd=0.0182 | test_mmd=0.0177 | test_mmd_cellot=0.0174\n",
      "[CellOT+scGen] epoch=600 f_loss=-8.6191 g_loss=-36.9035 | train_mmd=0.0162 | test_mmd=0.0166 | test_mmd_cellot=0.0183\n",
      "[CellOT+scGen] epoch=650 f_loss=2.4675 g_loss=-40.7812 | train_mmd=0.0094 | test_mmd=0.0095 | test_mmd_cellot=0.0173\n",
      "[CellOT+scGen] epoch=700 f_loss=2.1485 g_loss=-37.7320 | train_mmd=0.0114 | test_mmd=0.0120 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=750 f_loss=0.7964 g_loss=-39.5619 | train_mmd=0.0116 | test_mmd=0.0111 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=800 f_loss=1.2657 g_loss=-37.1052 | train_mmd=0.0113 | test_mmd=0.0127 | test_mmd_cellot=0.0187\n",
      "[CellOT+scGen] epoch=850 f_loss=0.1426 g_loss=-36.0664 | train_mmd=0.0082 | test_mmd=0.0088 | test_mmd_cellot=0.0165\n",
      "[CellOT+scGen] epoch=900 f_loss=1.1129 g_loss=-36.2204 | train_mmd=0.0138 | test_mmd=0.0135 | test_mmd_cellot=0.0239\n",
      "[CellOT+scGen] epoch=950 f_loss=-0.5592 g_loss=-37.5500 | train_mmd=0.0127 | test_mmd=0.0140 | test_mmd_cellot=0.0215\n",
      "[CellOT+scGen] epoch=1000 f_loss=-1.2483 g_loss=-33.6303 | train_mmd=0.0094 | test_mmd=0.0103 | test_mmd_cellot=0.0172\n",
      "[CellOT+scGen] epoch=1050 f_loss=-1.6067 g_loss=-34.4196 | train_mmd=0.0130 | test_mmd=0.0143 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=1100 f_loss=1.3669 g_loss=-31.5293 | train_mmd=0.0094 | test_mmd=0.0093 | test_mmd_cellot=0.0194\n",
      "[CellOT+scGen] epoch=1150 f_loss=-1.2335 g_loss=-31.2526 | train_mmd=0.0131 | test_mmd=0.0148 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=1200 f_loss=-1.2272 g_loss=-31.6333 | train_mmd=0.0094 | test_mmd=0.0098 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=1250 f_loss=-2.5025 g_loss=-34.0363 | train_mmd=0.0098 | test_mmd=0.0108 | test_mmd_cellot=0.0188\n",
      "[CellOT+scGen] epoch=1300 f_loss=1.2478 g_loss=-29.6604 | train_mmd=0.0085 | test_mmd=0.0091 | test_mmd_cellot=0.0182\n",
      "[CellOT+scGen] epoch=1350 f_loss=-0.7961 g_loss=-30.0278 | train_mmd=0.0099 | test_mmd=0.0103 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1400 f_loss=0.4204 g_loss=-31.4234 | train_mmd=0.0086 | test_mmd=0.0091 | test_mmd_cellot=0.0193\n",
      "[CellOT+scGen] epoch=1450 f_loss=-1.3245 g_loss=-30.6227 | train_mmd=0.0102 | test_mmd=0.0107 | test_mmd_cellot=0.0206\n",
      "[CellOT+scGen] epoch=1500 f_loss=0.4054 g_loss=-29.5550 | train_mmd=0.0086 | test_mmd=0.0096 | test_mmd_cellot=0.0212\n",
      "[CellOT+scGen] epoch=1550 f_loss=0.4182 g_loss=-27.7285 | train_mmd=0.0092 | test_mmd=0.0101 | test_mmd_cellot=0.0211\n",
      "[CellOT+scGen] epoch=1600 f_loss=-1.0716 g_loss=-32.0733 | train_mmd=0.0082 | test_mmd=0.0091 | test_mmd_cellot=0.0190\n",
      "[CellOT+scGen] epoch=1650 f_loss=-0.6151 g_loss=-28.3593 | train_mmd=0.0087 | test_mmd=0.0095 | test_mmd_cellot=0.0197\n",
      "[CellOT+scGen] epoch=1700 f_loss=-2.1499 g_loss=-29.0599 | train_mmd=0.0075 | test_mmd=0.0085 | test_mmd_cellot=0.0195\n",
      "[CellOT+scGen] epoch=1750 f_loss=-0.6477 g_loss=-26.4348 | train_mmd=0.0085 | test_mmd=0.0097 | test_mmd_cellot=0.0203\n",
      "[CellOT+scGen] epoch=1800 f_loss=1.7287 g_loss=-28.8563 | train_mmd=0.0112 | test_mmd=0.0127 | test_mmd_cellot=0.0223\n",
      "[CellOT+scGen] epoch=1850 f_loss=-1.8198 g_loss=-26.5507 | train_mmd=0.0106 | test_mmd=0.0121 | test_mmd_cellot=0.0237\n",
      "[CellOT+scGen] epoch=1900 f_loss=0.8133 g_loss=-27.2347 | train_mmd=0.0084 | test_mmd=0.0091 | test_mmd_cellot=0.0219\n",
      "[CellOT+scGen] epoch=1950 f_loss=-0.1097 g_loss=-27.1581 | train_mmd=0.0108 | test_mmd=0.0106 | test_mmd_cellot=0.0224\n",
      "[CellOT+scGen] epoch=2000 f_loss=1.1595 g_loss=-26.8151 | train_mmd=0.0105 | test_mmd=0.0108 | test_mmd_cellot=0.0222\n",
      "[CellOT+scGen] epoch=2050 f_loss=-0.1409 g_loss=-25.9635 | train_mmd=0.0106 | test_mmd=0.0119 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=2100 f_loss=-1.3802 g_loss=-26.2245 | train_mmd=0.0087 | test_mmd=0.0094 | test_mmd_cellot=0.0213\n",
      "[CellOT+scGen] epoch=2150 f_loss=0.4826 g_loss=-25.5675 | train_mmd=0.0119 | test_mmd=0.0128 | test_mmd_cellot=0.0250\n",
      "[CellOT+scGen] epoch=2200 f_loss=-0.3942 g_loss=-24.1037 | train_mmd=0.0110 | test_mmd=0.0122 | test_mmd_cellot=0.0253\n",
      "[CellOT+scGen] epoch=2250 f_loss=-2.0957 g_loss=-24.4587 | train_mmd=0.0078 | test_mmd=0.0079 | test_mmd_cellot=0.0196\n",
      "[CellOT+scGen] epoch=2300 f_loss=-1.0094 g_loss=-26.1698 | train_mmd=0.0086 | test_mmd=0.0090 | test_mmd_cellot=0.0214\n",
      "[CellOT+scGen] epoch=2350 f_loss=-0.7638 g_loss=-24.4589 | train_mmd=0.0091 | test_mmd=0.0099 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=2400 f_loss=1.1837 g_loss=-25.2314 | train_mmd=0.0075 | test_mmd=0.0085 | test_mmd_cellot=0.0208\n",
      "[CellOT+scGen] epoch=2450 f_loss=-3.1371 g_loss=-25.6785 | train_mmd=0.0104 | test_mmd=0.0112 | test_mmd_cellot=0.0232\n",
      "[CellOT+scGen] epoch=2500 f_loss=-0.3670 g_loss=-25.7636 | train_mmd=0.0097 | test_mmd=0.0105 | test_mmd_cellot=0.0225\n",
      "[CellOT+scGen] epoch=2550 f_loss=0.0622 g_loss=-23.3061 | train_mmd=0.0109 | test_mmd=0.0116 | test_mmd_cellot=0.0251\n",
      "[CellOT+scGen] epoch=2600 f_loss=0.2073 g_loss=-26.3361 | train_mmd=0.0100 | test_mmd=0.0105 | test_mmd_cellot=0.0233\n",
      "[CellOT+scGen] epoch=2650 f_loss=-0.6544 g_loss=-24.5784 | train_mmd=0.0109 | test_mmd=0.0115 | test_mmd_cellot=0.0250\n",
      "[CellOT+scGen] epoch=2700 f_loss=1.2433 g_loss=-24.2282 | train_mmd=0.0107 | test_mmd=0.0112 | test_mmd_cellot=0.0236\n",
      "[CellOT+scGen] epoch=2750 f_loss=-1.8995 g_loss=-27.9715 | train_mmd=0.0104 | test_mmd=0.0108 | test_mmd_cellot=0.0238\n",
      "[CellOT+scGen] epoch=2800 f_loss=-1.6571 g_loss=-23.1644 | train_mmd=0.0148 | test_mmd=0.0155 | test_mmd_cellot=0.0298\n",
      "[CellOT+scGen] epoch=2850 f_loss=2.6313 g_loss=-26.8647 | train_mmd=0.0094 | test_mmd=0.0093 | test_mmd_cellot=0.0210\n",
      "[CellOT+scGen] epoch=2900 f_loss=-0.3373 g_loss=-24.3237 | train_mmd=0.0105 | test_mmd=0.0114 | test_mmd_cellot=0.0250\n",
      "[CellOT+scGen] epoch=2950 f_loss=-0.3400 g_loss=-24.9627 | train_mmd=0.0103 | test_mmd=0.0106 | test_mmd_cellot=0.0234\n",
      "[CellOT+scGen] epoch=3000 f_loss=-0.5983 g_loss=-25.4280 | train_mmd=0.0099 | test_mmd=0.0105 | test_mmd_cellot=0.0230\n",
      "[CellOT+scGen] Final CellOT MMD: 0.0230\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=== Metrics Summary over Runs for top 100 genes ===\n",
      "                        mean     std\n",
      "mmd2_gamma_median     0.0129  0.0063\n",
      "mmd2_gamma_0.5        0.0022  0.0000\n",
      "mmd2_gamma_1.0        0.0022  0.0000\n",
      "wasserstein_distance  7.1009  0.8372\n",
      "R2_feature_means      0.7460  0.1995\n"
     ]
    }
   ],
   "source": [
    "\n",
    "print(X_tr_pre.shape)\n",
    "print(X_te_pre.shape)\n",
    "print(Y_tr_post.shape)\n",
    "print(Y_te_post.shape)\n",
    "\n",
    "\n",
    "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=3000, top_feature_subset=top_genes_idx, seed=seed)\n",
    "  \n",
    "    metrics = summarize_metrics(out[\"y_pred\"][:, top_genes_idx], Y_te_post[:, top_genes_idx], median_gamma)\n",
    "    all_metrics.append(metrics)\n",
    "\n",
    "# Results summary\n",
    "print(\"=== Metrics Summary over Runs for top 100 genes ===\")\n",
    "df = pd.DataFrame(all_metrics)\n",
    "print(df.describe().T[['mean', 'std']].round(4))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5ca1b443",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.25"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
