Skip to main content

Python tools for small-angle scattering data analysis.

Project description

pyIrena

Coded by Claude from SAXS_IgorCode Irena. Planned, defined, debugged, and validated by Jan Ilavsky.

Python tools for small-angle scattering (SAS) data analysis. A port of the Igor Pro Irena package. Includes interactive GUI tools for fitting, modeling, data merging, and visualization of SAXS/SANS/USAXS data.

Current release: v0.7.0 (public beta)

PyPI version Python Version License: MIT


Installation

From PyPI (recommended):

pip install pyirena[gui]

This installs pyirena with all GUI dependencies (PySide6, pyqtgraph, etc.). For the core library only (no GUI), use pip install pyirena.

From source (for development):

git clone https://github.com/jilavsky/pyirena.git
cd pyirena
pip install -e ".[gui]"

With conda:

git clone https://github.com/jilavsky/pyirena.git
cd pyirena
conda env create -f environment.yml
conda activate pyirena

environment.yml uses conda for Python + scientific stack and pip (inside conda) for the entire Qt6/GUI stack — this split is deliberate. Do not run conda install pyside6 in this env, and use Python 3.10 – 3.13 (Python 3.14 wheels are still flaky for compiled bindings).

See docs/installation.md for full details, troubleshooting, and platform notes.


Running the GUI

pyirena-gui

This launches the Data Selector, the main entry point for all analysis tools. See docs/gui_quickstart.md for a walkthrough.

Individual tools can also be launched directly:

Command Tool
pyirena-gui Data Selector (main entry point)
pyirena-viewer Data Explorer
pyirena-modeling Modeling tool (standalone)
pyirena-datamerge Data Merge tool (standalone)
pyirena-contrast Scattering Contrast Calculator

Analysis Tools

Modeling

Parametric forward-modeling of SAS data. Combine up to 10 populations, each of which can be a Size Distribution, Unified Fit Level, or Diffraction Peak. Fits the combined model to experimental data using least-squares optimization.

  • 5 distribution functions: Gaussian, LogNormal, LSW, Schulz-Zimm, Ardell
  • 9 form factors: Sphere, Spheroid, Cylinder (aspect ratio / fixed length), Core-Shell Sphere and Spheroid (by core R / shell t / total R)
  • 2 structure factors: Born-Green interferences, Hard Sphere (Percus-Yevick)
  • Monte Carlo uncertainty estimation
  • Modeling GUI guide

Unified Fit

Beaucage hierarchical model (1995, 1996) with 1-5 structural levels, each combining Guinier and power-law contributions. Optional Born-Green correlation function.

Size Distribution

Indirect Fourier transform to recover particle size distributions from SAS data. Four inversion methods: MaxEnt, Regularization, TNNLS, and Monte Carlo.

Simple Fits

13 direct analytical models: Guinier, Guinier-Porod, Porod, Sphere, Spheroid, Debye-Bueche, Treubner-Strey, Power Law, and more. Each with linearization plots and Monte Carlo uncertainty estimation.

WAXS Peak Fit

Fit diffraction peaks (Gaussian, Lorentzian, Pseudo-Voigt, Log-Normal) on linear I vs Q scale. Auto-detect peaks via Savitzky-Golay + scipy.signal.find_peaks. Simultaneous background fitting (constant, linear, cubic, or 5th-order polynomial).

Data Merge

Merge two SAS datasets (e.g., SAXS + WAXS) onto a common Q scale. Optimizes scale factor, flat background, and optional Q-shift using Nelder-Mead.

Data Explorer

Browse NXcanSAS HDF5 files, inspect raw data and analysis results, extract and plot datasets, and export to Igor Pro h5xp format. Supports all pyIrena result types (Unified Fit, Sizes, Simple Fits, WAXS Peaks, Modeling).

Scattering Contrast Calculator

Look up X-ray and neutron scattering length densities for materials by chemical formula. Computes contrast (Delta-rho-squared) between two materials.

Data Selector

Central GUI panel for managing data files and launching analysis tools. Load HDF5 files, select datasets, tabulate results across files, and generate reports.


Batch Scripting API

All analysis tools can be run headlessly from Python scripts or JSON configuration files:

from pyirena.batch import fit_pyirena

results = fit_pyirena(
    data_file='sample.h5',
    config_file='pyirena_config.json',
)

Individual functions: fit_unified, fit_sizes, fit_simple, fit_waxs, fit_modeling, merge_data.

See docs/batch_api.md for the full scripting guide.


NXcanSAS I/O

All data and results are stored in HDF5 files using the NXcanSAS format. Fit results are saved alongside raw data, making files self-contained and shareable.


AI integration (MCP)

pyirena ships a Model Context Protocol server that exposes its HDF5 readers, parameter aggregation, and headless plotting to any MCP client — Claude Desktop, Claude Code, custom AI agents.

pip install pyirena[mcp]

Add to claude_desktop_config.json (or your client's MCP server config):

{
  "mcpServers": {
    "pyirena": {
      "command": "pyirena-mcp",
      "env": {
        "PYIRENA_DATA_ROOT": "/path/to/your/data",
        "PYIRENA_PLOT_CACHE": "/tmp/pyirena-plots",
        "PYIRENA_MAX_ARRAY_POINTS": "500"
      }
    }
  }
}

The agent can then call tools like summarize_folder, tabulate_parameter, plot_iq, read_modeling etc. to answer questions about analysis results in plain language. The underlying pyirena.api module is also usable as a regular Python library (no MCP needed).

Full instructions, including configs for Claude Desktop, Claude Code, and AnythingLLM:


Documentation

Topic File
Installation docs/installation.md
Quick start (GUI) docs/gui_quickstart.md
Modeling GUI guide docs/modeling_gui.md
Unified Fit GUI guide docs/unified_fit_gui.md
Unified Fit features & parameters docs/unified_fit_features.md
Size Distribution methods docs/sizes_methods.md
Simple Fits GUI guide docs/simple_fits_gui.md
WAXS Peak Fit GUI guide docs/waxs_peakfit_gui.md
Data Merge GUI guide docs/data_merge_gui.md
Data Explorer guide docs/hdf5_viewer_gui.md
Contrast Calculator guide docs/scattering_contrast_gui.md
NXcanSAS file format docs/NXcanSAS_UnifiedFit_Format.md
Batch fitting API docs/batch_api.md
Usage guide (scripting) docs/usage_guide.md
AI integration (MCP) — install & configure docs/ai_integration.md
AI integration (MCP) — tool reference for agents docs/ai_tools_reference.md
Developer: adding form factors docs/developer_adding_form_factors.md
Developer: adding structure factors docs/developer_adding_structure_factors.md
Testing docs/testing.md
Distribution / packaging docs/distribution.md
Contributing CONTRIBUTING.md
Changelog CHANGELOG.md

License

MIT -- see LICENSE.

Contact

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

pyirena-0.7.1.tar.gz (641.3 kB view details)

Uploaded Source

Built Distribution

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

pyirena-0.7.1-py3-none-any.whl (651.8 kB view details)

Uploaded Python 3

File details

Details for the file pyirena-0.7.1.tar.gz.

File metadata

  • Download URL: pyirena-0.7.1.tar.gz
  • Upload date:
  • Size: 641.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for pyirena-0.7.1.tar.gz
Algorithm Hash digest
SHA256 924de61c07851f1efc97c7344f4597af9e78f2b6efda7f94a7c7222f85f22e5e
MD5 b8bc2f587ec885487608c1482b3453d9
BLAKE2b-256 41647e041b69d843f70891d152cb2f4f31d1149903c0f09efd6e02f8b61f1ee4

See more details on using hashes here.

File details

Details for the file pyirena-0.7.1-py3-none-any.whl.

File metadata

  • Download URL: pyirena-0.7.1-py3-none-any.whl
  • Upload date:
  • Size: 651.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for pyirena-0.7.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b12679508f16664d82180c83699d9016a06e8d73a42e5c912b5df17b4523942e
MD5 caa73db338fb05d875cc945408f83d8e
BLAKE2b-256 593d2d2a028862e2d99d87348e04916948b243d13d090d57a9138c562fb4326e

See more details on using hashes here.

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