- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 555808 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 172115
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 18
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
数学建模————统计问题之仿真(四)
( m) p; j- k6 C+ v* {0 v) t/ h 仿真,顾名思义,就是利用计算机模拟研究对象,对于那些用数学公式或者规则描述的系统,计算机可以将其通过数值模拟出来,还能实现可视化。就好比我们看的小说一样,创造一个世界,需要有初始的人或物质,再加上法则(规则),那么这个世界就会逐步成型,仿真也是如此,我们需要给这个模拟世界一个初始的状态(包含应有的数据),然后告诉他运转的规则。
, z4 U# z' h! y$ d" u4 |. O7 s C/ i) D- `
, V- \+ s- Z% x2 ~5 v
& b! ]0 I+ |: B' I5 z/ S% V* `1 j 真实的系统往往存在着很多不确定因素 ,比如:要模拟某条道路的交通,我们就得知道路上的行车的情况,除了基本的交通规则之外,我们需要的是车辆的模拟。一般来说,我们都会给车流量一个分布,这样我们就相当于有了一个车辆生成器,然后通过行车规则,就可以完整的模拟出整条道路的交通。; X [& }7 X. [; K" C4 H
不过,大多数时候我们都只是设定几个交通状况指标,然后仿真不同时间的情况,就可以实现交通状况的数值模拟。当然,有时候为了论文(观赏)效果,还可以将整条道路分成很多个小块,当车经过时就让小块发亮,这样就可以看到整个交通的运行情况,这种方法我们叫做元胞自动机。
5 F3 H3 g( ^8 R+ [: `/ V1 G
4 f9 g N6 U' s9 o$ w# J. h4 o; I) P7 E: Q, Z; i* @' c$ E5 @/ `
既然是模拟系统,那么就需要一个系统的推进方式,我们依此可以将仿真分为时间步长法和事件步长法。时间步长法即将每经过一定时间步长就仿真一次活动,然后推进下去,而事件步长法即每发生一件事情就推进一次,当然这个步长也可以看做是每两个事件之间的时间。
& o/ Y+ w, O9 q6 c' X' D
! f W9 E( I* A) ]1 ~ 上面介绍的仿真方法都讲究推进,也就是说是动态的 ,除此之外还有静态仿真。静态仿真比较有名的是蒙特卡洛模拟,下面给大家展示一道百度校招笔试题:/ m, I. m8 c& J. ?* E# f/ U5 s) V
在平面上有一组间距为d的平行线,将一根长度为l(l<d)的针任意掷在这个平面上,求此针与平行线中任意一根相交的概率,用高等数学(微积分、概率的方法)求解,基于布丰投针的结论,任选一种编程语言(C/C++, matlab, Python, Java),写出模拟投针实验(程序中允许把一个理想的π作为常量使用),求解圆周率。5 K8 ]" y: d* N) ?9 I
注:前面的高等数学部分可以求解,已证明这个概率=2l / πd,另外针中点到相邻平行线的距离x≤l/2sinφ,l是针的长度,φ是针与平行线的夹角。0 i4 ?- r% h0 H. W0 j
- A8 ]9 _3 s) w! Z; k- r
现在我们知道了规则,那就是x≤l/2sinφ,为了模拟各种情况,我们现在需要做的就是对未知量x和未知夹角φ进行随机模拟,然后计算符合规则的概率,最后依次计算圆周率。
" A! w" T+ ?, f* v0 f4 Q, P7 M0 V, f; ?4 J
# R! J8 R. [) K( e' P6 }
o0 a- t0 {8 ]
% U) [) P5 C9 u, I4 @clc;clear;close all;
, `$ ?. Z1 g' B' ~d = 2;%设定平行线之间的距离
% F: W" n m- O) G5 ul = 1;%设定针的长度2 f% R4 p. m" ?" ^/ N6 K
n = 1000;%设定投针个数
3 N9 f4 n7 F$ @: a6 bbeta = 0 : 0.002 : pi;
y2 h2 A3 a8 b$ \/ tplot(beta, l/2*sin(beta), 'k-')%绘出l/2*sin(φ)曲线: G" E1 z, N' Y. ~
axis([0, pi, 0, d/2])%横坐标范围设在0~pi,纵坐标范围设在0~d/24 ?+ b3 M9 F: d9 u/ G
title('蒲丰投针实验'): ~* ^3 [# w/ L2 C
hold on# d: n( q: C! R" L5 ~, G; b1 m$ k
beta = rand(1, n) * pi;%随机生成n个角度(0~180度)/ |/ T$ v' r& F( P5 w
x = (d/2) * rand(1, n);%在平行线中线以下生成n个针中心/ H0 b* V$ b) Q% T/ Z
m = 0;, V- F( q& q* D% r" o
for i = 1 : n2 d9 E: ], ~: Q
if x(i) <= l/2 * sin(beta(i))# N- g) C* C) @7 A: E
m = m + 1;%符合条件就增计数2 \* e8 d. f" n U: ~
plot(beta(i), x(i), '.r')%将符合条件的针以红点形式画在图中; U( z, I' e7 }1 h9 N& |. L/ b4 @
pause(0.00001)- ?0 Q+ l/ X1 l) [
else4 P; ]* y$ o$ `% j$ t# S- ^' `8 g
plot(beta(i),x(i),'.b')%将不符合条件的针以蓝点形式画在图中
/ h% w; ?% @0 r% r. p* u' I( o pause(0.00001)9 t" F3 D9 f% G0 \
end8 Q! D) y: Z) U4 _
end
V I; H4 L9 E+ n# D) u: \p = m/n;%计算概率
* X5 N+ g8 r t2 |pai = 2*l / (d*p);%计算圆周率6 _% X! P2 U- a/ V8 o2 q8 i$ W
disp(['圆周率为:',num2str(pai)])7 _8 u" _6 n1 }$ | H& L
4 _$ T" D2 }5 c' o
* d1 {+ W( j6 I: B2 W+ S- f
1 ?1 c" ^; G! J结果如下:
% w* Q* b I- j8 \; X+ R0 ?1 o3 T- W' d- P0 `, h8 ]1 n }
7 ~- }% w- r$ A4 I( V D$ _
![]()
2 c2 X! t" @" r3 C5 z
4 D$ R; I/ M K0 \1 ?) [: q$ G/ D5 j" P1 y; `: b
; Y% c, y6 F( p0 L
7 q/ L t( X( O' U4 ~, f |
zan
|