--- /dev/null
+# Power analysis for microarray data
+
+
+# Copyright 2003 By Don Armstrong
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
+# 02111-1307, USA.
+
+
+
+# power.ma.partition
+# calcualate the power for data split into paritions of 200 genes.
+power.ma.partition <- function(dataset,partition=200,n=7,delta.mul=1,sig.level=0.05){
+ power.ma.temp <- dataset[names(sort(apply(dataset,1,mean))),]
+ if (partition>NROW(power.ma.temp)){
+ partition <- NROW(power.ma.temp)
+ }
+ power.ma.p.high <- NROW(power.ma.temp)
+ power.ma.return <- c()
+ for (power.ma.p.low in ceiling(seq(NROW(power.ma.temp),0,length=partition))){
+ if(power.ma.p.low == power.ma.p.high){
+ next;
+ }
+ power.ma.p.sd <- mean(apply(power.ma.temp[power.ma.p.low:power.ma.p.high,],1,sd,na.rm=T))
+ power.ma.p.mean <- mean(apply(power.ma.temp[power.ma.p.low:power.ma.p.high,],1,mean,na.rm=T))
+ power.ma.p.power <- power.t.test(n=n,sd=power.ma.p.sd,delta=power.ma.p.mean*delta.mul,sig.level=0.05)
+ power.ma.p.power <- power.ma.p.power$power
+ power.ma.return <- rbind(cbind(power.ma.p.mean,power.ma.p.power,power.ma.p.sd),power.ma.return)
+ power.ma.p.high <- power.ma.p.low -1;
+ }
+
+ return(power.ma.return)
+}
+
+# power.ma
+# calculate the power of individual genes
+power.ma <- function(dataset,n=7,delta.mul=1,sig.level=0.05){
+ power.ma.p.sd <- apply(dataset,1,sd,na.rm=T)
+ power.ma.p.mean <- apply(dataset,1,mean,na.rm=T)
+ power.ma.p.return <- cbind(power.ma.p.mean,power.ma.p.sd)
+ power.ma.p.power.calc <- function(sdmeanarray,n=7,delta.mul=1,sig.level=0.05){
+ power.ma.p.power.calc.power <- power.t.test(n=n,sd=sdmeanarray[2],delta=sdmeanarray[1]*delta.mul,sig.level=sig.level)
+ return(power.ma.p.power.calc.power$power)
+ }
+ power.ma.p.power <- apply(power.ma.p.return,1,power.ma.p.power.calc,delta.mul=delta.mul,sig.level=sig.level,n=n)
+ power.ma.p.return <- cbind(power.ma.p.return,power.ma.p.power)
+
+ return(power.ma.p.return)
+}
+
+power.ma.sdmean <- function(dataset,n=7,delta.mul=1,sig.level=0.05){
+ power.ma.p.mean <- dataset[,1]
+ power.ma.p.sd <- dataset[,2]
+ power.ma.p.return <- cbind(power.ma.p.mean,power.ma.p.sd)
+ power.ma.p.power.calc <- function(sdmeanarray,n=7,delta.mul=1,sig.level=0.05){
+ power.ma.p.power.calc.power <- power.t.test(n=n,sd=sdmeanarray[2],delta=sdmeanarray[1]*delta.mul,sig.level=sig.level)
+ return(power.ma.p.power.calc.power$power)
+ }
+ power.ma.p.power <- apply(power.ma.p.return,1,power.ma.p.power.calc,delta.mul=delta.mul,sig.level=sig.level,n=n)
+ power.ma.p.return <- cbind(power.ma.p.return,power.ma.p.power)
+
+ return(power.ma.p.return)
+}
+