//================================================================================================== /* ROTGEN - Runtime Overlay for Eigen Copyright : CODE RECKONS SPDX-License-Identifier: BSL-1.0 */ //================================================================================================== #include #include "unit/tests.hpp" template using column = rotgen::matrix; template using column_ref = rotgen::ref>; template using const_column_ref = rotgen::ref const>; template void process(column_ref v) { v(0) = rotgen::sum(v); } auto process(column_ref<> v) { auto sz = v.size(); switch (sz) { case 1: process<1>(v); break; case 2: process<2>(v); break; case 3: process<3>(v); break; default: break; } return sz; } TTS_CASE("Reference of reference check") { auto v1 = rotgen::setOnes>(); auto v2 = rotgen::setRandom>(); auto v3 = rotgen::setConstant>(6.66); auto sum1 = v1(0); auto sum2 = v2(0) + v2(1); auto sum3 = v3(0) + v3(1) + v3(2); TTS_EQUAL(process(v1), 1); TTS_EQUAL(process(v2), 2); TTS_EQUAL(process(v3), 3); TTS_EQUAL(v1[0], sum1); TTS_EQUAL(v2[0], sum2); TTS_EQUAL(v3[0], sum3); }; int f(rotgen::ref>) { return +2; } template int g(rotgen::ref>) { return +1; } template int g(rotgen::ref>) requires(N > 1) { return -1; } TTS_CASE("Reference overload on storage order check") { using col3 = rotgen::matrix; using row3 = rotgen::matrix; rotgen::matrixXf mat_dyn(1, 3); col3 mat_col(1, 3); row3 mat_row(1, 3); TTS_EQUAL(f(mat_dyn), +2); TTS_EQUAL(g<3>(mat_dyn), +1); TTS_EQUAL(g<3>(mat_col), +1); TTS_EQUAL(g<3>(mat_row), -1); TTS_EQUAL(f(rotgen::map(mat_dyn.data(), 1, 3)), +2); TTS_EQUAL(g<3>(rotgen::map(mat_dyn.data(), 1, 3)), +1); TTS_EQUAL(g<3>(rotgen::map(mat_dyn.data(), 1, 3)), +1); TTS_EQUAL(g<3>(rotgen::map(mat_dyn.data(), 1, 3)), -1); TTS_EQUAL(f(rotgen::map>( mat_dyn.data(), 1, 3, rotgen::outer_stride<>{1})), +2); TTS_EQUAL(g<3>(rotgen::map>( mat_dyn.data(), 1, 3, rotgen::outer_stride<>{1})), +1); TTS_EQUAL(g<3>(rotgen::map>( mat_dyn.data(), 1, 3, rotgen::outer_stride<>{1})), +1); TTS_EQUAL(g<3>(rotgen::map>( mat_dyn.data(), 1, 3, rotgen::outer_stride<>{1})), -1); TTS_EQUAL(f(rotgen::extract(mat_dyn, 0, 0, 1, 3)), +2); TTS_EQUAL(g<3>(rotgen::extract(mat_dyn, 0, 0, 1, 3)), +1); TTS_EQUAL(g<3>(rotgen::extract(mat_col, 0, 0, 1, 3)), +1); TTS_EQUAL(g<3>(rotgen::extract(mat_row, 0, 0, 1, 3)), -1); };