R/plot.fdt_cat.multiple.R

plot.fdt_cat.multiple <- function (x,
                                   type=c('fb', 'fp', 'fd',
                                          'rfb', 'rfp', 'rfd',
                                          'rfpb', 'rfpp', 'rfpd',
                                          'cfb', 'cfp', 'cfd',
                                          'cfpb', 'cfpp', 'cfpd',
                                          'pa'),
                                   v=FALSE,
                                   v.round=2,
                                   v.pos=3,
                                   xlab=NULL,
                                   xlas=0,
                                   ylab=NULL,
                                   y2lab=NULL,
                                   y2cfp=seq(0, 100, 25),
                                   col=gray(.4),
                                   xlim=NULL,
                                   ylim=NULL,
                                   main=NULL,
                                   main.vars=TRUE,
                                   box=FALSE, ...)
{
  is.whole.number <- function (x,
                               tol=.Machine$double.eps^0.5)
    abs(x - round(x)) < tol

  old.mf  <- par("mfrow")
  old.oma <- par("oma")
  old.mar <- par("mar")
  on.exit(par(mfrow=old.mf,
              oma=old.oma,
              mar=old.mar))

  mf <- old.mf

  if (length(mf) == 0)
    mf <- c(1, 1)

  if ((n <- length(x)) > 1 & max(mf) == 1)
    mf <- if   (n <= 2)  c(2, 1)
      else  if (n <= 4)  c(2, 2)
      else  if (n <= 6)  c(2, 3)
      else  if (n <= 9)  c(3, 3)
      else  if (n <= 12) c(3, 4)
      else  if (n <= 16) c(4, 4)
      else               c(4, 5)

      par(mfrow=mf)
      nplot.device <- prod(mf)

      if (!is.null(main))
        main <- rep(main, 
                    length(x))
      else if (main.vars)
        main <- names(x)

      i <- 0

      repeat {
        if ((i != 0) & is.whole.number(i/nplot.device)) {
          dev.new()
          par(mfrow=mf)
        }
        i <- i + 1
        plot.fdt_cat.default(x[[i]][[1]],
                             type=type,
                             v=v,
                             v.round=v.round,
                             v.pos=v.pos,
                             xlab=xlab,
                             xlas=xlas,
                             ylab=ylab,
                             y2lab=y2lab,
                             y2cfp=y2cfp,
                             col=col,
                             xlim=xlim,
                             ylim=ylim,
                             main=main[i],
                             box=box, ...)
        if (i == length(x))
          break
      }
}

Try the fdth package in your browser

Any scripts or data that you put into this service are public.

fdth documentation built on Nov. 18, 2023, 1:08 a.m.