- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 564695 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174631
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
数学建模————统计问题之仿真(四)
3 P9 X1 L% M9 h: }( p- g7 J 仿真,顾名思义,就是利用计算机模拟研究对象,对于那些用数学公式或者规则描述的系统,计算机可以将其通过数值模拟出来,还能实现可视化。就好比我们看的小说一样,创造一个世界,需要有初始的人或物质,再加上法则(规则),那么这个世界就会逐步成型,仿真也是如此,我们需要给这个模拟世界一个初始的状态(包含应有的数据),然后告诉他运转的规则。
6 K8 Q7 p% j" h6 A5 s' G7 R2 P: v' j% m/ f0 Z( F# z( L
' c/ i( M1 x$ ~
* f3 J. x3 R4 W 真实的系统往往存在着很多不确定因素 ,比如:要模拟某条道路的交通,我们就得知道路上的行车的情况,除了基本的交通规则之外,我们需要的是车辆的模拟。一般来说,我们都会给车流量一个分布,这样我们就相当于有了一个车辆生成器,然后通过行车规则,就可以完整的模拟出整条道路的交通。
) M& X6 p- i) g6 o 不过,大多数时候我们都只是设定几个交通状况指标,然后仿真不同时间的情况,就可以实现交通状况的数值模拟。当然,有时候为了论文(观赏)效果,还可以将整条道路分成很多个小块,当车经过时就让小块发亮,这样就可以看到整个交通的运行情况,这种方法我们叫做元胞自动机。
* U3 k2 M! ]+ R8 ~
N/ R0 P2 ^ m5 c! |) T" w; A6 }3 x
+ R2 [: @* m/ b7 F$ Y) K! T. G 既然是模拟系统,那么就需要一个系统的推进方式,我们依此可以将仿真分为时间步长法和事件步长法。时间步长法即将每经过一定时间步长就仿真一次活动,然后推进下去,而事件步长法即每发生一件事情就推进一次,当然这个步长也可以看做是每两个事件之间的时间。% v; ]# A" R5 M
& ~# s: R' |, G9 U$ J+ D
上面介绍的仿真方法都讲究推进,也就是说是动态的 ,除此之外还有静态仿真。静态仿真比较有名的是蒙特卡洛模拟,下面给大家展示一道百度校招笔试题:
9 T8 l9 K2 |( A4 x8 n4 } 在平面上有一组间距为d的平行线,将一根长度为l(l<d)的针任意掷在这个平面上,求此针与平行线中任意一根相交的概率,用高等数学(微积分、概率的方法)求解,基于布丰投针的结论,任选一种编程语言(C/C++, matlab, Python, Java),写出模拟投针实验(程序中允许把一个理想的π作为常量使用),求解圆周率。$ {5 R. r6 a8 n. T3 u
注:前面的高等数学部分可以求解,已证明这个概率=2l / πd,另外针中点到相邻平行线的距离x≤l/2sinφ,l是针的长度,φ是针与平行线的夹角。
9 K! y; v3 q; w, ?2 k0 d$ m' D! J% `$ k' \$ U7 }
现在我们知道了规则,那就是x≤l/2sinφ,为了模拟各种情况,我们现在需要做的就是对未知量x和未知夹角φ进行随机模拟,然后计算符合规则的概率,最后依次计算圆周率。
Z+ J7 x+ n8 z. h; R( Z- I' Q* n1 f, F( ]) k% A+ w
, T" q- `! ]) \" e( J3 R. }
, ?- Q0 z8 J3 T5 O, J( |8 T- W/ ]; E% Q3 s, g) E n/ A r
clc;clear;close all;( P1 z- b5 ]% O" S8 {8 e7 H% E1 Z
d = 2;%设定平行线之间的距离
# v, D! p; O+ r+ A1 g" F3 I5 xl = 1;%设定针的长度- `, H5 E' v, y
n = 1000;%设定投针个数! e O1 p" _( @4 q$ G2 A7 Y. h6 A
beta = 0 : 0.002 : pi;
, M% {/ k4 ~7 n# w- Tplot(beta, l/2*sin(beta), 'k-')%绘出l/2*sin(φ)曲线4 d" q% w. H1 H: V
axis([0, pi, 0, d/2])%横坐标范围设在0~pi,纵坐标范围设在0~d/2
- s* l/ M* P* \3 |! Q9 o) B) rtitle('蒲丰投针实验')) Z% \3 C o3 g( d- L) O
hold on' M# K* |( y% V6 Y; l6 e
beta = rand(1, n) * pi;%随机生成n个角度(0~180度): m: m# g- b3 m
x = (d/2) * rand(1, n);%在平行线中线以下生成n个针中心3 `6 C/ J' v8 k+ ?2 ~
m = 0;
1 A: N% _0 Y% i" a& B& j, P# Kfor i = 1 : n5 k; F A+ c V
if x(i) <= l/2 * sin(beta(i))
6 t, S0 o& G* z9 [0 p! Q& Y m = m + 1;%符合条件就增计数" I+ N) y. ~* J C) G% l
plot(beta(i), x(i), '.r')%将符合条件的针以红点形式画在图中1 h" Y1 K7 W# G7 I# l8 T0 b+ }1 l
pause(0.00001)7 z( n- ~* ^. d6 x l5 Z
else
8 L$ i s! x/ p4 A \5 f% R plot(beta(i),x(i),'.b')%将不符合条件的针以蓝点形式画在图中
4 P/ u6 v2 q* Q" n3 g5 ` pause(0.00001)7 i5 w0 d+ n: y" ` t
end( n0 `% c, o3 g; w i
end0 ]9 x: e4 B d
p = m/n;%计算概率8 V5 u( }' a/ B9 R
pai = 2*l / (d*p);%计算圆周率
, R2 N% g7 C! Rdisp(['圆周率为:',num2str(pai)])/ s- B1 Y( c& Q1 p8 w7 O; @
; ^# S5 ^4 V3 ^# y- r& ?
; M# [, U/ v7 d5 u5 Y4 h, z+ }/ l2 q( A0 L
结果如下:" o: p& Y/ z; ?
. j6 K; b/ Y$ X
; b" h0 l; c$ q. h1 t; y![]()
: U6 Z! A: e4 A, m5 c/ v; b8 w2 ?! V% l( s; c1 V4 W8 D# J
) R" Y* X) u' ~6 J! ]" W
1 ]( H5 L5 _; ^; Y) g
$ h/ G8 S. w. i- s7 \# ? |
zan
|