找遍百度也没有找到关于Beam Search的详细解释,只有一些比较泛泛的讲解,因而有了这篇博文。算法
首先给出wiki地址:http://en.wikipedia.org/wiki/Beam_search翻译
1.简介排序
Beam Search(集束搜索)是一种启发式图搜索算法,一般用在图的解空间比较大的状况下,为了减小搜索所占用的空间和时间,在每一步深度扩展的时候,剪掉一些质量比较差的结点,保留下一些质量较高的结点。这样减小了空间消耗,并提升了时间效率,但缺点就是有可能存在潜在的最佳方案被丢弃,所以Beam Search算法是不彻底的,通常用于解空间较大的系统中。ip
2.流程get
Beam Search(集束搜索)使用广度优先策略创建搜索树,在树的每一层,按照启发代价对节点进行排序,而后仅留下预先肯定的个数(Beam Width-集束宽度)的节点,仅这些节点在下一层次继续扩展,其余节点就被剪掉了。若是集束宽度无穷大,那该搜索就是宽度优先搜索。table
|
集束宽度能够是预先定好的,也能够是变更的,能够先按照一个最小的集束宽度进行搜索,若是没有找到合适的解,再扩大集束宽度再找一遍。效率
Ps. 我的认为集束搜索方法其实提供了一种找最优解的思路,就是说在适当的状况下,能够剪掉一些可信度低的路径,在实际使用中,能够每一层的集束宽度不一致,好比在初始的一些层次中多保留一些结果,在后边就能够放心大胆的进行剪枝。固然也能够活学活用,能够结合深度优先算法,经过回溯,能够找到最优解。百度
3.应用扩展
Beam Search(集束搜索)多用在一些大型系统中,好比机器翻译系统,语音识别系统等,由于这些系统中的数据集可能很是大,并且结果也没有惟一正确的解,系统用最快的方式找到最接近正确的解才是系统的目标。搜索