我尝试在r&#34中编写程序;使用函数"从任何分布生成随机样本。但它在hist.default(xbars)中显示"错误:' x'必须是数字" 我的程序在这里
sim.clt <- function(n, ran.func,..., simsize,...)
{
xbars<-vector()
for(i in 1:simsize=simsize)
{
x<-function(ran.func)
xbars[i]<-mean(x)
}
par(mfrow=c(2,1))
hist(xbars)
qqnorm(xbars)
return(xbars)
}
sim.out<-sim.clt(n=20,ran.func="rexp",simsize=5000)
shapiro.test(sim.out)
我是r编程的新手,所以无法弄明白,如何解决问题。 感谢...
答案 0 :(得分:6)
这里有很多不妥之处。
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
的任何参数,即使只是使用n
的示例中的rexp
。
错误消息源于最后一点。您将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