File: BondStretch.h

package info (click to toggle)
rdkit 201403-1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 62,288 kB
  • ctags: 15,156
  • sloc: cpp: 125,376; python: 55,674; java: 4,831; ansic: 4,178; xml: 2,499; sql: 1,775; yacc: 1,551; lex: 1,051; makefile: 353; fortran: 183; sh: 148; cs: 93
file content (60 lines) | stat: -rw-r--r-- 1,964 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
//
//  Copyright (C) 2013 Paolo Tosco
//
//  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.
//
#ifndef __RD_MMFFBONDSTRETCH_H__
#define __RD_MMFFBONDSTRETCH_H__
#include <ForceField/Contrib.h>

namespace ForceFields {
  namespace MMFF {
    class MMFFBond;
    class MMFFBondStretchEmpiricalRule;

    //! The bond-stretch term for MMFF
    class BondStretchContrib : public ForceFieldContrib {
    public:
      BondStretchContrib() : d_at1Idx(-1), d_at2Idx(-1) {};
      //! Constructor
      /*!
	\param owner       pointer to the owning ForceField
	\param idx1        index of end1 in the ForceField's positions
	\param idx2        index of end2 in the ForceField's positions
	\param bondType    MMFF94 type of the bond (as an unsigned int)
	\param end1Params  pointer to the parameters for end1
	\param end2Params  pointer to the parameters for end2
	
      */
      BondStretchContrib(ForceField *owner,
        const unsigned int idx1, const unsigned int idx2,
        const MMFFBond *mmffBondParams);

      double getEnergy(double *pos) const;

      void getGrad(double *pos,double *grad) const;
    
    private:
      int d_at1Idx, d_at2Idx; //!< indices of end points
      double d_r0;        //!< rest length of the bond
      double d_kb;  //!< force constant of the bond

    };
  
    namespace Utils {
      //! returns the MMFF rest length for a bond 
      double calcBondRestLength(const MMFFBond *mmffBondParams);
      //! returns the MMFF force constant for a bond 
      double calcBondForceConstant(const MMFFBond *mmffBondParams);
      //! calculates and returns the bond stretching MMFF energy
      double calcBondStretchEnergy(const double r0, const double kb, const double distance);
    }  
  }
}
#endif