如何通过属性问题区分动物

我正在开发一个程序,实际上是一个人工智能,它通过一系列问题来学习区分动物,这些问题将确定我们所考虑的动物所具有的属性。因此,我需要一种方法来存储动物及其相应的属性问题,例如:

dog : does it have a wet nose?      does it have whiskers?

所有回答“是”的问题都是狗所具有的属性……有什么建议吗?另外,请注意一些动物可能具有相同的属性,例如:

dog : does it have a wet nose?      does it have whiskers?cat : does it purr?      does it have whiskers?

所以我希望程序能够通过问多个问题来确定哪个动物是哪个。


回答:

最简单的方法是使用字典,它将保持属性与具有该属性的动物列表之间的关系,例如:

attributes=[bite,scratch,purr,whiskers,...]dic={whiskers:[cat,dog]purr:[cat]scratch:[cat]bite:[cat,dog,rat]}dose it scratch

基于你的问题格式,例如:

   for each question:     for each word in question :       if word in attributes:         attributesFound.append(word)   animal=set(dic[attributesFound[0]])   for each attribute in attributesFound:   animal=animal.intersection(dict[attribute ])

假设我们有这种情况

      does it purr?      does it have whiskers?

attributesFound 将会是 [purr,whiskers],animal 将会是 [cat,dog],然后我们进入每个属性的循环

 for each attribute in [cat,dog] :   animal=set(animal.intersection(dict[attribute ]))//在第一次迭代中,animal 仍然是 [cat,dog]。

// 然而在第二次迭代中,set([cat,dog]intersection([cat])) 将只留下一个元素,即 cat

Related Posts

L1-L2正则化的不同系数

我想对网络的权重同时应用L1和L2正则化。然而,我找不…

使用scikit-learn的无监督方法将列表分类成不同组别,有没有办法?

我有一系列实例,每个实例都有一份列表,代表它所遵循的不…

f1_score metric in lightgbm

我想使用自定义指标f1_score来训练一个lgb模型…

通过相关系数矩阵进行特征选择

我在测试不同的算法时,如逻辑回归、高斯朴素贝叶斯、随机…

可以将机器学习库用于流式输入和输出吗?

已关闭。此问题需要更加聚焦。目前不接受回答。 想要改进…

在TensorFlow中,queue.dequeue_up_to()方法的用途是什么?

我对这个方法感到非常困惑,特别是当我发现这个令人费解的…

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注