25.10 matlab里面的10中优化方法介绍—— 函数fmincon(matlab程序)

1. 简述

关于非线性规划

非线性规划问题是指目标函数或者约束条件中包含非线性函数的规划问题。

前面我们学到的线性规划更多的是理想状况或者说只有在习题中,为了便于我们理解,引导我们进入规划模型的一种情况。相比之下,非线性规划会更加贴近实际的生活。那这节我们先通过一个类似于线性规划中linprog()函数的fmincon()来体会一下这类问题的解决过程。

一、fmincon()的基本形式

基本形式如下:x = fmincon('fun',x0,A,b,Aeq,beq,lb,ub,'nonlcon',options) ;

(1)'fun'为目标函数,注意需要单引号,或者@,或者直接在定义时写成匿名函数即可,后面的nonlcon为非线性约束(包括等式和不等式),形式要求同fun;

(2)x0表示决策变量的初始值,可以随机取一组符合约束条件的数据值,一般来讲没什么影响;

(3)A,b,Aeq,beq分别表示线性的不等式约束和等式约束,Ax<=b,Aeqx=beq;lb,ub同之前的linprog()函数,表示上下界的向量;

(4)使用 options 所指定的优化选项执行最小化。使用 optimoptions 可设置这些选项。如果没有非线性不等式或等式约束,请设置 nonlcon = \[\]。

基本要求就是以上这些,下面我们以几个例子来具体实现一下。

2. 代码

例子1

%% 用函数fmincon求约束最优化问题

clear all

f=inline('exp(x(1))*(4*x(1)^2+2*x(2)^2+4*x(1)*x(2)+2*x(2)+1)','x');

x0=-1 1;

x,fval=fmincon(f,x0,\[\],\[\],\[\],\[\],\[\],\[\],'fcon1212')

例子2

%% 用fmincon解线性约束的最优化

clear all

f=inline('-x(1)*x(2)*x(3)','x');

A=-1,-2,-2;1,2,2; %A*x<=b

b=0;72;

x0=10;10;10;

x,fval=fmincon(f,x0,A,b)

3. 运行结果

相关推荐
雪隐3 分钟前
个人电脑玩AI-08让5060 Ti给你打工——我拿 Unlimited-OCR扫了 600 页书,然后悟了
人工智能·后端
Coffeeee5 分钟前
Prompt要花心思写,与 AI 对话的七个技巧
人工智能·aigc·ai编程
烬羽32 分钟前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
蝎子莱莱爱打怪37 分钟前
Claude Code 官宣新升级:子智能体默认后台跑,你边聊它边干活
人工智能
武子康42 分钟前
调查研究-206 DeepSeek DSpark 深度解析:大模型推理加速,正在从“模型能力”转向“系统工程”
人工智能·agent·deepseek
甲维斯1 小时前
最佳work模型sonnet5来了,直接就能用!
人工智能
IT_陈寒2 小时前
React hooks 闭包陷阱把我的状态吃掉了,原来问题出在这里
前端·人工智能·后端
冬奇Lab14 小时前
Workflow 系列(03):状态管理——持久化、幂等性与版本绑定
人工智能·工作流引擎
冬奇Lab14 小时前
每日一个开源项目(第146篇):openpilot - 开源自动驾驶辅助系统,曾在 Consumer Reports 评测中超过特斯拉 Autopilot
人工智能·开源·自动驾驶