R/sip.R

Defines functions sip.default sip.enma sip.nma sip

Documented in sip sip.default sip.enma sip.nma

sip <- function(...)
  UseMethod("sip")

sip.nma <- function(a, b, ...) {
  if(length(a$fluctuations)!=length(b$fluctuations))
    stop("dimension mismatch")
  return(sip.default(a$fluctuations, b$fluctuations))
}

sip.enma <- function(enma, ncore=NULL, ...) {
  if(!inherits(enma, "enma"))
    stop("provide a 'enma' object as obtain from function 'nma.pdbs()'")
  
  ncore <- setup.ncore(ncore, bigmem = FALSE)
  
  if(ncore>1)
    mylapply <- mclapply
  else
    mylapply <- lapply

  gaps <- gap.inspect(enma$fluctuations)
  dims <- dim(enma$fluctuations)
  m <- dims[1]
  
  mat <- matrix(NA, m, m)
  ##inds <- pairwise(m)
  inds <- rbind(pairwise(m),
                matrix(rep(1:m,each=2), ncol=2, byrow=T))
  
  mylist <- mylapply(1:nrow(inds), function(row) {
    i <- inds[row,1]; j <- inds[row,2];
    out <- list(val=sip.default(
                  enma$fluctuations[i,gaps$f.inds],
                  enma$fluctuations[j,gaps$f.inds]),
                i=i, j=j)
    return(out)
  })

  for ( i in 1:length(mylist)) {
    tmp <- mylist[[i]]
    mat[tmp$i, tmp$j] <- tmp$val
  }

  mat[ inds[,c(2,1)] ] = mat[ inds ]
  ##diag(mat) <- rep(1, n)
  colnames(mat) <- basename(rownames(enma$fluctuations))
  rownames(mat) <- basename(rownames(enma$fluctuations))
  
  return(round(mat, 6))
}

sip.default <- function(v, w, ...) {
  if(length(v)!=length(w))
    stop("dimension mismatch")
  return(as.numeric(((t(v) %*% w)**2) / ((t(v) %*% v)*(t(w) %*% w))))
}

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.