Synthetic High-Speed AFM image generation with differentiable kernels
Project description
🧬 synth-afm: Differentiable HS-AFM Simulation
synth-afm is a JAX-powered toolkit for generating synthetic High-Speed Atomic Force Microscopy (HS-AFM) images and movies from atomistic protein structures.
Built with the differentiable biophysics philosophy, every step—from coordinate rotation to tip-collision height mapping—is end-to-end differentiable.
🧪 For Structural Biologists
HS-AFM provides a unique look at "proteins at work," but interpreting noisy movies is challenging. synth-afm helps you bridge the resolution gap:
- Realistic Tip Physics: Uses a spherical-tip dilation model to account for the broadening effect of the AFM probe.
- Atomic Rigor: Automatically assigns van der Waals radii based on element (Bondi, 1964) for accurate topography.
- Temporal Distortion: Models Scanning Lag, simulating how protein dynamics during a scan cause the "shear" artifacts seen in real HS-AFM movies.
- Force Maps: Go beyond height-maps with experimental support for tip-sample repulsion (deflection) modeling.
🤖 For Machine Learning Geeks
synth-afm treats the entire AFM scanning process as a differentiable operator $\mathcal{H}: \mathbb{R}^{N \times 3} \rightarrow \mathbb{R}^{H \times W}$:
- End-to-End Differentiable: Built entirely in JAX, allowing you to flow gradients from an experimental AFM image $\mathbf{I}_{exp}$ back to atomic coordinates $\mathbf{X}$.
- Flexible Fitting: Enable gradient-based optimization of molecular structures using experimental AFM data as a loss term: $\mathcal{L} = |\mathcal{H}(\mathbf{X}) - \mathbf{I}_{exp}|^2$.
- Synthetic Benchmarking: Generate large-scale, ground-truth datasets of "corrupted" AFM movies (with lag, noise, and dilation) to train denoising or state-detection models.
🚀 Key Features
- Differentiable Height Mapping: Efficient Log-Sum-Exp collision detection for sub-nanometer topography.
- Physical Realism: Simulate cantilever noise and substrate tilt (linear gradients) to match experimental conditions.
- Scanning Lag Simulation: Models the line-by-line temporal delay inherent in pixel-by-pixel acquisition.
- Memory Efficiency: Uses
jax.lax.scanfor constant-memory simulation of long trajectories. - Flexible Tip Geometries: Supports spherical tip-shape dilation.
- Integration: Reads PDB/mmCIF files via
biotiteand integrates withsynth-pdbandsynth-dynamics.
📦 Installation
pip install synth-afm
📖 Tutorials
Get started immediately with our interactive Jupyter notebooks:
- Quick Start: Differentiable HS-AFM Simulation: Learn how to generate height maps with tip dilation and scanning lag.
🛠 Quick Start
import jax.numpy as jnp
from synth_afm.simulator import AFMSimulator
from synth_afm.io import load_coords_and_radii
# 1. Load your structure (N, 3) and radii (N,)
coords, radii = load_coords_and_radii("molecule.pdb")
# 2. Initialize simulator (1A pixel size, 2nm tip radius, 0.5A noise, slight tilt)
sim = AFMSimulator(
pixel_size=1.0,
tip_radius=20.0,
noise_level=0.5,
substrate_tilt=(0.01, 0.0)
)
# 3. Generate height map (Differentiable!)
height_map = sim.scan(coords, radii)
🧪 Scientific Validation
The height-mapping kernels are validated against the standard Villarrubia algorithm and verified to preserve atomic heights within 0.01 Å precision. The temporal lag simulation correctly reproduces the stroboscopic shearing effects documented in high-speed biological AFM (Ando et al., 2011).
🔗 Related Projects
synth-afm is part of a broader ecosystem for synthetic biophysics data generation:
| Project | Purpose |
|---|---|
| synth-pdb | Foundation: Realistic protein structure generation and PDB/mmCIF handling |
| synth-nmr | NMR observables (NOE, RDC, chemical shifts, J-couplings, relaxation) |
| synth-saxs | SAXS profile simulation via Debye formula |
| synth-cryo-em | Cryo-EM density map generation with CTF/noise modeling |
| synth-dynamics | ANM/Langevin dynamics for conformational ensembles |
| diff-biophys | Differentiable JAX implementations of all biophysics kernels |
📜 License
Distributed under the MIT License. See LICENSE for more information.
✍️ Citation
If you use synth-afm in your research, please cite:
@software{synth_afm,
author = {Elkins, George},
title = {synth-afm: Differentiable HS-AFM Simulation},
year = {2026},
url = {https://github.com/elkins/synth-afm}
}
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file synth_afm-0.1.1.tar.gz.
File metadata
- Download URL: synth_afm-0.1.1.tar.gz
- Upload date:
- Size: 14.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d42b347c466e22ca5d2c5aa4c21d9041d8b440a6f4d30b03bf18266d0263c020
|
|
| MD5 |
62a3937c03d719053335faf3319493c6
|
|
| BLAKE2b-256 |
55ba6f9d33053c49a91716cf08c94e32f195a912c08d9709d26f05ade81f38a8
|
File details
Details for the file synth_afm-0.1.1-py3-none-any.whl.
File metadata
- Download URL: synth_afm-0.1.1-py3-none-any.whl
- Upload date:
- Size: 8.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.10
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5c8dab075747bc5b0fb30c9464c1f5daa7375c959322029459598e473c521450
|
|
| MD5 |
9c962c96789792d75ac59d56adda8800
|
|
| BLAKE2b-256 |
502caff3e2aa34af25416fdda302bccb7d0b59ffc87798a5ac5e6344ec337843
|