R/mtable.R

Defines functions write.mtable toLatex.memisc_mtable print.memisc_mtable format.memisc_mtable format_signif preformat_mtable ni dropnull nzchar_row do_prettyfy do_1sub do_subs pt_getrow relabel.memisc_mtable get_rows getRows dimnames3 rowexpand colexpand prefmt2 prefmt1 mtable names.or.rownames bind_arrays prettyNames1 prettyNames selectSummaryStats setSummaryTemplate getSummaryTemplate getFirstS3method summaryTemplate getSummary getCoefTemplate getFirstMatch setCoefTemplate str.has

Documented in format.memisc_mtable getCoefTemplate getSummary getSummaryTemplate mtable print.memisc_mtable relabel.memisc_mtable setCoefTemplate setSummaryTemplate summaryTemplate toLatex.memisc_mtable write.mtable

str.has <- function(text,has,not=NULL,how=c("all","any")){
    how <- match.fun(match.arg(how))

    hasit <- sapply(has,function(pat)regexpr(pat,text,fixed=TRUE) > 0)
    if(is.matrix(hasit))
        hasit <- apply(hasit,1,how)
    else
        hasit <- all(hasit)


    if(!length(not)) return(hasit)
    # else
    hasnot <- sapply(not,function(pat)regexpr(pat,text,fixed=TRUE) > 0)
    if(is.matrix(hasnot))
        hasnot <- apply(hasnot,1,how)
    else
        hasnot <- all(hasnot)

    hasit & !hasnot
}



setCoefTemplate <- function(...){
  args <- list(...)
  argnames <- names(args)
  CoefTemplates <- get("CoefTemplates", envir=.memiscEnv)
  OldCoefTemplates <- CoefTemplates
    for(coef.style in argnames){
      CoefTemplates[[coef.style]] <- args[[coef.style]]
  }
  assign("CoefTemplates",CoefTemplates, envir=.memiscEnv)
  return(invisible(OldCoefTemplates))
}

getFirstMatch <- function(x,n){
  for(n. in n){
    if(n. %in% names(x)) return(x[[n.]])
  }
  return(x[["default"]])
}

getCoefTemplate <- function(style){
  CoefTemplates <- get("CoefTemplates", envir=.memiscEnv)
  if(missing(style)) return(CoefTemplates)
  else return(CoefTemplates[[style]])
}


getSummary <- function(obj,alpha=.05,...) UseMethod("getSummary")
# setGeneric("getSummary")

summaryTemplate <- function(x)
  UseMethod("summaryTemplate")

getFirstS3method <- function(mname,cls,optional){
    for(cls1 in cls){
        mfun <- getS3method(mname,cls1,optional)
        if(length(mfun)) return(mfun)
    }
    return(NULL)
}

getSummaryTemplate <- function(x){
  SummaryTemplates <- get("SummaryTemplates", envir=.memiscEnv)
  if(missing(x)) return(SummaryTemplates)
  if(is.character(x)) cls <- x
  else cls <- class(x)
  stf <- getFirstS3method("summaryTemplate",cls,optional=TRUE)
  if(length(stf))
    res <- stf(x)
  else
    res <- getFirstMatch(SummaryTemplates,cls)
  return(res)
}

setSummaryTemplate <- function(...){
  args <- list(...)
  argnames <- names(args)
  OldSummaryTemplates <- SummaryTemplates <- get("SummaryTemplates", envir=.memiscEnv)
  for(cls in argnames){
      SummaryTemplates[[cls]] <- args[[cls]]
  }
  assign("SummaryTemplates",SummaryTemplates,envir=.memiscEnv)
  return(invisible(OldSummaryTemplates))
}

selectSummaryStats <- function(x,n) {
    if(is.character(n)){
        n
    }
    else if(isTRUE(n)){
        cls <- class(x)
        sumstats.name <- paste0("summary.stats.",cls)
        sumstats <- lapply(sumstats.name,getOption)
        if(any(!vapply(sumstats, is.null, TRUE))){
            sumstats <- unlist(sumstats)
            sumstats[1]
        }
        else
            sumstats <- getOption("summary.stats.default")
        sumstats
    }
    else FALSE
}

prettyNames <- function(coefnames,
                        contrasts,
                        xlevels,
                        factor.style,
                        show.baselevel,
                        baselevel.sep
                        ){
    termorders <- sapply(strsplit(coefnames,":",fixed=TRUE),length)
    ordergroups <- split(coefnames,termorders)
    ordergroups <- lapply(ordergroups,prettyNames1,
                        contrasts=contrasts,
                        xlevels=xlevels,
                        factor.style=factor.style,
                        show.baselevel=show.baselevel,
                        baselevel.sep=baselevel.sep
                        )
    unsplit(ordergroups,termorders)
}

prettyNames1 <- function(str,
                        contrasts,
                        xlevels,
                        factor.style,
                        show.baselevel,
                        baselevel.sep
                        ){
   str <- gsub(":"," x ",str,fixed=TRUE)
   for(f in names(contrasts)){
      contrast.f <- contrasts[[f]]
      levels <- xlevels[[f]]
      #if(!length(levels)) levels <- c("FALSE","TRUE")
      if(!length(levels)) {
        str <- gsub(paste(f,"TRUE",sep=""),f,str,fixed=TRUE)
        next
      }
      if(is.character(contrast.f))
        contrast.matrix <- do.call(contrast.f,list(n=levels))
      else if(is.matrix(contrast.f))
        contrast.matrix <- contrast.f
      levels.present <- sapply(levels,function(level)
            any(str.has(str,c(f,level)))
            )
      if(all(levels.present))
        oldlabels <- newlabels <- levels
      else if(!length(colnames(contrast.matrix))){
        oldlabels <- newlabels <- as.character(1:ncol(contrast.matrix))
        }
      else if(is.character(contrast.f) &&
          contrast.f %in% c(
              "contr.treatment",
              "contr.SAS"
              )){
         baselevel <- setdiff(rownames(contrast.matrix),colnames(contrast.matrix))
         if(show.baselevel)
           newlabels <- paste(colnames(contrast.matrix),baselevel,sep=baselevel.sep)
         else
           newlabels <- colnames(contrast.matrix)
         oldlabels <- colnames(contrast.matrix)
      }
      else if(is.character(contrast.f) &&
          contrast.f %in% c(
              "contr.sum",
              "contr.helmert"
              )){
         newlabels <- apply(contrast.matrix,2,
                                          function(x)rownames(contrast.matrix)[x>=1])
         oldlabels <- colnames(contrast.matrix)
      }
      else if(
        all(colnames(contrast.matrix) %in% rownames(contrast.matrix))
        ){
         baselevel <- setdiff(rownames(contrast.matrix),colnames(contrast.matrix))
         if(show.baselevel)
           newlabels <- paste(colnames(contrast.matrix),baselevel,sep=baselevel.sep)
         else
           newlabels <- colnames(contrast.matrix)
         oldlabels <- colnames(contrast.matrix)
      }
      else {
        oldlabels <- newlabels <- colnames(contrast.matrix)
      }
      from <- paste(f,oldlabels,sep="")
      to <- sapply(newlabels,
        function(l)applyTemplate(c(f=f,l=l),template=factor.style))
      for(i in 1:length(from))
        str <- gsub(from[i],to[i],str,fixed=TRUE)
   }
   str
}

bind_arrays <- function(args,along=1){
  along.dn <- unlist(lapply(args,function(x)dimnames(x)[[along]]))
  groups <- sapply(args,function(x)dim(x)[along])
  dn <- dimnames(args[[1]])
  keep.dn <- dn[-along]
  dim1 <- dim(args[[1]])
  keep.dim <- dim1[-along]
  ldim <- length(dim1)
  dimseq <- seq_len(ldim)
  perm.to <- dimseq
  perm.to[ldim] <- along
  perm.to[along] <- ldim
  res <- lapply(args,function(x){
    x <- aperm(x,perm.to)
    dim(x) <- c(prod(dim(x)[-ldim]),dim(x)[ldim])
    x
    })
  res <- do.call(cbind,res)
  dim(res) <- c(keep.dim,ncol(res))
  dimnames(res) <- c(keep.dn,list(along.dn))
  structure(aperm(res,perm.to),groups=groups)
}

names.or.rownames <- function(x){
    if(is.array(x)) rownames(x)
    else names(x)
}

mtable <- function(...,
                   coef.style=getOption("coef.style"),
                   summary.stats=TRUE,
                   signif.symbols=getOption("signif.symbols"),
                   factor.style=getOption("factor.style"),
                   show.baselevel=getOption("show.baselevel"),
                   baselevel.sep=getOption("baselevel.sep"),
                   getSummary=eval.parent(quote(getSummary)),
                   float.style=getOption("float.style"),
                   digits=min(3,getOption("digits")),
                   sdigits=digits,
                   show.eqnames=getOption("mtable.show.eqnames",NA),
                   gs.options=NULL,
                   controls=NULL,
                   collapse.controls=FALSE,
                   control.var.indicator=getOption("control.var.indicator",c("Yes","No"))
                   ){
  args <- list(...)
  if(length(args)==1 && inherits(args[[1]],"by"))
    args <- args[[1]]
  argnames <- names(args)
  if(!length(argnames)) {
    m <- match.call(expand.dots=FALSE)
    argnames <- sapply(m$...,paste)
  }
  n.args <- length(args)

  arg.classes <- lapply(args,class)
  if(any(sapply(arg.classes,length))==0) stop("don\'t know how to handle these arguments")
  
  if(length(gs.options)){
    summaries.call <- as.call(
      c(list(as.name("lapply"),
             as.name("args"),
             FUN=as.name("getSummary")),
        gs.options
      ))
    summaries <- eval(summaries.call)
  }
  else
    summaries <- lapply(args,getSummary)
  
  parameter.types <- unique(unlist(lapply(summaries,names)))
  parameter.types <- parameter.types[parameter.types %nin% c("sumstat","contrasts","call","xlevels")]
  parmnames <- list()
  for(pt in parameter.types){

      tmp.pn <- lapply(summaries,`[[`,pt)
      tmp.pn <- lapply(tmp.pn,names.or.rownames)
      parmnames[[pt]] <- unique(unlist(tmp.pn))
  }
  parameter.names <- unique(unlist(parmnames))
  
  stemplates <- lapply(args,getSummaryTemplate)
  if(isTRUE(summary.stats))
      summary.stats <- lapply(args,selectSummaryStats,TRUE)
  else if(is.character(summary.stats))
      summary.stats <- lapply(args,selectSummaryStats,summary.stats)
  else if(is.list(summary.stats)){
      tmp.summary.stats <- summary.stats
      summary.stats <- vector(mode="list",length=length(args))
      summary.stats[] <- tmp.summary.stats
  } else {
      summary.stats <- vector(mode="list",length=length(args))
      summary.stats[] <- list(FALSE)
  }
      
  if(length(controls)){
      if(is.character(controls))
          controls <- asOneSidedFormula(controls)
      if(inherits(controls,"formula")){
          control.coefs <- lapply(args,formula2coefs,fo=controls)
          control.terms <- lapply(args,formula2termlabs,fo=controls)
      }
      else
          stop("'controls=' must be a formula or a character vector.")
      controls <- list(coefs=control.coefs,terms=control.terms)
  } 
  
  structure(summaries,
            names=argnames,
            class="memisc_mtable",
            parameter.names=parameter.names,
            coef.style=coef.style,
            summary.stats=summary.stats,
            signif.symbols=signif.symbols,
            factor.style=factor.style,
            show.baselevel=show.baselevel,
            baselevel.sep=baselevel.sep,
            float.style=float.style,
            digits=digits,
            stemplates=stemplates,
            sdigits=sdigits,
            show.eqnames=show.eqnames,
            controls=controls,
            collapse.controls=collapse.controls,
            control.var.indicator=control.var.indicator
            )
  
}

prefmt1 <- function(parm,template,float.style,digits,signif.symbols,controls){
    
    rn <- rownames(parm)
    if(length(intersect(rn,controls))){
        controls <- intersect(rn,controls)
        rn <- setdiff(rn,controls)
        if(length(dim(parm))==2)
            parm <- parm[rn,,drop=FALSE]
        else
            parm <- parm[rn,,,drop=FALSE]
    }
    else controls <- NULL
    adims <- if(length(dim(parm))==2) 1 else c(1,3)
    if(length(parm)){
        
        if(is.array(parm)){
            ans <- apply(parm,adims,applyTemplate,
                         template=template,
                         float.style=float.style,
                         digits=digits,
                         signif.symbols=signif.symbols)
        }
        else {
            ans <- array(formatC(parm,
                                 digits=digits,
                                 ifelse(is.integer(parm),
                                        "d","f"),
                                 width=1),
                         dim=c(1,1,length(parm),1),
                         dimnames=list(NULL,NULL,names(parm),NULL))
            return(ans)
        }
    }
    else {
        ans <- array(character(0),
                     dim=c(0,dim(parm)[adims]),
                     dimnames=c(list(NULL),dimnames(parm)[adims]))
    }
        
    if(length(dim(template))){
        newdims <- c(dim(template),dim(ans)[-1])
        newdimnames <- c(dimnames(template),dimnames(ans)[-1])

        # for(i in 1:length(newdims)){
        #     if(!length(newdimnames[[i]])){
        #         if(newdims[i]==0)
        #             newdimnames[[i]] <- character(0)
        #         else
        #             newdimnames[[i]] <- as.character(1:newdims[i])
        #     }
        # }
        
        dim(ans) <- newdims
        dimnames(ans) <- newdimnames
    } else rownames(ans) <- names(template)

    ans[ans=="()"] <- ""
    attr(ans,"controls") <- controls
    return(ans)
}

prefmt2 <- function(parm){
    
    if(length(dim(parm))<4)
        dim(parm)[4] <- 1

    parm <- aperm(parm,c(1,3,2,4))
    dim(parm) <- c(prod(dim(parm)[1:2]),prod(dim(parm)[3:4]))

    parm
}

colexpand <- function(x,nc){
    x.nr <- nrow(x)
    x.nc <- ncol(x)
    y <- matrix("",nrow=x.nr,ncol=max(nc,1))
    if(length(x))
        y[,1:x.nc] <- x
    y
}

rowexpand <- function(x,nr){
    x.nr <- nrow(x)
    x.nc <- ncol(x)
    y <- matrix("",nrow=nr,ncol=x.nc)
    if(length(x))
        y[1:x.nr,] <- x
    y
}


dimnames3 <- function(x)dimnames(x)[[3]]

getRows <- function(x,r){
    if(is.character(r))
        r <- intersect(r,rownames(x))
    x[r,,drop=FALSE]
}
get_rows <- function(x,i)try(x[i,,drop=FALSE])

relabel.memisc_mtable <- function(x,...,gsub=FALSE,fixed=!gsub,warn=FALSE){

    relab.req <- list(...,
                      gsub=gsub,fixed=fixed,warn=warn)
    
    relab.attr <- attr(x,"relabel")
    if(!length(relab.attr))
        relab.attr <-list(relab.req)
    else
        relab.attr <-c(relab.attr,
                       list(relab.req))

    attr(x,"relabel") <- relab.attr

    x
}

pt_getrow <- function(x,i){
    y <- x[i,]
    isn <- sapply(y,is.null)
    if(any(isn)) return(y[!isn])
    else return(y)
}

do_subs <- function(x,r){
    for(rr in r)
        x <- do_1sub(x,rr)
    return(x)
}

do_1sub <- function(x,r){

    r.gsub <- r$gsub
    r.fixed <- r$fixed

    r <- r[names(r)%nin%c("gsub","fixed","warn")]

    y <- x
    for(i in seq_along(r)){
        from <- names(r)[i]
        to <- r[[i]]
        if(r.gsub)
            y <- gsub(from,to,y,fixed=r.fixed)
        else {
            y[y==from] <- to
        }
    }
    return(y)
}

do_prettyfy <- function(pn,
                        contrasts,     
                        xlevels,         
                        factor.style,    
                        show.baselevel,
                        baselevel.sep){

    if(!length(contrasts)) return(pn)
    
    res <- pn

    done <- res != pn

    for(m in names(contrasts)){
        contrasts.m <- contrasts[[m]]
        xlevels.m <- xlevels[[m]]
        if(all(done)) break
        pn.tmp <- pn[!done]
        pn.tmp  <- prettyNames(pn.tmp,
                               contrasts=contrasts.m,
                               xlevels=xlevels.m,
                               factor.style=factor.style,
                               show.baselevel=show.baselevel,
                               baselevel.sep=baselevel.sep)
        res[!done] <- pn.tmp
        done <- res != pn
    }
    
    return(res)
}    

nzchar_row <- function(x){
    nzch <- array(nzchar(x),dim=dim(x))
    apply(nzch,1,any)
}

dropnull <- function(x) {
    ii <- sapply(x,is.null)
    x[!ii]
}
ni <- function(tab,x) x%in%tab
preformat_mtable <- function(x){

    x <- unclass(x)
    
    coef.style <- attr(x,"coef.style")
    summary.stats <- attr(x,"summary.stats")
    signif.symbols <- attr(x,"signif.symbols")
    factor.style <- attr(x,"factor.style")
    show.baselevel <- attr(x,"show.baselevel")
    baselevel.sep <- attr(x,"baselevel.sep")
    float.style <- attr(x,"float.style")
    digits <- attr(x,"digits")
    stemplates <- attr(x,"stemplates")
    sdigits <- attr(x,"sdigits")
    
    allcompo <- unique(unlist(lapply(x,names)))
    nonparnames <- c("sumstat","contrasts","xlevels","call")
    partypes <- setdiff(allcompo,nonparnames)

    sumstats <- lapply(x,`[[`,"sumstat")
    contrasts <- lapply(x,`[[`,"contrasts")
    xlevels <- lapply(x,`[[`,"xlevels")
    calls <- lapply(x,`[[`,"call")
    parms <- lapply(x,`[`,partypes)
    parms <- lapply(parms,dropnull)

    ctemplate <- getCoefTemplate(coef.style)
    if(!length(ctemplate)) stop("invalid coef.style argument")
    ctemplate <- as.matrix(ctemplate)
    ctdims <- dim(ctemplate)
    lctdims <- length(ctdims)
    if(lctdims>2) stop("can\'t handle templates with dim>2")

    relab.attr <- attr(x,"relabel")
    
    modelnames <- names(x)
    modelgroups <- attr(x,"model.groups")

    force.header <- isTRUE(attr(x,"force.header")) # Document that later ...
    show.eqnames <- attr(x,"show.eqnames")

    all.control.terms <- NULL
    control.terms <- NULL
    control.coefs <- NULL
    controls <- attr(x,"controls")
    collapse.controls <- attr(x,"collapse.controls")
    if(length(controls)){
        control.terms <- controls$terms
        control.coefs <- controls$coefs
        control.coefs <- unique(unlist(control.coefs))

        all.control.terms <- unique(unlist(control.terms))
    }
    
    parmtab <- NULL

    ct.indicator <- attr(x,"control.var.indicator")
    if(!length(ct.indicator)) ct.indicator <- c("X","")
    
    if(length(partypes)){
        for(n in 1:length(parms)){

            parms.n <- parms[[n]]
            parms.n<- lapply(parms.n,
                             prefmt1,
                             template=ctemplate,
                             float.style=float.style,
                             digits=digits,
                             signif.symbols=signif.symbols,
                             controls=control.coefs)
            if(length(control.terms)){
                ct <- control.terms[[n]]
                ct <- all.control.terms %in% ct
                if(collapse.controls) {
                    if(all(ct))
                        ct <- ct.indicator[1]
                    else if(!any(ct))
                        ct <- ct.indicator[2]
                    else
                        ct <- as.character(NA)
                    dim(ct) <- c(1,1,1,1)
                    dimnames(ct) <- list(1,2,"Controls",3)
                }
                else {
                    ct <- ifelse(ct,ct.indicator[1],ct.indicator[2])
                    dim(ct) <- c(1,1,length(ct),1)
                    dimnames(ct) <- list(1,2,all.control.terms,3)
                }
                parms.n <- append(parms.n,list(Controls=ct),after=1)
            }
            parms[[n]] <- parms.n
        }
        if(length(control.terms))
            partypes <- append(partypes,"Controls",after=1)
        parmtab <- array(list(),
                  dim=c(length(partypes),length(parms)),
                  dimnames=list(partypes,names(parms)))

        for(n in 1:length(parms)){
            mod <- parms[[n]]
            modnames <- names(mod)
            for(m in modnames){
                mod.m <- mod[[m]]
                parmtab[[m,n]] <- mod.m
            }
        }

        parameter.names <- attr(x,"parameter.names")
        parmnames <- list()
        
        for(m in rownames(parmtab)){
            tmp.pn <- lapply(parmtab[m,],dimnames3)
            tmp.pn <- unique(unlist(tmp.pn))
            tmp.pn <- parameter.names[parameter.names %in% tmp.pn]
            parmnames[[m]] <- tmp.pn
        }
        if(length(all.control.terms)){
            if(collapse.controls)
                parmnames$Controls <- "Controls"
            else
                parmnames$Controls <- all.control.terms
        }
        # Make sure that columns and rows match across models
        for(n in 1:ncol(parmtab)){
            mod <- parms[[n]]
            for(m in rownames(parmtab)){
                parmtab.mn <- parmtab[[m,n]]
                if(length(parmnames[[m]])){
                    parmtab.mn <- coefxpand(parmtab.mn,parmnames[[m]])
                    parmtab.mn <- prefmt2(parmtab.mn)
                    parmtab[[m,n]] <- parmtab.mn
                }
                modm <- mod[[m]]
            }
            maxncol <- max(unlist(lapply(parmtab[,n],ncol)) )
            parmtab[,n] <- lapply(parmtab[,n],colexpand,maxncol)
        }
        # Drop empty rows
        for(n in 1:nrow(parmtab)){
            maxnrow <- max(unlist(lapply(parmtab[n,],nrow)) )
            parmtab[n,] <- lapply(parmtab[n,],rowexpand,maxnrow)
            nz <- lapply(parmtab[n,],nzchar_row)
            if(length(nz)>1)
                nz <- reduce(nz,`|`)
            else
                nz <- nz[[1]]
            parmtab[n,] <- lapply(parmtab[n,],get_rows,i=nz)
        }
    }
    headers <- list()
    if(length(modelnames) > 1 || length(modelnames) == 1 && force.header) {
        modelnames <- do_subs(modelnames,relab.attr)
        headers[[1]] <- Map(structure,modelnames,span=lapply(parmtab[1,],ncol))
        if(length(modelgroups)){
            ncols <- sapply(parmtab[1,],ncol)
            sp <- lapply(modelgroups,function(mg)sum(ncols[mg]))
            h <- Map(structure,names(modelgroups),span=sp)
            headers <- c(list(h),headers)
        }
    }
    # show.eqnames <- show.eqnames || has.multieq(x)

    get_eq.headers <- function(x){
        cf <- x$coef
        dn.cf <- dimnames(cf)
        if(length(dn.cf)>2)
            eq.names <- dimnames(cf)[[3]]
        else
            eq.names <- NULL
    }
    eq.headers <- lapply(x,get_eq.headers)
    all.eq.names <- unique(unlist(eq.headers))
    if(is.na(show.eqnames))
        show.eqnames <- length(all.eq.names) > 1
    if(!show.eqnames)
        eq.headers <- NULL
    
    leaders <- vector(mode="list",length=nrow(parmtab))
    names(leaders) <- rownames(parmtab)
    if(length(partypes)){
      i <- 0 
      for(m in rownames(parmtab)){
        i <- i + 1
        pn <- parmnames[[m]]
        pn <- do_prettyfy(pn,
                          contrasts=contrasts,     
                          xlevels=xlevels,         
                          factor.style=factor.style,    
                          show.baselevel=show.baselevel,
                          baselevel.sep=baselevel.sep)  
        pn <- do_subs(pn,relab.attr)
        span <- nrow(parmtab[[m,1]])/length(pn)
        if(span < 1)
          leaders[[i]] <- NULL
        else
          leaders[[i]] <- lapply(pn,structure,span=span)
      }
    }

    if(length(summary.stats)) {
        sumstats <- Map(applyTemplate,sumstats,stemplates,digits=sdigits)
        sst <- Map(getRows,sumstats,summary.stats)

        snames <- unique(unlist(lapply(sst,rownames)))
        nc <- lapply(parmtab[1,],ncol)
        summary.stats <- Map(smryxpand,sst,list(snames))

        snames <- do_subs(snames,relab.attr)
        snames <- lapply(snames,structure,span=1)
        leaders <- c(leaders,summary.stats=list(snames))
    }
    else summary.stats <- NULL

    needs.signif <- any(grepl("$p",ctemplate,fixed=TRUE))
    if(needs.signif){
        signif.symbols <- signif.symbols
    }
    else
        signif.symbols <- NULL

    outtypes <- array("num",
                      dim=dim(parmtab),
                      dimnames=dimnames(parmtab))
    if(length(controls)){
        outtypes["Controls",] <- "text"
    }
    
    structure(list(parmtab=parmtab,
                   leaders=leaders,
                   headers=headers,
                   eq.headers=eq.headers,
                   summary.stats = summary.stats,
                   signif.symbols=signif.symbols,
                   controls=controls,
                   outtypes=outtypes),
              class="preformatted.memisc_mtable")
    }


format_signif <- function(syms,tmpl){
    title <- tmpl[1]
    clps <- tmpl[3]
    tmpl <- tmpl[2]
    res <- c()
    for(i in seq_along(syms)){
        sym <- names(syms)[i]
        thrsh <- unname(syms[i])
        res.i <- sub("$sym",sym,tmpl,fixed=TRUE)
        res.i <- sub("$val",thrsh,res.i,fixed=TRUE)
        res <- c(res,res.i)
    }
    res <- paste(res,collapse=clps)
    paste0(title,res)
}


format.memisc_mtable <- function(x,
                          target=c("print","LaTeX","HTML","delim"),
                          ...){
    target <- match.arg(target)
    x <- preformat_mtable(x)
    switch(target,
           print=pf_mtable_format_print(x,...),
           LaTeX=pf_mtable_format_latex(x,...),
           HTML=pf_mtable_format_html(x,...),
           delim=pf_mtable_format_delim(x,...)
           )
}

print.memisc_mtable <- function(x,center.at=getOption("OutDec"),
      topsep="=",bottomsep="=",sectionsep="-",...){

    calls <- sapply(x,"[[","call")
    cat("\nCalls:\n")
    for(i in seq(calls)){
        cat(names(calls)[i],": ",sep="")
        print(calls[[i]])
    }
    cat("\n")
    cat(format.memisc_mtable(x,target="print",
                      center.at=center.at,
                      topsep=topsep,
                      bottomsep=bottomsep,
                      sectionsep=sectionsep,...),
        sep="")
}

toLatex.memisc_mtable <- function(object,...){
  structure(format.memisc_mtable(x=object,target="LaTeX",...),
  class="Latex")
}

write.mtable <- function(object,file="",
                         format=c("delim","LaTeX","HTML"),
                         ...){
  l <- list(...)
  if(isTRUE(l[["forLaTeX"]])) # Avoid breaking old code
    target <- "LaTeX"
  else
    target <- match.arg(format)
    
  f <- format.memisc_mtable(object,target=target,...)
  if(target %in% c("LaTeX","HTML"))
    f <- paste(f,"\n",sep="")
  cat(f,file=file,sep="")
}

Try the memisc package in your browser

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

memisc documentation built on March 31, 2023, 7:29 p.m.