/WiN-GUI

The Watch inside Neurons GUI (WiN-GUI)

Primary LanguagePythonGNU General Public License v3.0GPL-3.0

WiN-GUI

Have you ever wondered how your data would look like in neuromorphic? Have you ever wondered what is actually going on in a neuron and how does a bunch of them sound like? Just run the WiN_GUI.py file and you will find out!

Further information can be found in our related publication WiN-GUI: A graphical tool for neuron-based encoding.

example_surface_gui

Here we present the WiN-GUI (Watch inside Neurons-GUI) to interactively change neuron models and parameters. It allows to load any sample-based time-series data (for more details see Data structure) and converts it into membrane voltage traces and spike-trains. Playing with the parameter sliders helps to understand their interaction, the neuron mechanics and how your encoded data changes accordingly. The neuron model can be changed with a single click and the GUI will update the visualization. If you have your own neuron model and want to tune tha parameters check out the How-to: include custom neuron models chapter.

Available neuron models are:

Installation

The WiN-GUI is based on PyQT6 and PyTorch. Some other packages are requiered, too. Use the requirements file provided to set everything up Further libraries we face missing often are listed in Packages you might need to install.

Data structure

The WiN-GUI is intentionally designed to visualize data from robotic experiments different classes and multiple recordings per class. Nonetheless does the GUI support single class and single recording. In that case you only have to make sure, that the data is structured like: nb_time_steps x nb_sensors. If you provide the data as python dictionary with an entry 'label' the dataselection over the drop down menu is availabale, otherwise over the dial. If you want to visualize multi-class and multi recordings you have to provide each record with the according label (e.g. 'label': class_name).

Below you can find some example data structures:

  1. single trial: nb_time_steps x nb_sensors
  2. single class, multiple repetitions: nb_trial x nb_time_steps x nb_sensors (do not forget to provide the label 'repetition' as dictionary key)
  3. multi-class, no repetition: nb_classes x nb_time_steps x nb_sensors (do not forget to provide the label 'class' as dictionary key)
  4. multi-class, multiple repetitions: (nb_classes x nb_repetitions) x nb_time_steps x nb_sensors

Please have a look at the example data provided for further details.

Neuron model and parameter

Neuron models are implemented using PyTorch. The models can be found here. The according parameters here. Implementing a neuron requires setting all parameters with default values. Parameters that should be manipulatable in the GUI surface must be added by the same name in the parameters file. For all parameters not added, the GUI will fall back to the default values specified in the neuron model. Each parameter must start with the lower boundary, followed by the upper boundary, the step size, and finally the initial value.

Preprocessing

We use the Multidimensional image processing (scipy.ndimage) for filtering, and signal processing (scipy.signal) for resampling.

Channel selection

The channel selection panel allows enabling or disabling single channels to improve the readability of the remaining. Channels to visualize are highlighted in green, whereas hidden channels are highlighted in red. The channel selection can be adapted to personal needs and preferences regarding shape, spacing, and location.

How to

Change the filter

If you want to change the filter properties you can do this here. To change the filter type replace the default filter here.

Include custom neuron models

The WiN-GUI can be extended with further neuron models! To use your custom neuron model, the model has to be added here and the according parameter here. Finally, you need to load your model to be used in the GUI. Brief overview showing a custom neuron model in PyTroch you can find here.

Here comes a step by step how to guide based on the LIF neuron:

  1. Add your neuron model:
    1. Add a new class as NAME(nn.Module), e.g..
    2. List the NeuronState variables (must start with "V" and end with "spk"), e.g..
    3. Define the model (init, forward, reset) and pay attention to set the default values, e.g..
  2. Add the neuron parameter:
    1. Add a new dictionary in the neuron_parameters file, e.g..
    2. Each entry has to match a single member in the neuron model "init" list.
  3. Load the neuron model and parameter:
    1. Include the model in the main file here, here, here, here, and here.
    2. The default neuron model can be set here.

If you implement a new model, and want to make it available for the community, let us know!

Write your own template for the sensor visualization

For those who want to give there GUI the perfect personal glance can change the sensor visualization to reflect the physical setup. Implementing a custom visualization must be able to handle the splitting of each sensor stream into two streams. In other words: two layouts are needed: 1. the orignal and 2. twice as many as the original.

Packages you might need to install

apt-get packages: apt-get -y install '^libxcb.*-dev' libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev libxkbcommon-dev libxkbcommon-x11-dev

apt packages: apt -y install ffmpeg, portaudio19-dev