Skip to content

Commit

Permalink
version 1.0.1
Browse files Browse the repository at this point in the history
* Update testdata.R (#134) - fixes to tests described in #133
   - for fields like basis_of_record, splitting input into `words` since fixed values sometimes multiple terms
   - add "unknown" to lists of allowed values

* combined with fixes to metadata files in austraits.build
* Add less/greater than or equal signs to exceptions for metadata
* fixed taxonomic_updates table to include `aligned_name_taxon_id`, `aligned_name_taxonomic_status`
* changed `process_standardise_names` to not capitalise an "x" indicating a hybrid taxon
* some minor edits to schema

* report edits
   -  fix reports to work with new taxon scheme
   - Remove bins and ranges from plot_trait_distribution_beeswarm

---------

Co-authored-by: yangsophieee <sophie.yang917@gmail.com>
Co-authored-by: Sophie Yang <78716301+yangsophieee@users.noreply.github.com>
Co-authored-by: Elizabeth Wenk <ehwenk@gmail.com>
  • Loading branch information
4 people authored Nov 19, 2023
2 parents 0477802 + a64ce21 commit db7bbd2
Show file tree
Hide file tree
Showing 130 changed files with 928 additions and 794 deletions.
6 changes: 3 additions & 3 deletions DESCRIPTION
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
Type: Package
Package: traits.build
Title: A workflow for harmonising trait data from diverse sources into a documented standard structure.
Version: 1.0.0
Title: A workflow for harmonising trait data from diverse sources into a documented standard structure
Version: 1.0.1
Maintainer: Daniel Falster <daniel.falster@unsw.edu.au>
Authors@R: c(
person(given = "Daniel", family = "Falster", role = c("cre", "aut"), email = "daniel.falster@unsw.edu.au", comment = c(ORCID = "0000-0002-9814-092X")),
Expand Down Expand Up @@ -52,7 +52,7 @@ Suggests:
rcrossref,
ggplot2,
ggbeeswarm,
gridExtra,
gridExtra,
scales,
zip,
covr
Expand Down
8 changes: 8 additions & 0 deletions NEWS.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,11 @@
# traits.build 1.0.1

As described in #134, fixes some minor issues with

- testing of datasets in `dataset_test`
- generating of reports
- standardising of taxonomic names.

# traits.build 1.0.0

This is the first major release of the {traits.build} package, providing a workflow to harmonise trait data from diverse sources. The code was originally built to support AusTraits (see Falster et al 2021, <doi:10.1038/s41597-021-01006-6>, <https://github.com/traitecoevo/autraits.build>) and has been generalised here to support construction of other trait databases. Detailed instructions are available at
Expand Down
6 changes: 5 additions & 1 deletion R/plot.R
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,11 @@ plot_trait_distribution_beeswarm <- function(austraits, trait, y_axis_category,

# Subset data to this trait
austraits_trait <-
austraits$traits %>% dplyr::filter(.data$trait_name == trait) %>%
austraits$traits %>%
dplyr::filter(
.data$trait_name == trait,
!.data$value_type %in% c("bin", "range")
) %>%
dplyr::mutate(value = as.numeric(.data$value))

my_shapes <- c("_min" = 60, "_mean" = 16, "_max" = 62, "unknown" = 18)
Expand Down
99 changes: 51 additions & 48 deletions R/process.R
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ dataset_configure <- function(
#' @param resource_metadata Metadata about the traits compilation read in from the config folder
#' @param unit_conversion_functions `unit_conversion.csv` file read in from the config folder
#' @param filter_missing_values Default filters missing values from the excluded data table;
#' change to false to see the rows with missing values.
#' change to false to see the rows with missing values
#'
#' @return List, AusTraits database object
#' @export
Expand Down Expand Up @@ -203,20 +203,22 @@ dataset_process <- function(filename_data_raw,
dplyr::distinct() %>%
dplyr::arrange(.data$aligned_name)

# Taxon names explicitly excluded in metadata also excluded from taxonomic updates table.
# Taxon names explicitly excluded in metadata also excluded from taxonomic updates table
if (!is.na(metadata[["exclude_observations"]][1])) {
taxa_to_exclude <-
metadata[["exclude_observations"]] %>%
traits.build::util_list_to_df2() %>%
dplyr::mutate(
find = stringr::str_split(.data$find, ", ")
) %>%
tidyr::unnest_longer(.data$find) %>%
dplyr::filter(.data$variable == "taxon_name")
metadata[["exclude_observations"]] %>%
traits.build::util_list_to_df2() %>%
dplyr::mutate(
find = stringr::str_split(.data$find, ", ")
) %>%
tidyr::unnest_longer(.data$find) %>%
dplyr::filter(.data$variable == "taxon_name")

tmp <- taxa_to_exclude$find %>% process_standardise_names()

taxonomic_updates <-
taxonomic_updates %>%
dplyr::filter(!.data$aligned_name %in% taxa_to_exclude$find)
dplyr::filter(!.data$aligned_name %in% tmp)
}

## A temporary dataframe created to generate and bind `method_id`,
Expand All @@ -229,7 +231,7 @@ dataset_process <- function(filename_data_raw,
process_generate_method_ids()

# Ensure correct order of columns in traits table
# At this point, need to retain `taxonomic_resolution`, because taxa table & taxonomic_updates not yet assembled.
# At this point, need to retain `taxonomic_resolution`, because taxa table & taxonomic_updates not yet assembled

traits <-
traits %>%
Expand Down Expand Up @@ -265,34 +267,34 @@ dataset_process <- function(filename_data_raw,
identifier = "https://github.com/traitecoevo/traits.build",
relation_type = "isCompiledBy",
resource_type = "software",
version = as.character(packageVersion("traits.build"))
version = as.character(utils::packageVersion("traits.build"))
)
)


# Combine for final output
ret <-
list(
traits = traits %>% dplyr::filter(is.na(.data$error)) %>% dplyr::select(-dplyr::all_of(c("error", "unit_in"))),
locations = locations,
contexts = context_ids$contexts %>% dplyr::select(-dplyr::any_of(c("var_in"))),
methods = methods,
excluded_data = traits %>%
dplyr::filter(!is.na(.data$error)) %>%
dplyr::select(dplyr::all_of(c("error")), everything()) %>%
dplyr::select(-dplyr::all_of(c("unit_in"))),
taxonomic_updates = taxonomic_updates %>%
dplyr::filter(.data$aligned_name %in% traits$taxon_name),
taxa = taxonomic_updates %>%
dplyr::select(dplyr::all_of(c(taxon_name = "aligned_name"))) %>%
dplyr::distinct(),
contributors = contributors,
sources = sources,
definitions = definitions,
schema = schema,
metadata = metadata,
build_info = list(session_info = utils::sessionInfo())
)
ret <-
list(
traits = traits %>% dplyr::filter(is.na(.data$error)) %>% dplyr::select(-dplyr::all_of(c("error", "unit_in"))),
locations = locations,
contexts = context_ids$contexts %>% dplyr::select(-dplyr::any_of(c("var_in"))),
methods = methods,
excluded_data = traits %>%
dplyr::filter(!is.na(.data$error)) %>%
dplyr::select(dplyr::all_of(c("error")), everything()) %>%
dplyr::select(-dplyr::all_of(c("unit_in"))),
taxonomic_updates = taxonomic_updates %>%
dplyr::filter(.data$aligned_name %in% traits$taxon_name),
taxa = taxonomic_updates %>%
dplyr::select(dplyr::all_of(c(taxon_name = "aligned_name"))) %>%
dplyr::distinct(),
contributors = contributors,
sources = sources,
definitions = definitions,
schema = schema,
metadata = metadata,
build_info = list(session_info = utils::sessionInfo())
)

class(ret) <- c("list", "traits.build")

Expand All @@ -312,7 +314,7 @@ dataset_process <- function(filename_data_raw,
#' @param resource_metadata metadata for the compilation
#' @param taxon_list Taxon list
#' @param filter_missing_values Default filters missing values from the excluded data table;
#' change to false to see the rows with missing values.
#' change to false to see the rows with missing values
#' @return List, AusTraits database object
#' @export
#'
Expand Down Expand Up @@ -447,7 +449,7 @@ process_create_observation_id <- function(data, metadata) {
# There are 3 circumstances:

# 1. There is an `individual_id` column read in through metadata$data
# and `parsing_id` is equivalent to `individual_id`
# and `parsing_id` is equivalent to `individual_id`.
# 2. There is only a single observation for each individual,
# and therefore `parsing_id` values assigned based upon row number
# correctly identifies an individual. This includes instances where
Expand Down Expand Up @@ -1552,6 +1554,7 @@ process_parse_data <- function(data, dataset_id, metadata, contexts, schema) {

# Implement any value changes as per substitutions
if (!is.na(metadata[["substitutions"]][1])) {

substitutions_table <- util_list_to_df2(metadata[["substitutions"]]) %>%
dplyr::mutate(
find = tolower(.data$find),
Expand All @@ -1567,8 +1570,8 @@ process_parse_data <- function(data, dataset_id, metadata, contexts, schema) {
if (length(j) > 0) {
out[["value"]][j] <- substitutions_table[["replace"]][i]
}
}

}
}

list(
Expand Down Expand Up @@ -1722,8 +1725,9 @@ process_standardise_names <- function(x) {
}

x %>%
## Capitalise first letter
## Capitalise first letter, but not hybrid `x` at start
f("^([a-z])", "\\U\\1") %>%
f("^[Xx]\\s", "x ") %>%

## sp. not sp or spp
f("\\ssp(\\s|$)", " sp.\\1") %>%
Expand Down Expand Up @@ -1805,7 +1809,7 @@ process_taxonomic_updates <- function(data, metadata) {
}
}

# for any that haven't been updated, run script to standardize names
# For any that haven't been updated, run script to standardize names
out[["taxon_name"]][to_update] <- process_standardise_names(out[["taxon_name"]][to_update])

## Return updated table
Expand All @@ -1832,7 +1836,7 @@ build_combine <- function(..., d = list(...)) {

# Combine sources and remove duplicates
sources <- d %>% lapply("[[", "sources")
keys <- sources %>% lapply(names) %>% unlist() %>% unique() %>% sort()
keys <- sources %>% lapply(names) %>% unlist() %>% unique() %>% sort()
sources <- sources %>% purrr::reduce(c)
sources <- sources[keys]

Expand All @@ -1846,6 +1850,7 @@ build_combine <- function(..., d = list(...)) {
names(d) <- sapply(d, "[[", "dataset_id")

# Taxonomy

taxonomic_updates <-
combine("taxonomic_updates", d) %>%
dplyr::group_by(.data$original_name, .data$aligned_name, .data$taxon_name, .data$taxonomic_resolution) %>%
Expand Down Expand Up @@ -1877,11 +1882,9 @@ build_combine <- function(..., d = list(...)) {
definitions = definitions,
schema = d[[1]][["schema"]],
metadata = metadata,
build_info = list(
session_info = utils::sessionInfo()
)
build_info = list(session_info = utils::sessionInfo())
)

class(ret) <- c("list", "traits.build")

ret
Expand Down Expand Up @@ -1911,8 +1914,8 @@ dataset_update_taxonomy <- function(austraits_raw, taxa) {
dplyr::left_join(
by = "aligned_name",
taxa %>% dplyr::select(
dplyr::all_of(c("aligned_name", "taxon_name"))
)) %>%
c(dplyr::all_of(c("taxon_name")), dplyr::any_of(dplyr::contains("align"))))
) %>%
dplyr::distinct() %>%
dplyr::arrange(.data$aligned_name)

Expand All @@ -1937,7 +1940,7 @@ dataset_update_taxonomy <- function(austraits_raw, taxa) {
util_df_convert_character() %>%
dplyr::mutate(
# If no taxonomic resolution is specified from taxonomic_updates,
# then the name's taxonomic resolution is the taxon_rank for the taxon name.
# then the name's taxonomic resolution is the taxon_rank for the taxon name
taxonomic_resolution = ifelse(
.data$taxon_name %in% taxa$aligned_name,
taxa$taxon_rank[match(.data$taxon_name, taxa$aligned_name)],
Expand All @@ -1953,7 +1956,7 @@ dataset_update_taxonomy <- function(austraits_raw, taxa) {
# Remove `taxon_rank`, as it is about to be merged back in, but matches will now be possible to more rows
select(-dplyr::any_of(c("taxon_rank", "taxonomic_resolution"))) %>%
util_df_convert_character() %>%
# Merge in all data from taxa.
# Merge in all data from taxa
dplyr::left_join(by = c("taxon_name"),
taxa %>% dplyr::select(-dplyr::any_of(dplyr::contains("align"))) %>%
dplyr::distinct(.data$taxon_name, .keep_all = TRUE) %>%
Expand Down
Loading

0 comments on commit db7bbd2

Please sign in to comment.