[globalsearch] nonlinear constraint violation

4 views (last 30 days)
Hi,
I am using globalsearch with 'fmincon' solver for an optimization problem with one nonlinear constraint and two boundary constraints. However, the optimal solutions from Matlab violates the nonlinear constraint. I tried 'Interior-point', 'sqp' and 'active-set' algorithms. But none of them returns an answer that is feasible. Is there a way to require absolute obedience of the constraint? Thank you very much.
Jie

Answers (6)

Laura Proctor
Laura Proctor on 6 Oct 2011
How are you defining the nonlinear constraint function?
If you only have an equality nonlinear constraint, you still need the first output of your nonlinear constraint function to be the inequality constraint. If you don't have an inequality constraint, set that variable to the empty set, i.e.
function [c,ceq] = nlc(x)
c = [];
ceq = x.^2 - 2;

Jie Ning
Jie Ning on 6 Oct 2011
I did that. I have one nonlinear inequality constraint and no equality constraint. I defined the inequality constraint, say, f(x), then used
nonlcon = @(x) deal(f(x), []);

Laura Proctor
Laura Proctor on 6 Oct 2011
The next thing I would check is to be sure that the nonlinear inequality constraint function is evaluated such that it should be less than or equal to zero. For the example above, the constraint would translate to:
x.^2 <= 2

Jie Ning
Jie Ning on 6 Oct 2011
Yes. It is. I wanted the constraint to be f(x)<=0. My initial point x0 is feasible as well. However, the optimal solution x* from Matlab gives f(x*)>0. This f(x*) is ~10^(-3) while the tolerance is 10^(-6)...

Laura Proctor
Laura Proctor on 6 Oct 2011
Are you receiving a message that the optimal solution has been found? What is the final message saying?

Jie Ning
Jie Ning on 6 Oct 2011
The exitflag is 1 or 2. I think that means at least 1 local minimum is found and some converge, right?

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!