| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 人工智能 -> 模拟退火的实现思路、搜索模型及其可视化 -> 正文阅读 |
|
[人工智能]模拟退火的实现思路、搜索模型及其可视化 |
模拟退火的实现思路、搜索模型及其可视化目录原理与特点模拟退火(Simulated Annealing) 是一种启发式的优化算法,可以针对较复杂的解析式实现快速搜索其最值,优化目标函数。算法的实现过程与金属的退火过程类似。 退火 是指将金属加热到一定温度直到液化再冷却下来的过程,在退火过程中原子按照局部能量最小化进行排列。在冶金学中常利用金属的退火进行原子重排,以得到韧性和硬度都更好的金属。1 模拟退火实质上是一种随机搜索算法,其核心在于温度这一变量。在退火初期温度较高时,目标函数的状态变量通过随机无序运动尽可能探索状态空间,寻找目标函数更优值,并一定概率接受更差状态以便于跳出局部最优解,而随着温度降低,探索幅度下降,状态变量趋于稳定。 模拟退火常常用于解当算法无法遍历整个状态空间去寻找目标函数的最优解时的问题,也就是组合爆炸(combination explosion) 的情况。这个时候可以采用贪心算法去快速寻找一个近似解,但同样也会有概率陷入局部最优解。模拟退火算法一方面能够通过随机搜索的方式节省算力,为NP复杂性问题提供有效的近似解。另一方面,也能实现通过温度这一变量实现尽可能广的探索,使得收敛结果能够跳出局部最优解。‘ 算法实现思路1.冷却过程在模拟退火中,温度作为一个全局变量使用。首先需要明确温度下降函数。(温度T减小的模型也称为冷却进度表) 温度的下降一般有几何冷却和线性冷却两种方式: 线性冷却T ′ = T ? α (1) T'=T-\alpha \tag{1} T′=T?α(1) 几何冷却T ′ = T α (2) T'=T\alpha \tag{2} T′=Tα(2) 其中
α
\alpha
α为0到1之间的数 退火代码总体框架
2.退火过程(1)选择起点也就是初始化自变量 x 0 x_0 x0? (2)与温度正相关的随机搜索随机搜索的幅度一般选择与温度线性相关,用公式表示如下
d
x
=
R
a
n
d
?
T
(3)
dx=Rand*T \tag{3}
dx=Rand?T(3) 其中 d x dx dx表示随机搜索的幅度, R a n d Rand Rand为使得 x n e w x_{new} xnew?生成在定义域范围内满足平均分布的随机数,可以设置为未生成在定义域内则重新生成,但算法往往会在生成规范的随机数上花一定的时间,降低了退火过程的效率,也可以通过设计搜索模型实现一次性生成满足要求的随机数。 随机搜索是模拟退火的关键,决定了最终解的精确度。其核心是: 满足在退火的前期随机搜索的程度较大使得尽可能搜索状态空间,优化目标函数并跳出局部最优解,而在退火的后期应该减小随机搜索程度使得自变量在最优解附近的空间搜索,使得解更加精确。 (3)接受更好的状态或以一定概率接受更坏的状态退火算法中,跳出局部最优解的核心在于利用Metropolis抽样法确定对新的状态的选择准则。当系统能量状态将要变化时,系统能量由E(n)变化到E(n+1)的概率为 r = e ? E ( n ) ? E ( n + 1 ) T , E ( n + 1 ) > E ( n ) (6) r=e^{-\frac{E(n)-E(n+1)}{T}} ,E(n+1)>E(n) \tag{6} r=e?TE(n)?E(n+1)?,E(n+1)>E(n)(6) 也就是系统状态向更有利的方向(能量更小)发展时,一定接受新的状态;如果向不利方向发展,则以一定概率(
e
?
E
(
n
)
?
E
(
n
+
1
)
T
e^{-\frac{E(n)-E(n+1)}{T}}
e?TE(n)?E(n+1)?)接受。 可以看出,温度影响了对新的状态接受概率,当温度较高时,可以接受较差情况的解,而当温度降低时,接收更差情况的解概率更小,以便于稳定当前解。 实例分析例如利用MATLAB求解函数
f
(
x
)
=
s
i
n
(
x
)
+
6
s
i
n
(
2
x
)
f(x)=sin(x)+6sin(2x)
f(x)=sin(x)+6sin(2x) 在(-3,3)之间的最大值。 以下的代码均为MATLAB代码格式 (1)初始化设置
(2)与温度正相关的随机搜索
这里有几种方法设计dx=f(T)的函数,此代码中所设计的函数为: T0 为初始温度,x 为当前的解,rand() 为(0,1)之间的随机数,T 为当前温度,K 为常数。 注:生成范围在(a,b)之间的随机数可以表示为 a + ( b ? a ) ? r a n d ( ) a+(b-a)*rand() a+(b?a)?rand()表示,例如 ? 3 ? x T 0 + 6 T 0 r a n d ( ) \frac{-3-x}{T_0}+\frac{6}{T_0}rand() T0??3?x?+T0?6?rand()表示生成在( ? 3 ? x T 0 , 3 ? x T 0 \frac{-3-x}{T_0},\frac{3-x}{T_0} T0??3?x?,T0?3?x?)之间的随机数,通过此方法生成的 d x dx dx有 x + d x x+dx x+dx满足定义域(-3,3)范围 此搜索模型可以一次性生成在定义域范围内的随机数,提高退火效率,也能控制搜索的衰减过程。 当然也可以利用重复生成与温度正相关的随机数,直到生成定义域范围的方法。代码如下:
(3)接受更好的状态或以一定概率接受更坏的状态如果随机搜索得到的新的自变量对应的目标函数 f ( x n e w ) f(x_{new}) f(xnew?)状态更优,则接受这个自变量作为当前解( x f i n a l x_{final} xfinal?),如果新的状态 f ( x n e w ) f(x_{new}) f(xnew?)更差则以一定概率接受。
(4)降温
完整代码
求解结果进行十次求解,得到的结果如下表所示。
实现较准确的结果(1)初始温度与终止温度通过设置较高的初始温度 T 0 T_0 T0?和尽可能接近0的终止温度提高搜索的精度。 (2)温度下降模型一般采用几何冷却的模型,也就是温度T按照指数函数规律下降,使得在搜索后期能够在精确解附近进行搜索。 (3)搜索模型关于随机搜索 d x = f ( T ) dx=f(T) dx=f(T)有几种模型可供参考: 3.1衰减可控模型
d
x
=
[
a
?
x
T
0
+
b
?
a
T
0
r
a
n
d
(
)
]
?
[
T
0
+
K
(
T
?
T
0
)
e
?
T
]
(8)
dx= [\frac{a-x}{T_0}+\frac{b-a}{T_0}rand()]*[T_0+K(T-T_0)e^{-T}] \tag{8}
dx=[T0?a?x?+T0?b?a?rand()]?[T0?+K(T?T0?)e?T](8) 可以通过控制参数 K K K实现对搜索范围衰减的控制。以下是在初始温度 T 0 = 12000 T_0=12000 T0?=12000、衰减率 d T = 0.01 dT=0.01 dT=0.01,终止温度为0.001时的测试结果。 1)当K=0.98时,随机运动的衰减程度较高,容易过早地收敛从而无法找到更精确的全局解。 2)当K=0.8时,能够实现退火前期充分搜索,后期在精确解附近搜索,从而准确收敛。
实例求解中采用此模型 2.线性相关模型d x = T ? R a n d (9) dx=T*Rand \tag{9} dx=T?Rand(9) 采用重复生成的方法,直到生成满足定义域的随机数。大小与温度线性相关,由于温度是指数衰减,也就是实际上无序运动按照指数规律衰减。
同样此模型会一定程度降低算法效率 d x = [ a ? x T 0 + b ? a T 0 r a n d ( ) ] ? T (10) dx= [\frac{a-x}{T_0}+\frac{b-a}{T_0}rand()]*T \tag{10} dx=[T0?a?x?+T0?b?a?rand()]?T(10) 虽然能够使得生成的随机数一次性满足定义域 ( a , b ) (a,b) (a,b),但通过收敛表可以看到搜索过程随着温度衰减而过早地衰减,以至于还没有搜索到精确解附近的状态空间时就已经陷入了局部最优解。因此不推荐此类模型。 模拟退火可视化实例:求解 f ( x ) = s i n ( x ) + 6 s i n ( 2 x ) f(x)=sin(x)+6sin(2x) f(x)=sin(x)+6sin(2x)在(-3,3)之间的最大值 求解过程如图所示: 可视化之前,需要对每个搜索过程的变量保存到工作区,最后统一画图。在画图脚本里,可以使用matlab命令hold on和hold off,使得每一帧图像只包含函数图像和当前解,之前的解不再出现。然后通过储存每一帧图像合成动图gif格式。具体可参考命令:help(imwrite)。 可视化代码:
当然,目标函数的自变量也可以拓展到二维,例如将
f
(
x
)
=
s
i
n
(
x
)
+
6
s
i
n
(
2
x
)
f(x)=sin(x)+6sin(2x)
f(x)=sin(x)+6sin(2x)绕Z轴旋转得到曲面,模拟退火求解过程类似,不再叙述。由于gif文件过大,这里不给出可视化。
|
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/10 15:57:58- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |