-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathaffinity_visualisation.R
100 lines (84 loc) · 2.96 KB
/
affinity_visualisation.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
source("./process_affinity_data.R")
affinity$years_approx <- round(affinity$years,2)
affinity$years_approx[affinity$years_approx < 0.012] <-0
#Plot concentration against time
ggplot(data = affinity,
aes(x=days, y=value, col=sample_id, group=sample_id)) +
geom_line() +
theme_minimal()+
theme(legend.position = "none") +
facet_wrap(vars(biomarker), scales="free")
#Plot concentration (as proportion of baseline) against time
ggplot(data = affinity,
aes(x=days, y=100*(fraction-1))) +
ylab("% Change")+
geom_line(aes(col=sample_id, group=sample_id)) +
theme_minimal()+
theme(legend.position = "none") +
facet_wrap(vars(biomarker), scales="free") +
stat_smooth(method = "gam", formula = y ~ s(x, k = 4), size = 1)
#Plot conditional effects with median starting condition against time
#with boxplots
plot_list <- list()
biomarker_list <- "FSH"
for (bio in biomarker_list){
df <- affinity %>% filter(biomarker == bio)
baseline_median <- df %>%
filter(Timepoint == "T0") %>%
select(value) %>%
pull() %>%
median()
model <- readRDS(paste0("./models/", bio, "_SFO_model2.rds"))
ce_object <- conditional_effects(
model,
effects = "years"
)
cond_effect_plot_data <- ce_object$years %>%
mutate(across(effect1__:upper__, ~ .x * baseline_median))
p <- ggplot(data = cond_effect_plot_data) +
geom_line(aes(x = years, y = estimate__)) +
geom_ribbon(
aes(x = years , ymin = lower__, ymax = upper__),
alpha=0.3, fill="red") +
geom_point(data=df,
aes(x = years_approx, y = value)) +
geom_boxplot(data = df,
aes(y = value, group = years_approx, x=years_approx), alpha=0.2) +
theme_minimal() +
ylab("Concentration (pmol/L)") + xlab("Time (years)")
plot_list[[bio]] <- p
}
plot_list[["FSH"]]
#################################################
#Plot conditional effects with median starting condition against time
#with boxplots
#################
##BUT AS FRACTION OF BASELINE
###
plot_list <- list()
for (bio in unique(affinity$biomarker)){
df <- affinity %>% filter(biomarker == bio)
model <- readRDS(paste0("./models/", bio, "_SFO_model2.rds"))
ce_object <- conditional_effects(
model,
effects = "years"
)
cond_effect_plot_data <- ce_object$years
p <- ggplot(data = cond_effect_plot_data) +
geom_line(aes(x = years, y = estimate__)) +
geom_ribbon(
aes(x = years , ymin = lower__, ymax = upper__),
alpha=0.3, fill="red") +
geom_point(data=df,
aes(x = years, y = fraction)) +
geom_boxplot(data = df,
aes(y = fraction, group = years, x=years), alpha=0.2) +
theme_minimal() +
ylab("Concentration (pmol/L)") + xlab("Time (years)")
plot_list[[bio]] <- p
}
ggpubr::ggarrange(plot_list$Testosterone,
plot_list$Androstenedione,
plot_list$`11KT`,
plot_list$`11OHA4`,
plot_list$`17OHP`, labels = c("A", "B", "C", "D", "E"))