Python API overview¶
The brkraw Python API provides programmatic access to the same core functionality as the CLI, using explicit function calls and objects instead of shell commands.
The API is organized around a small set of core tasks:
- Load a dataset and bind a configuration context
- Inspect datasets and acquisition parameters
- Convert scans and generate outputs
- Manage mapping logic and extensions
This section documents the main API entry points and how they fit together.
For lower-level access (scan objects, file access, data/affine retrieval), see Data access.
Entry point¶
All workflows start by loading a dataset:
import brkraw as brk
loader = brk.load("/path/to/study")
The returned object acts as a dataset loader and the primary handle for inspection and conversion.
Loading a dataset is non-destructive and does not modify the source files.
Curated API Surface (brkraw.api)¶
For scripts and notebooks, BrkRaw also provides a curated, lazily-imported API
surface under brkraw.api. This is a convenient way to access “manager”
modules (addons/hooks) and resolver modules without importing deep internal
paths.
Example:
from brkraw.api import BrukerLoader
from brkraw.api import addon_manager, hook_manager
loader = BrukerLoader("/path/to/study")
hooks = hook_manager.list_hooks()
addons = addon_manager.list_installed()
Remapper/spec utilities (spec loading, context maps) are also exposed:
from brkraw.api import addon as remapper
context_map = remapper.load_context_map("map.yaml")
Recommended workflow¶
- Load a dataset:
loader = brk.load("/path/to/study")
- Inspect the dataset:
info = loader.info(scope="full", as_dict=True)
- Convert a scan:
nii = loader.convert(
scan_id=3,
reco_id=1,
)
- Reuse the same loader instance when converting multiple scans:
for scan_id in loader.avail.keys():
nii = loader.convert(
scan_id=scan_id,
reco_id=1,
)
Reusing the loader avoids repeated dataset discovery and validation, while keeping scan selection explicit at each call.
Notes¶
- Output naming and metadata generation are controlled by configuration
files (
config.yaml) and optionally by acontext_mapYAML passed at runtime. - Extensions are managed as addons (data files) and hooks (Python packages that install namespaced addon assets).