第一范文网 - 专业文章范例文档资料分享平台

概率论基础知识及其在matlab中的实现

来源:用户分享 时间:2025/5/19 22:46:52 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

第三章 概率论基础知识及其在matlab中的实现

概率论与应用数理统计十就是研究随机现象统计规律性的一门科学,本章学习随机 及其发生的概率,多维随机变量的分布规律,参数估计与假设检验,方差分析与回归分析等概率统计的基本方法以及它们在MATLAB中实现方法。 3.1 随机时间及其概率 3.1.1 古典概率及其模型

由古典概率的定义知,古典概率基于这样两个原则:(1) 所有可能发生的结果只有有限个;(2)每一种可能出现的结果机会是相同的。在MATLAB中提供了一个在[0,1]区间上均匀分布的随机函数rand,其命令格式为:

命令格式1: rand(N)

功能: 返回一个N?N的随机矩阵 命令格式2: rand(N,M)

功能: 返回一个N?M的随机矩阵 命令格式2: rand(P1,P2,…,Pn)

功能: 返回一个P1?P2???Pn的随机矩阵

可以用计算机模拟掷硬币这一过程,为了模拟硬币出现正面或反面,规定随机数小于0.5时为反面,否则为正面,可以用round()函数将其变成0—1矩阵,然后将整个矩阵的各元素值加起来再除以总的原始个数即为出现正面的概率。round()函数的命令格式为:

命令格式: round(x)

功能:对向量或矩阵x的每个分量四舍五入取整。

现以联系掷10000次硬币为例,重复做100次试验模拟出现正面的概率。在matlab中的程序如下:

for i =1:100

a(i) = sum(sum(round(rand(100))))/10000; end

mx = max(a); mn = min(a); ma = mean(a); a, mx, mn, ma

在该程序输出的四项中,a为实验100次中每次出现正面的频率,mx和mn分别为100次实验中出现正面频率的最大值和最小值,ma为100次试验出现正面的平均频率。运行结果如下:

这里要输入结果

下面介绍MATLAB中取整的几个函数命令: (1) 命令格式: fix(x)

功能: 对x朝零方向取整 (2) 命令格式: floor(x)

功能:对x朝负无穷大方向取整 (3) 命令格式: ceil(x)

功能:对x朝正无穷大方向取整

3.1.2 统计概率及其模型

由于古典概率是建立在事件发生的等可能基础上的概率,而现实生活中许多现象的出现并不是等可能的。例如某品种的玉米,当种下一粒后,其发芽与不发芽的机会并不相同。那么,这个概率就不能建立在等可能基础上,即不能使用古典概率的定义。

而统计概率的定义是建立在频率基础上的,就是说某事件出现 频率如果稳定在某数值?附近,则称数值?为该事件出现的概率。由于统计概型中的概率?是一个理论上的数值,实际问题中根本无法直接得到该数值,因而通常在试验次数充分多时,利用频率值近似代替概率值。在掷硬币的试验中,在试验次数充分多的情况下,掷硬币出现正面和反面的频率均在0.5左右,故出现正面和反面的概率均为 0.5。下面来看掷硬币时,当样本容量分别为

n = 10,100,1000,10000,100000,1 000 000 时频率的变化。在MATLAB中实现时程序代码如下:

for I = i:6

a(i) = sum(round(rand(1,10-i)))/10^I; end 运算结果为:

这里输入运算结果

从上面运行的结果中可以看出,当样本容量不够大时,其频率的波动范围很大,即频率不够稳定,即使有时达到 0.5,但最大时已达到0.9,然而随着样本容量的增加,频率的波动范围越来越小,相差仅有10左右。

3.1.3 条件概率、全概率公式与伯努利概率

若事件B的发生会影响到事件A的发生,则事件B发生的条件下,事件A发生的概率称为条件概率,条件的概率的计算公式为:

P(A|B)??3P(AB) P(B)若事件A的发与事件B的发生与否没有关系,即事件B发生与否不会影响到事件A的发生,反之亦然,则称事件A与事件B是相互独立的,这时有:

P(AB)?P(A)P(B)

例1 袋中有10只球,其中白球7只,黑球3只。分有放回和无放回两种情况,分三次取球,每次取一个,分别求:(1) 第三次摸到了黑球的概率,(2) 第三次才摸到黑球的概率,(3) 三次都摸到了黑球的概率。

解 当有放回地摸球时,由于三次摸球互不影响,因此三次摸球相互独立,从理论上可以求得:(1) 第三次摸到黑球的概率为

3?0.3;(2) 第三次才摸到黑球的概率为10773333???0.147;(3) 三次都摸到黑球的概率为???0.027。 101010101010在MATLAB中模拟这一过程时,可在[0,1]区间上产生三次随机数来模拟三次摸球,

6当随机数小于0.7时可认为摸到了白球,否则认为摸到了黑球。重复10次分别求上述三种情况出现的概率。程序如下:

a = round(rand(1000000,3) – 0.2); for i= 1:6

b = a(1:10^i,3; c(i) =sum(b)/(10^i); end c

for i =1:6

b = (~a(1:10^i,1))&(~a(1:10^i,2))&a(1:10^i,3); d(i) = sum(b)/(10^i); end d

for I = 1:6

b=a(1:10^i,1)&a(1:10^i,2)&a(1:10^i,3); e(i) = sum(b)/(10^i); end e 运行结果为:

这里加入运行结果

执行结果中c为第三次摸到黑球的概率,d为第三次才摸到黑球的概率,e为三次都摸到黑球的概率.可以看到,随着试验次数的增加,其频率都会逐渐稳定在理论值附近.

当无放回地摸球时,由于第二次摸球会受到第一次的影响,而第三次摸球又会受到前两次的影响,因而三次摸球相互影响,并不独立.从理论上可求得:

763732372321????????????0.3, 1098109810981098763(2) 第三次才摸到黑球的概率为???0.175

1098321(3) 三次都摸到了黑球的概率为???0.008

1098(1) 第三次摸到黑球的概率为

用计算机模拟该过程时,在[0,1]区间模拟第一次摸球,当值小于0.7时认为摸到了白球,否则认为摸到了黑球;第二次摸球时由于少了一个球,故可在区间长度为0.9的区间上模拟,若第一次摸到白球,可将区间设为[0.1,1],否则区间设为[0,0.9];第三次摸球可依次类推,其模拟程序如下:

a = rand(1000000,3);

a(:,1) = round(a(:,1) – 0.2);

a(:,2) =round(a(:,2)*0.9 – 0.2 – 0.1*((a:,1) – 1));

a(:,3) =round(a(:,3)*0.8 – 0.2 – 0.1*(a(:,1) –1) –0.1*(a(:,2) –1)); for i=1:6

b =a(1:10^i,3);

c(i) = sum(b)/(10^i); end c

for i =1:6

b = (~a(1:10^i,1)) & (~a(1:10^i,2)) & a(1:10^i,3); d(i) =sum(b)/(10^i); end d

for i =1:6

b =a(1:10^i,1) & a(1:10^i,2) & a(1:10^i,3); e(i) =sum(b)/(10^i); end e

运行结果为

上面在理论上计算第三次摸到黑球的概率时,用到了全概率公式:

若A1,A2,?,An构成一个完备事件组,且事件B的发生总是伴随着事件Ai(i?1,2,?,n)中的某一个发生而发生,则

P(B)??P(Ai)P(B|Ai)

i?1n下面将用到伯努利概型,所谓伯努利概型是指:

在相同条件下,进行n次独立重复试验,每次试验只有事件A发生或不发生两种结果,且 P(A)?p, P(A)?1?p?q

这里第三次摸到黑球的四种情况分别是:{白,白,黑},{白,黑,黑},{黑,白,黑},{黑,黑,黑}.这四种情况构成了完备事件组.现考虑下面问题: (1) 当不放回时,已知第三次摸到了黑球,问前两次是黑球的概率为多少? (2) 若有放回地连续摸10次,则恰有三次摸到黑球的概率是多少?

第一问是一逆概率问题,由逆概率公式即贝叶斯公式得到其概率应为

32131?????0.0278 10981036第二问则属伯努利概型,这里A为{摸到的是黑球},故P(A)?0.3 , P(A)?0.7.于是由二项概率公式有,10次有放回摸球中,恰有三次摸到黑球的概率为

3C10?0.33?0.77?0.2668

在MATLAB中实现这两个过程的程序如下:

a = rand(100000,3);

a(:,1) = round(a(:,1) –0.2);

a(:,2) = round(a(:,2)*0.9 – 0.2 –0.1*a(:,1) –1));

a(:,3) = round(a(:,3)*0.8 –0.2 –0.1*(a(:,1) –1) –0.1*(a(:,2) –1)); for i=1:6

b =a(1:10^I,3); c(i) =sum(b);

b =a(1:10^i,1) & a(1:10^i,2) & a(1:10^i,3); d(i) = sum(b); e(i) =d(i)./c(i); end

这里添加运行结果

a = round(rand(1000000,10) –0.2); for I =1:6

b =sum(a(1:10^i, :),2) –3;

搜索更多关于: 概率论基础知识及其在matlab中的实现 的文档
概率论基础知识及其在matlab中的实现.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c48gnc5ypkf3pebe0ilc1_1.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top