This vignette will guide you through analysis of an example
flow cytometry data set from an experiment examining time-lapse
florescence reporter levels from a synthetic biological circuit in
liquid cultures of budding yeast. In this example circuit, fluorescent
reporter expression is mediated by a transcription
factor/transcriptional repressor complex. The transcriptional repressor
is degraded via the ubiquitin proteasome system, in response to a small
molecule. Fluorescence levels are measured approximately every 10
minutes by flow cytometry. Here we demonstrate how to import the
resulting .fcs files into R, gate and annotate this data with
experimental metadata (e.g. the strain
and
treatment
for each sample), generate summary statistics for
each sample and time point and finally plot this data (in this case,
activation curves).
#Importing and annotating data Import your flow cytometry data using
read.flowset
. Here, we will import an example flowSet.
plate1<-read.flowSet(path=system.file("extdata", "tc_example", package = "flowTime"), alter.names = TRUE)
# add plate numbers to the sampleNames, in this example we have already done this
# step
# sampleNames(plate1)<-paste("1_",sampleNames(plate1),sep="")
dat<-plate1
If you have several plates this code can be repeated and each plate
can be combined (using rbind2
) to assemble the full data
set.
plate2<-read.flowSet(path = paste(experiment,"_2/",sep=""), alter.names = TRUE)
sampleNames(plate2)<-paste("2_", sampleNames(plate2), sep = "")
dat<-rbind2(plate1, plate2)
Now we import the table of metadata.
The sampleNames
of the assembled flowSet
(dat
in this example) must match that of a unique
identifier column of annotation
. We can also create this
column from our data set and attach the annotation columns. The order of
the unique identifier column does not matter, as
annotateFlowSet
will join annotation
to
dat
by matching identifiers.
sampleNames(dat) # view the sample names
sampleNames(dat) == annotation$id
# Replace 'id' with the unique identifier column to test,
# if this column is identical to the sample names of your flowset.
annotation <- cbind(annotation, 'names' = sampleNames(dat))
# If the sampleNames and unique identifiers are in the correct order
# this command will add the sampleNames as the identifier.
Finally we can attach this metadata to the flowSet using the
annotateFlowSet
function.
adat <- annotateFlowSet(dat, annotation)
head(rownames(pData(adat)))
#> [1] "0_A08.fcs" "0_B08.fcs" "0_C08.fcs" "0_D08.fcs" "0_E08.fcs" "0_F08.fcs"
head(pData(adat))
#> name X strain RD ARF AFB treatment
#> 0_A08.fcs 0_A08.fcs 0_A08 3 TPLRD1 19 AFB2 0
#> 0_B08.fcs 0_B08.fcs 0_B08 3 TPLRD1 19 AFB2 0
#> 0_C08.fcs 0_C08.fcs 0_C08 3 TPLRD1 19 AFB2 0
#> 0_D08.fcs 0_D08.fcs 0_D08 3 TPLRD1 19 AFB2 0
#> 0_E08.fcs 0_E08.fcs 0_E08 3 TPLRD1 19 AFB2 0
#> 0_F08.fcs 0_F08.fcs 0_F08 3 TPLRD1 19 AFB2 0
Now we can save this flowSet and anyone in perpetuity can load and analyze this annotated flowSet with ease!
write.flowSet(adat, outdir = 'your/favorite/directory')
read.flowSet('flowSet folder', path = 'your/flow/directory',
phenoData = 'annotation.txt', alter.names = TRUE)
#Compiling and plotting data Now we are ready to analyze the raw data
in this flowSet
. For this time-course experiment we will
use the summarizeFlow
function. This function will gate
each flowFrame
in the flowSet
and compile and
return a dataframe
of summary statistics for the specified
channel each flowFrame
. This dataframe
can
then be used to visualize the full data set.
#load the gate set for BD Accuri C6 cytometer
loadGates(gatesFile = 'C6Gates.RData', path = system.file("extdata", package = "flowTime"))
dat_sum <- summarizeFlow(adat, ploidy = 'diploid',
only = 'singlets',channel = 'FL1.A')
#> [1] "Gating with diploid singlet gates..."
#> Warning: There was 1 warning in `dplyr::summarise()`.
#> ℹ In argument: `dplyr::across(...)`.
#> Caused by warning:
#> ! Using `across()` without supplying `.cols` was deprecated in dplyr 1.1.0.
#> ℹ Please supply `.cols` instead.
qplot(x = time, y= FL1.Amean, data = dat_sum, linetype = factor(treatment)) +
geom_line() + xlab('Time post Auxin addition (min)') +
ylab('Reporter Fluorescence (AU)') +
scale_color_discrete(name=expression(paste("Auxin (",mu,"M)",sep = ""))) +
theme_classic(base_size = 14, base_family = 'Arial')
#> Warning: `qplot()` was deprecated in ggplot2 3.4.0.
#> This warning is displayed once every 8 hours.
#> Call `lifecycle::last_lifecycle_warnings()` to see where this warning was
#> generated.