你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

基于STM32的神经网络手写识别

[复制链接]
STMCU-管管 发布时间:2021-8-24 13:10


STM32是在国内非常流行的32位MCU芯片,它价格便宜,功能强大,已经占据国内MCU市场的半壁江山。大家知道,STM32 主打的是 arm-cortex M 芯片,也就我们常说的单片机芯片,它的处理能力不够强大,但它能不能运行对算力要求高的神经网络呢?答案是可以的,因为STM32的M4之上的芯片已经内置了DSP处理器,可以执行高精度浮点运算。正好可以拿来做神经网络计算。但是,神经网络计算除了要求能做浮点运算还要求可以存储大量的参数,这就需要大量的内存和flash空间,这也是单片机类芯片短板的地方。我们这次使用的单片机是M4系列的STM32F407,由于内存有限,我们仅仅实现了一个3层的神经网络,但也可以实现手写数字识别功能。
12.png

理论基础:
首先设计一个3层的神经网络:
结构如下:
13.png

三层的神经网络,第一层是输入层,输入图片是28*28的分辨率,每个点作为输入的一个节点,所以总共有28*28=784个节点

神经网络计算公式如下:
inputx 为输入矩阵,w1, b1 为第一层的权重和偏移量

第一层计算
z1= inputx *w1+b1
y2 =f(z1)   f() 为sigmoid激活函数

第二层计算
z2 = y2*w2+b2  y2 为第一层输出,w2, b2 为第一层的权重和偏移量
y3 = f(z2)   f() 为sigmoid激活函数
y3 为输出结果矩阵

训练模型
神经网络的训练使用TensorFlow keras实现
核心的代码如下
14.png

激活函数使用sigmoid函数,训练优化使用adam算法,损失函数使用交叉熵。

经过20次训练得到准确率96%
15.png

模型训练好了后把参数导出来。
16.png

保存的文件分别是权重文件wight1.txt,weight2.txt,偏移量文件bias1.txt,bias2.txt

STM32实现
在STM32上使用的是DSP库函数进行矩阵乘法运算

核心函数是arm_mat_mult_f32()

arm_mat_mult_f32(&input,&w1,&z1)表示 矩阵乘法:z1 = input*w1

核心代码
17.png

液晶屏和触摸屏代码移植的野火stm32 例程代码,实现把画的字转换为28*28矩阵输入给DSP函数。

完整项目代码和硬件原理图参考:https://github.com/lvjlcn/NeuralNetwork_STM32_Handwriting.git

文章出处:物联网电子世界

收藏 评论0 发布时间:2021-8-24 13:10

举报

0个回答

所属标签

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版