How can i bound initial guess during optimization
显示 更早的评论
i have initial Guess
A= [ 0 30 0 30 30 30 30 30];
i don't want compiler take other values than 0 or 30. It should change only sequence.
7 个评论
Walter Roberson
2015-12-19
编辑:Walter Roberson
2015-12-19
Which optimization routine are you using?
When you say that it should change only the sequence, do you mean that you want only permutations of A ?
Matt J
2015-12-19
Since there are only 2^8 possible values for A, an exhaustive combinatoric search might be easiest.
Triveni
2015-12-19
Walter Roberson
2015-12-19
If it is permutations of A, then only 28 of them are distinguishable.
Triveni
2015-12-19
Walter Roberson
2015-12-19
Do you need the solutions to be permutations of A, so that in theory you could just try all the permutations and take the best one? Or do you need the upper bound to be 30 and the lower bound to be 0 and you accept all values between those two?
Which optimization routine are you calling?
回答(1 个)
Walter Roberson
2015-12-20
Which input to ga() does this represent? If this is your x vector that is not explicitly passed in or initialized for ga(), then you would not use ga() at all: you would just call your objective function with all of the permutations .
A = [ 0 30 0 30 30 30 30 30];
Aperm = unique(perms(A),'rows');
best_perm = Aperm(1,:);
best_val = YourObjectiveFunction(best_perm);
for K = 2 : size(Aperm,1)
this_perm = Aperm(K,:);
this_val = YourObjectiveFunction(this_perm);
if this_val < best_val
best_perm = this_perm;
best_val = this_val;
end
end
类别
在 帮助中心 和 File Exchange 中查找有关 Genetic Algorithm 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!