ラスターを投影しようとしています。RにはprojectRaster()
これを行うための関数があります(完全に再現可能な例の下に):
# example Raster
require(raster)
r <- raster(xmn=-110, xmx=-90, ymn=40, ymx=60, ncols=40, nrows=40)
r <- setValues(r, 1:ncell(r))
projection(r)
# project to
newproj <- "+init=epsg:4714"
# using raster package to reproject
pr1 <- projectRaster(r, crs = CRS(newproj), method = 'bilinear')
それはうまくいきます。しかし、それはかなり遅いです。
速度を上げるために、gdalwarp
代わりに使用します(SSD を使用すると、ディスク/ Rへの読み書きのコストはそれほど高くありません)。
ただし、をprojectRaster()
使用した結果を再現できませんgdalwarp
。
# using gdalwarp to reproject
tf <- tempfile(fileext = '.tif')
tf2 <- tempfile(fileext = '.tif')
writeRaster(r, tf)
system(command = paste(paste0("gdalwarp -t_srs \'", newproj, "\' -r bilinear -overwrite"),
tf,
tf2))
pr2 <- raster(tf2)
動作するようですが、結果は異なります。
# Info
system(command = paste("gdalinfo",
tf))
system(command = paste("gdalinfo",
tf2))
# plots
plot(r)
plot(pr1)
plot(pr2)
#extents
extent(r)
extent(pr1)
extent(pr2)
# PROJ4
proj4string(r)
proj4string(pr1)
proj4string(pr2)
# extract value
take <- SpatialPoints(matrix(c(-100, 50), byrow = T, ncol = 2), proj4string = CRS(newproj))
plot(take, add = TRUE)
extract(pr1, take)
extract(pr2, take)
何が欠けている/間違っていますか?
他の(より速い)代替手段はありprojectRaster()
ますか?
誰も?完全に再現可能な例を提供しました(LinuxまたはMacで動作するはずです)...
—
EDi
どちらの方法でも、(-100、50)で同じ再投影されたラスター、同じ範囲、同じ値が生成されると思います。しかし、彼らは明らかにそうではない:(
—
EDi
2つのプログラムは、ワープする異なるグリッドを作成しています。双一次サンプリングがまったく同じであったとしても、補間されるポイントは異なる場所にあり、異なる答えが得られます。原点とピクセルサイズが異なります。gdalwarp(-te、-trなど)にいくつかのフラグを設定してRバージョンを試し、再現してから、ピクセル値を比較して、それらの違いを確認することができます。
複数の状況で、GCPを使用しなくても
—
クリストフ2015
-order
フラグ(「ワーピングに使用される多項式の次数」)を使用すると、gdalwarp
より正確な結果が得られることがわかりました。