Learn R Programming

Rpdb (version 2.3.4)

distances: Inter-Atomic Distances

Description

Computes inter-atomic distance vectors.

Usage

distances(...)

# S3 method for default distances( dx1 = numeric(0), dx2 = numeric(0), dx3 = numeric(0), basis = "xyz", ... )

# S3 method for coords distances(x, sel1, sel2, ...)

# S3 method for atoms distances(x, sel1, sel2, ...)

# S3 method for pdb distances(x, sel1, sel2, ...)

is.distances(x)

norm(...)

# S3 method for distances norm(x, type = "xyz", ...)

Value

The distance function return an object of class ‘distances’ containing inter-atomic distance vectors. The norm

function return an array, with the same dimensions as the dx1, dx2, dx3 components of the ‘distances’ object for which the norms have to be computed, containing the norm of the distance vectors.

is.distances returns TRUE if x is an object of class ‘distances’ and FALSE otherwise

Arguments

...

further arguments passed to or from other methods.

dx1, dx2, dx3

numeric arrays containing the first, second and third components of the distance vectors.

basis

a single element character vector indicating the type of basis vector used to express the coordinates.

x

an R object containing atomic coordinates.

sel1, sel2

integer or logical vectors defining two atomic selections between which the distance vectors are computed.

type

a single element character vector indicating how to project the distances vectors before computing the norms. See details.

Details

The purpose of the ‘distances’ class is to store the inter-atomic distance vectors and facilitate their manipulation when passing from the Cartesian to fractional references and vice versa.
The default method of the distances function is actually a builder allowing to create a ‘distances’ object from its different components, i.e.: dx1, dx2, dx3, and basis. All the arguments have to be specified except 'basis' which by default is set to "xyz" (Cartesian reference).

For objects of class ‘coords’, ‘atoms’, ‘pdb’, two sets of atomic coordinates, defined by sel1 and sel2, are extracted and inter-atomic distance vectors are computed between these two sets.

The method of the norm function for objects of class ‘distances’ computes the norm of the distances vectors. type specify how to project the distance vectors before computing the norms. By default no projection is perform. The three dx, dy, and dz components of the distance vectors are used to compute the norm. type can take the following values:

  • x: The distance vectors are projected over x.

  • y: The distance vectors are projected over y.

  • z: The distance vectors are projected over z.

  • xy: The distance vectors are projected in the xy-plan.

  • yz: The distance vectors are projected in the yz-plan.

  • zx: The distance vectors are projected in the zx-plan.

  • xyz: The distance vectors are not projected (The three components of the distance vectors are used to compute the norm).

is.distances tests if x is an object of class ‘distances’, i.e. if x has a “class” attribute equal to distances.

See Also

coords, basis, xyz2abc, abc2xyz

Examples

Run this code
x <- read.pdb(system.file("examples/PCBM_ODCB.pdb", package="Rpdb"))
is.DCB7 <- x$atoms$resname == "DCB" & x$atoms$resid == 7
is.DCB8 <- x$atoms$resname == "DCB" & x$atoms$resid == 8
d <- distances(x, is.DCB7, is.DCB8)
norm(d, type = "xyz")
norm(d, type = "xy")
norm(d, type = "x")

Run the code above in your browser using DataLab