123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- #include <iostream>
- #include <iterator>
- #include "ra/test.hh"
- using std::cout, std::endl, std::flush, ra::TestRecorder;
- template <class T, ra::rank_t RANK=ra::ANY> using BigValueInit = ra::Container<std::vector<T>, RANK>;
- using int2 = ra::Small<int, 2>;
- int main()
- {
- TestRecorder tr;
- tr.section("push_back");
- {
- std::vector<int2> a;
- a.push_back({1, 2});
- ra::Big<int2, 1> b;
- b.push_back({1, 2});
- int2 check[1] = {{1, 2}};
- tr.test_eq(check, ra::start(a));
- tr.test_eq(check, b);
- tr.test_eq(check[0], b.back());
- tr.test_eq(int2 {1, 2}, b().back());
- }
- tr.section(".back() is last element not last item");
- {
- ra::Big<int2, 0> b({}, ra::scalar(int2 {1, 3}));
- tr.test_eq(int2 {1, 3}, b.back());
- }
- tr.section("behavior of resize with default Container");
- {
- {
- ra::Big<int, 1> a = {1, 2, 3, 4, 5, 6};
- a.resize(3);
- a.resize(6);
- tr.test_eq(ra::iota(6, 1), a);
- }
- {
- BigValueInit<int, 1> a = {1, 2, 3, 4, 5, 6};
- a.resize(3);
- a.resize(6);
- tr.test_eq(ra::start({1, 2, 3, 0, 0, 0}), a);
- }
- }
- tr.section("resize works on first dimension");
- {
- {
- ra::Big<int, 2> a({3, 2}, {1, 2, 3, 4, 5, 6});
- a.resize(2);
- tr.test_eq(1+ra::_1 + 2*ra::_0, a);
- }
- {
- ra::Big<int, 2> a({3, 2}, {1, 2, 3, 4, 5, 6});
- resize(a, 2);
- tr.test_eq(1+ra::_1 + 2*ra::_0, a);
- }
- }
- tr.section("operator=");
- {
- ra::Big<int, 2> a = {{0, 1, 2}, {3, 4, 5}};
- a = {{4, 5, 6}, {7, 8, 9}};
- tr.test_eq(ra::iota(6, 4), ra::ptr(a.data()));
- a = {{{4, 5, 6}, {7, 8, 9}}};
- tr.test_eq(ra::iota(6, 4), ra::ptr(a.data()));
-
-
- }
- tr.section("behavior of forced Fortran array");
- {
- ra::Big<int, 2> a ({2, 3}, {0, 1, 2, 3, 4, 5});
- ra::Big<int, 2> b ({2, 3}, {0, 1, 2, 3, 4, 5});
- auto c = transpose({1, 0}, ra::ViewBig<int, 2>({3, 2}, a.data()));
- a.dimv = c.dimv;
- for (int k=0; k!=c.rank(); ++k) {
- std::cout << "CSTRIDE " << k << " " << c.step(k) << std::endl;
- std::cout << "CLEN " << k << " " << c.len(k) << std::endl;
- }
- cout << endl;
- for (int k=0; k!=a.rank(); ++k) {
- std::cout << "ASTRIDE " << k << " " << a.step(k) << std::endl;
- std::cout << "ALEN " << k << " " << a.len(k) << std::endl;
- }
- cout << endl;
- c = b;
- a = b;
- for (int k=0; k!=c.rank(); ++k) {
- std::cout << "CSTRIDE " << k << " " << c.step(k) << std::endl;
- std::cout << "CLEN " << k << " " << c.len(k) << std::endl;
- }
- cout << endl;
- for (int k=0; k!=a.rank(); ++k) {
- std::cout << "ASTRIDE " << k << " " << a.step(k) << std::endl;
- std::cout << "ALEN " << k << " " << a.len(k) << std::endl;
- }
- cout << endl;
- std::cout << "a: " << a << std::endl;
- std::cout << "b: " << b << std::endl;
- std::cout << "c: " << c << std::endl;
- }
- tr.section("using shape as expr");
- {
- ra::Unique<double, 3> v({3, 2, 4}, ra::_0 + 15*ra::_1);
- tr.test_eq(ra::start({3, 2}), ra::shape(v, ra::iota(2)));
- tr.test_eq(ra::start({3, 2}), ra::shape(v, ra::iota(ra::len-1)));
- tr.test_eq(ra::start({2, 4}), ra::shape(v, ra::iota(2, 1)));
- tr.test_eq(ra::start({2, 4}), ra::shape(v, ra::iota(2, ra::len-2)));
- ra::Small<int, 4> i = {0, 2, 1, 0};
- tr.test_eq(ra::start({3, 4}), ra::shape(v, i(ra::iota(ra::len-2))));
- }
- tr.section("casts from fixed rank View");
- {
- ra::Unique<double, 3> a({3, 2, 4}, ra::_0 + 15*ra::_1);
- ra::ViewBig<double> b(a);
- tr.test_eq(ra::scalar(a.data()), ra::scalar(b.data()));
- tr.test_eq(a.rank(), b.rank());
- tr.test_eq(a.len(0), b.len(0));
- tr.test_eq(a.len(1), b.len(1));
- tr.test_eq(a.len(2), b.len(2));
- tr.test(every(a==b));
- auto test = [&tr](ra::ViewBig<double, 3> a, double * p)
- {
- tr.test_eq(ra::Small<int, 3> {3, 2, 4}, shape(a));
- tr.test(p==a.data());
- };
- auto test_const = [&tr](ra::ViewBig<double const, 3> a, double * p)
- {
- tr.test_eq(ra::Small<int, 3> {3, 2, 4}, shape(a));
- tr.test(p==a.data());
- };
- auto test_const_ref = [&tr](ra::ViewBig<double const, 3> const & a, double * p)
- {
- tr.test_eq(ra::Small<int, 3> {3, 2, 4}, shape(a));
- tr.test(p==a.data());
- };
- test(b, b.data());
- test_const(b, b.data());
- test_const_ref(a(), a.data());
- }
- tr.section("casts from var rank View");
- {
- ra::Unique<double> a({3, 2, 4}, ra::none);
- ra::ViewBig<double, 3> b(a);
- tr.test_eq(ra::scalar(a.data()), ra::scalar(b.data()));
- tr.test_eq(a.rank(), b.rank());
- tr.test_eq(a.len(0), b.len(0));
- tr.test_eq(a.len(1), b.len(1));
- tr.test_eq(a.len(2), b.len(2));
- tr.test(every(a==b));
- auto test = [&tr](ra::ViewBig<double> a, double * p)
- {
- tr.test_eq(ra::Small<int, 3> {3, 2, 4}, shape(a));
- tr.test(p==a.data());
- };
- auto test_const = [&tr](ra::ViewBig<double const> a, double * p)
- {
- tr.test_eq(ra::Small<int, 3> {3, 2, 4}, shape(a));
- tr.test(p==a.data());
- };
- auto test_const_ref = [&tr](ra::ViewBig<double const> const & a, double * p)
- {
- tr.test_eq(ra::Small<int, 3> {3, 2, 4}, shape(a));
- tr.test(p==a.data());
- };
- test(b, b.data());
- test_const(b, b.data());
- test_const_ref(a, a.data());
- }
- tr.section("multidimensional []");
- {
- ra::Unique<int> a({3, 2, 4}, ra::_0 + ra::_1 - ra::_2);
- tr.test_eq(a(ra::all, 0), a[ra::all, 0]);
- }
- return tr.summary();
- }
|