Getting started with MotionAR activity recognition library in X-CUBE-MEMS1 expansion for STM32Cube

Similar documents
Getting started with MotionAR activity recognition library in X-CUBE-MEMS1 expansion for STM32Cube

UM2194. Getting started with MotionAW activity recognition for wrist library in X-CUBE-MEMS1 expansion for STM32Cube. User manual.

Getting started with MotionPM real-time pedometer library in X-CUBE-MEMS1 expansion for STM32Cube

UM2350. Getting started with MotionPW real-time pedometer for wrist library in X-CUBE-MEMS1 expansion for STM32Cube. User manual.

UM2276. Getting started with MotionSD standing vs sitting desk detection library in X-CUBE-MEMS1 expansion for STM32Cube. User manual.

Getting started with MotionPM real-time pedometer library in X CUBE-MEMS1 expansion for STM32Cube

UM2216 User manual. Getting started with MotionFA fitness activity library in X CUBE MEMS1 expansion for STM32Cube. Introduction

UM2192. Getting started with MotionMC magnetometer calibration library in X-CUBE-MEMS1 expansion for STM32Cube. User manual.

Getting started with osxmotionar activity recognition library for X-CUBE-MEMS1 expansion for STM32Cube

Getting started with osxmotiongc gyroscope calibration library for X-CUBE-MEMS1 expansion for STM32Cube

Getting started with MotionMC magnetometer calibration library in X-CUBE-MEMS1 expansion for STM32Cube

UM2220. Getting started with MotionFX sensor fusion library in X-CUBE-MEMS1 expansion for STM32Cube. User manual. Introduction

Getting started with osxmotionmc magnetometer calibration library for X-CUBE-MEMS1 expansion for STM32Cube

NUCLEO-L433RC-P NUCLEO-L452RE-P

IoT node with BLE connectivity, digital microphone, environmental and motion sensors, motion and audio middleware libraries.

Getting started with the X-CUBE-MEMS1 motion MEMS and environmental sensor software expansion for STM32Cube

Getting started with the FP-SNS-ALLMEMS1 Bluetooth low energy and sensors software expansion for STM32Cube

Getting started with the FP-NET-6LPBLE1 function pack for 6LoWPAN IoT node connection to a smartphone via BLE interface

AN4624 Application note

UM2045 User manual. Getting started with the X-CUBE-NFC3 near field communication transceiver software expansion for STM32Cube.

Getting started with the X-CUBE-IKA02A1 multifunctional software expansion for STM32Cube

P-NUCLEO-USB001. STM32 Nucleo pack for USB Type-C and Power Delivery. Features. Description

Getting started with STEVAL-IDB007V1 and STEVAL-IDB008V1 evaluation boards

Bluetooth low energy profiles for the X-CUBE-BLE1 expansion for STM32Cube. Description

Getting started with X-CUBE-LED channel LED driver software expansion based on LED1642GW for STM32Cube

Getting started with the X-CUBE-NFC5 high performance HF reader / NFC initiator IC software expansion for STM32Cube

Getting started with the FP-IND-PLCWIFI1 function pack for PLC management via Wi-Fi

P-NUCLEO-USB001. STM32 Nucleo pack for USB Type-C and Power Delivery Data brief. Features. Description

NUCLEO-L496ZG. STM32 Nucleo-144 board. Features. Description

Running a simple 6LowPAN network consisting of one receiver node and one or more sensor nodes in a Sub-1GHz RF band

Getting started with FP-SNS-6LPNODE1 software for IoT sensor node connection to 6LoWPAN networks using sub-1ghz RF

Getting started with the STM32 Nucleo pack for USB Type-C and Power Delivery with the Nucleo-F072RB board and the STUSB1602

Getting started with the STSW-BCNKT01 software package for STEVAL-BCNKT01V1 based on STM32Cube

USB Type-C and Power Delivery Nucleo pack with NUCLEO-F072RB expansion board based on the STUSB1602

USB Type-C and Power Delivery Nucleo pack with NUCLEO-F072RB expansion board based on STUSB1602. Description

Getting started with the digital MEMS microphone expansion board based on MP34DT01-M for STM32 Nucleo

Getting started with the software package for STEVAL-STLKT01V1 based on STM32Cube

32L476GDISCOVERY. Discovery kit with STM32L476VG MCU. Features. Description

Getting started with osxacousticsl real-time sound source localization software expansion for STM32Cube

AN4515 Application note

Getting started with the X-CUBE-53L1A1 Time-of-Flight long distance ranging sensor software expansion for STM32Cube

UM1853 User manual. STM32CubeF1 Nucleo demonstration firmware. Introduction

STM32H7x3I-EVAL. Evaluation board with STM32H7x3XI MCUs. Data brief. Features

Getting started with VL53L0X ranging and gesture detection sensor software expansion for STM32Cube

STM32L4R9I-EVAL. Evaluation board with STM32L4R9AI MCU. Features

32F412GDISCOVERY. Discovery kit with STM32F412ZG MCU. Features. Description

P-NUCLEO-IKA02A1. STM32 Nucleo pack: electrochemical toxic gas sensor expansion board with CO sensor. Description. Features

UM1727 User manual. Getting started with STM32 Nucleo board software development tools. Introduction

DT0095 Design tip. Datalogging the SensorTile through a PC. Purpose and benefits. Description

Software GUI user guide for STEVAL-ISV021V1, STEVAL- IDS002V1 and STEVAL-IDS003V1 evaluation boards

This design tip applies to all accelerometers, ecompass modules, and inemo inertial IMUs from STMicroelectronics.

Using the GPIOs and interrupt controller to drive LEDs on STM8 Nucleo-64 boards

Main components MEMS motion sensor: low power high g 3-axis digital accelerometer inemo inertial module: 3D accelerometer and 3D gyroscope

STSW-BLUENRG1-DK. BlueNRG-1, BlueNRG-2 DK SW package

UM2051 User manual. Getting started with the STM32 Nucleo pack for USB Type-C and Power Delivery. Introduction

32F469IDISCOVERY. Discovery kit with STM32F469NI MCU. Features. Description

STM32SnippetsL0. STM32L0xx Snippets firmware package. Features. Description

Getting started with X-NUCLEO-IHM06A1 low voltage stepper motor driver expansion board based on STSPIN220 for STM32 Nucleo

UM2361. Getting started with the ST BlueNRG-Mesh ios application. User manual. Introduction

P-NUCLEO-53L0A1. VL53L0X Nucleo pack with ranging, gesture detection sensor expansion board and STM32F401RE. Description. Features

Getting started with the X-CUBE-SPN3 high power stepper motor driver software expansion for STM32Cube

STSW-BNRG-Mesh. Mesh over Bluetooth low energy. Features. Description. Applications

How to upgrade the firmware on the STEVAL-USBC2DP USB Type-C to DisplayPort adapter

AN4045 Application note

Getting started with the software package for digital MEMS microphones in X-CUBE-MEMSMIC1 expansion for STM32Cube

32F746GDISCOVERY. Discovery kit with STM32F746NG MCU. Features. Description

X-NUCLEO-53L1A1. Long distance ranging Time-of-Flight sensor expansion board based on VL53L1X for STM32 Nucleo. Description.

AN3980 Application note

UM1997 User manual. Getting started with the BlueMS 3.x application. Introduction

P-NUCLEO-53L1A1. VL53L1X nucleo pack with X-NUCLEO-53L1A1 expansion board and STM32F401RE nucleo board. Description. Features

P-NUCLEO-6180X2. Proximity, gesture, ambient light sensor expansion board based on VL6180X for STM32L053R8. Description. Features

How to configure the BlueNRG-1 and BlueNRG-2 devices in network coprocessor mode. Main components Bluetooth Low Energy wireless system-on-chip

STSW-BNRGUI. BlueNRG GUI SW package. Data brief. Features. Description

Getting started with the ultra-low-power STM32 and LoRa Nucleo pack

UM2084 User manual. Getting started with the ultra-low-power STM32 and LoRa Nucleo pack. Introduction

X-NUCLEO-53L0A1. Ranging and gesture detection sensor expansion board based on VL53L0X for STM32 Nucleo. Description. Features

L9958 Evaluation board for high current (8.6A) DC and Stepper Motors. Description

Version (Apr 28, 2016)

UM0792 User manual. Demonstration firmware for the DMX-512 communication protocol transmitter based on the STM32F103Zx.

Getting started with the software package for L6474 stepper motor driver X-CUBE-SPN1 expansion for STM32Cube

Main components MEMS digital output motion sensor: high-performance ultra-low-power 3-axis "femto" accelerometer

Getting started with the P-NUCLEO-IKA02A1 STM32 Nucleo pack for electrochemical toxic gas sensor expansion board with CO sensor

Getting started with the FP-CLD-AWS1 software package for IoT node with Wi-Fi and sensors, connected to Amazon AWS IoT cloud

AN4749 Application note

UM2343 Application note

Quick Start Guide. Long distance ranging ToF sensor expansion board based on VL53L1X for STM32 Nucleo (X-NUCLEO-53L1A1) Version (February 20, 2018)

Description. January 2019 DB2381 Rev 3 1/5

UM2495. High performance HF reader / NFC initiator IC software expansion for NUCLEO-8S208RB. User manual. Introduction

UM2092 User manual. Basic metrology firmware for the STM32F103RD and the STPM32 devices. Introduction

AN3279 Application Note

UM2204. Getting started with STM32CubeH7 for STM32H7 Series. User manual. Introduction

UM1641 User manual. Sampling rate conversion SRC236 library software expansion for STM32Cube. Introduction

AN4869 Application note

Motor control power board based on the SLLIMM-nano 2 nd series

AN3996 Application Note

EVALKITSTKNX. Miniature transceiver STKNX evaluation and development kit. Features

AN5123 Application note

External memory code execution on STM32F7x0 Value line and STM32H750 Value line MCUs

UM1862 User manual. Getting started with STM32F411E Discovery software Development Tools. Introduction

AN2676 Application note

Transcription:

User manual Getting started with MotionAR activity recognition library in X-CUBE-MEMS1 expansion for STM32Cube Introduction The MotionAR is a middleware library part of X-CUBE-MEMS1 software and runs on STM32. It provides real-time information on the type of activity performed by the user. It is able to distinguish the following activities: stationary, walking, fast walking, jogging, biking, driving. This library is intended to work with ST MEMS only. The algorithm is provided in static library format and is designed to be used on STM32 microcontrollers based on the ARM Cortex -M3 or Cortex -M4 architecture. It is built on top of STM32Cube software technology that eases portability across different STM32 microcontrollers. The software comes with sample implementation running on X-NUCLEO-IKS01A1 (with optional STEVAL-MKI160V1) or X-NUCLEO-IKS01A2 expansion board on a NUCLEO-F401RE, NUCLEO-L476RG or NUCLEO-L152RE development board. UM2193 - Rev 3 - March 2018 For further information contact your local STMicroelectronics sales office. www.st.com

Acronyms and abbreviations 1 Acronyms and abbreviations Table 1. List of acronyms Acronym Description API BSP GUI HAL IDE Application programming interface Board support package Graphical user interface Hardware abstraction layer Integrated development environment UM2193 - Rev 3 page 2/16

MotionAR middleware library in X-CUBE-MEMS1 software expansion for STM32Cube 2 MotionAR middleware library in X-CUBE-MEMS1 software expansion for STM32Cube 2.1 MotionAR overview The MotionAR library expands the functionality of the X-CUBE-MEMS1 software. The library acquires data from the accelerometer and provides information on the type of activity performed by the user. The library is designed for ST MEMS only. Functionality and performance when using other MEMS sensors are not analyzed and can be significantly different from what described in the document. Sample implementation is available on X-NUCLEO-IKS01A2 and X-NUCLEO-IKS01A1 (with optional STEVAL- MKI160V1) expansion boards, mounted on a NUCLEO-F401RE, NUCLEO-L476RG or NUCLEO-L152RE development board. 2.2 MotionAR library Technical information fully describing the functions and parameters of the MotionAR APIs can be found in the MotionAR_Package.chm compiled HTML file located in the Documentation folder. 2.2.1 MotionAR library description The MotionAR activity recognition library manages data acquired from accelerometer; it features: possibility to distinguish the following activities: stationary, walking, fast walking, jogging, biking, driving recognition based on accelerometer data only required accelerometer data sampling frequency: 16 Hz occupies 7.2 kbyte of code memory and 1.6 kbyte of data memory Note: Real size might differ for different IDE (toolchain) available for ARM Cortex-M3 and Cortex-M4 architectures 2.2.2 MotionAR APIs The MotionAR APIs are: uint8_t MotionAR_GetLibVersion(char *version) retrieves the version of the library *version is a pointer to an array of 35 characters returns the number of characters in the version string void MotionAR_Initialize(void) performs MotionAR library initialization and setup of the internal mechanism the CRC module in STM32 microcontroller (in RCC peripheral clock enable register) has to be enabled before using the library Note: This function must be called before using the accelerometer calibration library. void MotionAR_Reset(void) resets activity recognition algorithms void MotionAR_Update (MAC_input_t *data_in, MAR_output_t *data_out) executes activity recognition algorithm *data_in parameter is a pointer to a structure with input data the parameters for the structure type MAR_input_t are: AccX is accelerometer sensor value in X axis in g UM2193 - Rev 3 page 3/16

MotionAR library AccY is accelerometer sensor value in Y axis in g AccZ is accelerometer sensor value in Z axis in g *data_out parameter is a pointer to enum with the following items: MAR_NOACTIVITY = 0 MAR_STATIONARY = 1 MAR_WALKING = 2 MAR_FASTWALKING = 3 MAR_JOGGING = 4 MAR_BIKING = 5 MAR_DRIVING = 6 void MotionAR_SetOrientation_Acc(const char *acc_orientation) sets the accelerometer data orientation configuration is usually performed immediately after the MotionAR_Initialize function call *acc_orientation parameter is a pointer to a string of three characters indicating the direction of each of the positive orientations of the reference frame used for accelerometer data output, in the sequence x, y, z. Valid values are: n (north) or s (south), w (west) or e (east), u (up) or d (down) As shown in the figure below, the X-NUCLEO-IKS01A1 accelerometer sensor has an ENU orientation (x - East, y - North, z - Up), so the string is: enu, while the accelerometer sensor in STEVAL- MKI160V1 is NWU (x-north, y-west, z-up): nwu. Figure 1. Sensor orientation example North Y Z X West Y Z X East South UM2193 - Rev 3 page 4/16

MotionAR library 2.2.3 API flow chart Figure 2. MotionAR API logic sequence Start Initialize GetLibVersion SetOrientation_Acc Wait Expiring Timer Data Ready Interrupt Read Accelerometer Data Update Get Activity Code 2.2.4 Demo code The following demonstration code reads data from accelerometer sensor and gets the activity code. [ ] #define VERSION_STR_LENG 35 [ ] /*** Initialization ***/ char lib_version[version_str_leng]; char acc_orientation[3]; /* Activity recognition API initialization function */ MotionAR_Initialize(); /* Optional: Get version */ MotionAR_GetLibVersion(lib_version); /* Set accelerometer orientation */ acc_orientation[0] ='n'; acc_orientation[1] ='w'; acc_orientation[2] ='u'; MotionAR_SetOrientation_Acc(acc_orientation); UM2193 - Rev 3 page 5/16

MotionAR library [ ] /*** Using activity recognition algorithm ***/ Timer_OR_DataRate_Interrupt_Handler() { MAR_input_t data_in; MAR_output_t activity; /* Get acceleration X/Y/Z in g */ MEMS_Read_AccValue(&data_in.AccX, &data_in.accy, &data_in.accz); /* Activity recognition algorithm update */ MotionAR_Update(&data_in, &activity); } 2.2.5 Algorithm performance The activity recognition algorithm only uses data from the accelerometer and runs at a low frequency (16 Hz) to reduce power consumption. Table 2. Algorithm performance Activity Detection probability (typical) (1) Best performance Susceptible Carry positions Stationary 92.27% Holding in hand and heavy texting All: trouser pocket, shirt pocket, back pocket, near the head, etc. Walking 99.44% Step rate 1.4 step/s Step rate 1.2 step/s all Fast walking 95.94% Step rate 2.0 step/s All Jogging 98.49% Step rate 2.2 step/s Duration < 1 minute; speed < 8 Km/h Biking 91.93% Outdoor speed 11 Km/h Passenger seat, glove compartment Driving 78.65% Speed 48 Km/h Passenger seat, glove compartment Trouser pocket, arm swing, inhand Backpack, shirt pocket, trouser pocket Cup holder, dash board, shirt pocket, trouser pocket 1. Typical specifications are not guaranteed Table 3. Elapsed time (µs) algorithm Cortex-M4 STM32F401RE at 84 MHz Cortex-M3 STM32L152RE at 32 MHz SW4STM32 1.13.1 (GCC 5.4.1) IAR EWARM 7.80.4 Keil µvision 5.22 SW4STM32 1.13.1 (GCC 5.4.1) IAR EWARM 7.80.4 Keil µvision 5.22 Min Avg Max Min Avg Max Min Avg Max Min Avg Max Min Avg Max Min Avg Max 5 43 801 5 44 547 12 90 1374 113 574 7923 120 435 5462 118 694 8991 UM2193 - Rev 3 page 6/16

Sample application 3 Sample application The MotionAR middleware can be easily manipulated to build user applications; a sample application is provided in the Application folder. It is designed to run on a NUCLEO-F401RE, NUCLEO-L476RG or NUCLEO-L152RE development board connected to an X-NUCLEO-IKS01A1 (based on LSM6DS0) or an X-NUCLEO-IKS01A2 (based on LSM6DSL) expansion board, with optional STEVAL-MKI160V1 board (based on LSM6DS3). The application recognizes performed activities in real-time. Data can be displayed through a GUI or stored in the board for offline analysis. The algorithm recognizes stationary, walking, fast walking, jogging, bike riding and driving activities. Stand-alone mode In stand-alone mode, the sample application allows the user to detect performed gesture and store it in the MCU flash memory. The STM32 Nucleo board may be supplied by a portable battery pack (to make the user experience more comfortable, portable and free of any PC connections). Table 4. Power supply scheme Power source JP1 settings Working mode USB PC cable JP1 open PC GUI driven mode Battery pack JP1 closed Stand-alone mode Figure 3. STM32 Nucleo: LEDs, button, jumper UM2193 - Rev 3 page 7/16

Sample application The above figure shows the user button B1 and the three LEDs of the NUCLEO-F401RE board. Once the board is powered, LED LD3 (PWR) turns ON and the tricolor LED LD1 (COM) begins blinking slowly due to the missing USB enumeration (refer to UM1724 on www.st.com for further details). After powering the board, LED LD2 blinks once indicating the application is ready. When the user button B1 is pressed, the system starts acquiring data from the accelerometer sensor and detects the performed activity; during this acquisition mode, a fast LED LD2 blinking indicates that the algorithm is running. During this phase, the detected device gesture is stored in the MCU internal flash memory. Pressing button B1 a second time stops the algorithm and data storage and LED LD2 switches off. Pressing the button again starts the algorithm and data storage once again. The flash sector dedicated to data storage is 128 KB, allowing memorization of more than 16,000 data sets. To retrieve those data, the board has to be connected to a PC, running Unicleo-GUI. When stored data is retrieved via the GUI, the MCU flash sector dedicated to this purpose is cleared. If LED LD2 is ON after powering the board, it represents a warning message indicating the flash memory is full. Note: Optionally, the MCU memory can be erased by holding the user push buttondown for at least 5 seconds. LED LD2 switches OFF and then blinks 3 times to indicate that the data stored in the MCU has been erased. This option is available only after power ON or reset of the board while LED LD2 is ON indicating the flash memory is full. When the application runs in stand-alone mode and the flash memory is full, theapplication switches to PC GUI drive mode and LED LD2 switches OFF. The flash memory must be erased by downloading data via the Unicleo-GUI or theuser push button (see the above note). PC GUI drive mode In this mode, a USB cable connection is required to monitor real-time data. The board is powered by the PC via USB connection. This working mode allows the user to display the activity detected, accelerometer data, time stamp and eventually other sensor data, in real-time, using the Unicleo-GUI. In this working mode, data are not stored in the MCU flash memory. UM2193 - Rev 3 page 8/16

Unicleo-GUI application 4 Unicleo-GUI application The sample application uses the Windows Unicleo-GUI utility, which can be downloaded from www.st.com. Step 1. Step 2. Ensure that the necessary drivers are installed and the STM32 Nucleo board with appropriate expansion board is connected to the PC. Launch the Unicleo-GUI application to open the main application window. If an STM32 Nucleo board with supported firmware is connected to the PC, it is automatically detected and the appropriate COM port is opened. Figure 4. Unicleo main window Step 3. Start and stop data streaming by using the appropriate buttons on the vertical tool bar. The data coming from the connected sensor can be viewed in the User Messages tab. Figure 5. User Messages tab Step 4. Click on the Activity icon in the vertical tool bar to open the dedicated application window. UM2193 - Rev 3 page 9/16

Unicleo-GUI application If the board has been working in stand-alone mode and the user wants to retrieve stored data, press Download Off-line Data button to upload the stored activities data to the application. This operation automatically deletes acquired data from microcontroller. Note: Activities with a duration of less than 20 seconds are not memorized. Press the Save Off-line Data to File button to save the uploaded data in a.tsv file. Figure 6. Activity recognition window Step 5. Click on the Datalog icon in the vertical tool bar to open the datalog configuration window: you can select which sensor and activity data to save in files. You can start or stop saving by clicking on the corresponding button. Figure 7. Datalog window UM2193 - Rev 3 page 10/16

References 5 References All of the following resources are freely available on www.st.com. 1. UM1859: Getting started with the X-CUBE-MEMS1 motion MEMS and environmental sensor software expansion for STM32Cube 2. UM1724: STM32 Nucleo-64 board 3. UM2128: Getting started with Unicleo-GUI for motion MEMS and environmental sensor software expansion for STM32Cube UM2193 - Rev 3 page 11/16

Revision history Table 5. Document revision history Date Version Changes 10-Apr-2017 1 Initial release. 26-Jan-2018 2 19-Mar-2018 3 Updated Section 3 Sample application. Added references to NUCLEO-L152RE development board and Table 3. Elapsed time (µs) algorithm. Updated Section Introduction, Section 2.1 MotionAR overview and Section 2.2.5 Algorithm performance. UM2193 - Rev 3 page 12/16

Contents Contents 1 Acronyms and abbreviations...2 2 MotionAR middleware library in X-CUBE-MEMS1 software expansion for STM32Cube...3 2.1 MotionAR overview...3 2.2 MotionAR library...3 2.2.1 MotionAR library description....3 2.2.2 MotionAR APIs....3 2.2.3 API flow chart....4 2.2.4 Demo code....5 2.2.5 Algorithm performance...6 3 Sample application...7 4 Unicleo-GUI application...9 5 References...11 Revision history...12 UM2193 - Rev 3 page 13/16

List of tables List of tables Table 1. List of acronyms...2 Table 2. Algorithm performance...6 Table 3. Elapsed time (µs) algorithm.... 6 Table 4. Power supply scheme...7 Table 5. Document revision history... 12 UM2193 - Rev 3 page 14/16

List of figures List of figures Figure 1. Sensor orientation example...4 Figure 2. MotionAR API logic sequence...5 Figure 3. STM32 Nucleo: LEDs, button, jumper... 7 Figure 4. Unicleo main window....9 Figure 5. User Messages tab...9 Figure 6. Activity recognition window.... 10 Figure 7. Datalog window... 10 UM2193 - Rev 3 page 15/16

IMPORTANT NOTICE PLEASE READ CAREFULLY STMicroelectronics NV and its subsidiaries ( ST ) reserve the right to make changes, corrections, enhancements, modifications, and improvements to ST products and/or to this document at any time without notice. Purchasers should obtain the latest relevant information on ST products before placing orders. ST products are sold pursuant to ST s terms and conditions of sale in place at the time of order acknowledgement. Purchasers are solely responsible for the choice, selection, and use of ST products and ST assumes no liability for application assistance or the design of Purchasers products. No license, express or implied, to any intellectual property right is granted by ST herein. Resale of ST products with provisions different from the information set forth herein shall void any warranty granted by ST for such product. ST and the ST logo are trademarks of ST. All other product or service names are the property of their respective owners. Information in this document supersedes and replaces information previously supplied in any prior versions of this document. 2018 STMicroelectronics All rights reserved UM2193 - Rev 3 page 16/16