- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 563297 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174212
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
数学建模————统计问题之仿真(四)
0 z2 p( z" \: _6 K! K 仿真,顾名思义,就是利用计算机模拟研究对象,对于那些用数学公式或者规则描述的系统,计算机可以将其通过数值模拟出来,还能实现可视化。就好比我们看的小说一样,创造一个世界,需要有初始的人或物质,再加上法则(规则),那么这个世界就会逐步成型,仿真也是如此,我们需要给这个模拟世界一个初始的状态(包含应有的数据),然后告诉他运转的规则。
! o' d2 ?: L% h3 R/ W2 {! k% r7 n, r
* y/ l7 k, _1 ^; \ _
8 Q1 x) S1 w0 ~* b 真实的系统往往存在着很多不确定因素 ,比如:要模拟某条道路的交通,我们就得知道路上的行车的情况,除了基本的交通规则之外,我们需要的是车辆的模拟。一般来说,我们都会给车流量一个分布,这样我们就相当于有了一个车辆生成器,然后通过行车规则,就可以完整的模拟出整条道路的交通。
9 f4 }6 A$ b) x y8 A# |0 A 不过,大多数时候我们都只是设定几个交通状况指标,然后仿真不同时间的情况,就可以实现交通状况的数值模拟。当然,有时候为了论文(观赏)效果,还可以将整条道路分成很多个小块,当车经过时就让小块发亮,这样就可以看到整个交通的运行情况,这种方法我们叫做元胞自动机。, c( M N! a* A* J3 s" p4 T4 K
, g3 b* Z8 o1 Y6 H6 s
4 Y! A4 J" P2 O& ~2 ]: z: J 既然是模拟系统,那么就需要一个系统的推进方式,我们依此可以将仿真分为时间步长法和事件步长法。时间步长法即将每经过一定时间步长就仿真一次活动,然后推进下去,而事件步长法即每发生一件事情就推进一次,当然这个步长也可以看做是每两个事件之间的时间。
" s# l. T7 e( a/ L H+ V2 ~
h, `7 _2 l" g( c' { 上面介绍的仿真方法都讲究推进,也就是说是动态的 ,除此之外还有静态仿真。静态仿真比较有名的是蒙特卡洛模拟,下面给大家展示一道百度校招笔试题:: Z; @6 b6 p/ {9 j0 X; b
在平面上有一组间距为d的平行线,将一根长度为l(l<d)的针任意掷在这个平面上,求此针与平行线中任意一根相交的概率,用高等数学(微积分、概率的方法)求解,基于布丰投针的结论,任选一种编程语言(C/C++, matlab, Python, Java),写出模拟投针实验(程序中允许把一个理想的π作为常量使用),求解圆周率。
7 Z z7 }9 ] k" ?注:前面的高等数学部分可以求解,已证明这个概率=2l / πd,另外针中点到相邻平行线的距离x≤l/2sinφ,l是针的长度,φ是针与平行线的夹角。. g S) S1 N8 _
% k1 [2 J9 V8 \( P y
现在我们知道了规则,那就是x≤l/2sinφ,为了模拟各种情况,我们现在需要做的就是对未知量x和未知夹角φ进行随机模拟,然后计算符合规则的概率,最后依次计算圆周率。
; @7 A3 W5 m- z% K6 i4 M; I
y7 a: P H" P% n1 d% a4 z" p; |6 D7 k6 s; v% B
0 e+ s: @7 e1 k
. ~: N) |) F8 ^9 q& l* i' s$ H
clc;clear;close all;9 S/ g0 K N( _3 V8 V6 Z
d = 2;%设定平行线之间的距离
- J1 g, X j* A8 J4 e% Bl = 1;%设定针的长度
3 \) m" H3 v7 |! J \+ Vn = 1000;%设定投针个数2 D# J7 r- s# k" |, w ]8 ~+ `
beta = 0 : 0.002 : pi;
# K9 ]; k! B g" K! xplot(beta, l/2*sin(beta), 'k-')%绘出l/2*sin(φ)曲线0 {. R. ~: ^" a+ v
axis([0, pi, 0, d/2])%横坐标范围设在0~pi,纵坐标范围设在0~d/2
/ S% i9 ^- a+ @1 Mtitle('蒲丰投针实验'). Z0 Y$ E" \" A7 w, T5 k& d; M
hold on
- Q! k) J; }7 `3 q+ H6 Rbeta = rand(1, n) * pi;%随机生成n个角度(0~180度)
/ T3 K' A' S6 B! Ux = (d/2) * rand(1, n);%在平行线中线以下生成n个针中心
J0 K9 Q, h+ p& Pm = 0;
; h( q5 k/ C R: S, Afor i = 1 : n; V7 r* l8 g1 Z+ w0 K; k
if x(i) <= l/2 * sin(beta(i))6 }$ B |- I) l: e
m = m + 1;%符合条件就增计数6 f9 Y& @- d' p' K3 h
plot(beta(i), x(i), '.r')%将符合条件的针以红点形式画在图中
7 Q3 t. d( q8 @$ Y" l! Q/ [! u pause(0.00001)
$ d2 B! f# s9 @$ R( } else
! V: @* k% h/ _, P plot(beta(i),x(i),'.b')%将不符合条件的针以蓝点形式画在图中
; Y+ m. X/ r! j6 K# e# m pause(0.00001)& s; W/ `+ w: C: E
end
" T% }# W/ c, Iend; L7 y) N4 a; Z5 l
p = m/n;%计算概率* \9 u: k7 Y1 X! U
pai = 2*l / (d*p);%计算圆周率7 c) k3 D( o3 ~! r+ x3 F2 ^
disp(['圆周率为:',num2str(pai)])
7 _, O9 b @0 v" ^$ D
! L2 s6 ~) q9 n# r
) O- S* ?/ H9 O. C; w% T! K% b& W$ D+ X0 Y6 E$ M2 ?
结果如下:& d( p7 R4 Z5 P% }! D
. d$ w* h8 k% d1 B' r+ ]: ~
3 @9 e2 G) `! H5 b& b . {: e4 x+ w8 U
1 g5 m( [& _8 e# I2 d
. P; E. u v" Y. X& k6 w6 |+ B
+ H3 N; v( \7 g, E- C
. b6 p* @8 ~& q; }% I" \ |
zan
|