[R] rounding in calculation

Prof Brian Ripley ripley at stats.ox.ac.uk
Fri Mar 21 16:44:11 CET 2008


On Fri, 21 Mar 2008, John Lande wrote:

> dear all,
>
> I report a problem very simple, that I does non know how to handle.
>
> look at the following code:
>
>> a = rep(16.256, 5)
>> sum(a[1:5]^2) - (sum(a[1:5])^2/5)
> [1] 2.273737e-13
>
> as you can see i retrieve a non 0 value, when i am expected to. what can I
> do?

Use mean() when you want a mean:

> sum(a[1:5]^2) - 5*mean(a[1:5])^2
[1] 0

Your number is not exactly representable so some rounding error would be 
acceptable, but there are more accurate ways to do this, e.g.

sum((a-mean(a))^2)

or make use of var(), which is written by someone knowledgable about these 
things.

>
>> sessionInfo()
> R version 2.6.2 (2008-02-08)
> i386-pc-mingw32
>
> locale:
> LC_COLLATE=Italian_Italy.1252;LC_CTYPE=Italian_Italy.1252;LC_MONETARY=Italian_Italy.1252;LC_NUMERIC=C;LC_TIME=Italian_Italy.1252
>
> attached base packages:
> [1] stats     graphics  grDevices utils     datasets  methods   base
>
> loaded via a namespace (and not attached):
> [1] rcompgen_0.1-17
>
> 	[[alternative HTML version deleted]]
>
> ______________________________________________
> R-help at r-project.org mailing list
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
> and provide commented, minimal, self-contained, reproducible code.
>

-- 
Brian D. Ripley,                  ripley at stats.ox.ac.uk
Professor of Applied Statistics,  http://www.stats.ox.ac.uk/~ripley/
University of Oxford,             Tel:  +44 1865 272861 (self)
1 South Parks Road,                     +44 1865 272866 (PA)
Oxford OX1 3TG, UK                Fax:  +44 1865 272595



More information about the R-help mailing list