Optimization through iteration - help!
Afficher commentaires plus anciens
I'm desperatley trying to optimize vector x such as its sum equals one.I need this for an optimization problem which can only be solved by iteration.. Thx for any adivce
best Jan
x = [0.125,0.125,0.125,0.125];
testf = sum(x);
test1 = 1;
while abs(test1-testf)~=0
test1 = testf;
testf = sum(x*2);
end
9 commentaires
Geoff Hayes
le 7 Mai 2015
Jan - your above example for x already sums to one, so perhaps give a different x. Also, what rules can you apply to your array on each iteration of the loop so that it eventually sums to one? Can you add elements or remove them or scale them?
Jan Morawietz
le 7 Mai 2015
Geoff Hayes
le 7 Mai 2015
Hmm...I misread your original values and just realized now that sum(x*2) is 1.0 which means that you are finished on the first iteration of your while loop.
So if they can be scaled, do they all have to be scaled identically or can some elements increase or decrease independent of the others?
Jan Morawietz
le 7 Mai 2015
Geoff Hayes
le 7 Mai 2015
What other rules must you enforce? Presumably I can't just set the first element to one and the remaining to all zeros. Is each element constrained to a certain interval?
Jan Morawietz
le 7 Mai 2015
Jan Morawietz
le 7 Mai 2015
Geoff Hayes
le 8 Mai 2015
Jan - the code never resets the weight array so you will get the same answer on each iteration of the while loop. And multiplying the weights by a number less than one will mean that
sum(weight*0.2) < sum(weight)
always since each element of weight is less than one.
Jan Morawietz
le 8 Mai 2015
Réponses (1)
Thorsten
le 7 Mai 2015
x = 1/sum(x)*x;
3 commentaires
Jan Morawietz
le 7 Mai 2015
Modifié(e) : Jan Morawietz
le 7 Mai 2015
Thorsten
le 8 Mai 2015
Hi Jan, yes, x is the weight vector. But why do you need an iteration when you can get the solution in one step? Is it homework?
Jan Morawietz
le 8 Mai 2015
Catégories
En savoir plus sur Third-Party Cluster Configuration dans Centre d'aide et File Exchange
Produits
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!