我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python非线性规划scipy.optimize.minimize介绍

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python非线性规划scipy.optimize.minimize介绍

目录

0. 官方说明

在 python 里用非线性规划求极值,最常用的就是 scipy.optimize.minimize()。最小化一个或多个变量的标量函数。(Minimization of scalar function of one or more variables.)

scipy.optimize.minimize(fun, x0, args=(), method=None, jac=None, hess=None, hessp=None, bounds=None, constraints=(), tol=None, callback=None, options=None)

在python脚本页面中,点击Ctrl+B或者Ctrl+左击,即可查看函数的定义、函数的使用案例

1. Parameters

  • fun:需要被最小化的目标函数(objective function)

  • x0:初始猜想值,形状(n, )

    • 大小为 (n,) 的实数元素数组,其中 “n” 是自变量的数量。
  • args:tuple元组,可选的 Optional

    • 传递给目标函数及其导数(fun、jac 和 hess 函数)的额外参数。
  • method : str or callable, 可选的
    求解器的类型,应该从下面选取一种
    如果未给出,则选择 BFGS、L-BFGS-B、SLSQP 之一,具体取决于问题是否有约束或界限。

          - 'Nelder-Mead' :ref:`(see here) `      - 'Powell'      :ref:`(see here) `      - 'CG'          :ref:`(see here) `      - 'BFGS'        :ref:`(see here) `      - 'Newton-CG'   :ref:`(see here) `      - 'L-BFGS-B'    :ref:`(see here) `      - 'TNC'         :ref:`(see here) `      - 'COBYLA'      :ref:`(see here) `      - 'SLSQP'       :ref:`(see here) `      - 'trust-constr':ref:`(see here) `      - 'dogleg'      :ref:`(see here) `      - 'trust-ncg'   :ref:`(see here) `      - 'trust-exact' :ref:`(see here) `      - 'trust-krylov' :ref:`(see here) `      - custom - a callable object (added in version 0.14.0),
  • jac: {callable, ‘2-point’, ‘3-point’, ‘cs’, bool}, optional ,目标函数的雅可比矩阵。

  • bounds:可选项,变量的边界(仅适用于L-BFGS-B,TNC和SLSQP)。以(min,max)对的形式定义 x 中每个元素的边界。如果某个参数在 min 或者 max 的一个方向上没有边界,则用 None 标识。如(None, max)

  • constraints:约束条件(只对 COBYLA 和 SLSQP)。

  • bounds:可选项,变量的边界(仅适用于L-BFGS-B,TNC和SLSQP)。以(min,max)对的形式定义 x 中每个元素的边界。如果某个参数在 min 或者 max 的一个方向上没有边界,则用 None 标识。如(None, max)

  • constraints:约束条件(只对 COBYLA 和 SLSQP)。

2. Returns

  • res:优化结果
    • 优化结果表示为“OptimizeResult”对象。
    • 重要的属性是:x 解决方案数组,success 一个布尔标志,指示优化器是否成功退出,message 描述终止原因。 有关其他属性的描述,请参阅 OptimizeResult

3. 案例

1)无约束求极值

计算 1/x+x 的最小值

# coding=utf-8from scipy.optimize import minimizeimport numpy as np #demo 1#计算 1/x+x 的最小值 def fun(args):     a=args     v=lambda x:a/x[0] +x[0]     return v  if __name__ == "__main__":     args = (1)  #a     x0 = np.asarray((2))  # 初始猜测值     res = minimize(fun(args), x0, method='SLSQP')     print(res.fun)  # 函数的最小值     print(res.success)     print(res.x)  # x 解决方案数组

执行结果:

0000000815356342 (函数的最小值)
True
[1.00028559]

2)有约束求极值

例2-1 计算 (2+x1)/(1+x2) - 3x1+4x3 的最小值, x1, x2, x3 都处于[0.1, 0.9] 区间内。

def fun(args):    a,b,c,d = args    v = lambda x: (a+x[0])/(b+x[1]) -c*x[0]+d*x[2]    return v    def con(args):    # 约束条件 分为eq 和ineq    # eq表示 函数结果等于0 ; ineq 表示 表达式大于等于0      x1min, x1max, x2min, x2max, x3min, x3max = args    cons = ({'type': 'ineq', 'fun': lambda x: x[0] - x1min},\            {'type': 'ineq', 'fun': lambda x: -x[0] + x1max},\            {'type': 'ineq', 'fun': lambda x: x[1] - x2min},\            {'type': 'ineq', 'fun': lambda x: -x[1] + x2max},\            {'type': 'ineq', 'fun': lambda x: x[2] - x3min},\            {'type': 'ineq', 'fun': lambda x: -x[2] + x3max})    return cons # 定义常量值args = (2,1,3,4)  # a,b,c,d# 设置参数范围/约束条件args1 = (0.1,0.9,0.1, 0.9,0.1,0.9)  # x1min, x1max, x2min, x2maxcons = con(args1)# 设置初始猜测值  x0 = np.asarray((0.5,0.5,0.5))res = minimize(fun(args), x0, method='SLSQP',constraints=cons)print(res.fun)print(res.success)print(res.x)

执行结果:

  • 0.773684210526435
  • True
  • [0.9 0.9 0.1]

例2-2 解决以下优化问题
m i n i m i z e x [ 0 ] , x [ 1 ] l o g2 ( 1 + x [ 0 ] × 2 3 + l o g2 x [ 1 ] × 3 4 ) minimize_{x[0],x[1]}log_2(1+\frac{x[0]\times2}{3}+log_2\frac{x[1]\times3}{4}) minimizex[0],x[1]log2(1+3x[0]×2+log24x[1]×3)
s . t . s.t. s.t.
l o g2 ( 1 + x [ 0 ] × 2 5 ) ≥ 5 log_2(1+\frac{x[0]\times2}{5})\geq5 log2(1+5x[0]×2)5
l o g2 ( 1 + x [ 0 ] × 6 4 ) ) ≥ 5 log_2(1+\frac{x[0]\times6}{4}))\geq5 log2(1+4x[0]×6))5

# 目标函数def fun(a,b,c,d):    def v(x):        return np.log2(1+x[0]*a/b)+np.log2(1+x[1]*c/d)    return v    #限制条件函数def con(a,b,i):    def v(x):        return np.log2(1 + x[i] * a / b)-5    return v# 定义常量值args = [2, 1, 3, 4]  # a,b,c,dargs1 = [2, 5, 6, 4] # 设置初始猜测值x0 = np.asarray((0.5, 0.5))#设置限制条件cons = ({'type': 'ineq', 'fun': con(args1[0],args1[1],0)},        {'type': 'ineq', 'fun': con(args1[2],args1[3],1)},        )res = minimize(fun(args[0], args[1], args[2], args[3]), x0, constraints=cons)print(res.fun)print(res.success)print(res.x)

输出结果:

  • 11.329796332293162
  • True
  • [77.5 20.66666658]

参考资料

[1] 官网资料 2022.9.19
[2] 非线性规划(scipy.optimize.minimize);

来源地址:https://blog.csdn.net/weixin_46713695/article/details/126936708

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python非线性规划scipy.optimize.minimize介绍

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python实现线性规划求解

线性规划标准形式:MATLAB-------------线性规划求解主要分 两个部分,目标函数(max,min)和约束条件(s.t.),求解时一般要化为MATLAB标准形式:求解用到的模块(scipy 和 numpy):from sci
2023-06-02

Python+PuLP怎么实现线性规划

今天小编给大家分享一下Python+PuLP怎么实现线性规划的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.PuLP 库的
2023-06-30

Python中怎么实现线性规划

这篇文章给大家介绍Python中怎么实现线性规划,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。 运筹学运筹学是一种科学的决策方法,它通常是在需要分配稀缺资源的条件下,寻求系统的优秀设计。科学的决策方法需要使用一个或多个
2023-06-16

python中如何实现线性规划

python中如何实现线性规划,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。说明1、图解法,用几何绘图的方法,求出最优解。中学就讲过这种方法,在经济学研究中非常
2023-06-20

浅谈Python数学建模之线性规划

目录一、求解方法、算法和编程方案1.1、线性规划问题的求解方法1.2、线性规划的最快算法1.3、选择适合自己的编程方案二、PuLP库求解线性规划问题2.1、线性规划问题的描述2.2、PuLP 求解线性规划问题的步骤2.3、Python例程:
2022-06-02

python中如何处理线性规划问题

这篇文章主要为大家展示了“python中如何处理线性规划问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python中如何处理线性规划问题”这篇文章吧。说明1、问题定义,确定决策变量、目标函数
2023-06-20

python中求解线性规划的包是什么

这篇文章主要介绍python中求解线性规划的包是什么,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!说明1、Scipy库提供简单的线性或非线性规划问题。但不能解决背包问题的0-1规划问题,或者整数规划问题,混合整数规划
2023-06-20

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录