- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 563438 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174254
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
数学建模————统计问题之仿真(四)# N; L: c& }+ d: m. d9 w) N
仿真,顾名思义,就是利用计算机模拟研究对象,对于那些用数学公式或者规则描述的系统,计算机可以将其通过数值模拟出来,还能实现可视化。就好比我们看的小说一样,创造一个世界,需要有初始的人或物质,再加上法则(规则),那么这个世界就会逐步成型,仿真也是如此,我们需要给这个模拟世界一个初始的状态(包含应有的数据),然后告诉他运转的规则。/ U2 U5 r9 C% K6 m9 J
5 @/ s/ @! | f1 M& k6 m9 K* u
9 D4 b b4 w4 L( b4 t. Q1 | t; V, u9 u& ^ r
真实的系统往往存在着很多不确定因素 ,比如:要模拟某条道路的交通,我们就得知道路上的行车的情况,除了基本的交通规则之外,我们需要的是车辆的模拟。一般来说,我们都会给车流量一个分布,这样我们就相当于有了一个车辆生成器,然后通过行车规则,就可以完整的模拟出整条道路的交通。. {; L+ i7 T& h/ I8 J) X/ N
不过,大多数时候我们都只是设定几个交通状况指标,然后仿真不同时间的情况,就可以实现交通状况的数值模拟。当然,有时候为了论文(观赏)效果,还可以将整条道路分成很多个小块,当车经过时就让小块发亮,这样就可以看到整个交通的运行情况,这种方法我们叫做元胞自动机。
& C. J' r3 x. |) V# o. w! k' {6 T3 v/ Q' L" a9 Q8 c0 O% J( D/ j
" \9 a/ h7 z+ b5 p" w 既然是模拟系统,那么就需要一个系统的推进方式,我们依此可以将仿真分为时间步长法和事件步长法。时间步长法即将每经过一定时间步长就仿真一次活动,然后推进下去,而事件步长法即每发生一件事情就推进一次,当然这个步长也可以看做是每两个事件之间的时间。6 R3 g; Q) l6 [4 Z3 |' _% l
) a8 J# `- u, O 上面介绍的仿真方法都讲究推进,也就是说是动态的 ,除此之外还有静态仿真。静态仿真比较有名的是蒙特卡洛模拟,下面给大家展示一道百度校招笔试题:
! p: Z, n& `: ?" i) ?3 k* I 在平面上有一组间距为d的平行线,将一根长度为l(l<d)的针任意掷在这个平面上,求此针与平行线中任意一根相交的概率,用高等数学(微积分、概率的方法)求解,基于布丰投针的结论,任选一种编程语言(C/C++, matlab, Python, Java),写出模拟投针实验(程序中允许把一个理想的π作为常量使用),求解圆周率。+ s8 P, D6 e: ?, l3 F$ _: V. E% O
注:前面的高等数学部分可以求解,已证明这个概率=2l / πd,另外针中点到相邻平行线的距离x≤l/2sinφ,l是针的长度,φ是针与平行线的夹角。
j, l& n; ^! g( O c) O8 x' Y& }2 ? V1 S4 E/ F5 ~3 d* n
现在我们知道了规则,那就是x≤l/2sinφ,为了模拟各种情况,我们现在需要做的就是对未知量x和未知夹角φ进行随机模拟,然后计算符合规则的概率,最后依次计算圆周率。% C: x1 E8 d! \2 V$ x9 S
: }4 k# O& K5 \! c- T# p; ]5 ~4 p- f
' @* y& D. z" W {8 C9 L# m& k9 |/ T: m3 B7 B! T
: k% W5 } }# Xclc;clear;close all;/ f. y; X5 c, ~* d) {) ~! q3 d
d = 2;%设定平行线之间的距离
4 H1 ?' ?0 _. k5 I' R# Z* Vl = 1;%设定针的长度2 y$ I) R- m" X. S
n = 1000;%设定投针个数
e0 k* }1 W# Ubeta = 0 : 0.002 : pi;
5 j) [4 s7 K+ N2 U# X$ aplot(beta, l/2*sin(beta), 'k-')%绘出l/2*sin(φ)曲线
& R( V; a/ p0 {0 |! f) s8 j) Uaxis([0, pi, 0, d/2])%横坐标范围设在0~pi,纵坐标范围设在0~d/2
8 u% b: q. o1 ^2 O5 ]1 Y2 U6 u: Etitle('蒲丰投针实验')
5 g" y% W; I# @( J+ [! i: Ehold on0 d# _+ l8 D" r, X
beta = rand(1, n) * pi;%随机生成n个角度(0~180度)
. _2 I6 r% j, fx = (d/2) * rand(1, n);%在平行线中线以下生成n个针中心- s2 U {/ h% L5 l: H. m
m = 0;
9 y4 [! S7 c5 i! V5 Q3 G5 jfor i = 1 : n. _5 v9 k9 i: x) o
if x(i) <= l/2 * sin(beta(i))
# i+ x( X- b) Y) k m = m + 1;%符合条件就增计数
& N) j4 Y y" ]1 S% c8 s4 Q5 Q plot(beta(i), x(i), '.r')%将符合条件的针以红点形式画在图中
+ F/ I+ ]3 x j+ V pause(0.00001)( [! o+ ] W0 u$ K" N
else
- ~ \: X# k9 N; o9 L c% @0 _ plot(beta(i),x(i),'.b')%将不符合条件的针以蓝点形式画在图中
" S: X8 Y; s( t& p4 j( x- x pause(0.00001)- O2 J4 [0 r, u, ^
end+ k4 ?7 u5 c t5 K6 p- P
end
# h% u& U5 i5 K/ X: Dp = m/n;%计算概率# i3 y$ p$ x0 R& g7 { A
pai = 2*l / (d*p);%计算圆周率
+ z+ ]/ s$ l ~: J5 pdisp(['圆周率为:',num2str(pai)])# k- _1 D( A9 u% @
, d3 u$ ?5 x+ \5 U9 Y$ m& G
$ u7 `# ?1 ~0 @) t* W+ C
& ^/ [- g' d% k
结果如下:0 E: `) \( k; q1 P2 ]" k
/ A: U6 ~' |# }& J7 h, q! W& H. Q
) H9 J/ u6 Z, l
![]()
8 L2 y# p4 }& K1 D7 B
' ]9 P1 h7 d; n! G: C1 T0 y- t
Y; J8 @) C# N; d2 `7 ^8 e q2 E: \' _5 k3 u
& G' l5 }: h( f/ L, L- d! T |
zan
|