RDKit
Open-source cheminformatics and machine learning.
types.h
Go to the documentation of this file.
1 //
2 // Copyright (C) 2001-2018 Greg Landrum and Rational Discovery LLC
3 //
4 // @@ All Rights Reserved @@
5 // This file is part of the RDKit.
6 // The contents are covered by the terms of the BSD license
7 // which is included in the file license.txt, found at the root
8 // of the RDKit source tree.
9 //
10 
11 #include <RDGeneral/export.h>
12 #ifndef RD_TYPES_H
13 #define RD_TYPES_H
14 
15 #ifdef WIN32
16 #ifndef _USE_MATH_DEFINES
17 #define _USE_MATH_DEFINES
18 #define _DEFINED_USE_MATH_DEFINES
19 #endif
20 #endif
21 #include <cmath>
22 #ifdef _DEFINED_USE_MATH_DEFINES
23 #undef _DEFINED_USE_MATH_DEFINES
24 #undef _USE_MATH_DEFINES
25 #endif
26 
27 #include "Invariant.h"
28 #include "Dict.h"
29 
30 #include <vector>
31 #include <deque>
32 #include <map>
33 #include <set>
34 #include <string>
35 #include <algorithm>
36 #include <numeric>
37 #include <list>
38 #include <limits>
39 
40 #include <cstring>
42 #include <boost/any.hpp>
43 #include <boost/lexical_cast.hpp>
45 
46 namespace RDKit {
47 
48 namespace detail {
49 // used in various places for computed properties
50 RDKIT_RDGENERAL_EXPORT extern const std::string computedPropName;
51 } // namespace detail
52 
53 namespace common_properties {
54 ///////////////////////////////////////////////////////////////
55 // Molecule Props
56 RDKIT_RDGENERAL_EXPORT extern const std::string _Name; // string
57 RDKIT_RDGENERAL_EXPORT extern const std::string MolFileInfo; // string
58 RDKIT_RDGENERAL_EXPORT extern const std::string MolFileComments; // string
59 RDKIT_RDGENERAL_EXPORT extern const std::string
60  _2DConf; // int (combine into dimension?)
61 RDKIT_RDGENERAL_EXPORT extern const std::string _3DConf; // int
62 RDKIT_RDGENERAL_EXPORT extern const std::string
63  _doIsoSmiles; // int (should probably be removed)
64 RDKIT_RDGENERAL_EXPORT extern const std::string extraRings; // vec<vec<int> >
65 RDKIT_RDGENERAL_EXPORT extern const std::string
66  _smilesAtomOutputOrder; // vec<int> computed
67 RDKIT_RDGENERAL_EXPORT extern const std::string _StereochemDone; // int
68 RDKIT_RDGENERAL_EXPORT extern const std::string _NeedsQueryScan; // int (bool)
69 RDKIT_RDGENERAL_EXPORT extern const std::string _fragSMARTS; // std::string
70 RDKIT_RDGENERAL_EXPORT extern const std::string
71  maxAttachIdx; // int TemplEnumTools.cpp
72 RDKIT_RDGENERAL_EXPORT extern const std::string origNoImplicit; // int (bool)
73 RDKIT_RDGENERAL_EXPORT extern const std::string
74  ringMembership; //? unused (molopstest.cpp)
75 
76 // Computed Values
77 // ConnectivityDescriptors
78 RDKIT_RDGENERAL_EXPORT extern const std::string
79  _connectivityHKDeltas; // std::vector<double> computed
80 RDKIT_RDGENERAL_EXPORT extern const std::string
81  _connectivityNVals; // std::vector<double> computed
82 
83 RDKIT_RDGENERAL_EXPORT extern const std::string
84  _crippenLogP; // double computed
85 RDKIT_RDGENERAL_EXPORT extern const std::string
86  _crippenLogPContribs; // std::vector<double> computed
87 
88 RDKIT_RDGENERAL_EXPORT extern const std::string _crippenMR; // double computed
89 RDKIT_RDGENERAL_EXPORT extern const std::string
90  _crippenMRContribs; // std::vector<double> computed
91 
92 RDKIT_RDGENERAL_EXPORT extern const std::string _labuteASA; // double computed
93 RDKIT_RDGENERAL_EXPORT extern const std::string
94  _labuteAtomContribs; // vec<double> computed
95 RDKIT_RDGENERAL_EXPORT extern const std::string
96  _labuteAtomHContrib; // double computed
97 
98 RDKIT_RDGENERAL_EXPORT extern const std::string _tpsa; // double computed
99 RDKIT_RDGENERAL_EXPORT extern const std::string
100  _tpsaAtomContribs; // vec<double> computed
101 
102 RDKIT_RDGENERAL_EXPORT extern const std::string
103  numArom; // int computed (only uses in tests?)
104 RDKIT_RDGENERAL_EXPORT extern const std::string
105  _MMFFSanitized; // int (bool) computed
106 
107 RDKIT_RDGENERAL_EXPORT extern const std::string
108  _CrippenLogP; // Unused (in the basement)
109 RDKIT_RDGENERAL_EXPORT extern const std::string
110  _CrippenMR; // Unused (in the basement)
111 RDKIT_RDGENERAL_EXPORT extern const std::string
112  _GasteigerCharge; // used to hold partial charges
113 RDKIT_RDGENERAL_EXPORT extern const std::string
114  _GasteigerHCharge; // used to hold partial charges from implicit Hs
115 
116 ///////////////////////////////////////////////////////////////
117 // Atom Props
118 
119 // Chirality stuff
120 RDKIT_RDGENERAL_EXPORT extern const std::string
121  _BondsPotentialStereo; // int (or bool) COMPUTED
122 RDKIT_RDGENERAL_EXPORT extern const std::string
123  _CIPCode; // std::string COMPUTED
124 RDKIT_RDGENERAL_EXPORT extern const std::string _CIPRank; // int COMPUTED
125 RDKIT_RDGENERAL_EXPORT extern const std::string _ChiralityPossible; // int
126 RDKIT_RDGENERAL_EXPORT extern const std::string
127  _UnknownStereo; // int (bool) AddHs/Chirality
128 RDKIT_RDGENERAL_EXPORT extern const std::string
129  _ringStereoAtoms; // int vect Canon/Chiral/MolHash/MolOps//Renumber//RWmol
130 RDKIT_RDGENERAL_EXPORT extern const std::string
131  _ringStereochemCand; // chirality bool COMPUTED
132 RDKIT_RDGENERAL_EXPORT extern const std::string
133  _ringStereoWarning; // obsolete ?
134 
135 // Smiles parsing
136 RDKIT_RDGENERAL_EXPORT extern const std::string _SmilesStart; // int
137 RDKIT_RDGENERAL_EXPORT extern const std::string
138  _TraversalBondIndexOrder; // ? unused
139 RDKIT_RDGENERAL_EXPORT extern const std::string
140  _TraversalRingClosureBond; // unsigned int
141 RDKIT_RDGENERAL_EXPORT extern const std::string _TraversalStartPoint; // bool
142 RDKIT_RDGENERAL_EXPORT extern const std::string
143  _queryRootAtom; // int SLNParse/SubstructMatch
144 RDKIT_RDGENERAL_EXPORT extern const std::string _hasMassQuery; // atom bool
145 RDKIT_RDGENERAL_EXPORT extern const std::string _protected; // atom int (bool)
146 RDKIT_RDGENERAL_EXPORT extern const std::string
147  _supplementalSmilesLabel; // atom string (SmilesWrite)
148 RDKIT_RDGENERAL_EXPORT extern const std::string
149  _unspecifiedOrder; // atom int (bool) smarts/smiles
150 RDKIT_RDGENERAL_EXPORT extern const std::string
151  _RingClosures; // INT_VECT smarts/smiles/canon
152 RDKIT_RDGENERAL_EXPORT extern const std::string
153  atomLabel; // atom string from CXSMILES
154 
155 // MDL Style Properties (MolFileParser)
156 RDKIT_RDGENERAL_EXPORT extern const std::string molAtomMapNumber; // int
157 RDKIT_RDGENERAL_EXPORT extern const std::string molFileAlias; // string
158 RDKIT_RDGENERAL_EXPORT extern const std::string molFileValue; // string
159 RDKIT_RDGENERAL_EXPORT extern const std::string molInversionFlag; // int
160 RDKIT_RDGENERAL_EXPORT extern const std::string molParity; // int
161 RDKIT_RDGENERAL_EXPORT extern const std::string molStereoCare; // int
162 RDKIT_RDGENERAL_EXPORT extern const std::string molRxnComponent; // int
163 RDKIT_RDGENERAL_EXPORT extern const std::string molRxnRole; // int
164 RDKIT_RDGENERAL_EXPORT extern const std::string molTotValence; // int
165 RDKIT_RDGENERAL_EXPORT extern const std::string molSubstCount; // int
166 RDKIT_RDGENERAL_EXPORT extern const std::string molAttachPoint; // int
167 RDKIT_RDGENERAL_EXPORT extern const std::string molAttachOrder; // int
168 RDKIT_RDGENERAL_EXPORT extern const std::string molAtomClass; // string
169 RDKIT_RDGENERAL_EXPORT extern const std::string molAtomSeqId; // int
170 RDKIT_RDGENERAL_EXPORT extern const std::string molRxnExactChange; // int
171 RDKIT_RDGENERAL_EXPORT extern const std::string molReactStatus; // int
172 RDKIT_RDGENERAL_EXPORT extern const std::string molFileLinkNodes; // string
173 
174 RDKIT_RDGENERAL_EXPORT extern const std::string _MolFileRLabel; // unsigned int
175 RDKIT_RDGENERAL_EXPORT extern const std::string _MolFileChiralFlag; // int
176 RDKIT_RDGENERAL_EXPORT extern const std::string _MolFileAtomQuery; // int
177 RDKIT_RDGENERAL_EXPORT extern const std::string _MolFileBondQuery; // int
178 RDKIT_RDGENERAL_EXPORT extern const std::string _MolFileBondEndPts; // string
179 RDKIT_RDGENERAL_EXPORT extern const std::string _MolFileBondAttach; // string
180 RDKIT_RDGENERAL_EXPORT extern const std::string
181  _MolFileBondType; // unsigned int
182 RDKIT_RDGENERAL_EXPORT extern const std::string
183  _MolFileBondStereo; // unsigned int
184 RDKIT_RDGENERAL_EXPORT extern const std::string
185  _MolFileBondCfg; // unsigned int
186 
187 RDKIT_RDGENERAL_EXPORT extern const std::string
188  MRV_SMA; // smarts string from Marvin
189 RDKIT_RDGENERAL_EXPORT extern const std::string dummyLabel; // atom string
190 
191 // Reaction Information (Reactions.cpp)
192 RDKIT_RDGENERAL_EXPORT extern const std::string _QueryFormalCharge; // int
193 RDKIT_RDGENERAL_EXPORT extern const std::string _QueryHCount; // int
194 RDKIT_RDGENERAL_EXPORT extern const std::string _QueryIsotope; // int
195 RDKIT_RDGENERAL_EXPORT extern const std::string
196  _QueryMass; // int = round(float * 1000)
197 RDKIT_RDGENERAL_EXPORT extern const std::string
198  _ReactionDegreeChanged; // int (bool)
199 RDKIT_RDGENERAL_EXPORT extern const std::string NullBond; // int (bool)
200 RDKIT_RDGENERAL_EXPORT extern const std::string _rgroupAtomMaps;
201 RDKIT_RDGENERAL_EXPORT extern const std::string _rgroupBonds;
202 RDKIT_RDGENERAL_EXPORT extern const std::string reactantAtomIdx;
203 RDKIT_RDGENERAL_EXPORT extern const std::string reactionMapNum;
204 
205 // SLN
206 RDKIT_RDGENERAL_EXPORT extern const std::string
207  _AtomID; // unsigned int SLNParser
208 RDKIT_RDGENERAL_EXPORT extern const std::string
209  _starred; // atom int COMPUTED (SLN)
210 RDKIT_RDGENERAL_EXPORT extern const std::string
211  _SLN_s; // string SLNAttribs (chiral info)
212 RDKIT_RDGENERAL_EXPORT extern const std::string _Unfinished_SLN_; // int (bool)
213 
214 // Smarts Smiles
215 RDKIT_RDGENERAL_EXPORT extern const std::string _brokenChirality; // atom bool
216 RDKIT_RDGENERAL_EXPORT extern const std::string isImplicit; // atom int (bool)
217 RDKIT_RDGENERAL_EXPORT extern const std::string
218  smilesSymbol; // atom string (only used in test?)
219 
220 // Tripos
221 RDKIT_RDGENERAL_EXPORT extern const std::string
222  _TriposAtomType; // string Mol2FileParser
223 // missing defs for _TriposAtomName//_TriposPartialCharge...
224 
225 // molecule drawing
226 RDKIT_RDGENERAL_EXPORT extern const std::string _displayLabel; // string
227 RDKIT_RDGENERAL_EXPORT extern const std::string _displayLabelW; // string
228 
229 ///////////////////////////////////////////////////////////////
230 // misc props
231 RDKIT_RDGENERAL_EXPORT extern const std::string
232  TWOD; // need THREED -> confusing using in TDTMol supplier
233  // converge with _2DConf?
234 RDKIT_RDGENERAL_EXPORT extern const std::string BalabanJ; // mol double
235 RDKIT_RDGENERAL_EXPORT extern const std::string BalanbanJ; // typo!! fix...
236 
237 RDKIT_RDGENERAL_EXPORT extern const std::string Discrims; // FragCatalog Entry
238 // Subgraphs::DiscrimTuple (uint32,uint32,uint32)
239 RDKIT_RDGENERAL_EXPORT extern const std::string
240  DistanceMatrix_Paths; // boost::shared_array<double>
241 // - note, confusing creation of names in
242 // - getDistanceMat
243 RDKIT_RDGENERAL_EXPORT extern const std::string internalRgroupSmiles;
244 RDKIT_RDGENERAL_EXPORT extern const std::string atomNote;
245 RDKIT_RDGENERAL_EXPORT extern const std::string bondNote;
246 RDKIT_RDGENERAL_EXPORT extern const std::string _isotopicHs;
247 
248 } // namespace common_properties
249 #ifndef WIN32
250 typedef long long int LONGINT;
251 #else
252 typedef __int64 LONGINT;
253 #endif
254 #ifdef max
255 #undef max // FUCK I hate this nonsense
256 #endif
257 #ifdef min
258 #undef min // FUCK I hate this nonsense
259 #endif
260 
261 RDKIT_RDGENERAL_EXPORT extern const double MAX_DOUBLE;
262 RDKIT_RDGENERAL_EXPORT extern const double EPS_DOUBLE;
263 RDKIT_RDGENERAL_EXPORT extern const double SMALL_DOUBLE;
264 RDKIT_RDGENERAL_EXPORT extern const double MAX_INT;
265 RDKIT_RDGENERAL_EXPORT extern const double MAX_LONGINT;
266 
267 typedef unsigned int UINT;
268 typedef unsigned short USHORT;
269 typedef unsigned char UCHAR;
270 
271 typedef std::vector<int> INT_VECT;
272 typedef INT_VECT::iterator INT_VECT_I;
273 typedef INT_VECT::const_iterator INT_VECT_CI;
274 typedef INT_VECT::reverse_iterator INT_VECT_RI;
275 typedef INT_VECT::const_reverse_iterator INT_VECT_CRI;
276 
277 typedef std::list<int> INT_LIST;
278 typedef INT_LIST::iterator INT_LIST_I;
279 typedef INT_LIST::const_iterator INT_LIST_CI;
280 
281 typedef std::list<INT_VECT> LIST_INT_VECT;
282 typedef LIST_INT_VECT::iterator LIST_INT_VECT_I;
283 typedef LIST_INT_VECT::const_iterator LIST_INT_VECT_CI;
284 
285 typedef std::vector<INT_VECT> VECT_INT_VECT;
286 typedef VECT_INT_VECT::iterator VECT_INT_VECT_I;
287 typedef VECT_INT_VECT::const_iterator VECT_INT_VECT_CI;
288 
289 typedef std::vector<UINT>::const_iterator UINT_VECT_CI;
290 typedef std::vector<UINT> UINT_VECT;
291 
292 typedef std::vector<std::string>::const_iterator STR_VECT_CI;
293 typedef std::vector<std::string>::iterator STR_VECT_I;
294 typedef std::vector<std::string> STR_VECT;
295 
296 typedef std::vector<double> DOUBLE_VECT;
297 typedef DOUBLE_VECT::iterator DOUBLE_VECT_I;
298 typedef DOUBLE_VECT::const_iterator DOUBLE_VECT_CI;
299 typedef std::vector<DOUBLE_VECT> VECT_DOUBLE_VECT;
300 typedef VECT_DOUBLE_VECT::iterator VECT_DOUBLE_VECT_I;
301 typedef VECT_DOUBLE_VECT::const_iterator VECT_DOUBLE_VECT_CI;
302 
303 typedef std::map<std::string, UINT> STR_UINT_MAP;
304 typedef std::map<std::string, UINT>::const_iterator STR_UINT_MAP_CI;
305 
306 typedef std::map<int, INT_VECT> INT_INT_VECT_MAP;
307 typedef INT_INT_VECT_MAP::const_iterator INT_INT_VECT_MAP_CI;
308 
309 typedef std::map<int, int> INT_MAP_INT;
310 typedef INT_MAP_INT::iterator INT_MAP_INT_I;
311 typedef INT_MAP_INT::const_iterator INT_MAP_INT_CI;
312 
313 typedef std::deque<int> INT_DEQUE;
314 typedef INT_DEQUE::iterator INT_DEQUE_I;
315 typedef INT_DEQUE::const_iterator INT_DEQUE_CI;
316 
317 typedef std::map<int, INT_DEQUE> INT_INT_DEQ_MAP;
318 typedef INT_INT_DEQ_MAP::const_iterator INT_INT_DEQ_MAP_CI;
319 
320 typedef std::set<int> INT_SET;
321 typedef INT_SET::iterator INT_SET_I;
322 typedef INT_SET::const_iterator INT_SET_CI;
323 
324 //! functor to compare two doubles with a tolerance
326  public:
327  ltDouble(){};
328  bool operator()(double d1, double d2) const {
329  if (fabs(d1 - d2) < _tol) {
330  return false;
331  } else {
332  return (d1 < d2);
333  }
334  }
335 
336  private:
337  double _tol{1.0e-8};
338 };
339 
340 //! std::map from double to integer.
341 typedef std::map<double, int, ltDouble> DOUBLE_INT_MAP;
342 
343 //! functor for returning the larger of two values
344 template <typename T>
346  T operator()(T arg1, T arg2) { return arg1 > arg2 ? arg1 : arg2; };
347 };
348 
349 //! functor for comparing two strings
351  bool operator()(const char *s1, const char *s2) const {
352  // std::cout << s1 << " " << s2 << " " << strcmp(s1, s2) << "\n";
353 
354  return strcmp(s1, s2) < 0;
355  };
356 };
357 
358 //! \brief calculate the union of two INT_VECTs and put the results in a
359 //! third vector
360 RDKIT_RDGENERAL_EXPORT void Union(const INT_VECT &r1, const INT_VECT &r2,
361  INT_VECT &res);
362 
363 //! \brief calculate the intersection of two INT_VECTs and put the results in a
364 //! third vector
366  INT_VECT &res);
367 
368 //! calculating the union of the INT_VECT's in a VECT_INT_VECT
369 /*!
370  \param rings the INT_VECT's to consider
371  \param res used to return results
372  \param exclude any values in this optional INT_VECT will be excluded
373  from the union.
374 */
376  const INT_VECT *exclude = nullptr);
377 
378 //! given a current combination of numbers change it to the next possible
379 // combination
380 /*!
381  \param comb the <b>sorted</b> vector to consider
382  \param tot the maximum number possible in the vector
383 
384  \return -1 on failure, the index of the last number changed on success.
385  Example:
386  for all combinations 3 of numbers between 0 and tot=5
387  given (0,1,2) the function wil return (0,1,3) etc.
388 
389 
390 */
392 
393 }; // namespace RDKit
394 
395 #endif
Defines the Dict class.
#define RDKIT_RDGENERAL_EXPORT
Definition: export.h:567
RDKIT_RDGENERAL_EXPORT const std::string _ringStereoWarning
RDKIT_RDGENERAL_EXPORT const std::string _MolFileBondQuery
RDKIT_RDGENERAL_EXPORT const std::string smilesSymbol
RDKIT_RDGENERAL_EXPORT const std::string _TriposAtomType
RDKIT_RDGENERAL_EXPORT const std::string _RingClosures
RDKIT_RDGENERAL_EXPORT const std::string bondNote
RDKIT_RDGENERAL_EXPORT const std::string _QueryHCount
RDKIT_RDGENERAL_EXPORT const std::string _labuteASA
RDKIT_RDGENERAL_EXPORT const std::string _supplementalSmilesLabel
RDKIT_RDGENERAL_EXPORT const std::string molStereoCare
RDKIT_RDGENERAL_EXPORT const std::string MolFileComments
RDKIT_RDGENERAL_EXPORT const std::string molInversionFlag
RDKIT_RDGENERAL_EXPORT const std::string DistanceMatrix_Paths
RDKIT_RDGENERAL_EXPORT const std::string maxAttachIdx
RDKIT_RDGENERAL_EXPORT const std::string _3DConf
RDKIT_RDGENERAL_EXPORT const std::string _NeedsQueryScan
RDKIT_RDGENERAL_EXPORT const std::string atomNote
RDKIT_RDGENERAL_EXPORT const std::string reactionMapNum
RDKIT_RDGENERAL_EXPORT const std::string _ChiralityPossible
RDKIT_RDGENERAL_EXPORT const std::string isImplicit
RDKIT_RDGENERAL_EXPORT const std::string _2DConf
RDKIT_RDGENERAL_EXPORT const std::string dummyLabel
RDKIT_RDGENERAL_EXPORT const std::string _doIsoSmiles
RDKIT_RDGENERAL_EXPORT const std::string _QueryMass
RDKIT_RDGENERAL_EXPORT const std::string _QueryFormalCharge
RDKIT_RDGENERAL_EXPORT const std::string _labuteAtomHContrib
RDKIT_RDGENERAL_EXPORT const std::string _connectivityNVals
RDKIT_RDGENERAL_EXPORT const std::string BalanbanJ
RDKIT_RDGENERAL_EXPORT const std::string _unspecifiedOrder
RDKIT_RDGENERAL_EXPORT const std::string _ringStereoAtoms
RDKIT_RDGENERAL_EXPORT const std::string molRxnRole
RDKIT_RDGENERAL_EXPORT const std::string _SmilesStart
RDKIT_RDGENERAL_EXPORT const std::string _MolFileBondType
RDKIT_RDGENERAL_EXPORT const std::string molFileValue
RDKIT_RDGENERAL_EXPORT const std::string _fragSMARTS
RDKIT_RDGENERAL_EXPORT const std::string molTotValence
RDKIT_RDGENERAL_EXPORT const std::string _connectivityHKDeltas
RDKIT_RDGENERAL_EXPORT const std::string _crippenLogP
RDKIT_RDGENERAL_EXPORT const std::string _TraversalStartPoint
RDKIT_RDGENERAL_EXPORT const std::string _GasteigerCharge
RDKIT_RDGENERAL_EXPORT const std::string molAttachPoint
RDKIT_RDGENERAL_EXPORT const std::string molAtomClass
RDKIT_RDGENERAL_EXPORT const std::string _MolFileAtomQuery
RDKIT_RDGENERAL_EXPORT const std::string TWOD
RDKIT_RDGENERAL_EXPORT const std::string _protected
RDKIT_RDGENERAL_EXPORT const std::string _displayLabelW
RDKIT_RDGENERAL_EXPORT const std::string _TraversalRingClosureBond
RDKIT_RDGENERAL_EXPORT const std::string _Unfinished_SLN_
RDKIT_RDGENERAL_EXPORT const std::string _CrippenMR
RDKIT_RDGENERAL_EXPORT const std::string _brokenChirality
RDKIT_RDGENERAL_EXPORT const std::string ringMembership
RDKIT_RDGENERAL_EXPORT const std::string molFileLinkNodes
RDKIT_RDGENERAL_EXPORT const std::string _MolFileRLabel
RDKIT_RDGENERAL_EXPORT const std::string _MolFileBondAttach
RDKIT_RDGENERAL_EXPORT const std::string molRxnComponent
RDKIT_RDGENERAL_EXPORT const std::string MRV_SMA
RDKIT_RDGENERAL_EXPORT const std::string _MolFileBondEndPts
RDKIT_RDGENERAL_EXPORT const std::string _queryRootAtom
RDKIT_RDGENERAL_EXPORT const std::string numArom
RDKIT_RDGENERAL_EXPORT const std::string origNoImplicit
RDKIT_RDGENERAL_EXPORT const std::string _rgroupBonds
RDKIT_RDGENERAL_EXPORT const std::string MolFileInfo
RDKIT_RDGENERAL_EXPORT const std::string _crippenMR
RDKIT_RDGENERAL_EXPORT const std::string _GasteigerHCharge
RDKIT_RDGENERAL_EXPORT const std::string _UnknownStereo
RDKIT_RDGENERAL_EXPORT const std::string _TraversalBondIndexOrder
RDKIT_RDGENERAL_EXPORT const std::string _rgroupAtomMaps
RDKIT_RDGENERAL_EXPORT const std::string _CIPCode
RDKIT_RDGENERAL_EXPORT const std::string _BondsPotentialStereo
RDKIT_RDGENERAL_EXPORT const std::string _Name
RDKIT_RDGENERAL_EXPORT const std::string _QueryIsotope
RDKIT_RDGENERAL_EXPORT const std::string molAtomMapNumber
RDKIT_RDGENERAL_EXPORT const std::string _CIPRank
RDKIT_RDGENERAL_EXPORT const std::string _hasMassQuery
RDKIT_RDGENERAL_EXPORT const std::string _ReactionDegreeChanged
RDKIT_RDGENERAL_EXPORT const std::string molParity
RDKIT_RDGENERAL_EXPORT const std::string _CrippenLogP
RDKIT_RDGENERAL_EXPORT const std::string molRxnExactChange
RDKIT_RDGENERAL_EXPORT const std::string _displayLabel
RDKIT_RDGENERAL_EXPORT const std::string molAttachOrder
RDKIT_RDGENERAL_EXPORT const std::string molAtomSeqId
RDKIT_RDGENERAL_EXPORT const std::string BalabanJ
RDKIT_RDGENERAL_EXPORT const std::string extraRings
RDKIT_RDGENERAL_EXPORT const std::string atomLabel
RDKIT_RDGENERAL_EXPORT const std::string _isotopicHs
RDKIT_RDGENERAL_EXPORT const std::string _MMFFSanitized
RDKIT_RDGENERAL_EXPORT const std::string _labuteAtomContribs
RDKIT_RDGENERAL_EXPORT const std::string _tpsa
RDKIT_RDGENERAL_EXPORT const std::string _MolFileBondStereo
RDKIT_RDGENERAL_EXPORT const std::string molFileAlias
RDKIT_RDGENERAL_EXPORT const std::string _StereochemDone
RDKIT_RDGENERAL_EXPORT const std::string _ringStereochemCand
RDKIT_RDGENERAL_EXPORT const std::string _MolFileBondCfg
RDKIT_RDGENERAL_EXPORT const std::string _SLN_s
RDKIT_RDGENERAL_EXPORT const std::string molSubstCount
RDKIT_RDGENERAL_EXPORT const std::string _MolFileChiralFlag
RDKIT_RDGENERAL_EXPORT const std::string _crippenMRContribs
RDKIT_RDGENERAL_EXPORT const std::string reactantAtomIdx
RDKIT_RDGENERAL_EXPORT const std::string Discrims
RDKIT_RDGENERAL_EXPORT const std::string _smilesAtomOutputOrder
RDKIT_RDGENERAL_EXPORT const std::string _AtomID
RDKIT_RDGENERAL_EXPORT const std::string molReactStatus
RDKIT_RDGENERAL_EXPORT const std::string NullBond
RDKIT_RDGENERAL_EXPORT const std::string internalRgroupSmiles
RDKIT_RDGENERAL_EXPORT const std::string _starred
RDKIT_RDGENERAL_EXPORT const std::string _tpsaAtomContribs
RDKIT_RDGENERAL_EXPORT const std::string _crippenLogPContribs
RDKIT_RDGENERAL_EXPORT const std::string computedPropName
Std stuff.
Definition: Abbreviations.h:17
INT_MAP_INT::iterator INT_MAP_INT_I
Definition: types.h:310
VECT_DOUBLE_VECT::const_iterator VECT_DOUBLE_VECT_CI
Definition: types.h:301
std::list< int > INT_LIST
Definition: types.h:277
std::list< INT_VECT > LIST_INT_VECT
Definition: types.h:281
std::vector< std::string > STR_VECT
Definition: Dict.h:29
std::set< int > INT_SET
Definition: types.h:320
INT_VECT::const_iterator INT_VECT_CI
Definition: types.h:273
RDKIT_RDGENERAL_EXPORT void Intersect(const INT_VECT &r1, const INT_VECT &r2, INT_VECT &res)
calculate the intersection of two INT_VECTs and put the results in a third vector
INT_INT_DEQ_MAP::const_iterator INT_INT_DEQ_MAP_CI
Definition: types.h:318
std::vector< int > INT_VECT
Definition: types.h:271
unsigned char UCHAR
Definition: types.h:269
long long int LONGINT
Definition: types.h:250
INT_SET::const_iterator INT_SET_CI
Definition: types.h:322
RDKIT_RDGENERAL_EXPORT int nextCombination(INT_VECT &comb, int tot)
given a current combination of numbers change it to the next possible
std::vector< std::string >::iterator STR_VECT_I
Definition: types.h:293
INT_VECT::const_reverse_iterator INT_VECT_CRI
Definition: types.h:275
std::map< int, int > INT_MAP_INT
Definition: types.h:309
std::vector< INT_VECT > VECT_INT_VECT
Definition: types.h:285
std::deque< int > INT_DEQUE
Definition: types.h:313
std::map< std::string, UINT > STR_UINT_MAP
Definition: types.h:303
RDKIT_RDGENERAL_EXPORT const double EPS_DOUBLE
std::map< std::string, UINT >::const_iterator STR_UINT_MAP_CI
Definition: types.h:304
std::map< int, INT_VECT > INT_INT_VECT_MAP
Definition: types.h:306
std::map< int, INT_DEQUE > INT_INT_DEQ_MAP
Definition: types.h:317
std::vector< DOUBLE_VECT > VECT_DOUBLE_VECT
Definition: types.h:299
RDKIT_RDGENERAL_EXPORT const double MAX_LONGINT
INT_DEQUE::iterator INT_DEQUE_I
Definition: types.h:314
INT_LIST::const_iterator INT_LIST_CI
Definition: types.h:279
INT_DEQUE::const_iterator INT_DEQUE_CI
Definition: types.h:315
unsigned short USHORT
Definition: types.h:268
INT_INT_VECT_MAP::const_iterator INT_INT_VECT_MAP_CI
Definition: types.h:307
RDKIT_RDGENERAL_EXPORT const double MAX_INT
std::map< double, int, ltDouble > DOUBLE_INT_MAP
std::map from double to integer.
Definition: types.h:341
INT_VECT::reverse_iterator INT_VECT_RI
Definition: types.h:274
INT_SET::iterator INT_SET_I
Definition: types.h:321
std::vector< UINT >::const_iterator UINT_VECT_CI
Definition: types.h:289
INT_MAP_INT::const_iterator INT_MAP_INT_CI
Definition: types.h:311
VECT_DOUBLE_VECT::iterator VECT_DOUBLE_VECT_I
Definition: types.h:300
DOUBLE_VECT::const_iterator DOUBLE_VECT_CI
Definition: types.h:298
unsigned int UINT
Definition: types.h:267
RDKIT_RDGENERAL_EXPORT void Union(const INT_VECT &r1, const INT_VECT &r2, INT_VECT &res)
calculate the union of two INT_VECTs and put the results in a third vector
INT_LIST::iterator INT_LIST_I
Definition: types.h:278
std::vector< std::string >::const_iterator STR_VECT_CI
Definition: types.h:292
LIST_INT_VECT::const_iterator LIST_INT_VECT_CI
Definition: types.h:283
std::vector< double > DOUBLE_VECT
Definition: types.h:296
VECT_INT_VECT::iterator VECT_INT_VECT_I
Definition: types.h:286
DOUBLE_VECT::iterator DOUBLE_VECT_I
Definition: types.h:297
RDKIT_RDGENERAL_EXPORT const double SMALL_DOUBLE
RDKIT_RDGENERAL_EXPORT const double MAX_DOUBLE
VECT_INT_VECT::const_iterator VECT_INT_VECT_CI
Definition: types.h:287
LIST_INT_VECT::iterator LIST_INT_VECT_I
Definition: types.h:282
INT_VECT::iterator INT_VECT_I
Definition: types.h:272
std::vector< UINT > UINT_VECT
Definition: types.h:290
functor for comparing two strings
Definition: types.h:350
bool operator()(const char *s1, const char *s2) const
Definition: types.h:351
functor for returning the larger of two values
Definition: types.h:345
T operator()(T arg1, T arg2)
Definition: types.h:346
functor to compare two doubles with a tolerance
Definition: types.h:325
bool operator()(double d1, double d2) const
Definition: types.h:328