File: Builder.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 (104 lines) | stat: -rw-r--r-- 4,381 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
//
//  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_MMFFBUILDER_H_
#define _RD_MMFFBUILDER_H_

#include <vector>
#include <string>
#include <boost/shared_array.hpp>
#include <boost/tuple/tuple.hpp>
#include <boost/cstdint.hpp>


namespace ForceFields {
  class ForceField;
}

namespace RDKit {
  class ROMol;
  namespace MMFF {

    //! Builds and returns a MMFF force field for a molecule
    /*!
      
      \param mol              the molecule to use
      \param nonBondedThresh  the threshold to be used in adding non-bonded terms
                              to the force field. Any non-bonded contact whose current
			distance is greater than \c nonBondedThresh * the minimum value
			for that contact will not be included.
      \param confId     the optional conformer id, if this isn't provided, the molecule's
                        default confId will be used.
      \param ignoreInterfragInteractions if true, nonbonded terms will not be added between
                                         fragments

      \return the new force field. The client is responsible for free'ing this.
    */
    ForceFields::ForceField *constructForceField(ROMol &mol,
      double nonBondedThresh = 100.0, int confId = -1, bool ignoreInterfragInteractions = true);


    //! Builds and returns a MMFF force field for a molecule
    /*!
      
      \param mol        the molecule to use
      \param mmffMolProperties        pointer to a MMFFMolProperties (as obtained by a
                        call to setupMMFFForceField())
      \param nonBondedThresh  the threshold to be used in adding non-bonded terms
                        to the force field. Any non-bonded contact whose current
			distance is greater than \c nonBondedThresh * the minimum value
			for that contact will not be included.
      \param confId     the optional conformer id, if this isn't provided, the molecule's
                        default confId will be used.
      \param ignoreInterfragInteractions if true, nonbonded terms will not be added between
                                         fragments
    
      \return the new force field. The client is responsible for free'ing this.
    */
    ForceFields::ForceField *constructForceField(ROMol &mol, MMFFMolProperties *mmffMolProperties,
      double nonBondedThresh = 100.0, int confId = -1, bool ignoreInterfragInteractions = true);

    namespace Tools {
      enum {
        RELATION_1_2 = 0,
        RELATION_1_3 = 1,
        RELATION_1_4 = 2,
        RELATION_1_X = 3
      };
      // these functions are primarily exposed so they can be tested.
      void setTwoBitCell(boost::shared_array<boost::uint8_t> &res,
        unsigned int pos, boost::uint8_t value);
      boost::uint8_t getTwoBitCell
        (boost::shared_array<boost::uint8_t> &res, unsigned int pos);
      boost::shared_array<boost::uint8_t> buildNeighborMatrix(const ROMol &mol);
      void addBonds(const ROMol &mol,
        MMFFMolProperties *mmffMolProperties, ForceFields::ForceField *field);
      void addAngles(const ROMol &mol,
        MMFFMolProperties *mmffMolProperties, ForceFields::ForceField *field);
      void addStretchBend(const ROMol &mol,
        MMFFMolProperties *mmffMolProperties, ForceFields::ForceField *field);
      void addOop(const ROMol &mol,
        MMFFMolProperties *mmffMolProperties, ForceFields::ForceField *field);
      void addTorsions(const ROMol &mol,
        MMFFMolProperties *mmffMolProperties, ForceFields::ForceField *field,
        std::string torsionBondSmarts = "[!$(*#*)&!D1]~[!$(*#*)&!D1]");
      void addVdW(const ROMol &mol, int confId, MMFFMolProperties *mmffMolProperties,
        ForceFields::ForceField *field, boost::shared_array<boost::uint8_t> neighborMatrix,
        double nonBondedThresh = 100.0, bool ignoreInterfragInteractions = true);
      void addEle(const ROMol &mol, int confId, MMFFMolProperties *mmffMolProperties,
        ForceFields::ForceField *field, boost::shared_array<boost::uint8_t> neighborMatrix,
        double nonBondedThresh = 100.0, bool ignoreInterfragInteractions = true);
    }
  }
}


#endif