search - 模拟退火算法中探索和利用的区别
问题描述
在进化算法中,维持了两个主要能力,即探索和开发。
在探索中,算法在新区域中寻找新的解决方案,而开发意味着使用已经存在的解决方案并对其进行细化,以提高其适应度。
在模拟退火中,我不明白什么时候Exploration
发生Exploitation
。
例如在遗传算法中:Exploration
发生在Crossover
和Mutation
步骤中,而选择发生在Exploitation
步骤中。
解决方案
我从未见过这些术语Exploration
以及Exploration
与模拟退火 (SA) 的关系。这是因为没有真正形成一棵树,只有来自当前状态的一长串提案,并且可能接受一个状态。所以这个结构更像是一把长长的梳子,而不是一棵树,每颗牙齿都是一个有可能被接受的提议状态。
所以请记住,在 SA 上应用这些术语并不常见 - 但无论如何我都会尝试使用这些术语通常适用于使用树状结构搜索的算法的评论。
你可以——如果你真的想——将条款投射到模拟退火上——比探索/开发在每一步都发生,但在开始时,SA 被允许更疯狂地探索,因为温度仍然很高——因此它几乎可以接受每一个状态。您可以将 SA 的早期阶段称为更多探索。随着温度的降低,它不太可能接受具有较高能量/目标的状态,但仍然接受所有导致较低能量/目标的状态,您可以称之为Exploration
相位。
推荐阅读
- oauth - (重新)使用 Google 访问令牌而不是每次都要求一个新令牌的动机是什么?
- javascript - 如何在不使用 z-index 的情况下制作滑出导航
- ios - 使用 Alamofire responseImage IOS swift 从 URLRequest 加载图像
- javascript - Spotify API - 在 Google Apps 脚本中检索有效的访问令牌
- vba - 出现错误“ActiveX 组件在与 CMS 主管连接时无法创建对象
- android - 通过相同的登录屏幕为android应用程序中的不同登录用户提供不同的功能
- c# - Linq 与 Dynamics CRM,如何处理 null ?你调用的对象是空的
- c# - LDAP 在不同的 OU 中创建两个用户名相同的用户
- android - Android Studio 构建无法删除路径
- javascript - 在javascript中选择一些元素怎么样?