A wrapper function for isOutlier. Identify outliers from numeric vectors stored in the SingleCellExperiment object.

detectCellOutlier(
  inSCE,
  slotName,
  itemName,
  sample = NULL,
  nmads = 3,
  type = "both",
  overwrite = TRUE
)

Arguments

inSCE

A SingleCellExperiment object.

slotName

Desired slot of SingleCellExperiment used for plotting. Possible options: "assays", "colData", "metadata", "reducedDims". Required.

itemName

Desired vector within the slot used for plotting. Required.

sample

A single character specifying a name that can be found in colData(inSCE) to directly use the cell annotation; or a character vector with as many elements as cells to indicates which sample each cell belongs to. Default NULL. decontX will be run on cells from each sample separately.

nmads

Integer. Number of median absolute deviation. Parameter may be adjusted for more lenient or stringent outlier cutoff. Default 3.

type

Character. Type/direction of outlier detection; whether the lower/higher outliers should be detected, or both. Options are "both", "lower", "higher".

overwrite

Boolean. If TRUE, and this function has previously generated an outlier decision on the same itemName, the outlier decision will be overwritten. Default TRUE.

Value

A SingleCellExperiment object with '' added to the

colData slot. Additionally, the decontaminated counts will be added as an assay called 'decontXCounts'.

Examples

data(scExample, package = "singleCellTK")
sce <- subsetSCECols(sce, colData = "type != 'EmptyDroplet'")
sce <- runDecontX(sce[,sample(ncol(sce),20)])
#> Tue Jun 28 22:02:48 2022 ... Running 'DecontX'
#> --------------------------------------------------
#> Starting DecontX
#> --------------------------------------------------
#> Tue Jun 28 22:02:48 2022 .. Analyzing all cells
#> Tue Jun 28 22:02:48 2022 .... Generating UMAP and estimating cell types
#> Tue Jun 28 22:02:51 2022 .... Estimating contamination
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 10 | converge: 0.02066
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 20 | converge: 0.008663
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 30 | converge: 0.004864
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 40 | converge: 0.003151
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 50 | converge: 0.002
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 60 | converge: 0.00177
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 70 | converge: 0.002201
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 80 | converge: 0.001666
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 90 | converge: 0.001212
#> Tue Jun 28 22:02:51 2022 ...... Completed iteration: 97 | converge: 0.0009997
#> Tue Jun 28 22:02:51 2022 .. Calculating final decontaminated matrix
#> --------------------------------------------------
#> Completed DecontX. Total time: 2.438382 secs
#> --------------------------------------------------
sce <- detectCellOutlier(sce, slotName = "colData", sample = sce$sample,
 nmads = 4, itemName = "decontX_contamination", type = "both")