Two more R/S differences
Martin Maechler
Martin Maechler <maechler@stat.math.ethz.ch>
Wed, 7 Jan 1998 09:29:02 +0100
(Another discussion out of R-core,
I think anyone in R-devel might have an opinion -- MM):
>>>>> "KH" == Kurt Hornik <hornik@ci.tuwien.ac.at> writes:
>>>>> Martin Maechler writes:
>>>>> "KH" == Kurt Hornik <Kurt.Hornik@ci.tuwien.ac.at> writes:
KH> * Bug or feature?
R> NULL + NULL
real(0)
R> NULL > NULL
Error: comparison is possible only for vector types
R> NULL & NULL
Error in NULL & NULL : operations are possible only for numeric or
logical types
KH> whereas S-PLUS:
>>>> NULL > NULL
NULL
>>>> NULL + NULL
NULL
>>>> NULL & NULL
NULL
>> NULL + NULL real(0) and NULL are not so different.. I think R is
>> better here...
>> The other two: R (once more) is stricter in order to help avoiding
>> buggy code.
>> In R,
>>> real(0) > integer(0)
>> logical(0)
>> Therefore, I don't see why NULL > NULL should work...
>> In sum, I think R behaves as we want, and the different behavior
>> should go into the FAQ and probably also be mentioned in some *.Rd
>> files.
KH> Again, I am not entirely convinced yet.
you are right, me neither anymore..
We should discuss this some more
KH> Why does adding two empty objects give something non-NULL? To me,
KH> this seems to violate `nihil nihilo fit' (the ``no-arbitrage
KH> condition'').
I think the paradigm is
NULL := list of length 0 + is sometimes coerced to vector of length 0
~~~~~~~~~
real(0) := numeric(0) = numeric vector of length 0
The real point of discussion is:
-------------------------------------------------------------------------
## In which situations should
## NULL silently be coerced to numeric(0) / logical(0) / character(0) ?
--------------------------------------------------------------------------
Currently, S does this silent coercion very often
while R does not.
I start thinking that maybe R should change here.
KH> Also, why is it o.k. to ADD two empty objects, but not to compare
KH> them? (Shouldn't two NULL objects be the same?)
KH> Btw, the code in chron that got me started on this was
KH> if(any(o1 != o2))
KH> trying to figure out whether two origins (o1, o2) were different.
KH> Under R, this code fails if at least one of the origins is NULL.
KH> What is the right way of coding this? (Surely not the
KH> if(any(o1 - o2))
KH> I changed it to :-))
All was ok, if both o1 and o2 where never NULL but rather numeric(0),
however see above.
-- Martin
-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-
r-devel mailing list -- Read http://www.ci.tuwien.ac.at/~hornik/R/R-FAQ.html
Send "info", "help", or "[un]subscribe"
(in the "body", not the subject !) To: r-devel-request@stat.math.ethz.ch
_._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._