Python 计算置信区间

Python 计算置信区间

用Python实现http://vassarstats.net/prop1.html 所计算的置信区间



import math
#计算置信区间的函数
def calc(r,n):
	if n < r :
		print ('r cannot be greater than n.')
		return 
	if math.floor(r) < r :
		print ('r must be an integer value.')
		return 
	if math.floor(n) < n :
		print ('n must be an integer value.')
		return
	p = round((r/n)*10000)/10000
	print ('p',p)

	q = 1-p
	p = round(p*10000)/10000
	print ('p',p)
	z=1.95996
	zsq = z*z
	
	# l95a
	num = (2*n*p)+zsq-(z*math.sqrt(zsq+(4*n*p*q)))
	denom = 2*(n+zsq)
	l95a = num/denom
	if p == 0 :
		l95a = 0
	l95a = round(l95a*10000)/10000
	
	# u95a
	num = (2*n*p)+zsq+(z*math.sqrt(zsq+(4*n*p*q)))
	denom = 2*(n+zsq)
	u95a = num/denom
	print ('u95a',u95a)
	if p == 1 :
		u95a = 1
	u95a = round(u95a*10000)/10000
	print('no continuity correction',l95a,'-',u95a)
	
	
	
	# l95b
	num = (2*n*p)+zsq-1-(z*math.sqrt(zsq-2-(1/n)+4*p*((n*q)+1)))
	denom = 2*(n+zsq)
	l95b = num/denom
	if p==0 :
		l95b = 0
	l95b = round(l95b*100000000)/100000000
	
	# u95b
	num = (2*n*p)+zsq+1+(z*math.sqrt(zsq+2-(1/n)+4*p*((n*q)-1)))
	denom = 2*(n+zsq)
	u95b = num/denom
	if p==1 :
		u95b = 1
	u95b = round(u95b*100000000)/100000000
	print('including continuity correction',l95b,'-',u95b)
	
	
	return
	


#测试k = 12 n = 40

calc(12,40)
print('THE END')











	
























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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值