当前位置: 首页 > news >正文

智能计算方法与实现2|模拟退火算法原理|工具箱及其应用

模拟退火算法原理

模拟退火算法

模拟退火算法(SimulatedAnnealing,SA)最早的思想是由N.Metropolis等人于1953年提出。
1983年,S.Kirkpatrick等成功地将退火思想引l入到组合优化领域
它是基于Monte-Carlo送代求解策略的一种随机寻优算法,其出发点是基于物理中固体物质的退火过程与一般组合优化问题之间的相似性

模拟退火算法从某一较高初温出发,伴随温度参数的不断下降,结合概率突跳特性在解空间中随机寻找目标函数的全局最优解,即在局部最优解能概率性地跳出并最终趋于全局最优。
模拟退火算法是一种通用的优化算法,理论上算法具有概率的全局优化性能,自前已在工程中得到了广泛应用,诸如VLSI、生产调度、控制工程、机器学习、神经网络、信号处理等领域

模拟退火算法是通过赋予搜索过程一种时变且最终趋于零的概率突跳性,从而可有效避免陷入局部极小并最终趋于全局最优的串行结构的优化算法

模拟退火核心思想

模拟退火算法从某一较高初温出发,伴随温度参数的不断下降,结合一定的概率突跳特性在解空间中随机寻找目标函数的全局最优解,即在局部最优解能概率性地跳出并最终趋于全局最优。
这里的”一定的概率”的计算参考了金属冶炼的退火过程,这也是模拟退火算法名称的由来。将温度T当作控制参数,目标函数值f视为内能E,而固体在某温度T时的一个状态对应一个解,然后算法试图随着控制参数T的降低,使目标函数f(内能E)也逐渐降低,直至趋于全局最小值(退火中低温时的最低能量状态),就像金属退火过程一样。

模拟退火数学原理

从上面我们知道,会结合概率突跳特性在解空间中随机寻找目标函数的全局最优解,那么具体的更新解的机制是什么呢?如果新解比当前解更优,则接受新解,否则基于Metropolis准则判断是否接受新解。
接受概率为:
P = { 1 , E t + 1 < E t e − ( E t + 1 − E t ) k T , E t + 1 ≥ E t P=\left\{\begin{matrix} 1,\qquad E_{t+1}<E_{t} \\ e^{\frac{-(E_{t+1}-E_{t})}{kT}},E_{t+1}\ge E_{t} \end{matrix}\right. P={1,Et+1<EtekT(Et+1Et),Et+1Et
如上公式,假设当前时刻搜索的解为 x t x_{t} xt,对应的系统能量(目标函数)为 E t E_{t} Et,对搜索点施加随机扰动,产生新解 x t + 1 x_{t+1} xt+1,相应地,系统能量为 E t + 1 E_{t+1} Et+1,那么系统对搜索点从 x t x_{t} xt x t + 1 x_{t+1} xt+1转变的接受概率就为上公式
![[Pasted image 20240829210414.png]]

假设开始状态在A,随着送代次数更新到B局部最优解,这时发现更新到B时,能量比A要低,则说明接近最优解了,因此百分百转移,状态到达B后,发现下一步能量上升了,如果是梯度下降则是不充许继续向前的,而这里会以一定的概率跳出这个坑,这个概率和当前的状态、能量等都有关系,如果B最终跳出来了到达C,又会继续以一定的概率跳出来,直到到达D后,就会稳定下来。

模拟退火流程

算法实质分两层循环,在任一温度水平下,随机扰动产生新解,并计算目标函数值的变化,决定是否被接受。由于算法初始温度比较高,这样,使E增大的新解在初始时也可能被接受,因而能跳出局部极小值,然后通过缓慢地降低温度,算法就最终可能收敛到全局最优解,具体流程为:

  1. T = T 0 T=T_{0} T=T0,表示开始退火的初始温度,随机产生一个初始解 x 0 x_{0} x0,并计算对应的目标函数值 E ( x 0 ) E(x_{0}) E(x0)
  2. T = k T T=kT T=kT,其中 k k k取值0到1之间,为温度下降速率;
  3. 对当前解x施加随机扰动,在其邻域内产生一个新解 x t + 1 x_{t+1} xt+1,并计算对应的目标函数值 E ( x t + 1 ) E(x_{t+1}) E(xt+1),计算
    Δ E = E ( x t + 1 ) − E ( x t ) \Delta E=E(x_{t+1})-E(x_{t}) ΔE=E(xt+1)E(xt)
  4. Δ E < 0 \Delta E<0 ΔE<0,接受新解作为当前解,否则按照概率 e − Δ E / k T e^{-\Delta E/kT} eΔE/kT判断是否接受新解;
  5. 在温度T下,重复L次扰动和接受过程,即执行步骤3和4;
  6. 判断温度是否达到终止温度水平,若是则终止算法,否则返回步骤2.
    ![[Pasted image 20240829211706.png]]

其中有几个需要注意的点:

  1. 初始点的选取对算法结果有一定的影响,最好是多次运行对结果进行综合判断
  2. 在算法运行初期,温度下降快,避免接受过多的差结果。当运行时间增加,温度下降减缓,以便于更快稳定结果。
  3. 当送代次数增加到一定次数时,结果可能已经达到稳定,但是距离算法结束还有一段时间。在设计程序时应该加入适当的输出条件,满足输出条件即可结束程序。
模拟退火算法求解TSP

![[Pasted image 20240829211907.png]]

clc; 
clear; 
close all;
%% 
tic
T0 = 1000; %初始温度 
Tend = 1e-3; %终止温度
L = 500; %各温度下的迭代次数(链长)
q = 0.9; %降温速率%%加载数据
load CityPosition;
%%
D = Distanse(X); %计算距离矩阵
N = size(D,1); %城市的个数
%%初始解
S1 = randperm(N); %随机产生一个初始路线%%画出随机解的路径图
DrawPath(S1,x) 
pause(0.0001)
%%输出随机解的路径和总距离 
disp('初始种群中的一个随机值:') 
OutputPath(S1);
Rlength = athLength(D,S1);
disp(['总距离:', num2str(Rlength)])%%计算迭代的次数Time
Time = ceil(exp(log(T0/Tend)/log(q))); 
count=0; %迭代计数
Obj = zeros(Time,1); %目标值矩阵初始化
track = zeros(Time,N); %每代的最优路线矩阵初始化%%迭代
while T0 > Tendcount = count + 1; %更新迭代次数temp = zeros(L, N+1); for k = 1:L%%产生新解S2 = NewAnswer(S1);%%Metropolis法则判断是否接受新解[S1, R] = Metropolis(S1, S2, D, T0);%Metropolis抽样算法temp(k,:) = [S1R]; %记录下一路线的及其路程 end%%记录每次迭代过程的最优路线[d0, index] = min(temp(:end)); %找出当前温度下最优路线 if count == 1 || d0 < Obj(count-1)obj(count) = d0;%如果当前温度下最优路程小于上一路程则记录当前路程 elseObj(count) = Obj(count-1); %如果当前温度下最优路程大于上一路程则记录上一路程 endtrack(count,:) = temp(index,1:end-1); %记录当前温度的最优路线 T0 = q * T0; %降温fprintf(1, '%d\n', count) %输出当前迭代次数
end
functionS2 = NewAnswer(S1)
%%输入
%S1:当前解
%%输出%S2:新解
N = length(S1); 
S2 = S1;
a = round(rand(1,2)*(N-1)+1);%产生两个随机位置用来交换 
W = S2(a(1));
S2(a(1)) = S2(a(2));
S2(a(2)) = W; %得到一个新路线
%%优化过程迭代图 
figure
plot(1: count, Obj) 
xlabel('迭代次数')
ylabel('距离') 
title('优化过程')%%最优解的路径图
DrawPath(track(end, :), X)%%输出最优解的路线和总距离
disp('最优解:')
S = track(end, :); 
p = OutputPath(S);
disp([总距离:num2str(PathLength(D,S)]);
disp('----------------------------------------------') 
toc

![[Pasted image 20240829213446.png]]

模拟退火算法工具箱及其应用

模拟退火算法工具箱

Matlab的Global OptimizationToolbox中集成了模拟退火算法,为了表示方便,我们称为模拟退火算法工具箱(SAT)。
它位于Matlab安装目录

\toolbox\globaloptim\globaloptim


![[Pasted image 20240829214056.png]]

下界,上界
[x, fval] = simulannealbnd(objectiveFunction, X0, lb, ub, options)
  • x,最优解,
  • fval,最优值
  • simulannealbnd,主函数
  • ObjectiveFunction,目标函数
  • x0,初始解
  • options,参数集
    参数设置
    options = saoptimset( …
    ‘Maxlter’,500,…%最大送代次数
    ‘StalllterLim’,500,…%算法终止条件’TolFun’,1e-100,…%适应度函数值偏差
    ‘AnnealingFcn’,@annealingfast, …%退火函数
    ‘Initial Temperature’, 100,…%初始温度
    ‘TemperatureFcn’,@temperatureexp,…%指数降温
    'Reanneallnterval,500,…%与Maxlter相同,表示不进行回火处理
'PlotFcns',{@saplotbestx, @saplotbestf, @saplotx, @saplotf,@saplottemperature);

PlotFcns,绘图函数
saplotbestx,最优解
saplotbestf,最优值
saplotx,解x
saplotf,x对应函数值
saplottemprature,温度

f ( x 1 , x 2 ) = 20 + x 1 2 + x 2 2 − 10 ( cos ⁡ 2 π x 1 + cos ⁡ 2 π x 2 ) f(x_{1},x_{2})=20+x_{1}^{2}+x_{2}^{2}-10(\cos 2\pi x_{1}+\cos 2\pi x_{2}) f(x1,x2)=20+x12+x2210(cos2πx1+cos2πx2)
− 1 ≤ x i ≤ 1 , i = 1 , 2 -1\le x_{i}\le 1,\ i=1,2 1xi1, i=1,2

![[Pasted image 20240829215759.png]]

clear 
clcObjectiveFunction = @Rastrigin; % Function handle to the objective function 
X0 = [0.5 0.5]; %Starting point
lb = [-1 -1]; %Lowerbound 
ub = [1 1]; %Upperboundoptions = saoptimset(...
'Maxlter', 500,...
'StalllterLim', 500,...
'TolFun', 1e-100,...
'AnnealingFcn', @annealingfast,...
'InitialTemperature', 100,...
'TemperatureFcn', @temperatureexp,...
'Reanneallnterval', 5o0,...
'PlotFcns',{@saplotbestx, @saplotbestf, @saplotx, @saplotf, @saplottemperature});[x, fval] = simulannealbnd(ObjectiveFunction, x0, lb, ub, options)
x = 1.0e-04 * -0.1839    -0.2334
fval = 1.7517e-07

![[Pasted image 20240903082810.png]]

SAT求解压力容器设计问题

![[Pasted image 20240903083743.png]]

clear 
clcObjectiveFunction = @fitnessFunction; %Function handleto theobjective function
X0 = [50504545]; %Startingpoint 
lb = [001010]; %Lowerbound
ub = [100100100100]; %Upperbound
options = saoptimset(...
'Maxlter',500,...
'StalllterLim',500,...
'TolFun', 1e-100,...
'AnnealingFcn', @annealingfast,...
'InitialTemperature',100,...
'TemperatureFcn', @temperatureexp,...
'Reanneallnterval',5o0,...
'PlotFcns',{@saplotbestx, @saplotbestf, @saplotx, @saplotf, @saplottemperature})[x,fval]= simulannealbnd(ObjectiveFunction, X0, lb, ub, options)

![[Pasted image 20240904221716.png]]

x = 1.8048  0.8919  93.4926  33.6489
fval = 2.3785e+04

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 斯洛文尼亚秋季徒步旅游 | 领略最美秋色!
  • 随身WiFi实测,真相让你大跌眼镜!随身携带的随身wifi哪个比较好?什么品牌的随身wifi好用?
  • 高级编程--第四章 输入和输出处理
  • PhpStorm 中配置调试功能的详尽指南
  • pyenv -- 一款macos下开源的多版本python环境安装管理工具 国内加速版安装 + 项目venv虚拟环境 pip加速 使用与总结
  • React学习-hooks
  • 【多线程】概述
  • 安全检查报告模板
  • 用c写一个谁考了第k名
  • Maptr
  • 2024数博会技术成果回顾 | KPaaS助力企业数智化转型
  • .net通过类组装数据转换为json并且传递给对方接口
  • 基于Spring和MybatisPlus下的Oracle转mysql语句语法适配修改
  • 使用Aqua进行WebUI测试(Pytest)——介绍篇(附汉化教程)
  • 合并区间【leetcode】
  • canvas 五子棋游戏
  • gitlab-ci配置详解(一)
  • HTTP那些事
  • JavaScript 无符号位移运算符 三个大于号 的使用方法
  • Java读取Properties文件的六种方法
  • log4j2输出到kafka
  • PaddlePaddle-GitHub的正确打开姿势
  • Vultr 教程目录
  • 阿里云ubuntu14.04 Nginx反向代理Nodejs
  • 多线程 start 和 run 方法到底有什么区别?
  • 翻译--Thinking in React
  • 工作踩坑系列——https访问遇到“已阻止载入混合活动内容”
  • 今年的LC3大会没了?
  • 手写一个CommonJS打包工具(一)
  • 微服务核心架构梳理
  • 用quicker-worker.js轻松跑一个大数据遍历
  • “十年磨一剑”--有赞的HBase平台实践和应用之路 ...
  • 如何用纯 CSS 创作一个菱形 loader 动画
  • 说说我为什么看好Spring Cloud Alibaba
  • ​字​节​一​面​
  • # SpringBoot 如何让指定的Bean先加载
  • #DBA杂记1
  • #基础#使用Jupyter进行Notebook的转换 .ipynb文件导出为.md文件
  • (2024,Flag-DiT,文本引导的多模态生成,SR,统一的标记化,RoPE、RMSNorm 和流匹配)Lumina-T2X
  • (python)数据结构---字典
  • (层次遍历)104. 二叉树的最大深度
  • (附源码)计算机毕业设计ssm基于B_S的汽车售后服务管理系统
  • (附源码)计算机毕业设计SSM教师教学质量评价系统
  • **Java有哪些悲观锁的实现_乐观锁、悲观锁、Redis分布式锁和Zookeeper分布式锁的实现以及流程原理...
  • .net dataexcel winform控件 更新 日志
  • .net 获取url的方法
  • .Net 中的反射(动态创建类型实例) - Part.4(转自http://www.tracefact.net/CLR-and-Framework/Reflection-Part4.aspx)...
  • .NET/C# 使窗口永不获得焦点
  • .NET6实现破解Modbus poll点表配置文件
  • .NetCore部署微服务(二)
  • .net安装_还在用第三方安装.NET?Win10自带.NET3.5安装
  • @hook扩展分析
  • @JsonFormat 和 @DateTimeFormat 的区别
  • @RequestMapping用法详解
  • [20160902]rm -rf的惨案.txt