123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183 |
- // -*- mode: c++; coding: utf-8 -*-
- /// @file ra-2.C
- /// @brief Checks for ra:: arrays, especially cell rank > 0 operations.
- // (c) Daniel Llorens - 2013, 2014
- // This library is free software; you can redistribute it and/or modify it under
- // the terms of the GNU Lesser General Public License as published by the Free
- // Software Foundation; either version 3 of the License, or (at your option) any
- // later version.
- #include <iostream>
- #include <iterator>
- #include <numeric>
- #include "ra/complex.H"
- #include "ra/test.H"
- #include "ra/big.H"
- #include "ra/operators.H"
- #include "ra/io.H"
- #include "test/old.H"
- using std::cout, std::endl, std::flush;
- using real = double;
- int main()
- {
- TestRecorder tr;
- tr.section("iterators on cell rank > 0");
- {
- ra::Unique<real, 2> a({4, 3}, ra::none);
- std::iota(a.begin(), a.end(), 1);
- {
- ra::cell_iterator<decltype(a), 1> i(a.dim, a.p);
- tr.test_eq(1, i.rank());
- ply_ravel(expr([](ra::View<real, 1> const & x) { cout << x << endl; }, i));
- }
- }
- #define ARGa iter<1>(a)
- #define ARGi ra::Small<int, 4> {1, 2, 3, 4}.iter()
- #define ARGd dump.iter()
- tr.section("ply on cell rank > 0");
- {
- ra::Unique<real, 2> a({4, 3}, ra::none);
- std::iota(a.begin(), a.end(), 1);
- real check[4] = {6, 15, 24, 33};
- tr.section("not driving");
- {
- auto f = [](int i, ra::View<real, 1> const & a, real & d)
- {
- cout << i << ": " << a << endl;
- d = a[0] + a[1] + a[2];
- };
- ra::Small<real, 4> dump;
- // plier(ra::expr(f, a.iter<0>(), ARGa, ARGd)); // how the hell does this work,
- #define TEST(plier) \
- dump = 0; \
- cout << "-> explicit iterator" << endl; \
- plier(ra::expr(f, ARGi, ARGa, ARGd)); \
- tr.test(std::equal(check, check+4, dump.begin())); \
- dump = 0; \
- cout << "-> iter<cell rank>()" << endl; \
- plier(ra::expr(f, ARGi, a.iter<1>(), ARGd)); \
- tr.test(std::equal(check, check+4, dump.begin())); \
- dump = 0; \
- cout << "-> iter<frame rank>()" << endl; \
- plier(ra::expr(f, ARGi, a.iter<-1>(), ARGd)); \
- tr.test(std::equal(check, check+4, dump.begin()));
- TEST(ply_index);
- TEST(ply_ravel);
- TEST(plyf_index);
- TEST(plyf);
- #undef TEST
- }
- // TODO Use explicit DRIVER arg to ra::expr; the fixed size ARGi should always drive.
- tr.section("driving");
- {
- auto f = [](ra::View<real, 1> const & a, int i, real & d)
- {
- cout << i << ": " << a << endl;
- d = a[0] + a[1] + a[2];
- };
- ra::Small<real, 4> dump;
- #define TEST(plier) \
- dump = 0; \
- plier(ra::expr(f, ARGa, ARGi, ARGd)); \
- tr.test(std::equal(check, check+4, dump.begin())); \
- dump = 0; \
- plier(ra::expr(f, a.iter<1>(), ARGi, ARGd)); \
- tr.test(std::equal(check, check+4, dump.begin())); \
- dump = 0; \
- plier(ra::expr(f, a.iter<-1>(), ARGi, ARGd)); \
- tr.test(std::equal(check, check+4, dump.begin()));
- TEST(ply_index);
- TEST(ply_ravel);
- TEST(plyf_index);
- TEST(plyf);
- #undef TEST
- }
- }
- // Higher level tests are in test/iterator-small.C (FIXME how about we square them).
- tr.section("ply on cell rank > 0, ref argument");
- {
- auto test_cell_rank_positive =
- [&](auto && a)
- {
- ra::Small<real, 4> dump { 1, 2, 3, 4 };
- real check[12] = {1, 2, 3, 2, 3, 4, 3, 4, 5, 4, 5, 6};
- tr.section("not driving");
- {
- auto f = [](int i, auto && a, real & d) { std::iota(a.begin(), a.end(), d); };
- std::fill(a.begin(), a.end(), 0);
- ply_index(ra::expr(f, ARGi, ARGa, ARGd));
- tr.test(std::equal(check, check+12, a.begin()));
- std::fill(a.begin(), a.end(), 0);
- ply_ravel(ra::expr(f, ARGi, ARGa, ARGd));
- tr.test(std::equal(check, check+12, a.begin()));
- }
- tr.section("driving");
- {
- auto f = [](auto && a, int i, real & d) { std::iota(a.begin(), a.end(), d); };
- std::fill(a.begin(), a.end(), 0);
- ply_index(ra::expr(f, ARGa, ARGi, ARGd));
- tr.test(std::equal(check, check+12, a.begin()));
- std::fill(a.begin(), a.end(), 0);
- ply_ravel(ra::expr(f, ARGa, ARGi, ARGd));
- tr.test(std::equal(check, check+12, a.begin()));
- }
- };
- test_cell_rank_positive(ra::Unique<real, 2>({4, 3}, ra::none));
- test_cell_rank_positive(ra::Small<real, 4, 3> {}); // FIXME maybe ra::none should also work for Small
- }
- tr.section("ply on cell rank = 0 using iter<-1>, ref argument");
- {
- ra::Small<real, 3> dump { 1, 2, 3 };
- ra::Unique<real, 1> a({3}, ra::none);
- real check[3] = {1, 2, 3};
- tr.section("driving");
- {
- auto f = [](real & a, real d) { a = d; };
- std::fill(a.begin(), a.end(), 0);
- ply_index(map(f, a.iter<-1>(), dump.iter<0>()));
- tr.test(std::equal(check, check+3, a.begin()));
- std::fill(a.begin(), a.end(), 0);
- ply_ravel(map(f, a.iter<-1>(), dump.iter<0>()));
- tr.test(std::equal(check, check+3, a.begin()));
- }
- }
- tr.section("FYI");
- {
- cout << "..." << sizeof(ra::View<real, 0>) << endl;
- cout << "..." << sizeof(ra::View<real, 1>) << endl;
- }
- tr.section("ply on cell rank > 0, dynamic rank");
- {
- ra::Big<int> ad({5, 2}, ra::_0 - ra::_1);
- ra::Big<int, 2> as({5, 2}, ra::_0 - ra::_1);
- ra::Big<int, 2> b({5, 2}, (ra::_0 - ra::_1)*2);
- tr.test_eq(1, as.iter<-1>().rank());
- auto cellr = as.iter<-1>().cellr; tr.test_eq(1, cellr);
- tr.test_eq(1, ad.iter<-1>().rank());
- tr.test_eq(ra::RANK_ANY, ad.iter<-1>().rank_s());
- auto e = ra::expr([](auto const & a, auto const & b) { cout << (b-2*a) << endl; },
- ad.iter<-1>(), b.iter<-1>());
- tr.test_eq(1, e.rank());
- tr.test_eq(0., map([](auto const & a, auto const & b) { return sum(abs(b-2*a)); },
- as.iter<-1>(), b.iter<-1>()));
- tr.test_eq(0., map([](auto const & a, auto const & b) { return sum(abs(b-2*a)); },
- ad.iter<-1>(), b.iter<-1>()));
- }
- tr.section("FIXME strange need for assert in ply_ravel with cell_iterator on VAR_RANK array [ra40], gcc 7.3 & 8.1.");
- {
- ra::Big<int> ad({5, 2}, ra::_0 - ra::_1);
- auto ii = iter<1>(ad);
- auto ee = map([&](auto && a) { tr.test_eq(1, a.rank()); }, ii);
- ply(ee);
- }
- return tr.summary();
- }
|