scikit-opt几种数值模拟退火的代码示例,和参数详解,以及基础模拟退火的原理代码示例

本文主要是介绍scikit-opt几种数值模拟退火的代码示例,和参数详解,以及基础模拟退火的原理代码示例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

python基础模拟退火原理示例

模拟退火的特性决定了一般可以用于算法的调参,相比较遗传算法来说,普遍更快一些,但是也更容易陷入局部最优。相对来说,遗传算法的更新解机制是在最每一个局部最优解附近盘旋游荡,则更容易达到全局最优,但是计算量则更大。

# -*- encoding: utf-8 -*-
'''
@File    :   simulate_anneal.py
@Time    :   2020/10/28 12:45:28
@Author  :   DataMagician 
@Version :   1.0
@Contact :   408903228@qq.com
'''# here put the import libimport numpy as np
import matplotlib.pyplot as plt# ### $ 根据热力学的原理,在温度为T时,出现能量差为dE的降温的概率为P(dE),表示为:$
# # $ P(dE) = exp( dE/(k*T) ) $
# ### $ 其中k是一个常数,exp表示自然指数,且dE<0(温度总是降低的)。这条公式指明了 $# # 单变量退火
def PDE(DE, T, k=1):'''Args:DE:t:k:Returns:'''return np.exp((DE) / (k * T))def DE_function(new, old):'''Args:new:old:Returns:'''return new - olddef jump(DE, T, k=1):'''Args:DE:T:k:Returns:'''return PDE(DE, T, k) > np.random.rand() and 0 or 1def simulate_anneal(func,parameter={"T": 1, #系统的温度,系统初始应该要处于一个高温的状态 初始温度越高,且马尔科夫链越长,算法搜索越充分,得到全局最优解的可能性越大,但这也意味着需要耗费更多的计算时间"T_min": 0, #温度的下限,若温度T达到T_min,则停止搜索"r": 0.0001, #用于控制降温的快慢 值越小T更新越快,退出越快"expr": 0, #初始解"jump_max": np.inf,#最大回炉停留次数"k":1 # k越小越不容易退出}):'''Args:func:parameter:Returns:'''path, funcpath = [], []T = parameter["T"]  # 系统温度,初时应在高温T_min = parameter["T_min"]  # 最小温度值r = parameter["r"]  # 降温速率counter = 0expr = parameter["expr"]  # 假设初解jump_max = parameter["jump_max"]  # 最大冷却值jump_counter = 0k = parameter["k"]while T > T_min:counter += 1new_expr = func.__next__()  # 迭代新解funcpath.append(new_expr)DE = DE_function(new_expr , expr)if DE <= 0:# 如果新解比假设初解或者上一个达标解要小,就更新解expr = new_expr# 跳出域值更新为0 jump_counter = 0elif DE > 0:# 如果新解比假设初解或者上一个达标解要大,就不更新解expr = exprif jump(DE, T,k):# 每更新一次T更新一次T *= rjump_counter += 1if jump_counter > jump_max:print("最大回炉冷却次数:", jump_counter)return expr, path, funcpathpath.append(expr)print("{}{}{}{}{}{}{}{}".format('系统温度:', T, ' 新状态:', expr, ' 迭代轮次:',counter, ' DE:', DE))return expr, path, funcpathif __name__ == "__main__":def f():  # 待优化最小函数'''Returns:'''for x in np.random.randn(1000):yield xexpr, path, funcpath = simulate_anneal(f(),parameter={"T": 1,"T_min": 0,"r": 0.4,"expr": 0,"jump_max": 1000,"k":0.000001})print(expr)plt.figure(figsize=(16, 9))  # %%plt.plot(path, c='g')plt.plot(funcpath, c='r')plt.show()plt.close()

请添加图片描述

快速模拟退火
from sko.SA import SAFast
import matplotlib.pyplot as plt
import pandas as pddef demo_func(x):return x[0] ** 2 + (x[1] - 0.05) ** 2 + x[2] ** 2sa = SAFast(func=demo_func, x0=[1, 1, 1] # 初始x解,初始解越大则越难到达最小值,越小则越容易错过, T_max=1 #系统的温度,系统初始应该要处于一个高温的状态 初始温度越高,且马尔科夫链越长,算法搜索越充分,得到全局最优解的可能性越大,但这也意味着需要耗费更多的计算时间, T_min=1e-9  #温度的下限,若温度T达到T_min,则停止搜索, L=300 #最大迭代次数,每个温度下的迭代次数(又称链长), max_stay_counter=100 # 最大冷却停留计数器,保证快速退出,如果 best_y 在最大停留计数器次数(也称冷却时间)内保持不变,则停止运行,lb = [-1,1,-1] #x的下限,ub = [2,3,4] #x的上限#,hop = [3,2,1] # x 的上下限最大差值 hop=ub-lb ,m = 1 # 0-正无穷,越大,越容易冷却退出,n = 1 # # 0-正无穷,越大,越不容易冷却退出,quench = 1 # 淬火指数,0-正无穷,越小则越慢,但是越能求出最小,越大则越快,但是容易陷入局部最优)
best_x, best_y = sa.run()
print('best_x:', best_x, 'best_y:', best_y,"y_history:",len(sa.best_y_history),sa.iter_cycle)
plt.plot(pd.DataFrame(sa.best_y_history).cummin(axis=0))
plt.show()

请添加图片描述

纯数值模拟退火
from sko.SA import SimulatedAnnealingValue
import matplotlib.pyplot as plt
import pandas as pddef demo_func(x):return x[0] ** 2 + (x[1] - 0.05) ** 2 + x[2] ** 2sa = SimulatedAnnealingValue(func=demo_func, x0=[1, 1, 1] # 初始x解,初始解越大则越难到达最小值,越小则越容易错过, T_max=1 #系统的温度,系统初始应该要处于一个高温的状态 初始温度越高,且马尔科夫链越长,算法搜索越充分,得到全局最优解的可能性越大,但这也意味着需要耗费更多的计算时间, T_min=1e-9  #温度的下限,若温度T达到T_min,则停止搜索, L=300 #最大迭代次数,每个温度下的迭代次数(又称链长), max_stay_counter=100000 # 冷却停留计数器,如果 best_y 在最大停留计数器次数(也称冷却时间)内保持不变,则停止运行,lb = [-1,1,-1] #x的下限,ub = [2,3,4] #x的上限#,hop = [3,2,1] # x 的上下限最大差值 hop=ub-lb ,learn_rate = 0.0001 # 学习率,用于控制降温的快慢 值越小T更新越快,退出越快)
best_x, best_y = sa.run()
print('best_x:', best_x, 'best_y:', best_y,"y_history:",len(sa.best_y_history))
plt.plot(pd.DataFrame(sa.best_y_history).cummin(axis=0))
plt.show()

请添加图片描述

柯西模拟退火
from sko.SA import SACauchy
import matplotlib.pyplot as plt
import pandas as pddef demo_func(x):return x[0] ** 2 + (x[1] - 0.05) ** 2 + x[2] ** 2sa = SACauchy(func=demo_func, x0=[1, 1, 1] # 初始x解,初始解越大则越难到达最小值,越小则越容易错过, T_max=1 #系统的温度,系统初始应该要处于一个高温的状态 初始温度越高,且马尔科夫链越长,算法搜索越充分,得到全局最优解的可能性越大,但这也意味着需要耗费更多的计算时间, T_min=1e-9  #温度的下限,若温度T达到T_min,则停止搜索, L=300 #最大迭代次数,每个温度下的迭代次数(又称链长), max_stay_counter=100 # 冷却停留计数器,如果 best_y 在最大停留计数器次数(也称冷却时间)内保持不变,则停止运行,lb = [-1,1,-1] #x的下限,ub = [2,3,4] #x的上限#,hop = [3,2,1] # x 的上下限最大差值 hop=ub-lb ,learn_rate = 0.1 # 学习率,用于控制降温的快慢 值越大T更新越快,退出越快)
best_x, best_y = sa.run()
print('best_x:', best_x, 'best_y:', best_y,"y_history:",len(sa.best_y_history))
plt.plot(pd.DataFrame(sa.best_y_history).cummin(axis=0))
plt.show()

请添加图片描述

玻尔兹曼模拟退火
from sko.SA import SABoltzmann
import matplotlib.pyplot as plt
import pandas as pddef demo_func(x):return x[0] ** 2 + (x[1] - 0.05) ** 2 + x[2] ** 2sa = SABoltzmann(func=demo_func, x0=[1, 1, 1] # 初始x解,初始解越大则越难到达最小值,越小则越容易错过, T_max=1 #系统的温度,系统初始应该要处于一个高温的状态 初始温度越高,且马尔科夫链越长,算法搜索越充分,得到全局最优解的可能性越大,但这也意味着需要耗费更多的计算时间, T_min=1e-9  #温度的下限,若温度T达到T_min,则停止搜索, L=300 #最大迭代次数,每个温度下的迭代次数(又称链长), max_stay_counter=100 # 冷却停留计数器,如果 best_y 在最大停留计数器次数(也称冷却时间)内保持不变,则停止运行# ,lb = [-1,1,-1] #x的下限# ,ub = [2,3,4] #x的上限,hop = [3,2,1] # x 的上下限最大差值 hop=ub-lb ,learn_rate = 0.1 # 学习率,用于控制降温的快慢 值越大T更新越快,退出越快)
best_x, best_y = sa.run()
print('best_x:', best_x, 'best_y:', best_y,"y_history:",len(sa.best_y_history))
plt.plot(pd.DataFrame(sa.best_y_history).cummin(axis=0))
plt.show()

请添加图片描述

这篇关于scikit-opt几种数值模拟退火的代码示例,和参数详解,以及基础模拟退火的原理代码示例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/439828

相关文章

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

MySQL的JDBC编程详解

《MySQL的JDBC编程详解》:本文主要介绍MySQL的JDBC编程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、前置知识1. 引入依赖2. 认识 url二、JDBC 操作流程1. JDBC 的写操作2. JDBC 的读操作总结前言本文介绍了mysq

Python实现Excel批量样式修改器(附完整代码)

《Python实现Excel批量样式修改器(附完整代码)》这篇文章主要为大家详细介绍了如何使用Python实现一个Excel批量样式修改器,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一... 目录前言功能特性核心功能界面特性系统要求安装说明使用指南基本操作流程高级功能技术实现核心技术栈关键函

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志