mirror of
https://github.com/rdkit/rdkit.git
synced 2026-06-03 21:44:30 +08:00
* Add many new c++ catch2 performance benchmarks. * inline splitmix64 from boost, splitmix64 is not always available in boost. fun fact, this version is ~twice as fast * reduce intensity of memory pressure test, target 200MB usage. * new bench compound; accept suggestion from code review * bench MolToCXSmiles * Update Code/Bench/stereo.cpp * impl first part of the suggestions from code reveiw * impl second part of the suggestions from code reveiw
47 lines
1.1 KiB
C++
47 lines
1.1 KiB
C++
#include <catch2/catch_all.hpp>
|
|
#include <string>
|
|
|
|
#include "bench_common.hpp"
|
|
|
|
#include <GraphMol/ROMol.h>
|
|
#include <GraphMol/SmilesParse/SmilesParse.h>
|
|
#include <GraphMol/SmilesParse/SmilesWrite.h>
|
|
|
|
using namespace RDKit;
|
|
|
|
TEST_CASE("SmilesToMol", "[smiles]") {
|
|
BENCHMARK("SmilesToMol") {
|
|
auto total_atoms = 0;
|
|
for (auto smiles : bench_common::SAMPLES) {
|
|
auto mol = v2::SmilesParse::MolFromSmiles(smiles);
|
|
REQUIRE(mol);
|
|
total_atoms += mol->getNumAtoms();
|
|
}
|
|
return total_atoms;
|
|
};
|
|
}
|
|
|
|
TEST_CASE("MolToSmiles", "[smiles]") {
|
|
auto samples = bench_common::load_samples();
|
|
BENCHMARK("MolToSmiles") {
|
|
auto total_length = 0;
|
|
for (auto &mol : samples) {
|
|
auto smiles = MolToSmiles(mol);
|
|
total_length += smiles.size();
|
|
}
|
|
return total_length;
|
|
};
|
|
}
|
|
|
|
TEST_CASE("MolToCXSmiles", "[smiles]") {
|
|
auto samples = bench_common::load_samples();
|
|
BENCHMARK("MolToCXSmiles") {
|
|
auto total_length = 0;
|
|
for (auto &mol : samples) {
|
|
auto smiles = MolToCXSmiles(mol);
|
|
total_length += smiles.size();
|
|
}
|
|
return total_length;
|
|
};
|
|
}
|