




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Monte Carlo Simulation 简介简介概述概述n蒙特卡罗(Monte Carlo)方法,或称计算机随机模拟方法或随机抽样方法或统计试验方法 ,属于计算数学的一个分支。是一种基于“随机数”的计算方法。起源起源nMonte Carlo方法的基本思想很早以前就被人们所发现和利用。早在17世纪,人们就知道用事件发生的“频率”来决定事件的“概率”。19世纪人们用投针试验的方法来决定圆周率。 成型成型n这一方法成型于美国在第一次世界大战进研制原子弹的“曼哈顿计划”。 n该计划的主持人之一、数学家冯诺伊曼用驰名世界的赌城摩纳哥的Monte Carlo来命名这种方法,为它蒙上了一层神秘色彩。
2、发展发展n本世纪40年代电子计算机的出现,特别是近年来高速电子计算机的出现,使得用数学方法在计算机上大量、快速地模拟这样的试验成为可能。 实质实质nMonte Carlo 方法也称为统计模拟方法,是二十世纪四十年代中期由于科学技术的发展和电子计算机的发明,而被提出的一种以概率统计理论为指导的一类非常重要的数值计算方法。是指使用随机数(或更常见的伪随机数)来解决很多计算问题的方法。与它对应的是确定性算法。n把一些复杂的东西用大量的模拟实验来做,最后得到一些结论。基本思想和原理基本思想和原理n基本思想:当所要求解的问题是某种事件出现的概率,或者是某个随机变量的期望值时,它们可以通过某种“试验”的方
3、法,得到这种事件出现的频率,或者这个随机变数的平均值,并用它们作为问题的解。n 原理:抓住事物运动的几何数量和几何特征,利用数学方法来加以模拟,即进行一种数字模拟实验。n它是以一个概率模型为基础,按照这个模型所描绘的过程,通过模拟实验的结果,作为问题的近似解。步骤步骤n可以把蒙特卡罗解题归结为三个主要步骤:n构造或描述概率过程;n实现从已知概率分布抽样;n建立各种估计量构造或描述概率过程构造或描述概率过程n对于本身就具有随机性质的问题,主要是正确描述和模拟这个概率过程,对于本来不是随机性质的确定性问题,比如计算定积分,就必须事先构造一个人为的概率过程,它的某些参量正好是所要求问题的解。即要将不
4、具有随机性质的问题转化为随机性质的问题。实现从已知概率分布抽样实现从已知概率分布抽样n构造了概率模型以后, 按照这个概率分布抽取随机变量 (或随机向量),这一般可以直接由软件包调用,或抽取均匀分布的随机数构造。这样,就成为实现蒙特卡罗方法模拟实验的基本手段,这也是蒙特卡罗方法被称为随机抽样的原因。 建立各种估计量建立各种估计量 n一般说来,构造了概率模型并能从中抽样后,即实现模拟实验后,我们就要确定一个随机变量,作为所要求的问题的解,我们称它为无偏估计。建立各种估计量,相当于对模拟实验的结果进行考察和登记,从中得到问题的解。 例子例子n考虑平面上的一个边长为1的正方形及其内部的一个形状不规则的
5、“图形”,如何求出这个“图形”的面积呢?Monte Carlo方法是这样一种“随机化”的方法:向该正方形“随机地”投掷N个点落于“图形”内,则该“图形”的面积近似为M/N。 比喻比喻n可用民意测验来作一个不严格的比喻。民意测验的人不是征询每一个登记选民的意见,而是通过对选民进行小规模的抽样调查来确定可能的民意。其基本思想是一样的。 应用应用n科技计算中的问题比这要复杂得多。但Monte Carlo 方法广泛地应用于许多应用领域,如计算物理学 、粒子输运计算、量子热力学计算、量子化学、分子动力学与 。特别在金融计算中,各方法有不可取代的优势。金融中的应用金融中的应用n金融衍生产品(期权、期货、掉
6、期等)的定价及交易风险估算,问题的维数(即变量的个数)可能高达数百甚至数千。对这类问题,难度随维数的增加呈指数增长,这就是所谓的“维数的灾难”(Course Dimensionality),传统的数值方法难以对付(即使使用速度最快的计算机)。 Monte Carlo方法的优势方法的优势nMonte Carlo方法能很好地用来对付维数的灾难,因为该方法的计算复杂性不再依赖于维数。以前那些本来是无法计算的问题现在也能够计算。为提高方法的效率,科学家们提出了许多所谓的“方差缩减”技巧。nMonte Carlo模拟适用于研究复杂体系。研究具有多得数不清的结构、状态的体系,对此我们可以采用蒙特卡洛模拟,
7、以统计的方法寻找出现几率最高的结构、状态,或相应的有关数据。 Monte Carlo 方法处理的问题方法处理的问题nMonte Carlo 方法处理的问题可以分两类n确定性的数学问题确定性的数学问题 多重积分、求逆矩阵、解线性代数方程组、解积分方程、解某些偏微分方程边值问题和计算代数方程组、计算微分算子的特征值等等n 随机性问题随机性问题方法方法n在解决实际问题的时候应用Monte Carlo方法主要有两部分工作:1、用此方法模拟某一过程时,需要产生各种概率分布的随机变量。 2、用统计方法把模型的数字特征估计出来,从而得到实际问题的数值解。用用Monte Carlo 计算定积分计算定积分n考虑
8、积分n假定随机变量具有密度函数n则 10,0.xIxe dx( ),xXfxe1().IE X用用Monte Carlo 计算定积分计算定积分-n抽取密度为e-x的随机数X_1,X_nn构造统计数n则111.niiIXn111111111()1.nniiiiniE IEXE XnnnE XE XInn用用Monte Carlo 计算定积分计算定积分-n且n即1121111211()1.nniiiiVar IVarXVar XnnnVar XVar Xnn11.IXn用用Monte Carlo 计算定积分计算定积分-n例如 =1.9n取n(1.9)=0.96176 模拟结果不好!n如果要达到0.
9、001的精确度,要4X5302=1123600计算!0.91.90.xIx e dx1234ln,(0,1):0.0587,0.0961,0.9019,0.3095,1.497iiiXRRURRRRI用用Monte Carlo 计算定积分计算定积分-n例子说明分析和设计是重要的。n重写积分n取两个随机数1.90.101.( )xyYIxedxfyyex密度函数为12121.90.11,(0,1),ln,R RUYRRIEY令算用用Monte Carlo 计算定积分计算定积分-n取8个随机数n大大改善了结果!123456781.90.0078,0.93250.10800.00630.5490,0
10、.85560.97710.27830.9187RRRRRRRRI,随机数的产生随机数的产生n随机数是我们实现蒙特卡罗模拟的基本工具。n随机数的产生就是抽样问题。可以用物理方法产生随机数,但价格昂贵,不能重复,使用不便。另一种方法是用数学递推公式产生。这样产生的序列,与真正的随机数序列不同,所以称为伪随机数,或伪随机数序列。不过,经过多种统计检验表明,它与真正的随机数,或随机数序列具有相近的性质,因此可把它作为真正的随机数来使用。随机数的取得随机数的取得n如果你对随机数有更高的要求,需要自己编辑“随机数生成器”n最简单、最基本、最重要的一个概率分布是(0,1)上的均匀分布(或称矩形分布)n 例如
11、在Matlab中,命令“rand()”将产生一个(0,1)中均匀分布的随机数n你可以根据需要给随机数一个“种子”,以求不同的数Matlab 的随机数函数的随机数函数n均匀分布nR=unidrnd(N),-产生1到N间的均匀分布随机数nR=unidrnd(N,n,m),产生1到N间的均匀分布随机数矩阵n连续均匀分布nR=unifrnd(A,B) -产生(A,B)间的均匀分布随机数nR=unifrnd(A,B,m,n)产生(A,B)间的均匀分布随机数矩阵Matlab 的随机数函数的随机数函数-n正态分布随机数nR=normrnd(mu,sigma)nR=normrnd(mu,sigma,m)nR=
12、normrnd(mu,sigma,m,n)n特定分布随机数发生器nR=random(name,A1,A2,A3,m,n)例例na=random(Normal,0,1,3,2)a= .-0.4326 0.2877 -1.6656 -1.1465 0.1253 1.1909精确性精确性n由于Monte Carlo 方法的随机性,精确性建立在大量的重复模拟上,最后去平均值。n 对确定值的计算,要估计出样本的个数与精确度之间的关系。n对随机过程的模拟,有置信区域的估算等方差削减技术方差削减技术n对偶变量技术(适用正态分布函数)n 取一组随机数Z_i,可得模拟值C_i ,i=1,2,.nn估计值为期平均
13、Cn再取Z_i 的对偶Z_i=-Z_i,再生成估计值Cn然后去新的平均值C*=(C+C)/2n则nvarC*=1/2varC+1/2cov(C,C) 1/2varC+n该技术使计算更稳定一个例子一个例子n问题问题 下图是一个中子穿过用于中子屏蔽的铅墙示意图。铅墙的高度远大于左右厚度。设中子是垂直由左端进入铅墙,在铅墙中运行一个单位距离然后与一个铅原子碰撞。碰撞后,任意改变方向,并继续运行一个单位后与另一个铅原子碰撞。这样下去,如果中子在铅墙里消耗掉所有的能量或者从左端逸出就被视为中子被铅墙挡住,如果中子穿过铅墙由右端逸出就视为中子逸出。如果铅墙厚度为5个单位,中子运行7个单位后能量耗尽,求中子
14、逸出的几率。n xn这个问题并不复杂,但不容易找到一个解析表达式。而用模拟的方法求解却可以有满意的结果。一个例子一个例子 - 这个问题并不复杂,但不容易找到一个解析表达式。这个问题并不复杂,但不容易找到一个解析表达式。而用模拟的方法求解却可以有满意的结果。而用模拟的方法求解却可以有满意的结果。 一个例子一个例子 -n建模建模 下面我们给出这个问题的模拟程序。我们关心的是一次碰撞后,中子在x轴方向行进了多少,所以行进方向是正负的结果是一样的,我们就只考虑是正的情形。由于中子运行的方向是随机的,我们用计算机抽取在0到间均衡分布的随机数,模拟1000000个中子在铅墙里行进的情形,看看这些中子与铅原
15、子碰撞7次后,有多少超过了铅墙的右端。一个例子一个例子 -nn=1000000;nm=0;nt=1;nfor i=1:nn x=1;n for k=1:7n ang=pi*rand;n x=x+cos(ang);n if x5 & t=1n l=1;n else l=0;n endn m=m+l;n t=1;nendnm/nn一个例子一个例子 -n解模解模 我们运行程序得出逸出铅墙的中子的可能性约为1.5%。n应用应用 有了这个数字,我们可以报告安全部门,如果数字不能达到安全要求,我们则要加厚铅墙。Monte Carlo 模拟二叉树期权定价模拟二叉树期权定价n 二叉树定价模型是从构造好
16、的二叉树中随机选择一条路径样本,从二叉树的末端开始倒推计算出衍生证券的价格,但是采用了Monte Carlo后,是顺着二叉树往后计算的。 基本方法:基本方法: 在第一个节点(根节点),随机产生一个0到1间的随机数,如果这个数小于p,就选择当前的上升分支,反之选择下降分支。这样就产生了一个新节点,继续上面的过程,直到二叉树的末端。一条路径产生了,衍生证券的最终价值就可以计算出来了(可以看作是全部可能终值集合中的一个随机样本),这样完成了第一次模拟。n更多的样本路径得到更多的样本终值。进行多次模拟,用平均值来估计衍生证券的价格Monte Carlo 模拟连续过程的欧式模拟连续过程的欧式期权定价期权
17、定价n欧式期权定价的期望公式为n如果标的资产服从几何布朗运动n则风险中性测度下,标的资产的过程为()rTTVeE VdSSdtSdW20exp2TSSrTTMonte Carlo 模拟连续过程的欧式模拟连续过程的欧式期权定价期权定价-n所以Call Option 到期日的现金流为n抽一个正态分布的随机数,算得上式再贴现,就可以得到一个结果n重复上面的过程(如计算10000次)n 将所有的结果取平均2max 0, (0)exp2SrTTK附表附表:Matlab随机数生成器随机数生成器betarnd 贝塔分布贝塔分布 binornd 二项分布二项分布chi2rnd 卡方分布卡方分布 exprnd 指数分布指数分布 frnd f分布分布 gamrnd 伽玛分布伽玛分布 g
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 历史●安徽卷丨2024年安徽省普通高中学业水平选择性考试历史试卷及答案
- 《ERP原理与应用(微课版)》陈承欢成明山课后思考参考答案
- 高中生英语课堂学习投入现状及其影响因素研究
- 西部志愿者试题及答案
- 北京八中2024-2025学年度第二学期第三次模拟答案
- 生物●全国甲卷丨2023年普通高等学校招生全国统一考试生物试卷及答案
- 建材公司风险管理与应急预案制定
- 2025版无限期劳动合同协议书模板
- 2025年中国台式封口机行业市场前景预测及投资价值评估分析报告
- 2025餐厅转让合同简易模板
- 29.4常见肿瘤标志物讲解
- 精神障碍者民事行为能力评定指南
- 游泳池安全保障制度和措施范本
- 志愿服务证明(多模板)
- 2024届高考语文复习诗歌教考融合之《登高》(含解析)
- 中南地区工程建设标准设计建筑图集 13ZJ301 建筑无障碍设施
- 阴道炎演示课件
- 妇科疾病的运动与体育锻炼预防
- 2023年重庆市高考思想政治试卷真题(含答案)
- CONSORT2010流程图(FlowDiagram)【模板】文档
- 篮球比赛分组循环积分表
评论
0/150
提交评论