fmincon and constrains
1 vue (au cours des 30 derniers jours)
Afficher commentaires plus anciens
Hello, I have a funktion f(x)
f and x are vector which I want to minimize with fmincon()
How can I implement follwing constrain:
x~=y this means the solution x is unequal to a vector y that I know
0 commentaires
Réponse acceptée
Titus Edelhofer
le 16 Juin 2012
Hi,
if you know that x(1)=a why don't you take x(1) out of the optimization problem? But if you want to keep it, just let lb(1)=ub(1)=a (i.e., lower and upper bound for x(1)=a).
For the first one: this is equal to saying
abs(x-y)>=aConst
where aConst is some value saying who "unequal" they shoud be. Reformulating as
-abs(x-y)+aConst<=0
gives a nonlinear constraint, see doc for fmincon.
Titus
4 commentaires
Titus Edelhofer
le 16 Juin 2012
Look here:
http://www.mathworks.de/help/toolbox/optim/ug/fmincon.html
look out for "nonlcon". In fact it's for you: c = -abs(x-y) + aConst;
Plus de réponses (2)
Sargondjani
le 17 Juin 2012
if you want to minimize all the values in the vector, you can sum them and use that as your objective....
about the not equal thing: i think it will make your problem non-differentiable, so you can not use fmincon in this way...
you would have to do it some other way: solve fmincon for all discrete cases or use genetic algorithm
2 commentaires
Sargondjani
le 17 Juin 2012
why not?? im mean, if you minimize 10 values that is the same as taking the minimum of the sum of those values... although you have to be carefull with scaling (the change in the objective of each fi)
Voir également
Catégories
En savoir plus sur Solver Outputs and Iterative Display dans Help Center et File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!