gtsam
3rdparty
Eigen
unsupported
test
cxx11_tensor_inflation.cpp
Go to the documentation of this file.
1
// This file is part of Eigen, a lightweight C++ template library
2
// for linear algebra.
3
//
4
// Copyright (C) 2015 Ke Yang <yangke@gmail.com>
5
//
6
// This Source Code Form is subject to the terms of the Mozilla
7
// Public License v. 2.0. If a copy of the MPL was not distributed
8
// with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
9
10
#include "
main.h
"
11
12
#include <Eigen/CXX11/Tensor>
13
14
using
Eigen::Tensor
;
15
16
template
<
int
DataLayout>
17
static
void
test_simple_inflation
()
18
{
19
Tensor<float, 4, DataLayout>
tensor(2,3,5,7);
20
tensor.
setRandom
();
21
array<ptrdiff_t, 4>
strides
;
22
23
strides
[0] = 1;
24
strides
[1] = 1;
25
strides
[2] = 1;
26
strides
[3] = 1;
27
28
Tensor<float, 4, DataLayout>
no_stride;
29
no_stride = tensor.inflate(
strides
);
30
31
VERIFY_IS_EQUAL
(no_stride.
dimension
(0), 2);
32
VERIFY_IS_EQUAL
(no_stride.
dimension
(1), 3);
33
VERIFY_IS_EQUAL
(no_stride.
dimension
(2), 5);
34
VERIFY_IS_EQUAL
(no_stride.
dimension
(3), 7);
35
36
for
(
int
i
= 0;
i
< 2; ++
i
) {
37
for
(
int
j
= 0;
j
< 3; ++
j
) {
38
for
(
int
k = 0; k < 5; ++k) {
39
for
(
int
l
= 0;
l
< 7; ++
l
) {
40
VERIFY_IS_EQUAL
(tensor(
i
,
j
,k,
l
), no_stride(
i
,
j
,k,
l
));
41
}
42
}
43
}
44
}
45
46
strides
[0] = 2;
47
strides
[1] = 4;
48
strides
[2] = 2;
49
strides
[3] = 3;
50
Tensor<float, 4, DataLayout>
inflated;
51
inflated = tensor.inflate(
strides
);
52
53
VERIFY_IS_EQUAL
(inflated.
dimension
(0), 3);
54
VERIFY_IS_EQUAL
(inflated.
dimension
(1), 9);
55
VERIFY_IS_EQUAL
(inflated.
dimension
(2), 9);
56
VERIFY_IS_EQUAL
(inflated.
dimension
(3), 19);
57
58
for
(
int
i
= 0;
i
< 3; ++
i
) {
59
for
(
int
j
= 0;
j
< 9; ++
j
) {
60
for
(
int
k = 0; k < 9; ++k) {
61
for
(
int
l
= 0;
l
< 19; ++
l
) {
62
if
(
i
% 2 == 0 &&
63
j
% 4 == 0 &&
64
k % 2 == 0 &&
65
l
% 3 == 0) {
66
VERIFY_IS_EQUAL
(inflated(
i
,
j
,k,
l
),
67
tensor(
i
/2,
j
/4, k/2,
l
/3));
68
}
else
{
69
VERIFY_IS_EQUAL
(0, inflated(
i
,
j
,k,
l
));
70
}
71
}
72
}
73
}
74
}
75
}
76
77
EIGEN_DECLARE_TEST
(cxx11_tensor_inflation)
78
{
79
CALL_SUBTEST
(test_simple_inflation<ColMajor>());
80
CALL_SUBTEST
(test_simple_inflation<RowMajor>());
81
}
Eigen::Tensor::dimension
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Index dimension(std::size_t n) const
Definition:
Tensor.h:101
Eigen::Tensor
The tensor class.
Definition:
Tensor.h:63
Eigen::internal::strides
EIGEN_ALWAYS_INLINE DSizes< IndexType, NumDims > strides(const DSizes< IndexType, NumDims > &dimensions)
Definition:
TensorBlock.h:26
Eigen::array
Definition:
EmulateArray.h:21
VERIFY_IS_EQUAL
#define VERIFY_IS_EQUAL(a, b)
Definition:
main.h:386
test_simple_inflation
static void test_simple_inflation()
Definition:
cxx11_tensor_inflation.cpp:17
j
std::ptrdiff_t j
Definition:
tut_arithmetic_redux_minmax.cpp:2
l
static const Line3 l(Rot3(), 1, 1)
EIGEN_DECLARE_TEST
EIGEN_DECLARE_TEST(cxx11_tensor_inflation)
Definition:
cxx11_tensor_inflation.cpp:77
Eigen::TensorBase< Tensor< Scalar_, NumIndices_, Options_, IndexType_ > >::setRandom
EIGEN_DEVICE_FUNC EIGEN_STRONG_INLINE Tensor< Scalar_, NumIndices_, Options_, IndexType_ > & setRandom()
Definition:
TensorBase.h:996
main.h
i
int i
Definition:
BiCGSTAB_step_by_step.cpp:9
CALL_SUBTEST
#define CALL_SUBTEST(FUNC)
Definition:
main.h:399
gtsam
Author(s):
autogenerated on Tue Jan 7 2025 04:02:07