mirror of
https://github.com/rdkit/rdkit.git
synced 2026-06-04 21:54:27 +08:00
* - generateDepictionMatching2DStructure can be used with referencePattern smaller than reference to only use part of a scaffold - adds generateDepictionMatching2DStructure overload to pass a matchVect instead of doing a substructure match - adds allowRGroups parameter to enable using a scaffold bearing R groups as reference * changes in response to review * added comments * fixes failing doctest * - reverted change committed accidentally - fixed get_sss_json for the case where R groups are not included in the match - added tests for the return value of generate_aligned_coords * Documented the value returned by GenerateDepictionMatching2DStructure (Python) * changes in response to review * - changes in response to review - fixed sortMatchesByDegreeOfCoreSubstitution that was not working - added Python wrappers for sortMatchesByDegreeOfCoreSubstitution and getMostSubstitutedCoreMatch - added C++ and Pyhon unit tests for the above * added missing variable initialization Co-authored-by: Tosco, Paolo <paolo.tosco@novartis.com>
45 lines
1.8 KiB
C++
45 lines
1.8 KiB
C++
//
|
|
// Copyright (C) 2003-2019 Greg Landrum and 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.
|
|
//
|
|
#include <RDGeneral/export.h>
|
|
#ifndef RD_SUBSTRUCT_UTILS_H
|
|
#define RD_SUBSTRUCT_UTILS_H
|
|
|
|
#include "SubstructMatch.h"
|
|
|
|
namespace RDKit {
|
|
class ROMol;
|
|
class Atom;
|
|
class Bond;
|
|
|
|
RDKIT_SUBSTRUCTMATCH_EXPORT double toPrime(const MatchVectType& v);
|
|
RDKIT_SUBSTRUCTMATCH_EXPORT void removeDuplicates(std::vector<MatchVectType>& v,
|
|
unsigned int nAtoms);
|
|
RDKIT_SUBSTRUCTMATCH_EXPORT bool atomCompat(const Atom* a1, const Atom* a2,
|
|
const SubstructMatchParameters& ps);
|
|
RDKIT_SUBSTRUCTMATCH_EXPORT bool chiralAtomCompat(const Atom* a1,
|
|
const Atom* a2);
|
|
RDKIT_SUBSTRUCTMATCH_EXPORT bool bondCompat(const Bond* b1, const Bond* b2,
|
|
const SubstructMatchParameters& ps);
|
|
//! This postprocesses the passed substruct matches and returns
|
|
//! the match that has the largest number of non-hydrogen atoms
|
|
//! in correspondence of terminal dummy atoms
|
|
RDKIT_SUBSTRUCTMATCH_EXPORT const MatchVectType& getMostSubstitutedCoreMatch(
|
|
const ROMol& mol, const ROMol& core,
|
|
const std::vector<MatchVectType>& matches);
|
|
//! This returns a copy of the passed substruct matches sorted by decreasing
|
|
//! number of non-hydrogen atoms in correspondence of terminal dummy atoms
|
|
RDKIT_SUBSTRUCTMATCH_EXPORT std::vector<MatchVectType>
|
|
sortMatchesByDegreeOfCoreSubstitution(
|
|
const ROMol& mol, const ROMol& core,
|
|
const std::vector<MatchVectType>& matches);
|
|
} // namespace RDKit
|
|
|
|
#endif
|