Learn R Programming

Rpdb (version 2.2)

distances: Inter-Atomic Distances

Description

Computes inter-atomic distance vectors.

Usage

is.distances(x)
distances(...) "distances"(dx1 = numeric(0), dx2 = numeric(0), dx3 = numeric(0), basis = "xyz", ...) "distances"(x, sel1, sel2, ...) "distances"(x, sel1, sel2, ...) "distances"(x, sel1, sel2, ...)
norm(...) "norm"(x, type = "xyz", ...)

Arguments

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.
...
further arguments passed to or from other methods.

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

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