Constraint Formulation doesnt work / is not applied to solution
Mostra commenti meno recenti
Hi everybody,
I have a problem with a specific constraint formulation. the problem requires to choose 4 players from a player pool (its a soccer problem) and maximizes expected points.
I want the optimizer to only pick players from a certain number of teams. For this I tried to use this:
% defining a new optimization variable
used_teams = optimvar('used_teams',length(teams),1,'Type','integer','LowerBound',0,'UpperBound',1);
% run variables
i = 1:length(teams);
t = 1:length(player_def);
%apply team info to optimization variable
soccer_lineup.Constraints.stack1 = used_teams(i) <= sum(def_team_info(i,t)*defense_lineup(t));
%set the maximum numbers of teams
def_teams = sum(used_teams);
soccer_lineup.Constraints.stack2 = def_teams <= 2;
My inspiration to code it like this came from a Github code in another language looking very similar:

The problem is, that it isnt applied to the problem. I can set the number of used teams to 0 and I still get a feasible solution (which should be impossible).(Yes the example from the other code is for more than 3 teams, but i want the optimizer to stack players from 2 teams. )
Does anyone see the mistake?
I would appreciate your help.
Kind regards,
Christian
8 Commenti
Walter Roberson
il 13 Dic 2019
When you say that you set the number of used teams to 0 do you mean that you change the upper bound in the optimization to 0 thereby forcing the vector to be all 0?
Christian Schumacher
il 13 Dic 2019
Walter Roberson
il 13 Dic 2019
It would help to have all your code.
Christian Schumacher
il 14 Dic 2019
Christian Schumacher
il 14 Dic 2019
Christian Schumacher
il 17 Dic 2019
Walter Roberson
il 18 Dic 2019
The input file would help. There is too much code for me to read it and mentally model it all and figure out all the combinations of circumstances in an input file that could potentially lead to problems.
Christian Schumacher
il 19 Dic 2019
Risposte (0)
Categorie
Scopri di più su Surrogate Optimization in Centro assistenza e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!