Python中差分进化differential_evolution的调用及参数说明

2024-09-08 03:20

本文主要是介绍Python中差分进化differential_evolution的调用及参数说明,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在场景应用中,要求我们的函数计算结果尽可能的逼近实际测量结果,可转化计算结果与测量结果的残差,通过最小化残差,便可求出最优的结果。但使用最小二乘等方法来计算时,常常会使迭代的结果显然局部最优点而导致结算错误。

差分进化原理

差分进化(Differential Evolution,DE)是一种基于群体差异的进化算法,其计算思想主要包括以下几个方面:

一、初始化种群

首先,随机生成一个初始种群。这个种群由若干个个体组成,每个个体代表问题的一个潜在解。在实际应用中,个体通常是一个向量,其维度取决于问题的变量个数。例如,对于一个二维优化问题,个体可能是一个包含两个元素的向量。

二、变异操作

差分进化的核心是变异操作。对于每个个体,通过以下方式生成一个变异个体:

  1. 随机选择三个不同的个体 x r 1 x_r1 xr1 x r 2 x_r2 xr2 x r 3 x_r3 xr3 从当前种群中。
  2. 计算差分向量 d = x r 2 − x r 3 d = x_r2 - x_r3 d=xr2xr3
  3. 然后,通过将当前个体 x i x_i xi 与差分向量进行加权组合来生成变异个体 v i v_i vi,即 v i = x i + F ⋅ d v_i = x_i + F \cdot d vi=xi+Fd,其中 F F F 是变异因子,通常是一个在 0 到 2 之间的常数。

变异操作的目的是引入新的基因组合,增加种群的多样性,从而探索搜索空间的不同区域。

三、交叉操作

接下来,进行交叉操作,将变异个体与当前个体进行交叉,生成一个试验个体。交叉操作的方式有多种,常见的是二项式交叉。具体步骤如下:

  1. 对于每个维度 j j j,随机生成一个在 0 到 1 之间的数 r j r_j rj
  2. 如果 r j r_j rj 小于交叉概率 C R CR CR(通常在 0 到 1 之间)或者 j j j 等于随机选择的一个维度索引,那么试验个体的第 j j j 个维度的值从变异个体中获取,即 u i j = v i j u_{ij}=v_{ij} uij=vij;否则,试验个体的第 j j j 个维度的值从当前个体中获取,即 u i j = x i j u_{ij}=x_{ij} uij=xij

交叉操作的目的是在保持一定多样性的同时,继承当前个体中的一些优良基因。

四、选择操作

最后,进行选择操作,确定是否用试验个体替换当前个体。选择操作通常基于目标函数值进行。如果试验个体的目标函数值优于当前个体的目标函数值,那么就用试验个体替换当前个体;否则,保持当前个体不变。

五、迭代过程

重复上述变异、交叉和选择操作,直到满足停止条件。停止条件可以是达到最大迭代次数、目标函数值达到一定精度或者在一定迭代次数内目标函数值没有明显改进等。

调用参数详解

scipy.optimize.differential_evolutionSciPy库中用于求解全局优化问题的一个非常强大的算法。这个算法基于遗传算法的原理,通过不断地迭代来寻找问题的最优解。下面,我将详细解释 differential_evolution 函数的主要参数、可选的求解方法、返回值以及调用经验。

(function) def differential_evolution(func: Any,bounds: Any,args: Any = (),strategy: str = 'best1bin',maxiter: int = 1000,popsize: int = 15,tol: float = 0.01,mutation: Any = (0.5, 1),recombination: float = 0.7,seed: Any | None = None,callback: Any | None = None,disp: bool = False,polish: bool = True,init: str = 'latinhypercube',atol: int = 0,updating: str = 'immediate',workers: int = 1,constraints: Any = (),x0: Any | None = None,*,integrality: Any | None = None,vectorized: bool = False
) -> OptimizeResult

scipy.optimize.differential_evolution中的参数设置
以下是对scipy.optimize.differential_evolution函数的详细解释:

  1. func

    • 含义:要最小化的目标函数。
    • 这个函数应该接受一个一维数组作为输入,并返回一个标量值,表示目标函数在该点的值。例如:def objective_function(x): return x[0]**2 + x[1]**2
  2. bounds

    • 含义:一个序列的元组,每个元组代表一个变量的边界。例如,对于一个二维问题,bounds=[(0, 10), (-5, 5)]表示第一个变量的范围是 0 到 10,第二个变量的范围是 -5 到 5。
    • 确保边界设置合理,以包含可能的最优解。如果边界设置过窄,可能会错过最优解;如果边界设置过宽,可能会增加计算时间。
  3. args

    • 含义:可选参数,目标函数的额外参数。如果目标函数需要除了输入变量之外的其他参数,可以通过这个参数传递。
    • 例如,如果目标函数是def objective_function(x, a, b): return (x[0] - a)**2 + (x[1] - b)**2,那么可以通过differential_evolution(objective_function, bounds, args=(2, 3))来调用,这里的(2, 3)就是传递给目标函数的额外参数ab
  4. strategy

    • 含义:差分进化策略。可选的值有:‘best1bin’、‘best1exp’、‘rand1exp’、‘randtobest1exp’、‘currenttobest1exp’、‘best2exp’、‘rand2exp’、‘randtobest1bin’、‘currenttobest1bin’、‘best2bin’、‘rand2bin’、‘rand1bin’。
    • 不同的策略在不同类型的问题上可能表现不同。一般来说,'best1bin’和’rand1bin’是比较常用的策略。可以尝试不同的策略,看哪个在特定问题上表现最好。
  5. maxiter

    • 含义:最大迭代次数。
    • 根据问题的复杂度和计算资源来设置。如果问题比较复杂,可以设置较大的迭代次数,但这也会增加计算时间。如果计算资源有限,可以适当减少迭代次数。
  6. popsize

    • 含义:种群大小。
    • 一般来说,较大的种群大小可以增加算法找到全局最优解的可能性,但也会增加计算时间。可以根据问题的复杂度和计算资源来调整种群大小。
  7. tol

    • 含义:收敛容忍度。当目标函数的改进小于这个值时,算法停止。
    • 较小的容忍度可以确保算法更接近全局最优解,但可能会增加计算时间。需要在精度和计算时间之间进行权衡。
  8. mutation

    • 含义:变异因子,控制差分向量的缩放。
    • 通常在 0.5 到 1 之间取值。较大的变异因子可以增加算法的探索能力,但可能会降低收敛速度。较小的变异因子可以提高收敛速度,但可能会陷入局部最优解。
  9. recombination

    • 含义:交叉概率,控制个体之间的基因交换。
    • 通常在 0 到 1 之间取值。较大的交叉概率可以增加算法的多样性,但可能会破坏好的解。较小的交叉概率可以保持好的解,但可能会降低算法的探索能力。
  10. seed

    • 含义:随机数种子,用于可重复的结果。
    • 如果需要可重复的结果,可以设置一个固定的种子值。如果不需要可重复的结果,可以不设置这个参数,让算法使用随机种子。
  11. callback

    • 含义:回调函数,在每次迭代后调用。
    • 可以定义一个回调函数,在每次迭代后执行一些特定的操作,例如记录优化过程中的中间结果、检查是否满足某些条件等。
  12. disp

    • 含义:是否打印优化过程的信息。
    • 如果设置为True,会打印每一代的最佳适应度值等信息。如果不需要打印信息,可以设置为False
  13. polish

    • 含义:是否在优化结束后使用局部优化方法进行精化。
    • 如果设置为True,会在差分进化算法找到的最优解附近使用局部优化方法(如 BFGS)进行精化,以提高解的精度。但这也会增加计算时间。如果对解的精度要求不高,可以设置为False

scipy.optimize.differential_evolution中的返回值

该函数返回一个OptimizeResult对象,包含以下属性:

  1. x:最优解的数组。
  2. fun:最优解对应的目标函数值。
  3. nfev:目标函数的评估次数。
  4. nit:实际迭代次数。
  5. message:优化结果的消息,例如“Maximum number of iterations reached”。

调用经验总结

  1. 在使用differential_evolution函数时,首先要确定目标函数和变量的边界。目标函数应该能够准确地反映问题的优化目标,边界应该合理地限制变量的取值范围。
  2. 根据问题的复杂度和计算资源,选择合适的参数值。例如,对于复杂的问题,可以设置较大的迭代次数和种群大小,但要注意计算时间。对于简单的问题,可以适当减少这些参数值,以提高计算效率。
  3. 尝试不同的差分进化策略,看哪个在特定问题上表现最好。可以从常用的策略开始尝试,如’best1bin’和’rand1bin’。
  4. 调整变异因子和交叉概率,以平衡算法的探索能力和收敛速度。可以通过实验来确定合适的参数值。
  5. 如果需要可重复的结果,可以设置随机数种子。如果需要打印优化过程的信息,可以设置disp=True
  6. 在优化结束后,可以考虑使用局部优化方法进行精化,以提高解的精度。但要注意计算时间的增加。
  7. 可以使用回调函数来记录优化过程中的中间结果或执行其他特定的操作。

这篇关于Python中差分进化differential_evolution的调用及参数说明的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python如何使用seleniumwire接管Chrome查看控制台中参数

《Python如何使用seleniumwire接管Chrome查看控制台中参数》文章介绍了如何使用Python的seleniumwire库来接管Chrome浏览器,并通过控制台查看接口参数,本文给大家... 1、cmd打开控制台,启动谷歌并制定端口号,找不到文件的加环境变量chrome.exe --rem

一文带你理解Python中import机制与importlib的妙用

《一文带你理解Python中import机制与importlib的妙用》在Python编程的世界里,import语句是开发者最常用的工具之一,它就像一把钥匙,打开了通往各种功能和库的大门,下面就跟随小... 目录一、python import机制概述1.1 import语句的基本用法1.2 模块缓存机制1.

使用Python将长图片分割为若干张小图片

《使用Python将长图片分割为若干张小图片》这篇文章主要为大家详细介绍了如何使用Python将长图片分割为若干张小图片,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果1. Python需求

Python实现将实体类列表数据导出到Excel文件

《Python实现将实体类列表数据导出到Excel文件》在数据处理和报告生成中,将实体类的列表数据导出到Excel文件是一项常见任务,Python提供了多种库来实现这一目标,下面就来跟随小编一起学习一... 目录一、环境准备二、定义实体类三、创建实体类列表四、将实体类列表转换为DataFrame五、导出Da

Python视频处理库VidGear使用小结

《Python视频处理库VidGear使用小结》VidGear是一个高性能的Python视频处理库,本文主要介绍了Python视频处理库VidGear使用小结,文中通过示例代码介绍的非常详细,对大家的... 目录一、VidGear的安装二、VidGear的主要功能三、VidGear的使用示例四、VidGea

Python Invoke自动化任务库的使用

《PythonInvoke自动化任务库的使用》Invoke是一个强大的Python库,用于编写自动化脚本,本文就来介绍一下PythonInvoke自动化任务库的使用,具有一定的参考价值,感兴趣的可以... 目录什么是 Invoke?如何安装 Invoke?Invoke 基础1. 运行测试2. 构建文档3.

Python实现数据清洗的18种方法

《Python实现数据清洗的18种方法》本文主要介绍了Python实现数据清洗的18种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录1. 去除字符串两边空格2. 转换数据类型3. 大小写转换4. 移除列表中的重复元素5. 快速统

Python结合requests和Cheerio处理网页内容的操作步骤

《Python结合requests和Cheerio处理网页内容的操作步骤》Python因其简洁明了的语法和强大的库支持,成为了编写爬虫程序的首选语言之一,requests库是Python中用于发送HT... 目录一、前言二、环境搭建三、requests库的基本使用四、Cheerio库的基本使用五、结合req

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

python中os.stat().st_size、os.path.getsize()获取文件大小

《python中os.stat().st_size、os.path.getsize()获取文件大小》本文介绍了使用os.stat()和os.path.getsize()函数获取文件大小,文中通过示例代... 目录一、os.stat().st_size二、os.path.getsize()三、函数封装一、os