// Created by Guillaume GODIN // Copyright (C) 2012-2016 Greg Landrum // @@ 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 #include #include #include #include #include #include #include #include #include #include void testautocorrelation() { std::cout << "=>start test autocorr3D\n"; std::string pathName = getenv("RDBASE"); // std::cout << "Path: " << pathName << "\n"; std::string sdfName = pathName + "/Code/GraphMol/Descriptors/test_data/PBF_egfr.sdf"; RDKit::SDMolSupplier reader(sdfName, true, false); std::string fName = pathName + "/Code/GraphMol/Descriptors/test_data/auto3D_dragon.out"; std::ifstream instrm(fName.c_str()); std::string line; std::vector> data; while (std::getline(instrm, line)) { std::string phrase; std::vector row; std::stringstream ss(line); while (std::getline(ss, phrase, '\t')) { row.push_back(phrase); } data.push_back(row); } int nDone = 0; while (!reader.atEnd()) { RDKit::ROMol *m = reader.next(); TEST_ASSERT(m); std::string nm; m->getProp("_Name", nm); std::vector da3d; RDKit::Descriptors::AUTOCORR3D(*m, da3d, -1); std::vector myrow = data[nDone]; std::string inm = myrow[0]; TEST_ASSERT(inm == nm); for (int i = 0; i < 80; i++) { double ref = atof(myrow[i + 1].c_str()); if (fabs(ref - da3d[i]) > 0.0015) { std::cout << "value mismatch: pos" << i << " " << inm << " " << ref << " " << da3d[i] << std::endl; } TEST_ASSERT(fabs(ref - da3d[i]) < 0.0015); } delete m; ++nDone; } BOOST_LOG(rdErrorLog) << "test on : " << nDone << " molecules done" << std::endl; } int main() { RDLog::InitLogs(); testautocorrelation(); }