我正在审查Dorigo & Gambardella (1997)关于蚁群系统 (ACS) 的论文。信息素更新规则有两种:局部更新和全局更新。但是,我并不清楚每个应该如何应用。
本地更新
据我所知,有3个选项:
- 更新为蚂蚁建立一个旅游,即移动到一个新的城市之后。(正如第 56 页的文字所建议的那样)
- 在一只蚂蚁建立游览后更新,在下一只蚂蚁开始之前。(如第 55 页图 3 所示)
- 在所有蚂蚁都建立了游览之后更新。(如附录 A 中指定的那样,将使该算法像它声称的那样最可并行化)。
哪个选项是预期的?
全局更新
从文本(等式 4,第 56 页)和附录中也不清楚更新规则的信息素蒸发部分是否适用于所有边缘或仅适用于全球最佳游览上的边缘。
在全局更新规则下,所有边都会蒸发吗?
编辑
从那以后,我发现这个GitHub 存储库似乎包含 Dorigo 的原始代码,其中似乎发生了以下规则:
- 当每只蚂蚁过渡到一个新城市时,本地更新(蒸发+沉积)(即上面的选项1)。
- 所有边缘的全球蒸发(或仅在设置某些标志的情况下关闭城市)。
- 仅沿全球最佳巡回赛进行全球更新(蒸发+沉积)。
这更令人困惑,因为它表明正在发生双重(甚至三重)蒸发。