[Rd] Surprising behavior of letters[c(NA, NA)]
Duncan Murdoch
murdoch.duncan at gmail.com
Fri Dec 17 15:58:52 CET 2010
On 17/12/2010 9:32 AM, Gabor Grothendieck wrote:
> Consider this:
>
> > letters[c(2, 3)]
> [1] "b" "c"
> > letters[c(2, NA)]
> [1] "b" NA
> > letters[c(NA, 3)]
> [1] NA "c"
> > letters[c(NA, NA)]
> [1] NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA NA
> [26] NA
>
> The result is a 2-vector in each case until we get to c(NA, NA) and
> then it unexpectedly changes from returning a 2-vector to returning a
> 26-vector. I think most people would have expected that the answer
> would be c(NA, NA).
>
This is because c(NA, NA) is a logical vector, so it gets recycled to
the length of letters, whereas c(NA, 3) and the others are numeric
vectors, so they aren't recycled, they're converted to integer indices.
So the surprise is due to not recognizing that NA is logical. You
wouldn't expect a length 1 result from letters[TRUE], would you?
Duncan Murdoch
More information about the R-devel
mailing list