5

我对 dot-dot-dot 论点的范围有疑问。考虑以下函数`foo =

foo <- function(x, ...){
   require(classInt);
   intvl = classIntervals(x, ...);
   return(intvl);
 }

该函数适用于以下调用

x = runif(100, 0, 100);
y1 = foo(x, n = 5, style = 'quantile');
y2 = foo(x, style = 'equal');

但是当我尝试使用 style = 'fixed' 参数时,它也需要一个 fixedBreaks 参数,我得到

y3 = foo(x, style = 'fixed', fixedBreaks = seq(0, 100, 20))

eval(expr, envir, enclos) 中的错误:... 列表不包含 2 个元素

请注意,以下工作完美

y5 = classIntervals(x, style = 'fixed', fixedBreaks = seq(0, 100, 20))

我怀疑这与范围规则有关,但一直无法确定。对此的任何帮助将不胜感激。

编辑。我拼凑了一个更简单的 hack 让它工作。我认为这是一个 match.call 问题,因为 style = 'pretty' 也存在同样的问题。快速浏览一下代码就会发现,这两种风格都是针对这种风格进行 match.call 的,所以这很可能是错误的来源。无论如何,这是我提出的 hack

foo2 <- function(x, ...){
  require(classInt);
  y = list(...); y$var = x;
  intvl = do.call('classIntervals', y);
}

y6 = foo2(x, style = 'fixed', fixedBreaks = seq(0, 100, 20))

我认为 Richie 对我的问题的回答揭示了为什么我之前的代码无法正常工作。但是,我仍然不明白为什么会这样。

4

1 回答 1

2

foo函数内部,省略号确实包含 2 个元素。调用此修改以查看此内容。

foo <- function(x, ...){
   require(classInt);
   print(list(...))
   intvl = classIntervals(x, ...);
   return(intvl);
 }

一旦classIntervals被调用,省略号就会改变,因为参数的匹配方式不同。这是该函数的签名

 classIntervals(var, n, style = "quantile", rtimes = 3, ...,
    intervalClosure = "left", dataPrecision = NULL)

在您失败的呼叫中,您有三个参数

foo(x, style = 'fixed', fixedBreaks = seq(0, 100, 20))

x通过位置匹配得到var匹配(即,因为它在每种情况下都位于签名中的第一个位置)。

style通过名称匹配匹配到style(因为它们具有相同的名称,duh)。

fixedBreaks不能按位置或名称匹配,因此它以点结尾。

因此,省略号包含 1 个参数,并且错误“...列表不包含 2 个元素”是正确的(如果相当愚蠢的话)。


编辑:建议修复classIntervals. 如果您正在联系作者,则建议替换第 42-43 行

mc <- match.call(expand.dots = FALSE)
fixedBreaks <- sort(eval(mc$...$fixedBreaks))

fixedBreaks <- list(...)$fixedBreaks

这就是(我认为)他们的意思,并且似乎解决了愚蠢的错误信息。

于 2011-03-06T21:00:47.157 回答