Title: | 'DataSHIELD' 'Tidyverse' Serverside Package |
---|---|
Description: | Implementation of selected 'Tidyverse' functions within 'DataSHIELD', an open-source federated analysis solution in R. Currently, DataSHIELD contains very limited tools for data manipulation, so the aim of this package is to improve the researcher experience by implementing essential functions for data manipulation, including subsetting, filtering, grouping, and renaming variables. This is the serverside package which should be installed on the server holding the data, and is used in conjuncture with the clientside package 'dsTidyverseClient' which is installed in the local R environment of the analyst. For more information, see <https://www.tidyverse.org/> and <https://datashield.org/>. |
Authors: | Tim Cadman [aut, cre] , Mariska Slofstra [aut] , Stuart Wheater [aut], Demetris Avraam [aut] |
Maintainer: | Tim Cadman <[email protected]> |
License: | LGPL (>= 2.1) |
Version: | 1.0.1 |
Built: | 2024-10-28 10:20:47 UTC |
Source: | https://github.com/molgenis/ds-tidyverse |
DataSHIELD implentation of dplyr::arrange
.
arrangeDS(tidy_expr, df.name, .by_group)
arrangeDS(tidy_expr, df.name, .by_group)
tidy_expr |
Variables, or functions of variables. Use |
df.name |
A data frame, data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
.by_group |
If TRUE, will sort first by grouping variable. Applies to grouped data frames only. |
An object of the same type as df.name
, typically a data frame or tibble.
DataSHIELD implementation of tibble::as_tibble
. Currently only implemented for data frames and matrices.
asTibbleDS(tidy_expr, x, .rows, .name_repair, rownames)
asTibbleDS(tidy_expr, x, .rows, .name_repair, rownames)
tidy_expr |
Unused in present function. |
x |
A data frame or matrix. |
.rows |
The number of rows, useful to create a 0-column tibble or just as an additional check. |
.name_repair |
Treatment of problematic column names:
|
rownames |
How to treat existing row names of a data frame or matrix:
|
A tibble.
DataSHIELD implementation of dplyr::bind_cols
.
bindColsDS(to_combine = NULL, .name_repair = NULL)
bindColsDS(to_combine = NULL, .name_repair = NULL)
to_combine |
Data frames to combine. Each argument can either be a data frame, a list that could be a data frame, or a list of data frames. Columns are matched by name, and any missing columns will be filled with NA. |
.name_repair |
One of "unique", "universal", or "check_unique". See
|
A data frame the same type as the first element of to_combine
DataSHIELD implementation of dplyr::bind_rows
.
bindRowsDS(to_combine = NULL, .id = NULL)
bindRowsDS(to_combine = NULL, .id = NULL)
to_combine |
Data frames to combine. Each argument can either be a data frame, a list that could be a data frame, or a list of data frames. Columns are matched by name, and any missing columns will be filled with NA. |
.id |
he name of an optional identifier column. Provide a string to create an output column that identifies each input. The column will use names if available, otherwise it will use positions. |
A data frame the same type as the first element of to_combine
DataSHIELD implentation of dplyr::case_when
.
caseWhenDS(tidy_expr = NULL, .default = NULL, .ptype = NULL, .size = NULL)
caseWhenDS(tidy_expr = NULL, .default = NULL, .ptype = NULL, .size = NULL)
tidy_expr |
A sequence of two-sided formulas. The left hand side (LHS) determines which values match this case. The right hand side (RHS) provides the replacement value. The LHS inputs must evaluate to logical vectors. The RHS inputs will be coerced to their common type. All inputs will be recycled to their common size. That said, we encourage all LHS inputs to be the same size. Recycling is mainly useful for RHS inputs, where you might supply a size 1 input that will be recycled to the size of the LHS inputs. NULL inputs are ignored. |
.default |
The value used when all of the LHS inputs return either FALSE or NA. |
.ptype |
An optional prototype declaring the desired output type. If supplied, this overrides the common type of true, false, and missing. |
.size |
An optional size declaring the desired output size. If supplied, this overrides the size of condition. |
A vector with the same size as the common size computed from the inputs in tidy_expr
and the same type as the common type of the RHS inputs in tidy_expr
.
This serverside function check that the server is running in "permissive" privacy control level.
checkPermissivePrivacyControlLevel(privacyControlLevels)
checkPermissivePrivacyControlLevel(privacyControlLevels)
privacyControlLevels |
is a vector of strings which contains the privacy control level names which are permitted by the calling method. |
Tests whether the R option "datashield.privacyControlLevel" is set to "permissive", if it isn't will cause a call to stop() with the message "BLOCKED: The server is running in 'non-permissive' mode which has caused this method to be blocked".
Returns an error if the method is not permitted; otherwise, no value is returned.
Wheater, Dr SM., DataSHIELD Team.
DataSHIELD implentation of dplyr::distinct
.
distinctDS(tidy_expr, df.name, .keep_all)
distinctDS(tidy_expr, df.name, .keep_all)
tidy_expr |
Optional variables to use when determining uniqueness. If there are multiple rows for a given combination of inputs, only the first row will be preserved. If omitted, will use all variables in the data frame. |
df.name |
A data frame, data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
.keep_all |
If TRUE, keep all variables in df.name If a combination of expr is not distinct, this keeps the first row of values. |
An object of the same type as df.name
, typically a data frame or tibble.
DataSHIELD implentation of dplyr::filter
.
filterDS(tidy_expr, df.name, .by, .preserve)
filterDS(tidy_expr, df.name, .by, .preserve)
tidy_expr |
Diffused expression that return a logical value, and are defined in terms of the
variables in |
df.name |
A data frame, data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
.by |
Optionally, a selection of columns to group by for just this operation, functioning as
an alternative to |
.preserve |
Relevant when the df.name input is grouped. If .preserve = FALSE (the default), the grouping structure is recalculated based on the resulting data, otherwise the grouping is kept as is. |
An object of the same type as df.name
, typically a data frame or tibble.
DataSHIELD implentation of dplyr::group_by
.
groupByDS(tidy_expr, df.name, .add, .drop)
groupByDS(tidy_expr, df.name, .add, .drop)
tidy_expr |
Diffused grouping expression. |
df.name |
A data frame, data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
.add |
When FALSE, the default, |
.drop |
Drop groups formed by factor levels that don't appear in the data? The default is TRUE except when df.name has been previously grouped with .drop = FALSE. |
A grouped data frame with class grouped_df, unless the combination of tidy_expr
and .add
yields a empty set of grouping columns, in which case a tibble will be returned.
group_keys
.DataSHIELD implentation of dplyr::group_keys
groupKeysDS(tidy_select, x)
groupKeysDS(tidy_select, x)
tidy_select |
Unused in this function. |
x |
a grouped tibble. |
A data frame describing the groups.
DataSHIELD implentation of dply::if_else
.
ifElseDS( condition = NULL, true = NULL, false = NULL, missing = NULL, ptype = NULL, size = NULL )
ifElseDS( condition = NULL, true = NULL, false = NULL, missing = NULL, ptype = NULL, size = NULL )
condition |
A list, specifying a logical vector in tidyverse syntax, ie data and column names unquoted. |
true |
Vector to use for TRUE value of condition. |
false |
Vector to use for FALSE value of condition. |
missing |
If not NULL, will be used as the value for NA values of condition. Follows the same size and type rules as true and false. |
ptype |
An optional prototype declaring the desired output type. If supplied, this overrides the common type of true, false, and missing. |
size |
An optional size declaring the desired output size. If supplied, this overrides the size of condition. |
A vector with the same size as condition
and the same type as the common type of true
, false
, and missing
.
This function returns a vector of function names that are permitted to be passed within the dsTidyverse functions, e.g. within the 'tidy_select' argument of 'ds.mutate.'
listPermittedTidyverseFunctionsDS()
listPermittedTidyverseFunctionsDS()
A character vector of function names, each representing a permitted function. Functions not included in this list will be blocked.
DataSHIELD implentation of mutate
.
mutateDS(tidy_expr, df.name, .keep = NULL, .before = NULL, .after = NULL)
mutateDS(tidy_expr, df.name, .keep = NULL, .before = NULL, .after = NULL)
tidy_expr |
Name-value pairs. The name gives the name of the column in the output. |
df.name |
A data frame, data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
.keep |
.keep Control which columns from
Grouping columns and columns created by |
.before |
<tidy-select> Optionally, control where new columns should appear (the default is
to add to the right hand side). See |
.after |
<tidy-select> Optionally, control where new columns should appear (the default is
to add to the right hand side). See |
An object of the same type as df.name
, typically a data frame or tibble.
DataSHIELD implentation ofdplyr::rename
.
renameDS(tidy_expr, df.name)
renameDS(tidy_expr, df.name)
tidy_expr |
list containing diffused expression. |
df.name |
A data frame or tibble. |
An object of the same type as df.name
, typically a data frame or tibble.
DataSHIELD implentation of dplyr::select
.
selectDS(tidy_expr, df.name)
selectDS(tidy_expr, df.name)
tidy_expr |
One or more unquoted expressions separated by commas. |
df.name |
A data frame or tibble. |
Performs dplyr select
An object of the same type as df.name
, typically a data frame or tibble.
DataSHIELD implentation of dplyr::slice
.
sliceDS(tidy_expr, df.name, .by, .preserve)
sliceDS(tidy_expr, df.name, .by, .preserve)
tidy_expr |
Provide either positive values to keep, or negative values to drop. The values provided must be either all positive or all negative. Indices beyond the number of rows in the input are silently ignored. |
df.name |
A data frame, data frame extension (e.g. a tibble), or a lazy data frame (e.g. from dbplyr or dtplyr). |
.by |
Optionally, a selection of columns to group by for just this operation, functioning as
an alternative to |
.preserve |
Relevant when the df.name input is grouped. If .preserve = FALSE (the default), the grouping structure is recalculated based on the resulting data, otherwise the grouping is kept as is. |
An object of the same type as df.name
, typically a data frame or tibble.
DataSHIELD implentation of dplyr::ungroup
.
ungroupDS(tidy_expr, x)
ungroupDS(tidy_expr, x)
tidy_expr |
Unused in this function. |
x |
A tibble. |
An ungrouped data frame or tibble.