Changes for page SGA2 SP3 UC002 KR3.2 - Slow Wave Analysis Pipeline
                  Last modified by robing on 2022/03/25 09:55
              
      Summary
- 
          Page properties (2 modified, 0 added, 0 removed)
- 
          Attachments (0 modified, 1 added, 0 removed)
- 
          Objects (0 modified, 3 added, 0 removed)
Details
- Page properties
- 
      - Author
-   ... ... @@ -1,1 +1,1 @@ 1 -XWiki. robing1 +XWiki.denker 
- Content
-   ... ... @@ -2,9 +2,24 @@ 2 2 ((( 3 3 (% class="container" %) 4 4 ((( 5 -= MyCollab'sExtendedTitle =5 += (% style="color:inherit" %)Slow Wave Analysis Pipeline(%%) = 6 6 7 -My collab's subtitle 7 +(% class="wikigeneratedid" id="HUseCaseSGA2-SP3-002:IntegratingmultiscaledataA0inareproducibleandadaptablepipeline" %) 8 +(% style="color:inherit; font-size:24px" %)Use Case SGA2-SP3-002: Integrating multi-scale data in a reproducible and adaptable pipeline 9 + 10 +To be discussed Author order, contributions,...: 11 + 12 +Experiments: ...? 13 + 14 +Implementation: Robin Gutzen^^1,*^^, Elena Pastorelli^^2,*^^, ... 15 + 16 +Lead: Michael Denker^^1^^, Pier Stanislao Paolucci^^2^^ 17 + 18 +,,1) Institute of Neuroscience and Medicine (INM-6) and Institute for Advanced Simulation (IAS-6) and JARA-Institute Brain Structure-Function Relationships (INM-10), Jülich Research Centre, Jülich, Germany,, 19 + 20 +,,2) Dipartimento di Fisica, Università di Cagliari and INFN Sezione di Cagliari, Italy,, 21 + 22 + 8 8 ))) 9 9 ))) 10 10 ... ... @@ -12,15 +12,79 @@ 12 12 ((( 13 13 (% class="col-xs-12 col-sm-8" %) 14 14 ((( 15 -= What canI findhere?=30 +== Flexible workflows to generate multi-scale analysis scenarios == 16 16 17 -* Notice how the table of contents on the right 18 -* is automatically updated 19 -* to hold this page's headers 32 +This Collab is aimed at experimental and computational neuroscientists interested in the usage of the Neo and Elephant tools in performing data analysis of spiking data. 20 20 21 -= Whohasaccess?=34 +== Executing the pipeline == 22 22 23 -Describe the audience of this collab. 36 +[[image:pipeline_flowchart.png]] 37 + 38 +=== In the collab (beta) === 39 + 40 +* **Copy the collab drive to your drive space** 41 +** Open the Drive from the left menu 42 +** Select the folders 'pipeline' and 'datasets' 43 +** Select 'Copy', and then 'My Library' from the dropdown 'Other Libraries' 44 + 45 +* **Start a Jupyter Hub instance ** 46 +In another browser, open [[https:~~/~~/lab.ebrains.eu>>https://lab.ebrains.eu]] 47 + 48 +* **Edit the config files** 49 +Each stage has a config file to specify which analysis/processing blocks to execute and which parameters to use. General and specific information about the blocks and parameters can found in the README and config files. The default values are set for an example dataset (ECoG, anesthetized mouse, IDIBAPS [ref]). 50 +** stage01_data_entry: [README.md](), [config.yaml]() 51 +** stage02_preprocessing: [README.md](), [config.yaml]() 52 +** stage03_trigger_detection: [README.md](), [config.yaml]() 53 +** stage04_wavefront_detection: [README.md](), [config.yaml]() 54 +** stage05_wave_characterization: [README.md](), [config.yaml]() 55 + 56 +* **Run the notebook** 57 +In the jupyter hub, navigate to `drive/My Libraries/My Library/pipeline/showcase_notebooks/run_snakemake_in_collab.ipynb`, or where you copied the 'pipeline' folder to. 58 +* Follow the notebook to install the required packages into your Python kernel, set the output path, and execute the pipeline with snakemake. 59 + 60 +* **Coming soon** 61 +** Use of KnowledgeGraph API 62 +** Provenance Tracking 63 +** HPC support 64 + 65 +=== Local execution === 66 + 67 +* **Get the code** 68 +The source code of the pipeline is available via Github: [INM-6/wavescalephant]('https:~/~/github.com/INM-6/wavescalephant') and can be cloned to your machine ([how to use Github]()). 69 + 70 +* **Build the Python environment** 71 +In the wavescalephant repository, there is an environment file (`pipeline/envs/wavescalephant_env.yaml`) specifying the required packages and versions. To build the environment, we recommend using *conda* ([how to get started with conda]()). 72 +`conda env create ~-~-file /envs/wavescalephant_env.yml`. 73 + 74 +* **Edit the settings** 75 +The settings file specifies the path to the output folder, where results are saved to. Open the template file `pipeline/settings_template.py`, set the `output_path` to the desired path, and save it as `pipeline/settings.py`. 76 + 77 +* **Edit the config files** 78 +Each stage has a config file to specify which analysis/processing blocks to execute and which parameters to use. Edit the config template files `pipeline/stageXX_<stage_name>/config_template.yaml` according to your dataset and analysis goal, and save them as `pipeline/stageXX_<stage_name>/config.yaml`. A detailed description of the available parameter settings and their meaning is commented in the template files, and a more general description of the working mechanism of each stage can be found in the respective README file `pipeline/stageXX_<stage_name>/README.md`. 79 + 80 +* **Enter a dataset** 81 +see `pipeline/stage01_data_entry/README.md` 82 + 83 +* **Run the pipeline (-stages)** 84 +To run the pipeline with snakemake ([intro to snakemake]()) activate the Python environment `conda activate wavescalephant_env`, make sure you are in the working directory `pipeline/`, and call `snakemake` to run the entire pipeline. 85 +To (re-)execute an individual stage, you can navigate to the corresponding stage folder and call the `snakemake` command there. For running an individual stage, you may need to manually set the path for input file for the stage (i.e. the output file of the previous stage) in the config file `INPUT: /path/to/file`. 86 + 87 +== Accessing and using the results == 88 + 89 +All results are stored in the path specified in the `settings.py` file. The folder structure reflects the structuring of the pipeline into stages and blocks. All intermediate results are stored as `.nix` files using the Neo data format ([Neo]()) and can be loaded with `neo.NixIO('/path/to/file.nix').read_block()` ([documentation]()). 90 +Additionally, most blocks produce a figure, and each stage a report file, to give an overview of the execution log, parameters, intermediate results, and to help with debugging. 91 +The final stage (*stage05_wave_characterization*) stores the results as pandas.DataFrames ([pandas]()) in `.csv` files, separately for each measure as well as in a combined dataframe for all measures. 92 + 93 +== References == 94 + 95 + 96 +== License (to discuss) == 97 + 98 +All text and example data in this collab is licensed under Creative Commons CC-BY 4.0 license. Software code is licensed under a modified BSD license. 99 + 100 +== Acknowledgments == 101 + 102 +This open source software code was developed in part or in whole in the Human Brain Project, funded from the European Union’s Horizon 2020 Framework Programme for Research and Innovation under the Specific Grant Agreement No. 785907 (Human Brain Project SGA2). 24 24 ))) 25 25 26 26 
 
- pipeline_flowchart.png
-   - Author
-   ... ... @@ -1,0 +1,1 @@ 1 +XWiki.robing 
- Size
-   ... ... @@ -1,0 +1,1 @@ 1 +1.8 MB 
- Content
 
- XWiki.XWikiRights[0]
-   - Allow/Deny
-   ... ... @@ -1,0 +1,1 @@ 1 +Allow 
- Groups
-   ... ... @@ -1,0 +1,1 @@ 1 +Collabs.slow-wave-analysis-pipeline._.groups.collab-slow-wave-analysis-pipeline-viewer 
- Levels
-   ... ... @@ -1,0 +1,1 @@ 1 +view,comment 
 
- XWiki.XWikiRights[1]
-   - Allow/Deny
-   ... ... @@ -1,0 +1,1 @@ 1 +Allow 
- Groups
-   ... ... @@ -1,0 +1,1 @@ 1 +Collabs.slow-wave-analysis-pipeline._.groups.collab-slow-wave-analysis-pipeline-editor 
- Levels
-   ... ... @@ -1,0 +1,1 @@ 1 +view,comment,edit 
 
- XWiki.XWikiRights[2]
-   - Allow/Deny
-   ... ... @@ -1,0 +1,1 @@ 1 +Allow 
- Groups
-   ... ... @@ -1,0 +1,1 @@ 1 +Collabs.slow-wave-analysis-pipeline._.groups.collab-slow-wave-analysis-pipeline-administrator 
- Levels
-   ... ... @@ -1,0 +1,1 @@ 1 +view,comment,edit,delete