-
Notifications
You must be signed in to change notification settings - Fork 2
/
poisson.R
55 lines (48 loc) · 1.65 KB
/
poisson.R
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
# get from input
data <- commandArgs(trailingOnly=TRUE)[1] # get the file name with the counts
mode <- commandArgs(trailingOnly=TRUE)[2] # do you want to use the raw counts or the percent of total reads? pertotal or count
num_reads <- commandArgs(trailingOnly=TRUE)[3] # file with the number of reads
# load the files into R
library(lme4)
library(qvalue)
data <- read.delim(data, header=T, sep="\t", row.names=1)
names <- row.names(data)
attach(data)
# define some variables
row <- length(data[,1]) # number of functions or OTUs
col <- length(data[1,]) # number of samples
pvalc <- col + 2
qvalc <- col + 3
treatment <- gl(2,4,col) # which samples are cases and controls ?
outcome <- gl(4,1,col) # which samples are paired ?
# make matricies
counts <- matrix(0, nrow=row, ncol=col)
pvalue <- array(0, dim=row)
pertotal <- matrix(0, nrow=row, ncol=col)
qvalue <- matrix(0, nrow=row, ncol=1)
# calcualte the percent of total reads
if (mode=="pertotal")
{
num_reads <- read.delim(num_reads, header=F, sep=" ", row.names=1) # load the file that has the number of reads for each sample
for (i in 1:row)
{
for (j in 1:col)
{
pertotal[i:i, j:j] <- (data[i:i, j:j]/num_reads[j:j, 1])*100
}
}
data <- pertotal
}
# poisson!
for (i in 1: row)
{
counts[i,] <- t(data[i,])
model <- glmer(counts[i,] ~ treatment +(0+treatment|outcome),family=poisson())
pvalue[i] <- summary(model)@coefs[2,4]
}
# get the qvalues from the pvalues
qvalue <- qvalue(pvalue)$qvalues
#print out the data and pvalues
print <- data.frame(names, data, pvalue, qvalue)
print <- print[order(print[,pvalc], print[,qvalc]),]
write.table(print, file="out", row.name=FALSE, quote=FALSE, sep="\t")