0

以下代码用于使用 gstat 包在 R 中使用克里金法预测三个位置的 v 值。

library(gstat);
library(sp);
walk470 <- read.table("D:/kriging/walk470.txt",header=T)
attach(walk470)
coordinates(walk470) = ~x+y
walk.var1 <- variogram(v ~ x+y,data=walk470,width=10)
plot(walk.var1,xlab="Distance",ylab="Semivariance",main="Variogram for V, Lag Spacing = 5")
model1.out <- fit.variogram(walk.var1,vgm(70000,"Sph",40,20000))
plot(walk.var1, model=model1.out,xlab="Distance",ylab="Semivariance",main="Variogram for V, Lag Spacing = 10")
predpts <- matrix(c(60,190,225,50,110,185),ncol=2,byrow=T)
predpts.g <- data.frame(x=predpts[,1],y=predpts[,2])
coordinates(predpts.g) <- ~x+y
g <- gstat(NULL,"new.v",v~1,data=walk470,model=model1.out)
three.pred <- predict(g,predpts.g)
print(three.pred)

我想知道为什么为了拟合变异函数模型,我们需要预先使用 vgm() 方法提供窗台、块金和范围值。根据克里金理论,我认为我们必须通过最小化 WLS 目标函数来计算这些值。

〜问候,钱丹

4

1 回答 1

2

由于您的参数之一是球面变异函数模型的范围,因此 WLS 解决的优化问题是非线性的。非线性优化通常需要初始值(参见例如?optim),这就是您传递给初始vgm调用的值。传递的实际值也有些重要:如果它远远超出合理值的范围(接近零或非常大),则拟合将不会成功。

如果您只适合 sill 和 nugget(传递fit.ranges=TRUEfit.variogram),那么问题将是线性的,并且原则上可以在没有初始值的情况下完成。在这种情况下,数据范围之外的任意值仍然有效。

于 2015-03-24T08:33:41.913 回答