Chemical Data Processing Library C++ API - Version 1.4.0
HydrophobicAtomFeatureGenerator.hpp
Go to the documentation of this file.
1 /*
2  * HydrophobicAtomFeatureGenerator.hpp
3  *
4  * This file is part of the Chemical Data Processing Toolkit
5  *
6  * Copyright (C) 2003 Thomas Seidel <thomas.seidel@univie.ac.at>
7  *
8  * This library is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2 of the License, or (at your option) any later version.
12  *
13  * This library is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public License
19  * along with this library; see the file COPYING. If not, write to
20  * the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
21  * Boston, MA 02111-1307, USA.
22  */
23 
29 #ifndef CDPL_PHARM_HYDROPHOBICATOMFEATUREGENERATOR_HPP
30 #define CDPL_PHARM_HYDROPHOBICATOMFEATUREGENERATOR_HPP
31 
32 #include "CDPL/Pharm/APIPrefix.hpp"
36 #include "CDPL/Chem/Fragment.hpp"
37 #include "CDPL/Util/Array.hpp"
38 
39 
40 namespace CDPL
41 {
42 
43  namespace Pharm
44  {
45 
46  class Feature;
47 
54  {
55 
56  public:
58  static constexpr double DEF_HYD_THRESHOLD = 0.5;
60  static constexpr double DEF_FEATURE_TOL = 1.5;
62  static constexpr unsigned int DEF_FEATURE_TYPE = FeatureType::HYDROPHOBIC;
64  static constexpr unsigned int DEF_FEATURE_GEOM = FeatureGeometry::SPHERE;
65 
67  typedef std::shared_ptr<HydrophobicAtomFeatureGenerator> SharedPointer;
68 
73 
79 
87 
92 
99  void setFeatureType(unsigned int type);
100 
106  unsigned int getFeatureType() const;
107 
114  void setFeatureTolerance(double tol);
115 
121  double getFeatureTolerance() const;
122 
129  void setFeatureGeometry(unsigned int geom);
130 
136  unsigned int getFeatureGeometry() const;
137 
143  void setHydrophobicityThreshold(double thresh);
144 
150 
157 
163 
164  private:
165  void addNonPatternFeatures(const Chem::MolecularGraph& molgraph, Pharmacophore& pharm);
166 
167  void emitFeature(const Chem::Atom&, Pharmacophore&, const Chem::Fragment::SharedPointer&, double) const;
168 
169  void getAtomHydrophobicities();
170 
171  Chem::Fragment::SharedPointer makeFragment(const Chem::Atom&) const;
172 
173  unsigned int featureType;
174  double featureTol;
175  unsigned int featureGeom;
176  double hydThreshold;
177  Util::DArray atomHydTable;
178  };
179  } // namespace Pharm
180 } // namespace CDPL
181 
182 #endif // CDPL_PHARM_HYDROPHOBICATOMFEATUREGENERATOR_HPP
Definition of class CDPL::Util::Array.
Definition of constants in namespace CDPL::Pharm::FeatureGeometry.
Definition of class CDPL::Chem::Fragment.
Definition of class CDPL::Pharm::PatternBasedFeatureGenerator.
Definition of the preprocessor macro CDPL_PHARM_API.
#define CDPL_PHARM_API
Tells the compiler/linker which classes, functions and variables are part of the library API.
Definition of constants in namespace CDPL::Pharm::FeatureType.
Abstract base class representing a chemical atom and its bonded neighborhood.
Definition: Atom.hpp:57
std::shared_ptr< Fragment > SharedPointer
A reference-counted smart pointer [SHPTR] for dynamically allocated Fragment instances.
Definition: Fragment.hpp:66
Abstract base class for representations of a chemical structure as a graph of bonded atoms.
Definition: MolecularGraph.hpp:57
std::shared_ptr< FeatureGenerator > SharedPointer
A reference-counted smart pointer [SHPTR] for dynamically allocated FeatureGenerator instances.
Definition: FeatureGenerator.hpp:62
Pharm::FeatureGenerator implementation that emits one hydrophobic feature per atom whose individual h...
Definition: HydrophobicAtomFeatureGenerator.hpp:54
double getFeatureTolerance() const
Returns the value of the feature tolerance property that gets set on newly generated features.
void setHydrophobicityThreshold(double thresh)
Specifies the minimum hydrophobicity of an atom that is required for the generation of a new feature.
double getHydrophobicityThreshold() const
Returns the minimum hydrophobicity of an atom that is required for the generation of a new feature.
FeatureGenerator::SharedPointer clone() const
Creates a deep copy of the HydrophobicAtomFeatureGenerator instance.
void setFeatureGeometry(unsigned int geom)
Specifies the value of the feature geometry property that has to be set on newly generated features.
std::shared_ptr< HydrophobicAtomFeatureGenerator > SharedPointer
A reference-counted smart pointer [SHPTR] for dynamically allocated HydrophobicAtomFeatureGenerator i...
Definition: HydrophobicAtomFeatureGenerator.hpp:67
HydrophobicAtomFeatureGenerator(const HydrophobicAtomFeatureGenerator &gen)
Constructs a copy of the HydrophobicAtomFeatureGenerator instance gen.
void setFeatureTolerance(double tol)
Specifies the value of the feature tolerance property that has to be set on newly generated features.
HydrophobicAtomFeatureGenerator & operator=(const HydrophobicAtomFeatureGenerator &gen)
Copies the HydrophobicAtomFeatureGenerator instance gen.
void setFeatureType(unsigned int type)
Specifies the value of the feature type property that has to be set on newly generated features.
unsigned int getFeatureType() const
Returns the value of the feature type property that gets set on newly generated features.
unsigned int getFeatureGeometry() const
Returns the value of the feature geometry property that gets set on newly generated features.
HydrophobicAtomFeatureGenerator()
Constructs the HydrophobicAtomFeatureGenerator instance.
HydrophobicAtomFeatureGenerator(const Chem::MolecularGraph &molgraph, Pharmacophore &pharm)
Perceives hydrophobic atom features of the molecular graph molgraph and adds them to the pharmacophor...
Pharm::FeatureGenerator implementation that perceives pharmacophore features by SMARTS-like substruct...
Definition: PatternBasedFeatureGenerator.hpp:59
Abstract base class for mutable containers of Pharm::Feature instances representing a pharmacophore m...
Definition: Pharmacophore.hpp:53
constexpr unsigned int SPHERE
Specifies a spherical feature geometry.
Definition: FeatureGeometry.hpp:53
constexpr unsigned int HYDROPHOBIC
Specifies a hydrophobic feature.
Definition: Pharm/FeatureType.hpp:53
Array< double > DArray
Array storing floating point values of type double.
Definition: Array.hpp:595
The namespace of the Chemical Data Processing Library.