|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
人工神经网络的基本概念:
3 ?# n) B2 [! C6 G5 v/ G0 K人工神经网络是对脑神经元结构的抽象。大脑中的神经元可以自行连接一定距离内的其他相同个体并与之通信,而人工神经元则是层层传递,其中每个人工神经元都设有有激活函数,并由此来决定到底是向下一次层传递兴奋信号还是抑制信号。激活函数中可变的是权值和阈值,在神经网络的训练过程中,就是不断对权值和阈值进行修正,使之更好的拟合训练集的数据。
# w, D) m; V8 F0 S8 }4 [& f: i- v0 f5 g- M2 e- D8 {5 D
常见神经网络拓扑:
! V& x! F: M4 p5 v数层若干神经元层层连接,就形成了神经网络。某种程度上,神经网络就是一个图问题,根据拓扑结构的不同,又有如下区分:6 V* P( M4 L, h% r/ W* ^% @
1. 单层前向神经网络; m; {( @: D R: G, F
这种神经网络的的缺陷是只能对线性问题分类。改进思路就是修改激活函数(把分类线变成曲线,如椭圆线)、增加神经网络层数(让两条直线或多条直线来分类)。
# v+ J# c; [6 c
0 N5 q, i' m( x, K5 B7 f! L: f
主流做法是增加层数,于是有了多层感知器 。
! O3 |& f$ Q2 K& w7 w% q2.多层前向神经网络% g5 a: s$ U' J9 q- C- T$ z
" V! u: K+ p% H3.反馈神经网络
" c8 E1 ]. ?4 {( F+ p0 y, P
# q- \) ?( ?! `. L3 k! \+ q4.随机神经网络
k( B6 r2 J- x% {$ X* ]+ |
' R1 ~7 a2 P, J8 r0 G5.竞争神经网络(一个神经细胞兴奋后抑制周围的神经细胞)4 ?. P" g, Q% z: X" Y# Q {2 J
0 @' P! `: s0 |# G; g5 {8 u: i8 d
随着时间的发展,深度神经网络不断出现,如最后的循环神经网络,卷积神经网络等。但是对于单片机而言,由于算力的限制,简单的浅层神经网络有更大的使用价值。而大部分浅层神经网路输入输出可以表示为下列公式:, h( Q8 b1 g# B* ~& r: D3 \
/ L" B, ? q* a4 C8 j- W5 d( D
其中的u指的是输入神经元的值,w与b分别是需要通过训练确认的权值和阈值,公式的迭代则反映的是神经网络内神经元的层级结构。
: P$ h( x0 d1 j! j" h, S2 o! K+ u5 H! T" u
单片机中运行神经网络的程序源码:
9 D/ H' m4 n* D6 i4 R程序代码如下:
. N7 z3 k( y8 [* a# J) g3 {#include <reg52.h>
2 z! z2 @9 o0 W& g& `#include <absacc.h>
- V- \% }7 u! _, Q# x. ^1 t#include <stdio.h>9 `7 W% s( @1 X1 x
#include <math.h>
1 E1 _ |& n+ k1 V, i8 n5 P#define uchar unsigned char4 t7 i) R& h' r8 L% {
uchar num;+ `6 _! T1 F' g) m k$ T4 f
flOAT s1_out1,s1_out2,s1_out3,s1_out4,s2_out1,s2_out2,s2_out3,s2_out4;
. r4 J+ o6 I* S7 F' P" }float yout,u1,u2,u3,u4;. ^4 v- b0 t9 o+ ]- P0 r' P' q
6 g1 E3 M2 @# L0 {" s; @2 r
void main()2 ^4 p) C, v% Z/ r
{
; F) X+ r9 X6 }& s5 _7 OEA = 1;* j& t# G/ d( @5 b6 s' I
ET0 = 1;1 V+ Q2 c w; \5 B% |. Z
TMOD = 0x01;( Q2 w o+ ^0 M0 o, M
TL0 = 0x00;3 v- L8 S- J, f
TH0 = 0x00;/ m1 f9 B/ X* A/ t/ U9 n
num = 0;4 Q0 `9 ` ]" z8 A) M8 }
u1 = 0.0107;& i7 @! s e1 V+ n. L, c
u2 = 0.3055;
: f h$ n! L; D4 Q) u1 Du3 = 0.3046;
& j) P/ x* B# x6 }5 O3 @u4 = 0.3038;
" J' n" A2 [7 e& Q9 e( Q% T& aTR0 = 1;' [5 O2 }$ C6 G* f/ ^0 T) G
s1_out1 = (-0.6133*u1+1.1958*u2+0.1451*u3-1.4079*u4+2.0969);9 i3 Y9 {" ~+ O: L
s1_out1 = 2/(exp(-2*s1_out1))-1;
! C# f- A" Z1 X5 f- @s1_out2 = (0.7955*u1+0.4564*u2+1.6416*u3-0.6515*u4-0.6728);. H* Q, P; w2 `# P
s1_out2 = 2/(exp(-2*s1_out2))-1;
5 B2 _% I( T+ A% j4 Q1 r4 Z7 is1_out3 = (0.1069*u1+0.6961*u2+1.3756*u3-1.5583*u4-0.0661);
4 J' R; r) G3 x3 V0 S$ `1 Ks1_out3 = 2/(exp(-2*s1_out3))-1;
- ?3 n2 {/ X: \# r. Vs1_out4 = (0.1996*u1+1.0877*u2+1.09058*u3-0.34468*u4-2.8265); x, E* X' d; ^6 ]
s1_out4 = 2/(exp(-2*s1_out4))-1;' ~! l3 `. D5 I) B
& A% w U3 L1 G5 X* K! Cs2_out1 = (-1.0413*s1_out1+0.8898*s1_out2-1.3195*s1_out3-0.2691*s1_out4+2.0827);; _+ N* _5 G" U+ I3 }# V7 r
s2_out1 = 2/(1+exp(-2*s2_out1))-1;
6 l5 v: U9 u3 p3 j% B+ Bs2_out2 = (-1.3146*s1_out1+0.4266*s1_out2-1.7021*s1_out3-0.0018*s1_out4+0.6756);
3 q8 {: }# u+ e6 U0 ]& V0 ks2_out2 = 2/(1+exp(-2*s2_out2))-1;
) S: x1 L9 [6 g; ^7 r! P) ss2_out3 = (1.6830*s1_out1-0.9289*s1_out2-0.3520*s1_out3-0.2839*s1_out4+0.6526);
5 Y8 y+ `; n5 E$ f2 Cs2_out3 = 2/(1+exp(-2*s2_out3))-1;/ r7 L4 k6 e* }0 n
s2_out4 = (-1.4929*s1_out1-0.1193*s1_out2-0.4037*s1_out3-1.2339*s1_out4+0.20409);
$ M5 a7 I) C- a% @; k* e% ~s2_out4 = 2/(1+exp(-2*s2_out4))-1;
+ R3 r2 ?& u9 v ^# oyout = (-0.1805*s2_out1+0.9100*s2_out2+0.5065*s2_out3-0.2351*s2_out4-0.1674);
" k. [( l% v6 o/ D/ v6 @( D2 W8 YTR0 = 0;; x. G7 M5 n9 M3 S
ET0 = 0;9 A5 j" W& \" Q. b5 I
while(1); U" S# B9 ^8 `9 t- ~/ I
7 q' E, x0 S- p}0 M" W2 w) Y. Y9 \
void intsVR1() interrupt 1 using 10 p$ X2 u1 ^. w+ l [8 ]# i
{; O1 h" y* n) z; Z6 I+ O2 L' j
num++;
+ w$ s2 x" n6 z1 } v* NTH0 = 0x00;1 m3 @1 o) u. ?9 g+ W% n
TL0 = 0x00;
$ L" ^7 y5 J/ l) y" P}9 t; a6 _( W3 I, D$ e
程序中的神经网络的权值和阈值,已经在先前训练阶段所确定,并且由于单片机对ROM和RAM的资源限制,我们选择将权值和阈值写成了立即数的形式。$ i; A0 W: u& t; W! o) \2 O! x) U j
由于我们这是训练后的神经网络,所以使用分段多项式的方式来拟合激活函数tanh,这也符合单片机计算浮点数较慢的现实。
& F% K6 g: J, W3 c* G9 e% F在保证一定预测精度的情况下,使用单片机来实现神经网络,应考虑现实条件的制约,将神经网络模型尽可能的简化。
: D2 Q; ]2 V, e ~) `, W5 D% k8 F5 @ |
|