1 | #define BDMLIB // not an ideal way to prevent double registration of UI factories... |
---|
2 | #include "../bdm/stat/exp_family.h" |
---|
3 | #include "UnitTest++.h" |
---|
4 | |
---|
5 | using namespace bdm; |
---|
6 | |
---|
7 | TEST(test_datalink) { |
---|
8 | // RV names are global, and a, b and c are already taken by a |
---|
9 | // different test... |
---|
10 | RV a = RV("{dla }", "2"); |
---|
11 | RV b = RV("{dlb }"); |
---|
12 | RV c = RV("{dlc }"); |
---|
13 | |
---|
14 | RV ab = a; |
---|
15 | ab.add(b); |
---|
16 | |
---|
17 | RV abc = ab; |
---|
18 | abc.add(c); |
---|
19 | |
---|
20 | datalink dl(ab, abc); |
---|
21 | vec total("0 37 42 66"); |
---|
22 | vec filtered = dl.pushdown(total); |
---|
23 | int exp_f[] = { 0, 37, 42 }; |
---|
24 | int exp_sz = sizeof(exp_f) / sizeof(exp_f[0]); |
---|
25 | CHECK_EQUAL(exp_sz, filtered.size()); |
---|
26 | for (int i = 0; i < exp_sz; ++i) { |
---|
27 | CHECK_EQUAL(exp_f[i], filtered(i)); |
---|
28 | } |
---|
29 | } |
---|
30 | |
---|
31 | TEST(test_datalink_m2e) { |
---|
32 | RV a = RV("{dla }", "2"); |
---|
33 | RV b = RV("{dlb }"); |
---|
34 | RV c = RV("{dlc }"); |
---|
35 | |
---|
36 | RV ab = a; |
---|
37 | ab.add(b); |
---|
38 | |
---|
39 | RV ba = a; |
---|
40 | ba.add(b); |
---|
41 | |
---|
42 | RV abc = ab; |
---|
43 | abc.add(c); |
---|
44 | |
---|
45 | datalink_m2e dl; |
---|
46 | dl.set_connection(ba, c, abc); |
---|
47 | vec total("0 37 42 66"); |
---|
48 | vec cond = dl.get_cond(total); |
---|
49 | CHECK_EQUAL(1, cond.size()); |
---|
50 | CHECK_EQUAL(66, cond(0)); |
---|
51 | } |
---|
52 | |
---|
53 | TEST(test_datalink_m2m) { |
---|
54 | RV a = RV("{dla }", "2"); |
---|
55 | RV b = RV("{dlb }"); |
---|
56 | RV c = RV("{dlc }"); |
---|
57 | |
---|
58 | datalink_m2m dl; |
---|
59 | dl.set_connection(a, concat(b, c), concat(a, b), c); |
---|
60 | |
---|
61 | vec val("1 1.5 2"); |
---|
62 | vec cond("3"); |
---|
63 | |
---|
64 | vec p = dl.pushdown(val); |
---|
65 | double exp_p[] = { 1.0, 1.5 }; |
---|
66 | int exp_sz = sizeof(exp_p) / sizeof(exp_p[0]); |
---|
67 | CHECK_EQUAL(exp_sz, p.size()); |
---|
68 | for (int i = 0; i < exp_sz; ++i) { |
---|
69 | CHECK_EQUAL(exp_p[i], p(i)); |
---|
70 | } |
---|
71 | |
---|
72 | vec dlcond = dl.get_cond(val, cond); |
---|
73 | int exp_c[] = { 2, 3 }; |
---|
74 | exp_sz = sizeof(exp_c) / sizeof(exp_c[0]); |
---|
75 | CHECK_EQUAL(exp_sz, dlcond.size()); |
---|
76 | for (int i = 0; i < exp_sz; ++i) { |
---|
77 | CHECK_EQUAL(exp_c[i], dlcond(i)); |
---|
78 | } |
---|
79 | } |
---|