R/wrap.R

Defines functions wrap.pdb wrap.atoms wrap.coords wrap

Documented in wrap wrap.atoms wrap.coords wrap.pdb

#' Wrap Atomic Coordinates
#' 
#' Wraps atomic coordinates using periodic boundary conditions.
#' 
#' The \code{wrap} function translates all atoms out of the unit cell back into
#' the unit cell using periodic boundary conditions. To do so, the \code{wrap}
#' function first converts Cartesian into fractional coordinates. Then atoms
#' with fractional coordinates greater than 1 or lower than 0 are respectively
#' translated by -1 or +1. Finally, if the original atomic coordinates were
#' Cartesian coordinates their are reconverted into Cartesian coordinates.
#' 
#' @return Return an object of class \sQuote{pdb} with wrapped atomic
#'   coordinates.
#'   
#' @param x an R object containing atomic coordinates to be wrapped.
#' @param crystal an object of class \sQuote{crystal} containing periodic boundary
#'   conditions used for wrapping.
#' @param factor a factor used to wrap the atoms by groups.
#' @param \dots further arguments passed to or from other methods.
#' 
#' @seealso \code{\link{coords}}, \code{\link{atoms}}, \code{\link{pdb}},
#' \code{\link{crystal}}, \code{\link{centres.pdb}}, \code{\link{xyz2abc}}
#' 
#' @examples 
#' x <- read.pdb(system.file("examples/PCBM_ODCB.pdb", package="Rpdb"))
#' 
#' # Translation of the atoms along x-axis
#' x$atoms$x1 <- x$atoms$x1 + 10
#' 
#' # Wrapping the structure
#' y <- wrap(x)
#' 
#' @keywords manip
#' 
#' @name wrap
#' @export
wrap <- function(x, ...)
  UseMethod("wrap")

#' @rdname wrap
#' @export
wrap.coords <- function(x, crystal = NULL, factor = NULL, ...)
{
	if(is.null(crystal)) stop("Please specify a 'crystal' object")
	if(is.null(factor)) factor = 1:natom(x);
  
	if(! is.coords(x)) stop("'x' must be an object of class 'coords'");
	if(! is.crystal(crystal)) stop("'crystal' must be an object of class 'crystal'");
	
	b = basis(x);
	if(b == "xyz") x = xyz2abc(x, crystal);
	
	centers = centres.coords(x, factor = factor, unsplit = TRUE);
	# TODO: can coords be >= 2 or < -1?
	x[centers > 1] = x[centers > 1] - 1;
	x[centers < 0] = x[centers < 0] + 1;
	
	if(b == "xyz") x = abc2xyz.coords(x, crystal);
	
	return(x);
}

#' @rdname wrap
#' @export
wrap.atoms <- function(x, crystal = NULL, factor = NULL, ...)
{
	if(is.null(crystal)) stop("Please specify a 'crystal' object");
	if(is.null(factor)) factor = x$resid;
	
	if(! is.atoms(x)) stop("'x' must be an object of class 'atoms'");
	if(! is.crystal(crystal)) stop("'crystal' must be an object of class 'crystal'");
	
	coords(x) = wrap.coords(coords(x), crystal, factor);
	
	return(x);
}

#' @rdname wrap
#' @export
wrap.pdb <- function(x, crystal = x$crystal, factor = NULL, ...)
{
	if(is.null(factor)) factor <- x$atoms$resid;
	
	if(! is.pdb(x)) stop("'x' must be an object of class 'pdb'");
	if(! is.crystal(crystal)) stop("'crystal' must be an object of class 'crystal'");
	
	coords(x) = wrap.coords(coords(x), crystal, factor);
	
	return(x);
}

Try the Rpdb package in your browser

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

Rpdb documentation built on March 16, 2026, 5:07 p.m.