iterator-as-ravel.C 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. // -*- mode: c++; coding: utf-8 -*-
  2. /// @file iterator-as-ravel.C
  3. /// @brief Using ptr(begin()) work as a lazy ravel (WIP)
  4. // (c) Daniel Llorens - 2019
  5. // This library is free software; you can redistribute it and/or modify it under
  6. // the terms of the GNU Lesser General Public License as published by the Free
  7. // Software Foundation; either version 3 of the License, or (at your option) any
  8. // later version.
  9. #include <iostream>
  10. #include <iterator>
  11. #include "ra/small.H"
  12. #include "ra/operators.H"
  13. #include "ra/io.H"
  14. #include "ra/test.H"
  15. using std::cout, std::endl, std::flush;
  16. int main()
  17. {
  18. TestRecorder tr;
  19. // this is trivial since Big::begin() is a raw pointer.
  20. tr.section("not driving, order I");
  21. {
  22. ra::Big<int, 2> a = {{1, 2}, {3, 4}, {5, 6}};
  23. // same rank
  24. auto x = concrete(ra::ptr(a.begin()) * ra::Small<int, 5> { 1, 2, 3, 4, 5 });
  25. cout << x << endl;
  26. // rank extension
  27. auto y = concrete(ra::ptr(a.begin()) * ra::Small<int, 2, 3> { {1, 2, 3}, {4, 5, 6} });
  28. cout << y << endl;
  29. }
  30. // // the interesting part [FIXME We are missing advance() on stl-like iterators & also += [] secondarily].
  31. // tr.section("not driving, order II");
  32. // {
  33. // ra::Big<int, 2> a_ = {{1, 2}, {3, 4}, {5, 6}};
  34. // auto a = transpose<1, 0>(a_);
  35. // // same rank
  36. // cout << (ra::ptr(a.begin()) * ra::Small<int, 5> { 1, 2, 3, 4, 5 }) << endl;
  37. // }
  38. return tr.summary();
  39. }