Data arithmatic addition with single precision

1 visualización (últimos 30 días)
GAGARIN  BISWAL
GAGARIN BISWAL el 27 de Sept. de 2019
Editada: James Tursa el 27 de Sept. de 2019
Hello
I am adding 21 elements of an array by two different methods. The two methods should show same value. But while printing the results the are different. Please suggest.
clc
clear all
close all
x=rand(1,100)*10^16;
x = single(x)
method1 = sum(x(1:21))+x(22)-x(1);
method2 = sum(x(2:22));
sprintf('%f',method1)
sprintf('%f',method2)
Regards,
Gagarin

Respuestas (1)

James Tursa
James Tursa el 27 de Sept. de 2019
Editada: James Tursa el 27 de Sept. de 2019
Floating point operations will often yield slightly different results if you change the order of operations. This is to be expected.

Community Treasure Hunt

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

Start Hunting!

Translated by