Skip to content
Snippets Groups Projects
CVectorTest.cpp 1.42 KiB
Newer Older
#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)
{
    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.));
Wuttke, Joachim's avatar
Wuttke, Joachim committed
    // Dot product defined in Vec3
    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));
pospelov's avatar
pospelov committed

    // 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)));
pospelov's avatar
pospelov committed
}