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
|
// $Id$
//
// Copyright (C) 2006 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.
//
#define NO_IMPORT_ARRAY
#include <RDBoost/python.h>
#include <boost/dynamic_bitset.hpp>
#include <GraphMol/RDKitBase.h>
#include <RDGeneral/types.h>
#include <GraphMol/MolChemicalFeatures/MolChemicalFeature.h>
#include <GraphMol/MolChemicalFeatures/MolChemicalFeatureFactory.h>
#include <ChemicalFeatures/FreeChemicalFeature.h>
namespace python = boost::python;
namespace RDKit {
python::object GetAtomMatch(python::object featMatch, int maxAts = 1024) {
python::list res;
unsigned int nEntries =
python::extract<unsigned int>(featMatch.attr("__len__")());
boost::dynamic_bitset<> indices(maxAts);
for (unsigned int i = 0; i < nEntries; ++i) {
MolChemicalFeature *feat =
python::extract<MolChemicalFeature *>(featMatch[i]);
const MolChemicalFeature::AtomPtrContainer &atoms = feat->getAtoms();
MolChemicalFeature::AtomPtrContainer_CI aci;
python::list local;
for (aci = atoms.begin(); aci != atoms.end(); ++aci) {
unsigned int idx = (*aci)->getIdx();
if (indices[idx]) {
return python::list();
} else {
indices[idx] = 1;
}
local.append(idx);
}
res.append(local);
}
return res;
}
struct ChemicalFeatureUtils_wrapper {
static void wrap() {
python::def(
"GetAtomMatch", GetAtomMatch,
(python::arg("featMatch"), python::arg("maxAts") = 1024),
"Returns an empty list if any of the features passed in share an atom.\n\
Otherwise a list of lists of atom indices is returned.\n");
}
};
} // end of namespace RDKit
void wrap_ChemicalFeatureUtils() {
RDKit::ChemicalFeatureUtils_wrapper::wrap();
}
|