Changes for page User Story: TVB
                  Last modified by ldomide on 2024/05/20 08:51
              
      Summary
- 
          Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
- 
      - Content
-   ... ... @@ -4,8 +4,10 @@ 4 4 ((( 5 5 = From MRI to personalized brain simulation = 6 6 7 -Here we explain step by step how to use TVB tools for end-to-end personalized brain simulation. We start by finding shared MRI data using KnowledgeGraph, create a brain model from extracted connectomes using TVB pipeline, and simulate neural activity using TVB brain network model simulators. We will use Jupyter notebooks on EBRAINS Collab platforms for frontend operations and supercomputers in the backend for intensive number crunching. 7 +Here we explain step by step how to use The Virtual Brain (TVB) tools for end-to-end personalized brain simulation. We start by finding shared MRI data using KnowledgeGraph, create a brain model from extracted connectomes using TVB pipeline, and simulate neural activity using TVB brain network model simulators. We will use Jupyter notebooks on EBRAINS Collab platforms for frontend operations and supercomputers in the backend for intensive number crunching. 8 8 9 +Overview video: [[https:~~/~~/youtu.be/_G_DjRb1ams>>https://youtu.be/_G_DjRb1ams||rel=" noopener noreferrer" target="_blank"]] 10 + 9 9 [[image:export_overview_new2.png]] 10 10 ))) 11 11 ))) ... ... @@ -19,9 +19,9 @@ 19 19 As a first step we browse through KnowledgeGraph in order to find a suitable dataset to construct a brain model. The dataset must contain diffusion-weighted MRI data, in order to extract a structural connectome, which will form the basis of a brain network model. Structural connectivity extracted from diffusion MRI is used to quantify how strongly brain regions interact in the brain model. Next, the data set must contain functional MRI (fMRI) data, because a common approach is to tune the parameters of the brain model such that the simulated fMRI functional connectivity fits with the empirical fMRI data. For fitting, we usually compute functional connectivity matrices from simulated and empirical data. Finally, we need anatomical T1-weighted MRI to extract cortical surfaces and to perform a parcellation of the brain into different regions. 20 20 21 21 22 -* Open KG in browser: [[https:~~/~~/kg.ebrains.eu/search/>>url:https://kg.ebrains.eu/search/||rel=" 23 -* Browse through KG and look for a data set that contains the above-mentioned MRI modalities. To find a suitable data set you may use the “Filter” sidebar on the left and e.g. select “Homo sapiens” or “magnetic resonance imaging”. In the following we are going to use the data set “Individual Brain Charting: ARCHI Social”. [[https:~~/~~/kg.ebrains.eu/search/instances/Dataset/f8c40aadc4939ad493bf7c839b82cb40>>https://kg.ebrains.eu/search/instances/Dataset/f8c40aadc4939ad493bf7c839b82cb40||rel=" 24 -* The data-set can be downloaded from [[https:~~/~~/openneuro.org/datasets/ds000244/versions/1.0.0>>url:https://openneuro.org/datasets/ds000244/versions/1.0.0||rel=" 24 +* Open KG in browser: [[https:~~/~~/kg.ebrains.eu/search/>>url:https://kg.ebrains.eu/search/||rel="noopener noreferrer" target="_blank"]] 25 +* Browse through KG and look for a data set that contains the above-mentioned MRI modalities. To find a suitable data set you may use the “Filter” sidebar on the left and e.g. select “Homo sapiens” or “magnetic resonance imaging”. In the following we are going to use the data set “Individual Brain Charting: ARCHI Social”. [[https:~~/~~/kg.ebrains.eu/search/instances/Dataset/f8c40aadc4939ad493bf7c839b82cb40>>https://kg.ebrains.eu/search/instances/Dataset/f8c40aadc4939ad493bf7c839b82cb40||rel="noopener noreferrer" target="_blank"]] 26 +* The data-set can be downloaded from [[https:~~/~~/openneuro.org/datasets/ds000244/versions/1.0.0>>url:https://openneuro.org/datasets/ds000244/versions/1.0.0||rel="noopener noreferrer" target="_blank"]] 25 25 26 26 [[image:img1.png]] 27 27 ... ... @@ -30,7 +30,7 @@ 30 30 [[image:tree.png]] 31 31 32 32 * We now have an MRI dataset in BIDS format. The next step is to compress the folder (e.g. as a .zip or .tar.gz file) so that we can upload it as a single file to the EBAINS Collaboratory and later to the supercomputer. In the next steps, we are going to use diffusion MRI tractography to reconstruct white matter fiber pathways and to estimate coupling weights between brain regions. 33 -* Open the TVB Pipeline EBRAINS Collab: [[https:~~/~~/wiki.ebrains.eu/bin/view/Collabs/tvb-pipeline/>>url:https://wiki.ebrains.eu/bin/view/Collabs/tvb-pipeline/||rel=" 35 +* Open the TVB Pipeline EBRAINS Collab: [[https:~~/~~/wiki.ebrains.eu/bin/view/Collabs/tvb-pipeline/>>url:https://wiki.ebrains.eu/bin/view/Collabs/tvb-pipeline/||rel="noopener noreferrer" target="_blank"]] 34 34 * The pipeline is implemented in the form of a Jupyter notebook that shows how to upload data from local filesystem to EBRAINS drive; how to copy the data to the supercomputer; how to run the three docker containers that perform the processing; how to download results to local filesystem. 35 35 * In order to use EBRAINS Collab software, it is necessary to download the notebook, create a new Collab, and upload the notebook there. The process is described on the main Collab page and in the notebook. 36 36 * For brain simulation the most important result of tractography is the structural connectome (SC), which consists of the coupling strengths matrix and the distances matrix. The former quantifies the strength of interaction between each pair of brain regions and the latter contains the average length of the respective fiber bundle. The exported SC can be directly imported to TVB: as one of the last steps of the pipeline, the SC was stored along with other data that can be read by TVB in the file "TVB_output.zip". Within that ZIP archive is the file “sub-<participant_label>_Connectome.zip”, which can be used to set up a brain network model in the other TVB workflows. ... ... @@ -39,14 +39,14 @@ 39 39 40 40 == The Virtual Brain: Simulate brain activity == 41 41 42 -The Virtual Brain is the main TVB software package. It is a neuroinformatics platform that provides an ecosystem of tools for simulating and analysing large-scale brain network dynamics based on biologically realistic connectivity. TVB can be operated via GUI and programmatic Python interface. On the HBP Collaboratory Platform TVB Simulator usage is introduced through IPython Notebooks. Additionally, the TVB GUI can be directly accessed as a Web App ([[https:~~/~~/thevirtualbrain.apps.hbp.eu/user/profile>>url:https://thevirtualbrain.apps.hbp.eu/user/profile||rel=" 44 +The Virtual Brain is the main TVB software package. It is a neuroinformatics platform that provides an ecosystem of tools for simulating and analysing large-scale brain network dynamics based on biologically realistic connectivity. TVB can be operated via GUI and programmatic Python interface. On the HBP Collaboratory Platform TVB Simulator usage is introduced through IPython Notebooks. Additionally, the TVB GUI can be directly accessed as a Web App ([[https:~~/~~/thevirtualbrain.apps.hbp.eu/user/profile>>url:https://thevirtualbrain.apps.hbp.eu/user/profile||rel="noopener noreferrer" target="_blank"]]). Via the Web App users can configure simulations that are – depending on their complexity – either simulated directly on the web server or on a supercomputer, thereby making resource-consuming TVB functionality accessible to researchers that do not have access to supercomputers. Compiled standalone versions of the main software package can be downloaded from thevirtualbrain.org. In the following we take you through the main steps of brain network model simulation. 43 43 44 -* Construct and downloaded the structural connectivity generated with the TVB pipeline. Alternatively, you can use demo SC that is shipped with the main TVB package. Next, go to the TVB Collaboratory and work through the example “Load TVB Connectivity”: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15645>>url:https://collab.humanbrainproject.eu/#/collab/1609/nav/15645||rel=" 46 +* Construct and downloaded the structural connectivity generated with the TVB pipeline. Alternatively, you can use demo SC that is shipped with the main TVB package. Next, go to the TVB Collaboratory and work through the example “Load TVB Connectivity”: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15645>>url:https://collab.humanbrainproject.eu/#/collab/1609/nav/15645||rel="noopener noreferrer" target="_blank"]] 45 45 * Having loaded the SC, next work through the basic process of setting up a simulation, see 46 -** Simulate with the reduced Wong-Wang model: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15656>>url:https://collab.humanbrainproject.eu/#/collab/1609/nav/15656||rel=" 47 -** Simulate with Jansen Rit Model: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15654>>https://collab.humanbrainproject.eu/#/collab/1609/nav/15654||rel=" 48 -* Next, explore how you can output BOLD activity using the BOLD monitor: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15660>>url:https://collab.humanbrainproject.eu/#/collab/1609/nav/15660||rel=" 49 -* Having simulated a longer time series (at least a few minutes of activity) you can compute a functional connectivity matrix following the examples here: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15657>>url:https://collab.humanbrainproject.eu/#/collab/1609/nav/15657||rel=" 48 +** Simulate with the reduced Wong-Wang model: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15656>>url:https://collab.humanbrainproject.eu/#/collab/1609/nav/15656||rel="noopener noreferrer" target="_blank"]] 49 +** Simulate with Jansen Rit Model: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15654>>https://collab.humanbrainproject.eu/#/collab/1609/nav/15654||rel="noopener noreferrer" target="_blank"]] 50 +* Next, explore how you can output BOLD activity using the BOLD monitor: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15660>>url:https://collab.humanbrainproject.eu/#/collab/1609/nav/15660||rel="noopener noreferrer" target="_blank"]] 51 +* Having simulated a longer time series (at least a few minutes of activity) you can compute a functional connectivity matrix following the examples here: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/1609/nav/15657>>url:https://collab.humanbrainproject.eu/#/collab/1609/nav/15657||rel="noopener noreferrer" target="_blank"]] 50 50 51 51 Congratulations, you performed your first brain simulation. You may now want to play with parameters and look how it affects the simulated FC – a goal may be to maximize the fit between simulated and empirical FC. Often a good first step is to vary the global coupling scaling factor: start at a low value (little exchange of synaptic currents between brain regions) and then increase until fMRI time series of the different brain regions become increasingly correlated. 52 52 ... ... @@ -55,18 +55,18 @@ 55 55 56 56 In the previous step we simulated the brain at a coarse spatial resolution: the macroscopic scale of brain regions (e.g. “M1”, “V1”, etc.) and long-range white matter fiber bundles. However, interesting computations often happen on smaller scales, like the mesoscopic scale of small neural populations or the microscopic scale of individual neurons and neural networks. TVB+NEST is a Python toolbox that makes it easier to simulate multi-scale networks, i.e., networks, where one part simulates activity on a coarse scale and another part simulates activity on a finer scale. Essentially, TVB+NEST is a Python wrapper for The Virtual Brain neuroinformatics platform and the NEST spiking network simulator. TVB+NEST exists as a web app and a download version. The web app runs on HBP computers, while the download version is implemented as standalone Docker container that can be downloaded. To run TVB+NEST follow the instructions here: 57 57 58 -[[https:~~/~~/collab.humanbrainproject.eu/#/collab/19/nav/2108?state=software,TVB%20and%20NEST%202>>url:https://collab.humanbrainproject.eu/#/collab/19/nav/2108?state=software,TVB%20and%20NEST%202||rel=" 60 +[[https:~~/~~/collab.humanbrainproject.eu/#/collab/19/nav/2108?state=software,TVB%20and%20NEST%202>>url:https://collab.humanbrainproject.eu/#/collab/19/nav/2108?state=software,TVB%20and%20NEST%202||rel="noopener noreferrer" target="_blank"]] 59 59 60 60 or directly open the App at 61 61 62 -[[https:~~/~~/tvb-nest.apps.hbp.eu/>>url:https://tvb-nest.apps.hbp.eu/||rel=" 64 +[[https:~~/~~/tvb-nest.apps.hbp.eu/>>url:https://tvb-nest.apps.hbp.eu/||rel="noopener noreferrer" target="_blank"]]. 63 63 64 64 Alternatively, download the standalone Docker container thevirtualbrain/tvb-nest from Dockerhub. In the previous sections you may have simulated a large-scale brain model, but are now interested how large-scale activity affects finer-scale activity in a specific region. To familiarize yourself with TVB+NEST, you may read through the following tutorials. 65 65 66 -* Test the TVB+NEST installation: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/58136/nav/396829>>url:https://collab.humanbrainproject.eu/#/collab/58136/nav/396829||rel=" 67 -* Run a custom co-simulation: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/58136/nav/41768>>url:https://collab.humanbrainproject.eu/#/collab/58136/nav/417686||rel=" 68 -* How to run a co-simulation from a notebook: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/58136/nav/531966>>url:https://collab.humanbrainproject.eu/#/collab/58136/nav/531966||rel=" 69 -* Run a notebook from storage: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/58136/nav/482634>>url:https://collab.humanbrainproject.eu/#/collab/58136/nav/482634||rel=" 68 +* Test the TVB+NEST installation: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/58136/nav/396829>>url:https://collab.humanbrainproject.eu/#/collab/58136/nav/396829||rel="noopener noreferrer" target="_blank"]] 69 +* Run a custom co-simulation: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/58136/nav/41768>>url:https://collab.humanbrainproject.eu/#/collab/58136/nav/417686||rel="noopener noreferrer" target="_blank"]] 70 +* How to run a co-simulation from a notebook: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/58136/nav/531966>>url:https://collab.humanbrainproject.eu/#/collab/58136/nav/531966||rel="noopener noreferrer" target="_blank"]] 71 +* Run a notebook from storage: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/58136/nav/482634>>url:https://collab.humanbrainproject.eu/#/collab/58136/nav/482634||rel="noopener noreferrer" target="_blank"]] 70 70 71 71 == Fast_TVB: Fast and parallel simulation == 72 72 ... ... @@ -74,14 +74,14 @@ 74 74 75 75 To perform a dense parameter space exploration or to simulate high-dimensional models (e.g. with the number of network nodes N > 10^^3^^) high performance simulation codes are necessary. For the ReducedWongWang model a high-performance C-version of the TVB simulator core is implemented as a Docker container: 76 76 77 -[[https:~~/~~/hub.docker.com/r/thevirtualbrain/fast_tvb>>url:https://hub.docker.com/r/thevirtualbrain/fast_tvb||rel=" 79 +[[https:~~/~~/hub.docker.com/r/thevirtualbrain/fast_tvb>>url:https://hub.docker.com/r/thevirtualbrain/fast_tvb||rel="noopener noreferrer" target="_blank"]] 78 78 79 79 The EBRAINS Collaboratory “TVB C ~-~- High-speed parallel brain network models” explains how to use the container on supercomputer backends with a Jupyter notebook as frontend: 80 80 81 -[[https:~~/~~/wiki.ebrains.eu/bin/view/Collabs/tvb-c-high-speed-parallel-brain-network->>url:https://wiki.ebrains.eu/bin/view/Collabs/tvb-c-high-speed-parallel-brain-network-||rel=" 83 +[[https:~~/~~/wiki.ebrains.eu/bin/view/Collabs/tvb-c-high-speed-parallel-brain-network->>url:https://wiki.ebrains.eu/bin/view/Collabs/tvb-c-high-speed-parallel-brain-network-||rel="noopener noreferrer" target="_blank"]] 82 82 83 -* Open the “TVB C ~-~- High-speed parallel brain network models” Collab: [[https:~~/~~/wiki.ebrains.eu/bin/view/Collabs/tvb-c-high-speed-parallel-brain-network>>url:https://wiki.ebrains.eu/bin/view/Collabs/tvb-c-high-speed-parallel-brain-network-||rel=" 84 -* Follow the instructions in the Collab notebook or at [[https:~~/~~/hub.docker.com/r/thevirtualbrain/fast_tvb>>url:https://hub.docker.com/r/thevirtualbrain/fast_tvb||rel=" 85 +* Open the “TVB C ~-~- High-speed parallel brain network models” Collab: [[https:~~/~~/wiki.ebrains.eu/bin/view/Collabs/tvb-c-high-speed-parallel-brain-network>>url:https://wiki.ebrains.eu/bin/view/Collabs/tvb-c-high-speed-parallel-brain-network-||rel="noopener noreferrer" target="_blank"]] 86 +* Follow the instructions in the Collab notebook or at [[https:~~/~~/hub.docker.com/r/thevirtualbrain/fast_tvb>>url:https://hub.docker.com/r/thevirtualbrain/fast_tvb||rel="noopener noreferrer" target="_blank"]] to set up a brain model, simulate it and collect the results. 85 85 * Simulations are more efficient when only a single thread is created, but faster for multiple threads. Play around with the num_threads parameter and compare the execution speeds for different settings. If execution speed is the primary goal a higher number of threads is advised, if efficiency during parameter space exploration is the goal, then it is advised to use multiple single-threaded instances of the program. 86 86 87 87 == TVB-HPC: High-performance computing == ... ... @@ -88,18 +88,18 @@ 88 88 89 89 In this project a toolbox has been created that supports the efficiently port TVB neural mass models between different computing architectures. This addresses the need that most models simulated in TVB are written in Python, and most of them have not yet been optimized for parallel execution or deployment on high-performance computing architectures. At the heart of this project is the development of a domain-specific language (DSL) that lets us define TVB models in a structured language that allows automatic code generation. Based on the model description computing code for different environments or hardware is automatically generated. 90 90 91 -In order to implement your own model in TVB-HPC DSL you may first familiarize yourself with the DSL and how to define models in it: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/80668/nav/546280>>url:https://collab.humanbrainproject.eu/#/collab/80668/nav/546280||rel=" 93 +In order to implement your own model in TVB-HPC DSL you may first familiarize yourself with the DSL and how to define models in it: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/80668/nav/546280>>url:https://collab.humanbrainproject.eu/#/collab/80668/nav/546280||rel="noopener noreferrer" target="_blank"]]. As a next step, you may go on to learn how to generate CUDA code from your models: [[https:~~/~~/collab.humanbrainproject.eu/#/collab/80715/nav/546614>>url:https://collab.humanbrainproject.eu/#/collab/80715/nav/546614||rel="noopener noreferrer" target="_blank"]]. 92 92 93 93 94 94 == Disease models == 95 95 96 -An advanced application of TVB is the specification of disease models like it was done in this publication by Stefanovski et al.: [[https:~~/~~/www.frontiersin.org/articles/10.3389/fncom.2019.00054/full>>url:https://www.frontiersin.org/articles/10.3389/fncom.2019.00054/full||rel=" 98 +An advanced application of TVB is the specification of disease models like it was done in this publication by Stefanovski et al.: [[https:~~/~~/www.frontiersin.org/articles/10.3389/fncom.2019.00054/full>>url:https://www.frontiersin.org/articles/10.3389/fncom.2019.00054/full||rel="noopener noreferrer" target="_blank"]]. 97 97 98 -[[https:~~/~~/nbviewer.jupyter.org/github/BrainModes/TVB_EducaseAD_molecular_pathways_TVB/blob/master/Educase_AD_study-LS-Surrogate.ipynb>>url:https://nbviewer.jupyter.org/github/BrainModes/TVB_EducaseAD_molecular_pathways_TVB/blob/master/Educase_AD_study-LS-Surrogate.ipynb||rel=" 100 +[[https:~~/~~/nbviewer.jupyter.org/github/BrainModes/TVB_EducaseAD_molecular_pathways_TVB/blob/master/Educase_AD_study-LS-Surrogate.ipynb>>url:https://nbviewer.jupyter.org/github/BrainModes/TVB_EducaseAD_molecular_pathways_TVB/blob/master/Educase_AD_study-LS-Surrogate.ipynb||rel="noopener noreferrer" target="_blank"]] 99 99 100 100 In the INCF training space an extensive tutorial is provided that walks the user through the approach of the paper: 101 101 102 -[[https:~~/~~/training.incf.org/lesson/linking-molecular-pathways-and-large-scale-computational-modeling-assess-candidate-disease>>url:https://training.incf.org/lesson/linking-molecular-pathways-and-large-scale-computational-modeling-assess-candidate-disease||rel=" 104 +[[https:~~/~~/training.incf.org/lesson/linking-molecular-pathways-and-large-scale-computational-modeling-assess-candidate-disease>>url:https://training.incf.org/lesson/linking-molecular-pathways-and-large-scale-computational-modeling-assess-candidate-disease||rel="noopener noreferrer" target="_blank"]] 103 103 104 104 105 105 == Tumor brain models == ... ... @@ -106,7 +106,7 @@ 106 106 107 107 Planning for tumour surgery involves delineating eloquent tissue to spare. To this end doctors analyze noninvasive neuroimages like fMRI and dwMRI. Instead of analyzing these modalities independently, brain models provide a novel way to combine the information in these different modalities, which may reveal information that is not apparent from individual analysis. Aerts et al. generated brain models of tumour patients before (https:~/~/doi.org/10.1523%2FENEURO.0083-18.2018) and after surgery (https:~/~/doi.org/10.1101%2F752931) and now published their core brain model data set: 108 108 109 -[[https:~~/~~/kg.ebrains.eu/search/?facet_type[0]=Dataset&q=marinazzo#Dataset/a696ccc7-e742-4301-8b43-d6814f3e5a44>>url:https://kg.ebrains.eu/search/?facet_type%5b0%5d=Dataset&q=marinazzo#Dataset/a696ccc7-e742-4301-8b43-d6814f3e5a44||rel=" 111 +[[https:~~/~~/kg.ebrains.eu/search/?facet_type[0]=Dataset&q=marinazzo#Dataset/a696ccc7-e742-4301-8b43-d6814f3e5a44>>url:https://kg.ebrains.eu/search/?facet_type%5b0%5d=Dataset&q=marinazzo#Dataset/a696ccc7-e742-4301-8b43-d6814f3e5a44||rel="noopener noreferrer" target="_blank"]] 110 110 111 111 The dataset contains BOLD time series averaged over 68 regions of interest according to the Desikan-Kilianny atlas, and a structural connectivity matrix displaying the fibers connecting each pair of these regions of interest, derived from the DWI data. The locations of the areas, the centers, the fiber lengths and densities are also included. The computational models are implemented at each of these regions of interested, connected according to the white matter fibers. The empirical functional connectivity matrix (the Pearson correlation among pairs of BOLD time series from each ROI) is used to fit the model. 112 112 ... ... @@ -117,7 +117,7 @@ 117 117 118 118 TVB EduPack provides didactic use cases for The Virtual Brain. Typically a use case consists of a jupyter notebook and a didactic video. EduPack use cases help the user to reproduce TVB based publications or to get started quickly with TVB. EduCases demonstrate for example how to use TVB via the Collaboratory of the Human Brain Project, how to run multi-scale co-simulations with other simulators such as NEST, how to process imaging data to construct personalized virtual brains of healthy individuals and patients. 119 119 120 -[[https:~~/~~/training.incf.org/ course/virtual-brain-education-pack-tvb-edupack>>url:https://training.incf.org/course/virtual-brain-education-pack-tvb-edupack||rel="122 +[[https:~~/~~/training.incf.org/studytrack/virtual-brain-simulation-platform>>https://training.incf.org/studytrack/virtual-brain-simulation-platform||rel="noopener noreferrer" target="_blank"]] 121 121 122 122 123 123 )))