首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么MATLAB fmincon忽略非线性约束?

为什么MATLAB fmincon忽略非线性约束?
EN

Stack Overflow用户
提问于 2019-05-04 13:55:07
回答 1查看 335关注 0票数 0

我想使用MATLAB的fmincon函数来解决一个非线性问题,我知道它可以用一种不同的方法很容易地解决,但我想使用fmincon (你可能不需要关于这个问题的以下详细信息,但我提供了它们,以防你需要):

函数f(x)是顶点在点(5|1)的二次函数。

f(x)=0.1(x-5)^2+1 for 0<=x<=5

函数g(x)是一个4阶多项式,其顶点在点(c|0)。

g(x)=(x-c)^4 for 0<=x<=c

函数h就是x轴上的一条线。

h=0 for c<=x<=5

我想最小化函数f(x)和两个连通函数g(x)和h在区间0,5之间的面积。

minimize A=2*(int(f,[0,5])-int(g,[0,c]))=55/3 - (2*c^5)/5

我也有一个约束,f(x)必须总是比函数g(x)和h高1个单位。

从图中我知道变量c必须在0和2之间(只是fmincon函数的一个范围)。

这是我的.m文件:

代码语言:javascript
复制
clc
clear

format long;
options = optimoptions(@fmincon, 'Display', 'iter', 'Algorithm', 'interior-point');

fun=@(x)55/3 - (2*(x(1))^5)/5;

lb = [0];
ub = [2];

[x,fval] = fmincon(fun,[0.1],[],[],[],[],lb,ub,@cons_Q6,options)

约束文件如下所示(我为x插入了很多值,增量为0.1):

代码语言:javascript
复制
function [c,ceq]=cons_Q6(x)
c=[(0.0-x(1))^4-0.1*(0.0-5)^2
(0.1-x(1))^4-0.1*(0.1-5)^2
(0.2-x(1))^4-0.1*(0.2-5)^2
(0.3-x(1))^4-0.1*(0.3-5)^2
(0.4-x(1))^4-0.1*(0.4-5)^2
(0.5-x(1))^4-0.1*(0.5-5)^2
(0.6-x(1))^4-0.1*(0.6-5)^2
(0.7-x(1))^4-0.1*(0.7-5)^2
(0.8-x(1))^4-0.1*(0.8-5)^2
(0.9-x(1))^4-0.1*(0.9-5)^2
(1.0-x(1))^4-0.1*(1.0-5)^2
(1.1-x(1))^4-0.1*(1.1-5)^2
(1.2-x(1))^4-0.1*(1.2-5)^2
(1.3-x(1))^4-0.1*(1.3-5)^2
(1.4-x(1))^4-0.1*(1.4-5)^2
(1.5-x(1))^4-0.1*(1.5-5)^2
(1.6-x(1))^4-0.1*(1.6-5)^2
(1.7-x(1))^4-0.1*(1.7-5)^2
(1.8-x(1))^4-0.1*(1.8-5)^2
(1.9-x(1))^4-0.1*(1.9-5)^2
(2.0-x(1))^4-0.1*(2.0-5)^2
(2.1-x(1))^4-0.1*(2.1-5)^2
(2.2-x(1))^4-0.1*(2.2-5)^2
(2.3-x(1))^4-0.1*(2.3-5)^2
(2.4-x(1))^4-0.1*(2.4-5)^2
(2.5-x(1))^4-0.1*(2.5-5)^2
(2.6-x(1))^4-0.1*(2.6-5)^2
(2.7-x(1))^4-0.1*(2.7-5)^2
(2.8-x(1))^4-0.1*(2.8-5)^2
(2.9-x(1))^4-0.1*(2.9-5)^2
(3.0-x(1))^4-0.1*(3.0-5)^2
(3.1-x(1))^4-0.1*(3.1-5)^2
(3.2-x(1))^4-0.1*(3.2-5)^2
(3.3-x(1))^4-0.1*(3.3-5)^2
(3.4-x(1))^4-0.1*(3.4-5)^2
(3.5-x(1))^4-0.1*(3.5-5)^2
(3.6-x(1))^4-0.1*(3.6-5)^2
(3.7-x(1))^4-0.1*(3.7-5)^2
(3.8-x(1))^4-0.1*(3.8-5)^2
(3.9-x(1))^4-0.1*(3.9-5)^2
(4.0-x(1))^4-0.1*(4.0-5)^2
(4.1-x(1))^4-0.1*(4.1-5)^2
(4.2-x(1))^4-0.1*(4.2-5)^2
(4.3-x(1))^4-0.1*(4.3-5)^2
(4.4-x(1))^4-0.1*(4.4-5)^2
(4.5-x(1))^4-0.1*(4.5-5)^2
(4.6-x(1))^4-0.1*(4.6-5)^2
(4.7-x(1))^4-0.1*(4.7-5)^2
(4.8-x(1))^4-0.1*(4.8-5)^2
(4.9-x(1))^4-0.1*(4.9-5)^2
(5.0-x(1))^4-0.1*(5.0-5)^2
];
ceq=[];

正如您所看到的,我已经为未知变量设置了边界,因此x(1)=[0,2]和我将约束设置在0,5的范围内,尽管由于x(1)的边界,我只需要它们在0,2的范围内。现在,当我像这样解决它时,我得到了一个不符合所有约束的解决方案。但当我删除范围中不必要的约束时]2;5]

代码语言:javascript
复制
function [c,ceq]=cons_Q6(x)
c=[(0.0-x(1))^4-0.1*(0.0-5)^2
(0.1-x(1))^4-0.1*(0.1-5)^2
(0.2-x(1))^4-0.1*(0.2-5)^2
(0.3-x(1))^4-0.1*(0.3-5)^2
(0.4-x(1))^4-0.1*(0.4-5)^2
(0.5-x(1))^4-0.1*(0.5-5)^2
(0.6-x(1))^4-0.1*(0.6-5)^2
(0.7-x(1))^4-0.1*(0.7-5)^2
(0.8-x(1))^4-0.1*(0.8-5)^2
(0.9-x(1))^4-0.1*(0.9-5)^2
(1.0-x(1))^4-0.1*(1.0-5)^2
(1.1-x(1))^4-0.1*(1.1-5)^2
(1.2-x(1))^4-0.1*(1.2-5)^2
(1.3-x(1))^4-0.1*(1.3-5)^2
(1.4-x(1))^4-0.1*(1.4-5)^2
(1.5-x(1))^4-0.1*(1.5-5)^2
(1.6-x(1))^4-0.1*(1.6-5)^2
(1.7-x(1))^4-0.1*(1.7-5)^2
(1.8-x(1))^4-0.1*(1.8-5)^2
(1.9-x(1))^4-0.1*(1.9-5)^2
(2.0-x(1))^4-0.1*(2.0-5)^2
];
ceq=[];

然后我就得到了正确的结果。有人知道为什么会发生这种情况吗?为什么MATLAB在设置整个0,5范围的约束时不遵守这些约束?

EN

回答 1

Stack Overflow用户

发布于 2019-05-04 15:36:47

代码语言:javascript
复制
   -Your problem is more related to calculus than matlab tool
   constraints like 
   function [c]=cons_Q6(x)
   c=[x < 0; x > 0]; are just ignored by fmincon, because they are not logical 

   Technically you need to know the optimum c before solving 
   this optimization problem


   - Another issue A = int(f,[0,5])-int(g,[0,c]) = 55/6 - c^5/5 instead of 
                   A = 2*(int(f,[0,5])-int(g,[0,c])) = 55/3 - (2*c^5)/5

   Factor 2 is used whether for even whether for odd function (like cosine or since). 
   Even for those kind of function the integration interval is reduced by half

I updated your optimization function and the solution c is as follow

x = [0, c], constraint is g(x)-f(x)-1<= 0--> (x-c)^4 -0.1(x-5)^2 <=0
x = [c, 5], constraint is h(x)-f(x)-1<= 0--> -0.1(x-5)^2 <=0

c must be predefined or guessed in advance, here I supposed c = 2 
because your upper bound ub = 2

结果

代码语言:javascript
复制
x = [0, 2], --> (x-c)^4 -0.1(x-5)^2 <=0
x = [2, 5], --> -0.1(x-5)^2 <=0

cons_Q6(x)如下所示

代码语言:javascript
复制
function [c,ceq]=cons_Q6(x)
c=[(0.0-x)^4-0.1*(0.0-5)^2;
(0.1-x)^4-0.1*(0.1-5)^2;
(0.2-x)^4-0.1*(0.2-5)^2;
(0.3-x)^4-0.1*(0.3-5)^2;
(0.4-x)^4-0.1*(0.4-5)^2;
(0.5-x)^4-0.1*(0.5-5)^2;
(0.6-x)^4-0.1*(0.6-5)^2;
(0.7-x)^4-0.1*(0.7-5)^2;
(0.8-x)^4-0.1*(0.8-5)^2;
(0.9-x)^4-0.1*(0.9-5)^2;
(1.0-x)^4-0.1*(1.0-5)^2;
(1.1-x)^4-0.1*(1.1-5)^2;
(1.2-x)^4-0.1*(1.2-5)^2;
(1.3-x)^4-0.1*(1.3-5)^2;
(1.4-x)^4-0.1*(1.4-5)^2;
(1.5-x)^4-0.1*(1.5-5)^2;
(1.6-x)^4-0.1*(1.6-5)^2;
(1.7-x)^4-0.1*(1.7-5)^2;
(1.8-x)^4-0.1*(1.8-5)^2;
(1.9-x)^4-0.1*(1.9-5)^2;
(2.0-x)^4-0.1*(2.0-5)^2;
-0.1*(2.1-5)^2;
-0.1*(2.2-5)^2;
-0.1*(2.3-5)^2;
-0.1*(2.4-5)^2;
-0.1*(2.5-5)^2;
-0.1*(2.6-5)^2;
-0.1*(2.7-5)^2;
-0.1*(2.8-5)^2;
-0.1*(2.9-5)^2;
-0.1*(3.0-5)^2;
-0.1*(3.1-5)^2;
-0.1*(3.2-5)^2;
-0.1*(3.3-5)^2;
-0.1*(3.4-5)^2;
-0.1*(3.5-5)^2;
-0.1*(3.6-5)^2;
-0.1*(3.7-5)^2;
-0.1*(3.8-5)^2;
-0.1*(3.9-5)^2;
-0.1*(4.0-5)^2;
-0.1*(4.1-5)^2;
-0.1*(4.2-5)^2;
-0.1*(4.3-5)^2;
-0.1*(4.4-5)^2;
-0.1*(4.5-5)^2;
-0.1*(4.6-5)^2;
-0.1*(4.7-5)^2;
-0.1*(4.8-5)^2;
-0.1*(4.9-5)^2;
-0.1*(5.0-5)^2;
];

ceq=[];

The constraints in the range ]2;5] are very necessary keep them

clc
clear

format long;
options = optimoptions(@fmincon, 'Display', 'iter', 'Algorithm',... 
'interior-point');

fun=@(x)55/6 - (x^5)/5;

lb = [0];
ub = [2];

[c, A] = fmincon(fun,[0.1],[],[],[],[],lb,ub,@cons_Q6,options)

解决方案:

代码语言:javascript
复制
c = 1.257432726024430


A = 8.537951710969493
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55979903

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档