[Rd] [EXTERNAL] Re: Re: all.equal failure

Duncan Murdoch murdoch@dunc@n @end|ng |rom gm@||@com
Fri Apr 5 17:12:48 CEST 2019


On 05/04/2019 10:46 a.m., Therneau, Terry M., Ph.D. wrote:
> 
> 
> On 4/5/19 9:39 AM, Duncan Murdoch wrote:
>> On 05/04/2019 10:19 a.m., Therneau, Terry M., Ph.D. wrote:
>>> Duncan,
>>>     I should have included it in my original note, but
>>>
>>>        all.equal(unclass(t0x), unclass(t1x))
>>>
>>> returns TRUE as well.  I had tried that as well.   But a further look at
>>> all.equal.default shows the following line right near the top:
>>>       if (is.language(target) || is.function(target))
>>>           return(all.equal.language(target, current, ...))
>>>
>>> and that path explicitly ignores attributes.
>>
>> Which R version are you using?  I see deparse(target) and deparse(current) in
>> all.equal.language(), and those should not be ignoring attributes according to the
>> documentation.
>>
> I'm using today's version of R-devel on Ubuntu.  (svn up this AM)
> But I agree, both target and current appear.

That's not what I said.  I said that the attributes should not be 
ignored in that function.  I don't see anything in the R-devel version 
of it that ignores attributes:

 > all.equal.language
function (target, current, ...)
{
     mt <- mode(target)
     mc <- mode(current)
     if (mt == "expression" && mc == "expression")
         return(all.equal.list(target, current, ...))
     ttxt <- paste(deparse(target), collapse = "\n")
     ctxt <- paste(deparse(current), collapse = "\n")
     msg <- c(if (mt != mc) paste0("Modes of target, current: ",
         mt, ", ", mc), if (ttxt != ctxt) {
         if (pmatch(ttxt, ctxt, 0L)) "target is a subset of current" 
else if (pmatch(ctxt,
             ttxt, 0L)) "current is a subset of target" else "target, 
current do not match when deparsed"
     })
     if (is.null(msg))
         TRUE
     else msg
}
<bytecode: 0x7fd9e792f1e0>
<environment: namespace:base>


Duncan Murdoch



> 
>> Duncan Murdoch
>>
>>>
>>> I'll change my original original title to "all.equal was not a good tool for testing
>>> certain code issues".
>>>
>>> Thanks for the pointer,
>>>
>>> Terry
>>>
>>>
>>>
>>> On 4/5/19 9:00 AM, Duncan Murdoch wrote:
>>>> On 05/04/2019 9:03 a.m., Therneau, Terry M., Ph.D. via R-devel wrote:
>>>>> This arose in testing [.terms and has me confused.
>>>>>
>>>>> data(esoph)   # use a standard data set
>>>>>
>>>>> t0x <- terms(model.frame( ~ tobgp, data=esoph))
>>>>> t1 <-  terms(model.frame(ncases ~ agegp + tobgp, data=esoph))
>>>>> t1x <- (delete.response(t1))[-1]
>>>>>
>>>>>    > all.equal(t0x, t1x)
>>>>> [1] TRUE
>>>>>
>>>>> # the above is wrong, because they actually are not the same
>>>>>
>>>>>    > all.equal(attr(t0x, 'dataClasses'), attr(t1x, 'dataClasses'))
>>>>> [1] "Names: 1 string mismatch"
>>>>> [2] "Lengths (1, 2) differ (string compare on first 1)"
>>>>
>>>> As documented, all.equal() is generic, with methods for different classes.  The
>>>> classes of both t0x and t1x are
>>>>
>>>>   c("terms","formula")
>>>>
>>>> with no all.equal.terms method, so all.equal.formula is called. That method isn't
>>>> specifically documented, but you can see its definition as
>>>>
>>>> function (target, current, ...)
>>>> {
>>>>      if (length(target) != length(current))
>>>>          return(paste0("target, current differ in having response: ",
>>>>              length(target) == 3L, ", ", length(current) == 3L))
>>>>      if (!identical(deparse(target), deparse(current)))
>>>>          "formulas differ in contents"
>>>>      else TRUE
>>>> }
>>>>
>>>> So the issue is that deparse(t0x) and deparse(t1x) give the same strings with no
>>>> attributes shown, even though "showAttributes" is set by default.   I haven't traced
>>>> through the C code to see where things are going wrong.
>>>>
>>>> Duncan Murdoch
>>>>
>>>>>
>>>>>    > sessionInfo()
>>>>> R Under development (unstable) (2019-04-05 r76323)
>>>>> Platform: x86_64-pc-linux-gnu (64-bit)
>>>>> Running under: Ubuntu 18.04.2 LTS
>>>>>
>>>>> Matrix products: default
>>>>> BLAS:   /usr/local/src/R-devel/lib/libRblas.so
>>>>> LAPACK: /usr/local/src/R-devel/lib/libRlapack.so
>>>>>
>>>>> locale:
>>>>>     [1] LC_CTYPE=en_US.UTF-8       LC_NUMERIC=C
>>>>>     [3] LC_TIME=en_US.UTF-8        LC_COLLATE=C
>>>>>     [5] LC_MONETARY=en_US.UTF-8    LC_MESSAGES=en_US.UTF-8
>>>>>     [7] LC_PAPER=en_US.UTF-8       LC_NAME=C
>>>>>     [9] LC_ADDRESS=C               LC_TELEPHONE=C
>>>>> [11] LC_MEASUREMENT=en_US.UTF-8 LC_IDENTIFICATION=C
>>>>>
>>>>> attached base packages:
>>>>> [1] stats     graphics  grDevices utils     datasets methods base
>>>>>
>>>>> loaded via a namespace (and not attached):
>>>>> [1] compiler_3.7.0 tools_3.7.0
>>>>>
>>>>>
>>>>>      [[alternative HTML version deleted]]
>>>>>
>>>>> ______________________________________________
>>>>> R-devel using r-project.org mailing list
>>>>> https://stat.ethz.ch/mailman/listinfo/r-devel
>>>>>
>>>>
>>>
>>
>



More information about the R-devel mailing list