/xsens-stm32-eui

Example integration of xsens-mti library with STM32F4 discovery. Data visualisations with Electric UI.

Primary LanguageCMIT LicenseMIT

STM32 with xsens MTi IMU

This is an example project which acts as a basic implementation of my xsens-mti library, running on a STM32F4 Discovery board.

This project also integrates electricui-embedded for real-time charting of variables from the STM32.

Youtube video of motion data plotting in car

IMU Configuration

The IMU used is a xsens MTi-300-2A5G4 (4th generation, RS232+USB, 450deg/sec), along with a CA-MP2-MTi cable. The IMU requires a 5-34V supply, drawing around 600mW.

The IMU can be configured with the MT manager tool, I configure them to output quaternions, acceleration, free acceleration, rate of turn, temperature, pressure, statusword and coarse timing, at 400Hz.

At some point in the future, I might perform configuration of the IMU from the STM32.

STM32 Setup

This project is intended for use with the ever-popular green STM32F407 Discovery Board.

xsens stm32 wiring diagram

A USB-UART adapter is needed to connect the STM32 to the PC for realtime display of data connected to USART2 with PD5/PD6.

The IMU's RS232 lines are connected to a MAX232 transceiver IC, ultimately interfacing to the STM32's USART1 with PB6/PB7.

Ground is common between the USB-UART, STM32 and xsens hardware.

Firmware Setup

This repo does not contain the xsens-mti or electricui-embedded libraries.

Download/clone them into /firmware/vendor/xsens-mti and /firmware/vendor/electricui respectively before use.

The firmware assumes an IMU baudrate of 921600 and an Electric UI baud rate of 500000. These can be changed in app_times.h.

Usage Notes

The actual firmware is pretty simple, but is built on an underlying bespoke co-operative hierarchical state-machine/tasking system which might appear intimidating at first glance.

As a quick explanation, the main loop runs at 1kHz. Each tick, a task is run along with background tasks and then the CPU is put into WFI light sleep until interrupts need servicing, or the next tick has arrived.

app_task_communication.c is responsible for setting up the UART hal (DMA driven RX/TX) for both the xsens-mti libary and electricui-embedded. It also sets up handlers and serial output callback functions.

Every tick, the inbound serial FIFO buffers are polled for data, and bytes are passed to the relevant libraries.

Inbound motion related packets are received from the IMU, parsed, then a callback is fired providing valid motion data (AppTaskCommunication_imu_callback_event()). This data is passed over to a setter/getter 'config' helper in configuration.c which is essentially data storage and abstraction on the UI communications library.

In more involved applications, this data would instead be passed to control systems, or events generated to allow other systems to handle IMU data.

Interface

3d-model

Setup

The UI works on Windows, Mac OS, and Linux.

With arc installed, navigate a shell to /interface and run arc install to get everything setup.

Usage

From /interface, run arc start from a shell to launch the development environment.

To build an executable bundle (production build), run arc build. The output will be put in /interface/release/....

The main points of interest are inside the DevicePages folder.