Tools to convert LSL + friends automatically to BIDS, and upload it to a Dataverse
Get started with LSLAutoBIDS by installing the package and its dependencies.
This package automates the conversion of xdf files to BIDS format and uploads the data to a dataverse. The package is written in python and uses the pyxdf library to convert the xdf files to BIDS and the pyDataverse library to upload the data to the dataverse.
git clone https://github.com/s-ccs/LSLAutoBIDS.git
It is advised to install the requirements in a seperate conda environment.
Note
If you are using conda, you can create a new conda environment using the following command and activate it.
conda create -n <ENV_NAME> python=3.12
conda activate <ENV_NAME>
Install the requirements using the following command inside the conda environment.
python -m pip install -r requirements.txt
Install the datalad library using the following command:
conda install -c conda-forge datalad
If you donot have git and git-annex installed in your Operating System, you can install it seperately using the datalad-installer.
Dataset refers to the recorded eeg data in the xdf format.
A BIDS compliant dataset/project is organized in a specific directory structure.
- The project root location is the root directory where all the recording are stored under a
<projectname>
directory. - The project stimuli root location is the directory where the experiments and behavioral files are stored under a
<projectname>
directory. - The BIDS root location is the directory where the converted BIDS data is stored under a
<projectname>
directory.
You can read more about the project data and file organization in the data_organization section.
Important
Please follow the BIDS data organization structure for storing the data in the projectfolder
. The BIDS conversion guidelines are based on the recommended directory/files structure. You only can change the location of the root directories according to your preference. You must also strictly follow the naming convention for the project and subject subdirectories.
For convenience, we have provided a recommended project organization structure for the root directories to organize the data better. You can directory skip to the configuration section if you are not following the recommended directory structure.
Important
The recommended directory structure is not self generated. The user needs to create the directories and store the recorded and stimulus data in them.
The dataset (both recorded and converted) is stored in the parent data
directory. The data
directory has three subdirectories under which the project data is stored. The recommended directory structure is as follows:
data
├── bids # Converted BIDS data
├── projectname1
├── projectname2
├── project_stimulus # Experimental files
├── projectname1
├── projectname2
├── projects
├── projectname1 # Raw data
├── projectname2
This data
directory can be in the current project or home directory as per choice.
Here ./data/projects/
, ./data/project_stimulus/
, ./data/bids/
are the root project directories. Each of this root directories will have a project name directory inside it and each project directory will have a subdirectory for each subject. The organization of the files under the projectname directory is in the data_organization file.
TODO: For convenience there are some sample data in the sample folder. You can copy the sample data to the data
directory and run the scripts to see how the scripts work.
This configuration is required to run the scripts. This scripts are to run from inside the LSLAutoBIDS
directory.
- AutoBIDS Project Configuration : This is to be done only once for all the projects if the dataverse and the root directory is the same.
- Run the command below to create a configuration file template in folder.
python gen_dv_config.py
The config will be created in the ~/.config/lslautobids/config.yaml file. This file will have the dataverse details and the root directories for the projects. .
- Edit the file
autobids_config.yaml
to add the dataverse details. Here the dataverse credentials and the root directories needs to be added.
This will be mostly same for all the projects, thus creating only once per system is recommended.
- Project Configuration : This is to be done once for each new project. This store the project details like project name, project id, project description etc.
- Run the command below to create a configuration file template in
/projects/<PROJECT_NAME>/
folder (according to the selected root directories).
python gen_project_config.py -p <PROJECT_NAME> -s yes
Flags:
- -p : Project name (required)
- -s : toml_file standalone (optional)
- Edit the configuration file in the
projects/<PROJECT_NAME>
folder to add the project details for the project if not used the standalone version.
The conversion involves checking for new files to be converted, converting the files to BIDS and uploading the data to the dataverse.
Run the following command to convert and upload the raw files.
python lsl_autobids/main.py -p <PROJECT_NAME>
The -p
flag is used to specify the project name. The project name is the name of the project directory in the projects
directory.
│
- https://earthly.dev/blog/python-makefile/
- https://github.com/AUSSDA//
- dataverse2021_automation-with-pydataverse/tree/master
- https://psychoinformatics-de.github.io/rdm-course/02-structuring-data/index.html