[Rd] [Kurt.Hornik at wu-wien.ac.at: Re: range( <dates>, na.rm = (PR#10509)

P.Dalgaard at biostat.ku.dk P.Dalgaard at biostat.ku.dk
Tue Dec 11 16:55:04 CET 2007


Kurt.Hornik at wu-wien.ac.at wrote:
> ------- Start of forwarded message -------
> Date: Tue, 13 Nov 2007 21:44:57 +0100
> To: Steve Mongin <sjm at ccbr.umn.edu>
> Cc: cran at r-project.org
> Subject: Re: range( <dates>, na.rm =3D TRUE )
> In-Reply-To: <200711062044.OAA14064 at minnow.ccbr.umn.edu>
> Reply-To: Kurt.Hornik at wu-wien.ac.at
> From: Kurt Hornik <Kurt.Hornik at wu-wien.ac.at>
> X-AntiVirus: checked by AntiVir MailGate (version: 2.1.3-2; AVE: 7.6.0.=
34; VDF: 7.0.0.210; host: fsme.wu-wien.ac.at)
> X-Virus-Scanned: ClamAV 0.90.3/4768/Tue Nov 13 18:25:08 2007 on pocken.=
wu-wien.ac.at
> X-Virus-Status: Clean
>
>  =20
>>>>>> Steve Mongin writes:
>>>>>>            =20
>
>  =20
>> Dear CRAN:
>> I am running 'R' on Linux as follows:
>>    =20
>
>  =20
>>> version
>>>      =20
>>                _                          =20
>>   platform       i686-redhat-linux-gnu      =20
>>   arch           i686                       =20
>>   os             linux-gnu                  =20
>>   system         i686, linux-gnu            =20
>>   status                                    =20
>>   major          2                          =20
>>   minor          6.0                        =20
>>   year           2007                       =20
>>   month          10                         =20
>>   day            03                         =20
>>   svn rev        43063                      =20
>>   language       R                          =20
>>   version.string R version 2.6.0 (2007-10-03)
>>    =20
>
>
>  =20
>> I have a question about the behavior of "range()" with missing dates.
>>    =20
>
>  =20
>> With the previous version (2.4?) , the command:
>>    =20
>
>  =20
>>> range( as.Date( c( "2007-11-06", NA ) ), na.rm =3D TRUE )
>>>      =20
>
>  =20
>> yielded:
>>    =20
>
>  =20
>>> [1] "2007-11-06" "2007-11-06"
>>>      =20
>
>  =20
>> Now I get:
>>    =20
>
>  =20
>>> [1] NA NA
>>>      =20
>
>  =20
>> Is this a bug?
>>    =20
>
>  =20
>> Yes, I see in the "What's New" page:
>>    =20
>
>  =20
>>   "The Math2 and Summary groups (round, signif, all, any, max, min,
>>    summ, prod, range) are now primitive."
>>    =20
>
>  =20
>> Is the "primitive" characteristic supposed to behave as above with
>> missing dates?
>>    =20
>
>  =20
>> Thanks for any help that you can provide.
>>    =20
>
> This is really a question for r-devel or r-bugs, I think, but not for
> the CRAN maintainers.
>
> I would think it is a bug.  Perhaps simply file a bug report?
>
>  =20
Again? ;-)

The bug is here:

> range.default
function (..., na.rm =3D FALSE, finite =3D FALSE)
{
    x <- c(..., recursive =3D TRUE)
    if (is.numeric(x)) {
        if (finite)
            x <- x[is.finite(x)]
        else if (na.rm)
            x <- x[!is.na(x)]
    }
    c(min(x), max(x))
}
<environment: namespace:base>

Objects of class Date are not considered numeric, so we end up taking
min and max without removing NA.

One solution could be

if (is.numeric(x) || inherits(x, "Date") ){....}


--=20
   O__  ---- Peter Dalgaard             =C3=98ster Farimagsgade 5, Entr.B=

  c/ /'_ --- Dept. of Biostatistics     PO Box 2099, 1014 Cph. K
 (*) \(*) -- University of Copenhagen   Denmark          Ph:  (+45) 35327=
918
~~~~~~~~~~ - (p.dalgaard at biostat.ku.dk)                  FAX: (+45) 35327=
907



More information about the R-devel mailing list