File: joyPlot.R

package info (click to toggle)
r-cran-plotrix 3.8-1-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 1,580 kB
  • sloc: makefile: 6
file content (41 lines) | stat: -rw-r--r-- 1,368 bytes parent folder | download | duplicates (4)
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
joyPlot<-function(x,mar=c(5,4,4,2),newrange=c(0,1),border=NA,fill=NULL,
 main="",xlab="",ylab="",xlim=NA,line_labels=names(x),xat=NULL,
 xaxlab=NULL) {

 oldmar<-par(mar=mar)
 nlines<-length(x)
 xmin<-min(x[[1]]$x,na.rm=TRUE)
 xmax<-max(x[[1]]$x,na.rm=TRUE)
 ymax<-max(x[[1]]$y,na.rm=TRUE)
 for(i in 2:nlines) {
  thisxmin<-min(x[[i]]$x,na.rm=TRUE)
  if(thisxmin < xmin) xmin<-thisxmin
  thisxmax<-max(x[[i]]$x,na.rm=TRUE)
  if(thisxmax < xmax) xmax<-thisxmax
  ymax<-c(ymax,max(x[[i]]$y,na.rm=TRUE))
 }
 if(is.na(xlim[1])) xlim<-c(xmin,xmax)
 oaymax<-max(ymax)
 if(is.na(border[1])) border<-rainbow(nlines)
 else if(length(border) < nlines) border=rep(border,length.out=nlines)
 if(!is.null(fill)) if(length(fill) < nlines)
  fill<-rep(fill,length.out=nlines)
 plot(0,type="n",xlim=xlim,ylim=c(0,nlines+newrange[2]-1),
  main=main,xlab=xlab,ylab=ylab,xaxt="n",yaxt="n")
 if(is.null(xat)) axis(1)
 else {
  if(is.null(xaxlab)) xaxlab<-xat
  axis(1,at=xat,labels=xaxlab)
 }
 abline(h=0:(nlines-1),col="lightgray")
 if(is.null(line_labels)) line_labels<-1:nlines
 axis(2,at=0:(nlines-1)+0.5,labels=line_labels,las=1)
 for(i in nlines:1) {
  thisrange<-c(newrange[1],newrange[2]*ymax[i]/oaymax)
  x[[i]]$y<-rescale(x[[i]]$y,thisrange)+i-1
  if(is.null(fill[i])) lines(x[[i]],col=border[i])
  else polygon(x[[i]],border=border[i],col=fill[i])
 }
 box()
 par(mar=oldmar)
}