Wiki source code of Extension tvb-ext-xircuits
                  Version 26.1 by rominabaila on 2022/11/25 16:03
              
      Show last authors
| author | version | line-number | content | 
|---|---|---|---|
| 1 | Source code: [[https:~~/~~/github.com/the-virtual-brain/tvb-ext-xircuits>>https://github.com/the-virtual-brain/tvb-ext-xircuits]] | ||
| 2 | |||
| 3 | == Jupyter Lab Extension for building and executing EBRAINS Workflows == | ||
| 4 | |||
| 5 | == Purpose == | ||
| 6 | |||
| 7 | This is a Jupyter Lab extension with the role of offering graphical support for EBRAINS workflows. It allows users to utilize all the TVB and EBRAINS capabilities, while drastically reducing the complexity of configuring them inside a Jupyter Lab environment. | ||
| 8 | |||
| 9 | **Note: **This extension is still a WIP (Work In Progress). | ||
| 10 | |||
| 11 | |||
| 12 | == Acknowledgements == | ||
| 13 | |||
| 14 | This extension is build on top of the [[Xircuits Jupyter extension>>https://xircuits.io/]], but it also comes with custom functionalities, specifically designed for TVB and EBRAINS. These functionalities are detailed in a section below. | ||
| 15 | |||
| 16 | == Installation == | ||
| 17 | |||
| 18 | The extension can installed using the official PyPi distribution ([[https:~~/~~/pypi.org/project/tvb-ext-xircuits/>>https://pypi.org/project/tvb-ext-xircuits/]]): | ||
| 19 | |||
| 20 | (% class="box" %) | ||
| 21 | ((( | ||
| 22 | pip install tvb-ext-xircuits | ||
| 23 | ))) | ||
| 24 | |||
| 25 | After installing the extension and opening a Jupyter Lab session, you should be able to see in the left panel of Jupyter Lab a new icon, which represents the Xircuits components tray: | ||
| 26 | |||
| 27 | [[image:image-20221116115659-2.png]] | ||
| 28 | |||
| 29 | == **Usage** == | ||
| 30 | |||
| 31 | === **Step 1. Create a new Xircuits workflow** === | ||
| 32 | |||
| 33 | Using the Jupyter Lab launcher. You will notice that 2 components are already placed inside the workflow: the Start and the Finish components. They cannot be modified or deleted, and they represent the starting and finishing point of the workflow. | ||
| 34 | |||
| 35 | === **Step 2. Drag components into the workflow area** === | ||
| 36 | |||
| 37 | Open the components tray, browse through the components, select the one you wish to use and drag it into the workflow area. | ||
| 38 | |||
| 39 | === **Step 3. Configure the components** === | ||
| 40 | |||
| 41 | The components that are provided in this extensions are configurable, meaning you can set some parameters on almost every component. For this you need to open the //General// tab from the components tray and drag the appropriate //literal//: float, int, string, dict, etc. | ||
| 42 | |||
| 43 | === **Step 4. Make connections** === | ||
| 44 | |||
| 45 | After dragging all your desired components in the workflow area, it's time to connect the components. | ||
| 46 | |||
| 47 | First, link the Start node to the first component of your workflow. Then make the connections between all your components. The last component should be linked to the Finish node, to indicate the end of your workflow. | ||
| 48 | |||
| 49 | === **Step 5. Run the workflow** === | ||
| 50 | |||
| 51 | After connecting everything, you need to run the workflow to actually see its result. For this you can click on the Run button (▶), which will also implicitly compile the workflow. | ||
| 52 | |||
| 53 | After clicking on Run, a new Jupyter Output window should appear in the bottom of your Jupyter Lab environment. Here you will see the output of your workflow, such as logs, static plots, etc. | ||
| 54 | |||
| 55 | === **Step 6. Share your work*** === | ||
| 56 | |||
| 57 | This step is, of course, optional, but it is worth mentioning that sharing your workflows with others is extremely easy. By just saving and sharing your workflow (*.xircuits) file, anyone can access the entire workflow, see the exact connections that you made and receive the same configuration for the components. | ||
| 58 | |||
| 59 | |||
| 60 | |||
| 61 | == Custom functionalities == | ||
| 62 | |||
| 63 | As mentioned before, besides all the core functionalities provided by Xircuits, some other functionalities were added to better suit the needs of the EBRAINS users. | ||
| 64 | |||
| 65 | === 1. Configure TVB models using the Phase Plane widget. === | ||
| 66 | |||
| 67 | This functionality was added to make it easier for users to provide the correct parameters to TVB models, using the Phase Plane widget. | ||
| 68 | |||
| 69 | To use this functionality, drag any model from the **TVB_MODELS** (inside the components tray) into the workflow area. Then right click on the model and select the **Open Viewer** option: | ||
| 70 | |||
| 71 | |||
| 72 | (% style="text-align:center" %) | ||
| 73 | [[image:image-20221116125354-2.png||height="800" width="1130"]] | ||
| 74 | |||
| 75 | |||
| 76 | A new Jupyter tab should open, which contains a read-only Jupyter notebook. After following the instructions provided there, you should be able to see the Phase Plane widget associated with this particular model. | ||
| 77 | |||
| 78 | (% style="text-align:center" %) | ||
| 79 | [[image:image-20221116125822-1.png||height="800" width="821"]] | ||
| 80 | |||
| 81 | After configuring the parameters with the desired values, go to the Exports tab of the widget and click on **Export model configuration**. Now all you have to do is to go back to the tab where your workflow is and you will see that the model will have values set for all the parameters that you modified in the Phase Plane widget (that is all the parameters there were assigned values different than the default ones). | ||
| 82 | |||
| 83 | (% style="text-align:center" %) | ||
| 84 | [[image:image-20221116130425-1.png||height="900" width="1069"]] | ||
| 85 | |||
| 86 | |||
| 87 | == Workflow examples == | ||
| 88 | |||
| 89 | ((( | ||
| 90 | === 1. Full TVB Simulation workflow === | ||
| 91 | ))) | ||
| 92 | |||
| 93 | Contains all TVB components necessary for running a TVB simulation (i.e. connectivity, coupling, model, integrator, monitor, simulator). | ||
| 94 | |||
| 95 | {{html}} | ||
| 96 | <iframe src="https://drive.google.com/file/d/14sVjWXmtfZB-Zt7i3MA26-MiNWwv3jZI/preview" width="1920" height="1080" allow="autoplay"></iframe> | ||
| 97 | {{/html}} | ||
| 98 | |||
| 99 | |||
| 100 | === 2. Configuring model parameters using the PhasePlaneWidget: === | ||
| 101 | |||
| 102 | Same workflow as before, but the parameter for the model used in simulation are set using the PhasePlaneWidget. | ||
| 103 | |||
| 104 | {{html}} | ||
| 105 | <iframe src="https://drive.google.com/file/d/1Puoi4-Ej4BhVwtdRzciPD_qNKMF0HvGT/preview" width="1920" height="1080" allow="autoplay"></iframe> | ||
| 106 | {{/html}} | ||
| 107 | |||
| 108 | |||
| 109 | === 3. Using siibra to retrieve connectivities from the EBRAINS KG === | ||
| 110 | |||
| 111 | A simulation workflow where **siibra **is used to retrieve a connectivity from the EBRAINS KG. That connectivity is fed into a TVB Simulator, where the rest of the parameters (coupling, model, etc.) are set to default values. | ||
| 112 | |||
| 113 | {{html}} | ||
| 114 | <iframe src="https://drive.google.com/file/d/1bakH6ZD96eMHnYSw1aasF_gNXt8sBS7D/preview" width="1920" height="1080" allow="autoplay"></iframe> | ||
| 115 | {{/html}} | ||
| 116 | |||
| 117 | |||
| 118 | === 4. Run a workflow inside an HPB job === | ||
| 119 | |||
| 120 | A workflow simulation which is run remotely, by submitting a job to an HPC site and getting back the results (TimeSeries object). | ||
| 121 | |||
| 122 | {{html}}<iframe src="https://drive.google.com/file/d/1rvcj_9lGtR069iXlL3Rm1czMNdA3qmGM/preview" width="1920" height="1080" allow="autoplay"></iframe>{{/html}} | ||
| 123 |