1

我必须从相同的输入坐标(x,y)到相同的输出坐标(xo,yo)执行多个二维线性插值。每次只有数据值 (z) 发生变化 (z1,z2,z3,...)。

我一直在 R 上使用包 interp。到目前为止,我已经多次调用命令“interp”。像这样:

# create data 
y <- rep(1:5,5)      # input coords
x <- rep(1:5,each=5)
z1 <- 1:25           # data
z2 <- 25:1
xo <- c(1.1,2.2,3.3) # output coords
yo <- c(2.2,3.3,4.4)

# interpolate 
library(interp)
z1.int <- interp(x,y,z1,xo,yo,output="points")[[3]]; z1.int
z2.int <- interp(x,y,z2,xo,yo,output="points")[[3]]; z2.int

# plot (optional)
layout(t(1:2))
plot(x,y,type='n'); text(x,y,z1,col='red'); text(xo,yo,z1.int)
plot(x,y,type='n'); text(x,y,z2,col='red'); text(xo,yo,z2.int)

但是,我怀疑有一种方法可以大大加快我的计算速度。插值过程由多个步骤组成。我认为其中一些只需要执行一次,然后将它们的结果多次用于多个数据向量。

有没有办法做到这一点?

4

0 回答 0