朴素贝叶斯(离散型)

博客探讨了朴素贝叶斯算法的理论基础,强调其条件独立假设在实际中的局限性,并介绍了如何通过极大似然估计和拉普拉斯平滑来估计概率。博主分享了离散型朴素贝叶斯算法的代码实现细节,使用三维张量存储条件概率。
摘要由CSDN通过智能技术生成

你越以为简单的东西,实现起来就不一样了。。。真的是烦。。。


朴素贝叶斯的假设异常严格,要求条件概率相互之间独立(实际怎么可能啊┗|`O′|┛

即p(x1,x2,x3...,xn|y)=p(x1|y)*p(x2|y)*...*p(xn|y)


有了这个假设我们便可以计算出各个类别下的条件概率,再藉由贝叶斯公式推算出p(y|x1,x2,x3,...,xn)的条件概率


至于各个类的条件概率以及类的概率一般藉由样本均值及方差来估计

为啥这么求(直觉就该这么算啊

通过极大似然估计展开并联合正态分布的假设,可以算出参数的估计


OK,开始码代码

import numpy as np

class NaiveBayesClassifier(object):
    def __init__(self):
        self.x = self.y = []
        self.feat_dics = self.label_dic = self.dic_label = self.pri = None
        self.con = []

    def pre(self, x, y):
        xt = map(list, zip(*x))
        features = [set(feat) for feat in xt]
        self.feat_dics = [{_l: i for i, _l in enumerate(feats)}
                     for i, feats in enumerate(features)]
       
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值