R/tdarec.R

Defines functions required_pkgs.step_tdarec .onLoad

Documented in required_pkgs.step_tdarec

#' @title A *recipes* and *dials* Extension for Persistent Homology
#'
#' @description The *tdarec* package extends *recipes* and *dials* by providing
#'   pre-processing steps with tunable parameters for computing persistent
#'   homology of suitable data and for vectorizing persistent homology.
#'
#' @import recipes
#' @name tdarec
#' @importFrom rlang on_load run_on_load
#' @importFrom dials new_qual_param new_quant_param unknown
"_PACKAGE"

#' @importFrom rlang "%||%"
#' @importFrom magrittr %>%

.onLoad <- function(...) {
  rlang::run_on_load()
}

# installed version of {ripserr}, or `NULL` if not installed
rlang::on_load({
  .ripserr_version <-
    if (! identical(find.package("ripserr", quiet = TRUE), character(0))) {
      utils::packageVersion("ripserr")
    } else NA_character_
  .TDAvec_version <- 
    if (! identical(find.package("TDAvec", quiet = TRUE), character(0))) {
      utils::packageVersion("TDAvec")
    } else NA_character_
})
# to check that the ripserr engine can handle input data
rlang::on_load({
  # Vietoris-Rips filtration
  .ripserr_vietoris_rips_classes <- if (is.na(.ripserr_version)) {
    character(length = 0L)
  } else if (.ripserr_version == "0.1.1") {
    # https://github.com/cran/ripserr/blob/
    # 8cadc3a86009149418d6f9a61124af9d6372d34e/R/calculate.R#L68
    c(
      "dist", "matrix",
      gsub("as\\.matrix\\.", "",
           as.character(utils::methods(base::as.matrix)))
    )
  } else if (.ripserr_version >= "0.2.0") {
    gsub("vietoris_rips\\.", "",
         as.character(utils::methods(ripserr::vietoris_rips)))
  }
  .ripserr_vietoris_rips_classes <- 
    setdiff(.ripserr_vietoris_rips_classes, "default")
  # cubical filtration
  .ripserr_cubical_classes <- if (is.na(.ripserr_version)) {
    character(length = 0L)
  } else if (.ripserr_version == "0.1.1") {
    # https://github.com/cran/ripserr/blob/
    # 8cadc3a86009149418d6f9a61124af9d6372d34e/R/calculate.R#L177
    c("array", "matrix")
  } else if (.ripserr_version >= "0.2.0") {
    gsub("cubical\\.", "",
         as.character(utils::methods(ripserr::cubical)))
  }
  .ripserr_cubical_classes <- setdiff(.ripserr_cubical_classes, "default")
})

#' @title S3 methods for tracking which additional packages are needed for
#'   steps.
#'
#' @description Recipe-adjacent packages always list themselves as a required
#'   package so that the steps can function properly within parallel processing
#'   schemes.
#' @param x A recipe step.
#' @returns A character vector.
#' @rdname required_pkgs.tdarec
#' @keywords internal
#' @export
required_pkgs.step_tdarec <- function(x, ...) {
  c("tdarec")
}

Try the tdarec package in your browser

Any scripts or data that you put into this service are public.

tdarec documentation built on June 8, 2025, 10:41 a.m.