- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
各分布函数分位点及p-value计算及程序实现
一、各分布函数计算
1.标准正态分布函数的计算
方法(1):利用泰勒展示求解
由于分布函数不能被求解成为简单的初等函数,所以不能直接用定义初等复合函数的方法计算其值。通过把正态密度函数展开为泰勒级数,对泰勒级数的各项求定积分,然后相加各项数值即得分布函数F(t)的值。
(1)
(2)
由(1),(2)得出
(3)
因为(3)式是一个无穷级数,计算时只能对前面有限项相加。选择越多,结果越准确。但数值精度并不要求无限高,可选取50项就足够,因而这里n=0,1,2…50。
流程图如下:
代开C++软件,输入以下程序代码:
#includestdio.h
#includemath.h
#define PI 3.141592653
main( )
{
float z,t,y=0,jsx,F,b=1 ; //jsx为每个级数项的值,F为所要求分布函数的值
int n=1,a=1,m=1 ;
printf(Please enter t:);
scanf(%f,t); //输入分位点t
while(n101) //n101,得出的级数项值共有50个
{
z=pow(t,n);
jsx=a*z/(b*n);
y+=jsx;
a=-1*a ; //正负符号标志
b=b*2*m ;
m++;
n=n+2;
}
F=0.5+y/sqrt(2*PI);
printf(The result you want is:\n);
printf(%f,F);
}
输入数据:比如t=0.02,x=-0.01,x=0
输出:
方法(2):积分的近似算法:
正态分布函数的计算归为积分计算。
设将区间[a,b]分为n等份,共有n+1个分点。分点,在每个子区间(k=0,1,….,n-1)上采用梯形公式则可得复合梯形公式。如果将求积区间再二分一次,则可提高求积精度。此时分点增至2n+1个,则由原来每个子区间经过二分只增加了一个分点,再用复合梯形公式求得该子区间上的积分值为(其中代表二分前的步长)。将每个子区间上的积分值相加得:
C++程序算法:
#includestdio.h
#includemath.h
double f(double x)
{
return exp(-x*x/2);
}
double F(double a,double b,double ep=1e-6)
{
double h,s1=0,s2=(b-a)*(f(a)+f(b))/2;
int n,k;
for(int n=1;fabs(s1-s2)ep;n*=2)
{
h=(b-a)/n;
s1 = s2;
s2 = 0;
for(int k=0;kn;++k)
{
s2 += h*f(a+(k+0.5)*h);
}
s2 = (s1+s2)/2;
}
return s2*sqrt(1/(8*atan(1.0)));
}
int main()
{
double c=0,x;
printf(please enter x:);
scanf(%lf,x);
printf(%lf,0.5+F(c,x));
return 0;
}
结果显示:(输入x的值为2)
输出:
方法(3):连分式展开(算法程序见下面最后部分的总程序编写)
Φ(x)为标准正态分布函数,其是对称的,只要求出x0时Φ(x)的值也就可以求得x0时Φ(x)=1-Φ(-x)。由于Φ(x)的近似式:
Φ(x)≈
其中采用递推式表达,
当0≤x≤3时,令则Φ(x)=
当x3时,令则Φ(x)=
一般当n28时,精度可达10-12
2.Beta分布函数的计算
Beta分布的分布函数递推如下:
其中
由于利用Beta分布的分布函数计算t分布,F分布,二项分布时,参数a,b的值要么是正整数,要么就是1/2的倍数。所以考虑参数a,b的值是正整数或者是1/2倍数情况下的计算。此时递推公式初值选取有以下4种:
3.t分布函数的计算
与 t分布的关系
。由于n为整数,所以n/2可以递归到?,即可以使用Beta分布的递推公式。
4.F分布函数计算
与 F分布的关系
。由于m,
文档评论(0)