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中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Python中win32包的安装及常见用途介绍

《Python中win32包的安装及常见用途介绍》在Windows环境下,PythonWin32模块通常随Python安装包一起安装,:本文主要介绍Python中win32包的安装及常见用途的相关... 目录前言主要组件安装方法常见用途1. 操作Windows注册表2. 操作Windows服务3. 窗口操作