[R] number of decimal places in a number?

Jim Plante jimplante at me.com
Mon Jul 9 14:52:18 CEST 2012


I don't know how significant this is, but WolframAlpha's value of pi disagrees with R's at about the 16th decimal:
 
Wpi->3.141592653589793238462643383279502884197169399375105
......................^
Rpi->3.14159265358979311599796346854418516

Probably not of interest to anyone but astronomers, nanotechnologists, and us anal lurkers though. We went to the moon and back on two decimal places.

Jim Plante

On Jul 8, 2012, at 1:39 PM, arun wrote:

> Hi Petr,
> 
> I think sprintf and formatC are identical as it can round >22 decimal places as opposed to print and signif
> print(pi,digits=35)
> Error in print.default(pi, digits = 35) : invalid 'digits' argument
>  signif(pi,digits=22)
> [1] 3.141593
> a<-sprintf("%.35f",pi)
> a
> [1] "3.14159265358979311599796346854418516"
> b<-formatC(pi,digits=36)
>  b
> [1] "3.14159265358979311599796346854418516"
> 
>  identical(a,b)
> [1] TRUE
> 
> 
> identical(a,signif(pi,digits=35))
> [1] FALSE
> 
> 
> A.K.
> 
> 
> 
> ----- Original Message -----
> From: Petr Savicky <savicky at cs.cas.cz>
> To: r-help at r-project.org
> Cc: 
> Sent: Sunday, July 8, 2012 2:21 PM
> Subject: Re: [R] number of decimal places in a number?
> 
> On Sat, Jul 07, 2012 at 01:12:34PM +0100, Ted Harding wrote:
>> I had thought of also (as well as my numerical routing) suggesting
>> a "gsub()" type solution like Joshua's below, but held back because
>> the result could depend on how the number arose (keyboard input,
>> file input, or from computation within R).
>> 
>> However, I now also realise that (again because of binary rounding
>> errors), the "gsub()" method has interesting differences from my
>> numerical method. Example:
>> 
>> [A] (as from my original method):
>>    f(123456789.123456789)
>>    # [1] 7
>> 
>> [B] (the "gsub()" method)
>>    nchar(gsub("(.*\\.)|([0]*$)", "", as.character(123456789.123456789)))
>>    # [1] 6
>> 
>> Now look at:
>> 
>> [C] (what as.character() does to 123456789.123456789)
>>    as.character(123456789.123456789)
>>    # [1] "123456789.123457"
>> 
>> [D] ("22" is the maximum number of decimal digits for print())
>>    print(123456789.123456789,22)
>>    # [1] 123456789.1234568
>> 
>> So as.character() has rounded it to 6 decimal places (agreeing
>> with [B]), while using print() with the maximum of 22 digits
>> (more than enough for the 18 digits in 123456789.123456789)
>> rounds it to 7 decimal places (i.e. 16 digits in all), which
> 
> Hi.
> 
> This difference is due to rounding to 15 digits in as.character().
> This function rounds to 15 decimal digits, which is the maximum
> number of digits, which can always be converted to binary
> and back. Function print(, digits=22) prints the decimal
> equivalent of the represented number. So, it is more accurate, but
> its output may contain digits, which are purely the consequence
> of inaccuracy of the representation.
> 
> The same output as from print(, digits=17) may be obtained
> using
> 
>    sprintf("%20.17f", x)
> 
> Of course, if the required number of digits is close to 17 or
> even more, the last digits are the last digits of the represented
> number, not of the intended result of the computation.
> 
> Hope this helps.
> 
> Petr Savicky.
> 
> ______________________________________________
> 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.
> 
> 
> ______________________________________________
> 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.



More information about the R-help mailing list