File: main_test.cpp

package info (click to toggle)
isospec 2.3.2-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 12,472 kB
  • sloc: cpp: 9,530; python: 2,095; makefile: 180; ansic: 100; sh: 88
file content (68 lines) | stat: -rw-r--r-- 2,324 bytes parent folder | download | duplicates (4)
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
62
63
64
65
66
67
68
#define ISOSPEC_TESTS_SKIP_MAIN true
#include "from_formula_layered.cpp"
#include "from_formula_ordered.cpp"
#include "from_formula_threshold.cpp"
#include "from_formula_threshold_simple.cpp"
#include "element_zero.cpp"
#include "unity-build.cpp"
#include "empty_iso.cpp"
#include <vector>

#if !defined(ISOSPEC_TESTS_MEMSAN)
#define TEST(formula, prob, function) \
std::cout << "Testing " << formula << " prob: " << prob << " function: " << #function << "..." << std::flush; \
tmp = function(formula, prob, false); \
std::cout << " " << tmp << " confs." << std::endl; \
total += tmp;
#else
#define TEST(formula, prob, function) \
tmp = function(formula, prob, false); \
total += tmp;
#endif

int main()
{
        bool zero_ok = false;
        try{
            test_zero(0.1, false);
        }
        catch(std::invalid_argument&)
        {
            zero_ok = true;
        }
        assert(zero_ok);
        test_empty_and_print();
        #if !defined(ISOSPEC_SKIP_SLOW_TESTS)
	char test_formulas[] = "P1 P2 H1 H2 O1 O2 H2O1 C0 P0 C10000P10 F10C10000P10 P10F10O100 C100O0P100 C100 P100 C1 H10C10O10N10S5 Se1 Se10 Sn1 Sn4 Sn4C1 C2H6O1 C1000 C1H1O2N2Se1Sn1P1 P1C1Sn1 Se5 Sn5 Se2Sn2C2O2N2S2B2He2U2Na2Cl2";
        #else
        char test_formulas[] = "P1 P2 H1 H2 O1 O2 H2O1 C0 P0 C10000P10 F10C10000P10 P10F10O100 C100O0P100 C100 P100 C1 H3C3O3N3S3 Se1 Se3 Sn1 Sn3C1 C2H6O1 C1000 C1H1O2N2Se1Sn1P1 P1C1Sn1 Se5";
        #endif
	size_t tf_len = strlen(test_formulas);
	std::vector<const char*> formulas;
	formulas.push_back(test_formulas);
	std::vector<float> probs = {0.0, 0.1, 0.5, 0.01, 0.9, 0.99, 0.01, 0.0001, 0.999, 0.362, 0.852348};

	for(size_t ii=0; ii<tf_len; ii++)
	{
		if(test_formulas[ii] == ' ')
		{
			test_formulas[ii] = '\0';
			formulas.push_back(&test_formulas[ii+1]);
		}
	}

	size_t total = 0;
	size_t tmp;
	for(auto it_formula = formulas.begin(); it_formula != formulas.end(); it_formula++)
		for(auto it_prob = probs.begin(); it_prob != probs.end(); it_prob++)
		{
			TEST(*it_formula, *it_prob, test_threshold_simple);
			TEST(*it_formula, *it_prob, test_threshold);
			TEST(*it_formula, *it_prob, test_layered_tabulator);
			TEST(*it_formula, *it_prob, test_ordered);
		}

        #if !defined(ISOSPEC_TESTS_MEMSAN)
	std::cout << "Total confs considered: " << total << std::endl;
        #endif
}