Post-hoc BIDS conversion for NIfTI datasets and neurobehavioral logs.
Project description
NIfTI2BIDS
A toolkit for post-hoc BIDS conversion of legacy or unstructured NIfTI datasets. Intended for cases that require custom code and flexibility, such as when NIfTI source files lack consistent naming conventions, organized folder hierarchies, or sidecar metadata. Includes utilities for metadata reconstruction from NIfTI headers, file renaming, neurobehavioral log parsing (for E-Prime and Presentation), and JSON sidecar generation.
Installation
Standard Installation
pip install nifti2bids[all]
Development Version
git clone --depth 1 https://github.com/donishadsmith/nifti2bids/
cd nifti2bids
pip install -e .[all]
Features
-
File renaming: Convert arbitrary filenames to BIDS-compliant naming
-
File creation: Generate
dataset_description.jsonandparticipants.tsv -
Metadata utilities: Extract header metadata (e.g., TR, orientation, scanner info) and generate slice timing for singleband and multiband acquisitions
-
Log parsing: Load Presentation (e.g.,
.log) and E-Prime 3 (e.g,.edat3,.txt) files as DataFrames, or use extractor classes to generate BIDS events for block and event designs:Class Software Design Description PresentationBlockExtractorPresentation Block Extracts block-level timing with mean RT and accuracy PresentationEventExtractorPresentation Event Extracts trial-level timing with individual responses EPrimeBlockExtractorE-Prime 3 Block Extracts block-level timing with mean RT and accuracy EPrimeEventExtractorE-Prime 3 Event Extracts trial-level timing with individual responses -
Auditing: Generate a table of showing the presence or abscence of certain files for each subject and session
-
QC: Creation and computation of certain quality control metrics (e.g., framewise displacement)
Quick Start
Creating BIDS-Compliant Filenames
from nifti2bids.bids import create_bids_file
create_bids_file(
src_file="101_mprage.nii.gz",
subj_id="101",
ses_id="01",
desc="T1w",
dst_dir="/data/bids/sub-101/ses-01/anat",
)
Extracting Metadata from NIfTI Headers
from nifti2bids.metadata import get_tr, create_slice_timing, get_image_orientation
tr = get_tr("sub-01_bold.nii.gz")
slice_timing = create_slice_timing(
"sub-01_bold.nii.gz",
slice_acquisition_method="interleaved",
multiband_factor=4,
)
orientation_map, orientation = get_image_orientation("sub-01_bold.nii.gz")
Loading Raw Log Files
from nifti2bids.parsers import (
load_presentation_log,
load_eprime_log,
convert_edat3_to_txt,
)
presentation_df = load_presentation_log("sub-01_task.log", convert_to_seconds=["Time"])
# E-Prime 3: convert .edat3 to text first, or load .txt directly
eprime_txt_path = convert_edat3_to_txt("sub-01_task.edat3")
eprime_df = load_eprime_log(eprime_txt_path, convert_to_seconds=["Stimulus.OnsetTime"])
Creating BIDS Events from Presentation Logs
from nifti2bids.bids import PresentationBlockExtractor
import pandas as pd
extractor = PresentationBlockExtractor(
"sub-01_task-faces.log",
block_cue_names=("Face", "Place"), # Can use regex ("Fa.*", "Pla.*")
scanner_event_type="Pulse",
scanner_trigger_code="99",
convert_to_seconds=["Time"],
rest_block_codes="crosshair",
rest_code_frequency="fixed",
split_cue_as_instruction=True,
)
events_df = pd.DataFrame(
{
"onset": extractor.extract_onsets(),
"duration": extractor.extract_durations(),
"trial_type": extractor.extract_trial_types(),
"mean_rt": extractor.extract_mean_reaction_times(),
}
)
Creating BIDS Events from E-Prime Logs
from nifti2bids.bids import EPrimeEventExtractor
import pandas as pd
extractor = EPrimeEventExtractor(
"sub-01_task-gonogo.txt",
trial_types="Go|NoGo", # Can also use ("Go", "NoGo")
onset_column_name="Stimulus.OnsetTime",
procedure_column_name="Procedure",
trigger_column_name="ScannerTrigger.RTTime",
convert_to_seconds=[
"Stimulus.OnsetTime",
"Stimulus.OffsetTime",
"ScannerTrigger.RTTime",
],
)
events_df = pd.DataFrame(
{
"onset": extractor.extract_onsets(),
"duration": extractor.extract_durations(
offset_column_name="Stimulus.OffsetTime"
),
"trial_type": extractor.extract_trial_types(),
"reaction_time": extractor.extract_reaction_times(
reaction_time_column_name="Stimulus.RT"
),
}
)
Audit BIDS Dataset
from nifti2bids.audit import BIDSAuditor
from nifti2bids.simulate import simulate_bids_dataset
bids_root = simulate_bids_dataset()
auditor = BIDSAuditor(bids_root)
auditor.check_raw_nifti_availability()
auditor.check_raw_sidecar_availability()
auditor.check_events_availability()
auditor.check_preprocessed_nifti_availability()
analysis_dir = bids_root / "first_level"
analysis_sub_dir = analysis_dir / "sub-1" / "ses-1"
analysis_sub_dir.mkdir(parents=True, exist_ok=True)
with open(analysis_sub_dir / "sub-1_task-rest_desc-betas.nii.gz", "w") as f:
pass
auditor.check_first_level_availability(analysis_dir=analysis_dir, desc="betas")
Compute QC
from nifti2bids.qc import create_censor_mask, compute_consecutive_censor_stats
censor_mask = create_censor_mask(
"confounds.tsv",
column_name="framewise_displacement",
threshold=0.5,
n_dummy_scans=4,
)
consecutive_censor_mean, consecutive_censor_std = compute_consecutive_censor_stats(
censor_mask, n_dummy_scans=4
)
See the API documentation for full parameter details and additional utilities.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nifti2bids-0.17.3.tar.gz.
File metadata
- Download URL: nifti2bids-0.17.3.tar.gz
- Upload date:
- Size: 57.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fd28fbca01d2eb90ecf5f4e6571d19ccb6c50606db9b6a771711d7b10b3097b9
|
|
| MD5 |
f2206dcf5071de47a9920f1d87fe179b
|
|
| BLAKE2b-256 |
f6b1d87842eb389388e05f264d797bbea8cc0122c12cedcd5f6ae9221299c60e
|
File details
Details for the file nifti2bids-0.17.3-py3-none-any.whl.
File metadata
- Download URL: nifti2bids-0.17.3-py3-none-any.whl
- Upload date:
- Size: 51.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f5c2be063f19c09c6d462853a3bf99880a2de14020c416525087e7175e881e97
|
|
| MD5 |
6235f3766f038325c50ee2949802ca09
|
|
| BLAKE2b-256 |
ce1d19f317a644e38319ab9c70b77864d7dca28618171d8b8faf93fb37f134fa
|