随机数是我们编程中非常常用的一项技术,在我们的生活中应用场景十分广泛,例如密码学中对密码的加密,在模拟信号中用来模拟随机事件的出现。9 q8 N$ `0 X& T* k
7 C, t2 U- P$ `% j- P& W
例如我们在之前的使用NanoEdge中测试的数据模拟正弦波的时候就出现了数据太过于精确而不像一个模拟信号的样子。
1 v$ m% s! T* s }7 N f, I$ N! `- F( _
因此使用随机数可以在模拟仿真领域中起到非常重要的作用。1 m$ j o) h7 K# q
$ s! I3 ?4 G, Y+ e
- ?* Q8 `: _2 g& Z' A: Y' I3 U
; w% Z# J$ p* D" x; J( c在STM32参考手册(F4系列)中提到了STM32中具有一个随机数发生器(RNG)读取其可以获得一个32位的随机数。
. w: g! O0 x. Q, g, l; s5 ^
6 C$ Y; O* o# O% {' b2 ?7 K
' W# F* r3 h1 g
5 n" N' t/ Z; q- `/ N& U
随机数发生器RNG采用模拟电路实现,同样具备着异常检测的功能。接着手册的后续部分讲述了如何操作寄存器中操作实现RNG,但是由于我们使用HAL库编程代码,因此我们直接跳到HAL库的部分。0 ^# e3 K4 _; [$ m! Z; b
& z$ h& Z1 `7 @3 o, r, h: v
# t9 O- I, y7 O- p
1 v7 o3 U: D$ D: R- |! m) z* v在CubeMX中我们需要使能RNG功能。
& }4 u- K7 F+ i% x0 S$ b: Y+ |
0 g' {+ |1 s9 m3 Z之后创建我们的工程。. K# v( h' v" H( _: y$ W1 s0 k
" c1 Z5 n! u4 y5 o' i5 t
我们可以使用HAL_RNG_GetRandomNumber来获取随机数+ z w5 D) V6 Z
- while (1)0 ~9 y$ ^5 q: X4 ~) S8 a0 h! H$ |! b
- {" K# m% q) R* Y" n$ y7 Q: g3 m7 G# i
- /* USER CODE END WHILE */
" |# k+ G4 h( E* e1 k# K6 C8 L
4 ]! D& v* C: H0 j$ x, x. f$ c% f2 W
0 g7 @4 {+ d4 i; {% ]$ K, k- /* USER CODE BEGIN 3 */
+ y6 m0 w9 t# Y) c& Q - printf("%ld\r\n",HAL_RNG_GetRandomNumber(&hrng));' w" g/ w/ k3 X8 u
- HAL_Delay(1000);
9 W# f8 Q, g& [2 L; X - }
复制代码 + r/ \. i. R/ C* W
需要注意的是,这里生成的随机数是32位的,因此我们可以利用一些简单的计算来获取我们需要的随机数。" w5 B/ ~! u. a7 P) @0 G g5 G
- uint32_t RnNum = HAL_RNG_GetRandomNumber(&hrng);5 Q! A; ^. O6 {' c5 e! q# e
- printf("%ld\r\n",RnNum%10);
" S6 A" s( V0 v, O O: G - HAL_Delay(1000);
复制代码 3 V# t: g# W9 Q: ~2 s+ u' p
我们对其进行取余,即可获得0~9之间的随机数。
& ]% t) a; I6 r& X: [$ t1 @- C+ @8 w0 [$ G( Z( q/ H# c9 w8 i
6 z5 G( J1 g8 {: y! V
8 n' a4 g) w* R# a0 r9 J& N2 X4 J3 ?初次之外,我们可以利用这个随机数来模拟噪声信号。8 Q* E/ A8 L* `5 _$ V% V0 l/ \
- while (1)( y% j5 n, _: e' s) R* _
- {
$ Q9 l7 A! i" O - /* USER CODE END WHILE */! }8 j3 T$ U7 p* i4 R' @
- 9 r( }4 S0 `, z* n% e
- 0 n$ Q* i/ B" \( a; r) p* H
- /* USER CODE BEGIN 3 */8 b3 ?4 v* S/ m$ V; f- M
- uint32_t RnNum = HAL_RNG_GetRandomNumber(&hrng);
* i: u9 d% |7 N - static float t = 0;
* P& d. V" W8 V( m5 B% z4 ~+ H - float s = sin(t)+RnNum%10*0.05;5 K$ F1 b6 ?1 H" A
- printf("A:%.3f\r\n",s);
% p! W0 o" w8 C/ g+ B' W - t+=0.01;
: J! S. B, P/ I; ~& q -
9 ], N( r8 d4 k! _2 R2 p* D - }
复制代码
9 _9 t2 I4 p; S# I0 e6 ~
/ }- [8 L D% i) ]6 \1 e" p& l- \
- I% u/ o% G$ ]# s. m. g: x5 j我们在原始信号之上添加一个噪声信号,这个噪声信号的产生就由我们的随机数发生器产生。8 w6 o& H2 G( u
9 L1 v- X! d1 Q1 I% Q( K/ C7 `. c
6 @: u2 e" m7 c2 L, [2 A/ j转载自:电路小白
4 u9 u! A m0 F; c& N. [8 F如有侵权请联系删除
( b/ B( ]/ S4 N* h6 ]- v; Z
5 t7 M. b& d% ^0 c1 w* X: H |