这里有很多问题。
for(i in 1:simsize=simsize)
应该会报错:
> for(i in 1:simsize=simsize) { print(i)}
Error: unexpected '=' in "for(i in 1:simsize="
更好的是
for(i in seq_len(simsize))
然后
x <- function(ran.func)
没有按照你的想法做;它返回一个以xbars[i]<-mean(x) 为主体的函数,如:
> x <- function(ran.func)
+
+ xbars[i]<-mean(x)
> x
function(ran.func)
xbars[i]<-mean(x)
> is.function(x)
[1] TRUE
我想你想打电话给ran.func,所以你可能需要
FUN <- match.fun(ran.func)
x <- FUN()
但这会失败,因为您似乎没有传递任何参数以使 ran.func 起作用,即使在使用 rexp 的示例中只是 n。
错误消息源于最后一点。您将xbars 定义为空的vector(),默认情况下它创建了一个空的逻辑向量:
> xbars <- vector()
> xbars
logical(0)
> is.numeric(xbars)
[1] FALSE
现在,如果您在定义 x 时没有犯错误,这不会是一个问题(回想一下,xbars[i]<-mean(x) 现在位于函数 x 的主体中,并且从未被显式调用),这意味着xbars 仍然是一个空的逻辑向量。由于这不是数字,hist 会抛出您看到的错误。
另一个错误是你不能在函数定义中使用两次...。您是否试图让第一个包含参数传递给 ran.func 和第二个 ... 传递给别的东西。你只是不能在 R 中做到这一点。
这是你想要的吗?
sim.clt <- function(n, ran.func, simsize, ...) {
## ... passed to ran.func for other parameters of distribution
xbars <- numeric(simsize)
for(i in seq_len(simsize)) {
FUN <- match.fun(ran.func)
x <- FUN(n = n, ...)
xbars[i] <- mean(x)
}
## plot
op <- par(mfrow=c(2,1))
on.exit(op)
hist(xbars)
qqnorm(xbars)
xbars
}
> sim.out<-sim.clt(n=20,ran.func="rexp",simsize=5000)
> shapiro.test(sim.out)
Shapiro-Wilk normality test
data: sim.out
W = 0.9867, p-value < 2.2e-16