// 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() { BOOST_LOG(rdErrorLog) << "----------------------------\nstart test autocorr2D\n"; std::string pathName = getenv("RDBASE"); std::string sdfName = pathName + "/Code/GraphMol/Descriptors/test_data/PBF_egfr.sdf"; // std::string sdfName ="PBF_egfr.sdf"; RDKit::SDMolSupplier reader(sdfName, true, false); std::string fName = pathName + "/Code/GraphMol/Descriptors/test_data/auto2D.out"; // std::string fName = "auto2D.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 res2d; RDKit::Descriptors::AUTOCORR2D(*m, res2d); std::vector myrow = data[nDone]; std::string inm = myrow[0]; TEST_ASSERT(inm == nm); for (int i = 0; i < 192; i++) { double ref = atof(myrow[i + 1].c_str()); if (fabs(ref - res2d[i]) > 0.05) { std::cout << "value mismatch: pos" << i << " " << inm << " " << ref << " " << res2d[i] << std::endl; } TEST_ASSERT(fabs(ref - res2d[i]) < 0.05); } res2d.clear(); res2d.resize(48); delete m; ++nDone; } BOOST_LOG(rdErrorLog) << " done" << std::endl; } int main() { RDLog::InitLogs(); testautocorrelation(); }