//================================================================================================== /* ROTGEN - Runtime Overlay for Eigen Copyright : CODE RECKONS SPDX-License-Identifier: BSL-1.0 */ //================================================================================================== #include "unit/tests.hpp" #include #include #include auto generate_data(int rows, int cols) { std::vector buffer(rows * cols * 3); for (size_t i = 0; i < buffer.size(); ++i) buffer[i] = static_cast(1+i); return buffer; } template using r_mat_t = rotgen::matrix; template using e_mat_t = Eigen::Matrix; template using r_map_t = rotgen::map; template> using e_map_t = Eigen::Map; TTS_CASE("Validate Column Major Map with regular stride behavior") { auto rows = 3; auto cols = 4; auto buffer = generate_data(rows,cols); r_map_t> r_map(buffer.data(), rows, cols); TTS_EQUAL(r_map.innerStride(), 1); TTS_EQUAL(r_map.outerStride(), 3); e_map_t> e_map(buffer.data(), rows, cols); for(std::ptrdiff_t r=0;r, rotgen::outer_stride<>> r_map(buffer.data(), rows, cols, rotgen::outer_stride(rows + 1)); TTS_EQUAL(r_map.innerStride(), 1); TTS_EQUAL(r_map.outerStride() , 4); e_map_t, Eigen::OuterStride<>> e_map(buffer.data(), rows, cols, Eigen::OuterStride<>(rows + 1)); for(std::ptrdiff_t r=0;r> r_map(buffer.data(), rows, cols, rotgen::stride(rows, 2)); TTS_EQUAL(r_map.innerStride(), 2); TTS_EQUAL(r_map.outerStride() , 3); e_map_t,Eigen::Stride> e_map(buffer.data(), rows, cols, Eigen::Stride(rows,2)); for(std::ptrdiff_t r=0;r> r_map(buffer.data(), rows, cols); TTS_EQUAL(r_map.innerStride(), 1); TTS_EQUAL(r_map.outerStride(), 4); e_map_t> e_map(buffer.data(), rows, cols); for(std::ptrdiff_t r=0;r, rotgen::outer_stride<>> r_map(buffer.data(), rows, cols, rotgen::outer_stride(cols + 1)); TTS_EQUAL(r_map.innerStride(), 1); TTS_EQUAL(r_map.outerStride() , 5); e_map_t, Eigen::OuterStride<>> e_map(buffer.data(), rows, cols, Eigen::OuterStride<>(cols + 1)); for(std::ptrdiff_t r=0;r,rotgen::stride> r_map(buffer.data(), rows, cols, rotgen::stride(2, cols)); TTS_EQUAL(r_map.innerStride(), 4); TTS_EQUAL(r_map.outerStride() , 2); e_map_t,Eigen::Stride> e_map(buffer.data(), rows, cols, Eigen::Stride(2,cols)); for(std::ptrdiff_t r=0;r