搜索技术——模拟退火算法

news2024/12/28 20:59:12

如果有兴趣了解更多相关内容,欢迎来我的个人网站看看:瞳孔空间

一:算法及模型

物理退火过程

什么是退火:是指将固体加热到足够高的温度,使分子呈随机排列状态,然后逐步降温使之冷却,最后分子以低能状态排列,固体达到某种稳定状态。

物理退火过程:

  • 加温过程:增强粒子的热运动,消除系统原先可能存在的非均匀态
  • 等温过程:对于与环境换热而温度不变的封闭系统,系统状态的自发变化总是朝自由能减少的方向进行,当自由能达到最小时,系统达到平衡态
  • 冷却过程:使粒子热运动减弱并渐趋有序,系统能量逐渐下降,从而得到低能的晶体结构

温度越低,物体的能量状态越低,到达足够的低点时,液体开始冷凝与结晶,在结晶状态时,系统的能量状态最低。

  • 缓慢降温(退火,annealing)时,可达到最低能量状态
  • 快速降温(淬火,quenching)时,会导致不是最低能态的非晶形

数学表述:在温度T,分子停留在状态r满足Boltzmann概率分布
在这里插入图片描述

在同一个温度T,选定两个能量E1<E2,有:
在这里插入图片描述

Boltzmann概率分布告诉我们:

  • 在同一个温度,分子停留在能量小的状态的概率大于停留在能量大的状态的概率
  • 温度越高,不同能量状态对应的概率相差越小;温度足够高时,各状态对应概率基本相同
  • 随着温度的下降,能量最低状态对应概率越来越大;温度趋于0时,其状态趋于1

模拟退火算法

模拟退火算法最早的思想由Metropolis等(1953)提出,1983年Kirkpatrick等将其应用于组合优化。是模仿自然界退火现象而得,利用了物理中固体物质的退火过程与一般优化问题的相似性,从某一初始温度开始,伴随温度的不断下降,结合概率突跳特性在解空间中随机寻找全局最优解。

介绍模拟退火前,需要先介绍爬山算法。爬山算法是一种简单的贪心搜索算法,该算法每次从当前解的临近解空间中选择一个最优解作为当前解,直到达到一个局部最优解。
在这里插入图片描述
爬山算法实现很简单,其主要缺点是会陷入局部最优解,而不一定能搜索到全局最优解。如上图所示:假设从当前解出发,爬山算法搜索到这个局部最优解就会停止搜索,因为在局部最优解位置无论向那个方向小幅度移动都不能得到更优的解。

而模拟退火算法从某一较高初温出发,伴随温度参数的不断下降,结合一定的概率突跳特性在解空间中随机寻找目标函数的全局最优解,即在局部最优解能概率性地跳出并最终趋于全局最优。如下:

e23b45cc-2379-11eb-905e

关于爬山算法与模拟退火,有一个有趣的比喻:

  • 爬山算法:兔子朝着比现在高的地方跳去。它找到了不远处的最高山峰。但是这座山不一定是珠穆朗玛峰。这就是爬山算法,它不能保证局部最优值就是全局最优值。
  • 模拟退火:兔子喝醉了。它随机地跳了很长时间。这期间,它可能走向高处,也可能踏入平地。但是,它渐渐清醒了并朝最高方向跳去。这就是模拟退火。

退火算法的基本思想:在一定温度下,搜索从一个状态随机地变化到另一个状态;随着温度的不断下降直到最低温度,搜索过程以概率1停留在最优解。

  • 将温度T当作控制参数
  • 目标函数值f视为内能E
  • 固体在某温度T时的一个状态对应一个解
  • 算法试图随着控制参数T的降低,使目标函数f(内能E)也逐渐降低,直至趋于全局最小值(退火中低温时的最低能量状态),就像金属退火过程一样

算法的目的

  • 解决NP复杂性问题
  • 克服优化过程陷入局部极小
  • 克服初值依赖性

Metropolis准则(1953)——以概率接受新状态:固体在恒定温度下达到热平衡的过程可以用Monte Carlo方法(计算机随机模拟方法)加以模拟,虽然该方法简单,但必须大量采样才能得到比较精确的结果,计算量很大。
在这里插入图片描述
在这里插入图片描述

组合优化与物理退火的相似性比较:
在这里插入图片描述

模拟退火算法的基本步骤:在这里插入图片描述

代码表示:
在这里插入图片描述
文字表述:
在这里插入图片描述

二:应用实例

集成电路设计:利用模拟退火算法进行超大规模集成电路的最优设计,是目前模拟退火算法最成功的应用实例之一。用模拟退火算法几乎可以很好地完成所有优化的VLSI设计工作。如全局布线、布板、布局和逻辑最小化等。

图像处理中的应用:模拟退火算法可用来进行图像恢复等工作,即把一幅被污染的图像重新恢复成清晰的原图,滤掉其中被畸变的部分。因此它在图像处理方面的应用前景是广阔的。

神经网计算机中的应用:模拟退火算法具有跳出局部最优陷阱的能力。在Boltzmann机中,即使系统落入了局部最优的陷阱,经过一段时间后,它还能再跳出来,系统最终将往全局最优值的方向收敛

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/54518.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SPECjvm 2008 小记

背景 specjvm2008是免费的&#xff0c;直接官网下载就可以开跑了。但俗话说的好&#xff0c;便宜无好货&#xff0c;没啥厂家买账&#xff0c;看官网列出的成绩公示结果&#xff0c;根本没几家上传成绩。 另外&#xff0c;SPECjvm2008本身是测试JRE的执行成绩&#xff0c;也就…

Android databinding之RecycleView使用与介绍(二)

一 、介绍 通过上一篇databinding接入&#xff0c;我们已大概了解到databinding接入的流程和数据的简单绑定。 如果你刚看这边&#xff0c;并不了解databinding的使用&#xff0c;可以查看&#xff1a;Android databinding的接入使用与详解(一) Activity和fragment的数据绑定…

左(6)hash,大数据,位运算

前言 仅记录学习笔记&#xff0c;如有错误欢迎指正。 一、哈希函数和哈希表&#xff1a; hash()&#xff1a; (1) 输入是无限的&#xff0c;输出有限&#xff01; (2)相同的输入&#xff0c;相同的输出&#xff08;无随机因子&#xff09; (3)不同的输入&#xff0c;也可能相…

jQuery 语法

通过 jQuery&#xff0c;您可以选取&#xff08;查询&#xff0c;query&#xff09; HTML 元素&#xff0c;并对它们执行"操作"&#xff08;actions&#xff09;。 jQuery 语法 jQuery 语法是通过选取 HTML 元素&#xff0c;并对选取的元素执行某些操作。 基础语法…

【Python教学】pyqt6入门到入土系列,超详细教学讲解

一、什么是PyQt6? 简单介绍一下PyQt6 1、基础简介 PyQt6 Digia 公司的 Qt 程序的 Python 中间件。Qt库是最强大的GUI库之一。PyQt6的官网&#xff1a;www.riverbankcomputing.co.uk/news。PyQt6是由Riverbank Computing公司开发的 资料大礼包点击蓝色字体领取 Python零基础…

机器学习6scikit-learn中的scaler

文章目录一、scikit-learn中的scaler对测试数据集如何归一化&#xff1f;测试数据是模拟真实环境&#xff1a;综上二、演示一、scikit-learn中的scaler 对测试数据集如何归一化&#xff1f; 测试数据集不能跟训练数据集归一化一样&#xff0c;应该把测试数据集与训练数据集归…

Java JDK 环境变量配置教程

文章目录Java JDK 环境变量配置JDK 11 环境变量配置详细步骤Java JDK 环境变量配置 环境变量&#xff08;environment variables&#xff09;一般是指在操作系统中用来指定操作系统运行环境的一些参数&#xff0c;如&#xff1a;临时文件夹位置和系统文件夹位置等。 环境变量…

第二证券|抖音发布三季度安全透明度报告,整治贩卖焦虑广告近3万条

近来&#xff0c;抖音发布《2022年第三季度安全透明度陈述》(以下简称《陈述》)。《陈述》显现经过要点整治&#xff0c;渠道不标准表达削减超越30%&#xff0c;不实信息被告发量同比下降36.7%&#xff0c;整治贩卖焦虑广告2.9万条。一起&#xff0c;抖音还更新了《社区自律条约…

关于我对线程安全问题中死锁的理解

文章目录1.什么是死锁2.三个典型情况3.可重入与不可重入4.死锁的四个必要条件5.如何破除死锁1.什么是死锁 比如张三谈了一个女朋友&#xff0c;张三就对这个女朋友加锁了。 此时李四也看上了这个女生&#xff0c;但是他只能等待张三分手&#xff08;解锁&#xff09;后&#xf…

[附源码]计算机毕业设计保护濒危动物公益网站Springboot程序

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

赋能千百行加快 “5G+工业互联网”落地深耕

目前&#xff0c;我国5G基站已达196.8万个&#xff0c;“5G工业互联网”建设项目3100个&#xff0c;5G与工业互联网融合应用深入工业设计、制造、管理、服务等各环节&#xff0c;在促进传统企业提质降本增效的同时&#xff0c;不断拓展信息通信产业新蓝海。 记者从工信部获悉&a…

Nginx部署Vue前端项目

系统环境&#xff1a;Mac Pro—10.15.7版本 Nginx版本&#xff1a;1.19.6 一、安装Nginx brew install nginx 1、安装完成 Nginx的配置文件目录&#xff1a;/usr/local/etc/nginx Nginx的安装目录&#xff1a;/usr/local/Cellar/nginx 2、启动Nginx brew services star…

Linux虚拟机共享文件夹不显示问题终极解决方法

打开共享文件夹处查看一下&#xff0c;我的结果如下图&#xff08;没有显示共享文件内容&#xff09;&#xff1a; 接着打开终端&#xff1a; 输入命令&#xff1a;没有共享目录显示 解决方法&#xff1a; 输入&#xff1a;sudo apt-get install open-vm-tools 等待安装完 …

音乐在线教育解决方案,打造在线教育高品质教学体验

音乐是一种在时间中流动的形态&#xff0c;有节奏的音乐&#xff0c;能给人带来心理的快乐和艺术的享受&#xff0c;学一门乐器成为了很多人的选择。因此&#xff0c;音乐教育培训机构在搭建线上音乐课程时&#xff0c;就需要选择低延时、高同步、画质还原、高保真的技术方案&a…

基于轻量级CNN的12306验证码识别分析系统

在我很早的一篇文章中有写过图标型验证码识别的实践项目&#xff0c;这里主要是基于以往的实践经历做出的技术升级&#xff0c;包括&#xff1a;模型轻量化、界面开发、Grad-CAM热力图集成等。 话不多说&#xff0c;首先看效果&#xff1a; 基于CNN的轻量级12306验证码识别分析…

用Python预测世界杯球赛结果,还别说准确度还是蛮高的

前言 那么四年一度的世界杯即将要在卡塔尔开幕了&#xff0c;对于不少热爱足球运动的球迷来说&#xff0c;这可是十分难得的盛宴&#xff0c;而对于最后大力神杯的归属&#xff0c;相信很多人都满怀着期待&#xff0c;每个人心中都有不同的答案。 今天我就通过Python数据分析…

Word控件Spire.Doc 【图像形状】教程(10): 如何在C#中重置word文档的形状大小

Spire.Doc for .NET是一款专门对 Word 文档进行操作的 .NET 类库。在于帮助开发人员无需安装 Microsoft Word情况下&#xff0c;轻松快捷高效地创建、编辑、转换和打印 Microsoft Word 文档。拥有近10年专业开发经验Spire系列办公文档开发工具&#xff0c;专注于创建、编辑、转…

SEO优化之扁平化目录结构PbootCMS

在网站内部优化中&#xff0c;扁平化的目录结构对于一个网站来讲是非常有意义的。我们经常看到一些网站结构混乱&#xff0c;搞的你都不知道哪里是哪里了。而有的网站结构非常清晰&#xff0c;这样用户喜欢&#xff0c;搜索引擎也喜欢。而PbootCMS 2.0开始&#xff0c;系统也默…

2022,开发转测试,会不会后悔?

每个人做任何选择都是趋利避害的&#xff0c;当选择了认为对自己更有利的选择后&#xff0c;发现结果和期望不符&#xff0c;甚至发现大失所望&#xff0c;才会出现后悔的情绪。 那么为什么开发转测试就会后悔呢&#xff0c;只有一个原因&#xff1a; 那就是转到测试行业后&a…

PIL+pyplot+transforms.ToTensor+unsqueeze+div

目录PIL & pyplottransforms.ToTensortorch.unsqueeze(input,dim,outNone)torch.squeeze(input, dimNone, outNone)torch.divPIL & pyplot from PIL import Image import matplotlib.pyplot as plt from torchvision import transforms# PIL打开图片 img_PIL Image.o…