Changeset 424 for library

Show
Ignore:
Timestamp:
07/22/09 10:07:52 (16 years ago)
Author:
vbarta
Message:

moved datalink tests to testsuite, added default initialization to datalink classes

Location:
library
Files:
3 modified

Legend:

Unmodified
Added
Removed
  • library/bdm/base/bdmbase.h

    r422 r424  
    461461  //! Remember how long val should be 
    462462  int downsize; 
     463 
    463464  //! Remember how long val of "Up" should be 
    464465  int upsize; 
    465   //! val-to-val link, indeces of the upper val 
     466 
     467  //! val-to-val link, indices of the upper val 
    466468  ivec v2v_up; 
     469 
    467470public: 
    468471  //! Constructor 
    469   datalink() {}; 
    470   datalink(const RV &rv, const RV &rv_up) {set_connection(rv, rv_up);}; 
     472  datalink():downsize(0), upsize(0) { } 
     473  datalink(const RV &rv, const RV &rv_up) { set_connection(rv, rv_up); } 
     474 
    471475  //! set connection, rv must be fully present in rv_up 
    472476  void set_connection(const RV &rv, const RV &rv_up) { 
    473477    downsize = rv._dsize(); 
    474478    upsize = rv_up._dsize(); 
    475     v2v_up = (rv.dataind(rv_up)); 
     479    v2v_up = rv.dataind(rv_up); 
    476480 
    477481    it_assert_debug(v2v_up.length() == downsize, "rv is not fully in rv_up"); 
    478482  } 
    479   //! set connection using indeces 
     483 
     484  //! set connection using indices 
    480485  void set_connection(int ds, int us, const ivec &upind) { 
    481486    downsize = ds; 
     
    485490    it_assert_debug(v2v_up.length() == downsize, "rv is not fully in rv_up"); 
    486491  } 
     492 
    487493  //! Get val for myself from val of "Up" 
    488494  vec pushdown(const vec &val_up) { 
     
    490496    return get_vec(val_up, v2v_up); 
    491497  } 
     498 
    492499  //! Fill val of "Up" by my pieces 
    493500  void pushup(vec &val_up, const vec &val) { 
     
    498505}; 
    499506 
    500 //! data link between 
     507//! Data link with a condition. 
    501508class datalink_m2e: public datalink 
    502509{ 
     
    504511  //! Remember how long cond should be 
    505512  int condsize; 
    506   //!upper_val-to-local_cond link, indeces of the upper val 
     513 
     514  //!upper_val-to-local_cond link, indices of the upper val 
    507515  ivec v2c_up; 
    508   //!upper_val-to-local_cond link, ideces of the local cond 
     516 
     517  //!upper_val-to-local_cond link, indices of the local cond 
    509518  ivec v2c_lo; 
    510519 
    511520public: 
    512   datalink_m2e() {}; 
    513521  //! Constructor 
    514   void set_connection(const RV &rv,  const RV &rvc, const RV &rv_up) { 
     522  datalink_m2e():condsize(0) { } 
     523 
     524  void set_connection(const RV &rv, const RV &rvc, const RV &rv_up) { 
    515525    datalink::set_connection(rv, rv_up); 
    516     condsize =  rvc._dsize(); 
     526    condsize = rvc._dsize(); 
    517527    //establish v2c connection 
    518528    rvc.dataind(rv_up, v2c_lo, v2c_up); 
    519529  } 
     530 
    520531  //!Construct condition 
    521532  vec get_cond(const vec &val_up) { 
     
    524535    return tmp; 
    525536  } 
     537 
    526538  void pushup_cond(vec &val_up, const vec &val, const vec &cond) { 
    527539    it_assert_debug(downsize == val.length(), "Wrong val"); 
     
    531543  } 
    532544}; 
     545 
    533546//!DataLink is a connection between mpdf and its superordinate (Up) 
    534547//! This class links 
     
    536549{ 
    537550protected: 
    538   //!cond-to-cond link, indeces of the upper cond 
     551  //!cond-to-cond link, indices of the upper cond 
    539552  ivec c2c_up; 
    540   //!cond-to-cond link, indeces of the local cond 
     553  //!cond-to-cond link, indices of the local cond 
    541554  ivec c2c_lo; 
     555 
    542556public: 
    543557  //! Constructor 
     
    549563    it_assert_debug(c2c_lo.length() + v2c_lo.length() == condsize, "cond is not fully given"); 
    550564  } 
     565 
    551566  //! Get cond for myself from val and cond of "Up" 
    552567  vec get_cond(const vec &val_up, const vec &cond_up) { 
  • library/tests/CMakeLists.txt

    r422 r424  
    1111 
    1212# BASIC EXECS 
    13 EXEC(datalink_test) 
    1413EXEC(loggers_test) 
    1514 
     
    4140 
    4241# using UnitTest++ 
    43 add_executable(testsuite rv_test.cpp testsuite.cpp test_user_info.cpp test_shared_ptr.cpp) 
     42add_executable(testsuite datalink_test.cpp rv_test.cpp testsuite.cpp test_user_info.cpp test_shared_ptr.cpp) 
    4443target_link_libraries(testsuite bdm itpp unittest) 
    4544 
  • library/tests/datalink_test.cpp

    r386 r424  
     1#define BDMLIB // not an ideal way to prevent double registration of UI factories... 
    12#include "../bdm/stat/exp_family.h" 
     3#include "UnitTest++.h" 
     4 
    25using namespace bdm; 
    36 
    4 int main() { 
    5         RV a = RV ( "{a }","2" ); 
    6         RV b = RV ( "{b }" ); 
    7         RV c = RV ( "{c }" ); 
     7TEST(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 }"); 
    813 
    9         datalink_m2m dl;dl.set_connection ( a,concat(b,c),concat(a,b), c ); 
     14    RV ab = a; 
     15    ab.add(b); 
    1016 
    11         vec val ( "1 1.5 2" ); 
    12         vec cond ( "3" ); 
     17    RV abc = ab; 
     18    abc.add(c); 
    1319 
    14         cout << "val: " << val  << endl; 
    15         cout << "cond: " << cond  << endl; 
     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} 
    1630 
    17         cout << "lo val: " << dl.pushdown ( val ) <<endl; 
    18         cout << "lo cond: " << dl.get_cond ( val,cond ) <<endl; 
     31TEST(test_datalink_m2e) { 
     32    RV a = RV("{dla }", "2"); 
     33    RV b = RV("{dlb }"); 
     34    RV c = RV("{dlc }"); 
    1935 
    20         //getchar(); 
    21         return 0; 
     36    RV ab = a; 
     37    ab.add(b); 
    2238 
     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)); 
    2351} 
     52 
     53TEST(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}