nested-0.C 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. // -*- mode: c++; coding: utf-8 -*-
  2. /// @file nested-0.C
  3. /// @brief Using nested arrays as if they were arrays if higher rank.
  4. // (c) Daniel Llorens - 2014
  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. // TODO Make more things work and work efficiently.
  10. #include <iostream>
  11. #include <sstream>
  12. #include <iterator>
  13. #include "ra/complex.H"
  14. #include "ra/test.H"
  15. #include "ra/big.H"
  16. #include "ra/operators.H"
  17. #include "ra/io.H"
  18. using std::cout, std::endl, std::flush, std::cerr;
  19. template <class T, int N> using Array = ra::Big<T, N>;
  20. template <class T> using Vec = Array<T, 1>;
  21. int main()
  22. {
  23. TestRecorder tr;
  24. tr.section("operators on nested arrays");
  25. {
  26. // default init is required to make vector-of-vector, but I still want Vec {} to mean 'an empty vector' and not a default-init vector.
  27. {
  28. auto c = Vec<int> {};
  29. tr.test_eq(0, c.size(0));
  30. tr.test_eq(0, c.size());
  31. }
  32. {
  33. auto c = Vec<Vec<int>> { {} , {1}, {1, 2} };
  34. std::ostringstream os;
  35. os << c;
  36. std::istringstream is(os.str());
  37. Vec<Vec<int>> d;
  38. is >> d;
  39. tr.test_eq(3, d.size());
  40. tr.test_eq(d[0], Vec<int>{});
  41. tr.test_eq(d[1], Vec<int>{1});
  42. tr.test_eq(d[2], Vec<int>{1, 2});
  43. // TODO Actually nested 'as if higher rank' should allow just (every(c==d)). This is explicit nesting.
  44. tr.test(every(ra::expr([](auto & c, auto & d) { return every(c==d); }, c.iter(), d.iter())));
  45. }
  46. }
  47. tr.section("selector experiments");
  48. {
  49. // These is an investigation of how to make a(ra::all, i) or a(i, ra::all) work.
  50. // The problem with a(ra::all, i) here is that we probably want to leave the iteration on ra::all for last. Otherwise the indexing is redone for each rank-1 cell.
  51. Vec<int> i = {0, 3, 1, 2};
  52. Array<double, 2> a({4, 4}, ra::_0-ra::_1);
  53. Array<double, 2> b = from([](auto && a, auto && i) -> decltype(auto) { return a(i); }, a.iter<1>(), start(i));
  54. tr.test_eq(a(0, i), b(0));
  55. tr.test_eq(a(1, i), b(1));
  56. tr.test_eq(a(2, i), b(2));
  57. tr.test_eq(a(3, i), b(3));
  58. // The problem with a(i) = a(i, ra::all) is that a(i) returns a nested expression, so it isn't equivalent to a(i, [0 1 ...]), and if we want to write it as a rank 2 expression, we can't use from() as above because the iterator we want is a(i).iter(), it depends on i.
  59. // So ...
  60. }
  61. tr.section("copying btw arrays nested in the same way");
  62. {
  63. Vec<ra::Small<int, 2> > a {{1, 2}, {3, 4}, {5, 6}};
  64. ra::Small<ra::Small<int, 2>, 3> b = a;
  65. tr.test_eq(ra::Small<int, 2> {1, 2}, b(0));
  66. tr.test_eq(ra::Small<int, 2> {3, 4}, b(1));
  67. tr.test_eq(ra::Small<int, 2> {5, 6}, b(2));
  68. b(0) = ra::Small<int, 2> {7, 9};
  69. b(1) = ra::Small<int, 2> {3, 4};
  70. b(2) = ra::Small<int, 2> {1, 6};
  71. a = b;
  72. tr.test_eq(ra::Small<int, 2> {7, 9}, a(0));
  73. tr.test_eq(ra::Small<int, 2> {3, 4}, a(1));
  74. tr.test_eq(ra::Small<int, 2> {1, 6}, a(2));
  75. }
  76. tr.section("TODO copying btw arrays nested in different ways");
  77. {
  78. Vec<ra::Small<int, 2> > a {{1, 2}, {3, 4}, {5, 6}};
  79. Array<int, 2> b({3, 2}, {1, 2, 3, 4, 5, 6});
  80. // there's one level of matching so a(0) matches to b(0, 0) and b(0, 1), a(1) to b(1, 0) and b(1, 1), etc. So this results in a(0) = 1 overwritten with a(0) = 2, etc. finally a = [[2, 2], [4, 4], [6, 6]]. Probably not what we want.
  81. a = b;
  82. // b = a; // dnc b/c [x, y] ← z is ok but z ← [x, y] is not.
  83. cout << a << endl;
  84. }
  85. return tr.summary();
  86. }