Beam Search(集束搜索/束搜索)

找遍百度也没有找到关于Beam Search的详细解释,只有一些比较泛泛的讲解,因而有了这篇博文。算法

首先给出wiki地址:http://en.wikipedia.org/wiki/Beam_search翻译

1.简介排序

Beam Search(集束搜索)是一种启发式图搜索算法,一般用在图的解空间比较大的状况下,为了减小搜索所占用的空间和时间,在每一步深度扩展的时候,剪掉一些质量比较差的结点,保留下一些质量较高的结点。这样减小了空间消耗,并提升了时间效率,但缺点就是有可能存在潜在的最佳方案被丢弃,所以Beam Search算法是不彻底的,通常用于解空间较大的系统中。ip

2.流程get

Beam Search(集束搜索)使用广度优先策略创建搜索树,在树的每一层,按照启发代价对节点进行排序,而后仅留下预先肯定的个数(Beam Width-集束宽度)的节点,仅这些节点在下一层次继续扩展,其余节点就被剪掉了。若是集束宽度无穷大,那该搜索就是宽度优先搜索。table

  • 将初始节点插入到list中,
  • 将给节点出堆,若是该节点是目标节点,则算法结束;
  • 不然扩展该节点,取集束宽度的节点入堆。而后到第二步继续循环。
  • 算法结束的条件是找到最优解或者堆为空。

 

集束宽度能够是预先定好的,也能够是变更的,能够先按照一个最小的集束宽度进行搜索,若是没有找到合适的解,再扩大集束宽度再找一遍。效率

Ps. 我的认为集束搜索方法其实提供了一种找最优解的思路,就是说在适当的状况下,能够剪掉一些可信度低的路径,在实际使用中,能够每一层的集束宽度不一致,好比在初始的一些层次中多保留一些结果,在后边就能够放心大胆的进行剪枝。固然也能够活学活用,能够结合深度优先算法,经过回溯,能够找到最优解。百度

3.应用扩展

Beam Search(集束搜索)多用在一些大型系统中,好比机器翻译系统,语音识别系统等,由于这些系统中的数据集可能很是大,并且结果也没有惟一正确的解,系统用最快的方式找到最接近正确的解才是系统的目标。搜索

相关文章
相关标签/搜索