8#include <gtest/gtest.h>
10#include "arcane/utils/NumArray.h"
12#include "arcane/utils/Real2.h"
13#include "arcane/utils/Real3.h"
14#include "arcane/utils/Real2x2.h"
15#include "arcane/utils/Real3x3.h"
17#include "arcane/utils/NumArrayUtils.h"
33 std::cout <<
"TEST_NUMARRAY Empty\n";
44 std::cout <<
"TEST_NUMARRAY Basic\n";
48 ASSERT_EQ(array1(1), 5.0);
49 std::cout <<
" V=" << array1(1) <<
"\n";
51 ASSERT_EQ(array1[2], 3.0);
52 std::cout <<
" V=" << array1(1) <<
"\n";
54 ASSERT_EQ(array1.totalNbElement(), 7);
58 std::cout <<
" V=" << array2(1, 2) <<
"\n";
60 ASSERT_EQ(array2.totalNbElement(), (7 * 5));
63 array3(1, 2, 3) = 5.0;
64 std::cout <<
" V=" << array3(1, 2, 3) <<
"\n";
65 ASSERT_EQ(array3(1, 2, 3), 5.0);
66 array3.resize(12, 4, 6);
67 ASSERT_EQ(array3.totalNbElement(), (12 * 4 * 6));
69 array3(1, 2, 3) = 4.0;
70 array3(2, 3, 5) = 1.0;
74 ASSERT_EQ(array3.extent0(), span_array3.extent0());
77 ASSERT_EQ(const_span_array3.to1DSpan(), span_array3.to1DSpan());
79 ASSERT_EQ(array3.extent0(), span_array3.extent0());
80 std::cout <<
"Array3: extents=" << array3.extent0()
81 <<
"," << array3.extent1() <<
"," << array3.extent2() <<
"\n";
82 for (Int32 i = 0; i < array3.extent0(); ++i) {
84 ASSERT_EQ(span_array2.
extent0(), span_array3.extent1());
85 ASSERT_EQ(span_array2.
extent1(), span_array3.extent2());
86 std::cout <<
" MDDim2 slice i=" << i <<
" X=" << span_array2.
extent0() <<
" Y=" << span_array2.
extent1() <<
"\n";
87 for (Int32 x = 0, xn = span_array2.
extent0(); x < xn; ++x) {
88 for (Int32 y = 0, yn = span_array2.
extent1(); y < yn; ++y) {
89 ASSERT_EQ(span_array2.
ptrAt(x, y), span_array3.ptrAt(i, x, y));
96 std::cout <<
"Array2: extents=" << array2.extent0() <<
"," << array2.extent1() <<
"\n";
97 for (Int32 i = 0; i < array2.extent0(); ++i) {
100 std::cout <<
" MDDim1 slice i=" << i <<
" X=" << span_array2.
extent0() <<
"\n";
101 for (Int32 x = 0, xn = span_array1.
extent0(); x < xn; ++x) {
102 ASSERT_EQ(span_array1.
ptrAt(x), span_array2.
ptrAt(i, x));
107 array4(1, 2, 3, 4) = 5.0;
108 std::cout <<
" V=" << array4(1, 2, 3, 4) <<
"\n";
109 array4.resize(8, 3, 7, 5);
110 ASSERT_EQ(array4.totalNbElement(), (8 * 3 * 7 * 5));
113 ASSERT_EQ(num_data1[0], 2.4);
114 ASSERT_EQ(num_data1[1], 5.6);
115 ASSERT_EQ(num_data1[2], 3.3);
116 ASSERT_EQ(num_data1[3], 5.4);
119 ASSERT_EQ(num_data2(0, 0), 1.4);
120 ASSERT_EQ(num_data2(0, 1), 15.6);
121 ASSERT_EQ(num_data2(1, 0), 33.3);
122 ASSERT_EQ(num_data2(1, 1), 7.4);
123 ASSERT_EQ(num_data2(2, 0), 4.2);
124 ASSERT_EQ(num_data2(2, 1), 6.5);
132 std::cout <<
"TEST_NUMARRAY Basic2\n";
137 std::cout <<
" V=" << array1(1) <<
"\n";
142 std::cout <<
" V=" << array2(1,2) <<
"\n";
145 array3.resize(2,3,4);
147 std::cout <<
" V=" << array3(1,2,3) <<
"\n";
150 array4.resize(2,3,4,5);
151 array4(1,2,3,4) = 5.0;
152 std::cout <<
" V=" << array4(1,2,3,4) <<
"\n";
160 std::cout <<
"TEST_NUMARRAY Extents\n";
167 ASSERT_EQ(1, MDDim1::nb_dynamic);
168 ASSERT_EQ(2, MDDim2::nb_dynamic);
169 ASSERT_EQ(3, MDDim3::nb_dynamic);
171 ASSERT_EQ(4, MDDim4::nb_dynamic);
195 constexpr int nb_x = 3;
196 constexpr int nb_y = 4;
197 constexpr int nb_z = 5;
202 auto v_extents = v.extentsWithOffset();
204 for( Int32 x=0, xn=v.dim1Size(); x<xn; ++x ){
205 for( Int32 y=0, yn=v.dim2Size(); y<yn; ++y ){
206 for( Int32 z=0, zn=v.dim3Size(); z<zn; ++z ){
207 ArrayIndex<3> idx{x,y,z};
208 Int64 offset = v_extents.offset(idx);
216 std::cout <<
"CAPACITY V1=" << v.capacity() <<
"\n";
218 std::cout <<
"CAPACITY V2=" << v.capacity() <<
"\n";
220 std::cout <<
"CAPACITY V3=" << v.capacity() <<
"\n";
222 std::cout <<
"CAPACITY V4=" << v.capacity() <<
"\n";
226#if NUMARRAY_HAS_VALID_RESIZE
230 std::vector<Int64> valid_values =
232 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11,
233 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
234 24 , 25, 26, 27, 28, 29, 20 , 21, 22, 23, 24, 25
236 ASSERT_EQ(valid_values.size(),(
size_t)36);
238 v_extents = v.extentsWithOffset();
240 for( Int64 x=0, xn=v.dim1Size(); x<xn; ++x ){
241 for( Int64 y=0, yn=v.dim2Size(); y<yn; ++y ){
242 for( Int64 z=0, zn=v.dim3Size(); z<zn; ++z ){
243 ArrayBoundsIndex<3> idx{x,y,z};
244 Int64 offset = v_extents.offset(idx);
245 Int64 val1 = v(x,y,z);
246 Int64 val2 = v({x,y,z});
247 std::cout <<
"XYZ=" << x <<
" " << y <<
" " << z
248 <<
" V=" << val1 <<
" offset=" << offset <<
"\n";
249 ASSERT_EQ(index,offset);
250 ASSERT_EQ(val1,val2);
251 ASSERT_EQ(valid_values.at(offset),val1);
266 std::cout <<
"IN_CREATE_1\n";
268 std::cout <<
"IN_CREATE_2\n";
269 for(Int32 i=0; i<size; ++i )
290 ASSERT_EQ(vi1.to1DSpan(), vi0.to1DSpan());
291 ASSERT_EQ(vi2.
to1DSpan(), vi1.to1DSpan());
293 ASSERT_EQ(vi3.to1DSpan(), vi0.to1DSpan());
297 ASSERT_EQ(vi0.to1DSpan(), vi0_span);
298 ASSERT_EQ(vi1_span, vi1.to1DSpan());
299 ASSERT_EQ(vi1.to1DSmallSpan(), vi0.to1DSmallSpan());
300 ASSERT_EQ(vi1.to1DConstSmallSpan(), vi0.to1DConstSmallSpan());
303 ASSERT_EQ(vi1_ref_span, vi1.to1DSpan());
311 ASSERT_EQ(vi1.to1DSpan(), vi0.to1DSpan());
312 ASSERT_EQ(vi2.
to1DSpan(), vi1.to1DSpan());
320 std::cout <<
"PART_1\n";
323 Int32 wanted_size1 = 23;
324 test_move = _createNumArray(wanted_size1);
325 std::cout <<
"PART_2\n";
326 ASSERT_EQ(test_move.totalNbElement(),wanted_size1) <<
"Bad size (test move 1)";
327 ASSERT_EQ(test_move[6],wanted_size1+8) <<
"Bad size (test move 2)";
328 Int32 wanted_size2 = 17;
329 test_move = _createNumArray(wanted_size2);
330 std::cout <<
"PART_3\n";
331 ASSERT_EQ(test_move.totalNbElement(),wanted_size2) <<
"Bad size (test move 3)";
332 ASSERT_EQ(test_move[3],wanted_size2+5) <<
"Bad size (test move 4)";
336 Int32 wanted_size1 = 31;
337 std::cout <<
"PART_4\n";
339 std::cout <<
"PART_5\n";
340 ASSERT_EQ(test_move.totalNbElement(),wanted_size1) <<
"Bad size (test move 1)";
341 ASSERT_EQ(test_move[7],wanted_size1+9) <<
"Bad size (test move 2)";
350 ArrayIndex<3> index(1,4,2);
351 auto [i, j, k] = index();
361void _setNumArray2Values(T& a)
363 for( Int32 i=0; i<a.dim1Size(); ++i ){
364 for( Int32 j=0; j<a.dim2Size(); ++j ){
365 a(i,j) = (i*253) + j;
370void _setNumArray3Values(T& a)
372 for( Int32 i=0; i<a.dim1Size(); ++i ){
373 for( Int32 j=0; j<a.dim2Size(); ++j ){
374 for( Int32 k=0; k<a.dim3Size(); ++k ){
375 a(i,j,k) = (i*253) + (j*27) + k;
385TEST(NumArray2,Layout)
387 std::cout <<
"TEST_NUMARRAY2 Layout\n";
391 ASSERT_EQ(a.totalNbElement(),(3*5));
392 _setNumArray2Values(a);
393 auto values = a.to1DSpan();
394 std::cout <<
"V=" << values <<
"\n";
395 UniqueArray<Real> ref_value = { 0, 1, 2, 3, 4, 253, 254, 255, 256, 257, 506, 507, 508, 509, 510 };
396 ASSERT_EQ(values.smallView(),ref_value.
view());
401 ASSERT_EQ(a.totalNbElement(),(3*5));
402 _setNumArray2Values(a);
403 auto values = a.to1DSpan();
404 std::cout <<
"V=" << values <<
"\n";
405 UniqueArray<Real> ref_value = { 0, 253, 506, 1, 254, 507, 2, 255, 508, 3, 256, 509, 4, 257, 510 };
406 ASSERT_EQ(values.smallView(),ref_value.
view());
413template<
typename NumArray3>
414void _checkRightLayoutDim3(NumArray3& a)
417 ASSERT_EQ(a.totalNbElement(),(2*3*5));
418 ASSERT_EQ(a.extent0(),2);
419 ASSERT_EQ(a.extent1(),3);
420 ASSERT_EQ(a.extent2(),5);
421 _setNumArray3Values(a);
422 auto values = a.to1DSpan();
423 std::cout <<
"V=" << values <<
"\n";
426 0, 1, 2, 3, 4, 27, 28, 29, 30, 31, 54, 55, 56, 57, 58,
427 253, 254, 255, 256, 257, 280, 281, 282, 283, 284, 307, 308, 309, 310, 311
429 ASSERT_EQ(values.smallView(),ref_value.
view());
432template<
typename NumArray3>
433void _checkLeftLayoutDim3(NumArray3& a)
437 ASSERT_EQ(a.totalNbElement(),(2*3*5));
438 _setNumArray3Values(a);
439 auto values = a.to1DSpan();
440 std::cout <<
"V=" << values <<
"\n";
443 0, 253, 27, 280, 54, 307, 1, 254, 28, 281, 55, 308, 2, 255, 29,
444 282, 56, 309, 3, 256, 30, 283, 57, 310, 4, 257, 31, 284, 58, 311
446 ASSERT_EQ(values.smallView(),ref_value.
view());
449TEST(NumArray3, Layout)
451 std::cout <<
"TEST_NUMARRAY3 Layout\n";
455 std::cout <<
"TEST_NUMARRAY3 RightLayout 1\n";
456 _checkRightLayoutDim3(a);
460 std::cout <<
"TEST_NUMARRAY3 RightLayout 2\n";
461 _checkRightLayoutDim3(a);
465 std::cout <<
"TEST_NUMARRAY3 RightLayout 3\n";
466 _checkRightLayoutDim3(a);
470 std::cout <<
"TEST_NUMARRAY3 RightLayout 4\n";
471 _checkRightLayoutDim3(a);
475 std::cout <<
"TEST_NUMARRAY3 RightLayout 5\n";
476 _checkRightLayoutDim3(a);
481 std::cout <<
"TEST_NUMARRAY3 LeftLayout 1\n";
482 _checkLeftLayoutDim3(a);
486 std::cout <<
"TEST_NUMARRAY3 LeftLayout 2\n";
487 _checkLeftLayoutDim3(a);
491 std::cout <<
"TEST_NUMARRAY3 LeftLayout 3\n";
492 _checkLeftLayoutDim3(a);
496 std::cout <<
"TEST_NUMARRAY3 LeftLayout 4\n";
497 _checkLeftLayoutDim3(a);
501 std::cout <<
"TEST_NUMARRAY3 LeftLayout 5\n";
502 _checkLeftLayoutDim3(a);
513 a(2) =
Real2(0.0,3.2);
515 ASSERT_EQ(a(3).y,2.0);
520 const Real3 v(0.0,3.2,5.6);
523 ASSERT_EQ(a(4).y,4.0);
529 const Real2 v0(1.2,1.7);
535 ASSERT_EQ(a(4).y.x,4.0);
537 ASSERT_EQ(a(3)(1),v0);
542 const Real3 v0(1.2,3.4,1.7);
549 ASSERT_EQ(a(4).y.z,4.0);
551 ASSERT_EQ(a(3)(1),v0);
561 const char* values1_str =
"1 3 -2 \n -7 -5 12 \n 3 9 11\n";
562 NumArray<Int32, MDDim1> ref_value(9, { 1, 3, -2, -7, -5, 12, 3, 9, 11 });
563 std::istringstream istr1(values1_str);
566 ASSERT_EQ(int32_values.
extent0(), 9);
567 ASSERT_EQ(int32_values.
to1DSpan(), ref_value.to1DSpan());
570 const char* values1_str =
"1.1 3.3 -2.5 \n \n 2.1 4.99 12.23 \n 23 \n 45.1 11.9e2 -12.6e4\n";
571 NumArray<Real, MDDim1> ref_value(10, { 1.1, 3.3, -2.5, 2.1, 4.99, 12.23, 23, 45.1, 11.9e2, -12.6e4 });
572 std::istringstream istr1(values1_str);
575 ASSERT_EQ(real_values.
extent0(), 10);
576 ASSERT_EQ(real_values.
to1DSpan(), ref_value.to1DSpan());
579namespace TestCopyNumArray
593 std::cout << w.to1DSpan() <<
"\n";
595 std::cout << b.a_.to1DSpan() <<
"\n";
601 auto tpq = Arcane::NumArray<Real, Arcane::MDDim1>(5);
603 std::cout << tpq.to1DSpan() <<
"\n";
611 using namespace TestCopyNumArray;
614 std::cout <<
"Val 4 = "
616 <<
" " << test4.a_.to1DSpan() <<
"\n";
618 std::cout <<
"Val 5 = " << &test5 <<
" " << test5.to1DSpan() <<
"\n";
619 ASSERT_EQ(test4.a_.to1DSpan(), test5.to1DSpan());
627 std::cout <<
"Test_SpanUsage";
636 a1.
copy(span_ua1,
nullptr);
640 ASSERT_EQ(span_ua1, md_a1.to1DSmallSpan());
643 ASSERT_EQ(const_span_ua1, md_a2.to1DSmallSpan());
646 ASSERT_EQ(span_ua1, md_a3.to1DSmallSpan());
#define ASSERT_TRUE(condition)
Vérifie que condition est vrai.
SmallSpan< const T > smallSpan() const
Vue immutable sur ce tableau.
ArrayView< T > view() const
Vue mutable sur ce tableau.
Classe de base des vues multi-dimensionnelles.
__host__ __device__ MDSpan< DataType, RemovedFirstExtentsType, LayoutPolicy > slice(Int32 i) const
Retourne une vue de dimension (N-1) à partir de l'élément d'indice i.
constexpr __host__ __device__ DataType * ptrAt(Int32 i, Int32 j, Int32 k, Int32 l) const
Pointeur sur la valeur pour l'élément i,j,k.
constexpr __host__ __device__ Int32 extent1() const
Valeur de la deuxième dimension.
constexpr __host__ __device__ Int32 extent0() const
Valeur de la première dimension.
Tableaux multi-dimensionnels pour les types numériques accessibles sur accélérateurs.
constexpr Int32 extent0() const
Valeur de la première dimension.
Span< const DataType > to1DSpan() const
Vue 1D constante sur l'instance.
void copy(SmallSpan< const DataType > rhs)
Copie dans l'instance les valeurs de rhs.
constexpr SmallSpan< DataType > to1DSmallSpan()
Vue 1D sur l'instance (uniquement si rank == 1)
void fill(const DataType &v)
Remplit les valeurs du tableau par v.
constexpr Int32 extent1() const
Valeur de la deuxième dimension.
constexpr Int32 extent3() const
Valeur de la quatrième dimension.
constexpr Int32 extent2() const
Valeur de la troisième dimension.
void resize(Int32 dim1_size)
Modifie la taille du tableau en gardant pas les valeurs actuelles.
Classe gérant un vecteur de réel de dimension 2.
Classe gérant une matrice de réel de dimension 2x2.
Classe gérant un vecteur de réel de dimension 3.
Classe gérant une matrice de réel de dimension 3x3.
Vue d'un tableau d'éléments de type T.
Vue d'un tableau d'éléments de type T.
Vecteur 1D de données avec sémantique par valeur (style STL).
void readFromText(NumArray< double, MDDim1 > &v, std::istream &input)
Remplit v avec les valeurs de input.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-