User Guide
Launching
From Command Line
To launch the framework with the GUI:
vai_lab
To launch the framework with an existing config file:
vai_lab --file <path_to_config_file>
From Code
To launch the framework with the GUI:
1import vai_lab as ai
2
3core = ai.Core()
4core.run()
or to execute an existing config file:
1import vai_lab as ai
2
3core = ai.Core()
4core.load_config_file("<path_to_config_file>")
5core.run()
Examples
Pre-made examples show the syntax and form of the config files and pipeline as a whole, and are the best way to get started.
- Some basic use-cases are provided among many others:
user_feedback_demo.xml Demonstrates manual image classification of chest X-rays
canvas_demo.xml Launches the canvas state-action pair visualiser and editor
regression_demo.xml Demonstrates simple linear regression on a small set of sample data
Launching examples:
To demonstrate the syntax for launching examples using user_feedback_demo.xml
.
From Command Line
vai_lab --file ./src/vai_lab/examples/xml_files/user_feedback_demo.xml
From code
1import vai_lab as ai
2
3core = ai.Core()
4core.load_config_file(("./examples/xml_files/user_feedback_demo.xml"))
5core.run()
Absolute paths, as well paths relative to the library’s base directory can be used.
For library-relative paths, starting a path definition with ./
defaults to the directory <path_to_site_packages>/vai_lab/
In addition to path strings, the config file paths can be passed as lists or tuples of directory paths. Therefore, the above command/code are equivalent to
vai_lab --file ./src/vai_lab/examples xml_files user_feedback_demo.xml
and
1import vai_lab as ai
2
3core = ai.Core()
4core.load_config_file(("./examples","xml_files","user_feedback_demo.xml"))
5core.run()
Defining Pipelines in GUI
The VAIL module allows to define a pipeline and the relations within by drawing a flowchart on a canvas. This canvas always starts with an initialiser
module and an output
module and allows to define any number of modules between these two. To do so, the user needs to define the modules and the relations between them.
Modules
- At this moment, there are 7 possible modules for VAIL.
initialiser
andoutput
are compulsory for the pipeline, the rest of them can be freely placed in the canvas. These are: Data processing
Modelling
Decision making
User Feedback Adaptation
Input data
If you click on a module and drag it you can modify its position on the canvas.
Finally, they can be deleted by clicking on the desired module and then clicking on the Delete selection
button.
Connecting Modules
Each module object has a number of circles that can be used to join two modules. The initially clicked circle will be identified as the parent and the second one as the child (the output of the father is fed to the input of the child). There can be only one connection from each circle. As of this version, if you need to edit an existing connection you need to delete one of the connected modules.
Loops
If you click on the canvas and drag, you can draw a rectangle that defines which modules are inside the loop. Upon releasing the button you are requested to input what type of loop you want and what condition should be fulfilled to end the loop.
Loading from XML
The pipeline can also be defined uploading an existing XML file. The structure of the XML file is described in the Back-end section.
Plugin Examples
manual_input
Requires the user to indicate to which class the specified data corresponds to. In the current example, the model needs to classify images and the model requires expert knowledge for specific images. The user needs to indicate which classes correspond to the image and save the results to send them to the model.
canvas_input
Requires the user to give feedback to state-action pairs.
It opens a tab for each interactable object in the model and either requires adding new state-action samples or to modify the existing ones.
In the current example, the model has two interactable objects that require feedback in two forms: (1) an angle for the state and for the action or (2) a tuple of Cartesian coordinates for the state and for the action. It has been adapted to be able to give feedback to any number of objects. These, at the same time, can be either sliding
or rotating
objects. Specifically, sliding
refers to objects that need Cartesian feedback in a two-dimensional space, while rotating
refers to objects that require an angle. In order to give feedback, you can choose to either move the corresponding state-action pairs on the canvas or directly edit the tree view display. This last option results in an automatic update on the canvas of the state-action location.
Defining a pipeline in XML
The pipeline structure is defined between the pipeline
tags:
1<pipeline>
2 ...
3</pipeline>
Initialising
The Initialise
tag is the dedicated entry point to the pipeline. No other entry points can be declared.
- Current options:
name
: attribute for user defined nameinitial_data
: element for declaring directory for initial datarelationships
: User defined names of modules this one is connected to
Example from canvas_demo.xml:
1<Initialiser name="Init">
2 <inputdata>
3 <X file="./examples/state-action/X_data.csv" />
4 </inputdata>
5 <relationships>
6 <child name="My First UserFeedback Module" />
7 </relationships>
8</Initialiser>
Loops
Loop tags are used to iterate over a given set of modules until a condition is met. Loops can be nested and named.
See loop_demo.xml for full example. Current options:
type
: what variety of loop will this be:for
,while
,manual
(user defined stopping condition on-the-fly)
condition
: Termination condition for the loop. I’m not sure how to deal with the criteria forwhile
loops
name
: User defined name for loop
1<loop type="for" condition="10" name="For Loop 1">
2 ...
3</loop>
Modules
Modules are declared by tags matching their names, e.g. the GUI module is loaded with the GUI
tag:
- Required:
name
: Unique user defined name for module, so can be referenced laterplugin
: The type of plugin to be loaded into the module, along with associated options.relationships
: User-defined names of theparent
modules which this module receives data from andchild
modules that this module passes data to.
Example from ridge_regression_demo.xml:
1 <Modelling name="Modelling">
2 <relationships>
3 <parent name="Initialiser" />
4 <child name="Output" />
5 </relationships>
6 <plugin type="RidgeRegression">
7 <alpha>
8 0.02
9 </alpha>
10 </plugin>
11</Modelling>
Data Definition
Data is loaded from existing files in either the Initialiser
or Input Data
modules and is specified using the inputdata
tags.
Example from ridge_regression_demo.xml <https://github.com/AaltoPML/VAI-lab/tree/main/src/vai_lab/examples/xml_files/ridge_regression_demo.xml>`_:
1<inputdata>
2 <X file="./examples/supervised_regression/X_tr.csv" />
3 <Y file="./examples/supervised_regression/Y_tr.csv" />
4 <X_test file="./examples/supervised_regression/X_tst.csv" />
5 <Y_test file="./examples/supervised_regression/Y_tst.csv" />
6</inputdata>
Writing Data
Two methods are given to add data to the XML file. One for modules (append_pipeline_module_to_file
) and one for data structures (append_data_structure_field_to_file
).