博客
关于我
曲奇饼问题
阅读量:751 次
发布时间:2019-03-22

本文共 707 字,大约阅读时间需要 2 分钟。

使用贝叶斯公式计算条件概率

案例背景

碗1和碗2各放30个香草曲奇饼和10个巧克力曲奇饼,分别与10个香草曲奇饼和10个巧克力曲奇饼。我们需要计算从碗1取出香草曲奇饼的概率。

通过贝叶斯定理,可以得到公式:[ P(B_1|V) = \frac{P(B_1) \cdot P(V|B_1)}{P(V)} ]

其中:

  • ( B_1 ):碗1。
  • ( V ):取出的是香草曲奇饼。

概率定义

  • ( P(B_1) = 0.5 )(碗1被选中的概率)。
  • ( P(V|B_1) = \frac{30}{40} = 0.75 )(从碗1中取到香草曲奇饼的概率)。
  • ( P(V) ):取到香草曲奇饼的总概率。
  • 计算总概率

    总样本空间为两个碗,每个碗有40个曲奇饼,总共80个曲奇饼。其中:

    • 香草曲奇饼总数:30(碗1) + 10(碗2)= 40个。
    • 巧克力曲奇饼总数:10(碗1) + 10(碗2)= 20个。

    因此:[ P(V) = \frac{40}{80} = 0.5 ]

    计算条件概率

    代入贝叶斯公式:[ P(B_1|V) = \frac{0.5 \cdot 0.75}{0.5} = 0.6 ]

    即,从碗1中取到香草曲奇饼的概率为60%。

    Python验证

    from thinkbayes import Pmfpmf = Pmf()pmf.Set('Bow1', 0.5)pmf.Set("Bow2", 0.5)pmf.Mult('Bow1', 0.75)pmf.Mult('Bow2', 0.5)pmf.Normalize()print(pmf.Prob('Bow1'))

    输出结果为:

    0.6

    验证结果正确,说明计算无误。

    转载地址:http://eigwk.baihongyu.com/

    你可能感兴趣的文章
    oracle 中的 CONCAT,substring ,MINUS 用法
    查看>>
    Oracle 中的 decode
    查看>>
    oracle 中表一对多取多方的最新的一条数据
    查看>>
    oracle 使用 PL/SQL Developer创建表并插入单条、多条数据
    查看>>
    oracle 使用leading, use_nl, rownum调优
    查看>>
    oracle 修改字段类型方法
    查看>>
    Oracle 修改数据库表数据提交之后进行回滚
    查看>>
    UML-总结
    查看>>
    oracle 内存参数示意图
    查看>>
    Oracle 写存储过程的一个模板还有一些基本的知识点
    查看>>
    UML- 配置图(部署图)
    查看>>
    oracle 切割字符串加引号_使用Clean() 去掉由函数自动生成的字符串中的双引号...
    查看>>
    Oracle 创建 DBLink 的方法
    查看>>
    oracle 创建job
    查看>>
    oracle 创建一个用户,只能访问指定的对象
    查看>>
    oracle 创建双向备份,Materialized View 物化视图实现 Oracle 表双向同步
    查看>>
    oracle 创建字段自增长——两种实现方式汇总
    查看>>
    Oracle 升级10.2.0.5.4 OPatch 报错Patch 12419392 Optional component(s) missing 解决方法
    查看>>
    oracle 去重
    查看>>
    oracle 可传输的表空间:rman
    查看>>