[Rd] precedence (was 'historical NA question')

Simon Urbanek simon.urbanek at r-project.org
Wed May 7 23:45:23 CEST 2014


On May 7, 2014, at 5:17 PM, Hervé Pagès <hpages at fhcrc.org> wrote:

> On 05/07/2014 12:52 PM, Simon Urbanek wrote:
>> On May 7, 2014, at 3:37 PM, Hervé Pagès <hpages at fhcrc.org> wrote:
>> 
>>> No big deal. These things can be tricky:
>>> 
>>> https://stat.ethz.ch/pipermail/r-devel/2006-January/036022.html
>>> 
>>> Sorry I couldn't resist ;-)
>>> 
>> 
>> Yeah, but that's just yet another trip down the rabbit hole - why is -2 parsed as `-`(2) and not a single constant?
> 
> You wouldn't want -2 to be parsed as a single constant exactly for
> the reason that you wouldn't want -2^2 to return 4. Having -2^2 treated
> the same way as -x^2 is a sane feature.
> 

On what grounds? -2 is one value - negative two - and if you square it, you get four - so that's not even a question of precedence. It's just a matter of interpretation: do you see the constant -2 or do you see the constant 2 with unary minus? When you print -2 you get -2 - and that's not a positive constant with an unary minus - or is it? ;) - aaah, will we ever know … R is good at hiding that subtlety from us:

> a = quote(-2^2)
> b = bquote(.(-2)^2)
> a
-2^2
> b
-2^2
> eval(a)
[1] -4
> eval(b)
[1] 4


>> Is there a way to express a negative constant in R? Hmm…
> 
> Maybe some people have some use cases for this (speed ?).

Wrong tree ;). You kick-started the trip but failed to follow the path it takes into the depths of the human mind … :P (or was that computer mind? ;))

Cheers,
Simon



> Personally I don't. Of course it would require a special syntax,
> something that would probably be as ugly and confusing as the
> L suffix used for integer constants (L means long int in C).
> 
> H.
> 
>> 
>> 
>>> On 05/07/2014 09:16 AM, John Chambers wrote:
>>>> On 5/7/14, 5:21 AM, Therneau, Terry M., Ph.D. wrote:
>>>>> Hadley asked about the Blue book; my shelf still has the earlier brown
>>>>> book
>>>>>    Becker and Chambers, 1984, S: An interactive environment for data
>>>>> analysis and graphics.
>>>> 
>>>> Historically interesting, but there was never a guarantee that Version 3
>>>> of S (the "blue book") was back-compatible with earlier versions.  We
>>>> gave users some help in "getting on the road" to converting, that was
>>>> all (see Appendix 4 to the blue book).
>>>> 
>>>> For that one brief moment, we felt free to innovate.
>>>> 
>>>> John
>>>> 
>>>>> 
>>>>> The manual page for precedence is
>>>>> 
>>>>> $               component select
>>>>> %x              special operator
>>>>> -               unary minus
>>>>> :               sequence operator
>>>>> ^ **            exponentiation
>>>>> * /             mult/div
>>>>> + -             add/sub
>>>>> < > <= >= == != logical
>>>>> !               not
>>>>> & |             and/or
>>>>> <- ->           assignment
>>>>> 
>>>>> Terry Therneau
>>>>> 
>>>>> ______________________________________________
>>>>> R-devel at r-project.org mailing list
>>>>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>>> 
>>>> ______________________________________________
>>>> R-devel at r-project.org mailing list
>>>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>> 
>>> --
>>> Hervé Pagès
>>> 
>>> Program in Computational Biology
>>> Division of Public Health Sciences
>>> Fred Hutchinson Cancer Research Center
>>> 1100 Fairview Ave. N, M1-B514
>>> P.O. Box 19024
>>> Seattle, WA 98109-1024
>>> 
>>> E-mail: hpages at fhcrc.org
>>> Phone:  (206) 667-5791
>>> Fax:    (206) 667-1319
>>> 
>>> ______________________________________________
>>> R-devel at r-project.org mailing list
>>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>> 
>> 
> 
> -- 
> Hervé Pagès
> 
> Program in Computational Biology
> Division of Public Health Sciences
> Fred Hutchinson Cancer Research Center
> 1100 Fairview Ave. N, M1-B514
> P.O. Box 19024
> Seattle, WA 98109-1024
> 
> E-mail: hpages at fhcrc.org
> Phone:  (206) 667-5791
> Fax:    (206) 667-1319
> 



More information about the R-devel mailing list