- 在线时间
- 1630 小时
- 最后登录
- 2024-1-29
- 注册时间
- 2017-5-16
- 听众数
- 82
- 收听数
- 1
- 能力
- 120 分
- 体力
- 564704 点
- 威望
- 12 点
- 阅读权限
- 255
- 积分
- 174634
- 相册
- 1
- 日志
- 0
- 记录
- 0
- 帖子
- 5313
- 主题
- 5273
- 精华
- 3
- 分享
- 0
- 好友
- 163
TA的每日心情 | 开心 2021-8-11 17:59 |
|---|
签到天数: 17 天 [LV.4]偶尔看看III 网络挑战赛参赛者 网络挑战赛参赛者 - 自我介绍
- 本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。
 群组: 2018美赛大象算法课程 群组: 2018美赛护航培训课程 群组: 2019年 数学中国站长建 群组: 2019年数据分析师课程 群组: 2018年大象老师国赛优 |
数学建模————统计问题之仿真(四)
. |1 Z1 j+ X; y3 l, K 仿真,顾名思义,就是利用计算机模拟研究对象,对于那些用数学公式或者规则描述的系统,计算机可以将其通过数值模拟出来,还能实现可视化。就好比我们看的小说一样,创造一个世界,需要有初始的人或物质,再加上法则(规则),那么这个世界就会逐步成型,仿真也是如此,我们需要给这个模拟世界一个初始的状态(包含应有的数据),然后告诉他运转的规则。0 f6 o6 n. Z# m# u8 s* V: q9 z
7 [( e1 ~% c1 U7 m- x) I- _
* [& {2 P# I$ T6 N T- ]$ X
: f' l i$ D1 | 真实的系统往往存在着很多不确定因素 ,比如:要模拟某条道路的交通,我们就得知道路上的行车的情况,除了基本的交通规则之外,我们需要的是车辆的模拟。一般来说,我们都会给车流量一个分布,这样我们就相当于有了一个车辆生成器,然后通过行车规则,就可以完整的模拟出整条道路的交通。8 j+ G# e# h! C+ ]2 _+ b/ P @
不过,大多数时候我们都只是设定几个交通状况指标,然后仿真不同时间的情况,就可以实现交通状况的数值模拟。当然,有时候为了论文(观赏)效果,还可以将整条道路分成很多个小块,当车经过时就让小块发亮,这样就可以看到整个交通的运行情况,这种方法我们叫做元胞自动机。
6 I7 l9 v6 A( ]5 I" n, L4 j& [- k2 T$ U6 D! i/ ]
/ K( t9 w1 C" I
既然是模拟系统,那么就需要一个系统的推进方式,我们依此可以将仿真分为时间步长法和事件步长法。时间步长法即将每经过一定时间步长就仿真一次活动,然后推进下去,而事件步长法即每发生一件事情就推进一次,当然这个步长也可以看做是每两个事件之间的时间。
5 T& R/ O- B* ~. o2 b* Z8 D/ q) f' [
/ E1 m/ b- @6 p4 L/ l 上面介绍的仿真方法都讲究推进,也就是说是动态的 ,除此之外还有静态仿真。静态仿真比较有名的是蒙特卡洛模拟,下面给大家展示一道百度校招笔试题:2 Z' l' f' x4 G6 r% V5 W9 L
在平面上有一组间距为d的平行线,将一根长度为l(l<d)的针任意掷在这个平面上,求此针与平行线中任意一根相交的概率,用高等数学(微积分、概率的方法)求解,基于布丰投针的结论,任选一种编程语言(C/C++, matlab, Python, Java),写出模拟投针实验(程序中允许把一个理想的π作为常量使用),求解圆周率。
' n/ K1 V/ t; t+ N2 A# M# n7 ]注:前面的高等数学部分可以求解,已证明这个概率=2l / πd,另外针中点到相邻平行线的距离x≤l/2sinφ,l是针的长度,φ是针与平行线的夹角。) Y# A- `! x; e/ v, b
3 U* g2 ^( p+ B
现在我们知道了规则,那就是x≤l/2sinφ,为了模拟各种情况,我们现在需要做的就是对未知量x和未知夹角φ进行随机模拟,然后计算符合规则的概率,最后依次计算圆周率。+ I* t }1 H' ?' ?( F/ o* e9 t3 e& a
" [% ] ?3 w/ W7 ^, x! d! C1 h7 |8 f- l! \& \) D6 I# M( Y7 i
1 L8 g2 r1 ?% v; v$ p( T) w1 O6 v7 s
clc;clear;close all;$ X7 _/ N. ~# R+ B3 t. C5 @
d = 2;%设定平行线之间的距离6 L1 r9 O9 k6 Q: a! `* M! x
l = 1;%设定针的长度
* N# t# V7 e0 Q( d9 C4 Q" P! nn = 1000;%设定投针个数4 D& r) v- L/ W' [7 Z: C _: y
beta = 0 : 0.002 : pi;
6 e0 h' ?$ t9 g' i; C4 J( Tplot(beta, l/2*sin(beta), 'k-')%绘出l/2*sin(φ)曲线
6 J& {, e( o; \% b7 s! v; P% R5 C" gaxis([0, pi, 0, d/2])%横坐标范围设在0~pi,纵坐标范围设在0~d/2
/ y U9 B$ ]- Ctitle('蒲丰投针实验')/ x L' R) `( v7 \
hold on4 K0 S; ~- j$ G" G3 P( v" U
beta = rand(1, n) * pi;%随机生成n个角度(0~180度)5 c3 F$ L* }# y" W( V+ \5 R
x = (d/2) * rand(1, n);%在平行线中线以下生成n个针中心
$ g' d# b% y5 |" w! |1 ]/ Pm = 0;$ n$ n, u+ e; K1 o- c5 a1 n
for i = 1 : n
( O2 _( N% f+ I8 ~6 f2 |9 w if x(i) <= l/2 * sin(beta(i))
- `6 B. E1 @5 w, c. X m = m + 1;%符合条件就增计数$ `* j( B( B( `
plot(beta(i), x(i), '.r')%将符合条件的针以红点形式画在图中
: s* ~+ f2 @1 ] p8 t pause(0.00001)
1 @4 s7 Y0 J7 o5 u else. t3 t8 g) v$ J& ]; J) D
plot(beta(i),x(i),'.b')%将不符合条件的针以蓝点形式画在图中
: \9 F5 p# v7 v' x$ q! N/ K# P pause(0.00001)
$ o8 {& `# |) t end: d9 u/ u$ I: i, D
end8 `; f: M0 }" u2 D( E% t7 @
p = m/n;%计算概率
" L6 b d' }5 G0 {5 Ipai = 2*l / (d*p);%计算圆周率5 ]* N' a# ^8 h" {' u5 B2 B
disp(['圆周率为:',num2str(pai)])1 a0 |5 o$ x1 R% V1 V
' A* A' M% `. z3 [8 w
& a( q7 u$ E) ^- i1 U$ z
/ }! @% k# b7 q! h& T" N
结果如下:7 p6 l% n, M* Z0 D( n; }( W7 B
% E) F( @$ G: y+ p, P
5 r/ t& e3 L' s: C# S7 ^! J : I% B+ j- b- |" p ?" E8 g
: Y1 m; u+ I, g
( ?0 Y2 G; P! q4 D) ]6 N$ p2 e
3 J8 k' @! \7 \4 \4 Q7 z q# a7 c8 ~5 P( n
|
zan
|