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

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
  • 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

Documentation

Full docs are hosted on Read the Docs:

For consistent, central plot behavior, set plotting defaults at Project creation (typically via project.yaml), and see PlotConfig details and override patterns here: https://time-resolved-spectroscopy-fit.readthedocs.io/en/latest/api/plot_config.html

Support and Community

  • Questions and usage help: GitHub Discussions (Q&A category)
  • Ideas and brainstorming: GitHub Discussions (Ideas category)
  • Reproducible bugs and trackable feature requests: GitHub Issues
  • Maintainer response target: within 7 days

Links:

Installation

Install from PyPI:

pip install trspecfit

Install from GitHub:

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

Quick Usage

from trspecfit import Project, File

project = Project(path='examples/simulator', name='local-test')
file = File(parent_project=project, path='simulated_dataset')

file.load_model('models_energy.yaml', ['ModelName'])
file.describe_model()

file.add_time_dependence(
    model_yaml='models_time.yaml',
    model_info=['TimeModelName'],
    par_name='EnergyModelComponent_NN_par',
)

file.model_active.create_value2D()
value_2d = file.model_active.value2D

For full workflows, see the docs examples page and the notebooks in examples/.

Development

# Create env (same on all platforms)
python -m venv .venv

# Activate virtual environment
# Linux / macOS
source .venv/bin/activate
# OR Windows PowerShell
.\.venv\Scripts\Activate

# Install and setup (same on all platforms)
pip install -U pip
pip install -e ".[dev]"
python -m pre_commit install --install-hooks

# Commit changes (same on all platforms)
pytest
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.4.3.tar.gz (116.9 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.4.3-py3-none-any.whl (111.6 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for trspecfit-0.4.3.tar.gz
Algorithm Hash digest
SHA256 40be71414e85486cd5afd8f33b33beb1d06e38013a49a0adf2dea2ae19d17c9a
MD5 b260c0de761bab3b9c169802197ae8ae
BLAKE2b-256 466a4fc57dbc34b0516b94d79118c11fc40f0f5a5054a7cdcd9c11b88e7617fa

See more details on using hashes here.

Provenance

The following attestation bundles were made for trspecfit-0.4.3.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.4.3-py3-none-any.whl.

File metadata

  • Download URL: trspecfit-0.4.3-py3-none-any.whl
  • Upload date:
  • Size: 111.6 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.4.3-py3-none-any.whl
Algorithm Hash digest
SHA256 aa5820a083014eda5766e2a7f5c252b18043f482ba22cd372b14f2ce6f4c895e
MD5 faab7a7c09093cf3819d11094794855d
BLAKE2b-256 b1c30efb6b7e00673361a4833e2cdd64b69bb9d10687e3c4db94d35bf6b4f21d

See more details on using hashes here.

Provenance

The following attestation bundles were made for trspecfit-0.4.3-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