cxx11_tensor_sugar.cpp
Go to the documentation of this file.
1 #include "main.h"
2 
3 #include <Eigen/CXX11/Tensor>
4 
5 using Eigen::Tensor;
6 using Eigen::RowMajor;
7 
8 static void test_comparison_sugar() {
9  // we already trust comparisons between tensors, we're simply checking that
10  // the sugared versions are doing the same thing
11  Tensor<int, 3> t(6, 7, 5);
12 
13  t.setRandom();
14  // make sure we have at least one value == 0
15  t(0,0,0) = 0;
16 
18 
19 #define TEST_TENSOR_EQUAL(e1, e2) \
20  b = ((e1) == (e2)).all(); \
21  VERIFY(b())
22 
23 #define TEST_OP(op) TEST_TENSOR_EQUAL(t op 0, t op t.constant(0))
24 
25  TEST_OP(==);
26  TEST_OP(!=);
27  TEST_OP(<=);
28  TEST_OP(>=);
29  TEST_OP(<);
30  TEST_OP(>);
31 #undef TEST_OP
32 #undef TEST_TENSOR_EQUAL
33 }
34 
35 
37  Tensor<float, 3> A(6, 7, 5);
38  Tensor<float, 3> B(6, 7, 5);
39  A.setRandom();
40  B.setRandom();
41 
42  const float alpha = 0.43f;
43  const float beta = 0.21f;
44  const float gamma = 0.14f;
45 
46  Tensor<float, 3> R = A.constant(gamma) + A * A.constant(alpha) + B * B.constant(beta);
47  Tensor<float, 3> S = A * alpha + B * beta + gamma;
48  Tensor<float, 3> T = gamma + alpha * A + beta * B;
49 
50  for (int i = 0; i < 6*7*5; ++i) {
51  VERIFY_IS_APPROX(R(i), S(i));
52  VERIFY_IS_APPROX(R(i), T(i));
53  }
54 }
55 
57  Tensor<float, 3> A(6, 7, 5);
58  Tensor<float, 3> B(6, 7, 5);
59  A.setRandom();
60  B.setRandom();
61 
62  const float alpha = 0.43f;
63  const float beta = 0.21f;
64  const float gamma = 0.14f;
65  const float delta = 0.32f;
66 
67  Tensor<float, 3> R = A.constant(gamma) - A / A.constant(alpha)
68  - B.constant(beta) / B - A.constant(delta);
69  Tensor<float, 3> S = gamma - A / alpha - beta / B - delta;
70 
71  for (int i = 0; i < 6*7*5; ++i) {
72  VERIFY_IS_APPROX(R(i), S(i));
73  }
74 }
75 
76 EIGEN_DECLARE_TEST(cxx11_tensor_sugar)
77 {
81 }
Eigen::Tensor
The tensor class.
Definition: Tensor.h:63
B
Matrix< SCALARB, Dynamic, Dynamic, opt_B > B
Definition: bench_gemm.cpp:49
TEST_OP
#define TEST_OP(op)
alpha
RealScalar alpha
Definition: level1_cplx_impl.h:147
test_scalar_sugar_sub_div
static void test_scalar_sugar_sub_div()
Definition: cxx11_tensor_sugar.cpp:56
b
Scalar * b
Definition: benchVecAdd.cpp:17
test_scalar_sugar_add_mul
static void test_scalar_sugar_add_mul()
Definition: cxx11_tensor_sugar.cpp:36
EIGEN_DECLARE_TEST
EIGEN_DECLARE_TEST(cxx11_tensor_sugar)
Definition: cxx11_tensor_sugar.cpp:76
T
Eigen::Triplet< double > T
Definition: Tutorial_sparse_example.cpp:6
Eigen::RowMajor
@ RowMajor
Definition: Constants.h:321
beta
double beta(double a, double b)
Definition: beta.c:61
A
Matrix< SCALARA, Dynamic, Dynamic, opt_A > A
Definition: bench_gemm.cpp:48
gtsam.examples.PlanarManipulatorExample.delta
def delta(g0, g1)
Definition: PlanarManipulatorExample.py:45
Eigen::Triplet< double >
gamma
#define gamma
Definition: mconf.h:85
VERIFY_IS_APPROX
#define VERIFY_IS_APPROX(a, b)
Definition: integer_types.cpp:15
test_comparison_sugar
static void test_comparison_sugar()
Definition: cxx11_tensor_sugar.cpp:8
main.h
align_3::t
Point2 t(10, 10)
i
int i
Definition: BiCGSTAB_step_by_step.cpp:9
R
Rot2 R(Rot2::fromAngle(0.1))
S
DiscreteKey S(1, 2)
CALL_SUBTEST
#define CALL_SUBTEST(FUNC)
Definition: main.h:399


gtsam
Author(s):
autogenerated on Wed Jan 1 2025 04:01:24