Matlab R2018b 使用Bayes Net Toolbox的经历和问题

2024-02-12 03:32

本文主要是介绍Matlab R2018b 使用Bayes Net Toolbox的经历和问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

安装包的下载与加载主要参考:
https://blog.csdn.net/moodytong/article/details/8122327
问题1:
简单案例运行后,图形绘制没有箭头,出现错误提示:
未定义与 ‘matlab.graphics.axis.Axes’ 类型的输入参数相对应的运算符 ‘*’。
出错 arrow (line 393) ax = o * gca;
出错 draw_graph (line 82) h = arrow([x(i)+dx1 y(i)+dy1],[x(k)-dx2 y(k)-dy2],‘BaseAngle’,30);
这个应该是arrow.m 这边有些出问题了,论坛上有人说更新arrow.m可以解决
找到新版本arrow.m替换后成功绘制出箭头。
新版本arrow.m见:
https://download.csdn.net/download/suiya_jessica/11104047

问题2:
使用BNT建造一个贝叶斯网,了解贝叶斯网的几个关键参数如何设定。

%使用BNT官方教程的示例
%建立N*N的matrix记录DAG
N = 4;
dag = zeros(N,N);
C = 1; S = 2; R= 3; W =4;
dag(C,[R S]) = 1;
dag(R,W) = 1;
dag(S,W)=1;
%离散节点,节点为二值量
discrete_nodes = 1:N;
node_sizes = 2*ones(1,N);
%make the Bayes net
bnet = mk_bnet(dag, node_sizes);
%默认是离散节点
%bnet = mk_bnet(dag, node_sizes, 'discrete', discrete_nodes);bnet.CPD{C} = tabular_CPD(bnet,C,[0.5 0.5]);%手动输入的条件概率
bnet.CPD{R} = tabular_CPD(bnet,R,[0.8 0.2 0.2 0.8]);
bnet.CPD{S} = tabular_CPD(bnet,S,[0.5 0.9 0.5 0.1]);
bnet.CPD{W} = tabular_CPD(bnet,W,[1 0.1 0.1 0.01 0 0.9 0.9 0.99]);figure
draw_graph(dag)engine = jtree_inf_engine(bnet);evidence = cell(1,N);
evidence{W} = 2;[engine, loglik] = enter_evidence(engine, evidence);
marg = marginal_nodes(engine, S);
marg.T
p = marg.T(2);evidence{R} = 2;
[engine, loglik] = enter_evidence(engine, evidence);
marg = marginal_nodes(engine, S);
p = marg.T(2);

3,计算图的连通性
没有看到BNT中有此函数,参考教程自己写了个程序

%图的连通性计算
function[S,Q] = concom(G)n = size(G,1);
m = sum(sum(G))/2;
S = 0; j = 1; C = 1;
Q = zeros(n,1);
for i=1:n for j=(i+1):n if G(i,j) == 1if Q(i) == Q(j)if Q(i) == 0Q(i) = C;Q(j) = C;C = C+1;S = S+1;end elseif Q(i) == 0Q(i) = Q(j);elseif Q(j) == 0Q(j) = Q(i);else for k=1:nif Q(k) == Q(i)Q(k) = Q(j);endendS = S-1;end endendend
endS;
Q;

后记:matlab中自带的图相关函数暂时够用,为了去掉一些不必要的警告,卸载了BNT
rmpath(genpath(‘D:\Program Files\MATLAB\R2018b\toolbox\FullBNT-1.0.4\BNT’));
savepath
这下打开再也没有警告了,清净了哈哈

这篇关于Matlab R2018b 使用Bayes Net Toolbox的经历和问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/701560

相关文章

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

Spring Boot中JSON数值溢出问题从报错到优雅解决办法

《SpringBoot中JSON数值溢出问题从报错到优雅解决办法》:本文主要介绍SpringBoot中JSON数值溢出问题从报错到优雅的解决办法,通过修改字段类型为Long、添加全局异常处理和... 目录一、问题背景:为什么我的接口突然报错了?二、为什么会发生这个错误?1. Java 数据类型的“容量”限制

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚