mirror of
https://github.com/slsdetectorgroup/aare.git
synced 2025-06-06 21:00:41 +02:00
195 lines
4.6 KiB
C++
195 lines
4.6 KiB
C++
#include "aare/NDView.hpp"
|
|
#include <catch2/catch_test_macros.hpp>
|
|
|
|
#include <iostream>
|
|
#include <vector>
|
|
|
|
using aare::NDView;
|
|
using aare::Shape;
|
|
|
|
TEST_CASE("Element reference 1D") {
|
|
std::vector<int> vec;
|
|
for (int i = 0; i != 10; ++i) {
|
|
vec.push_back(i);
|
|
}
|
|
NDView<int, 1> data(vec.data(), Shape<1>{10});
|
|
REQUIRE(vec.size() == static_cast<size_t>(data.size()));
|
|
for (int i = 0; i != 10; ++i) {
|
|
REQUIRE(data(i) == vec[i]);
|
|
REQUIRE(data[i] == vec[i]);
|
|
}
|
|
}
|
|
|
|
TEST_CASE("Element reference 2D") {
|
|
std::vector<int> vec;
|
|
for (int i = 0; i != 12; ++i) {
|
|
vec.push_back(i);
|
|
}
|
|
|
|
NDView<int, 2> data(vec.data(), Shape<2>{3, 4});
|
|
REQUIRE(vec.size() == static_cast<size_t>(data.size()));
|
|
int i = 0;
|
|
for (int row = 0; row != 3; ++row) {
|
|
for (int col = 0; col != 4; ++col) {
|
|
REQUIRE(data(row, col) == i);
|
|
REQUIRE(data[i] == vec[i]);
|
|
++i;
|
|
}
|
|
}
|
|
}
|
|
|
|
TEST_CASE("Element reference 3D") {
|
|
std::vector<int> vec;
|
|
for (int i = 0; i != 24; ++i) {
|
|
vec.push_back(i);
|
|
}
|
|
NDView<int, 3> data(vec.data(), Shape<3>{2, 3, 4});
|
|
REQUIRE(vec.size() == static_cast<size_t>(data.size()));
|
|
int i = 0;
|
|
for (int frame = 0; frame != 2; ++frame) {
|
|
for (int row = 0; row != 3; ++row) {
|
|
for (int col = 0; col != 4; ++col) {
|
|
REQUIRE(data(frame, row, col) == i);
|
|
REQUIRE(data[i] == vec[i]);
|
|
++i;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
TEST_CASE("Plus and miuns with single value") {
|
|
std::vector<int> vec;
|
|
for (int i = 0; i != 12; ++i) {
|
|
vec.push_back(i);
|
|
}
|
|
NDView<int, 2> data(vec.data(), Shape<2>{3, 4});
|
|
data += 5;
|
|
int i = 0;
|
|
for (int row = 0; row != 3; ++row) {
|
|
for (int col = 0; col != 4; ++col) {
|
|
REQUIRE(data(row, col) == i + 5);
|
|
++i;
|
|
}
|
|
}
|
|
data -= 3;
|
|
i = 0;
|
|
for (int row = 0; row != 3; ++row) {
|
|
for (int col = 0; col != 4; ++col) {
|
|
REQUIRE(data(row, col) == i + 2);
|
|
++i;
|
|
}
|
|
}
|
|
}
|
|
|
|
TEST_CASE("Multiply and divide with single value") {
|
|
std::vector<int> vec;
|
|
for (int i = 0; i != 12; ++i) {
|
|
vec.push_back(i);
|
|
}
|
|
NDView<int, 2> data(vec.data(), Shape<2>{3, 4});
|
|
data *= 5;
|
|
int i = 0;
|
|
for (int row = 0; row != 3; ++row) {
|
|
for (int col = 0; col != 4; ++col) {
|
|
REQUIRE(data(row, col) == i * 5);
|
|
++i;
|
|
}
|
|
}
|
|
data /= 3;
|
|
i = 0;
|
|
for (int row = 0; row != 3; ++row) {
|
|
for (int col = 0; col != 4; ++col) {
|
|
REQUIRE(data(row, col) == (i * 5) / 3);
|
|
++i;
|
|
}
|
|
}
|
|
}
|
|
|
|
TEST_CASE("elementwise assign"){
|
|
std::vector<int> vec(25);
|
|
NDView<int, 2> data(vec.data(), Shape<2>{5,5});
|
|
|
|
data = 3;
|
|
for (auto it : data){
|
|
REQUIRE(it == 3);
|
|
}
|
|
}
|
|
|
|
TEST_CASE("iterators") {
|
|
std::vector<int> vec;
|
|
for (int i = 0; i != 12; ++i) {
|
|
vec.push_back(i);
|
|
}
|
|
NDView<int, 1> data(vec.data(), Shape<1>{12});
|
|
int i = 0;
|
|
for (const auto item : data) {
|
|
REQUIRE(item == vec[i]);
|
|
++i;
|
|
}
|
|
REQUIRE(i == 12);
|
|
|
|
for (auto ptr = data.begin(); ptr != data.end(); ++ptr) {
|
|
*ptr += 1;
|
|
}
|
|
for (auto& item : data){
|
|
++item;
|
|
}
|
|
|
|
i = 0;
|
|
for (const auto item : data) {
|
|
REQUIRE(item == i + 2);
|
|
++i;
|
|
}
|
|
}
|
|
|
|
|
|
TEST_CASE("shape from vector"){
|
|
std::vector<int> vec;
|
|
for (int i = 0; i != 12; ++i) {
|
|
vec.push_back(i);
|
|
}
|
|
std::vector<ssize_t> shape{3,4};
|
|
NDView<int,2> data(vec.data(), shape);
|
|
}
|
|
|
|
TEST_CASE("divide with another span"){
|
|
std::vector<int> vec0{9,12,3};
|
|
std::vector<int> vec1{3,2,1};
|
|
std::vector<int> result{3,6,3};
|
|
|
|
NDView<int, 1> data0(vec0.data(), Shape<1>{static_cast<ssize_t>(vec0.size())});
|
|
NDView<int, 1> data1(vec1.data(), Shape<1>{static_cast<ssize_t>(vec1.size())});
|
|
|
|
data0 /= data1;
|
|
|
|
for(size_t i =0; i!=vec0.size(); ++i){
|
|
REQUIRE(data0[i] == result[i] );
|
|
}
|
|
}
|
|
|
|
TEST_CASE("Retrieve shape"){
|
|
std::vector<int> vec;
|
|
for (int i = 0; i != 12; ++i) {
|
|
vec.push_back(i);
|
|
}
|
|
NDView<int,2> data(vec.data(), Shape<2>{3,4});
|
|
REQUIRE(data.shape()[0] == 3);
|
|
REQUIRE(data.shape()[1] == 4);
|
|
|
|
}
|
|
|
|
TEST_CASE("compare two views"){
|
|
std::vector<int> vec1;
|
|
for (int i = 0; i != 12; ++i) {
|
|
vec1.push_back(i);
|
|
}
|
|
NDView<int,2> view1(vec1.data(), Shape<2>{3,4});
|
|
|
|
std::vector<int> vec2;
|
|
for (int i = 0; i != 12; ++i) {
|
|
vec2.push_back(i);
|
|
}
|
|
NDView<int,2> view2(vec2.data(), Shape<2>{3,4});
|
|
|
|
REQUIRE(view1 == view2);
|
|
} |