Newer
Older
#include "Base/Vector/EigenCore.h"
#include "Base/Vector/Vectors3D.h"
#include "Tests/GTestWrapper/google_test.h"
Celine Durniak
committed
class CVectorTest : public ::testing::Test {
};
TEST_F(CVectorTest, TrivialOperations)
{
EXPECT_EQ(vec_k.complex().z(), complex_t(3., 0.));

Wuttke, Joachim
committed
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.);

Wuttke, Joachim
committed
}
TEST_F(CVectorTest, BasicArithmetics)
{
Celine Durniak
committed
// 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.));
Celine Durniak
committed
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));
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)));