PharmacoGx 3.9.0
The PharmacoSet class is structured to contain several different types of
genomic data, as well as drug dose response data. It is built upon base R data
types and the SummarizedExperiment
class. However, a PharmacoSet
object
requires the presence of specific annotations for the data to be able to
function correctly with the function provided in PharmacoGx. The structure
allows users to then interrogate the data on the basis of cells and drugs,
removing the need for the user to deal with single experiments. We do not
recommend creating PharmacoSet objects by the end users, rather we recommend
contacting us to have the objects created for your dataset of interest.
However, for completeness and power users the process and structure is
documented below.
The base PharmacoSet structure is as follows:
sample
Previously called @cell
.
This slot contains a data.frame
which contains information about all the cells
profiles across all the data types in the PharamcoSet, including both
perturbation and sensitivity experiments. It is crucial for the rownames of each
entry in the data frame to be the unique sample identifier used across all the
datatypes for each cell type. The content of this data frame will vary based on
what information each dataset provides. Mandatory columns in this data frame
must be sampleid
, which should be equivalent to the rownames and tissueid
,
which contains a curated annotation of the source tissue for each cell line.
An example of a sample
slot is shown below:
sample <- data.frame(
sampleid = c("A549", "MCF7", "PC3"),
tissueid = c("lung", "breast", "prostate"),
cellosaurus.accession = c("CVCL_0023", "CVCL_0031", "CVCL_0035"),
row.names = c("A549", "MCF7", "PC3"))
sample
sampleid tissueid cellosaurus.accession
A549 A549 lung CVCL_0023
MCF7 MCF7 breast CVCL_0031
PC3 PC3 prostate CVCL_0035
treatment
Previously called @drug
.
This slot contains a data.frame
which contains information about all the drugs
profiled across all the data types in the PharmacoSet, including both
perturbation and sensitivity experiments. Similar to the sample
slot, it is
crucial for the rownames of each entry in the data frame to be the
unique treatment identifier used across all the datatypes for each compound.
Once again, the content in this data frame will vary based on information
provided by each dataset. Mandatory columns must be treatmentid
, which should
be equivalent to the object rownames.
treatment <- data.frame(
treatmentid = c("Doxorubicin", "Tamoxifen", "Docetaxel"),
chembl.MechanismOfAction = c("DNA topoisomerase II inhibitor", "Estrogen receptor antagonist", "Microtubule inhibitor"),
row.names = c("Doxorubicin", "Tamoxifen", "Docetaxel"))
treatment
treatmentid chembl.MechanismOfAction
Doxorubicin Doxorubicin DNA topoisomerase II inhibitor
Tamoxifen Tamoxifen Estrogen receptor antagonist
Docetaxel Docetaxel Microtubule inhibitor
curation
:This slot contains three data.frames, one for sample
, treatment
, and tissue
.
Each contains two columns, the first with the unique identifier that is used between
all PharmacoSet objects for this drug, and the second with the identifier used
within the dataset. At this time there is no set method to find the unique
identifiers between all PharmacoSets for arbitrary drugs, as much labour
intensive curation has gone into carefully matching identifiers between datasets.
However, these tables are used only by the intersecting function, and all other
functions will function without this data, therefore for PharmacoSet objects
created by users, we recommend just filling both columns with the identifiers
used in the datasets, to allow for at least some matching to be done.
sample
: data frame annotating all cell-lines investigated in the study.treatment
: data frame annotating all the compounds investigated in the study.tissue
: data.frame annotating all tissues investigated in the study.molecularProfiles
:Either a:
SummarizedExperiment
objectsMultiAssayExperiment
objectcontaining the molecular profiles of the samples, such as mutations, gene expressions, or copy number variations.
The molecular profiles slot of a PharmacoSet object contains all the molecular
expression data profiled in the dataset. Each type of data is kept in a separate
SummarizedExperiment (SE) object, and they are all stored as a list. However, to
insure coordination between data types, there are specific annotations that must
be included in the SummarizedExperiment object. The annotations also differ
slightly in the cases of perturbation
and sensitivity
datasets.
First of all, each SummarizedExperiment object must be labelled with the type of
dataincluded within the object. Currently only mutation
, fusion
, and rna
molecular data types are recognized and handled differently by summarizing and
signature generating functions. This labelling is done by calling, for example:
SE@annotation <- "rna"
The phenoData in each SummarizedExperiment object also needs to contain specific columns labelling each experiment. For sensitivity type datasets, this has to include:
sampleid
: This column contains a cell identifier that matches exactly the
rownames of the sample
slot of the PSet.
batchid
: This column contains and id of the batch of each experiment. If
such data is not available then it is customary to fill with NA, but this column
must be present.
Additionally, for the perturbation type datasets, there are several more columns of metadata that must be included to enable the modelling of differential gene expression. These are:
treatmentid
: The identifier of the drug used in each experiment when a compound
was applied. For controls, it should be left as NA. These must match exactly
to the rownames of the treatment
slot in the PharmacoSet.
duration
: If available, the ength of the experiment. Should be 0 for
controls.
concentration
: For experiments where compounds were applied, the
concentration. Should be 0 for controls.
xptype
: A label of either perturbation
, of control
respectively.
Otherwise each SummarizedExperiment object should be constructed as specified by the SummarizedExperiment package.
Once these SummarizedExperiment objects are created, they should be:
MultiAssayExperiment
object, with the name of each assay being
descriptive of the type of data contained.datasetType
This slot is being deprecated, since perturbation
data can effectively before
stored in the colData
slot of the SummarizedExperiment
in the
molecularProfiles
slot
The datasetType
slot is a character string which signifies whether the
PharmacoSet contains drug dose sensitivity
data, genomic perturbation
data,
or both
. This slot is necessary for the subsetting and intersecting function
to be aware of what data types they should be looking for.
treatmentResponse
:Previously called @sensitivity
this slot contains viability measurements for
cell-lines treated with different therapeutic compounds.
PharmacoGx 2.0
In PharmacoGx 2.0
this slot now takes an object of the
CoreGx::treatmentResponseExperiment
class.
This class is a container for drug dose response data, and adds a layer of
functionality to incorporate drug combination data while also being able to
perform computations efficiently.
The design takes the aspects of the SummarizedExperiment
and MultiAssayExperiment
classes and implements them using the data.table
package, which provides an R API
to a rich set of tools for scalable, high performance data processing implemented in C.
To create a TreatmentResponseExperiment
object, please refer to the
The TreatmentResponseExperiment Class Documentation.
PharmacoGx 1.0
In PharmacoGx 1.0
, this was a list of data.frame
objects, each containing
the following slots:
n
: Number of experiments for each cell line treated with a given drug.info
: Metadata for each pharmacological experiment.raw
: All cell viability measurements at each drug concentration from the
drug dose-response curves.profiles
: Drug sensitivity values summarizing each dose-response curve
(IC\(_{50}\), AUC, etc.)
This is a list containing all the data pertaining to drug dose response
experiments, usually only present in sensitivity
or both
type datasets. This
includes the names the following names slots in the list:info
: Metadata for each pharmacological experiment stored in a data.frame
.
Each row of this data.frame should be labelled with a unique experiment
identifier. This data.frame must also contain specific columns:
sampleid
: Contains a cell identifier that matches exactly the rownames of
the cell slot of the PSet.
treatmentid
: The identifier of the drug used in each experiment when a compound was
applied. These must match exactly to the rownames of the drug slot in the
PharmacoSet.
raw
: This is a 3-D array
of raw drug dose response data. The first
dimension is the experiments, with the names of each row in this dimension
labelled exactly as the experiment ids used in the metadata data.frame info
above. The second dimension is the doses, with each “column” labelled as
doses
, where the number is the column number. This is as long as there are
different number of doses for each experiment. The third dimension is always
fixed at 2, with names Dose
, and Viability
. Dose
contains the actual dose
used (usually in micro-molar), while viability contains the cell viability
measurement at that dose. Therefore, for each experiment there are two vectors,
one of doses and one of viabilities at each dose.
profiles
This is a data.frame containing down the rows, with exactly
matching rownames, the experiments as labelled in the info
data.frame, and
each column being a summary of the drug dose sensitivity, such as
auc\_published
or ic50\_published
, as published with the data.
n
This is a matrix
containing cellids matching exactly the rownames of the
cell slot of the PSet down the rows, and drugids matching exactly the rownames
of the drug slot in the columns. This data.frame summaries how many experiments
are in the data for each pair, allowing quick identification of what pairs were
tested together. Note that this does not need to be generated before
constructing the object, it is generated by the constructor.
perturbation
:This slot is being deprecated, as discussed above in datasetType
.
n
: Number of experiments for each cell line perturbed by a given drug, for
each molecular data typeprofiles
: The metadata for the perturbation experiments is available for
each molecular type by calling the appropriate info functioncuration
: list of data frames containing the mapping between original drug,
cell line, and tissue names to standardized identifiers.
This slot is fully filled by the constructor, so nothing needs to be created for it.
n
: This is a 3-D array
containing cellids matching exactly the rownames of
the cell slot of the PSet down the rows, and drugids matching exactly the
rownames of the drug slot in the columns, and the third dimension being the
names of the different molecular profile types. This array summarizes how many
perturbation experiments are in each molecular data type for each pair, allowing
quick identification of what pairs were tested together.
info
: This is always exactly the string referring to each data type
separately: ‘The metadata for the perturbation experiments is available for each
molecular type by calling the appropriate info function’
annotation
The annotation
slot contains information pertaining to the PharmacoSet
as a
whole, including the full information on what packages were loaded into R when
the PharmacoSet was created, as well as the date and call to the constructor.
The only data that must be entered upon creation of the object is the name of
the PharmacoSet, which is passed to the constructor.
name
: Acronym of the pharmacogenomic dataset.dateCreated
: When the object was created.sessionInfo
: Software environment used to create the object.call
: Set of parameters used to create the object.Once all the data is in the proper format, it can be passed to a the constructor function as below:
PharmacoGx::PharmacoSet2(
name = "emptySet",
treatment = data.frame(),
sample = data.frame(),
molecularProfiles = MultiAssayExperiment::MultiAssayExperiment(),
treatmentResponse = CoreGx::TreatmentResponseExperiment(),
perturbation = list(),
curation = list(
sample = data.frame(),
treatment = data.frame(),
tissue = data.frame()),
datasetType = "sensitivity"
)
PharmacoGx::PharmacoSet(
name,
molecularProfiles=list(),
sample=data.frame(),
treatment=data.frame(),
sensitivityInfo=data.frame(),
sensitivityRaw=array(dim=c(0,0,0)),
sensitivityProfiles=matrix(),
curationTreatment=data.frame(),
curationSample=data.frame(),
curationTissue=data.frame(),
datasetType=c("sensitivity", "perturbation", "both"),
verify = TRUE)
Here, name
is the name of the PharmacoSet as described in annotations above,
molecularProfiles
is the list of ExpressionSet objects described above, cell
and drug are the data.frames in the cell and drug slots. The sensitivityInfo
,
sensitivityRaw
, sensitivityProfiles
are the elements of the sensitivity
slot, and curationTreatment, curationSample, and curationTissue the contents of the
curation slot. Finally, datasetType
is a string to signify which type of data
isincluded in the datset, and verify is a flag for running the verification of
the pSet after its construction. Any data detailed above but missing from this
constructor call will be created by the constructor, and the default empty
values are as in the call above. Notice that none of the values should be set
as NA, they should be omited if the data is not being provided.