- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 563419 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174249
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
数学建模————统计问题之仿真(四)
0 C9 j1 _! a3 y% w 仿真,顾名思义,就是利用计算机模拟研究对象,对于那些用数学公式或者规则描述的系统,计算机可以将其通过数值模拟出来,还能实现可视化。就好比我们看的小说一样,创造一个世界,需要有初始的人或物质,再加上法则(规则),那么这个世界就会逐步成型,仿真也是如此,我们需要给这个模拟世界一个初始的状态(包含应有的数据),然后告诉他运转的规则。$ i3 v4 B0 F. f+ W# }9 j5 `; P
; n8 X {7 ]* l9 I! G! ~0 \; L
: @) o& \& Y" l7 ?6 j
/ @" M5 g7 i1 |0 b 真实的系统往往存在着很多不确定因素 ,比如:要模拟某条道路的交通,我们就得知道路上的行车的情况,除了基本的交通规则之外,我们需要的是车辆的模拟。一般来说,我们都会给车流量一个分布,这样我们就相当于有了一个车辆生成器,然后通过行车规则,就可以完整的模拟出整条道路的交通。0 Z( O! x/ z4 u4 ]
不过,大多数时候我们都只是设定几个交通状况指标,然后仿真不同时间的情况,就可以实现交通状况的数值模拟。当然,有时候为了论文(观赏)效果,还可以将整条道路分成很多个小块,当车经过时就让小块发亮,这样就可以看到整个交通的运行情况,这种方法我们叫做元胞自动机。
: t1 Z" c! A# z% y. L9 Y& F
Q$ n& I2 A, I1 i; t
- h" w- m/ Y* ?7 \9 V+ Y* ^; Y 既然是模拟系统,那么就需要一个系统的推进方式,我们依此可以将仿真分为时间步长法和事件步长法。时间步长法即将每经过一定时间步长就仿真一次活动,然后推进下去,而事件步长法即每发生一件事情就推进一次,当然这个步长也可以看做是每两个事件之间的时间。/ Z% m! R: b+ {7 b
0 {$ ^4 ~- j2 G' \+ P6 h# \ 上面介绍的仿真方法都讲究推进,也就是说是动态的 ,除此之外还有静态仿真。静态仿真比较有名的是蒙特卡洛模拟,下面给大家展示一道百度校招笔试题:: [- y3 E9 J& D) g* L) a
在平面上有一组间距为d的平行线,将一根长度为l(l<d)的针任意掷在这个平面上,求此针与平行线中任意一根相交的概率,用高等数学(微积分、概率的方法)求解,基于布丰投针的结论,任选一种编程语言(C/C++, matlab, Python, Java),写出模拟投针实验(程序中允许把一个理想的π作为常量使用),求解圆周率。
: h3 v5 A) S" P注:前面的高等数学部分可以求解,已证明这个概率=2l / πd,另外针中点到相邻平行线的距离x≤l/2sinφ,l是针的长度,φ是针与平行线的夹角。/ _& R( q- s- C$ N& B& i8 I
2 ]; B( f; ~2 i: N! P5 ~ 现在我们知道了规则,那就是x≤l/2sinφ,为了模拟各种情况,我们现在需要做的就是对未知量x和未知夹角φ进行随机模拟,然后计算符合规则的概率,最后依次计算圆周率。, l& t6 f" ^# h- R# o
# k. a5 v% [* d
3 V' ^$ r* H+ {/ u1 r( A0 d3 S$ v
" i! I( ^4 i1 s' B5 k" m( }
) |3 J# o+ \# t4 U% p0 v, d( Yclc;clear;close all;
6 D) p- q; Q% z: s8 b( Nd = 2;%设定平行线之间的距离
4 {$ D* [0 s' al = 1;%设定针的长度7 S/ J; v1 O6 V7 Z
n = 1000;%设定投针个数
, t) u* F- L2 V/ T# G+ Jbeta = 0 : 0.002 : pi;
4 J9 ?8 _8 P$ @4 { u( d/ Fplot(beta, l/2*sin(beta), 'k-')%绘出l/2*sin(φ)曲线
0 t7 h/ t- i7 d) f( y1 |2 ?axis([0, pi, 0, d/2])%横坐标范围设在0~pi,纵坐标范围设在0~d/2' G; J) S2 T1 a' P; Z
title('蒲丰投针实验')7 q4 _; l7 a! L( Q( G
hold on
, E" C+ S7 ^0 e9 j! R6 M+ y6 r4 ]beta = rand(1, n) * pi;%随机生成n个角度(0~180度)5 j3 Q5 D/ e$ t6 l: s: C
x = (d/2) * rand(1, n);%在平行线中线以下生成n个针中心
, _; I- ~* K) \m = 0;. t$ Z0 c0 q5 n# P6 Z$ u) U
for i = 1 : n1 M$ u' z4 B P' {
if x(i) <= l/2 * sin(beta(i))
0 q' U' p+ T# M- T! h6 W5 h8 g m = m + 1;%符合条件就增计数+ r* k1 \- P4 f. f
plot(beta(i), x(i), '.r')%将符合条件的针以红点形式画在图中, @" e" z9 M* B+ }) G( d, @7 ^
pause(0.00001)
' T0 S2 X- l& C8 j. P) ] else" s; l' p8 S& J: {. E
plot(beta(i),x(i),'.b')%将不符合条件的针以蓝点形式画在图中& g2 k' Q; W7 O# g0 m+ l: P2 N
pause(0.00001)8 v: b+ c+ Q/ F$ @* p% D% b1 X
end1 O! m) w; W4 i7 G/ r2 c
end
! C/ q. S$ q& @, B; V( Cp = m/n;%计算概率6 h& a0 A) t$ j- C* F
pai = 2*l / (d*p);%计算圆周率
8 \# k: c+ n& T8 z( Y* Rdisp(['圆周率为:',num2str(pai)])
/ w6 i4 p, w/ x
8 I2 h, M. L5 u
! X) c$ W7 t* G1 ?0 f7 F5 D( Z. y2 v$ _! T* k2 X* l, {& t+ c8 s
结果如下:
" z1 T7 f! W) \6 u$ g/ x- I- F2 f. N, y3 \) P& ?
8 D, Q9 s( T& j% Y6 t: R
0 L! V3 v; ^$ q3 q' M9 k; g# x2 [
, B& `+ I2 V3 K* d- V; u$ K9 U, i& t$ D) w% @6 T0 _
/ [$ N( t9 Q" A+ c2 S' T; w
+ A; r+ A; h X, i6 D |
zan
|