Skip to content

Pneumaethylamine/CopBET

 
 

Repository files navigation

Copenhagen Brain Entropy Toolbox

The Copenhagen Brain Entropy Toolbox is a MATLAB toolbox that provides a collection of functions for evaluating 12 different entropy metrics described in the paper Navigating the chaos of psychedelic neuroimaging: A multi-metric evaluation of acute psilocybin effects on brain entropy" by Drummond McCulloch, Anders S Olsen et al (MedRxiv). This toolbox allows researchers to analyze and quantify the entropy of fMRI-recorded brain activity using various methods.

Installation

To use the Copenhagen Brain Entropy Toolbox, follow the steps below:

  1. Clone this repository to your local machine:

    git clone https://github.com/anders-s-olsen/CopBET.git
  2. Add the toolbox directory to your MATLAB path using the addpath function:

    addpath(genpath('/path/to/CopBET');)

Usage

The toolbox provides a set of MATLAB functions that can be used to evaluate different entropy metrics on brain data. The functions take either a matrix (time by regions) or a table in which the first column of the table contains matrices of size (time by regions) as input. The output will always be a table with a column with the name "entropy". The functions have an option to keep the input table information in the output, thus adding a new entropy-column to the existing table. Note that three functions need voxel-wise input data and thus, the input data for these should be either a char or a table or chars of the path to the (denoised) 4D-volumes for the corresponding subject. These functions also require an atlas (in the same space!) to be specified. Here's an example of how to use the toolbox:

% Load your brain data (i.e., time series)
data1 = load('brain_data1.mat'); %subject 1
data2 = load('brain_data2.mat'); %subject 2

% Structure the data in a table:
tbl = table;
tbl.data{1} = data1;
tbl.data{2} = data2;
tbl.subject = [1;2];

% Compute entropy using a specific metric, specifying to add entropy
% as a new column in the existing table and to parallelize computation.
tbl = CopBET_FUNCTION(tbl, 'keepdata',true,'parallel',true);

Replace 'CopBET_FUNCTION' with the name of the desired entropy metric:

  • CopBET_DCC_entropy
  • CopBET_degree_distribution_entropy
  • CopBET_diversity_coefficient
  • CopBET_geodesic_entropy
  • CopBET_intranetwork_synchrony
  • CopBET_LEiDA_transition_entropy
  • CopBET_metastate_series_complexity
  • CopBET_motif_connectivity_entropy
  • CopBET_sample_entropy
  • CopBET_temporal_entropy
  • CopBET_time_series_complexity
  • CopBET_von_Neumann_entropy

The functions that require voxel-wise input data and a specified atlas are 'CopBET_intranetwork_synchrony', 'CopBET_motif_connectivity_entropy', and 'CopBET_sample_entropy'. Please refer to the paper for more details on available metrics and their usage. Note that while some functions return scalar entropy values per row in the input table, some return a vector or matrix of entropy values, which may need to be further processed afterwards for e.g., plotting. For example, CopBET_degree_distribution_entropy returns an entropy value for each "mean degree".

Please note that the MATLAB-functions in this toolbox have been implemented to mimic the behavior of the methods presented by the papers from where they were introduced. Thus, some functions may include some odd modeling decisions, and only a few function-specific input parameters have been implemented. For example, in CopBET_degree_distribution_entropy, a static connectivity matrix is established and non-significant correlation coefficients set to zero, while in CopBET_geodesic_entropy, which also establishes a static connectivity matrix, no extra thresholding is applied. We hope to be able to implement further modeling decisions as inputs to the functions in the future. For now, we advise users who wish to employ these functions to look through them carefully, perhaps extracting/altering some pieces of the code.

Example script

We have posted a script CopBET_main_CH2016data showing examples of how to use the functions with the openly available acute IV LSD dataset https://openneuro.org/datasets/ds003059. The script can either be used with the example data in this repostitory, or with the full LSD dataset, which would then be assumed to be present in the CopBET/LSDdata folder. Please follow the dedicated script CopBET/LSDdata/LSDdata_roi.m to extract ROI-information for each of the atlases in the CopBET_Atlases folder after downloading the full data set.

Atlases

We have provided a folder with all the atlases that we used in our paper to replicate previous studies in 2mm MNI-152 space. These atlases may be used in conjunction with the LSD dataset. For the analyses in our paper we stripped away cerebellar ROIs due to inconsistent inclusion in the field of view. Neither the cerebellum-removed atlases nor any of our own data are available in this repository.

Statistics

In the statistics folder, an R-function permlme.R is included which contains the permutation testing function used in the statistics section of our paper.

MATLAB versions and dependencies

The toolbox has been tested on MATLAB R2018b. It doesn't work on R2017b due to the way matlab tables are used. The toolbox include the external dependencies Brain Connectivity toolbox (2019_03_03), the complexity toolbox (LOFT) and the DCC toolbox (the original one from 2014)

Contributing

Please email Anders S. Olsen (ansol@dtu.dk) if you would like to contribute to the toolbox or otherwise have comments and questions to the code not answered in the paper.

References

If you use the Copenhagen Brain Entropy Toolbox in your research, please cite the following paper:

Drummond McCulloch, Anders S Olsen, et al. "Navigating the chaos of psychedelic neuroimaging: A multi-metric evaluation of acute psilocybin effects on brain entropy". (MedRxiv), 2023.

Repo Version

1.0.0 June 21st 2023 - Initial commit

License

Copyright (C) 2023 Drummond E-Wen McCulloch & Anders Stevnhoved Olsen

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see http://www.gnu.org/licenses/.

About

Copenhagen brain entropy toolbox

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • MATLAB 94.4%
  • R 5.6%