Я намагався зробити растрове зображення з бази даних невірно розташованих точок. Дані виглядають як:
> head(s100_ras)
x y z
1 267573.9 2633781 213.29545
2 262224.4 2633781 69.78261
3 263742.7 2633781 51.21951
4 259328.4 2633781 301.98413
5 264109.8 2633781 141.72414
6 255094.8 2633781 88.90244
Я хочу, щоб ці значення 'z' були в сітці, яку я створив
# Create a fine mesh grid
my_mesh=expand.grid(seq(min(s100_ras$Y),max(s100_ras$Y),l=100),
seq(min(s100_ras$X),max(s100_ras$X),l=100))
Я також хочу, щоб z-значення були призначені як "NA" для тих точок сітки, які знаходяться поза точками даних. Точки над сіткою виглядають так: https://drive.google.com/file/d/0B6GUNg-8d30vYzlwTkhvaHBFTnc/edit?usp=sharing, коли я будувати графік
plot(my_mesh)
points(s100_ras$Y, s100_ras$X, pch="*", col='blue')
Проблема полягає в тому, що я не впевнений, як це зробити, наступні кроки не працюють, оскільки сітчаста сітка та точки даних не мають однакового масштабу !!
library(rgdal)
library(raster)
xyz<-cbind(my_mesh, s100_ras)
r <- rasterFromXYZ(xyz)
image(r)
Якщо я спробую зробити растр лише за допомогою точок даних (без жодної сітки), R видає помилку, оскільки мої дані неправильно розміщені!
library(sp)
s100_ras <- data.frame(expand.grid(x = s100_ras$Y, y = s100_ras$X),
z = as.vector(s100_ras$mean))
coordinates(s100_ras) <- ~x+y
proj4string(s100_ras) <- CRS("+proj=utm +zone=46 +datum=WGS84")
gridded(s100_ras) = TRUE
suggested tolerance minimum: 0.916421
Error in points2grid(points, tolerance, round) :
dimension 1 : coordinate intervals are not constant
Більше того, я намагався грати з функцією 'rasterize' (для нерегулярних сіток) 'растрового пакету', але не міг знайти шлях до нього :(. Я знаю, як інтерполювати та робити звичайну сітку, але заради Оригінальність, я хочу AVOID інтерполяції. Чи можна зробити растр неправильно розташованих точок даних без idw або методів крігінгу?
SpatialPixelsDataFrame
запропонованим tolerance
аргументом (0,916421 у вашому випадку).