均匀成本搜索和最佳优先搜索方法之间有什么区别?

这两种方法都有一个数据结构,用于保存待扩展的节点(及其成本)。两种方法首先扩展成本最优的节点。那么,它们之间有什么区别呢?

我被告知均匀成本搜索是一种盲目方法,而最佳优先搜索不是,这让我更加困惑(它们是否都有关于节点成本的信息?)。


回答:

区别在于启发式函数。

均匀成本搜索是一种无信息搜索:它不使用任何领域知识。它扩展成本最低的节点,并且在各个方向上进行扩展,因为没有提供关于目标的信息。它可以被视为一个函数f(n) = g(n),其中g(n)是路径成本(“路径成本”本身是一个函数,根据性能度量为路径分配一个数值成本,例如公里数的距离,或移动的次数等)。它仅仅是到达节点n的成本。

最佳优先搜索是一种有信息搜索:它使用启发式函数来估计当前状态与目标的接近程度(我们是否接近目标?)。因此,我们的成本函数f(n) = g(n)与从n到目标的成本相结合,即h(n)(估计该成本的启发式函数),给我们f(n) = g(n) + h(n)。最佳优先搜索算法的一个例子是A*算法。

是的,这两种方法都有一个扩展节点的列表,但最佳优先搜索会试图最小化扩展节点的数量(路径成本 + 启发式函数)。

Related Posts

Keras Dense层输入未被展平

这是我的测试代码: from keras import…

无法将分类变量输入随机森林

我有10个分类变量和3个数值变量。我在分割后直接将它们…

如何在Keras中对每个输出应用Sigmoid函数?

这是我代码的一部分。 model = Sequenti…

如何选择类概率的最佳阈值?

我的神经网络输出是一个用于多标签分类的预测类概率表: …

在Keras中使用深度学习得到不同的结果

我按照一个教程使用Keras中的深度神经网络进行文本分…

‘MatMul’操作的输入’b’类型为float32,与参数’a’的类型float64不匹配

我写了一个简单的TensorFlow代码,但不断遇到T…

发表回复

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