File: TorsionAngle.h

package info (click to toggle)
rdkit 201809.1%2Bdfsg-6
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 123,688 kB
  • sloc: cpp: 230,509; python: 70,501; java: 6,329; ansic: 5,427; sql: 1,899; yacc: 1,739; lex: 1,243; makefile: 445; xml: 229; fortran: 183; sh: 123; cs: 93
file content (109 lines) | stat: -rw-r--r-- 4,255 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
//
//  Copyright (C) 2004-2006 Rational Discovery LLC
//
//   @@ All Rights Reserved @@
//  This file is part of the RDKit.
//  The contents are covered by the terms of the BSD license
//  which is included in the file license.txt, found at the root
//  of the RDKit source tree.
//
#include <RDGeneral/export.h>
#ifndef __RD_TORSIONANGLE_H__
#define __RD_TORSIONANGLE_H__

#include <ForceField/Contrib.h>
#include <Geometry/point.h>

// we need this so that we get the hybridizations:
#include <GraphMol/Atom.h>

namespace RDGeom {
class Point3D;
}

namespace ForceFields {
namespace UFF {
class AtomicParams;

//! the torsion term for the Universal Force Field
class RDKIT_FORCEFIELD_EXPORT TorsionAngleContrib : public ForceFieldContrib {
 public:
  TorsionAngleContrib()
      : d_at1Idx(-1), d_at2Idx(-1), d_at3Idx(-1), d_at4Idx(-1), d_order(0){};
  //! Constructor
  /*!
    The torsion is between atom1 - atom2 - atom3 - atom4
    (i.e the angle between bond atom1-atom2 and bond atom3-atom4
    while looking down bond atom2-atom3)

    \param owner       pointer to the owning ForceField
    \param idx1        index of atom1 in the ForceField's positions
    \param idx2        index of atom2 in the ForceField's positions
    \param idx3        index of atom3 in the ForceField's positions
    \param idx4        index of atom4 in the ForceField's positions
    \param bondOrder23 order of the torsional bond between atoms 2 and 3 (as a
    double)
    \param atNum2      atomic number of atom2
    \param atNum3      atomic number of atom3
    \param hyb2        hybridization of atom2
    \param hyb3        hybridization of atom3
    \param at2Params   pointer to the parameters for atom 2
    \param at3Params   pointer to the parameters for atom 3
    \param endAtomIsSP2 (optional)
      This boolean is used to signal whether either atom1 or atom4 are
      RDKit::Atom::SP2 hybridized.
      This triggers a special case when either of these cases holds:
       - atom1 is RDKit::Atom::SP2, atom2 is RDKit::Atom::SP2
         and atom3 is RDKit::Atom::SP3
       - atom4 is RDKit::Atom::SP2, atom3 is RDKit::Atom::SP2
         and atom2 is RDKit::Atom::SP3
  */
  TorsionAngleContrib(ForceField *owner, unsigned int idx1, unsigned int idx2,
                      unsigned int idx3, unsigned int idx4, double bondOrder23,
                      int atNum2, int atNum3,
                      RDKit::Atom::HybridizationType hyb2,
                      RDKit::Atom::HybridizationType hyb3,
                      const AtomicParams *at2Params,
                      const AtomicParams *at3Params, bool endAtomIsSP2 = false);
  double getEnergy(double *pos) const;
  void getGrad(double *pos, double *grad) const;
  void scaleForceConstant(unsigned int count) {
    this->d_forceConstant /= static_cast<double>(count);
  };
  virtual TorsionAngleContrib *copy() const {
    return new TorsionAngleContrib(*this);
  };

 private:
  int d_at1Idx, d_at2Idx, d_at3Idx, d_at4Idx;
  unsigned int d_order;
  double d_forceConstant, d_cosTerm;

  //! returns dE/dTheta
  double getThetaDeriv(double cosTheta, double sinTheta) const;

  //! calculate default values of the torsion parameters.
  /*!
     see the constructor for an explanation of the arguments
  */
  void calcTorsionParams(double bondOrder23, int atNum2, int atNum3,
                         RDKit::Atom::HybridizationType hyb2,
                         RDKit::Atom::HybridizationType hyb3,
                         const AtomicParams *at2Params,
                         const AtomicParams *at3Params, bool endAtomIsSP2);
};

namespace Utils {
//! calculates and returns the cosine of a torsion angle
RDKIT_FORCEFIELD_EXPORT double calculateCosTorsion(const RDGeom::Point3D &p1, const RDGeom::Point3D &p2,
                           const RDGeom::Point3D &p3,
                           const RDGeom::Point3D &p4);
RDKIT_FORCEFIELD_EXPORT void calcTorsionGrad(RDGeom::Point3D *r, RDGeom::Point3D *t, double *d,
                     double **g, double &sinTerm, double &cosPhi);
RDKIT_FORCEFIELD_EXPORT double equation17(double bondOrder23, const AtomicParams *at2Params,
                  const AtomicParams *at3Params);
RDKIT_FORCEFIELD_EXPORT bool isInGroup6(int num);
}
}
}
#endif