Skip to main content

Interactive exploration of single-cell embeddings with directional analysis

Project description

scSketch project

scSketch is an interactive exploration tool of single-cell embeddings (UMAP, tSNE, etc.) for Python notebooks. It is based on the jupyter-scatter widget by Fritz Lekschas and it reimplements the earlier SciViewer visualizer.

scSketch directional analysis demo

Directional sketch → compute directional analysis → click a gene for pathway context.

scSketch differential expression demo

Select two groups → compute differential expression → browse results.

Usage

Quick Start

The easiest way to try scSketch is with the built-in demo (no installation required):

uvx scsketch demo

This single command will automatically install scSketch and all dependencies, then launch the demo notebook.

Alternatively, if you've cloned the repository, you can run the demo notebook directly with juv:

git clone https://github.com/colabobio/scsketch.git
cd scsketch
uvx juv run demo.ipynb

Then use in any notebook:

from scsketch import ScSketch

sketch = ScSketch(adata=...)
sketch.show()

See the demo notebook for more details

Use scSketch in your own notebook

Install scSketch into the environment backing your Jupyter kernel:

python -m pip install scsketch

Then in a notebook:

import scanpy as sc
from scsketch import ScSketch

adata = sc.read_h5ad("my_data.h5ad")

# scSketch currently reads coordinates from `adata.obsm["X_umap"]`.
# If you have a different embedding (e.g. tSNE), you can copy it into `X_umap`:
# adata.obsm["X_umap"] = adata.obsm["X_tsne"]

sketch = ScSketch(
    adata=adata,
    metadata_cols=["louvain"],   # optional: columns in `adata.obs` for coloring
    color_by_default="louvain",  # optional: which metadata to color by initially
)

# If this isn't the last line in the cell, use: `from IPython.display import display; display(sketch.show())`
sketch.show()

Directional Search: keep brush selections roughly linear

Directional Search reduces your selection to a 1D “along-the-sketch” axis by projecting cells onto a single direction vector. If your brush selection is very curved, loops back, or spans multiple branches/blobs, that 1D projection can mix multiple directions of variation and produce hard-to-interpret results.

Practical tips:

  • Sketch along one clear gradient at a time (a selection closer to a straight line works best).
  • If the trajectory bends, split it into multiple shorter selections and compare results.

Gene IDs vs gene symbols

scSketch currently uses adata.var_names as the gene identifier for display/search. If your AnnData uses Ensembl IDs (e.g. ENSG...) in var_names, you will see Ensembl IDs in the UI.

If you have gene symbols in a column like adata.var["gene_symbols"], you can create a visualization-only copy that displays symbols:

adata_view = adata.copy()
adata_view.var["ensembl_id"] = adata_view.var_names
adata_view.var_names = adata_view.var["gene_symbols"].astype(str)
adata_view.var_names_make_unique()

sketch = ScSketch(adata=adata_view, metadata_cols=["louvain"], color_by_default="louvain")
sketch.show()

Running the original notebook with juv

To run the original inline notebook, first install juv and then call:

juv run demo.ipynb

Development

This project uses uv for development and dependency management.

Setup

  1. Clone the repository:

    git clone https://github.com/colabobio/scsketch.git
    cd scsketch
    
  2. Sync environment (installs dependencies):

    uv sync
    

Development Workflow

You can run commands inside the project's environment using uv run.

  • Launch Jupyter Lab for testing:

    uv run jupyter lab
    

    Open debug.ipynb to test changes.

  • Hot-reloading JS/CSS: The debug.ipynb notebook is pre-configured with ANYWIDGET_HMR=1. Any changes you save to files in src/scsketch/static/ will legally update the widget in your browser without reloading the page.

  • Linting (Ruff):

    uv run ruff check .
    
  • Testing: Run the unit test suite with pytest:

    uv run pytest tests/
    

Optional: Manual Activation

If you prefer to activate the environment in your shell:

source .venv/bin/activate
# Now you can use `jupyter`, `python`, `pip` directly
jupyter lab

Or with editable installs:

python -m venv .venv
source .venv/bin/activate
python -m pip install -e ".[dev]"
jupyter lab demo.ipynb

Debugging with VS Code

To debug the Python side of your widgets step-by-step:

  1. Debugging Jupyter Notebooks:

    • Open debug.ipynb in VS Code.
    • Click the "Select Kernel" button at the top right and select your project environment (e.g., .venv or the one created by uv).
    • You can set breakpoints directly in the notebook cells or in the python files (src/scsketch/widgets/*.py).
    • To debug code in external files (like the widgets), use the "Debug Cell" option (often found in the dropdown menu next to the run button of a cell).
  2. Attaching to a running kernel: If you prefer using jupyter lab in your browser but want to debug Python code in VS Code:

    • Run jupyter lab (e.g., uv run jupyter lab).
    • Add this code to a cell at the beginning of your notebook:
      import debugpy
      debugpy.listen(5678)
      print("Waiting for debugger attach...")
      debugpy.wait_for_client()
      print("Debugger attached")
      
    • In VS Code, go to the Run and Debug view (Ctrl+Shift+D).
    • Select "Python: Attach to Local Process" from the dropdown and click the Play button.
    • VS Code will attach to your running kernel, and you can now use breakpoints in your local Python files.

Debugging Frontend (JavaScript)

Since the widgets run in the web browser (or VS Code's webview), you need to use browser developer tools to debug the JavaScript code (src/scsketch/static/*.js).

  1. Run the widget: Open debug.ipynb and run the cell that displays the widget.
  2. Open Developer Tools:
    • In Browser (Jupyter Lab): Right-click anywhere on the page > Inspect.
    • In VS Code: Open the command palette (Cmd+Shift+P) and run "Developer: Open Webview Developer Tools".
  3. Find your source:
    • Go to the Sources tab in the developer tools.
    • Use Cmd+P (Mac) or Ctrl+P (Windows/Linux) to search for your file (e.g., correlation_table.js).
    • Note: Because of how modules are loaded, the file path might look like localhost:xyz/.../correlation_table.js.
  4. Set Breakpoints: Click on the line number in the JS file to set a breakpoint.
  5. Trigger the code: Interact with the widget in the notebook. The debugger will pause on your breakpoint, allowing you to inspect variables and step through the code.

Publish a New Version

To bump the version use one of the following commands:

  1. uvx bump-my-version bump minor (e.g., v0.1.0 → v0.2.0)
  2. uvx bump-my-version bump patch (e.g., v0.1.0 → v0.1.1)
  3. uvx bump-my-version bump major (e.g., v0.1.0 → v1.0.0)

Afterward do git push --follow-tags. Github actions will handle the rest.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

scsketch-0.1.0.tar.gz (3.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

scsketch-0.1.0-py3-none-any.whl (42.4 kB view details)

Uploaded Python 3

File details

Details for the file scsketch-0.1.0.tar.gz.

File metadata

  • Download URL: scsketch-0.1.0.tar.gz
  • Upload date:
  • Size: 3.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for scsketch-0.1.0.tar.gz
Algorithm Hash digest
SHA256 efeaa5999e62a3aa2467102d3b0c882efaf5c11ce0554093552ef9d90cdd095b
MD5 4a49e1e9b325e084681b3eabc2b9e560
BLAKE2b-256 ec9b4abe85f632fe03d58d6d410bbed977294105d8b9d7b969c625ac2109c12f

See more details on using hashes here.

Provenance

The following attestation bundles were made for scsketch-0.1.0.tar.gz:

Publisher: publish.yml on colabobio/scsketch

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file scsketch-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: scsketch-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 42.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for scsketch-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 386499e15fabfc0ee5284e66205ba1804c7a5087064fbcf8433ea71b44048e27
MD5 e3b8e5864d267f28ba4319dfa3512e13
BLAKE2b-256 0a5ff42b36281b9af16bc7e3e3decfbf534f2f639a2ed92fe1b4fe324ec17ed4

See more details on using hashes here.

Provenance

The following attestation bundles were made for scsketch-0.1.0-py3-none-any.whl:

Publisher: publish.yml on colabobio/scsketch

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page