File size: 2,175 Bytes
985c397 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 | #include <gtest/gtest.h>
#include <Base/DualNumber.h>
TEST(DualNumber, TestDefault)
{
Base::DualNumber dn;
EXPECT_EQ(dn.re, 0.0);
EXPECT_EQ(dn.du, 0.0);
}
TEST(DualNumber, TestNonDefault)
{
Base::DualNumber dn(1.0);
EXPECT_EQ(dn.re, 1.0);
EXPECT_EQ(dn.du, 0.0);
Base::DualNumber dn2(1.0, 2.0);
EXPECT_EQ(dn2.re, 1.0);
EXPECT_EQ(dn2.du, 2.0);
}
TEST(DualNumber, TestNegate)
{
Base::DualNumber dn(-Base::DualNumber(1.0, 2.0));
EXPECT_EQ(dn.re, -1.0);
EXPECT_EQ(dn.du, -2.0);
}
TEST(DualNumber, TestPlus)
{
Base::DualNumber dn1(1.0, 2.0);
Base::DualNumber dn2(2.0, -1.0);
Base::DualNumber dn3 = dn1 + dn2;
EXPECT_EQ(dn3.re, 3.0);
EXPECT_EQ(dn3.du, 1.0);
Base::DualNumber dn4 = dn1 + 2.0;
EXPECT_EQ(dn4.re, 3.0);
EXPECT_EQ(dn4.du, 2.0);
Base::DualNumber dn5 = 2.0 + dn1;
EXPECT_EQ(dn5.re, 3.0);
EXPECT_EQ(dn5.du, 2.0);
}
TEST(DualNumber, TestMinus)
{
Base::DualNumber dn1(1.0, 2.0);
Base::DualNumber dn2(2.0, -1.0);
Base::DualNumber dn3 = dn1 - dn2;
EXPECT_EQ(dn3.re, -1.0);
EXPECT_EQ(dn3.du, 3.0);
Base::DualNumber dn4 = dn1 - 2.0;
EXPECT_EQ(dn4.re, -1.0);
EXPECT_EQ(dn4.du, 2.0);
Base::DualNumber dn5 = 2.0 - dn1;
EXPECT_EQ(dn5.re, 1.0);
EXPECT_EQ(dn5.du, -2.0);
}
TEST(DualNumber, TestMultiply)
{
Base::DualNumber dn1(1.0, 2.0);
Base::DualNumber dn2(2.0, -1.0);
Base::DualNumber dn3 = dn1 * dn2;
EXPECT_EQ(dn3.re, 2.0);
EXPECT_EQ(dn3.du, 3.0);
Base::DualNumber dn4 = dn1 * 2.0;
EXPECT_EQ(dn4.re, 2.0);
EXPECT_EQ(dn4.du, 4.0);
Base::DualNumber dn5 = 2.0 * dn1;
EXPECT_EQ(dn5.re, 2.0);
EXPECT_EQ(dn5.du, 4.0);
}
TEST(DualNumber, TestDivide)
{
Base::DualNumber dn1(1.0, 2.0);
Base::DualNumber dn2(2.0, -1.0);
Base::DualNumber dn3 = dn1 / dn2;
EXPECT_EQ(dn3.re, 0.5);
EXPECT_EQ(dn3.du, 1.25);
Base::DualNumber dn4 = dn1 / 2.0;
EXPECT_EQ(dn4.re, 0.5);
EXPECT_EQ(dn4.du, 1.0);
}
TEST(DualNumber, TestPow)
{
Base::DualNumber dn1(3.0, 2.0);
Base::DualNumber dn2 = Base::pow(dn1, 2.0);
EXPECT_EQ(dn2.re, 9.0);
EXPECT_EQ(dn2.du, 12.0);
}
|