OERandomizeTorsions¶
bool OERandomizeTorsions(OEMolBase &mol, double maxRadians)
bool OERandomizeTorsions(OEMolBase &mol, double maxRadians,
const OESystem::OEUnaryPredicate<OEBondBase> &isRotor)
Modifies each of the torsions in a molecule by a random value between
+maxRadians
and -maxRadians
. While most people think about
this sort of function in degrees, all angles in OEChem TK are measures
in radians. The following simple constants may be used
OEMath.Pi
, OEMath.Rad2Deg
and
OEMath.Deg2Rad
to generate the appropriate value.
There are two API points, the one with two arguments applies the
random torsion adjustment to every bond for which the OEChem TK bond
predicate ‘IsRotor` returns true
. The second API point has an
additional argument in which the user can specify a functor which
defines which bonds are rotatable. If the user’s functor causes the
function to attempt to apply a random rotation on a ring bond, no
change in the internal coordinates will occur, however, the frame of
reference of the molecule may change.
The functions return true
if completes successfully. The functions
return false
if there are no torsions to randomize.
- mol
The molecule to randomize torsions of.
- maxRadians
Maximum value of torsions angle to be modified, in radians.
- isRotor
Predicate to define which torsions should be randomized.