文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-09-02 16:34

关注

目录

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

2. Returns

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

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯