01 DICOM to BIDS
1 This Site is currently under construction!!
2 DICOM-Files
- the raw files from the scanner are DICOM-Files
- not really useful since we need .nifti files for our analysis
3 From Dicom to nifti
Even though we often get the data from the scanner already in BIDS format, there can be cases when you have to do this conversion by yourself. For this, you can use a script from Adam: dcm2bids.sh
(You can find this script here: /shared/website/dcm2bids.sh
)
3.1 About BIDS
Apart from a clear structure that is understandable (for other researchers as well) and standardized, the BIDS format offers further advantages. For example, various BIDS-Apps can perform different steps automatically (e.g. fmriprep), but they require the data to be BIDS-valid).
4 Preparations
4.1 Setting up the directory structure
First, you need to set up the correct structure for the script to run properly later. For this, you:
Create an empty directory named
bids
(right-click,Create New... > Folder
)Create a directory (name can be anything, for example
dicoms
) and copy/paste your folder with the DICOM-Files in this directory
It should look like this:
These two directories (bids
& dicoms
) need to be there for the script to work!
The directory scrips
is not necessary for the script to run, but it may be helpful to gather and safe the scripts and notes that you need during the process from your raw files to the “final” analysis.
4.2 Naming of the nifti files
It is curcial for the BIDS format, that the resulting nifti-files are named properly (see here for the naming convention(s)).
To ensure that later, it might be helpful to write down the proper names for the files before you start the process. This could be done in a simple .txt file, where you specify all the file-names. You can then just open this .txt file and copy/paste the file-names whenever you need them. To have everything at one place, you could save this file in your scripts
folder as well.
4.2.1 Create a naming.txt
navigate to your
scripts
folder, right-click, selectCreate New > Empty File
assign a name (in this case
naming.txt
)fill this text file with the proper, BIDS-conform names for the nifti files and save
Now, you can just open this file when you need to change the name of a nifti.
5 Starting the script
To start the script, you first need to know where the script
dcm2bids.sh
is. In this case it is here:/home/jovyan/Website/scripts/dcm2bids.sh
(you can copy/paste this file to your directory from/shared/website/dcm2bids.sh
, or directly access)Navigate to the location of the script, right-click it, and select
Copy Path(s)
Open a Terminal (icon of a monitor at the bottom left of your screen):
Type
ml freesurfer
and press enterType
bash
, add a space, then right-click and selectPaste
to fill in the path to the script (or type in the path manually)Press
enter
to start the script.
6 (Installing all necessary packages)
It is possible (especially if you start the script for the first time), that some necessary packages are not installed. If this is the case, the script will tell you! If something is missing you´ll be asked, if you want to install these packages. By typing in y
and pressing enter
, the package will get installed (you might have to do this for more than one package):
If there is still a missing package after all “automatic” suggestions of packages to install, it is probably related to dcm2bids_scaffold
(but again, the script will “show” you that there is something missing). In this case, type pip install dcm2bids
and press enter
Now “restart” the script (see 2.d + 2.e):
7 Preparation: Provide Input and Output Directory
With all necessary packages installed, you are asked to provide the path to the nifti directory. It should look like this:
Nifti directory means the directory/folder, where the nifti-files should be saved to. This is our (currently empty) bids folder that we created in the beginning.
To indicate the nifti directory, we either type in the path manually, or get the path by navigating to the directory, right-clicking the bids directory and selecting
Copy Path(s)
(same procedure as when we needed the path of the script)go back to the terminal window where
dcm2bids
is runningright-click and select
Paste
to enter the pathpress enter
Subsequently, you are asked to indicate the dicom directory.
When both paths are set, you are asked to choose a dicom name (basically the files of a participant; in this case, there is only one scanning-session, but if you have more than one subject, you can select the one that you want do process) and it should look like this:
After selecting a subject/dicom name (Press enter
), the script automatically suggest a BIDS “subject id” and asks if it is correct (Watch out! Generally the suggested ID is not BIDS-conform!)
For your data to be BIDS-conform at the end, the “subject id” has to have a structure like this: sub-001, sub-002,… (All necessary information about BIDS can be found here)
If the suggested name is correct, type in y
and press enter
.
If it is not correct, type in n
, press enter
and type in a/the correct subject id Once again, press
enter
As a last preparative step, you are asked, if you would like to change the session folder from ses-1
to another session. If you only have one session, type n
and press enter
If you want to change the session, type y
and provide the name of the sessions (Important: to have/get a BIDS-conform structure at the end, subdirectories for sessions have to be named ses-x
with x
being a number)
Subsequently, you get a short reminder in which directories your files should be stored.
By pressing enter
, the script starts to convert your dicom files to nifti’s. This can take a few seconds - be patient!
8 Assigning nifti’s to directories and adjusting file names
After the script converts the dicom’s to nifti’s, we have to potentially correct automatically assigned names and assign a directory. At the top of the terminal, you always see how many dicoms are left to categorize.
8.1 Possible Actions to perform for a dicom
You can select one of three options for any dicom file (use up-/down arrow key to switch between the options and press enter to confirm your choice):
Keep
: By selecting this option, you tell the script that the suggested name is correct and that you want to assign this file with the shown name to a directory (Since BIDS uses a specific naming convention, you´ll probably need this option only for “additional files”, like files related to denoising, that will be placed in a directory that is more or less independent of the BIDS-Format; see Section 8.3*)Modify Name
: This option tells the script that you want to change the suggested name. This is needed, when the suggested name is not BIDS-conform. After selecting this option (by pressingenter
), you are asked to edit the name. Change the name (first delete the suggested one) to a BIDS-conform filename (Hint: the initially suggested name implies what type of scan it was, so you should be able to easily determine if it was an anatomical scan, which run of a functional scan, or the fieldmap). Using a previously created file with bids-conform names can help avoiding errors and typos here, by just copy/pasting the prepared filenames! After you changed the name, pressenter
to confirmDelete (Do not convert)
: As the name suggests, selecting this option deletes the mentioned file (thus, there will be no corresponding nifti-file!). One case when this is generally used is for theanat-scout
scan that is irrelevant for the preprocessing and analysis, since it is a short scan at the beginning of a scanning session to ensure a proper position of the participant and to adjust the parameters for the actual scans.
8.2 Assigning a file to a directory
After either keeping or modifying the name, you are asked to assign the file to a directory.
You can either:
Keep folder name
: By selecting this option, you accept the suggested directory. In general, the correct directory is already suggested for most files (anatomicalanat
, functionalfunc
, fieldmapfmap
)Modify folder name
: This option is only needed for files that were acquired “additionally”, for example, when a denoising sequence was used (files with.ph
at the end, see here). As for the file name, you can edit the name of the directory after selecting this option. Entering a new/unique name for the directory here will result in an additional sub-directory in the subsequent BIDS-directory (if you enter the same name for all “additional” files, they will all be stored in this specified directory)
8.3 The “extra” directory
Sometimes we acquire files that are not part of the BIDS-Format (and, more importantly, are not used by BIDS-Apps), for example when running a denoising sequence during acquisition of the data. In the example of a denoising sequence, corresponding files are named with _ph
at the end. When asked about the filename, we can just keep it as it is, since we use these files separately anyway.
Important!!
Those files have to be stored in a different directory! Thus, when asked about where to assign the file, we select Modify folder name
. All “additional” files can be saved in a directory named extra
(extra
and press enter
)
After assigning the last file to its directory, you´ll see the information, that an additional file has been created, which we will use later. The script has finished:
9 The resulting BIDS-directory
This is how your bids-directory (which was initially created as an empty directory) should look like:
When you enter the sub-999
directory, you´ll find the sub-directory ses-1
(or whatever session you specified during the preparation). Inside, all sub-directories that you selected/edited to assign the files to are listed:
Each of these sub-directories contains all the files that you assigned, including the .nii.gz
and a .json
file
10 Edit “IntendedFor”-Section in the fmap
Before you continue, there is one last potential adaptation that should be considered.
With changing Versions of BIDS and BIDS-Apps, slight changes occur in how and where you have to include specific information. One example for this is the IntendedFor
information in the fmap’s .json
file.
Depending on the Version of fmriprep you plan to use, it may be necessary to change the IntendedFor
field of the fmap’s .json file! The steps described below have to be done if you want to use fmriprep 24.0.0 or newer! (If you use an older Version, you don´t have to do the described steps)
Navigate to your
bids
directoryOpen the file
sub-999-bidsurifmap.json
(double click, or right-click +gedit
)Select all content and copy it (since Strg + c/v does not always work, you can use right-click and select
copy
)Navigate to the
fmap
directory (*/bids/sub-999/ses-1/fmap/
) and open the.json
fileAfter the file opens, scroll down to the very end of it. There should be a section that starts with
IntendedFor
and looks like this:Remove all lines within the brackets after
"IntendedFor"
and paste the lines you copied from thebidsurifmap.json
file. Remember to end every (but the last) line with a comma (,
)!! It might also be good to keep the indentation at the beginning of each line (4 Spaches). At the end, it should look like this:
Don´t forget to save the file afterwards!!!
11 Congratuliations, you did it!
Congratulations! You successfully finished the process of converting your DICOM to nifti files in BIDS-Format and you are one step closer to analyzing your data!
Please return to the Overview-Page to check what to do next.
Alternatively, here is a list of potential next steps to continue with