Nothing
descriptives.trait <- function (data, subset, file, by.var = NULL, digits = 3)
{
if (missing(data))
stop("data argument must be provided")
if (is(data, "gwaa.data"))
data <- data@phdata
if (!is(data, "data.frame"))
stop("data argument must be of gwaa.data or data.frame-class")
len <- dim(data)[1]
ntra <- dim(data)[2]
if (!missing(subset))
data <- data[subset, ]
if (!is.null(by.var)) {
svar <- by.var
if(class(by.var)=="formula"){
svar<-data[,as.character(by.var)[2]]
}
if(is.character(by.var) & length(by.var==1)){
svar<-data[,by.var]
}
if (length(levels(factor(svar))) != 2)
stop("The by.var argument should contain a binary variable")
out <- matrix(data = NA, nrow = ntra, ncol = 9)
lvls <- levels(factor(svar))
for (i in (1:ntra)) {
ctrao <- data[, i]
if (!is.numeric(ctrao) | all(ctrao == svar,na.rm=T)) {
ctra <- ctrao[svar == lvls[1]]
out[i, 1] <- length(ctra) - sum(is.na(ctra))
ctra <- ctrao[svar == lvls[2]]
out[i, 4] <- length(ctra) - sum(is.na(ctra))
}
else {
ctra <- ctrao[svar == lvls[1]]
out[i, 1] <- length(ctra) - sum(is.na(ctra))
out[i, 2] <- mean(ctra, na.rm = TRUE)
out[i, 3] <- sd(ctra, na.rm = TRUE)
ctra <- ctrao[svar == lvls[2]]
out[i, 4] <- length(ctra) - sum(is.na(ctra))
out[i, 5] <- mean(ctra, na.rm = TRUE)
out[i, 6] <- sd(ctra, na.rm = TRUE)
tmp<-try(t.test(ctrao ~ svar)$p.value)
if(class(tmp)=="numeric"){
out[i, 7] <- tmp
}
tmp<-try(kruskal.test(ctrao ~ svar)$p.value)
if(class(tmp)=="numeric"){
out[i, 8] <- tmp
}
clv <- length(unique(ctrao))
if (clv > 1 & clv < 5)
out[i, 9] <- fisher.test(ctrao, svar)$p.value
}
}
}
else {
out <- matrix(data = NA, nrow = ntra, ncol = 3)
for (i in (1:ntra)) {
ctra <- data[, i]
out[i, 1] <- length(ctra) - sum(is.na(ctra))
if (!is.numeric(ctra))
next
out[i, 2] <- mean(ctra, na.rm = TRUE)
out[i, 3] <- sd(ctra, na.rm = TRUE)
}
}
out <- round(out, digits = digits)
out <- data.frame(out)
rownames(out) <- colnames(data)
if (is.null(by.var))
colnames(out) <- c("No", "Mean", "SD")
else colnames(out) <- c(paste("No(by.var=", lvls[1], ")",
sep = ""), "Mean", "SD", paste("No(by.var=", lvls[2],
")", sep = ""), "Mean", "SD", "Ptt", "Pkw", "Pexact")
if (!missing(file)) {
cat("\t", file = file, sep = "")
cat(colnames(out), file = file, sep = "\t", append = TRUE)
cat("\n", file = file, sep = "", append = TRUE)
write.table(out, file = file, sep = "\t", append = T,
col.names = FALSE)
}
out
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.