File: DetermineBonds.h

package info (click to toggle)
rdkit 202503.1-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 220,160 kB
  • sloc: cpp: 399,240; python: 77,453; ansic: 25,517; java: 8,173; javascript: 4,005; sql: 2,389; yacc: 1,565; lex: 1,263; cs: 1,081; makefile: 580; xml: 229; fortran: 183; sh: 105
file content (97 lines) | stat: -rw-r--r-- 4,397 bytes parent folder | download | duplicates (2)
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
//
//  Copyright (C) 2022 Sreya Gogineni and other RDKit contributors
//
//   @@ 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_DETERMINEBONDS_H
#define RD_DETERMINEBONDS_H
#include <GraphMol/RDKitBase.h>

namespace RDKit {
// ! assigns atomic connectivity to a molecule using atomic coordinates,
// disregarding pre-existing bonds
/*!

   This is based on xyz2mol: https://github.com/jensengroup/xyz2mol

   \param mol is the molecule of interest; it must have a 3D conformer
   \param useHueckel (optional) if this is  \c true, extended Hueckel theory
   will be used to determine connectivity rather than the van der Waals or
   connect-the-dots method
   \param charge (optional) the charge of the molecule; it must be provided if
   the Hueckel method is used and charge is non-zero
   \param covFactor (optional) the factor with which to multiply each covalent
   radius if the van der Waals method is used
   \param useVdw (optional) if this is  \c false, the connect-the-dots method
    will be used instead of the van der Waals method
 */
RDKIT_DETERMINEBONDS_EXPORT void determineConnectivity(RWMol &mol,
                                                       bool useHueckel = false,
                                                       int charge = 0,
                                                       double covFactor = 1.3,
                                                       bool useVdw = false);

// ! assigns bond ordering to a molecule that has atomic connectivity defined;
// it is recommended to sanitize the molecule after calling this function if
// embedChiral is not set to true
/*!

   This is based on xyz2mol: https://github.com/jensengroup/xyz2mol

   \param mol is the molecule of interest; it must have single bonds
   corresponding to the atomic connectivity
   \param charge (optional) the charge
   of the molecule; it must be provided if charge is non-zero
   \param allowChargedFragments (optional) if this is  \c true, formal charges
   will be placed on atoms according to their valency; otherwise, radical
   electrons will be placed on the atoms
   \param embedChiral (optional) if this is \c true,
   chirality information will be embedded into the molecule; the function calls
   sanitizeMol() when this is true
   \param useAtomMap (optional) if this is \c
   true, an atom map will be created for the molecule
 */
RDKIT_DETERMINEBONDS_EXPORT void determineBondOrders(
    RWMol &mol, int charge = 0, bool allowChargedFragments = true,
    bool embedChiral = true, bool useAtomMap = false);

// ! assigns atomic connectivity to a molecule using atomic coordinates,
// disregarding pre-existing bonds; it is recommended to sanitize the molecule
// after calling this function if embedChiral is not set to true
/*!

   This is based on xyz2mol: https://github.com/jensengroup/xyz2mol

   \param mol is the molecule of interest; it must have a 3D conformer
   \param useHueckel (optional) if this is  \c true, extended Hueckel theory
   will be used to determine connectivity rather than the van der Waals or
   connect-the-dots method
   \param charge (optional) the charge of the molecule; it must be provided if
   charge is non-zero
   \param covFactor (optional) the factor with which to multiply each covalent
   radius if the van der Waals method is used
   \param allowChargedFragments (optional) if this is  \c true, formal charges
   will be placed on atoms according to their valency; otherwise, radical
   electrons will be placed on the atoms
   \param embedChiral (optional) if this is \c true, chirality information will
   be embedded into the molecule; the function calls sanitizeMol() when this is
   true
   \param useAtomMap (optional) if this is \c true, an atom map will be created
   for the molecule
   \param useVdw (optional) if this is  \c false, the connect-the-dots method
    will be used instead of the van der Waals method
 */
RDKIT_DETERMINEBONDS_EXPORT void determineBonds(
    RWMol &mol, bool useHueckel = false, int charge = 0, double covFactor = 1.3,
    bool allowChargedFragments = true, bool embedChiral = true,
    bool useAtomMap = false, bool useVdw = false);

}  // namespace RDKit

#endif