Attention: The EBRAINS drive will be unavailable for most of the weekend starting the 25th October. Although the Lab is availble while the Drive is down, files that are stored in the Drive will not be loaded and you will be unable to save documents directly on the Lab.


Last modified by paulapopa on 2023/03/24 08:17

From version 42.1
edited by paulapopa
on 2023/03/08 16:00
Change comment: Uploaded new attachment "out.png", version {1}
To version 46.1
edited by paulapopa
on 2023/03/08 16:30
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -6,11 +6,8 @@
6 6  
7 7  == Purpose ==
8 8  
9 -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.
9 +This is a Jupyter Lab extension that offers graphical support for TVB workflows. It is already available in the EBRAINS Lab and it allows users to configure and execute TVB simulations directly from a GUI, while drastically reducing the complexity of configuring them inside a Jupyter Lab notebook.
10 10  
11 -**Note: **This extension is still a WIP (Work In Progress).
12 -
13 -
14 14  == Acknowledgements ==
15 15  
16 16  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.
... ... @@ -17,7 +17,7 @@
17 17  
18 18  == Installation ==
19 19  
20 -The extension can installed using the official PyPi distribution ([[https:~~/~~/pypi.org/project/tvb-ext-xircuits/>>https://pypi.org/project/tvb-ext-xircuits/]]):
17 +The extension can be installed using the official PyPi distribution ([[https:~~/~~/pypi.org/project/tvb-ext-xircuits/>>https://pypi.org/project/tvb-ext-xircuits/]]):
21 21  
22 22  (% class="box" %)
23 23  (((
... ... @@ -28,33 +28,58 @@
28 28  
29 29  [[image:side.png]]
30 30  
31 -
32 32  == **Usage** ==
33 33  
34 34  === **Step 1. Create a new Xircuits workflow** ===
35 35  
36 -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.
32 +From the Jupyter Lab launcher, click on the **Xircuits File** icon, as in the screenshot below.
37 37  
34 +[[image:newxircs.png]]
35 +
36 +A new file with the .xircuits extension will be generated under your current working directory. This is where you can start building the workflow diagram interactively.
37 +
38 +[[image:newfile.png]]
39 +
40 +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.
41 +
38 38  === **Step 2.  Drag components into the workflow area** ===
39 39  
40 -Open the components tray, browse through the components, select the one you wish to use and drag it into the workflow area.
44 +Open the components tray, from the left-side bar icon highlighted below.
41 41  
46 +[[image:tray.png]]
47 +
48 +Now, you can browse through the components, select the one you wish to use, then drag and drop it into the workflow area.
49 +
50 +[[image:components.png]]
51 +
42 42  === **Step 3. Configure the components** ===
43 43  
44 -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.
54 +The components that are provided in this extensions are configurable, meaning you can set some parameters on almost every component. Some of the parameters are literals, while some parameters are results of other components.
45 45  
56 +In case of primitives you need to open the //General// tab from the components tray and drag the appropriate //literal//: float, int, string, dict, etc.
57 +
58 +The parameters need to be linked to the inputs of the component by dragging and dropping a connection from the output port of a literal/component towards the corresponding input port of the other component (e.g. the gray connections in the screenshot below).
59 +
60 +[[image:diagr.png]]
61 +
46 46  === **Step 4. Make connections** ===
47 47  
48 -After dragging all your desired components in the workflow area, it's time to connect the components.
64 +After dragging all your desired components/literals in the workflow area, it's time to connect the components.
49 49  
50 -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.
66 +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 (e.g. the blue connections in the screenshot below). These connections will dictate the order of execution of the components in your workflow.
51 51  
68 +[[image:diagram.png]]
69 +
52 52  === **Step 5. Run the workflow** ===
53 53  
54 54  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.
55 55  
74 +[[image:run.png]]
75 +
56 56  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.
57 57  
78 +[[image:out.png]]
79 +
58 58  === **Step 6. Share your work*** ===
59 59  
60 60  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.
Public

TVB Widgets