diff --git a/docs/notebooks/300_satija_unseen_cell_line_cytokine.ipynb b/docs/notebooks/300_satija_unseen_cell_line_cytokine.ipynb
new file mode 100644
index 00000000..fabd1750
--- /dev/null
+++ b/docs/notebooks/300_satija_unseen_cell_line_cytokine.ipynb
@@ -0,0 +1,676 @@
+{
+ "cells": [
+  {
+   "cell_type": "markdown",
+   "id": "c7a0b6f9-b392-49fe-afb6-7b227bf5a73d",
+   "metadata": {},
+   "source": [
+    "# Predicting the effect of gene knockouts on unseen cytokine-induced cell lines"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "id": "bc061b8c-aaab-413f-8f20-a0f07c812dde",
+   "metadata": {},
+   "source": [
+    "In this tutorial, we predict the effect of genetic knockouts on unseen combinations of pathway and cell lines. Therefore, we consider [a dataset](https://www.nature.com/articles/s41556-025-01622-z2) which captures the effect of genetic knockouts on 6 cancer cell lines stimulated with 5 different cytokines."
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "id": "52cbffa5-7171-4c5e-8d21-c188af805502",
+   "metadata": {},
+   "source": [
+    "## Preliminaries"
+   ]
+  },
+  {
+   "cell_type": "markdown",
+   "id": "e44f0ce5-2981-4c5c-a8be-dc07de0b15ab",
+   "metadata": {},
+   "source": [
+    "The dataset is relatively large, hence we use [rapids-single-cell](https://rapids-singlecell.readthedocs.io/en/latest/index.html) which allows us to leverage GPU acceleration for preprocessing and downstream tasks. This notebook is executed on a A100 GPU with 80GB memory, as well as 500GB CPU memory. \n",
+    "\n",
+    "We also require `mygene` to translate gene names to Ensembl IDs, it can be installed via `pip install mygene`"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 1,
+   "id": "07690e5c-523c-4a81-93c8-d57f89cabc07",
+   "metadata": {},
+   "outputs": [
+    {
+     "name": "stderr",
+     "output_type": "stream",
+     "text": [
+      "/home/icb/dominik.klein/mambaforge/envs/cellflow/lib/python3.12/site-packages/optuna/study/_optimize.py:29: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
+      "  from optuna import progress_bar as pbar_module\n"
+     ]
+    }
+   ],
+   "source": [
+    "import warnings\n",
+    "from pandas.errors import SettingWithCopyWarning\n",
+    "\n",
+    "warnings.simplefilter(\"ignore\", UserWarning)\n",
+    "warnings.simplefilter(\"ignore\", FutureWarning)\n",
+    "warnings.simplefilter(\"ignore\", SettingWithCopyWarning)\n",
+    "\n",
+    "import numpy as np\n",
+    "import pandas as pd\n",
+    "import seaborn as sns\n",
+    "import jax\n",
+    "from tqdm import tqdm\n",
+    "import functools\n",
+    "import matplotlib.pyplot as plt\n",
+    "import anndata as ad\n",
+    "import scanpy as sc\n",
+    "import rapids_singlecell as rsc\n",
+    "import flax.linen as nn\n",
+    "import optax\n",
+    "import cellflow\n",
+    "from cellflow.model import CellFlow\n",
+    "import cellflow.preprocessing as cfpp\n",
+    "from cellflow.utils import match_linear\n",
+    "from cellflow.plotting import plot_condition_embedding\n",
+    "from cellflow.preprocessing import transfer_labels, compute_wknn, centered_pca, project_pca, reconstruct_pca, get_esm_embedding\n",
+    "from cellflow.metrics import compute_r_squared, compute_e_distance\n"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 2,
+   "id": "eb05381d-1f6a-4907-9996-95ee2236495c",
+   "metadata": {},
+   "outputs": [
+    {
+     "data": {
+      "text/plain": [
+       "AnnData object with n_obs × n_vars = 1628476 × 33056\n",
+       "    obs: 'orig.ident', 'nCount_RNA', 'nFeature_RNA', 'sample', 'cell_type', 'percent.mito', 'sample_ID', 'Batch_info', 'bc1_well', 'bc2_well', 'bc3_well', 'guide', 'gene', 'mixscale_score', 'pathway'\n",
+       "    var: 'highly_variable', 'means', 'dispersions', 'dispersions_norm'\n",
+       "    uns: 'cell_line_embedding', 'cell_type_colors', 'gene_embeddings', 'hvg', 'log1p', 'neighbors', 'pathway_colors', 'pathway_embeddings', 'pca', 'umap'\n",
+       "    obsm: 'X_pca', 'X_umap'\n",
+       "    varm: 'PCs'\n",
+       "    obsp: 'connectivities', 'distances'"
+      ]
+     },
+     "execution_count": 2,
+     "metadata": {},
+     "output_type": "execute_result"
+    }
+   ],
+   "source": [
+    "adata = sc.read_h5ad(\"/lustre/groups/ml01/workspace/ot_perturbation/data/satija_tmp/adata_satija_processed.h5ad\")\n",
+    "adata"
+   ]
+  },
+  {
+   "cell_type": "code",
+   "execution_count": 3,
+   "id": "75bcd7fb-56c2-4849-a328-2fc02cf3a5c9",
+   "metadata": {},
+   "outputs": [
+    {
+     "data": {
+      "text/html": [
+       "
\n",
+       "\n",
+       "
\n",
+       "  \n",
+       "    \n",
+       "      | \n",
+       " | orig.ident\n",
+       " | nCount_RNA\n",
+       " | nFeature_RNA\n",
+       " | sample\n",
+       " | cell_type\n",
+       " | percent.mito\n",
+       " | sample_ID\n",
+       " | Batch_info\n",
+       " | bc1_well\n",
+       " | bc2_well\n",
+       " | bc3_well\n",
+       " | guide\n",
+       " | gene\n",
+       " | mixscale_score\n",
+       " | pathway\n",
+       " | 
\n",
+       "  \n",
+       "  \n",
+       "    \n",
+       "      | 05_54_42_1_1_1_1_1_1_1_1_1\n",
+       " | 05\n",
+       " | 15381.0\n",
+       " | 5362\n",
+       " | A549_IFNG\n",
+       " | A549\n",
+       " | 5.961901\n",
+       " | sample_1\n",
+       " | Rep1\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | ATF3g2\n",
+       " | ATF3\n",
+       " | 1.176385\n",
+       " | IFNG\n",
+       " | 
\n",
+       "    \n",
+       "      | 08_58_81_1_1_1_1_1_1_1_1_1\n",
+       " | 08\n",
+       " | 13534.0\n",
+       " | 4995\n",
+       " | A549_IFNG\n",
+       " | A549\n",
+       " | 1.780700\n",
+       " | sample_1\n",
+       " | Rep1\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | STAT2g1\n",
+       " | STAT2\n",
+       " | -0.787551\n",
+       " | IFNG\n",
+       " | 
\n",
+       "    \n",
+       "      | 06_01_92_1_1_1_1_1_1_1_1_1\n",
+       " | 06\n",
+       " | 11520.0\n",
+       " | 4454\n",
+       " | A549_IFNG\n",
+       " | A549\n",
+       " | 9.644097\n",
+       " | sample_1\n",
+       " | Rep1\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | CUL1g1\n",
+       " | CUL1\n",
+       " | 4.208174\n",
+       " | IFNG\n",
+       " | 
\n",
+       "    \n",
+       "      | 05_33_45_1_1_1_1_1_1_1_1_1\n",
+       " | 05\n",
+       " | 11174.0\n",
+       " | 4575\n",
+       " | A549_IFNG\n",
+       " | A549\n",
+       " | 4.966887\n",
+       " | sample_1\n",
+       " | Rep1\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | IRF2g2\n",
+       " | IRF2\n",
+       " | -0.345167\n",
+       " | IFNG\n",
+       " | 
\n",
+       "    \n",
+       "      | 06_35_73_1_1_1_1_1_1_1_1_1\n",
+       " | 06\n",
+       " | 10807.0\n",
+       " | 3961\n",
+       " | A549_IFNG\n",
+       " | A549\n",
+       " | 13.528269\n",
+       " | sample_1\n",
+       " | Rep1\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | NaN\n",
+       " | MYCg2\n",
+       " | MYC\n",
+       " | -0.182128\n",
+       " | IFNG\n",
+       " | 
\n",
+       "  \n",
+       "
\n",
+       "