初级
第09章 EM算法及其推广 - 习题9.1 - 实现EM类
未完成
初级参考
完整示例代码供参考,建议自己理解后重新输入
%matplotlib inline
import numpy as np
import math
class EM:
def __init__(self, prob):
self.pro_A, self.pro_B, self.pro_C = prob
def pmf(self, i):
pro_1 = self.pro_A * math.pow(self.pro_B, data[i]) * math.pow(
(1 - self.pro_B), 1 - data[i])
pro_2 = (1 - self.pro_A) * math.pow(self.pro_C, data[i]) * math.pow(
(1 - self.pro_C), 1 - data[i])
return pro_1 / (pro_1 + pro_2)
def fit(self, data):
print('init prob:{}, {}, {}'.format(self.pro_A, self.pro_B,
self.pro_C))
count = len(data)
theta = 1
d = 0
while (theta > 0.00001):
# 迭代阻塞
_pmf = [self.pmf(k) for k in range(count)]
pro_A = 1 / count * sum(_pmf)
pro_B = sum([_pmf[k] * data[k] for k in range(count)]) / sum(
[_pmf[k] for k in range(count)])
pro_C = sum([(1 - _pmf[k]) * data[k]
for k in range(count)]) / sum([(1 - _pmf[k])
for k in range(count)])
d += 1
print('{} pro_a:{:.4f}, pro_b:{:.4f}, pro_c:{:.4f}'.format(
d, pro_A, pro_B, pro_C))
theta = abs(self.pro_A - pro_A) + abs(self.pro_B -
pro_B) + abs(self.pro_C -
pro_C)
self.pro_A = pro_A
self.pro_B = pro_B
self.pro_C = pro_C
👑
升级 VIP
解锁全部题目,畅通无阻地学习
- ✓ 解锁全部训练包所有题目
- ✓ 查看完整参考代码和提示
- ✓ 浏览器内直接运行 Python 代码
- ✓ 自动批改 + 进度追踪
30天
¥18
1年
¥99
2年
¥158
3年
¥199