2016-06-15 1 views
0

Comment créer un calque raster avec des cercles pleins centrés dans "c (df $ lat, cd $ lon)" et rayon "df $ radius" à partir d'une image?Création de raster avec des cercles à partir de données dans R

df <- data.frame(lat=c(40.4,42.4,42.4,42.4,42.3), 
       lon=c(-0.3,1,1.5,2.7,2.1), 
       radius=c(4.4,8.4,11.4,5.4,10.3)) 

df 
# lat lon radius 
# 40.4 -0.3 4.4 
# 42.4 1.0 8.4 
# 42.4 1.5 11.4 
# 42.4 2.7 5.4 
# 42.3 2.1 10.3 

Répondre

0
library(dismo) 
df <- data.frame(lat=c(40.4,42.4,42.4,42.4,42.3), 
       lon=c(-0.3,1,1.5,2.7,2.1), 
       radius=c(4.4,8.4,11.4,5.4,10.3)) 

Notez l'utilisation de lon/lat, non latitude/longitude

p <- df[,2:1] 

Le rayon est en mètres afin que vos chiffres sont très petites. Je vais les changer

rad <- df[,3]*2500 

cercles Compute

cc <- circles(p, rad, lonlat=TRUE, dissolve=FALSE) 
plot(cc) 
points(p) 

Obtenez les polygones

pls <- polygons(cc) 

Pour obtenir une couche raster vous pouvez utiliser predict(cc, ) ou rasterize(pls, )

r <- raster(extent(pls), res=.01) 
pr <- predict(cc, r) 

(si vous ne voulez pas que les chevauchements soient comptés, utilisez dissolve=TRUE dans la fonction circles)

+0

C'est exactement ce dont j'ai besoin. Merci beaucoup! – ADM