Как получить многопараметрические фасеты, используя tmap для растровых карт (tm_raster () + tm_facets ()) - PullRequest
0 голосов
/ 30 января 2019

Я хотел бы создать граненую карту, используя мои растровые данные, используя пакет tmap.Конечным результатом будут несколько растровых карт, показывающих «значения», со строками, показывающими карты «class1», и столбцами, показывающими карты «class2», как показано на следующем рисунке:

enter image description here

Я попробовал несколько подходов без успеха.Я думаю, что проблема заключается в построении слоя растрового кирпича в правильном формате.Буду признателен за любые советы.

library(tmap)
library(dplyr)
library(magrittr)
library(raster)

r<-data.frame(lat=c(rep(12.25,5),rep(12.5,5)),
          lon=c(rep(c(-72.25,-71.75,-71.25,-70.25,-69.25),2)),
          value=runif(10));r
rx<-sp::SpatialPointsDataFrame(sp::SpatialPoints(coords= 
(cbind(r$lon,r$lat))),data=r%>%dplyr::select(value))
rx@data
sp::gridded(rx)<-T
rx<-raster(rx);rx
r
tm_shape(rx)+tm_raster()
# This works and shows one of the raster maps I would like.


m1<-r%>%dplyr::mutate(class1="class1_A",class2="class2_A",value=value*0.5)
m2<-r%>%dplyr::mutate(class1="class1_A",class2="class2_B",value=value*3)
m3<-r%>%dplyr::mutate(class1="class1_B",class2="class2_B",value=value*10)
m<-bind_rows(m1,m2,m3);m

mx<-sp::SpatialPointsDataFrame(sp::SpatialPoints(coords= 
(cbind(m$lon,m$lat))),data=m)
sp::gridded(mx)<-T
mx@data
# mx@data shows the data.frame with the lat/lon and the classes. 
# I would like to plot this as facets
mxr<-brick(mx)
tm_shape(mxr)+tm_raster(col="value")+tm_facets(by="class1","class2")

1 Ответ

0 голосов
/ 31 января 2019

Ответ, используя ggplot2 вместо tmap :

library(dplyr)
library(ggplot2)

r <- data.frame(lat = c(rep(12.25, 5), rep(12.5, 5)),
                lon = c(rep(c(-72.25, -71.75, -71.25, -70.25, -69.25), 2)),
                value = runif(10))

m1 <- r %>% dplyr::mutate(class1 = "class1_A",
                      class2 = "class2_A",
                      value = value * 0.5)
m2 <- r %>% dplyr::mutate(class1 = "class1_A",
                      class2 = "class2_B",
                      value = value * 3)
m3 <- r %>% dplyr::mutate(class1 = "class1_B",
                      class2 = "class2_B",
                      value = value * 10)
m4 <- r %>% dplyr::mutate(class1 = "class1_B",
                          class2 = "class2_A",
                          value = value * 6)
m <- bind_rows(m1, m2, m3, m4)
head(m)
#>     lat    lon      value   class1   class2
#> 1 12.25 -72.25 0.07352787 class1_A class2_A
#> 2 12.25 -71.75 0.44638923 class1_A class2_A
#> 3 12.25 -71.25 0.20745736 class1_A class2_A
#> 4 12.25 -70.25 0.48200665 class1_A class2_A
#> 5 12.25 -69.25 0.06922203 class1_A class2_A
#> 6 12.50 -72.25 0.12036249 class1_A class2_A

# probably you should also add + coord_map()
ggplot(m, aes(x = lat, y = lon, fill = value)) + 
  geom_tile() +
  facet_grid(class1~class2) 

Создано в 2019-01-31 * * * * * * * * * * * *. * * * * * 1014

.
...