When labs organize datasets in different ways time is often wasted rewriting scripts to expect a particular structure. BIDS solves this problem by standardizing the organization of neuroimaging data. BIDS is nothing more than a prescribed directory structure and file naming convention, but it allows labs to more easily share datasets and processing pipelines, interact with the dataset programmatically via pybids, and run all the most popular neuroimaging tools ("BIDS Apps") in a consistent way.
Although it's possible to manually organize NIFTIs into the BIDS structure, doing so is error-prone and inefficient. Manual organization may be the only option if dicoms aren't available, but otherwise you can use heudiconv to automatically format the produced NIFTIs according to BIDS.
Unlike dcm2niix
which can simply be fed a directory of dicoms, heudiconv requires a bit more setup. First, your dicoms be organized either by StudyUID or accession_number. Then, you need to run heudiconv with the -c none -f convertall
options to generate TSVs with dicom metadata needed to write a heuristic.
For example,
heudiconv \
-d "/path/to/data/{subject}/{session}/*.dcm" \
-o /path/to/output \
-f convertall \
-s 001 -ss abc -c none -b -g accession_number
There will now be a hidden .heudiconv directory with dicom header TSVs. Once you've determined which dicoms go where, write a heuristic then use the -c dcm2niix
option to tell heudiconv to do the actual dcm2niix conversion.
heudiconv \
-d "/path/to/data/{subject}/{session}/*.dcm" \
-o /path/to/output \
-f /path/to/your_heuristic.py \
-s 001 -ss abc -c dcm2niix -b -g accession_number