#include "Base/Vector/EigenCore.h" #include "Base/Vector/Vectors3D.h" #include "Tests/GTestWrapper/google_test.h" class CVectorTest : public ::testing::Test { }; TEST_F(CVectorTest, TrivialOperations) { R3 vec_k(1., 2., 3.); EXPECT_EQ(vec_k.complex().z(), complex_t(3., 0.)); C3 vec_c(complex_t(1., 3.), complex_t(2., -5.), complex_t(-3., -4.)); EXPECT_EQ(-vec_c.z(), complex_t(3., 4.)); EXPECT_DOUBLE_EQ(vec_c.mag(), 8.); } TEST_F(CVectorTest, BasicArithmetics) { // Dot product with "Eigen" library Eigen::Vector3cd va(complex_t(1., 0.), complex_t(2., 0.), complex_t(3., 0.)); Eigen::Vector3cd vc(complex_t(1., 1.), complex_t(2., -5.), complex_t(3., 4.)); EXPECT_TRUE(va.dot(vc) == complex_t(14., 3.)); // Dot product defined in BasicVector3D C3 vec_a(complex_t(1., 0.), complex_t(2., 0.), complex_t(3., 0.)); C3 vec_b(complex_t(2., 0.), complex_t(3., 0.), complex_t(4., 0.)); C3 vec_c(complex_t(1., 1.), complex_t(2., -5.), complex_t(3., 4.)); EXPECT_TRUE(vec_a.dot(vec_b) == complex_t(20., 0)); EXPECT_TRUE(vec_a.dot(vec_c) == complex_t(14., 3.)); EXPECT_TRUE(vec_c.dot(vec_b) == complex_t(20., -3.)); EXPECT_TRUE(vec_a.dot(vec_a) == complex_t(14., 0)); EXPECT_TRUE(vec_c.dot(vec_c) == complex_t(56., 0)); // f = f_re + j*f_im C3 vec_e(1., 2., 3.); C3 vec_f(5., 6., 7.); EXPECT_EQ(vec_e + I * vec_f, C3(complex_t(1., 5.), complex_t(2., 6), complex_t(3, 7))); }