File: BCUT.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 (66 lines) | stat: -rw-r--r-- 2,369 bytes parent folder | download | duplicates (3)
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
//
//  Copyright (C) 2020 Brian P. Kelley
//
//   @@ 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 RDKIT_BCUT_H
#define RDKIT_BCUT_H
#ifdef RDK_HAS_EIGEN3
#include <RDGeneral/export.h>
#include <vector>
#include <string>
namespace RDKit {
class ROMol;
namespace Descriptors {
const std::string BCUT2DVersion = "1.0.0";

//! Implements BCUT descriptors From J. Chem. Inf. Comput. Sci., Vol. 39, No. 1,
//! 1999
/*!
   \param mol         the molecule of interest
   \param atom_props  A vector of double for the atom properties to use for the
                      diagonal elements of the BCUT matrix.  Must be equal to
                      the number of atoms in mol.
   \return            std::pair<double,double> pair.first is the high eval,
                      pair.second the lowest
*/
RDKIT_DESCRIPTORS_EXPORT
std::pair<double, double> BCUT2D(const ROMol &mol,
                                 const std::vector<double> &atom_props);

//! Implements BCUT descriptors From J. Chem. Inf. Comput. Sci., Vol. 39, No. 1,
//! 1999
/*!
   \param mol         the molecule of interest
   \param atom_props  An atom property holding a double value on the atom
                      If atom_propname does not exist on the atom, raises
                      If atom_propname cannot be coerced into a double, raises
   \return            std::pair<double,double> pair.first is the high eval,
                      pair.second the lowest
*/
RDKIT_DESCRIPTORS_EXPORT
std::pair<double, double> BCUT2D(const ROMol &mol,
                                 const std::string &atom_propname);

//! Implements BCUT descriptors From J. Chem. Inf. Comput. Sci., Vol. 39, No. 1,
//! 1999
//!  Diagonal elements are (currently) atomic mass, gasteiger charge,
//!  crippen logP and crippen MR
/*!
  \param mol           the molecule of interest

  \return              The bcut vector (mass high eval, mass low eval,
                                        gasteiger charge high eval, gasteiger
  charge low eval, LogP high eval, LogP low eval, MR high eval, MR low eval)
*/
RDKIT_DESCRIPTORS_EXPORT
std::vector<double> BCUT2D(const ROMol &m);
}  // namespace Descriptors
}  // namespace RDKit

#endif
#endif