计算机模拟数学实验的概念,数学建模与数学实验之计算机模拟教材.ppt

11cbc1e44d50bc91599981632979f685.gif数学建模与数学实验之计算机模拟教材.ppt

数学建模与数学实验,后勤工程学院数学教研室,之计算机模拟,实验目的,实验内容,学习计算机模拟的基本过程与方法,1、模拟的概念,4、实验作业,3、计算机模拟实例,2、产生随机数的计算机命令,连续系统模拟实例 追逐问题,离散系统模拟实例 排队问题,用蒙特卡洛法解非线性规划问题,返回,计算机模拟实例,模拟的概念,模拟就是利用物理的、数学的模型来类比、模仿现实系统及其演变过程,以寻求过程规律的一种方法,模拟的基本思想是建立一个试验模型,这个模型包含所研究系统的主要特点通过对这个实验模型的运行,获得所要研究系统的必要信息,模拟的方法,1、物理模拟 对实际系统及其过程用功能相似的实物系统去模仿。 例如,军事演习、船艇实验、沙盘作业等,物理模拟通常花费较大、周期较长,且在物理模型上改变系统结构和系数都较困难。而且,许多系统无法进行物理模拟,如社会经济系统、生态系统等,在实际问题中,面对一些带随机因素的复杂系统,用分析方法建模常常需要作许多简化假设,与面临的实际问题可能相差甚远,以致解答根本无法应用。这时,计算机模拟几乎成为唯一的选择,在一定的假设条件下,运用数学运算模拟系统的运行,称为数学模拟。现代的数学模拟都是在计算机上进行的,称为计算机模拟,2、数学模拟,计算机模拟可以反复进行,改变系统的结构和系数都比较容易,蒙特卡洛(Monte Carlo)方法是一种应用随机数来进行计算机模拟的方法此方法对研究的系统进行随机观察抽样,通过对样本值的观察统计,求得所研究系统的某些参数,例1在我方某前沿防守地域,敌人以一个炮排(含两门火炮)为单位对我方进行干扰和破坏为躲避我方打击,敌方对其阵地进行了伪装并经常变换射击地点,经过长期观察发现,我方指挥所对敌方目标的指示有50是准确的,而我方火力单位,在指示正确时,有1/3的射击效果能毁伤敌人一门火炮,有1/6的射击效果能全部消灭敌人,现在希望能用某种方式把我方将要对敌人实施的20次打击结果显现出来,确定有效射击的比率及毁伤敌方火炮的平均值,分析 这是一个概率问题,可以通过理论计算得到相应的概率和期望值.但这样只能给出作战行动的最终静态结果,而显示不出作战行动的动态过程,为了能显示我方20次射击的过程,现采用模拟的方式,需要模拟出以下两件事,1. 问题分析,2 当指示正确时,我方火力单位的射击结果情况,1 观察所对目标的指示正确与否,模拟试验有两种结果,每一种结果出现的概率都是1/2,因此,可用投掷一枚硬币的方式予以确定,当硬币出现正面时为指示正确,反之为不正确,模拟试验有三种结果毁伤一门火炮的可能性为1/3即2/6,毁伤两门的可能性为1/6,没能毁伤敌火炮的可能性为1/2即3/6,这时可用投掷骰子的方法来确定 如果出现的是、三个点则认为没能击中敌人; 如果出现的是、点则认为毁伤敌人一门火炮; 若出现的是点则认为毁伤敌人两门火炮,2. 符号假设,i要模拟的打击次数; k1没击中敌人火炮的射击总数; k2击中敌人一门火炮的射击总数;k3击中敌人两门火炮的射击总数 E有效射击比率; E120次射击平均每次毁伤敌人的火炮数,3. 模拟框图,4. 模拟结果,5. 理论计算,6. 结果比较,返回,虽然模拟结果与理论计算不完全一致,但它却能更加真实地表达实际战斗动态过程,用蒙特卡洛方法进行计算机模拟的步骤,1 设计一个逻辑框图,即模拟模型这个框图要正确反映系统各部分运行时的逻辑关系。 2 模拟随机现象可通过具有各种概率分布的模拟随机数来模拟随机现象,产生模拟随机数的计算机命令,在Matlab软件中,可以直接产生满足各种分布的随机数,命令如下,2产生mn阶,均匀分布的随机数矩阵rand m, n 产生一个,均匀分布的随机数rand,1产生mn阶a,b均匀分布U(a,b)的随机数矩阵 unifrnd a,b,m, n 产生一个a,b均匀分布的随机数unifrnd a,b,当只知道一个随机变量取值在(a,b)内,但不知道(也没理由假设)它在何处取值的概率大,在何处取值的概率小,就只好用U(a,b)来模拟它,例 1的计算机模拟,To Matlab(rnd,当研究对象视为大量相互独立的随机变量之和,且其中每一种变量对总和的影响都很小时,可以认为该对象服从正态分布,机械加工得到的零件尺寸的偏差、射击命中点与目标的偏差、各种测量误差、人的身高、体重等,都可近似看成服从正态分布,若连续型随机变量X的概率密度函数为 其中 0为常数,则称X服从参数为 的指数分布,指数分布的期望值为,排队服务系统中顾客到达率为常数时的到达间隔、故障率为常数时零件的寿命都服从指数分布,指数分布在排队论、可靠性分析中有广泛应用,注意Matlab中,产生参数为 的指数分布的命令为exprnd,例 顾客到达某商店的间隔时间服从参数为0.1的指数分布,指数分布的均值为1/0.110。 指两个顾客到达商店的平均间隔时间是10个单位时间.即平均10个单位时间到达1个顾客. 顾客到达的间隔时间可用exprnd10模拟,设离散型随机变量X的所有可能取值为0,1,2,且取各个值的概率为 其中 0为常数,则称X服从参数为 的帕松分布,帕松分布在排队系统、产品检验、天文、物理等领域有广泛应用,帕松分布的期望值为,指数分布与帕松分布的关系,1指两个顾客到达商店的平均间隔时间是10个单位时间.即平均10个单位时间到达1个顾客. 2指一个单位时间内平均到达0.1个顾客,例 1顾客到达某商店的间隔时间服从参数为0.1的指数分布 2该商店在单位时间内到达的顾客数服从参数为0.1的帕松分布,返回,例2敌坦克分队对我方阵地实施突袭,其到达规律服从泊松分布,平均每分钟到达辆(1)模拟敌坦克在分钟内到达目标区的数量,以及在第、分钟内各到达几辆坦克(2)模拟在3分钟内每辆敌坦克的到达时刻,1)用poissrnd4进行模拟,To Matlab(poiss,2)坦克到达的间隔时间应服从参数为4的负指数分布,用exprnd(1/4)模拟,To Matlab(time,连续系统模拟实例 追逐问题,状态随时间连续变化的系统称为连续系统。对连续系统的计算机模拟只能是近似的,只要这种近似达到一定的精度,也就可以满足要求,例 追逐问题 如图,正方形ABCD的四个顶点各有一人.在某一时刻,四人同时出发以匀速v1米/秒按顺时针方向追逐下一人,如果他们始终保持对准目标,则最终按螺旋状曲线于中心点O.试求出这种情况下每个人的行进轨迹,1. 建立平面直角坐标系Ax1,y1, Bx2,y2, Cx3,y3, Dx4,y4,2. 取时间间隔为t,计算每一点在各个时刻的坐标,4. 对每一个点,连接它在各时刻的位置,即得所求运动轨迹,求解过程,To Matlabchase,返回,v1; dt0.05; x0 0 10 10; y0 10 10 0; for i14 plotxi,yi,.,hold on end d20; whiled0.1 x5x1;y5y1; for i14 dsqrtxi1-xi2yi1-yi2; xixiv*dt*xi1-xi/d; yiyiv*dt*yi1-yi/d; plotxi,yi,.,hold on end end,计算程序,To Matlabchase,返回,离散系统模拟实例 排队问题,排队论主要研究随机服务系统的工作过程,在排队系统中,服务对象的到达时间和服务时间都是随机的。排队论通过对每个个别的随机服务现象的统计研究,找出反映这些随机现象平均特性的规律,从而为设计新的服务系统和改进现有服务系统的工作提供依据,对于排队服务系统, 顾客常常注意排队的人是否太多, 等候的时间是否长, 而服务员则关心他空闲的时间是否太短. 于是人们常用排队的长度、等待的时间及服务利用率等指标来衡量系统的性能,1 系统的假设 (1) 顾客源是无穷的; (2) 排队的长度没有限制; ( 3) 到达系统的顾客按先后顺序依次进入服务, 即“先到先服务,单服务员的排队模型在某商店有一个售货员,顾客陆续来到,售货员逐个地接待顾客当到来的顾客较多时,一部分顾客便须排队等待,被接待后的顾客便离开商店设 1顾客到来间隔时间服从参数为0.1的指数分布 对顾客的服务时间服从,上的均匀分布 排队按先到先服务规则,队长无限制,假定一个工作日为8小时,时间以分钟为单位。 1模拟一个工作日内完成服务的个数及顾客平均等待时间t 2模拟100个工作日,求出平均每日完成服务的个数及每日顾客的平均等待时间,2 符号说明 w总等待时间;ci第i个顾客的到达时刻; bi第i个顾客开始服务时刻; ei第i个顾客服务结束时刻 xi第i-1个顾客与第i个顾客之间到达的间隔时间 yi对第i个顾客的服务时间,c1,b1,c3,c4,c5,c2,e1,b2,e2,b3,e3,b4,e4,b5,cici-1 xi eibiyi bimaxci,ei-1,t,1模拟一日 To Matlabsimu1,2模拟100日 To Matlabsimu2,返回,用蒙特卡洛法解非线性规划问题,基本假设,试验点的第j个分量xj服从aj ,bj内的均匀分布,符号假设,求解过程,先产生一个随机数作为初始试验点,以后则将上一个试验点的第j个分量随机产生,其它分量不变而产生一新的试验点这样,每产生一个新试验点只需一个新的随机数分量当KMAXK或PMAXP时停止迭代,在Matlab软件包中编程,共需三个文件randlp.m, mylp.m, lpconst.m.主程序为randlp.m, mylp.m function zmylpx 目标函数 z2*x12x22-x1*x2-8*x1-3*x2; 转化为求最小值问题, randlp.m function sol,r1,r2randlpa,b,n 随机模拟解非线性规划 debug1; a0; 试验点下界 b10; 试验点上界 n1000; 试验点个数 r1unifrnda,b,n,1;n1阶的a,b均匀分布随机数矩阵 r2unifrnda,b,n,1; solr11 r21; z0inf; for i1n x1r1i; x2r2i; lpclpconstx1 x2; if lpc1 zmylpx1 x2; if zz0 z0z; solx1 x2; end end end,To Matlabrandlp,返回,实验作业,1、编一个福利彩票电脑选号的程序,4. 某设备上安装有四只型号规格完全相同的电子管,已知电子管寿命为1000-2000小时之间的均匀分布。当电子管损坏时有两种维修方案,一是每次更换损坏的那一只;二是当其中一只损坏时四只同时更换。已知更换时间为换一只时需1小时,4只同时换为2小时。更换时机器因停止运转每小时的损失为20元,又每只电子管价格10元,试用模拟方法决定哪一个方案经济合理,5. 导弹追踪问题设位于坐标原点的甲舰向位于x轴上点A1, 0处的乙舰发射导弹,导弹头始终对准乙舰.如果乙舰以最大的速度是常数沿平行于y轴的直线行驶,导弹的速度是5,模拟导弹运行的轨迹.又乙舰行驶多远时,导弹将它击中,投掷硬币的计算机模拟,1、产生服从U(0,1)的随机数R1,2、将区间0,1两等分 若 ,则对应硬币正面 若 ,则对应硬币反面,掷骰子的计算机模拟,1、产生服从U(0,1)的随机数R2,2、将区间0,1六等份 若 ,则对应骰子点数为1 若 ,则对应骰子点数为2 若 ,则对应骰子点数为3 若 ,则对应骰子点数为4 若 ,则对应骰子点数为5 若 ,则对应骰子点数为6,To Matlabliti1

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值