三硬币模型——机器学习课后作业

题目要求:

给出解决代码如下:

import numpy as np


def miu_calc(pii, pi, qi, yj):
    up_b = pii * pi ** yj * (1 - pi) ** (1 - yj)
    up_c = (1 - pii) * qi ** yj * (1 - qi) ** (1 - yj)
    return up_b / (up_b + up_c)


yj = np.array([1, 1, 0, 1, 0, 0, 1, 0, 1, 1])

pi0 = 0.46
p0 = 0.55
q0 = 0.67

miu = miu_calc(pi0, p0, q0, yj)

pi_n = miu.mean()
p_n = (miu * yj).sum() / miu.sum()
q_n = ((1 - miu) * yj).sum() / (1 - miu).sum()

for ii in range(100):
    miu = miu_calc(pi_n, p_n, q_n, yj)

    pi_n = miu.mean()
    p_n = (miu * yj).sum() / miu.sum()
    q_n = ((1 - miu) * yj).sum() / (1 - miu).sum()

print(pi_n, p_n, q_n)

 算法解析:

def miu_calc(pii, pi, qi, yj):
    up_b = pii * pi ** yj * (1 - pi) ** (1 - yj)
    up_c = (1 - pii) * qi ** yj * (1 - qi) ** (1 - yj)
    return up_b / (up_b + up_c)

 

for ii in range(100):
    miu = miu_calc(pi_n, p_n, q_n, yj)

    pi_n = miu.mean()
    p_n = (miu * yj).sum() / miu.sum()
    q_n = ((1 - miu) * yj).sum() / (1 - miu).sum()

 最终得到结果:

代码来源及参考文章:统计学习方法 EM算法三硬币问题python代码 - 知乎

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值