首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >TypeError:“DiscreteFactor”对象不可订阅

TypeError:“DiscreteFactor”对象不可订阅
EN

Stack Overflow用户
提问于 2020-12-23 06:03:35
回答 2查看 1.7K关注 0票数 1

我有一个贝叶斯算法程序要执行,我使用python 3。

代码语言:javascript
复制
import numpy as np
import csv
import pandas as pd
from pgmpy.models import BayesianModel
from pgmpy.estimators import MaximumLikelihoodEstimator
from pgmpy.inference import VariableElimination


heartDisease = pd.read_csv('heart.csv')
heartDisease = heartDisease.replace('?',np.nan)

print('Few examples from the dataset are given below')
print(heartDisease.head())

model = BayesianModel([('age','trestbps'),('age','fbs'),('sex','trestbps'),('exang','trestbps'),('trestbps','heartdisease'),('fbs','heartdisease'),('heartdisease','restecg'),('heartdisease','thalach'),('heartdisease','chol')])

print('\nLearning CPD using Maximum likelihood estimators')
model.fit(heartDisease,estimator=MaximumLikelihoodEstimator)

print('\n Inferencing with Bayesian Network:')
HeartDisease_infer = VariableElimination(model)

print('\n 1. Probability of HeartDisease given Age=28')
q=HeartDisease_infer.query(variables=['heartdisease'],evidence={'age':28})
print(q['heartdisease'])

print('\n 2. Probability of HeartDisease given cholesterol=100')
q=HeartDisease_infer.query(variables=['heartdisease'],evidence={'chol':100})
print(q['heartdisease'])

运行贝叶斯网络程序时所收到的错误是:

代码语言:javascript
复制
TypeError                                 Traceback (most recent call last)
<ipython-input-7-84a6b48627b2> in <module>
     23 print('\n 1. Probability of HeartDisease given Age=28')
     24 q=HeartDisease_infer.query(variables=['heartdisease'],evidence={'age':28})
---> 25 print(q['heartdisease'])
     26 
     27 print('\n 2. Probability of HeartDisease given cholesterol=100')

TypeError: 'DiscreteFactor' object is not subscriptable

到目前为止,我还没有在堆栈溢出中看到这个确切的错误。有人能解释我为什么会犯这个错误吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-01-15 02:43:30

在试图解决错误后,我想出了解决方案。

代码语言:javascript
复制
print('\n 1. Probability of HeartDisease given Age=28')
q=HeartDisease_infer.query(variables=['heartdisease'],evidence={'age':28})
print(q['heartdisease'])
代码语言:javascript
复制
print(q['heartdisesase']

在这部分代码片段中,我刚刚删除了“”。这里的实际上是试图将自己存储到一个数组对象中,但是输出实际上是特殊的表格式,不能存储在数组中,因此打印实际的答案'q‘会给出所需的结果。

代码语言:javascript
复制
print(q)

这是你的工作完成了!

票数 4
EN

Stack Overflow用户

发布于 2021-01-13 18:04:25

用于获取数据的API可能是旧的。您应该通过简单地将joint=False作为第24行的另一个参数传递回原来的API。如图所示

代码语言:javascript
复制
24 q=HeartDisease_infer.query(variables=['heartdisease'],evidence={'age':28},joint=False)
25 print(q['heartdisease'])
print(prob_offer['Offer']) 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65419735

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档