因为某个测试需要,在STM32F407平台上验证矩阵乘法,使用ARM官方库“CMSIS_5-5.5.1\CMSIS\DSP\Source\MatrixFunctions\arm_mat_mult_q31.c”中函数arm_mat_mult_q31。
测试实例,参照《安富莱_STM32-V5开发板_数字信号处理教程(V1.0).pdf》-20.2 矩阵乘法 MatMult
-20.2.6 实例讲解中所列(参考并便于对比)。
实例代码整理如下:
uint8_t i;
arm_status status;
arm_matrix_instance_q31 pMatrixSrcA1_q31; /* 10 * 10 */
arm_matrix_instance_q31 pMatrixSrcB1_q31; /* 10 * 10 */
arm_matrix_instance_q31 pMatrixDst1_q31; /* 10 * 10 */
for (i = 0; i < DEF_matrix_src_size; i++)
{
pDataSrcA1_q31[i] = i;
pDataSrcB1_q31[i] = i + 100;
pDataDst1_q31[i] = 1;
pDataDst1_q31[i + 10] = 1;
}
arm_mat_init_q31(&pMatrixSrcA1_q31, DEF_matrix_square_size, DEF_matrix_square_size, pDataSrcA1_q31);
arm_mat_