R/pymol.modes.R

Defines functions pymol.modes pymol.pca pymol.nma

Documented in pymol.modes pymol.nma pymol.pca

pymol.nma <- function(...)
  pymol.modes(...)

pymol.pca <- function(...)
  pymol.modes(...)

pymol.modes <- function(modes, mode=NULL, file=NULL, scale=5, dual=FALSE,
                      type="script", exefile = "pymol", ...) {

  if(! (inherits(modes, "nma") || inherits(modes,"pca")) )
    stop("must supply a 'nma' or 'pca' object, i.e. from 'nma()' or 'pca.xyz()'")
  
  allowed <- c("session", "script", "launch")
  if(!type %in% allowed) {
    stop(paste("input argument 'type' must be either of:",
               paste(allowed, collapse=", ")))
  }
    
    ## Check if the program is executable
    if(type %in% c("session", "launch")) {
        
        ## determine path to exefile
        exefile1 <- .get.exepath(exefile)
        
        ## Check if the program is executable
        success <- .test.exefile(exefile1)
        
        if(!success) {
            stop(paste("Launching external program failed\n",
                       "  make sure '", exefile, "' is in your search path", sep=""))
        }
        exefile <- exefile1
    }
    
  if(inherits(modes, "nma")) {
    if(is.null(mode))
      mode <- 7
    xyz <- modes$xyz
    mode.vecs <- matrix(modes$modes[,mode], ncol=3, byrow=T)
  }
  else {
    if(is.null(mode))
      mode <- 1
    xyz <- modes$mean
    mode.vecs <- matrix(modes$U[,mode], ncol=3, byrow=T)
  }
  
  ## calc all vec lengths (for coloring later)
  all.lens <- apply(mode.vecs, 1, function(x) sqrt(sum(x**2)))

  ## output file name
  if(is.null(file)) {
    if(type=="session")
      file <- "R.pse"
    if(type=="script")
      file <- "R.py"
  }
  
  ## use temp-dir unless we output a PML script
  if(type %in% c("session", "launch"))
    tdir <- tempdir()
  else
    tdir <- "."

  pyfile <- tempfile(tmpdir=tdir, fileext=".py")
  psefile <- tempfile(tmpdir=tdir, fileext=".pse")
  pdbfile <- tempfile(tmpdir=tdir, fileext=".pdb")
  
  ## start building pymol script
  scr <- c("from pymol import cmd")
  scr <- c(scr, "from pymol.cgo import *")
  scr <- c(scr, paste("cmd.load('", 
    normalizePath(pdbfile, winslash='/', mustWork=FALSE),
    "', 'prot')", sep=""))
  scr <- c(scr, "cmd.show('cartoon')")
  scr <- c(scr, "cmd.set('cartoon_trace_atoms', 1)")
      
  ## define color range 
  blues <- colorRamp(c("blue", "white", "red"))

  ## Arrow widths
  w.body <- 0.15; w.head <- 0.2

  scr <- c(scr, "obj=[]")
  for ( i in 1:nrow(mode.vecs)) {
    inds    <- atom2xyz(i) 
    coords  <- xyz[inds]
    
    ## For coloring (longest vec has length=1)
    tmp.len <- sqrt(sum((mode.vecs[i,]/max(all.lens))**2))
    if(tmp.len>1)
      tmp.len <- 1
    
    col <- blues(tmp.len)
    col <- round(col/256,4)
    col <- paste(col, collapse=", ")
    
    ## Main vector
    tmp.vec <- mode.vecs[i,] * scale
    
    ## For arrow head
    if(sqrt(sum(tmp.vec**2))<1)
      norm.vec <-  tmp.vec
    else
      norm.vec <- normalize.vector(mode.vecs[i,])
    
    ## Set vectors
    arrow.vec.a <- (coords + tmp.vec)
    head.vec.a  <- (arrow.vec.a + (norm.vec))
    
    arrow.vec.b <- (coords - tmp.vec)
    head.vec.b <- (arrow.vec.b - (norm.vec))
    
    a  <- paste(coords,      collapse=",")
    b1 <- paste(arrow.vec.a, collapse=",")
    c1 <- paste(head.vec.a,  collapse=",")
    b2 <- paste(arrow.vec.b, collapse=",")
    c2 <- paste(head.vec.b,  collapse=",")
    
    
    ## Arrow body
    scr <- c(scr, paste("obj.extend([CYLINDER", a, b1, w.body, col, col, "])", sep=", "))
    if(dual)
      scr <- c(scr, paste("obj.extend([CYLINDER", a, b2, w.body, col, col, "])", sep=", "))
    
    ## Arrow heads
    scr <- c(scr, paste("obj.extend([CONE", b1, c1, w.head, 0.0, col, col, 1.0, 1.0,"])", sep=", "))
    if(dual)
      scr <- c(scr, paste("obj.extend([CONE", b2, c2, w.head, 0.0, col, col, 1.0, 1.0,"])", sep=", "))
  }
  
  name <- "vecs"
  scr <- c(scr, paste("cmd.load_cgo(obj, '", name, "')", sep=""))

  if(type == "session")
    scr <- c(scr, paste0("cmd.save('", 
      normalizePath(psefile, winslash='/', mustWork=FALSE),
      "')"))
   
  ## Write PDB structure file
  write.pdb(xyz=xyz, file=pdbfile)
  
  ## Write python script or PDB with conect records
  write(scr, file=pyfile, sep="\n")

  if(type %in% c("session", "launch")) {
    if(type == "session")
      args <- "-cq"
    else
      args <- ""
    
    ## Open pymol
    cmd <- paste(exefile, args, pyfile)
    
    os1 <- Sys.info()["sysname"]
    if (os1 == "Windows") {
        status <- shell(paste(shQuote(exefile), args, pyfile))
    }
    else {
        status <- system(cmd)
    }
    
    if(!(status %in% c(0,1))) {
        stop(paste("An error occurred while running command\n '",
                   exefile, "'", sep=""))
    }

  }

  if(type == "session") {
    file.copy(psefile, file, overwrite=TRUE)
    message(paste("PyMOL session written to file", file))
    invisible(file)
  }
  
  if(type == "script") {
    file.copy(pyfile, file, overwrite=TRUE)
    unlink(pyfile)
    message(paste("PyMOL script written to file", file))
    invisible(file)
  }

  
}

Try the bio3d package in your browser

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

bio3d documentation built on Oct. 27, 2022, 1:06 a.m.