Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

pre-release tm_a_pca document update #646

Merged
merged 11 commits into from
Feb 26, 2024
47 changes: 27 additions & 20 deletions R/tm_a_pca.R
Original file line number Diff line number Diff line change
@@ -1,54 +1,61 @@
#' Principal component analysis module
#' @md
#'
#' Module conducts principal component analysis (PCA) on a given dataset and offers different
#' ways of visualizing the outcomes, including elbow plot, circle plot, biplot, and eigenvector plot.
#' Additionally, it enables dynamic customization of plot aesthetics, such as opacity, size, and
#' font size, through UI inputs.
#'
#' @inheritParams teal::module
#' @inheritParams shared_params
#' @param dat (`data_extract_spec` or `list` of multiple `data_extract_spec`)
#' Columns used to compute PCA.
#' @param alpha optional, (`numeric`) If scalar then the plot points will have a fixed opacity. If a
#' slider should be presented to adjust the plot point opacity dynamically then it can be a vector of
#' length three with `c(value, min, max)`.
#' @param size optional, (`numeric`) If scalar then the plot point sizes will have a fixed size.
#' If a slider should be presented to adjust the plot point sizes dynamically then it can be a
#' vector of length three with `c(value, min, max)`.
#' @param font_size optional, (`numeric`) font size control for title, x-axis label, y-axis label and legend.
#' If scalar then the font size will have a fixed size. If a slider should be presented to adjust the plot
#' point sizes dynamically then it can be a vector of length three with `c(value, min, max)`.
#'
#' specifying columns used to compute PCA.
#' @param alpha (`numeric`, optional) value or a vector of length three in the form `c(value, min, max)`.
kartikeyakirar marked this conversation as resolved.
Show resolved Hide resolved
#' - If provided as a scalar, it sets a fixed opacity for plot points.
kartikeyakirar marked this conversation as resolved.
Show resolved Hide resolved
#' - If provided as a vector, it allows dynamic adjustment of plot point opacity via a slider in the UI.
#' @param size (`numeric`, optional) value or a vector of length three in the form `c(value, min, max)`.
#' - If provided as a scalar, it sets a fixed size for plot points.
#' - If provided as a vector, it allows dynamic adjustment of plot point sizes via a slider in the UI.
#' @param font_size (`numeric`, optional) value or a vector of length three in the form `c(value, min, max)`.
#' It controls the font size for plot titles, axis labels, and legends.
#' - If scalar then the font size will have a fixed size.
#' - If provided as a vector, it enables dynamic adjustment of font size via a slider in the UI.
#' @templateVar ggnames "Elbow plot", "Circle plot", "Biplot", "Eigenvector plot"
#' @template ggplot2_args_multi
#'
#' @export
#'
#' @examples
#'
#' # ADSL example
# ADSL example
kartikeyakirar marked this conversation as resolved.
Show resolved Hide resolved
#' library(teal.widgets)
m7pr marked this conversation as resolved.
Show resolved Hide resolved
#'
#' data <- teal_data()
#' data <- within(data, {
#' library(nestcolor)
#' ADSL <- teal.modules.general::rADSL
#' })
#'
#' datanames <- c("ADSL")
#' datanames(data) <- datanames
#' join_keys(data) <- default_cdisc_join_keys[datanames]
#' app <- teal::init(
#'
#' app <- init(
#' data = data,
#' modules = teal::modules(
#' teal.modules.general::tm_a_pca(
#' modules = modules(
#' tm_a_pca(
#' "PCA",
#' dat = teal.transform::data_extract_spec(
#' dat = data_extract_spec(
#' dataname = "ADSL",
#' select = teal.transform::select_spec(
#' choices = teal.transform::variable_choices(
#' select = select_spec(
#' choices = variable_choices(
#' data = data[["ADSL"]], c("BMRKR1", "AGE", "EOSDY")
#' ),
#' selected = c("BMRKR1", "AGE"),
#' multiple = TRUE
#' ),
#' filter = NULL
#' ),
#' ggplot2_args = teal.widgets::ggplot2_args(
#' ggplot2_args = ggplot2_args(
#' labs = list(subtitle = "Plot generated by PCA Module")
#' )
#' )
Expand Down
50 changes: 31 additions & 19 deletions man/tm_a_pca.Rd

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.