why coding this function returns un exact numerical results?

Ackley's Function (a=20,b=0.2) d=2.
function [ y ] = objfun14 (phen )
d=size(phen,2);
v=cos(2*pi*phen); x=(1/d)* sum(v,2);
t=-20*exp(-0.2*sqrt((1/d)*sum(phen.^2,2))) - exp( x ) +20+exp(1);
y=sum(t,2);
end
%when phen=[0 0] the output should be t=0 however excuting the code gives t=8.8818e-16

1 commentaire

t=8.8818e-16 is pretty close to zero. You are dealing with floating point arithmetic, that's why the result is not exactly what you expect. See Floating-Point Numbers for further details.

Connectez-vous pour commenter.

Réponses (1)

Kishan Dhakan
Kishan Dhakan le 23 Juin 2021
Try using 'format long', which shows 15 decimal places. If it still doesn't work, then your value is probably smaller than what many call 'machine epsilon' and hence is getting rounded to zero.

1 commentaire

The other way around, the function is returning -4*eps when the user expects 0

Connectez-vous pour commenter.

Catégories

En savoir plus sur Matrices and Arrays dans Centre d'aide et File Exchange

Question posée :

le 22 Juin 2021

Commenté :

le 23 Juin 2021

Community Treasure Hunt

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

Start Hunting!

Translated by