Machine Learning机器学习之贝叶斯网络(BayesianNetwork)

news2024/9/22 11:36:09

目录

前言

算法提出背景:

贝叶斯算法特点:

一、贝叶斯定理

二、朴素贝叶斯分类模型

1、朴素贝叶斯分类模型(Naive Bayes Classifier)

2、原理

2.1 朴素贝叶斯假设

2.2条件独立性假设

2.3后验概率计算

2.4类别预测

2.5小结

3、建模应用

4、贝叶斯垃圾邮件过滤应用 

三、贝叶斯网络推理 

四、贝叶斯网络学习

五、总结

优点:

缺点:

应用:


博主介绍:✌专注于前后端、机器学习、人工智能应用领域开发的优质创作者、秉着互联网精神开源贡献精神,答疑解惑、坚持优质作品共享。本人是掘金/腾讯云/阿里云等平台优质作者、擅长前后端项目开发和毕业项目实战,深受全网粉丝喜爱与支持✌有需要可以联系作者我哦!

🍅文末三连哦🍅

👇🏻 精彩专栏推荐订阅👇🏻 不然下次找不到哟

前言

贝叶斯网络(Bayesian Network),也称为信念网络(Belief Network)或概率有向无环图(Probabilistic Directed Acyclic Graph,PDAG),是一种用图形表示概率模型的方法,它基于概率推断的贝叶斯定理。贝叶斯网络的背景可以追溯到 1980 年代初期,它是由一些著名的人工智能研究者如Judea Pearl、Peter Spirtes、Clark Glymour等提出和发展起来的。

算法提出背景:

贝叶斯网络的提出源于对概率图模型的研究,旨在解决不确定性推理问题。传统的概率图模型有两种主要类型:贝叶斯网络和马尔可夫网络。在贝叶斯网络中,变量之间的关系通过有向边连接来表示,而在马尔可夫网络中,变量之间的关系通过无向边连接来表示。

贝叶斯算法特点:

  1. 图形化表示: 贝叶斯网络使用有向无环图(DAG)来表示变量之间的依赖关系,图中的节点表示随机变量,有向边表示变量之间的因果关系或依赖关系

  2. 概率推断: 贝叶斯网络基于贝叶斯定理进行概率推断,可以用来计算给定观测数据情况下变量的概率分布,或者用来预测新数据的概率分布。

  3. 因果推理: 贝叶斯网络可以用来探索变量之间的因果关系,并进行因果推理,即根据已知的因果关系推断其他变量的状态。

  4. 不确定性建模: 贝叶斯网络可以有效地处理不确定性信息,允许将概率分布的不确定性纳入到推理过程中。

一、贝叶斯定理

贝叶斯定理(Bayes' theorem)是概率论中的一个基本定理,描述了在已知相关信息的情况下,如何更新对事件发生的概率估计。贝叶斯定理的数学表达如下:

P(A|B) = \frac{P(B|A) \times P(A)}{P(B)}

其中,P(A|B)表示在观测到事件 B 的条件下事件 A 发生的概率,P(B|A) 表示在事件 A 发生的条件下事件 B 发生的概率,P(A)P(B)分别表示事件 A 和事件 B 的先验概率。

贝叶斯定理可以解决以下类型的问题:

1. 后验概率计算:已知事件 B 发生的条件下,事件 A 发生的概率是多少?
2. 先验概率更新:当观测到事件 B 发生后,如何更新对事件 A 发生的先验概率?
3. 概率推断:已知事件 A 和 B 之间的关系,如何推断事件 A 和 B 的关联程度?

贝叶斯定理的应用非常广泛,涵盖了各个领域,如机器学习、统计学、医学、金融等。在机器学习中,贝叶斯定理常用于朴素贝叶斯分类器、贝叶斯优化等算法中,用于处理分类、回归、优化等问题。在实际应用中,贝叶斯定理为我们提供了一种有效的概率推断方法,能够更好地利用先验知识和观测数据,进行准确的推断和预测。

二、朴素贝叶斯分类模型

1、朴素贝叶斯分类模型(Naive Bayes Classifier)

基于贝叶斯定理和特征独立假设的一种简单而有效的分类算法。该模型假设给定类别的特征之间是相互独立的,并且通过计算给定类别下各个特征的条件概率来进行分类。尽管朴素贝叶斯分类器存在“朴素”的假设,即特征之间是相互独立的,但在许多实际情况下,该算法仍然表现出惊人的性能。

朴素贝叶斯分类模型(Naive Bayes Classifier)是基于贝叶斯定理和特征独立假设的一种简单而有效的分类算法。该模型假设给定类别的特征之间是相互独立的,并且通过计算给定类别下各个特征的条件概率来进行分类。尽管朴素贝叶斯分类器存在“朴素”的假设,即特征之间是相互独立的,但在许多实际情况下,该算法仍然表现出惊人的性能。

2、原理

朴素贝叶斯分类模型基于贝叶斯定理,利用特征之间的条件独立性,计算给定类别下各个特征的条件概率,然后根据贝叶斯定理计算后验概率,最终确定样本所属的类别。

具体而言,假设有一个包含特征 \left ( x_1, x_2, ..., x_n \right )和类别\left ( y \right )的数据集,朴素贝叶斯分类器的计算过程如下:

2.1 朴素贝叶斯假设

朴素贝叶斯分类器假设特征之间是相互独立的,即给定类别的情况下,特征之间的条件概率是相互独立的。这个假设简化了模型的计算,并且在实际应用中通常能够取得良好的效果。

2.2条件独立性假设

基于朴素贝叶斯假设,我们可以将后验概率P(y|x)展开为特征之间的条件概率的乘积:

P(y|x) = \frac{P(x|y) \times P(y)}{P(x)}

根据朴素贝叶斯假设,特征之间是相互独立的,因此可以将条件概率 P(x|y)展开为特征的乘积:

P(x|y) = P(x_1|y) \times P(x_2|y) \times ... \times P(x_n|y)

2.3后验概率计算

将条件独立性假设代入贝叶斯定理的表达式中,得到后验概率P(y|x) 的计算公式:

P(y|x) = \frac{P(y) \times P(x_1|y) \times P(x_2|y) \times ... \times P(x_n|y)}{P(x)}

其中,P(y)表示类别y 的先验概率,P(x_i|y) 表示在类别 y 的条件下特征x_i的条件概率,P(x)是样本 x出现的概率。

2.4类别预测

通过计算每个类别的后验概率P(y|x),选择具有最大后验概率的类别作为样本的预测类别。

2.5小结

朴素贝叶斯分类器的原理基于贝叶斯定理和朴素贝叶斯假设,通过计算类别的后验概率来进行分类。虽然朴素贝叶斯假设简化了模型的计算,但在实际应用中,朴素贝叶斯分类器仍然能够取得良好的分类效果,并且具有简单高效的特点。但也因此存在明显的缺点

  • 特征独立性假设:朴素贝叶斯分类器假设特征之间是相互独立的,这在某些情况下可能不成立,导致分类性能下降。
  • 处理连续特征困难:朴素贝叶斯分类器对于连续特征的处理比较困难,通常需要对连续特征进行离散化处理。
  • 样本不平衡问题:当数据集中不同类别的样本数量差异较大时,朴素贝叶斯分类器的分类性能可能受到影响。

3、建模应用

生成了80000个随机样本,然后将其划分为训练集和测试集。接着使用高斯朴素贝叶斯分类器对训练集进行训练,并在训练集和测试集上进行预测。最后,使用Matplotlib库可视化了训练数据和测试数据的分类结果

import numpy as np
import matplotlib.pyplot as plt
from sklearn.datasets import make_classification
from sklearn.model_selection import train_test_split
from sklearn.naive_bayes import GaussianNB
from sklearn.metrics import accuracy_score

# 生成随机样本
X, y = make_classification(n_samples=80000, n_features=2, n_informative=2, n_redundant=0, random_state=42)

# 划分数据集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.4, random_state=42)

# 初始化高斯朴素贝叶斯分类器
nb_classifier = GaussianNB()

# 训练模型
nb_classifier.fit(X_train, y_train)

# 进行预测
y_pred_train = nb_classifier.predict(X_train)
y_pred_test = nb_classifier.predict(X_test)

# 计算准确率
train_accuracy = accuracy_score(y_train, y_pred_train)
test_accuracy = accuracy_score(y_test, y_pred_test)
print("Training set accuracy:", train_accuracy)
print("Test set accuracy:", test_accuracy)

# 可视化训练数据和分类结果
plt.figure(figsize=(12, 6))

# 绘制训练数据
plt.subplot(1, 2, 1)
plt.scatter(X_train[:, 0], X_train[:, 1], c=y_train, cmap=plt.cm.Paired, marker='o', edgecolors='k')
plt.title('Training Data')
plt.xlabel('Feature1')
plt.ylabel('Feature2')

# 绘制测试数据及分类结果
plt.subplot(1, 2, 2)
plt.scatter(X_test[:, 0], X_test[:, 1], c=y_pred_test, cmap=plt.cm.Paired, marker='o', edgecolors='k')
plt.title('Test Data and Classification Results')
plt.xlabel('Feature1')
plt.ylabel('Feature2')

plt.show()

执行结果:随机生成样本80000份,划分2两个样本特征,40%测试集。

图1 可视化数据分类结果 

4、贝叶斯垃圾邮件过滤应用 

传统的垃圾邮件过滤方式是关键词过滤,但是这种方法过于绝对,容易出现误判的情况。贝叶斯过滤将会充分考虑关键词在正常邮件和垃圾邮件中出现的概率,可以极大降低失误率。下面我们通过一个案列来展示贝叶斯是如何过滤垃圾邮件的。

具体过程:

  1. 建立词汇表和训练集:首先,贝叶斯过滤器会建立一个词汇表,并将每个词语与其在垃圾邮件和正常邮件中出现的频率联系起来。为了完成这一步,需要一个已经分类好的训练集,其中包含了大量的垃圾邮件和正常邮件样本。
  2. 计算词语频率:通过对训练集的学习,贝叶斯过滤器可以计算出每个词语在垃圾邮件和正常邮件中出现的频率。这些频率用于后续计算每个词语在待分类邮件中出现的概率。
  3. 预处理待分类邮件:当有新的邮件需要分类时,贝叶斯过滤器会对该邮件进行预处理。这通常包括将邮件转化为一个特征向量,该向量包含了待分类邮件中出现的每个词语以及它们的频率。
  4. 计算概率:根据贝叶斯定理,贝叶斯过滤器可以计算出该邮件属于垃圾邮件和正常邮件的概率。具体来说,它会计算邮件中每个词语在垃圾邮件和正常邮件中的条件概率,并结合这些词语在邮件中的出现频率,来得出最终的分类概率。
  5. 自我学习功能:贝叶斯过滤器具有自我学习的功能。随着时间的推移,它收到的垃圾邮件越多,其分类的准确率通常会越高。这是因为更多的数据可以帮助过滤器更准确地计算词语的频率和概率。同时为了提高准确率,贝叶斯过滤器通常会考虑多个词语的联合概率,而不仅仅是单个词语的概率。这意味着它会考虑邮件中多个词语的组合,以更准确地判断邮件的类别。
import numpy as np
from sklearn.feature_extraction.text import CountVectorizer
from sklearn.naive_bayes import MultinomialNB
from sklearn.model_selection import train_test_split
from sklearn.metrics import accuracy_score

# 随机生成5000的邮件数据
np.random.seed(42)
num_emails = 50000
emails = []
for _ in range(num_emails):
    if np.random.rand() < 0.3:  # 50% 的邮件是非垃圾邮件
        email = ("嘿,Mika!你今天好吗?", 0)
    else:
        email = ("现在免费获取抽奖获取小米手机!快来!", 1)
    emails.append(email)

# 提取特征和标签
X, y = zip(*emails)

# 将文本数据转换为数值特征
vectorizer = CountVectorizer()
X = vectorizer.fit_transform(X)

# 将数据集拆分为训练集和测试集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=42)

# 初始化并训练分类器
classifier = MultinomialNB()
classifier.fit(X_train, y_train)

# 进行预测
y_pred = classifier.predict(X_test)

# 计算准确率
accuracy = accuracy_score(y_test, y_pred)
print("准确率:", accuracy)

执行结果:精确率100%

三、贝叶斯网络推理 

在贝叶斯网络中,节点表示随机变量,边表示变量之间的依赖关系。推理过程是指在给定一些证据或观察值的情况下,通过贝叶斯网络计算出目标变量的后验概率分布的过程。

推理过程一般可以通过以下几种方法实现:

  1. 采样推理(Sampling Inference):通过随机抽样的方式,在贝叶斯网络中进行大量的随机采样,从而近似计算目标变量的后验概率分布。

  2. 变量消除推理(Variable Elimination Inference):通过变量消除的方式,逐步削减网络中的变量,最终计算出目标变量的后验概率分布。

  3. 精确推理(Exact Inference):对于小规模的贝叶斯网络,可以使用精确推理方法,如枚举法或动态规划,精确地计算出目标变量的后验概率分布。

  4. 近似推理(Approximate Inference):对于大规模的贝叶斯网络,精确推理可能变得困难,可以采用一些近似推理方法,如变分推断或马尔可夫链蒙特卡洛法(MCMC),来近似计算目标变量的后验概率分布。

总之,贝叶斯网络的推理过程是通过计算机算法在给定证据的情况下,利用概率论的知识来推断目标变量的概率分布。

四、贝叶斯网络学习

主要分为参数学习和结构学习两种方式。第一种参数学习(Parameter Learning),参数学习是指在已知贝叶斯网络结构的情况下,从数据中学习网络中节点的条件概率分布参数的过程。参数学习可以通过最大似然估计、贝叶斯估计等方法来实现。通过参数学习,可以利用数据来估计贝叶斯网络中每个节点的条件概率分布参数,从而使网络更符合实际数据。第二种是结构学习(Structure Learning),结构学习是指从数据中学习贝叶斯网络的结构的过程。结构学习的目标是发现最优的网络结构,使得网络能够最好地表示数据之间的依赖关系。结构学习可以通过搜索算法(如贪婪搜索、爬山算法)、约束优化方法(如评分函数、信息准则)等方法来实现。结构学习是一个复杂的问题,因为可能存在多个符合数据的网络结构,需要考虑结构的复杂性和有效性。

五、总结

优点:

  • 处理复杂关系:贝叶斯网络可以有效地描述大量变量之间的复杂依赖关系。
  • 引入先验知识:它允许通过引入先验知识来修正概率分布,从而提高模型的准确性。
  • 预测与推断:贝叶斯网络能够进行模型的推断和预测,对未来的情况做出估计。
  • 动态建模:它可以逐步加入新的变量,构建动态的模型,适应不断变化的环境。
  • 直观性:贝叶斯网络的结构直观,易于理解和解释,有助于揭示变量之间的关联。

缺点:

  • 计算复杂度:对于大规模数据或复杂模型,贝叶斯网络的计算复杂度较高,需要较长的计算时间。
  • 先验知识的依赖:构建贝叶斯网络需要依赖先验知识。如果先验知识不准确或不完备,可能导致模型预测结果的不准确。
  • 非线性关系建模困难:对于变量之间的非线性关系和交互作用,贝叶斯网络的建模可能较为困难。
  • 模型可解释性:虽然贝叶斯网络的结构直观,但不同的模型结构可能产生相同的预测结果,这可能导致在某些情况下模型难以解释。
  • 数据依赖性:贝叶斯网络对训练数据的依赖较强,如果数据质量不高或数量不足,可能导致模型的不准确。
  • 学习过程无法迭代更新:一旦先验概率和似然函数确定,后续的训练数据无法直接影响先验概率的更新,这在面对不断变化的数据时可能是一个问题。

应用:

  1. 医疗诊断:利用患者的临床数据、病史等构建贝叶斯网络模型,帮助医生进行更准确的疾病诊断和预测。
  2. 金融风险管理:用于分析客户的信用记录、财务状况等因素,评估信用风险,制定信贷政策。
  3. 工业控制:用于故障诊断和设备维护,提高设备的可靠性和效率。
  4. 贝叶斯网络还在决策支持系统、自然语言处理、专家系统等领域发挥重要作用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1552760.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Postman测试含有变量的接口的方法

1.在路径中用/&#xff1a;设置变量名 2.设置token验证 3.填写参数

Vue 04 Vue 中的 Ajax、slot 插槽

Vue学习 Vue 0401 Vue中的Ajax服务器准备axios使用跨域问题解决Vue-CLI 配置代理1Vue-CLI 配置代理2案例: 用户搜索vue-resource 02 slot插槽默认插槽具名插槽作用域插槽slot总结 Vue 04 B站 Vue全家桶&#xff08;BV1Zy4y1K7SH&#xff09; 学习笔记 Vue 中的 ajax 01 Vue中的…

Unity 学习日记 12.小球撞击冰块游戏

目录 1.准备场景 2.让小球动起来 3.用鼠标把小球甩出去 4.加入鼠标点击小球的判断 5.小球与冰块的碰撞测试 6.撞击后销毁冰块 ​编辑 7.显示游戏计时 8.显示扔球次数 9.显示剩余冰块个数 10.游戏结束 11.完整代码 下载源码 UnityPackage 最终效果&#xff1a; 1.准…

Idea2023.3.6版本无法启动设置界面-settings界面打不开无反应---IntelliJ Idea工作笔记013

先说一下网上有,把某个文件删除的 有说是因为汉化问题的 可以看到,其实都不是,这样弄就好了,很简单 Please report thisjava.lang.ClassCastException: class [Lcom.intellij.execution.filters.CompositeInputFilter$InputFilterWrapper; cannot be cast to class java.uti…

关于使用vscode搭建c/c++编程环境

目录 关于使用vscode搭建c/c编程环境一、前言二、安装 IDE 二、安装TDM-GCC安装三、安装C/C环境四、编写代码并进行编译 关于使用vscode搭建c/c编程环境 一、前言 一直觉得vscode是生产强有力的生产工具&#xff0c;基于此&#xff0c;做一篇学习笔记进行记录。 二、安装 ID…

洛谷 P1379 八数码难题

代码如下&#xff1a; #include<bits/stdc.h> using namespace std; struct node{string s;int pos; }star,en; map<string,int>mp[2]; queue<node>q[2]; int main(){cin>>star.s;en.s"123804765";for(int i0;i<9;i){if(star.s[i]0) sta…

服务器停止解析域名,但仍然可以访问到

1.centos7 如何刷新dns缓存 在CentOS 7上&#xff0c;DNS缓存由nscd&#xff08;Name Service Cache Daemon&#xff09;管理&#xff0c;如果系统上安装了nscd&#xff0c;可以通过清除nscd缓存来刷新DNS缓存。 要刷新DNS缓存&#xff0c;请执行以下命令&#xff1a; sudo …

【XXL-JOB】执行器架构设计和源码解析

简介 XXL-JOB是一个分布式任务调度平台&#xff0c;其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线&#xff0c;开箱即用。 XXL-JOB分为B/S架构&#xff0c;调用中心是XXL-JOB服务端&#xff0c;执行器是客户端。 调度中心核…

入门指南|营销中人工智能生成内容的主要类型 [新数据、示例和技巧]

由于人工智能技术的进步&#xff0c;内容生成不再是一项令人头疼的任务。随着人工智能越来越多地接管手动内容制作任务&#xff0c;营销人员明智的做法是了解现有的不同类型的人工智能生成内容&#xff0c;以及哪些内容从中受益最多。这些工具可以帮助我们制作对您的受众和品牌…

3.28C++

复数类的实现&#xff0c;写出三种构造函数&#xff0c;算术运算符、关系运算符、逻辑运算符重载尝试实现自增、自减运算符的重载 #include <iostream> using namespace std; class Num {int rel; //实部int vir; //虚部 public:Num():rel(2),vir(1){}Num(int rel,…

若依 3.8.7版本springboot前后端分离 整合mabatis plus

1.去掉mybatis 这一步我没有操作&#xff0c;看别人的博客有说不去掉可能冲突&#xff0c;也可能不冲突&#xff0c;我试下来就没去掉如需要去除&#xff0c;到总的pom.xml中properties标签下的<mybatis-spring-boot.version>x.x.x</mybatis-spring-boot.version>…

如何在极狐GitLab 自定义 Pages 域名、SSL/TLS 证书

本文作者&#xff1a;徐晓伟 GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 本文主要讲述了在极狐GitLab 用户…

深圳区块链交易所app系统开发,撮合交易系统开发

随着区块链技术的迅速发展和数字资产市场的蓬勃发展&#xff0c;区块链交易所成为了数字资产交易的核心场所之一。在这个快速发展的领域中&#xff0c;区块链交易所App系统的开发和撮合交易系统的建设至关重要。本文将探讨区块链交易所App系统开发及撮合交易系统的重要性&#…

包子凑数(蓝桥杯,闫氏DP分析法)

题目描述&#xff1a; 小明几乎每天早晨都会在一家包子铺吃早餐。 他发现这家包子铺有 N 种蒸笼&#xff0c;其中第 i 种蒸笼恰好能放 Ai 个包子。 每种蒸笼都有非常多笼&#xff0c;可以认为是无限笼。 每当有顾客想买 X 个包子&#xff0c;卖包子的大叔就会迅速选出若干笼…

解决:PytorchStreamWriter failed writing file data

文章目录 问题内容问题分析解决思路 问题内容 今天在炼丹的时候&#xff0c;我发现模型跑到140步的时候保存权重突然报了个问题&#xff0c;详细内容如下&#xff1a; Traceback (most recent call last):File "/public/home/dyedd/.conda/envs/diffusers/lib/python3.8…

uniapp输入框事件(防抖)

一、描述 在输入框输入内容或者说输入关键词的时候&#xff0c;往往都要进行做防抖处理。如果不做防抖&#xff0c;你输入什么&#xff0c;动态绑定的数据就会保持一致。这样不好吗&#xff0c;同步获取。有个业务场景&#xff0c;如果是搜索框&#xff0c;你每次一个字符&…

2024年第十届国际虚拟现实大会(ICVR 2024)即将召开!

会议面向虚拟现实、增强现实、人工智能等互联网新技术领域的专家及学者&#xff0c; 致力于共同促进国内外虚拟现实的发展与应用。 2014年至今&#xff0c;ICVR在全球新加坡&#xff0c;美国洛杉矶&#xff0c;中国成都&#xff0c;香港等国家及地区召开&#xff0c;面向虚拟现…

力扣面试150 二叉搜索树的最小绝对差 中序遍历

Problem: 530. 二叉搜索树的最小绝对差 文章目录 思路复杂度Code 思路 &#x1f468;‍&#x1f3eb; 录哥题解 复杂度 时间复杂度: O ( n ) O(n) O(n) 空间复杂度: O ( 1 ) O(1) O(1) Code // 递归 class Solution {int ans Integer.MAX_VALUE;TreeNode pre;//一开…

C++的非类型模板参数与模板分离编译(模板显式实例化)

非类型模板参数与模板分离编译&#xff08;模板显式实例化&#xff09; 文章目录 非类型模板参数与模板分离编译&#xff08;模板显式实例化&#xff09;前言一、非类型模板参数二、模版分离编译1. 分离编译概念2. 模版的分离编译问题案例解决方法 总结 前言 ​ 本篇博客文章介…

vue2源码解析——Vue.set/$set方法如何给响应式对象添加属性

在Vue 2中需要向响应式对象添加新属性时&#xff0c;可以使用Vue.set或$set方法来实现。这两个方法的作用是向响应式对象添加属性并确保这个新属性也是响应式的。 为什么会有vue.set方法 Vue提供了Vue.set方法主要是为了解决在Vue 2.x 中动态添加属性时可能遇到的响应性问题。 …