这是我的数据:
a <- c(60, 65, 70, 75, 80, 85, 90, 95, 100, 105)
b <- c(26, 24.7, 20, 16.1, 12.6, 10.6, 9.2, 7.6, 6.9, 6.9)
a_b <- cbind(a,b)
plot(a,b, col = "purple")
abline(lm(b ~ a),col="red")
reg <- lm(b ~ a)
我想使用预测函数来计算110处预测b值的标准误差。
z <- predict(reg, newdata=data.frame(year=110), se.fit=TRUE)
这是我得到的输出,但我认为这只是给了我10个时间点的标准误差,而不是新的第11个数据点:
z
$fit
1 2 3 4 5 6 7 8 9 10
24.456364 22.146061 19.835758 17.525455 15.215152 12.904848 10.594545 8.284242 5.973939 3.663636
$se.fit
1 2 3 4 5 6 7 8 9 10
1.2616229 1.0700007 0.8998935 0.7657760 0.6889958 0.6889958 0.7657760 0.8998935 1.0700007 1.2616229
$df
[1] 8
$residual.scale
[1] 2.146516
我不知道该怎么做,感谢任何帮助!
答案 0 :(得分:2)
您应该对data.frames内外的数据更加小心。你的newdata =参数应该是一个data.frame,其列名与原始的prodicters相匹配。像这样的东西会更好
a_b <- data.frame(
a=c(60, 65, 70, 75, 80, 85, 90, 95, 100, 105),
b=c(26, 24.7, 20, 16.1, 12.6, 10.6, 9.2, 7.6, 6.9, 6.9)
)
plot(b~a, a_b, col = "purple")
reg <- lm(b ~ a, a_b)
abline(reg,col="red")
z <- predict(reg, newdata=data.frame(a=110), se.fit=TRUE)
# $fit
# 1
# 1.353333
#
# $se.fit
# [1] 1.466349
#
# $df
# [1] 8
#
# $residual.scale
# [1] 2.146516