mirror of
https://gitlab.com/libeigen/eigen.git
synced 2025-04-20 00:29:38 +08:00
153 lines
5.6 KiB
C++
153 lines
5.6 KiB
C++
// This file is part of Eigen, a lightweight C++ template library
|
|
// for linear algebra.
|
|
//
|
|
// Copyright (C) 2014 Benoit Steiner <benoit.steiner.goog@gmail.com>
|
|
//
|
|
// This Source Code Form is subject to the terms of the Mozilla
|
|
// Public License v. 2.0. If a copy of the MPL was not distributed
|
|
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
#include "main.h"
|
|
|
|
#include <sstream>
|
|
#include <Eigen/CXX11/Tensor>
|
|
|
|
template <typename Scalar, int rank, int Layout>
|
|
struct test_tensor_ostream_impl {};
|
|
|
|
template <typename Scalar, int Layout>
|
|
struct test_tensor_ostream_impl<Scalar, 0, Layout> {
|
|
static void run() {
|
|
Eigen::Tensor<Scalar, 0> t;
|
|
t.setValues(1);
|
|
std::ostringstream os;
|
|
os << t.format(Eigen::TensorIOFormat::Plain());
|
|
VERIFY(os.str() == "1");
|
|
}
|
|
};
|
|
|
|
template <typename Scalar, int Layout>
|
|
struct test_tensor_ostream_impl<Scalar, 1, Layout> {
|
|
static void run() {
|
|
Eigen::Tensor<Scalar, 1> t = {3};
|
|
t.setValues({1, 2, 3});
|
|
std::ostringstream os;
|
|
os << t.format(Eigen::TensorIOFormat::Plain());
|
|
VERIFY(os.str() == "1 2 3");
|
|
}
|
|
};
|
|
|
|
template <typename Scalar, int Layout>
|
|
struct test_tensor_ostream_impl<Scalar, 2, Layout> {
|
|
static void run() {
|
|
Eigen::Tensor<Scalar, 2> t = {3, 2};
|
|
t.setValues({{1, 2}, {3, 4}, {5, 6}});
|
|
std::ostringstream os;
|
|
os << t.format(Eigen::TensorIOFormat::Plain());
|
|
VERIFY(os.str() == "1 2\n3 4\n5 6");
|
|
}
|
|
};
|
|
|
|
template <typename Scalar, int Layout>
|
|
struct test_tensor_ostream_impl<Scalar, 3, Layout> {
|
|
static void run() {
|
|
Eigen::Tensor<Scalar, 3> t = {4, 3, 2};
|
|
t.setValues({{{1, 2}, {3, 4}, {5, 6}},
|
|
{{7, 8}, {9, 10}, {11, 12}},
|
|
{{13, 14}, {15, 16}, {17, 18}},
|
|
{{19, 20}, {21, 22}, {23, 24}}});
|
|
std::ostringstream os;
|
|
os << t.format(Eigen::TensorIOFormat::Plain());
|
|
VERIFY(os.str() == " 1 2\n 3 4\n 5 6\n\n 7 8\n 9 10\n11 12\n\n13 14\n15 16\n17 18\n\n19 20\n21 22\n23 24");
|
|
}
|
|
};
|
|
|
|
template <int Layout>
|
|
struct test_tensor_ostream_impl<bool, 2, Layout> {
|
|
static void run() {
|
|
Eigen::Tensor<bool, 2> t = {3, 2};
|
|
t.setValues({{false, true}, {true, false}, {false, false}});
|
|
std::ostringstream os;
|
|
os << t.format(Eigen::TensorIOFormat::Plain());
|
|
VERIFY(os.str() == "0 1\n1 0\n0 0");
|
|
}
|
|
};
|
|
|
|
template <typename Scalar, int Layout>
|
|
struct test_tensor_ostream_impl<std::complex<Scalar>, 2, Layout> {
|
|
static void run() {
|
|
Eigen::Tensor<std::complex<Scalar>, 2> t = {3, 2};
|
|
t.setValues({{std::complex<Scalar>(1, 2), std::complex<Scalar>(12, 3)},
|
|
{std::complex<Scalar>(-4, 2), std::complex<Scalar>(0, 5)},
|
|
{std::complex<Scalar>(-1, 4), std::complex<Scalar>(5, 27)}});
|
|
std::ostringstream os;
|
|
os << t.format(Eigen::TensorIOFormat::Plain());
|
|
VERIFY(os.str() == " (1,2) (12,3)\n(-4,2) (0,5)\n(-1,4) (5,27)");
|
|
|
|
os.str("");
|
|
os.clear();
|
|
os << t.format(Eigen::TensorIOFormat::Numpy());
|
|
VERIFY(os.str() == "[[ 1+2j 12+3j]\n [-4+2j 0+5j]\n [-1+4j 5+27j]]");
|
|
|
|
os.str("");
|
|
os.clear();
|
|
os << t.format(Eigen::TensorIOFormat::Native());
|
|
VERIFY(os.str() == "{{ {1, 2}, {12, 3}},\n {{-4, 2}, {0, 5}},\n {{-1, 4}, {5, 27}}}");
|
|
}
|
|
};
|
|
|
|
template <typename Scalar, int rank, int Layout>
|
|
void test_tensor_ostream() {
|
|
test_tensor_ostream_impl<Scalar, rank, Layout>::run();
|
|
}
|
|
|
|
void test_const_tensor_ostream() {
|
|
Eigen::Tensor<float, 0> t;
|
|
t.setValues(1);
|
|
const Eigen::TensorMap<Eigen::Tensor<const float, 0, Eigen::RowMajor>, Eigen::Unaligned> t_const(
|
|
t.data(), Eigen::DSizes<Eigen::DenseIndex, 0>{});
|
|
std::ostringstream os;
|
|
os << t_const.format(Eigen::TensorIOFormat::Plain());
|
|
VERIFY(os.str() == "1");
|
|
}
|
|
|
|
EIGEN_DECLARE_TEST(cxx11_tensor_io) {
|
|
CALL_SUBTEST((test_tensor_ostream<float, 0, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<float, 1, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<float, 2, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<float, 3, Eigen::ColMajor>()));
|
|
|
|
CALL_SUBTEST((test_tensor_ostream<double, 0, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<double, 1, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<double, 2, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<double, 3, Eigen::ColMajor>()));
|
|
|
|
CALL_SUBTEST((test_tensor_ostream<int, 0, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<int, 1, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<int, 2, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<int, 3, Eigen::ColMajor>()));
|
|
|
|
CALL_SUBTEST((test_tensor_ostream<float, 0, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<float, 1, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<float, 2, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<float, 3, Eigen::RowMajor>()));
|
|
|
|
CALL_SUBTEST((test_tensor_ostream<double, 0, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<double, 1, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<double, 2, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<double, 3, Eigen::RowMajor>()));
|
|
|
|
CALL_SUBTEST((test_tensor_ostream<int, 0, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<int, 1, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<int, 2, Eigen::RowMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<int, 3, Eigen::RowMajor>()));
|
|
|
|
CALL_SUBTEST((test_tensor_ostream<bool, 2, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<bool, 2, Eigen::RowMajor>()));
|
|
|
|
CALL_SUBTEST((test_tensor_ostream<std::complex<double>, 2, Eigen::ColMajor>()));
|
|
CALL_SUBTEST((test_tensor_ostream<std::complex<float>, 2, Eigen::ColMajor>()));
|
|
|
|
// Test printing TensorMap with const elements.
|
|
CALL_SUBTEST((test_const_tensor_ostream()));
|
|
}
|