Skip to content

Commit

Permalink
water retention curves - data and processing script
Browse files Browse the repository at this point in the history
  • Loading branch information
kaizadp committed Oct 5, 2023
1 parent 4c96688 commit ac64287
Show file tree
Hide file tree
Showing 3 changed files with 82 additions and 0 deletions.
Binary file added water_retention/wrc_GCREW_Transition.xlsx
Binary file not shown.
Binary file added water_retention/wrc_GCREW_Upland.xlsx
Binary file not shown.
82 changes: 82 additions & 0 deletions water_retention/wrc_processing.R
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
## Process and plot water retention curves for GCREW
## KFP, Oct 2023

################ #
################

library(tidyverse)
theme_set(theme_minimal() + theme(text = element_text(size = 11)))


# import and process data ----
import_wrc_data = function(FILEPATH){

filePaths_wrc <- list.files(path = FILEPATH, pattern = "xlsx", full.names = TRUE, recursive = FALSE)
wrc_data <- do.call(bind_rows, lapply(filePaths_wrc, function(path) {

# importing both, the evaluated values and the fitted values
df_eval <- readxl::read_excel(path, sheet = "Evaluation-Retention Θ(pF)") %>% mutate_all(as.character) %>% janitor::clean_names()
df_eval = df_eval %>% mutate(source = basename(path)) %>% dplyr::select(p_f, water_content_vol_percent, source) %>% rename(pf_eval = p_f)

df_fit <- readxl::read_excel(path, sheet = "Fitting-Retention Θ(pF)") %>% mutate_all(as.character) %>% janitor::clean_names()
df_fit = df_fit %>% mutate(source = basename(path)) %>% dplyr::select(p_f, water_content_vol_percent, source) %>% rename(pf_fit = p_f)

df <- full_join(df_eval, df_fit)
df
}

))

}
wrc_data = import_wrc_data(FILEPATH = "water_retention")


process_wrc = function(wrc_data){

#wrc_processed <-
wrc_data %>%
# assign locations
mutate(location = case_when(grepl("Upland", source) ~ "upland",
grepl("Transition", source) ~ "lowland")) %>%
dplyr::select(location, water_content_vol_percent, starts_with("pf")) %>%
mutate_at(vars(starts_with("pf")), as.numeric) %>%
mutate_at(vars(starts_with("water")), as.numeric) %>%
# convert pF to kPa (water potential units)
mutate(
kpa_eval = round((10^pf_eval)/10,2),
kpa_fit = round((10^pf_fit)/10,2))

}
wrc_processed = process_wrc(wrc_data)

#
# plot the curves ----
wrc_processed %>%
filter(kpa_fit >= 0 | kpa_eval >= 0) %>%
filter(pf_fit >= 0 | pf_eval >= 0) %>%
ggplot(aes(y = water_content_vol_percent, color = location))+
geom_line(aes(x = kpa_fit), linewidth = 1)+
geom_point(aes(x = kpa_eval), shape = 1, show.legend = F)+
scale_x_log10(labels = scales::comma)+
scale_color_manual(values = c("#FF33CC", "#00CC66"))+
labs(color = "",
x = "Water potential (kPa)",
y = "Volumetric water content (%)")+
theme(legend.position = c(0.8, 0.8))
#ggsave("water_retention/wrc_fit_and_eval.png", height = 4, width = 4)


wrc_processed %>%
filter(kpa_fit >= 0 | kpa_eval >= 0) %>%
filter(pf_fit >= 0 | pf_eval >= 0) %>%
ggplot(aes(y = water_content_vol_percent, color = location))+
geom_line(aes(x = kpa_fit), linewidth = 1)+
scale_x_log10(labels = scales::comma)+
scale_color_manual(values = c("#FF33CC", "#00CC66"))+
labs(color = "",
x = "Water potential (kPa)",
y = "Volumetric water content (%)")+
theme(legend.position = c(0.8, 0.8))
#ggsave("water_retention/wrc_fit_only.png", height = 4, width = 4)


0 comments on commit ac64287

Please sign in to comment.