Skip to main content

An xarray-based MRI and MRS toolbox

Project description

xmris logo

A modern, N-dimensional, xarray-based toolbox for Magnetic Resonance Imaging and Spectroscopy.

MyST GitHub Pages Deploy Tests codecov
uv Ruff Python Versions License: AGPL v3

📖 Documentation

Documentation, tutorials, and API reference can be found here.

⚡ Overview

xmris bridges the gap between modern data structures and magnetic resonance research. By building on top of xarray, it provides a robust environment for handling multi-dimensional MRI and MRS data with labeled coordinates, powerful broadcasting, and seamless integration with the scientific Python ecosystem.

Key Features:

  • N-Dimensional Data: Native handling of complex MRI/MRS datasets using xarray.
  • MRS Integration: Direct compatibility with tools like pyAMARES and nmrglue.
  • Modern Tooling: Built for speed and reliability, developed using uv and strictly typed for modern Python environments.

🚀 Installation

Note: xmris requires Python 3.11 or 3.12.

You can install the package directly from PyPI using standard package managers:

# Using pip
pip install xmris

# Using uv (recommended)
uv add xmris

💻 Quick Start

import numpy as np
import xarray as xr
import xmris  # Registers the .xmr accessor!

# 1. Create a dummy N-dimensional FID (e.g., 5 Voxels x 1024 Time points)
time = np.linspace(0, 1, 1024)
data = np.random.randn(5, 1024) + 1j * np.random.randn(5, 1024)

mrsi_data = xr.DataArray(
    data,
    dims=["voxel", "time"],
    coords={"voxel": np.arange(5), "time": time},
    attrs={"MHz": 120.0, "sw": 10000.0}
)

# 2. Process all voxels simultaneously using the .xmr accessor!
results = (
    mrsi_data
    .xmr.zero_fill(target_points=2048)
    .xmr.apodize_exp(lb=5.0)
    .xmr.to_spectrum()
    .xmr.autophase()
)

🛠️ Development

We use uv for lightning-fast dependency management and Ruff for linting/formatting. To set up a local development environment:

  1. Fork this repository and then clone your version of this repository.

  2. Sync the environment and install dependencies:

uv sync
  1. Run tests via pytest (which includes notebook testing via nbmake):
uv run pytest
  1. Build the MyST based documentation :
uv run docs

More information can be found in the documentation here


⚖️ License & Commercial Use

xmris is licensed under the GNU Affero General Public License v3.0 (AGPLv3).

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

xmris-0.6.0.tar.gz (56.3 kB view details)

Uploaded Source

Built Distribution

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

xmris-0.6.0-py3-none-any.whl (67.2 kB view details)

Uploaded Python 3

File details

Details for the file xmris-0.6.0.tar.gz.

File metadata

  • Download URL: xmris-0.6.0.tar.gz
  • Upload date:
  • Size: 56.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for xmris-0.6.0.tar.gz
Algorithm Hash digest
SHA256 7c86457ef5b475a9a92234dc86904f80a0d24e5d56f5858cce7c0ef65f13a01d
MD5 64b618ca97852db67ce5e6eade49af08
BLAKE2b-256 7a224eed815a9a45686839e9098f7cf8d983ed17aae23cfa0ca5da8f02f73206

See more details on using hashes here.

File details

Details for the file xmris-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: xmris-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 67.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for xmris-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b7efe36ccbf9b5739fc0a6948cddbf8cf6ac061142943365d8eec4be63442697
MD5 3e86b0dd092c41a705e095fa035388c9
BLAKE2b-256 6d8c86e06f8b8d5042972e814f777dab254aac348599a3f1075366b79c784e0b

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