Metadata-Version: 2.4
Name: deeplife
Version: 1.0.1
Summary: Official DeepLife Python package: TwinCell (`deeplife.twincell`), pseudo-bulk (`deeplife.pseudobulk`), differential expression (`deeplife.differential_expression`). Tutorial notebooks: https://twincell.deeplife.co/docs/tutorials/ (optional `[notebook]` extra for Jupyter).
Project-URL: Homepage, https://deeplife.co
Project-URL: Documentation, https://twincell.deeplife.co/docs/
Project-URL: Repository, https://github.com/deeplifeai/deeplife
Project-URL: Issues, https://github.com/deeplifeai/deeplife/issues
Project-URL: Changelog, https://github.com/deeplifeai/deeplife/releases
Author-email: DeepLife <hello@deeplife.co>
License: MIT
License-File: LICENSE
Keywords: anndata,api,bioinformatics,deeplife,differential-expression,digital-twin,drug-discovery,pseudobulk,scanpy,single-cell,twincell
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Healthcare Industry
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Scientific/Engineering :: Bio-Informatics
Classifier: Topic :: Scientific/Engineering :: Medical Science Apps.
Classifier: Typing :: Typed
Requires-Python: >=3.12
Requires-Dist: anndata>=0.12.7
Requires-Dist: boto3>=1.35.0
Requires-Dist: decoupler>=2.1.1
Requires-Dist: dotenv>=0.9.9
Requires-Dist: gseapy>=1.1.13
Requires-Dist: h5py>=3.10.0
Requires-Dist: hdf5plugin>=5.1.0
Requires-Dist: httpx>=0.27.2
Requires-Dist: hydra-core>=1.3.0
Requires-Dist: ipykernel>=7.1.0
Requires-Dist: ipywidgets>=8.1.8
Requires-Dist: kaleido>=1.0.0
Requires-Dist: mkdocs>=1.6.1
Requires-Dist: networkx>=3.2.1
Requires-Dist: numpy>=1.26.4
Requires-Dist: omegaconf>=2.3.0
Requires-Dist: pandas>=2.2.3
Requires-Dist: plotly>=6.3.0
Requires-Dist: pyarrow>=21.0.0
Requires-Dist: pydantic>=2.8.2
Requires-Dist: pydeseq2>=0.5.2
Requires-Dist: pyyaml>=6.0
Requires-Dist: scanpy[leiden]>=1.11.4
Requires-Dist: tenacity>=9.0.0
Requires-Dist: tqdm>=4.67.1
Provides-Extra: notebook
Requires-Dist: adjusttext>=0.8.0; extra == 'notebook'
Requires-Dist: comm>=0.1.1; extra == 'notebook'
Requires-Dist: gseapy>=1.1.9; extra == 'notebook'
Requires-Dist: ipython>=8.26.0; extra == 'notebook'
Requires-Dist: six>=1.5; extra == 'notebook'
Description-Content-Type: text/markdown

# deeplife

[![PyPI version](https://img.shields.io/pypi/v/deeplife)](https://pypi.org/project/deeplife/)
[![CI](https://github.com/deeplifeai/deeplife/actions/workflows/ci.yml/badge.svg)](https://github.com/deeplifeai/deeplife/actions/workflows/ci.yml)
[![Python 3.12+](https://img.shields.io/badge/python-3.12+-blue.svg)](https://www.python.org/downloads/)
[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](LICENSE)

Official **[DeepLife](https://deeplife.co/)** Python **toolkit** for **TwinCell** and related analysis: call the Open API from Python, **pseudo-bulk** with **`deeplife.pseudobulk`**, and run **sample-level differential expression** with **`deeplife.differential_expression`** (suitable for pseudo-bulk, bulk, or other compatible count tables). TwinCell code is split into focused subpackages under **`deeplife.twincell`** (HTTP client, workflows, preprocess, validation); **`deeplife.twincell`** itself still exposes a flat import surface for notebooks.

**Source:** [github.com/deeplifeai/deeplife](https://github.com/deeplifeai/deeplife) · **Documentation:** [twincell.deeplife.co/docs](https://twincell.deeplife.co/docs/) · **Python:** 3.12+ (see [`pyproject.toml`](https://github.com/deeplifeai/deeplife/blob/main/pyproject.toml)).

---

## Install

```bash
pip install deeplife
```

**API key:** you need a DeepLife key (usually `dl_…`). Create or copy one from the **[TwinCell console](https://twincell.deeplife.co/)** (sign in, then open **API keys** / **Keys**). In code, set `DEEPLIFE_API_KEY` in the environment or pass `api_key=` when constructing the client. API documentation for your deployment is usually at `{base_url}/docs` when enabled (the client defaults to the production Open API host; pass `base_url=` for another environment).

**Network:** the TwinCell **Open API** is **not** on the public Internet today. It runs in DeepLife’s cluster and is reachable only when your machine has access to that network—for example by being signed into your organization’s **[Tailscale](https://tailscale.com/)** tailnet (or whatever access path your team documents). Local-only features (pseudo-bulk, differential expression on `.h5ad`) do **not** require API connectivity.

**From a git clone** (contributors):

```bash
uv sync --group dev
```

---

## Documentation

Hosted docs (same content as the **`Documentation`** link on [PyPI](https://pypi.org/project/deeplife/)):

| Guide | Description |
|--------|----------------|
| [Quick Start](https://twincell.deeplife.co/docs/quickstart/) | `pip install`, optional **`[notebook]`**, API keys, first TwinCell workflow |
| [Tutorials](https://twincell.deeplife.co/docs/tutorials/) | Single-cell and bulk RNA-seq target-validation notebooks |
| [API Reference](https://twincell.deeplife.co/docs/api/) | `TwinCell`, preprocessing, validation, pseudo-bulk, differential expression |

Source: [docs/index.md](https://github.com/deeplifeai/deeplife/blob/main/docs/index.md).

---

## Package layout

### TwinCell (`deeplife.twincell`)

| Import | Role |
|--------|------|
| **`deeplife.twincell`** | Convenience namespace: `DeepLifeClient`, `TwinCell`, `TwinCellSession`, `TwinCellStudy` (alias of `TwinCell`), `read_h5ad`, `adata_to_h5ad_bytes`, etc.; plus the preprocess helpers `pseudobulk`, `pydeseq2` (and lazy `preprocessing`). |
| **`deeplife.twincell.http`** | REST client (`DeepLifeClient`, `AsyncDeepLifeClient`), request/response models, errors, HTTP helpers, logging (`DeepLifeClient` lives in `twincell.http.client`). |
| **`deeplife.twincell.workflows`** | High-level session and study code: import submodules explicitly, e.g. `twincell.workflows.workflows` (`TwinCellSession`, …), `twincell.workflows.study` (`TwinCell`, …), `twincell.validation.upload_helpers` (`adata_to_h5ad_bytes` for client-side serialization), `twincell.workflows.h5ad_io` (`read_h5ad` for local paths and remote `.h5ad` URIs). The package `__init__` resolves names lazily to avoid import cycles. |
| **`deeplife.twincell.preprocess`** | Notebook-oriented pseudo-bulk and PyDESeq2 helpers (`preprocess.pseudobulk`, `preprocess.pydeseq2`). |
| **`deeplife.twincell.validation`** | Local checks for the **split inference** upload path (`validate_twincell_split_anndata`, shared with the HTTP client). Exceptions live under **`validation.core`**; shared result types under **`validation.checks`**. |

### Other packages

| Import | Role |
|--------|------|
| `deeplife.pseudobulk`, `deeplife.differential_expression` | Pseudo-bulk from single-cell `AnnData`, and sample-level DE (CLIs `twincell-pseudobulk`, `twincell-diffexpr`) |

Install with **`pip install deeplife`**. **Import** **`deeplife.twincell`** (flat or by submodule), **`deeplife.pseudobulk`**, and **`deeplife.differential_expression`**.

---

## Minimal API usage

End-to-end flow: prepare `.h5ad` or `AnnData` yourself → `create_prediction` (single file) or `create_prediction_split` (control + perturbed + DEGs; validated locally) → poll or `watch_prediction` → read `results` (and optional influence / causal helpers).

```python
import os
from deeplife.twincell import DeepLifeClient

client = DeepLifeClient(api_key=os.environ["DEEPLIFE_API_KEY"])
prediction = client.create_prediction(dataset="twincell_ready.h5ad")
final = client.wait_for_prediction(prediction_id=prediction.prediction_id)
print(final.status)
```

The same client is available explicitly as **`from deeplife.twincell.http import DeepLifeClient`** (recommended in application code so imports stay close to the HTTP layer).

**Defaults:** the client uses the toolkit’s configured API base URL; pass `base_url=` for another environment. You must be able to reach that host from your network (see **Network** under [Install](#install)). Retries apply to safe **GET**-style calls (polling), not duplicate uploads on `POST`. For TLS/proxy issues, use `tls_verify=` and `trust_env=` on the client—see **`DeepLifeClient`** in **`deeplife.twincell.http.client`**.

For richer AnnData preparation (QC, column mapping, pseudo-bulk), use **`deeplife.twincell.preprocess`** or the [tutorial notebooks](#tutorials).

---

## Tutorials

Tutorial **`.ipynb`** files are published on the **[docs site](https://twincell.deeplife.co/docs/tutorials/)** (interactive + download). **`getting-started-single-cell.ipynb`** covers Kang PBMC pseudo-bulk, PyDESeq2, and TwinCell target validation. **`getting-started-bulk.ipynb`** is the bulk RNA-seq companion.

**Run locally from a git clone:**

```bash
pip install "deeplife[notebook]" jupyterlab
git clone https://github.com/deeplifeai/deeplife
cd deeplife
jupyter lab tutorials/
```

Set **`DEEPLIFE_API_KEY`** (or use the notebook `getpass` prompt) before the TwinCell API steps. Network access to the Open API is required for those cells — see [Install](#install).

| Location | Role |
|----------|------|
| [twincell.deeplife.co/docs/tutorials/](https://twincell.deeplife.co/docs/tutorials/) | Canonical hosted tutorials (browse or download) |
| [`tutorials/`](tutorials/) in a **git clone** | Same notebooks for local Jupyter |

**Contributors** can use `uv sync --group dev --extra notebook` instead of `pip` if you prefer the locked lockfile.

> After `pip install -U deeplife`, confirm imports match the [layout](#package-layout) you expect; the latest release is always on [PyPI](https://pypi.org/project/deeplife/).

---

## Development

```bash
uv sync --group dev
make check-all    # or: ruff, mypy, pytest — see Makefile
```

**CI:** [`.github/workflows/ci.yml`](https://github.com/deeplifeai/deeplife/blob/main/.github/workflows/ci.yml) runs on pushes and PRs to **`main`** / **`master`**: `uv sync --frozen --group dev`, **Ruff**, **mypy**, **pytest**, **`uv build`**, **`twine check --strict`**. [`.github/dependabot.yml`](https://github.com/deeplifeai/deeplife/blob/main/.github/dependabot.yml) bumps **GitHub Actions** weekly.

**Releases to PyPI:** [`.github/workflows/pypi-publish.yml`](https://github.com/deeplifeai/deeplife/blob/main/.github/workflows/pypi-publish.yml) runs the same checks, then publishes with **OIDC trusted publishing** (GitHub environment **`pypi`**, trusted publisher configured on the **`deeplife`** PyPI project). Bump **`version`** in `pyproject.toml`, push to **`main`**, then either push a tag matching **`v*`** or run the workflow manually from the **Actions** tab.
