Overview
corella
is an R package that helps users standardize their data using the Darwin Core data standard, used for biodiversity data like species occurrences. corella
provides tools to prepare, manipulate and validate data against the standard’s criteria. Once standardized, data can be subsequently shared as a Darwin Core Archive and published to open data infrastructures like the Atlas of Living Australia and GBIF.
corella
was built, and is maintained, by the Science & Decision Support Team at the Atlas of Living Australia (ALA). It is named for the Little Corella (Cacatua sanguinea). The logo was designed by Dax Kellie.
If you have any comments, questions or suggestions, please contact us.
Installation
You can install the development version of corella
from GitHub with:
# install.packages("devtools")
devtools::install_github("AtlasOfLivingAustralia/corella")
Usage
Here we have a small sample of some example data. We’d like to convert our data to use Darwin Core standards.
library(corella)
library(tibble)
# A simple example of species occurrence data
df <- tibble(
species = c("Callocephalon fimbriatum", "Eolophus roseicapilla"),
latitude = c(-35.310, "-35.273"), # deliberate error for demonstration purposes
longitude = c(149.125, 149.133),
eventDate = c("14-01-2023", "15-01-2023"),
status = c("present", "present")
)
df
#> # A tibble: 2 × 5
#> species latitude longitude eventDate status
#> <chr> <chr> <dbl> <chr> <chr>
#> 1 Callocephalon fimbriatum -35.31 149. 14-01-2023 present
#> 2 Eolophus roseicapilla -35.273 149. 15-01-2023 present
One of the most important aspects of Darwin Core standard is using standard column names (Darwin Core terms). We can update column names in our data to match Darwin Core terms with use_
functions.
Each use_
function name corresponds to the type of data, and argument names correspond to the available Darwin Core terms to use as column names. use_
functions support data wrangling operations & dplyr::mutate()
functionality, meaning columns can be changed or fixed in your pipe. use_
functions will indicate if anything needs fixing because they also automatically run checks on each column data to make sure each column is in the correct format.
suppressMessages( # for readability
df |>
use_coordinates(
decimalLatitude = as.numeric(latitude), # fix latitude
decimalLongitude = longitude
) |>
use_scientific_name(
scientificName = species
) |>
use_datetime(
eventDate = lubridate::dmy(eventDate) # specify date format
) |>
use_occurrences(occurrenceStatus = status)
)
#> # A tibble: 2 × 5
#> eventDate decimalLatitude decimalLongitude scientificName occurrenceStatus
#> <date> <dbl> <dbl> <chr> <chr>
#> 1 2023-01-14 -35.3 149. Callocephalon fi… present
#> 2 2023-01-15 -35.3 149. Eolophus roseica… present
Not sure where to start? Use suggest_workflow()
to know what steps you need to make to make your data Darwin Core compliant.
df |>
suggest_workflow()
#>
#> ── Matching Darwin Core terms ──────────────────────────────────────────────────
#> Matched 1 of 5 column names to DwC terms:
#> ✔ Matched: eventDate
#> ✖ Unmatched: latitude, longitude, species, status
#>
#> ── Minimum required Darwin Core terms ──────────────────────────────────────────
#>
#> Type Matched term(s) Missing term(s)
#> ✔ Date/Time eventDate -
#> ✖ Identifier (at least one) - occurrenceID, catalogNumber, recordNumber
#> ✖ Record type - basisOfRecord
#> ✖ Scientific name - scientificName
#> ✖ Location - decimalLatitude, decimalLongitude, geodeticDatum, coordinateUncertaintyInMeters
#>
#> ── Suggested workflow ──────────────────────────────────────────────────────────
#>
#> To make your data Darwin Core compliant, use the following workflow:
#> df |>
#> use_occurrences() |>
#> use_scientific_name() |>
#> use_coordinates()
#>
#> ── Additional functions
#> ℹ See all `use_` functions at
#> <https://galaxias.ala.org.au/reference/index.html#add-darin-core-terms>
Or, if your data is nearly ready and you want to run checks over all columns that match Darwin Core terms, run check_dataset()
. check_dataset()
checks all columns with valid Darwin Core terms as column names.
df |>
check_dataset()
#> ℹ Testing data
#> ✔ | E P | Column
#> ⠙ | 0 eventDate
#> ⠹ | 1 ✖ | eventDate ✔ | 1 ✖ | eventDate [355ms]
#> ══ Results ═════════════════════════════════════════════════════════════════════
#>
#> [ Errors: 1 | Pass: 0 ]
#>
#> ✖ Data meets minimum Darwin Core requirements
#> ℹ Use `suggest_workflow()` to see more information.
#> ── Error in eventDate ──────────────────────────────────────────────────────────
#>
#> eventDate must be a Date vector, not a character.
#> ℹ Specify date format with lubridate functions e.g. `ymd()`, `mdy()`, or
#> `dmy()`.
Citing corella
To generate a citation for the package version you are using, you can run:
citation(package = "corella")
The current recommended citation is:
Kellie D, Balasubramaniam S & Westgate MJ (2024) corella: Tools to standardize biodiversity data to Darwin Core. R Package version 0.1.0.