Skip to main content

CPU-optimized JAX-based homodyne scattering analysis for XPCS under nonequilibrium conditions

Project description

Homodyne

License: MIT Python Documentation ReadTheDocs DOI

CPU-optimized JAX package for X-ray Photon Correlation Spectroscopy (XPCS) analysis, implementing the theoretical framework from He et al. PNAS 2024 and He et al. PNAS 2025 for characterizing transport properties in flowing soft matter systems.

Homodyne Model

The package implements a single-component scattering model where correlation decay encodes diffusion and shear dynamics. The scattered intensity auto-correlates to produce a two-time correlation function whose shape reveals transport coefficients.

Two-Time Correlation

$$c_2(\vec{q}, t_1, t_2) = 1 + \beta \times [c_1(\vec{q}, t_1, t_2)]^2$$

where $\beta$ the optical contrast and the intermediate scattering function combines diffusion and shear:

$$c_1(\vec{q}, t_1, t_2) = \exp\left(-q^2 \int_{t_1}^{t_2} J(t')\ dt'\right) \times \mathrm{sinc}\left(\frac{qL\cos(\phi)}{2} \int_{t_1}^{t_2} \dot{\gamma}(t')\ dt'\right)$$

where $\phi$ is the angle between the scattering vector and the flow direction.

Rate Functions

Transport coefficients follow power-law forms:

$$J(t) = D_0 \cdot t^{\alpha} + D_{\text{offset}} \qquad \dot{\gamma}(t) = \dot{\gamma}0 \cdot t^{\beta} + \dot{\gamma}{\text{offset}}$$

All time integrals are evaluated numerically via cumulative trapezoid on the discrete time grid -- no analytical antiderivatives are ever used, ensuring correctness for the general power-law form.

Parameters

The model has up to 7 physics parameters organized into three groups, plus 2 per-angle scaling parameters:

Diffusion transport -- $J(t) = D_0 t^\alpha + D_{\text{offset}}$

Parameter Description Default Units
D0 Diffusion prefactor 1e4 Ų/s
alpha Transport exponent (0 = Wiener, 1 = ballistic) 0.0 --
D_offset Transport rate offset 0.0 Ų/s

Shear rate (laminar_flow only) -- $\dot\gamma(t) = \dot\gamma_0 t^\beta + \dot\gamma_{\text{offset}}$

Parameter Description Default Units
gamma_dot_0 Shear rate prefactor 1e-3 s⁻¹
beta Shear rate exponent (0 = constant shear) 0.0 --
gamma_dot_offset Shear rate offset 0.0 s⁻¹

Flow angle

Parameter Description Default Units
phi0 Flow angle offset relative to q-vector 0.0 degrees

Per-angle scaling (2 parameters per detector angle)

Parameter Description Default
contrast Optical contrast (speckle contrast) 0.5
offset Baseline offset 1.0
Mode Parameters Count
static D0, alpha, D_offset 3
laminar_flow D0, alpha, D_offset, gamma_dot_0, beta, gamma_dot_offset, phi0 7

Per-angle contrast and offset are added automatically based on the number of azimuthal angles.

Installation

pip install homodyne

For development:

git clone https://github.com/imewei/homodyne.git
cd homodyne
make dev    # or: uv sync

Requirements: Python 3.12+, CPU-only (no GPU). Runs on Linux, macOS, and Windows.

Quick Start

CLI

# Generate a config template
homodyne-config --mode static --output config.yaml

# Run NLSQ optimization
homodyne --method nlsq --config config.yaml

# Run Consensus Monte Carlo for uncertainty quantification
homodyne --method cmc --config config.yaml

Python API

from homodyne.data import load_xpcs_data
from homodyne.config import ConfigManager
from homodyne.optimization import fit_nlsq_jax
from homodyne.optimization.cmc import fit_mcmc_jax

# Load data and config
data = load_xpcs_data("config.yaml")
config = ConfigManager("config.yaml")

# NLSQ trust-region optimization
nlsq_result = fit_nlsq_jax(data, config)

# CMC with NLSQ warm-start for Bayesian uncertainty
cmc_result = fit_mcmc_jax(data, config, nlsq_result=nlsq_result)

Data Flow

YAML config --> XPCSDataLoader(HDF5) --> HomodyneModel --> NLSQ or CMC --> Results (JSON + NPZ)

Optimization Methods

NLSQ (primary) -- JAX-native trust-region Levenberg-Marquardt with automatic anti-degeneracy defense, CMA-ES global search for multi-scale problems, and memory-aware routing for large datasets.

CMC (secondary) -- Consensus Monte Carlo using NumPyro NUTS sampling with automatic sharding, NLSQ warm-start priors, and multiprocessing across CPU cores. Produces publication-quality posterior distributions with ArviZ diagnostics.

Configuration

Homodyne uses YAML configuration files. Generate a template:

homodyne-config --mode laminar_flow --output config.yaml

Key sections:

analysis_mode: "laminar_flow"
experimental_data:
  file_path: "data.h5"
optimization:
  method: "nlsq"
  nlsq:
    anti_degeneracy:
      per_angle_mode: "auto"   # auto, constant, individual, fourier
  cmc:
    sharding:
      max_points_per_shard: "auto"

See the User Guide for full configuration reference.

CLI Commands

Command Purpose
homodyne Run XPCS analysis (NLSQ/CMC)
homodyne-config Generate and validate config files
homodyne-config-xla Configure XLA device settings
homodyne-post-install Install shell completion (bash/zsh/fish)
homodyne-cleanup Remove shell completion files

Shell completion and aliases are available after running homodyne-post-install --interactive.

Development

make test       # Unit tests
make test-all   # Full suite + coverage
make quality    # Format + lint + type-check

Documentation

Citation

If you use Homodyne in your research, please cite:

@article{He2024,
  author  = {He, Hongrui and Liang, Hao and Chu, Miaoqi and Jiang, Zhang and
             de Pablo, Juan J and Tirrell, Matthew V and Narayanan, Suresh
             and Chen, Wei},
  title   = {Transport coefficient approach for characterizing nonequilibrium
             dynamics in soft matter},
  journal = {Proceedings of the National Academy of Sciences},
  volume  = {121},
  number  = {31},
  year    = {2024},
  doi     = {10.1073/pnas.2401162121}
}
@article{He2025,
  author  = {He, Hongrui and Liang, Heyi and Chu, Miaoqi and Jiang, Zhang and
             de Pablo, Juan J and Tirrell, Matthew V and Narayanan, Suresh
             and Chen, Wei},
  title   = {Bridging microscopic dynamics and rheology in the yielding
             of charged colloidal suspensions},
  journal = {Proceedings of the National Academy of Sciences},
  volume  = {122},
  number  = {42},
  year    = {2025},
  doi     = {10.1073/pnas.2514216122}
}

License

MIT License -- see LICENSE for details.

Authors

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

homodyne-2.22.9.tar.gz (2.0 MB view details)

Uploaded Source

Built Distribution

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

homodyne-2.22.9-py3-none-any.whl (870.6 kB view details)

Uploaded Python 3

File details

Details for the file homodyne-2.22.9.tar.gz.

File metadata

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

File hashes

Hashes for homodyne-2.22.9.tar.gz
Algorithm Hash digest
SHA256 04a77ea008765f78120cf18d526334273653476774bca98c08229a73c0c36b2e
MD5 b9a5dc0eddf616bd05f696b40f6d8105
BLAKE2b-256 677d53d873dc626c3f1910aeef2c025643c5cd5b5b54bc9b0da1e07e305d9184

See more details on using hashes here.

Provenance

The following attestation bundles were made for homodyne-2.22.9.tar.gz:

Publisher: release.yml on imewei/homodyne

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

File details

Details for the file homodyne-2.22.9-py3-none-any.whl.

File metadata

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

File hashes

Hashes for homodyne-2.22.9-py3-none-any.whl
Algorithm Hash digest
SHA256 0d4c1d632b3747745a991820470de98b41915c6eab4063aa7d3c27399259f417
MD5 b6ad66c746f9f18ddf99490d3d825d72
BLAKE2b-256 ec6095cc138768b42e81ca1d591dc6215f34d09f843cacbfb8505596f03bbd72

See more details on using hashes here.

Provenance

The following attestation bundles were made for homodyne-2.22.9-py3-none-any.whl:

Publisher: release.yml on imewei/homodyne

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