Description Usage Arguments Details Value Author(s) References See Also Examples
Given a gene expression matrix D where rows correspond to genes and columns to samples and a list of Entrez gene ids, this function will assign the breast cancer molecular subtype using Absolute PAM50 (AIMS) (Paquet et al. under review at JNCI).
1 | applyAIMS (eset, EntrezID)
|
eset |
An ExpressionSet (Biobase) or a matrix D of gene expression. Rows are genes and columns are samples (tumor from breast cancer patients). |
EntrezID |
A character vector corresponding to the Entrez Ids of the genes of matrix D. |
We defined Absolute assignment of breast cancer Molecular Intrinsic Subtypes (AIMS) to stabilize the actual PAM50. The idea of the approach is to use simple rules of the form "if gene A expression < gene B expression assigned sample to subtype X". By using those simple rules we are able to assign subtype using only the expression values of one patient. We have shown AIMS recapitulates PAM50 subtype assignments and preserved the prognostic values of the subtypes. This function will return the subtype assignment as well as the posterior probabilities for all the subtypes.
cl |
Subtypes identified by the AIMS. It could be either "Basal", "Her2", "LumA", "LumB" or "Normal". |
prob |
A vector corresponding to the posterior probabilities of the subtypes in cl. |
all.probs |
A matrix of all the posterior probabilities for all the samples and all the subtypes |
rules.matrix |
The matrix of 100 rules used by AIMS to assign the breast cancer subtypes. Rows correspond to rules and columns to samples. This is a 0,1 matrix in which 1 represents the rules is true and 0 the rule is false |
data.used |
The expression values used to evaluate the simple rules. |
EntrezID.used |
The list of Entrez ids used by AIMS |
Eric R. Paquet (eric.r.paquet@gmail.com)
Parker, Joel S. and Mullins, Michael and Cheang, Maggie C.U. and Leung, Samuel and Voduc, David and Vickery, Tammi and Davies, Sherri and Fauron, Christiane and He, Xiaping and Hu, Zhiyuan and Quackenbush, John F. and Stijleman, Inge J. and Palazzo, Juan and Marron, J.S. and Nobel, Andrew B. and Mardis, Elaine and Nielsen, Torsten O. and Ellis, Matthew J. and Perou, Charles M. and Bernard, Philip S. (2009) "Supervised Risk Predictor of Breast Cancer Based on Intrinsic Subtypes", Journal of Clinical Oncology, 27(8):1160–1167
Donald Geman, Christian d'Avignon, Daniel Q. Naiman and Raimond L. Winslow (2004) "Classifying Gene Expression Profiles from Pairwise mRNA Comparisons", Stat Appl Genet Mol Biol., 3: Article19.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 | ## Load the McGill dataset used in the paper
data(mcgillExample)
## Convert the expression matrix to an ExpressionSet.
## could also send directly an expresion matrix
mcgillExample$D <- ExpressionSet(assayData=mcgillExample$D)
## Assigne AIMS on McGill dataset
mcgill.AIMS.subtypes.batch <- applyAIMS (mcgillExample$D,
mcgillExample$EntrezID)
## Print a summary of all the subtype in the dataset
table(mcgill.AIMS.subtypes.batch$cl)
## We can do the samething using only one sample
mcgill.AIMS.subtypes.first <- applyAIMS (mcgillExample$D[,1,drop=FALSE],
mcgillExample$EntrezID)
table(mcgill.AIMS.subtypes.first$cl)
if (mcgill.AIMS.subtypes.batch$cl[1] == mcgill.AIMS.subtypes.first$cl[1]){
message("Identical assignment batch and first sample")
}else{
message("Different assignment batch and first sample")
}
## We can do the samething for the first 20 samples
mcgill.AIMS.subtypes.first20 <- applyAIMS (mcgillExample$D[,1:20,drop=FALSE],
mcgillExample$EntrezID)
table(mcgill.AIMS.subtypes.first20$cl)
if (all(mcgill.AIMS.subtypes.batch$cl[1:20] == mcgill.AIMS.subtypes.first20$cl)){
message("Identical assignment batch and first 20")
}else{
message("Different assignment batch and first 20")
}
## We can do the samething using 50 randomly selected samples, no
## set.seed needed
sel.rand.50 = sample(1:ncol(mcgillExample$D),50)
mcgill.AIMS.subtypes.rand50 <- applyAIMS (mcgillExample$D[,sel.rand.50,drop=FALSE],
mcgillExample$EntrezID)
table(mcgill.AIMS.subtypes.rand50$cl)
if (all(mcgill.AIMS.subtypes.batch$cl[sel.rand.50] == mcgill.AIMS.subtypes.rand50$cl)){
message("Identical assignment batch and random 50")
}else{
message("Different assignment batch and random 50")
}
|
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.