在R中分割数据和拟合

4

我有1951年的以下降雨数据:

dat.1951=c(122,122,122,122,122,122,122,122,122,122,122,121,121,121,121,120,119,119,117,117,117,115,115,115,114,112,112,111,110,109,106,105,104,103,102,99,97,95,91,89,88,86,84,83,83,82,82,79,77,77,76,74,74,72,72,71,70,69,66,65,64,61,61,58,56,56,54,53,51,49,48,47,46,46,46,45,42,40,39,38,37,36,36,35,34,33,33,32,30,30,29,28,28,27,25,25,23,22,21,20,20,20,20,20,19,19,18,18,18,16,16,15,15,15,15,15,14,14,14,14,14,14,14,14,14,14,14,13,13,12,12,11,11,11,11,11,11,11,11,11,11,11,11,11,11,10,10,10,9,8,8,8,8,8,8,8,8,8,8,8,8,7,7,6,6,6,6,5,5,5,4,4,4,4,4,4,4,4,4,4,4,4,4,4,4,3,3,3,3,3,2,2,2,2,2,2,2,2,2,2,2,1,1)

我想拟合这些数据。 我将这些数据分成两个区域(头部和尾部)。 一个是小于100的点(头部),另一个是大于100的点(尾部)。 我可以对头部进行指数拟合(请参见下面的代码)。 对于尾部,我想拟合曲线,并希望在单个图中同时绘制两个部分以及数据。 有人能帮忙吗?

dat.1951<-dat.1951[dat.1951 > 0]
dat.1951.tail<-dat.1951[dat.1951 >= 100]
dat.1951.head<-dat.1951[dat.1951 < 100]
x.head<-seq(1,length(dat.1951.head))
log.data<-log(dat.1951.head)
idf.head<-data.frame(x.head,dat.1951.head)
idf.head$dat.1951.head<-log(idf.head$dat.1951.head)
model=lm(idf.head$dat.1951.head ~ idf.head$x.head,data=idf.head)
summary(model)

plot(dat.1951.head)
lines(idf.head$x.head,exp(fitted(model)),col="blue")

2
我想拟合一条曲线。这是什么意思? - Roland
1个回答

1
我不确定为什么你想要(1)将数据分成两个区域,(2)排除没有降雨的记录,和(3)拟合你所描述的模型。你可能需要就这些问题咨询统计学家。
但是,为了回答你的问题,我举了第二个模型的例子,并在同一图上展示了两个模型的拟合情况。
x <- seq(dat.1951)
sel <- dat.1951 >= 100
model1 <- lm(dat.1951[sel] ~ poly(x[sel], 2))
model2 <- lm(log(dat.1951[!sel]) ~ x[!sel])

plot(dat.1951, cex=1.5)
lines(x[sel], fitted(model1), col="blue", lwd=3)
lines(x[!sel], exp(fitted(model2)), col="navy", lwd=3)

为了好玩,我添加了第三个模型,使用mgcv包中的gam()函数使用广义可加模型来拟合所有数据。

library(mgcv)
model3 <- gam(dat.1951 ~ s(x))
lines(x, fitted(model3), col="orange", lwd=3, lty=2)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接