R/latex.lrm.s

Defines functions latex.orm latex.lrm

Documented in latex.lrm latex.orm

latex.lrm <-
  function(object, title, 
           file='',
           append=FALSE, which, varnames, columns=65, inline=FALSE, 
           before=if(inline)"" else "& &", after="",
           pretrans=TRUE, caption=NULL, digits=.Options$digits, size='',
           ...)
{
  f <- object
  md <- prType() %in% c('html', 'md', 'markdown')
  
  if(missing(which) & !inline)
    {
      Y <- paste("\\mathrm{", as.character(attr(f$terms,"formula")[2]),
                 "}", sep="")
      lev <- names(f$freq)
      nrp <- f$non.slopes
      
      w <- '$$'
      
      j <- if(lev[2]=="TRUE") "" else paste("=", lev[2], sep="")
      if(nrp==1) w <- paste(w, "\\Pr(", Y, j,
           ") = \\frac{1}{1+\\exp(-X\\beta)}", sep="")

      else
        w <- paste(w,"\\Pr(", Y, 
                   "\\geq j) = \\frac{1}{1+\\exp(-\\alpha_{j}-X\\beta)}",
                   sep="")

      w <- paste(w, ", \\mathrm{~~where} \\\\ $$", sep="")

      if(length(caption)) {
        if(md) w <- c(paste('<div align=center><strong>', caption,
                             '</strong></div>'), w)
        else
          w <- c(paste('\\begin{center} \\bf',caption,
                       '\\end{center}'), w)
        }
      
      if(nrp > 1) {
        w <- c(w,"\\begin{array}")
        cof <- format(f$coef[1:nrp])
        for(i in 1:nrp)
          w <- c(w, paste("\\hat{\\alpha}_{\\rm ",
                          lev[i+1],"} &=&",cof[i],"\\\\",sep=""))
        w <- c(w,"\\end{array}",sep="")
      }
    }
  else w <- NULL
  
  if(missing(which) | missing(varnames)) at <- f$Design

  if(missing(which))    which    <- 1:length(at$name)
  if(missing(varnames)) varnames <- at$name[at$assume.code!=9]

  z <- latexrms(f, file='', which=which, varnames=varnames, 
           columns=columns, 
           before=before, after=after, prefix="X\\hat{\\beta}",
           inline=inline, pretrans=pretrans, digits=digits,
           size=size)
  if(inline) return(z)
  w <- c(w, z)
  if(file != '' || prType() == 'plain') {
    cat(w, file=file, append=append, sep='\n')
    return(invisible())
    }
  rendHTML(w, html=FALSE)
}


latex.orm <-
  function(object, title, 
           file='',
           append=FALSE, which, varnames, columns=65, inline=FALSE, 
           before=if(inline)"" else "& &", after="",
           pretrans=TRUE, caption=NULL, digits=.Options$digits, size='',
           intercepts=nrp < 10, ...)
{
  f <- object

  md <- prType() %in% c('html', 'md', 'markdown')

  
  if(missing(which) & !inline)
    {
      Y <- paste("\\mathrm{", as.character(attr(f$terms,"formula")[2]),
                 "}", sep="")
      lev <- names(f$freq)
      nrp <- f$non.slopes

      z <- '\\alpha_{y} + X\\beta'
      zm <- '- \\alpha_{y} - X\\beta'
      dist <-
        switch(f$family,
               logistic = paste('\\frac{1}{1+\\exp(', zm, ')}', sep=''),
               probit   = paste('\\Phi(', z, ')', sep=''),
               cauchit  = paste('\\frac{1}{\\pi}\\tan^{-1}(', z,
                 ') + \\frac{1}{2}', sep=''),
               loglog   = paste('\\exp(-\\exp(', zm, '))', sep=''),
               cloglog  = paste('1 - \\exp(-\\exp(', z, ')', sep=''))
                     
      w <- '$$'
      
      w <- paste(w, "\\Pr(", Y, 
                   "\\geq y | X) = ", dist, sep='')

      w <- paste(w, "\\mathrm{~~where}$$", sep="")

      if(length(caption)) {
        if(md) w <- c(paste('<div align=center><strong>', caption,
                             '</strong></div>'), w)
        else
          w <- c(paste('\\begin{center} \\bf',caption,
                       '\\end{center}'), w)
        }
      
      if(intercepts) {
        nl <- as.numeric(lev)
        if(!any(is.na(nl))) lev <- format(nl, digits=digits)
          w <- c(w,"\\begin{array}")
          cof <- format(f$coef[1:nrp], digits=digits)
          for(i in 1:nrp)
            w <- c(w, paste("\\hat{\\alpha}_{\\mathrm{",
                            lev[i+1], "}} &=&", cof[i], "\\\\", sep=""))
          w <- c(w, "\\end{array}", sep="")
      }
    }
  else w <- NULL
  if(missing(which) | missing(varnames)) at <- f$Design

  if(missing(which)) which <- 1:length(at$name)
  if(missing(varnames)) varnames <- at$name[at$assume.code!=9]
  z <- 
  latexrms(f, file='', append=TRUE, which=which, varnames=varnames, 
           columns=columns, 
           before=before, after=after, prefix="X\\hat{\\beta}",
           inline=inline, pretrans=pretrans, digits=digits,
           size=size)
  if(inline) return(z)
  w <- c(w, z)
  if(file == '' && prType() != 'plain') return(rendHTML(w))
  cat(w, file=file, append=append, sep='\n')
  invisible()
}

Try the rms package in your browser

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

rms documentation built on Sept. 12, 2023, 9:07 a.m.