目录

    • 0. 官方说明
    • 1. Parameters
    • 2. Returns
    • 3. 案例
      • 1)无约束求极值
      • 2)有约束求极值
  • 参考资料

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) <optimize.minimize-neldermead>`- 'Powell'      :ref:`(see here) <optimize.minimize-powell>`- 'CG'          :ref:`(see here) <optimize.minimize-cg>`- 'BFGS'        :ref:`(see here) <optimize.minimize-bfgs>`- 'Newton-CG'   :ref:`(see here) <optimize.minimize-newtoncg>`- 'L-BFGS-B'    :ref:`(see here) <optimize.minimize-lbfgsb>`- 'TNC'         :ref:`(see here) <optimize.minimize-tnc>`- 'COBYLA'      :ref:`(see here) <optimize.minimize-cobyla>`- 'SLSQP'       :ref:`(see here) <optimize.minimize-slsqp>`- 'trust-constr':ref:`(see here) <optimize.minimize-trustconstr>`- 'dogleg'      :ref:`(see here) <optimize.minimize-dogleg>`- 'trust-ncg'   :ref:`(see here) <optimize.minimize-trustncg>`- 'trust-exact' :ref:`(see here) <optimize.minimize-trustexact>`- 'trust-krylov' :ref:`(see here) <optimize.minimize-trustkrylov>`- 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-8
from scipy.optimize import minimize
import numpy as np#demo 1
#计算 1/x+x 的最小值def fun(args):a=argsv=lambda x:a/x[0] +x[0]return vif __name__ == "__main__":args = (1)  #ax0 = np.asarray((2))  # 初始猜测值res = minimize(fun(args), x0, method='SLSQP')print(res.fun)  # 函数的最小值print(res.success)print(res.x)  # x 解决方案数组

执行结果:

2.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 = argsv = lambda x: (a+x[0])/(b+x[1]) -c*x[0]+d*x[2]return vdef con(args):# 约束条件 分为eq 和ineq# eq表示 函数结果等于0 ; ineq 表示 表达式大于等于0  x1min, x1max, x2min, x2max, x3min, x3max = argscons = ({'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, x2max
cons = 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 g 2 ( 1 + x [ 0 ] × 2 3 + l o g 2 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​+log2​4x[1]×3​)
s . t . s.t. s.t.
l o g 2 ( 1 + x [ 0 ] × 2 5 ) ≥ 5 log_2(1+\frac{x[0]\times2}{5})\geq5 log2​(1+5x[0]×2​)≥5
l o g 2 ( 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)-5return v# 定义常量值
args = [2, 1, 3, 4]  # a,b,c,d
args1 = [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);

python非线性规划scipy.optimize.minimize介绍相关推荐

  1. python网页优化公司_使用python优化scipy.optimize.minimize公司

    我将逐行检查您的代码,并强调一些问题:from scipy.optimize import minimize import numpy as np prices=np.array([[1.5,50,3 ...

  2. python:scipy.optimize.minimize(method=’Nelder-Mead’)

    简介 优化问题是工程实践中经常遇到的一种问题.简单讲,就是搜索优化出一组自变量参数,使得目标函数达到极小值(极大值). 如何搜索出这组参数呢:这就是优化算法做的事情.不同的优化算法适用于不同的优化问题 ...

  3. python数学建模之用scipy.optimize.minimize解决高次非线性规划问题

    在实际的数学建模应用中,我们会遇到很多约束条件是二次的,三次的或者是高次函数的情况,这样用 optimize.linprog()来解决就显得不适用了,因此我们使用scipy.optimize下得min ...

  4. 非线性规划(scipy.optimize.minimize)

    1.minimize() 函数介绍 在 python 里用非线性规划求极值,最常用的就是 scipy.optimize.minimize(). [官方介绍点这里](Constrained minimi ...

  5. 利用scipy.optimize.minimize()求解有约束、非线性规划问题

    ''' scipy.optimize.minimize(目标函数obj,初始点,constraints=cons,bounds=bd)此函数有很多参数,这里介绍主要参数 obj:目标函数,最小值形式, ...

  6. python scipy.optimize.minimize多变量多参数优化

    python scipy.optimize.minimize多变量多参数优化 x是一维变量,无超参数 x是二维变量,无超参数,带bounds x是二维变量,有一个超参数,带bounds x是二维变量, ...

  7. Scipy优化scipy.optimize.minimize

    如果喜欢请点赞,收藏,谢谢! 要解决一个优化问题 m i n i m i z e x [ 0 ] , x [ 1 ] \mathrm{minimize}_{x[0],x[1]} minimizex[0 ...

  8. scipy.optimize函数介绍

    scipy.optimize模块使用 前言 一.scipy.optimize模块包含什么? 二.使用步骤 1.函数介绍 前言 简单使用scipy.optimize,训练逻辑回归损失函数,得到权值. 一 ...

  9. scipy.optimize.minimize 的优化算法(1): Nelder–Mead Simplex

    Nelder–Mead Simplex Algorithm Reference: http://home.agh.edu.pl/~pba/pdfdoc/Numerical_Optimization.p ...

最新文章

  1. 2020 年 5 大 DevOps 趋势
  2. SVN账号重新指定方法
  3. python三十:time模块
  4. 006_JavaScript注释
  5. 解读全球海缆地图,带你看懂隐藏的秘密
  6. linux字符串转大写_在 Linux 命令行中转换大小写
  7. 我的CSDN_Blog激活啦~~
  8. Maximum Xor Secondary(单调栈好题)
  9. oracle索引使用例子,Oracle中利用函数索引处理数据倾斜案例
  10. 老路教你用得上的商学课_系列笔记
  11. java timezone 中国_Java中TimeZone类的常用方法
  12. Excel的LOOKUP函数用法和实例以及与VLOOKUP的异同
  13. 数据库中的行式存储和列式存储
  14. snmp-cmds:最简单的调用 Net-SNMP 二进制文件作为子进程的库可移植python SNMP 库
  15. 双十一来了,给自己的应用做个icon换脸小功能
  16. foxmail清除无法清除的未读邮件
  17. 【2022】超详细的JAVA JDK配置和IDEA安装教程(Windows 版)
  18. CloudComparePCL 点云点匹配(基于点到面的距离)
  19. 锁定表格栏位范例网页
  20. 2021.09.27-10.3 AI行业周刊(第65期):坚持的力量

热门文章

  1. conda配置国内镜像
  2. Windows server 2008 网络负载均衡配置
  3. idea 连接远程docker
  4. 分析生态系统服务社会价值问题
  5. Viva Confetti UVALive - 2572
  6. qq管家工具无声无息的过滤阻止了网页
  7. 单目和双目摄像头到底有神马差?
  8. 链接两个“名字完全一样”的【动态库】,你会怎么处理?
  9. kafka!还好我留了一手
  10. 【云原生之K8s】 Kubernetes原理