145、Python实现概率分布

一、概率分布
概率分布,是概率论的基本概念之一,主要用以表述随机变量取值的概率规律。为了使用的方便,根据随机变量所属类型的不同,概率分布取不同的表现形式。
概率分布包括离散概率分布和连续概率分布。
离散数据:数据由一个个单独的数值组成,其中的每一个数值都有相应概率。
连续数据:数据涵盖的是一个范围,这个范围内的任何一个数值都有可能成为事件的结果。
离散概率分布包括:伯努利分布、二项分布、几何分布、泊松分布
连续概率分布包括:正态分布、幂律分布
二、安装python的科学计算包scipy
在python的科学计算包scipy的stats模块计算出常见概率分布的概率值,并用matplotlib包进行绘图。
在notebook环境下安装科学计算包scipy。如果已安装忽略下面安装步骤。
安装步骤:
1)打开终端Anaconda Prompt
2)在conda中运行以下命令:conda install scipy
如果存在多个python环境,先进入想要的环境再安装,比如我自己设置了py2和py3两个环境,先在conda中进入python环境:activate py3,再按上面步骤2执行
如果还没有安装numpy包和matplotlib包,也按上述命令安装这些包
三、概率分布
1.离散概率分布:伯努利分布(Bernoulli Distribution)
伯努利分布亦称“零一分布”、“两点分布”,即事件的结果只有两个值,且事件之间相互独立,例如抛一次硬币就为一次伯努利试验,结果要么为正面要么为反面,因此它符合伯努利分布。伯努利试验只做一次。
伯努利试验的特点是:
(1)每次试验中事件只有两种结果:事件发生或者不发生,如硬币正面或反面,患病或没患病;
(2)每次试验中事件发生的概率是相同的,注意不一定是0.5;
(3)n次试验的事件相互之间独立。

公式为:
1.伯努利分布公式.jpg

期望与方差:
2.伯努利分布期望与公差.png

案例:玩抛硬币的游戏,只抛1次硬币,成功抛出正面朝上记录为1,反面朝上即抛硬币失败记录为0

思路:
3.思路.jpg

Python代码实现:

导入包并求出对应概率:
4.导入包.png

绘制伯努利分布:
5.绘制伯努利分布.png

2.离散概率分布:二项分布(Binomial Distribution)
二项分布就是重复n次独立的伯努利试验。在每次试验中只有两种可能的结果,而且事件相互独立,事件发生与否的概率在每一次独立试验中都保持不变。当试验次数为1时,二项分布服从0-1分布。它计算的结果是做n次试验发生某个结果的概率,例如:抛一次硬币正面朝上的概率,抛两次正面朝上,抛n次正面朝上的概率。
二项分布的特点是:
(1)是在进行一系列独立试验;
(2)每一次都存在成功或失败的可能,每一次试验的成功概率相同;
(3)试验次数有限。
如果事件发生的概率是P,则不发生的概率q=1-p,n表示试验次数,X和r表示n次试验中的成功次数,

公式为:
6.二项分布公式.png

期望与方差:
7.二项分布期望与方差.png

案例:继续玩抛硬币游戏,假如抛硬币5次,求抛出正面朝上次数的概率
Python代码实现:

求出二项分布概率:
8.求出二项分布概率.png

绘制二项分布:
9.绘制二项分布.png

3.离散概率分布:几何分布(Geometric Distribution)
几何分布就是在n次伯努利试验中,试验k次才得到第一次成功的机率。
几何分布的特点:
(1)进行一系列相互独立的试验;
(2)每一次试验既有成功的可能,也有失败的可能,且单次试验的成功概率相同;
(3)主要是为了取得第一次成功需要进行多少次试验。

公式为:
10.几何分布公式.png

期望与方差:
11.几何分布期望与方差.png

案例:向一个喜欢的女孩表白,会存在表白成功和不成功的可能,如果向这个女孩表白,直到表白成功为止,有可能表白1次、2次、3次,现在求首次表白成功的概率
Python代码实现:

求出几何分布概率:
12.求几何分布概率.png

绘制几何分布:
13.绘制几何分布.png

4.离散概率分布:泊松分布(Poisson Distribution)
泊松分布描述的是已知一段时间内事件发生的平均数,求某个时间内发生的概率。
泊松分布的特点:
(1)单独事件在给定区间内随机、独立地发生,给定区间可以是时间或空间;
(2)已知该区间内的事件平均发生次数(或叫做发生率),且为有限数值。该事件平均发生次数通常用希腊字母λ(lambda)表示。

公式为:
14.泊松分布公式.png

期望与方差:
15.泊松分布期望与方差.png

其中,r表示给定区间内发生事件的次数;
λ表示每个区间内平均发生次数。

案例:已知某路口发生事故的比率是每天2次,那么在此处一天内发生k次事故的概率是多少?
Python代码实现:

求出泊松分布的概率:
16.求泊松分布的概率.png

绘制泊松分布:
17.绘制泊松分布.png

5.连续概率分布:正态分布(Normal Distribution)
正态分布(Normal distribution),又名高斯分布(Gaussian distribution),正态曲线呈钟型,两头低,中间高,左右对称,中央部位的概率密度最大。越偏离均值,其概率密度减小。
若随机变量X服从一个数学期望为μ、方差为σ2的正态分布,记为N(μ,σ2)。其概率密度函数为正态分布的期望值μ决定了其位置,其标准差σ决定了分布的幅度。当μ = 0,σ = 1时的正态分布是标准正态分布。
概率密度函数f(x):通过它可以求出一个数据范围内的某个连续变量的概率,可以指出该概率分布的形状。
概率密度:通过面积指出各种范围内的概率大小,通过概率密度函数进行描述。
求解正态分布概率步骤:
(1)确定分布和范围,即算出均值和标准差;
(2)将分布标准化,求出标准分;

18.标准分.png

(3)查找概率,通过在概率表中查找标准分可以求出正态概率,概率表给出的是等于或小于这个数值的概率。
Python代码实现:

定义正态分布随机变量:
19.定义正态分布随机变量.png

求出概率密度函数并绘图:
20.求出概率密度函数并绘图.png

源码:

# coding: utf-8

# # 1.离散概率分布:伯努利分布(Bernoulli Distribution)

# 案例:玩抛硬币的游戏,只抛1次硬币,成功抛出正面朝上记录为1,反面朝上即抛硬币失败记录为0

# In[1]:

# 导入包
import numpy as np
import matplotlib.pyplot as plt
# 统计计算包的统计模块
from scipy import stats


# In[2]:

'''
第1步,定义随机变量:1次抛硬币
正面朝上记录为1,反面朝上记录为0
'''
# arange用于生成一个等差数组,arange([start, ]stop, [step, ]
X1 = np.arange(0,2,1)
X1


# In[3]:

'''
第2步,求对应分布的概率:概率质量函数(PMF)
返回一个列表,列表中每个元素表示随机变量中对应值的概率
'''
p1 = 0.5 # 硬币朝上的概率
pList1 = stats.bernoulli.pmf(X1,p1)
pList1


# In[4]:

'''
第3步,绘图
plot默认绘制折线
marker:点的形状,值o表示点为圆圈标记(circle marker)
linestyle:线条的形状,值None表示不显示连接各个点的折线
'''
plt.plot(X1,pList1,marker='o',linestyle='None')

'''
vlines用于绘制竖直线(vertical lines),
参数说明:vline(x坐标值, y坐标最小值, y坐标值最大值)
我们传入的X是一个数组,是给数组中的每个x坐标值绘制竖直线,
竖直线y坐标最小值是0,y坐标值最大值是对应pList1中的值
'''
plt.vlines(X1,0,pList1)
plt.xlabel('随机变量:抛1次硬币')
plt.ylabel('概率')
plt.title('伯努利分布:p=%.2f' % p1)
plt.show()


# # 2.离散概率分布:二项分布(Binomial Distribution)

# 案例:继续玩抛硬币游戏,假如抛硬币5次,求抛出正面朝上次数的概率

# In[5]:

# 第1步,定义随机变量:5次抛硬币,正面朝上的次数
n2 = 5    # 做某件事情的次数
p2 = 0.5  # 做某件事情成功的概率(抛硬币正面朝上的概率)
X2 = np.arange(0,n2+1,1) # 做某件事成功的次数(抛硬币正面朝上的次数)
X2


# In[6]:

# 第2步,求对应分布的概率:概率质量函数(PMF)
# 返回一个列表,列表中每个元素表示随机变量中对应值的概率
pList2 = stats.binom.pmf(X2,n2,p2)
pList2


# In[7]:

'''
第3步,绘图
plot默认绘制折线
marker:点的形状,值o表示点为圆圈标记(circle marker)
linestyle:线条的形状,值None表示不显示连接各个点的折线
'''
plt.plot(X2,pList2,marker='o',linestyle='None')

'''
vlines用于绘制竖直线(vertical lines),
参数说明:vline(x坐标值, y坐标最小值, y坐标值最大值)
我们传入的X是一个数组,是给数组中的每个x坐标值绘制竖直线,
竖直线y坐标最小值是0,y坐标值最大值是对应pList2中的值
'''
plt.vlines(X2,0,pList2)
plt.xlabel('随机变量:抛硬币正面朝上的次数')
plt.ylabel('概率')
plt.title('二项分布:n=%i,p=%.2f' % (n2,p2))
plt.show()


# # 3.离散概率分布:几何分布(Geometric Distribution)

# 案例:向一个喜欢的女孩表白,会存在表白成功和不成功的可能,如果向这个女孩表白,直到表白成功为止,有可能表白1次、2次、3次,现在求首次表白成功的概率

# In[8]:

'''
第1步,定义随机变量:
首次表白成功的次数,可能是1次,2次,3次
'''
# 第k次做某件事,才取得第1次成功
# 这里我们想知道5次表白成功的概率
k = 5
# p3表示做某件事成功的概率,这里假设每次表白成功的概率为60%
p3 = 0.6
X3 = np.arange(1,k+1,1)
X3


# In[9]:

'''
第2步,求对应分布的概率:概率质量函数(PMF)
返回一个列表,列表中每个元素表示随机变量中对应值的概率
分别表示第1次表白成功的概率,第2次表白成功的概率一直到第5次表白成功的概率
''' 
pList3 = stats.geom.pmf(X3,p3)
pList3


# In[10]:

'''
第3步,绘图
plot默认绘制折线
marker:点的形状,值o表示点为圆圈标记(circle marker)
linestyle:线条的形状,值None表示不显示连接各个点的折线
vlines用于绘制竖直线(vertical lines),
参数说明:vline(x坐标值, y坐标最小值, y坐标值最大值)
我们传入的X是一个数组,是给数组中的每个x坐标值绘制竖直线,
竖直线y坐标最小值是0,y坐标值最大值是对应pList中的值
'''
plt.plot(X3,pList3,marker='o',linestyle='None')
plt.vlines(X3,0,pList3)
plt.xlabel('随机变量:表白第k次才首次成功')
plt.ylabel('概率')
plt.title('几何分布:p=%.2f' % p3)
plt.show()


# # 4.离散概率分布:泊松分布(Poisson Distribution)

# 案例:已知某路口发生事故的比率是每天2次,那么在此处一天内发生k次事故的概率是多少?

# In[11]:

# 第1 步,定义随机变量
mu4 = 2  # 平均值:每天发生2次事故
k4 = 4   # 次数,现在想知道每天发生4次事故的概率
# 发生事故次数,包含0次,1次,2次,3次,4次事故
X4 = np.arange(0,k4+1,1)
X4


# In[12]:

'''
第2步,求对应分布的概率:概率质量函数(PMF)
返回一个列表,列表中每个元素表示随机变量中对应值的概率
分别表示发生0次,1次,2次,3次,4次事故的概率
'''
pList4 = stats.poisson.pmf(X4,mu4)
pList4


# In[13]:

# 第3步,绘图
plt.plot(X4,pList4,marker='o',linestyle='None')
plt.vlines(X4,0,pList4)
plt.xlabel('某路口发生k次事故')
plt.ylabel('概率')
plt.title('泊松分布:平均值mu=%i' % mu4 )
plt.show()


# # 5.连续概率分布:正态分布(Normal Distribution)

# In[14]:

# 第1步,定义随机变量
mu5 = 0   # 平均值
sigma = 1 # 标准差
X5 = np.arange(-5,5,0.1)
X5


# In[15]:

# 第2步,求概率密度函数(PDF)
y = stats.norm.pdf(X5,mu5,sigma)


# In[16]:

# 第3步,绘图
plt.plot(X5,y)
plt.xlabel('随机变量:x')
plt.ylabel('概率:y')
plt.title('正态分布:$\mu$=%.1f,$\sigma^2$=%.1f' % (mu5,sigma))
plt.grid()
plt.show()
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,098评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,213评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,960评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,519评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,512评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,533评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,914评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,574评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,804评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,563评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,644评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,350评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,933评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,908评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,146评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,847评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,361评论 2 342

推荐阅读更多精彩内容

  • 本文主要是基于下面优秀博客文的总结和梳理:概率論中常見分佈總結以及python的scipy庫使用:兩點分佈、二項分...
    程序猪小羊阅读 16,522评论 0 5
  • 作者:Joel Grus读者:锅巴GG Joel Grus 是 Google 的一位软件工程师,曾于数家创业公司担...
    锅巴GG阅读 2,152评论 3 16
  • 你走进我的生活看起来突然,实则是有意, 你走出我的生活看起来有意,实则很突然, 你来时如何,走时我也是盼着你如来时...
    一朵黑阅读 126评论 0 0
  • 席振桓12月份第1次读书打卡,读的书是《小学生满分作文》221——241页。 我最喜欢的一篇文章是《我贪吃的童年》...
    席振桓阅读 265评论 0 0
  • 我是有多久没有写文字了,努力想想,13年的冬天吧。那时候还在还在上一个公司上班,相对比较空闲,反正打字,提笔就写写...
    大琴512阅读 76评论 0 0