Title: | Sequential Flow Cytometry Data Gating |
---|---|
Description: | This package provides tools for automated sequential gating analogous to the manual gating strategy based on the density of the data. |
Authors: | Mehrnoush Malek,M. Jafar Taghiyar |
Maintainer: | Mehrnoush Malek <[email protected]> |
License: | Artistic-2.0 |
Version: | 1.41.0 |
Built: | 2025-01-21 05:47:36 UTC |
Source: | https://github.com/bioc/flowDensity |
"CellPopulation"
This class represents the output of 'flowDensity(.)' function from flowDensity package.
Objects can be created by calls of the form new("CellPopulation", ...)
.
flow.frame
:Object of class "flowFrame"
representing the flow cytometry data of the cell population
proportion
:Object of class "numeric"
representing proportion of the cell population with respect to its parent cell population
cell.count
:Object of class "numeric"
representing cell count of the cell population
channels
:Object of class "character"
representing channel names corresponding to the 2 dimensions where the cell population is extracted
position
:Object of class "logical"
representing position of the cell population in the 2-dimensional space
gates
:Object of class "numeric"
representing thresholds on each channel used to gate the cell population
filter
:Object of class "matrix"
representing boundary of the cell population using a convex polygon
index
:Object of class "numeric"
representing indices of the data points in the cell population with respect to its parent cell population
signature(obj = "CellPopulation", channels = "ANY", position = "logical", singlet.gate = "missing")
: ...
signature(obj = "CellPopulation", channels = "missing", position = "missing", singlet.gate = "logical")
: ...
signature(obj = "CellPopulation")
: ...
signature(x = "flowFrame", y = "CellPopulation")
: ...
Jafar Taghiyar <email: <[email protected]>>
showClass("CellPopulation")
showClass("CellPopulation")
Find the best threshold for a single channel in flow cytometry data based on its density distribution.
deGate(obj,channel, n.sd = 1.5, use.percentile = FALSE, percentile =NA,use.upper=FALSE, upper = NA,verbose=TRUE,twin.factor=.98, bimodal=F,after.peak=NA,alpha = 0.1, sd.threshold = FALSE, all.cuts = FALSE, tinypeak.removal=1/25, adjust.dens = 1,count.lim=20,magnitude=.3,slope.w=4,seq.w = 4, spar = 0.4, ...)
deGate(obj,channel, n.sd = 1.5, use.percentile = FALSE, percentile =NA,use.upper=FALSE, upper = NA,verbose=TRUE,twin.factor=.98, bimodal=F,after.peak=NA,alpha = 0.1, sd.threshold = FALSE, all.cuts = FALSE, tinypeak.removal=1/25, adjust.dens = 1,count.lim=20,magnitude=.3,slope.w=4,seq.w = 4, spar = 0.4, ...)
obj |
obj: a 'FlowFrame' object, 'CellPopulation' or 'GatingHierarchy' |
channel |
a channel's name or its corresponding index in the 'flow.frame'. |
n.sd |
an integer coefficient for the standard deviation to determine the threshold based on the standard deviation if 'sd.threshold' is TRUE. |
use.percentile |
if TRUE, forces to return the 'percentile'th threshold. |
percentile |
A value in [0,1] that is used as the percentile. The default is NA. If set to a value(n) and use.percentile=F, it returns the n-th percentile, for 1-peak populations. |
use.upper |
Logical. If TRUE, forces to return the inflection point based on the first (last) peak if upper=F (upper=T). Default value is set to 'FALSE' |
upper |
if TRUE, finds the change in the slope at the tail of the density curve, if FALSE, finds it at the head. Default value is set to 'NA'. |
verbose |
Logical. If TRUE, Prints a message if only one peak is found, or when inflection point is used to set the gates. |
twin.factor |
a value in [0,1] that is used to exclude twinpeaks |
bimodal |
Logical. If TRUE, it returns a cutoff that splits population closer to 50-50, when there are more than two peaks. |
after.peak |
Logical. If TRUE, it returns a cutoff that is after the maximum peaks, when there are more than two peaks. |
alpha |
a value in [0,1) specifying the significance of change in the slope being detected. This is by default 0.1, and typically need not be changed. |
sd.threshold |
if TRUE, uses 'n.sd' times standard deviation as the threshold. Default value is set to 'FALSE'. |
all.cuts |
if TRUE, returns all the identified cutoff points, i.e. potential thresholds for that channel. Default value is set to 'FALSE'. |
tinypeak.removal |
A number in [0,1] to exclude/include tiny peaks in density distribution. |
adjust.dens |
The smoothness of density in [0,Inf] to be used in density(.). The default value is 1 and should not be changed unless necessary |
count.lim |
minimum limit for events count in order to calculate the threshold. Default is 20, returning NA as threshold. |
magnitude |
A value between 0 and 1, for tracking a slope and reporting changes that are smaller than magnitude*peak_height |
slope.w |
window.width for tracking slope. Default is 4, calculating a slope based on 4 points before and after the current point. |
seq.w |
value used for making the sequence of density points, used in trackSlope. |
spar |
value used in smooth.spline function, used in generating the density, default is 0.4. |
... |
Extra arguments to be passed to smoothSpline function. |
deGate works for GatingHierarchy, flowFrame, CellPopulation object or a numeric vector of data. In case the input is a numeric vector, channel doesn't need to provided, but the rest of arguments can be used to tune the outcome.
an integer value (vector) of cutoff(s), i.e. threshold(s), on the specified channel
Mehrnoush Malek <[email protected]>
getflowFrame
notSubFrame
flowDensity
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) #Find the threshold for CD20 cd19.gate <- deGate(f,channel="PerCP-Cy5-5-A") # Gate out the CD20- populations using the notSubFrame plotDens(f,c("APC-H7-A","PerCP-Cy5-5-A")) abline(h=cd19.gate,lty=3,col=2)
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) #Find the threshold for CD20 cd19.gate <- deGate(f,channel="PerCP-Cy5-5-A") # Gate out the CD20- populations using the notSubFrame plotDens(f,c("APC-H7-A","PerCP-Cy5-5-A")) abline(h=cd19.gate,lty=3,col=2)
flowDensity
in Package flowDensity Methods for function flowDensity
in package flowDensity
obj |
GatingHierarchy or |
channels |
a vector of two channel names or their corresponding indices. |
position |
a vector of two logical values specifying the position of the cell subset of interest on the 2D plot. |
... |
This can be used to pass one of the following arguments:
|
a CellPopulation object.
an accessor for 'CellPopulation' class to get its 'FlowFrame' object. This will remove all the NA values in the frame.
getflowFrame(obj)
getflowFrame(obj)
obj |
a 'CellPopulation' object. |
a 'FlowFrame' object.
Jafar Taghiyar <[email protected]>
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) lymph <- flowDensity(obj=f, channels=c('FSC-A', 'SSC-A'), position=c(TRUE, NA)) f.lymph <- getflowFrame(lymph)
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) lymph <- flowDensity(obj=f, channels=c('FSC-A', 'SSC-A'), position=c(TRUE, NA)) f.lymph <- getflowFrame(lymph)
Find all peaks in density along with their indices
getPeaks(obj, channel,tinypeak.removal=1/25, adjust.dens=1,verbose=F,twin.factor=1,spar = 0.4,...)
getPeaks(obj, channel,tinypeak.removal=1/25, adjust.dens=1,verbose=F,twin.factor=1,spar = 0.4,...)
obj |
a 'FlowFrame', 'GatingHierarchy', 'CellPopulation' a density object or a numeric vector of density. |
channel |
a channel's name or its corresponding index. If the input is numeric vector, channel is NA. |
tinypeak.removal |
A number in [0,1] to exclude/include tiny peaks in density distribution. Default is 1/25. |
adjust.dens |
The smoothness of density in [0,Inf] to be used in density(.). The default value is 1 and should not be changed unless necessary |
verbose |
If TRUE, printing warnings. |
twin.factor |
If smaller than 1, peaks that are of greater than hieght as the maximum peak*twin.factor will be removed. |
spar |
argument to pass to smoothSpline function, default value of spar is 0.4. |
... |
Other arguments that can be passed to smoothSpline function. |
a list, including peaks, their corresponding indices and height.
Mehrnoush Malek <[email protected]>
deGate
notSubFrame
flowDensity
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) #Find the threshold for CD20 peaks <- getPeaks(f,channel="PerCP-Cy5-5-A",tinypeak.removal=1/30) peaks
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) #Find the threshold for CD20 peaks <- getPeaks(f,channel="PerCP-Cy5-5-A",tinypeak.removal=1/30) peaks
Remove the margin events on the axes. Usually, these events are considered as debris or artifacts. This is specifically useful for 'FSC' and 'SSC' channels in a 'FlowFrame' object. However, any channel can be input as an argument.
nmRemove( flow.frame, channels, neg=FALSE, verbose=FALSE,return.ind=FALSE)
nmRemove( flow.frame, channels, neg=FALSE, verbose=FALSE,return.ind=FALSE)
flow.frame |
a 'FlowFrame' object. |
channels |
a vector of channel names or their corresponding indices. |
neg |
if TRUE, negative events are also removed |
verbose |
if TRUE, it prints the margin event in each channel |
return.ind |
if TRUE, it return indices of margin events for each channel. |
a 'FlowFrame' object, or a 'list' of indices identifying margin events for each channel.
Jafar Taghiyar <[email protected]> Mehrnoush Malek <[email protected]>
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_2', data_dir, full = TRUE)) #Removing margin events of FSC-A and SSC-A channels no.margin <- nmRemove(f2, c("FSC-A","SSC-A"),verbose=TRUE) plotDens(f2, c("FSC-A","SSC-A")) # Scatter plot of FSC-A vs. SSC-A after removing margins plotDens(no.margin, c("FSC-A","SSC-A"))
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_2', data_dir, full = TRUE)) #Removing margin events of FSC-A and SSC-A channels no.margin <- nmRemove(f2, c("FSC-A","SSC-A"),verbose=TRUE) plotDens(f2, c("FSC-A","SSC-A")) # Scatter plot of FSC-A vs. SSC-A after removing margins plotDens(no.margin, c("FSC-A","SSC-A"))
Remove a subset of a FlowFrame object specified by gates from the flowDensity method. It comes in handy when one needs the complement of a cell population in the input flow cytometry data.
notSubFrame(obj, channels, position = NA, gates, filter)
notSubFrame(obj, channels, position = NA, gates, filter)
obj |
a 'FlowFrame' or 'cellPopulation' object. |
channels |
a vector of two channel names or their corresponding indices in the 'flow.frame'. |
position |
a vector of two logical values specifying the position of the cell subset of interest on the 2D plot. |
gates |
the gates slot in the CellPoulation object which is output by flowDensity function. It can also be a vector of two integer values each of which specifies a threshold for the corresponding channel in 'channels' argument. |
filter |
boundary of the subset to be removed. This value is stored in the 'filter' slot of a 'CellPopulation' object. |
a CellPopulation object.
Mehrnoush Malek <[email protected]>
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) #Find the threshold for CD20 cd20.gate <- deGate(f,channel="APC-H7-A") # Gate out the CD20- populations using the notSubFrame CD20.pos <- notSubFrame(f,channels=c("APC-H7-A","PerCP-Cy5-5-A"),position=c(FALSE,NA),gates=c(cd20.gate,NA)) #Plot the CD20+ cells on same channels plotDens([email protected],c("APC-H7-A","PerCP-Cy5-5-A"))
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) #Find the threshold for CD20 cd20.gate <- deGate(f,channel="APC-H7-A") # Gate out the CD20- populations using the notSubFrame CD20.pos <- notSubFrame(f,channels=c("APC-H7-A","PerCP-Cy5-5-A"),position=c(FALSE,NA),gates=c(cd20.gate,NA)) #Plot the CD20+ cells on same channels plotDens(CD20.pos@flow.frame,c("APC-H7-A","PerCP-Cy5-5-A"))
Generate a scatter dot plot with colors based on the distribution of the density of the provided channels.
plotDens(obj, channels ,col, main, xlab, ylab, xlim,ylim, pch=".", density.overlay=c(FALSE,FALSE),count.lim=20, dens.col=c("grey48","grey48"),cex=1, dens.type=c("l","l"),transparency=1, adjust.dens=1,show.contour=F, contour.col="darkgrey", verbose=TRUE,...)
plotDens(obj, channels ,col, main, xlab, ylab, xlim,ylim, pch=".", density.overlay=c(FALSE,FALSE),count.lim=20, dens.col=c("grey48","grey48"),cex=1, dens.type=c("l","l"),transparency=1, adjust.dens=1,show.contour=F, contour.col="darkgrey", verbose=TRUE,...)
obj |
a 'FlowFrame', or 'cellPopulation' object. |
channels |
a vector of two channel names or their corresponding indices in the 'flow.frame'. |
col |
A specification for the default plotting color: see '?par'. |
main |
an overall title for the plot: see '?plot' |
xlab |
a title for the x axis: see '?plot' |
ylab |
a title for the y axis: see '?plot' |
xlim |
a range for the x axis: see '?plot' |
ylim |
a range for the y axis: see '?plot' |
pch |
Either an integer specifying a symbol or a single character to be used as the default in plotting points: see '?par'. |
density.overlay |
Logical vector of length 2, to plot density overlays on the x and y axes. Default is c(FALSE,FALSE). |
count.lim |
Cutoff for number of events to set color. Default is 20. Samples with less than 20 cells will be plotted in black. |
dens.col |
2-character string giving the color of plot desired for density curves. |
cex |
Size of the points for the plot. For more information look at ?plot in graphics. |
dens.type |
2-character string giving the type of plot desired. |
transparency |
Transparency of the bi-variate plot, to see the densitu curves in the background. The lower it is, the more transparent the plot is. |
adjust.dens |
The smoothness of density in [0,Inf] to be used in density(.). The default value is 1 and should not be changed unless necessary |
show.contour |
Default is FALSE. It add the contourLines to plot. |
contour.col |
Color for contourLines. Default is darkgrey. |
verbose |
Default is True. It will add that the sample has 0 cells in the plot title. |
... |
can be used to provide desired arguments for the plot() function used to plot the output results. |
a scatter dot plot with density-based colors, along with density overlays if desired. Set xlim and ylim when plotting if you would like to have all your plots to have same range on the axes (specially when density.overlay=TRUE)
Mehrnoush Malek <[email protected]> Jafar Taghiyar <[email protected]>
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) #Plot CD3 vs. CD19 to see the distribution of cell populations and their density plotDens(f,c("V450-A","PerCP-Cy5-5-A"))
data_dir <- system.file("extdata", package = "flowDensity") load(list.files(pattern = 'sampleFCS_1', data_dir, full = TRUE)) #Plot CD3 vs. CD19 to see the distribution of cell populations and their density plotDens(f,c("V450-A","PerCP-Cy5-5-A"))