-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathfigure_04.R
174 lines (163 loc) · 6.36 KB
/
figure_04.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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
# 30 October 2023
# Visualize abundance differences between regions
library(here)
library(tidyverse)
library(MetBrewer)
library(MCMCvis)
library(patchwork)
library(reshape)
setwd(here::here("results"))
load("herbivore_case_study_results_v01.RData")
sp_key <- tibble::tibble(
sp = 1:11,
sp_name = c( "buffalo", "eland", "elephant",
"giraffe", "Grant's gazelle", "hartebeest",
"impala", "Thomson's gazelle", "topi",
"warthog", "waterbuck" ),
mass = c(592666, 562592.7, 3824540, 964654.7, 55464.46,
160937.9, 52591.69, 22907.43, 136000.3,
82499.99, 204393.5)) |>
dplyr::arrange(mass) |>
dplyr::mutate( sp_name = factor(sp_name, levels = unique(sp_name))) |>
dplyr::mutate( mass = base::as.numeric( base::scale( base::log( mass ) ) ) )
sp_n <- lapply(
X = MCMCvis::MCMCpstr( out, params = c("alpha0"), type = "chains"),
FUN = reshape::melt,
varnames = c("sp", "region", "iter")) |>
dplyr::bind_rows(.id = "param") |>
dplyr::mutate(region = ifelse(region == 1, "Mara", "Talek")) %>%
dplyr::mutate( value = exp(value)) %>%
tibble::as_tibble() |>
dplyr::select(sp, region, iter, value) |>
dplyr::mutate(value = log(value)) |>
dplyr::full_join(sp_key) |>
dplyr::group_by(sp_name, region) |>
dplyr::summarise( mean = mean(value),
l95 = quantile(value, c(0.025)),
u95 = quantile(value, c(0.975)))
sp_sig <-
lapply(
X = MCMCvis::MCMCpstr( out, params = c("alpha0"), type = "chains"),
FUN = reshape::melt,
varnames = c("sp", "region", "iter")) |>
dplyr::bind_rows(.id = "param") |>
dplyr::mutate(region = ifelse(region == 1, "Mara", "Talek")) %>%
dplyr::mutate( value = exp(value)) %>%
tibble::as_tibble() |>
dplyr::select(sp, region, iter, value) %>%
tidyr::pivot_wider(names_from = region, values_from = value) %>%
dplyr::mutate(diff = Talek - Mara) %>%
dplyr::group_by(sp) %>%
dplyr::summarise( mean = mean(diff),
l95 = quantile(diff, c(0.025)),
u95 = quantile(diff, c(0.975))) |>
dplyr::full_join(sp_key) |>
dplyr::mutate(region = ifelse( mean > 0, "Talek", "Mara")) |>
dplyr::mutate(sig = ifelse( l95 < 0 & u95 > 0, NA, "*")) |>
dplyr::select(sp_name, sig, region) |>
tibble::add_column( mean = -3.45)
com_n <- lapply(
X = MCMCvis::MCMCpstr( out, params = c("mu_alpha0"), type = "chains"),
FUN = reshape::melt,
varnames = c("region", "iter")) |>
dplyr::bind_rows(.id = "param") |>
tibble::as_tibble() |>
tidyr::separate( region, into = c("junk", "region"), sep = "\\[") |>
dplyr::mutate(region = parse_number(region)) |>
dplyr::mutate( value = exp(value)) |>
dplyr::select( param, region, iter, value ) %>%
dplyr::mutate(value = log(value)) |>
dplyr::mutate(region = ifelse(region == 1, "Mara", "Talek")) %>%
dplyr::group_by( region) |>
dplyr::summarise( mean = mean(value),
sd = sd(value),
l95 = quantile(value, c(0.025)),
u95 = quantile(value, c(0.975)))
lapply(
X = MCMCvis::MCMCpstr( out, params = c("mu_alpha0"), type = "chains"),
FUN = reshape::melt,
varnames = c("region", "iter")) |>
dplyr::bind_rows(.id = "param") |>
tibble::as_tibble() |>
tidyr::separate( region, into = c("junk", "region"), sep = "\\[") |>
dplyr::mutate(region = parse_number(region)) |>
dplyr::mutate( value = exp(value)) |>
dplyr::select( param, region, iter, value ) %>%
dplyr::mutate(value = log(value)) |>
dplyr::mutate(region = ifelse(region == 1, "Mara", "Talek")) |>
pivot_wider(names_from = region, values_from = value) |>
mutate(diff = Mara - Talek) |>
summarise( mean = mean(diff),
l95 = quantile(diff, c(0.025)),
u95 = quantile(diff, c(0.975)))
( nplot <- ggplot2::ggplot() +
ggplot2::geom_rect(
data = com_n,
aes( xmin = l95,
xmax = u95,
fill = region),
ymin = -Inf,
ymax = Inf,
alpha = 0.2) +
ggplot2::geom_vline(
data = com_n,
aes(xintercept = mean,
color = region),
size = 1,
alpha = 0.2) +
ggplot2::geom_errorbar(
data = sp_n,
aes(y = sp_name,
xmin = l95,
xmax = u95,
color = region),
width = 0,
size = 1,
position = position_dodge(width = 0.75)) +
ggplot2::geom_point(
data = sp_n,
aes(y = sp_name,
x = mean,
color = region),
size = 3,
position = position_dodge(width = 0.75)) +
ggplot2::geom_text( data = sp_sig,
aes(x = mean,
y = sp_name,
label = sig,
color = region),
size = 6,
vjust = 0.75,
fontface = "bold",
show.legend = FALSE) +
ggplot2::scale_fill_manual("Region",
values = MetBrewer::MetPalettes$Tam[[1]][c(3, 7)]) +
ggplot2::scale_color_manual( "Region",
values = MetBrewer::MetPalettes$Tam[[1]][c(3, 7)]) +
ggplot2::scale_x_continuous( limits = c(-3.5, 5.5),
expand = c(0.02, 0)) +
ggplot2::theme_minimal() +
ggplot2::labs( x = " Log ( Abundance ) ") +
ggplot2::theme( panel.grid = element_blank(),
axis.title.y = element_blank(),
legend.text = element_text(color = "black", size = 9),
legend.title = element_text(color = "black", size = 10),
legend.position = c(0.9, 0.9),
plot.title = element_text(color = "black", size = 9),
axis.text = element_text(color = "black", size = 9),
axis.title.x = element_text(color = "black", size = 10),
axis.line = element_line(color = "black", size = 0.1),
axis.ticks = element_line(color = "black", size = 0.1),
plot.background = element_rect(color = NA, fill = "white"),
panel.background = element_rect(color = NA, fill = "white")) +
ggplot2::guides(color = guide_legend(reverse = TRUE),
fill = guide_legend(reverse = TRUE)) )
setwd(here::here("figures"))
ggsave(
"figure_04.png",
nplot,
width = 4.5,
height = 3.5,
units = "in",
dpi = 300
)