Próbowałem zrobić obraz rastrowy z bazy danych punktów o nieregularnych odstępach. Dane wyglądają jak
> 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
Chcę te wartości „z” w siatce, którą utworzyłem
# 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))
Chcę również, aby wartości Z były przypisane jako „NA” dla tych punktów siatki, które znajdują się poza punktami danych. Punkty nad siatką wyglądają tak: https://drive.google.com/file/d/0B6GUNg-8d30vYzlwTkhvaHBFTnc/edit?usp=sharing podczas rysowania
plot(my_mesh)
points(s100_ras$Y, s100_ras$X, pch="*", col='blue')
Problem polega na tym, że nie jestem pewien, jak to zrobić, poniższe kroki nie działają, ponieważ moja siatka siatki i punkty danych nie są w tej samej skali !!
library(rgdal)
library(raster)
xyz<-cbind(my_mesh, s100_ras)
r <- rasterFromXYZ(xyz)
image(r)
Jeśli spróbuję utworzyć raster tylko przy użyciu punktów danych (bez siatki), R zgłasza błąd, ponieważ moje dane są nieregularnie rozmieszczone!
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
Co więcej, próbowałem grać z funkcją „rasterize” (dla nieregularnych siatek) „pakietu raster”, ale nie mogłem się z tym pogodzić :(. Wiem, jak interpolować i robić regularną siatkę, ale dla dobra oryginalności, chcę UNIKNĄĆ interpolacji. Czy można zrobić raster nieregularnie rozmieszczonych punktów danych bez metod idw lub kriging?
SpatialPixelsDataFramesugerowanego toleranceargumentu (w twoim przypadku 0.916421).