How to determine Simplex using Nelder-Mead Algorithm in all direction?

7 Ansichten (letzte 30 Tage)
Dear All, how can I determine all the possibles simplexes while working with Nelder-Mead Algorithm? Please have a look into the illustrated picture along with codes.
function [xMin] = NMS2(objfunc,x0,alpha,beta,gamma,varargin)
N = length(x0);
% Initializing the simplex
smp = repmat(x0,1,N+1);
smp(:,2:end) = smp(:,2:end) + eye(N);
% Identify the vertices
fval = feval(objfunc,smp,varargin{:});
iter = 0;TOL = 1e-8; maxIter = 500*N;
while iter <= maxIter
% sort function values in ascending order
[fval,I2] = sort(fval);
smp = smp(:,I2);
v0 = smp(:,1);
f0 = fval(1);
fStd = std(fval);
distv0 = max(max(abs(repmat(v0,1,N)-smp(:,2:end))));
if fStd < TOL && distv0 < TOL
break;
end
vn = smp(:,N+1);
fn = fval(N+1);
%calculate the centroid over all vertices vi ~= vn
vert = mean(smp(:,1:N),2);
This is the partial code along with stopping condition.
  2 Kommentare
James Tursa
James Tursa am 10 Feb. 2020
I don't understand the question. What do you mean by "determine all the possible simplexes"?
Julkar_Mustakim
Julkar_Mustakim am 12 Feb. 2020
Dear James Tursa, If you have a look into the picture you will understand what I meant. Usually we find the simplex based on three points (V0,V1 & V2). But in this case the intial simplex could be any three points in any direction where "V0" is fixed but "V1 and V2" could be anywhere around "V0" like the way it is mentioned in the picture. I hope, I clarified the method. Thank you.

Melden Sie sich an, um zu kommentieren.

Antworten (1)

James Tursa
James Tursa am 12 Feb. 2020
Bearbeitet: James Tursa am 12 Feb. 2020
The Nelder-Mead Simplex Method is an adaptive method that adjusts the lengths and directions dynamically. The vertices could be anywhere on your plot above (and outside of it), not just at the square corner points and mid-points. So your desire to determine all possible simplexes simply doesn't make sense for this algorithm. There are an infinite number of them and an infinite variety of shapes and sizes.
  1 Kommentar
Julkar_Mustakim
Julkar_Mustakim am 14 Feb. 2020
Dear James, thanks for your answer. So it is possible to assign the points statically instead of dynamically around the point "V0"? Thank you.

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Quadratic Programming and Cone Programming finden Sie in Help Center und File Exchange

Produkte


Version

R2018a

Community Treasure Hunt

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

Start Hunting!

Translated by