Lab. of Statistical Signal Processing - Deep Neural Network for CS based signal reconstruction on STM32 MCU board
- System Workbench for STM32 (or equivalent IDE)
- STCube MX v5.2.0
- STCube MX AI package v4.1.0
- Python v3.7
- Tensorflow v2.0
- Jupyter Notebook
- SMT32 Board - NucleoH743ZI2 and STM32F4DISCO have been used for this demo
CS hinges on the assumption that x is -sparse, i.e., in the simplest possible setting, that an orthonormal matrix exists (whose columns are the vectors of the sparsity basis) such that when we express , then the vector does not contain more than non-zero entries. The fact that depends only on a number of scalars that is less than its sheer dimensionality hints at the possibility of compressing it. CS does this by applying a linear operator depending on the acquisition (or encoding) matrix with m < n and defined in such a way that can be retrieved from . The ratio is the compression ratio and will be indicated by CR. [Mangia, Mauro & Prono, Luciano & Pareschi, Fabio & Rovatti, Riccardo & Setti, Gianluca. (2019). Deep Neural Oracles for Short-window Optimized Compressed Sensing of Biosignals. 10.36227/techrxiv.10049843.v2. ]
More specifically, in this demo a serial communication has been established between the MCU and Python enironment. A master computer feeds y_test data to the MCU which in turn computes the output from the neural network and sends back such data to the computer. Finally, RSNR and the reconstructed input are computed by the Jupyter Notebook.
After having installed STCube MX version 5.2 and AI extension version 4.1 on a virtual machine with Windows 7 (Neither "Validation on Desktop" nor "Validation on Target" tasks appear to work on Windows 10), I have followed these steps:
- Click on "Access Board Selector", choose the appropriate device and click on "Start Project".
- Enable UART peripheral: USART3 peripheral of NUCLEO-144 board is directly connected to the ST-LINK therefore just a USB cable wil be needed for both programming and communication. Select USART3 from "Connectivity" dropdown menu and select "Asynchronous".
- Cick on "Additional Software" -> "STMicroelectronics.X_CUBE_AI" -> "Validation" (or "Application Template" to generate the code)
- Open Artificial Intelligence menu from the left-hand side, select the UART peripheral under "Platform Setting" previously enabled and click on "Add Network". Choose "Keras", "Saved Model" and upload the h5 format file containing the trained Neural Network.
- The model can be accurately examined with the options "Analyze", "Validate on Desktop", "Validate on target". Pay attention to select the correct COM port associated to the ST-LINK. This can be checked from "Control Panel" in Windows.
- Choose the adopted IDE (for this demo SystemWorkbench for STM32) in "Project Manager" options and run "Generate Code" (Remember to switch mode from Validation to Application Template, see point 3)
- Initialize the UART peripheral by calling this procedure inside main.c
- Define globally the following variables inside app_x-cube-ai.c
- Modify MX_X_CUBE_AI_Process() function
MX_USART3_UART_Init();
UART_HandleTypeDef huart3;
ai_float outdata[AI_NETWORK_OUT_1_SIZE];
uint8_t shat[AI_NETWORK_OUT_1_SIZE];
ai_float threshold = 0.0352120689269106; //O_min threshold
void MX_X_CUBE_AI_Process(void)
{
/* USER CODE BEGIN 1 */
int nb_run = 100;
AI_ALIGNED(4)
//INPUT AND OUTPUT BUFFERS
static ai_i8 out_data[AI_NETWORK_OUT_1_SIZE_BYTES];
static ai_u8 in_data[AI_NETWORK_IN_1_SIZE_BYTES];
/* Perform nb_rub inferences (batch = 1) */
while (--nb_run) {
/* ---------------------------------------- */
/* Data generation and Pre-Process */
/* ---------------------------------------- */
//FILL THE INPUT BUFFER
while(HAL_UART_Receive(&huart3, in_data, sizeof(in_data), HAL_MAX_DELAY)!=HAL_OK);
/* Perform the inference */
aiRun(in_data, out_data);
for (ai_size i=0; i < AI_NETWORK_OUT_1_SIZE; i++ ){
//CASTING TO AI_FLOAT THE OUTPUT OF THE NN
outdata[i] = ((ai_float *)out_data)[i];
//COMPUTING S_HAT
if(outdata[i] > threshold) shat[i] = 0x01;
else shat[i] = 0x00;
}
//TRANSMIT S_HAT
while(HAL_UART_Transmit(&huart3,shat,sizeof(shat),0xFFFF)!=HAL_OK);
}
/* USER CODE END 1 */
}
The python script Serial.py essentially imports the dataset, establishes a serial connection with the MCU and computes support mismatch and Recontruction SNR with the vectors provided by the microcontroller.