# -*- coding: utf-8 -*-
"""
Created on Tue Jan 16 20:11:07 2018 @author: markli
"""
import numpy as np;
import pandas as pd; """
贝叶斯分类
训练数据格式
X = [x1,x2,...xm]; m*n
xi = [xi1,xi2,...xin].T
Y = [y1,y2,...ym];1*m
""" class Bayes:
def __init__(self,lamda,region):
"""
lamda 贝叶斯修正参数
region 特征属性取值域,类标签取值域
例如两个特征取值范围分别为,A1=[1,2,3],A2=['S','M','L']
类标签取值:C=[1,-1],region=[A1,A2,C]
"""
self.lamda = lamda;
#存放类标签域
self.Y = region[-1];
#存放特征取值域
self.X = region[:-1]; #存放先验概率 P(Y = Ck)
self.PrioPro = np.zeros((1,len(region[-1]))); #存放条件概率 P(Xj = ajl | Y = Ck)
self.ConditionalPro = [];
for i in range(len(region)-1):
cp = np.zeros((len(region[-1]),len(region[i])));
self.ConditionalPro.append(cp); def fit(self,TrainData):
"""
计算先验概率和条件概率,建立模型
TrainData 为二维数组
TrainData 列的顺序与region中特征属性顺序一致
TrainData 最后一列为类别
"""
N = len(TrainData);
K = len(self.Y);
TrainData = TrainData.astype(np.str); NumofCk = pd.value_counts(TrainData[:,-1], sort=True); #Series 类型
CountOfCk = [NumofCk[ck] for ck in self.Y]; #list类型
self.PrioPro = [(ck+self.lamda) / (N + K * self.lamda) for ck in CountOfCk]; j=0;
for ck in self.Y:
#选出类别为Ck的数据
DataofCk = TrainData[np.where(TrainData[:,-1]==ck)];
n = len(DataofCk);
#选出第i个特征的数据
for i in range(len(self.X)):
DataofCkandXi = DataofCk[:,i];
Numofaj = pd.value_counts(DataofCkandXi,sort=True); #为第i个特征的每个特征值计数
Countofaj = [Numofaj[aj] for aj in self.X[i]];
S = len(self.X[i]);
self.ConditionalPro[i][j] = [(aj+self.lamda) / (n+S * self.lamda) for aj in Countofaj];
j = j+1; def predict(self,TestData):
"""
预测实例,为其分类
测试数据没有类别列,其余数据格式与训练数据格式一致
"""
predictY = [];
for i in range(len(TestData)):
x = TestData[i];
y = self.GetLable(x);
predictY.append(y);
return predictY; def GetLable(self,x):
"""
输入一个测试实例x ,输出使其后验概率最大的类别y
"""
pro = [];
n = len(x);
for j in range(len(self.Y)):
p = 1;
for i in range(n):
feature = self.ConditionalPro[i];
fi = self.X[i] #获得第i个特征的值域
index = fi.index(x[i]);
p = p * feature[j][index]; p = p * self.PrioPro[j];
pro.append(p); y = self.Y[np.argmax(pro)]; return y;

测试代码

 # -*- coding: utf-8 -*-
"""
Created on Wed Jan 17 15:29:14 2018 @author: markli
""" import numpy as np;
import pandas as pd;
from BayesClass import Bayes A1 = ['','',''];
A2 = ['S','M','L'];
C = ['','-1']; Data = np.array([[1,'S',-1],[1,'M',-1],[1,'M',1],[1,'S',1],[1,'S',-1],
[2,'S',-1],[2,'M',-1],[2,'M',1],[2,'L',1],[2,'L',1],
[3,'L',1],[3,'M',1],[3,'M',1],[3,'L',1],[3,'L',-1]]);
test = np.array([[2,'S']]);
B = Bayes(0,[A1,A2,C]);
B.fit(Data);
y = B.predict(test);
print(y);

Python3 贝叶斯分类的更多相关文章

  1. 利用朴素贝叶斯分类算法对搜狐新闻进行分类(python)

    数据来源  https://www.sogou.com/labs/resource/cs.php介绍:来自搜狐新闻2012年6月—7月期间国内,国际,体育,社会,娱乐等18个频道的新闻数据,提供URL ...

  2. 机器学习之路: python 朴素贝叶斯分类器 MultinomialNB 预测新闻类别

    使用python3 学习朴素贝叶斯分类api 设计到字符串提取特征向量 欢迎来到我的git下载源代码: https://github.com/linyi0604/MachineLearning fro ...

  3. python3  threading初体验

    python3中thread模块已被废弃,不能在使用thread模块,为了兼容性,python3将thread命名为_thread.python3中我们可以使用threading进行代替. threa ...

  4. Python3中的字符串函数学习总结

    这篇文章主要介绍了Python3中的字符串函数学习总结,本文讲解了格式化类方法.查找 & 替换类方法.拆分 & 组合类方法等内容,需要的朋友可以参考下. Sequence Types ...

  5. Mac-OSX的Python3.5虚拟环境下安装Opencv

    Mac-OSX的Python3.5虚拟环境下安装Opencv 1   关键词 关键词:Mac,OSX,Python3.5,Virtualenv,Opencv 2   概述 本文是一篇 环境搭建 的基础 ...

  6. Ubuntu部署python3.5的开发和运行环境

    Ubuntu部署python3.5的开发和运行环境 1 概述 由于最近项目全部由python2.x转向 python3.x(使用目前最新的 python3.5.1) ,之前的云主机的的默认python ...

  7. Python3 登陆网页并保持cookie

    网页登陆 网页登陆的原理都是,保持一个sessionid在cookie然后,根据sessionid在服务端找到cookie进行用户识别 python实现 由于python的简单以及丰富的类库是开发网络 ...

  8. 阿里云 SDK python3支持

    最近的一个项目需要操作阿里云的RDS,项目使用python3,让人惊讶的是官方的SDK竟然只支持python2 在阿里云现有SDK上改了改,文件的修改只涉及aliyun/api/base.py,详见h ...

  9. python3爬取1024图片

    这两年python特别火,火到博客园现在也是隔三差五的出现一些python的文章.各种开源软件.各种爬虫算法纷纷开路,作为互联网行业的IT狗自然看的我也是心痒痒,于是趁着这个雾霾横行的周末瞅了两眼,作 ...

随机推荐

  1. POJ 1511 Invitation Cards / UVA 721 Invitation Cards / SPOJ Invitation / UVAlive Invitation Cards / SCU 1132 Invitation Cards / ZOJ 2008 Invitation Cards / HDU 1535 (图论,最短路径)

    POJ 1511 Invitation Cards / UVA 721 Invitation Cards / SPOJ Invitation / UVAlive Invitation Cards / ...

  2. 【转】如何学习android开发

    1.Java基础 很多朋友一上手就开始学习Android,似乎太着急了一些.Android应用程序开发是以Java语言为基础的,所以没有扎实的Java基础知识,只 是机械的照抄别人的代码,是没有任何意 ...

  3. python常用模块-配置文档模块(configparser)

    python常用模块-配置文档模块(configparser) 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. ConfigParser模块用于生成和修改常见配置文档,当前模块的名称 ...

  4. 在同一个表中将varchar2类型的数据转存到blob类型的字段中

    用一条修改语句即可:update t_content set f_body=rawtohex(f_check) where f_type in (0,4)此处须用rawtohex()函数将f_chec ...

  5. python---django中models配置修改数据库引擎

    Django支持多种数据库,sqlite,mysql,oracle等,其默认数据库是sqlite 在settings文件中可以发现: DATABASES = { 'default': { 'ENGIN ...

  6. ThinkPHP框架学习(二)

    在上一节中,我主要讲到了如何获取ThinkPHP框架,以及虚拟目录和虚拟主机的配置.准备工作完成之后,就可以利用ThinkPHP去部署项目了. 先在工作目录(D:/zend/workspace)下新建 ...

  7. HDU 1524 树上无环博弈 暴力SG

    一个拓扑结构的图,给定n个棋的位置,每次可以沿边走,不能操作者输. 已经给出了拓扑图了,对于每个棋子找一遍SG最后SG和就行了. /** @Date : 2017-10-13 20:08:45 * @ ...

  8. Web性能优化系列(2):剖析页面绘制时间

    本文由 伯乐在线 - J.c 翻译,sunbiaobiao 校稿.未经许可,禁止转载!英文出处:www.deanhume.com.欢迎加入翻译小组. 最近,我参加了在伦敦举办的Facebook移动开发 ...

  9. CSS-3 box-shadow 的使用

    box-shadow是给对象实现图层阴影效果的. 语法: E {box-shadow: <length> <length> <length>?<length& ...

  10. jsp前端验证(非常好用)

    1.在jsp页面中引入<script type="text/javascript" src="${ctxStatic}/js/valid.js">& ...