-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path07_synchrony_map.R
125 lines (100 loc) · 4.19 KB
/
07_synchrony_map.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
## ------------------------------------------ ##
# Synchrony Figure Preparation
## ------------------------------------------ ##
# Written by: Nick J Lyon
# PURPOSE
## Create publication-quality site map figure
# PRE-REQUISITES
## The script has no pre-requisite scripts.
## ------------------------------------------ ##
# Housekeeping ----
## ------------------------------------------ ##
# Load libraries
# install.packages("librarian")
librarian::shelf(tidyverse, sf, maps, terra, njlyon0/supportR, cowplot)
# Clear environment
rm(list = ls())
# This map is very data hungry so we'll need to do garbage collection too
gc()
# Create needed local folder(s)
dir.create(path = file.path("map_data"), showWarnings = F)
dir.create(path = file.path("synchrony_figure_files"), showWarnings = F)
# Gather up some needed plotting aesthetics
# Site palette
site_palette <- c("CWT" = "#bd0026", "LUQ" = "orange", "HBR" = "gold",
"AND" = "limegreen", "CDR" = "lightblue", "BNZ" = "#f1b6da",
"SEV" = "#9d4edd")
# Define shape palette
shp_palette <- c("AND" = 22, "BNZ" = 21, "CDR" = 24, "CWT" = 23,
"HBR" = 22, "LUQ" = 21, "SEV" = 24)
# Clean up environment
rm(list = setdiff(ls(), c("site_palette", "shp_palette")))
## ------------------------------------------ ##
# Site Map Prep ----
## ------------------------------------------ ##
# Combine global and state map
combo <- sf::st_as_sf(maps::map(database = "world", plot = F, fill = T)) %>%
dplyr::bind_rows(sf::st_as_sf(maps::map(database = "state", plot = F, fill = T)))
# Read in LTER site coordinates
(lter_coords <- read.csv(file.path("map_data", "lter_site_coordinates.csv")))
# Set lat/long limits
lat_lims <- c(15, 75)
lon_lims <- c(-160, -60)
# Read in land cover raster
lulc <- terra::rast(x = file.path("map_data", "gblulcgeo20.tif"))
# Crop to only North America
lulc_crop <- terra::crop(x = lulc, y = terra::ext(c(lon_lims, lat_lims)))
# Demo plot to be sure that worked
plot(lulc_crop, axes = T)
# Keep only tree categories
lc_v2 <- (lulc_crop %in% c(11:15)) # True forest only
# Demo plot
plot(lc_v2, axes = T)
## 11: deciduous broadleaf forest
## 12: deciduous needleleaf forest
## 13: evergreen broadleaf forest
## 14: evergreen needleleaf forest
## 15: mixed forest
# Coerce the raster into a dataframe with one row per XY coordinate
## Note this step takes a minute to complete
lc_v3 <- as.data.frame(lc_v2, xy = T) %>%
# Retain only true content pixels
dplyr::filter(gblulcgeo20 != 0)
# Check that out
dplyr::glimpse(lc_v3)
## ------------------------------------------ ##
# Site Map Creation ----
## ------------------------------------------ ##
# Make map figure!
fig1c <- combo %>%
ggplot() +
geom_sf(fill = "gray95") +
# Set map extent
coord_sf(xlim = lon_lims, ylim = lat_lims, expand = F) +
# Add forest cover information
geom_tile(data = lc_v3, aes(x = x, y = y), col = "darkolivegreen4", alpha = 0.5) +
# Add points for LTERs (and customize their aesthetics)
geom_point(data = lter_coords, aes(x = lon, y = lat,
fill = LTER, shape = LTER), size = 4) +
scale_fill_manual(values = site_palette) +
scale_shape_manual(values = shp_palette) + # different shapes for each LTER
# Add labels for LTERs
geom_label(data = lter_coords, aes(x = lon, y = lat),
label = lter_coords$LTER, nudge_y = 3, size = 3, fontface = "bold",
label.padding = unit(x = 0.15, units = "lines")) +
# Tweak theme / formatting
labs(x = "Longitude", y = "Latitude") +
scale_x_continuous(limits = lon_lims, breaks = seq(from = -150, to = -75, by = 25)) +
scale_y_continuous(limits = lat_lims, breaks = seq(from = 20, to = 70, by = 15)) +
supportR::theme_lyon() +
theme(legend.position = "none",
axis.text.y = element_text(angle = 90, vjust = 1, hjust = 0.5)); fig1c
# Add label on the map
cowplot::plot_grid(fig1c, labels = c("C"), nrow = 1)
# Save locally
ggsave(filename = file.path("synchrony_figure_files", "sync_fig1C_map.png"),
plot = last_plot(), width = 6, height = 6, units = "in", dpi = 420)
# Clean up environment and collect garbage to speed R up going forward
rm(list = ls())
gc()
# End ----