please help me with the error
显示 更早的评论
I used the following functions to do an optimization problem and got the given error.
Could you please help me correct it.
Thanks
function v = funv(x)
%UNTITLED Summary of this function goes here
% Detailed explanation goes here
x1=x(1);
x2=x(2);
x3=x(3);
x4=x(4);
x5=x(5);
v = 46.149*x1+39.158*x2+19.834*x3+59.307*x4+35.526*x5;
end
function [c,ceq] = nlconst(x)
x1=x(1);
x2=x(2);
x3=x(3);
x4=x(4);
x5=x(5);
c=[];
ceq = x1+x2+x3+x4+x5-1;
end
clc;
clear;
A = [];
B = []; % the linear inequality constraints: A*X <= B
Aeq = [];
Beq = []; % the linear equality constraints: Aeq*X = B
LB = [];
UB = []; % LB <= X <= UB
x0 = [1, 1, 1, 1, 1]; % initial guess
[x,FVAL,EXITFLAG,OUTPUT,LAMBDA] = fmincon(@funv,x0,A,B,Aeq,Beq,LB,UB,@nlconst);
ERROR:
Warning: The default trust-region-reflective algorithm does
not solve problems with the constraints you have specified.
FMINCON will use the active-set algorithm instead. For
information on applicable algorithms, see Choosing the
Algorithm in the documentation.
> In fmincon at 486
In sc at 12
Error using nlconst
Too many input arguments.
Error in fmincon (line 794)
[X,FVAL,LAMBDA,EXITFLAG,OUTPUT,GRAD,HESSIAN]=...
Error in sc (line 12)
[x,FVAL,EXITFLAG,OUTPUT,LAMBDA] =
fmincon(@funv,x0,A,B,Aeq,Beq,LB,UB,@nlconst);
回答(1 个)
Walter Roberson
2013-8-14
1 个投票
http://www.mathworks.com/matlabcentral/newsreader/view_thread/38221 and see Eckhard Arnold's reply.
7 个评论
dav
2013-8-14
Walter Roberson
2013-8-14
I do not know at the moment. I wonder, though, why you are not using Aeq = [1 1 1 1 1] and beq = 1 instead of using the nonlinear constraints ?
dav
2013-8-14
dav
2013-8-14
Walter Roberson
2013-8-14
Use optimset() to create an options structure that you pass to fmincon(). You want to set MaxFunEvals
Your nlconst looks okay to me. Is it in the same file as your other code? If it is not then check with "which" to be sure you are getting the right nlconst function.
You could debug to some extent using
function [c,ceq] = nlconst(varargin)
if nargin ~= 1
error(sprintf('unexpectedly received %d arguments for nlconst', nargin))
end
x = varargin[1};
c = [];
ceq = sum(x) - 1;
dav
2013-8-14
Walter Roberson
2013-8-14
Please use
which -all nlconst
to check whether the nlconst.m you are getting is the one you expect.
类别
在 帮助中心 和 File Exchange 中查找有关 Linear Least Squares 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!