[0aeb11]: / voomDDA.train.R

Download this file

55 lines (48 with data), 1.8 kB

 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
49
50
51
52
53
54
55
voomDDA.train = function (counts, conditions, normalization = c("TMM", "deseq", "none"), pooled.var = TRUE)
{
normalization = match.arg(normalization)
counts = data.matrix(counts)
p = nrow(counts)
n = ncol(counts)
nclass = length(unique(conditions))
n.class = table(conditions)
if (min(n.class) == 1) {
stop(warning("Warning: a class contains only 1 sample"))
}
#### voom transformation steps
{
if (normalization == "TMM"){
design = model.matrix(~conditions)
rownames(design) = colnames(counts)
dge = DGEList(counts = counts)
dge = calcNormFactors(dge, method = "TMM")
vm = voom(dge, design, plot=F)
x = vm $ E #pxn dim gene expression matrix
w = vm $ weights #pxn dim weight matrix
dimnames(w) = dimnames(x)
}
else if (normalization == "deseq"){
design = model.matrix(~conditions)
rownames(design) = colnames(counts)
dge = DGEList(counts = counts)
dge = calcNormFactors(dge, method = "RLE")
vm = voom(dge, design, plot=F)
x = vm $ E #pxn dim gene expression matrix
w = vm $ weights #pxn dim weight matrix
dimnames(w) = dimnames(x)
}
else {
design = model.matrix(~conditions)
rownames(design) = colnames(counts)
vm = voom(counts, design, plot=F)
x = vm $ E #pxn dim gene expression matrix
w = vm $ weights #pxn dim weight matrix
dimnames(w) = dimnames(x)
}
}
if(is.factor(conditions)) classNames = levels(conditions)
wStats = weighted.stats(x, w, conditions)
results = structure(list(counts = counts, conditions = factor(conditions), weightedStats = wStats, normalization = normalization,
nclass = nclass, classNames = classNames, PooledVar = pooled.var), class = "voomDDA")
return(results)
}