Skip to main content

Fit 2D time- and energy-resolved spectroscopy data

Project description

trspecfit - 2D Time- and Energy-resolved Spectroscopy Fitting

Documentation Status PyPI version CI Python versions

trspecfit is a Python package for modeling and fitting 1D energy-resolved and 2D time-and-energy-resolved spectroscopy data. It extends lmfit with composable spectral components, parameter-level time dynamics, convolution kernels, and simulation tools so you can build, fit, and validate physically meaningful models in one workflow.

Capabilities

  • Modular components (Gaussian, Voigt/GLP/GLS, Doniach-Sunjic, backgrounds, kernels)
  • 1D and 2D model construction with time-dependent parameters
  • Auxiliary-axis parameter profiles via add_par_profile(...)
  • Global fitting via lmfit, including CI and optional MCMC (lmfit.emcee)
  • Synthetic data generation (single spectra, 2D datasets, noisy realizations)
  • Parameter-sweep simulation for validation and ML training data generation
  • Centralized plot configuration via PlotConfig with per-plot overrides

Installation

These instructions assume Python 3.12+, pip, and virtual environment support are already installed.

Install from PyPI:

python -m pip install trspecfit

Or install with Jupyter support for the example notebooks:

python -m pip install "trspecfit[lab]"

Install from GitHub:

python -m pip install git+https://github.com/InfinityMonkeyAtWork/time-resolved-spectroscopy-fit.git

Quick Usage

from trspecfit import Project, File

project = Project(path='my_project', name='my_experiment')
file = File(parent_project=project, path='my_dataset',
            data=..., energy=..., time=...)

# Define baseline, load model, fit
file.define_baseline(time_start=0, time_stop=3)
file.load_model('models_energy.yaml', 'my_base_model')
file.set_fit_limits(energy_limits=[...], time_limits=[...])
file.fit_baseline('my_base_model')

# Load 2D energy model, add time dependence, fit
file.load_model('models_energy.yaml', 'my_2d_model')
file.add_time_dependence('my_2d_model', 'my_par', 'models_time.yaml', 'my_dynamics')
file.fit_2d('my_2d_model')

# Inspect results
df = file.get_fit_results(fit_type='2d')

For global fits, dynamics, profiles, and advanced workflows see the Quick Start and Examples.

Documentation

Full docs are hosted on Read the Docs: Installation | Quick Start | Examples | API Reference

Citation

If trspecfit contributes to published research, please cite the DOE CODE / OSTI software record:

Johannes Mahl; Ethan Crumlin. time-resolved spectroscopy fit (trspecfit) v0.01. Lawrence Berkeley National Laboratory, 2025. DOI: 10.11578/dc.20251009.2

Support and Community

Development

# Create and activate virtual environment
# Linux / macOS
python3 -m venv .venv
source .venv/bin/activate
# OR Windows (PowerShell)
python -m venv .venv
.\.venv\Scripts\Activate

# [same commands for all platforms from here on]
# Install and setup
pip install -U pip
pip install -e ".[dev]"
python -m pre_commit install --install-hooks

# Quick local test run (same pytest selection used by the pre-commit hook)
pytest

# Full suite, including slow tests (matches CI and release)
pytest -m ""

# Run all configured pre-commit hooks, including the quick pytest hook
python -m pre_commit run --all-files

Repository Layout

  • src/trspecfit/ - package source
  • docs/ - Sphinx docs source
  • examples/ - notebooks and YAML models
  • tests/ - pytest test suite

Copyright Notice

time-resolved spectroscopy fit (trspecfit) Copyright (c) 2025, The Regents of the University of California, through Lawrence Berkeley National Laboratory (subject to receipt of any required approvals from the U.S. Dept. of Energy). All rights reserved.

If you have questions about your rights to use or distribute this software, please contact Berkeley Lab's Intellectual Property Office at IPO@lbl.gov.

NOTICE. This Software was developed under funding from the U.S. Department of Energy and the U.S. Government consequently retains certain rights. As such, the U.S. Government has been granted for itself and others acting on its behalf a paid-up, nonexclusive, irrevocable, worldwide license in the Software to reproduce, distribute copies to the public, prepare derivative works, and perform publicly and display publicly, and to permit others to do so.

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

trspecfit-0.7.4.tar.gz (167.2 kB view details)

Uploaded Source

Built Distribution

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

trspecfit-0.7.4-py3-none-any.whl (129.7 kB view details)

Uploaded Python 3

File details

Details for the file trspecfit-0.7.4.tar.gz.

File metadata

  • Download URL: trspecfit-0.7.4.tar.gz
  • Upload date:
  • Size: 167.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for trspecfit-0.7.4.tar.gz
Algorithm Hash digest
SHA256 dc6d6c8e1501a8397e485e61ff14be18b1f22cf3f07e627d0dd9e5d4c4d601fb
MD5 1746ef551b66dd5b5abf2ffdac1fc5f1
BLAKE2b-256 868d555feacf65494e70e1af5c4cf6dc1ea5b0abacc0f212d50eff2598f6101b

See more details on using hashes here.

Provenance

The following attestation bundles were made for trspecfit-0.7.4.tar.gz:

Publisher: release.yaml on InfinityMonkeyAtWork/time-resolved-spectroscopy-fit

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

File details

Details for the file trspecfit-0.7.4-py3-none-any.whl.

File metadata

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

File hashes

Hashes for trspecfit-0.7.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b13aa5345aa4b0ca3c018d6d203cd951700167f437f9cc3acae39444fdfc20bd
MD5 30b5cc92cae3a5092bd0a28ff8c8f42d
BLAKE2b-256 ed60f4d28e3098dd9ce81712389c7bd67be53cffbba2b52da3aab08dde90c803

See more details on using hashes here.

Provenance

The following attestation bundles were made for trspecfit-0.7.4-py3-none-any.whl:

Publisher: release.yaml on InfinityMonkeyAtWork/time-resolved-spectroscopy-fit

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