annotate cluster.tools/gen.survival.curves.R @ 0:0decf3fd54bc draft

Uploaded
author peter-waltman
date Thu, 28 Feb 2013 01:45:39 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
1 #!/usr/bin/env Rscript
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
2 ##
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
3 ## Calculates the log-rank test for a given clustering, in the output format from ConsensusClusterPlus
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
4 ##
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
5 ## Input (required):
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
6 ## - consensus cluster file (consensusClass.csv file)
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
7 ## - survival data
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
8 ## Input (optional):
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
9 ## Output: a KM plot, with the most significant p-value. Output to stdout can be captured by re-direction
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
10 ##
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
11 ## Uses: survival library
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
12 ## Date: August 21, 2012
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
13 ## Author: Peter Waltman
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
14 ##
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
15
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
16 ##usage, options and doc goes here
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
17 argspec <- c("gen.survival.curves.R takes a clustering from ConsensusClusterPlus and clinical survival data
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
18 and generates a KM-plot, along with the log-rank p-values
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
19
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
20 Usage:
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
21 gen.survival.curves.R -c <cluster.file> -s <clinical.file>
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
22 Options:
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
23 -o <output file> (postscript)
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
24 -m <mode> (all, one, both)
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
25 \"all\" - perform all-vs-all log-rank test
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
26 \"one\" - perform one-vs-others log-rank test (returns min)
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
27 \"both\" - perform both \"all\" and \"one\" tests
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
28 -t <title>
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
29 -p <pval.only> ( only return the p-value for this given mode - no plotting at all (to screen or postscript))
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
30 -v <verbose>
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
31 ")
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
32
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
33 lib.load.quiet <- function( package ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
34 package <- as.character(substitute(package))
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
35 suppressPackageStartupMessages( do.call( "library", list( package=package ) ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
36 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
37 lib.load.quiet(getopt)
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
38 lib.load.quiet( survival )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
39
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
40
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
41 args <- commandArgs(TRUE)
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
42 if ( length( args ) == 1 && args =="--help") {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
43 write(argspec, stderr())
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
44 q();
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
45 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
46
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
47 spec <- matrix( c( "cluster.fname", "C", 1, "character",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
48 "survival.fname", "S", 1, "character",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
49 "mode", "M", 2, "character",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
50 "title", "T", 2, "character",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
51 "myplots.rda", "R", 2, "character",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
52 "image.format", "I", 2, "character",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
53 "output.fname", "O", 2, "character",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
54 "pval.only", "P", 0, "logical",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
55 "verbose", "V", 0, "logical"
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
56 ),
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
57 ncol=4,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
58 byrow=TRUE
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
59 )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
60 opt <- getopt( spec=spec )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
61
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
62
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
63 #set some reasonable defaults for the options that are needed,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
64 #but were not specified.
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
65 if ( is.null(opt$mode ) ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
66 opt$mode <- "all"
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
67 } else {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
68 if ( ! opt$mode %in% c( 'all', 'one', 'both' ) ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
69 stop( "invalid mode specified,' -m", opt$mode, "'. must be either {all, one, both}\n" )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
70 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
71 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
72 if ( is.null( opt$title ) ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
73 opt$title <- opt$cluster.fname
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
74 opt$title <- strsplit( opt$title, "\\/" )[[1]]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
75 opt$title <- opt$title[ length( opt$title ) ]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
76 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
77 if ( is.null( opt$image.format ) ){
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
78 opt$image.format <- "png"
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
79 } else {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
80 if ( ! opt$image.format %in% c( "pdf", "png", "none" ) ) stop( 'invalid image format specified\n' )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
81 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
82 if ( is.null(opt$output.fname ) ) { opt$output.fname <- paste( opt$mode, "survival.curve", opt$image.format, sep="." ) }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
83 if ( is.null(opt$cluster.header ) ) { opt$cluster.header = FALSE }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
84 if ( is.null(opt$pval.only ) ) { opt$pval.only = FALSE }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
85 if ( is.null(opt$verbose ) ) { opt$verbose = FALSE }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
86
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
87 ##print some progress messages to stderr, if requested.
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
88 if ( opt$verbose ) { write("writing...",stderr()); }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
89
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
90 load( opt$cluster.fname )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
91 cluster.data <- cbind( names( cl ), as.numeric( cl ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
92 colnames( cluster.data ) <- c( "id", "group_num" )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
93 rownames( cluster.data ) <- names( cl )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
94
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
95 survival.data <- read.delim( opt$survival.fname, as.is=TRUE, row.names=1 )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
96 survival.data <- cbind( rownames( survival.data ), survival.data ) ## add in the ids, so we can merge on them
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
97 if ( length( colnames( survival.data ) ) == 3 ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
98 ## we have to left-shift the current colanmes to drop the 1st one
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
99 ## b/c cbind will add one for the column we just added
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
100 colnames( survival.data ) <- c( "id", colnames( survival.data )[-1] )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
101 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
102 if ( length( colnames( survival.data ) ) == 2 ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
103 ## added just in case there's a change to cbind as R is prone to doing
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
104 colnames( survival.data ) <- c( "id", colnames( survival.data ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
105 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
106 survival.data$id <- as.character( survival.data$id )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
107
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
108
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
109 ## Now, filter so we only contain the same samples
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
110 n.clust.data.samps <- nrow( cluster.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
111 n.surv.data.samps <- nrow( survival.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
112 if ( n.clust.data.samps > n.surv.data.samps ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
113 ovp.samples <- rownames( cluster.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
114 ovp.samples <- ovp.samples[ ovp.samples %in% survival.data$id ]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
115 } else {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
116 ovp.samples <- survival.data$id
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
117 ovp.samples <- ovp.samples[ ovp.samples %in% rownames( cluster.data ) ]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
118 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
119
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
120 cluster.data <- cluster.data[ ovp.samples, , drop=FALSE]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
121 survival.data <- survival.data[ ovp.samples, ]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
122 survival.data <- merge( survival.data, cluster.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
123
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
124
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
125 calc.all.pval <- function( survival.data ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
126 survdiff( Surv( time, status )~group_num, data=survival.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
127 surv.res <- survdiff( Surv( time, status )~group_num, data=survival.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
128 pval <- surv.res$chisq
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
129 df <- length( surv.res$n ) - 1
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
130 pval <- pchisq( pval, df=df, lower=F )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
131 return( pval )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
132 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
133
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
134 calc.one.v.others.pval <- function( survival.data ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
135 grps <- sort( unique( as.numeric( survival.data$group_num ) ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
136
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
137 retval <- numeric()
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
138 for ( g in grps ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
139 one.v.all.survival.data <- survival.data
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
140 tmp <- as.numeric( one.v.all.survival.data$group_num )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
141 tmp[ ! tmp %in% g ] <- -1
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
142 tmp[ tmp %in% g ] <- 1
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
143 tmp[ tmp %in% -1 ] <- 2
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
144 one.v.all.survival.data$group_num <- tmp
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
145 surv.res <- survdiff( Surv( time, status )~group_num, data=one.v.all.survival.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
146 pval <- surv.res$chisq
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
147 df <- length( surv.res$n ) - 1
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
148 pval <- pchisq( pval, df=df, lower=F )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
149 retval <- c( retval, pval )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
150 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
151 names( retval ) <- grps
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
152 return( retval )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
153 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
154
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
155
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
156 if ( opt$mode == "all" ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
157
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
158 pval <- calc.all.pval( survival.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
159 log.rank <- paste( "Log Rank p-value:", sprintf( "%1.2e",pval ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
160 opt$title <- paste( opt$title, log.rank, sep="\n" )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
161 } else {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
162 if ( opt$mode == "one" ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
163
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
164 pvals <- calc.one.v.others.pval( survival.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
165 min.p <- min( pvals, na.rm=T )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
166 if ( length( min.p ) == 0 ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
167 stop( 'no valid p-value returned from the one-v-others test\n' )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
168 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
169 cluster.num <- names( pvals )[ pvals == min.p ]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
170 pval <- pvals[ cluster.num ]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
171 log.rank <- paste( "Log Rank p-value for cluster", cluster.num,"is:", sprintf( "%1.2e",pval ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
172 opt$title <- paste( opt$title, log.rank, sep="\n" )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
173 } else {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
174 if ( opt$mode== "both" ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
175 ## add the all-v-all p-value
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
176 bak <- pval <- calc.all.pval( survival.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
177 log.rank <- paste( "Log Rank p-value:", sprintf( "%1.2e",pval ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
178 opt$title <- paste( opt$title, log.rank, sep="\n" )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
179
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
180 ## now add the one-v-all p-value
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
181 pvals <- calc.one.v.others.pval( survival.data )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
182 min.p <- min( pvals, na.rm=T )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
183 if ( length( min.p ) == 0 ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
184 stop( 'no valid p-value returned from the one-v-others test\n' )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
185 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
186 cluster.num <- names( pvals )[ pvals == min.p ]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
187 pval <- pvals[ cluster.num ]
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
188 log.rank <- paste( "Log Rank p-value for cluster", cluster.num,"is:", sprintf( "%1.2e",pval ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
189 opt$title <- paste( opt$title, log.rank, sep="\n" )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
190
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
191 if ( opt$pval.only ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
192 pval <- min( c( bak, pval ), na.rm=T )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
193 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
194 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
195 else {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
196 stop( "invalid mode specified, mode = ", opt$mode, "\n" )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
197 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
198 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
199 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
200
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
201 if ( opt$pval.only ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
202 cat( paste(pval, "\n", sep="" ), file=stdout() )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
203 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
204
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
205
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
206 if ( ! opt$pval.only ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
207 ngrps <- length( unique( survival.data$group_num ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
208 col.map <- rainbow( ngrps )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
209
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
210
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
211
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
212 ##postscript( opt$output.fname, horizontal=T, paper='letter' )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
213 if ( opt$image.format == 'png' ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
214 plot.dev <- png( opt$output.fname,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
215 width=11,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
216 height=8.5,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
217 units='in',
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
218 res=72 )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
219 } else if ( opt$image.format == 'pdf' ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
220 pdf( opt$output.fname,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
221 paper="letter" )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
222 } else if ( opt$image.format == 'none' ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
223 ## do nothing - this allows other scripts to call this and hopefully plot into them
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
224 ## NOPE, this doesn't work. see what I do with the myplots.rda file
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
225 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
226
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
227 plot( survfit( Surv( time, status )~group_num, data=survival.data ),
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
228 main = opt$title,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
229 ##lty = 1:ngrps,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
230 lty=1,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
231 col=col.map,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
232 ylab = "Probability",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
233 xlab = "Survival Time in Days",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
234 )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
235
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
236
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
237 ## set the legend.labels if they're still not set yet
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
238 if( ! exists( "legend.labels" ) ) {
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
239 grp.counts <- table( as.factor( survival.data[, "group_num" ] ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
240 legend.labels <- paste( "Cluster", 1:ngrps, paste( "(n=", as.integer(grp.counts), ")", sep="" ) )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
241 }
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
242
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
243 legend( "topright",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
244 lty=1,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
245 col=col.map,
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
246 bty = "n",
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
247 legend=legend.labels
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
248 )
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
249
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
250 if( opt$image.format != "none" ) dev.off()
0decf3fd54bc Uploaded
peter-waltman
parents:
diff changeset
251 }