This software allows to record hand gesture Emg and orientation signals using a surface Emg device. Compatible devices are Myo Armband and gForce Pro.
The data collected in this interface is fully compatible with Manual Segmentation.
Using the Myo Armband has an easier installation procedure. Check the MyoMex repository for the tutorial installation. We have included in this repository a copy of MyoMex.
The gForce_mex function must be compiled and added to the path. If you receive an error about it, check the gForce_interface project for help.
MYO Connect SDK: 0.9.0
MATLAB: Version 2023B or higher
Data Acquisition: Version established in:
Operating System: Windows 10 or higher
Processor: Intel i5 6th generation, with a clock speed of at least 3.60 GHz
RAM: more than 10 GB
Storage: 12 GB of free disk space for MATLAB installation, along with Toolboxes and MYO Connect installation.
To use the Myo armband with our computer, it is necessary to install the required software to connect it and receive the signals.
At the following link, you can download the various installers:
https://drive.google.com/drive/folders/10lPDZ2VtnKZBWrFkTThiKI6hKaMzjYIT?usp=sharing
We need to connect the Bluetooth adapter to our computer, and it is important to mention that the adapter must remain connected while we are using the Myo. Once the Myo is synchronized, the following bubble will appear on our screen with this message.
To use the Myo in our program, it is necessary to install the Myo SDK (Myo Software Development Kit), as it allows us to access movement data and use it in our applications. We can find the file at:
https://drive.google.com/drive/folders/10lPDZ2VtnKZBWrFkTThiKI6hKaMzjYIT?usp=sharing
Once we have the folder “myo-sdk-*-0.9.0” unzipped, we enter it and copy the path of the "bin" folder.
Next, go to environment variables, edit the PATH variable, and paste the path we just copied.
Once the project is on our computer, we simply need to run the script ejecutar.m
. We must select a user and then in Gesture Selector G5. The following window will open.
On the right side of the window, we have a panel labeled "User Information" where we input the various data collected from the user, such as: age, occupation, gender, dominant hand, temperature, pressure, SpO2, weight, and height.
There is a "Survey" button that opens a window with a set of questions to be filled out with the user’s answers.
In "Device Connection", by pressing one of the buttons according to the device we are going to use, our program will automatically connect to it.
If the armband is successfully connected, the sample recording will be enabled.
In the central part of the screen, we have the "Sample" panel, which is divided into three sections. In the "Sample" area, there are two buttons: RECORD and REPEAT. RECORD is used to capture a new sample, and REPEAT allows us to repeat the last sample in case of any issues.
In the central zone, images and GIFs are displayed, which serve to indicate the gesture to be performed at that moment. The images or GIFs will appear when the sampling process begins.
Finally, in the "Acquisition" zone, pressing the "New" button generates a new session to capture samples, while "Resume" is a button that allows us to resume sampling if there is any interruption.
To take a sample, as mentioned before, press the “RECORD” button, which starts a countdown from 3, while a bar indicates the duration of the sample through its movement. The respective gesture must be performed when the GO symbol appears.
Finally, after the sample is taken, in the lower section there is an area labeled "Device Signals" that will graphically display the signals taken by the various sensors of the armband.
Once all 50 samples for each of the 6 gestures are taken, the application will automatically close.
- The gForce library is still in beta. There are some issues with the SDK that may difficult data acquisition. Please, be aware of the following issues:
- In the case of a Run Time Error in the C++ MEX function, Matlab will crash inmediately and close itself. The device must be restarted manually.
- Battery level sometimes returns 0%. This is the response from the device (the SDK not the C++ MEX function). It may not correspond to a completely empty battery, as in some tests afterwards the command returned a value (e.g. 77%).
- Emg data is encoded in 8 or 12 bits. So, it should be centered at 128 or 2048, but it is not. The reference is slightly moved down. At 8 bits it is centered in 118 and at 12 bits, in 2000.
- Gesture predictions are currently unavailable due to empty responses from the device.
We included in this repository the MyoMex connector. Special thanks to @mark-toma.
After finishing the recordings in this interface, to carry on with the manual segmentation procedure, do the following:
- Copy the data of all users (i.e. the content of this ./data/ folder except the README.md file) to the /manualSegmentation/data/ folder in Manual Segmentation repository.
- Run the script /manualSegmentation/ejecutar.m in manual segmentation repository.
If you use this Data Acquisition System, please refer and cite the following paper:
Changelog:
- v1.7 | June 21st, 2024 | Inclues GUI to survey and optimization of the data collection process.
- v1.6 | June 26th, 2023 | Inclues GUI to gesture set selection.
- v1.5.1 Updated recolectors and list of devices.
- v1.5 Version of dataset G11.