[Rd] ifelse

Peter Dalgaard p.dalgaard at biostat.ku.dk
Tue Aug 19 08:57:56 CEST 2008


Prof Brian Ripley wrote:
> Another way of looking at this is that ifelse(TRUE, character(0), "") 
> asks for a length-one result 
Just to rub it in: The length of an ifelse() computation is the length 
of the  "test" argument, so there is no way you should expect 
character(0) as the result. (The class of the result is also taken from 
"test", which is arguably one of the lesser convenient features in R.)

> containing the first element of yes=character(0), and character(0)[1] 
> is NA_character_
>
> I suspect if(TRUE) character(0) else "" was intended.
>
> On Mon, 18 Aug 2008, Marc Schwartz wrote:
>
>> on 08/18/2008 06:35 PM Heikki Kaskelma wrote:
>>> I find it slightly surprising, that
>>>
>>> ifelse(TRUE, character(0), "")
>>>
>>> returns NA instead of character(0).
>>>
>>> [WNT 2.6.2 Patched]
>>
>> Time to upgrade...  :-)
>>
>>
>> The same behavior is in:
>>
>>  R version 2.7.2 beta (2008-08-16 r46368)
>>
>>
>> The reason for this is that the internal code for ifelse() has:
>>
>>    if (any(test[!nas]))
>>        ans[test & !nas] <- rep(yes, length.out = length(ans))[test &
>>            !nas]
>>
>> where the key code is:
>>
>>  rep(yes, length.out = length(ans))
>>
>> In this case, 'yes' is character(0) and 'ans' is TRUE.
>>
>> Thus, you get:
>>
>>  > rep(character(0), length.out = length(TRUE))
>>  [1] NA
>>
>>
>> This behavior is documented in ?rep, where in the Details section you
>> will find:
>>
>> "If x has length zero and length.out is supplied and is positive, the
>> values are filled in using the extraction rules, that is by an NA of the
>> appropriate class for an atomic vector (0 for raw vectors) and NULL for
>> a list. "
>>
>> Thus:
>>
>>> class(rep(character(0), length.out = length(TRUE)))
>> [1] "character"
>>
>>
>> which shows that the NA that is returned is of class character, which is
>> the class for character(0).
>


-- 
   O__  ---- Peter Dalgaard             Øster Farimagsgade 5, Entr.B
  c/ /'_ --- Dept. of Biostatistics     PO Box 2099, 1014 Cph. K
 (*) \(*) -- University of Copenhagen   Denmark      Ph:  (+45) 35327918
~~~~~~~~~~ - (p.dalgaard at biostat.ku.dk)              FAX: (+45) 35327907



More information about the R-devel mailing list