2020-12-26 14:12:05 -08:00
|
|
|
// Copyright (c) FIRST and other WPILib contributors.
|
|
|
|
|
// Open Source Software; you can modify and/or share it under the terms of
|
|
|
|
|
// the WPILib BSD license file in the root directory of this project.
|
2019-07-24 02:57:39 -04:00
|
|
|
|
|
|
|
|
#include <cmath>
|
|
|
|
|
|
|
|
|
|
#include "frc/geometry/Translation2d.h"
|
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
|
|
|
|
|
|
using namespace frc;
|
|
|
|
|
|
|
|
|
|
TEST(Translation2dTest, Sum) {
|
2022-05-06 08:41:23 -07:00
|
|
|
const Translation2d one{1_m, 3_m};
|
|
|
|
|
const Translation2d two{2_m, 5_m};
|
2019-07-24 02:57:39 -04:00
|
|
|
|
|
|
|
|
const auto sum = one + two;
|
|
|
|
|
|
2022-05-06 08:41:23 -07:00
|
|
|
EXPECT_DOUBLE_EQ(3.0, sum.X().value());
|
|
|
|
|
EXPECT_DOUBLE_EQ(8.0, sum.Y().value());
|
2019-07-24 02:57:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(Translation2dTest, Difference) {
|
2022-05-06 08:41:23 -07:00
|
|
|
const Translation2d one{1_m, 3_m};
|
|
|
|
|
const Translation2d two{2_m, 5_m};
|
2019-07-24 02:57:39 -04:00
|
|
|
|
|
|
|
|
const auto difference = one - two;
|
|
|
|
|
|
2022-05-06 08:41:23 -07:00
|
|
|
EXPECT_DOUBLE_EQ(-1.0, difference.X().value());
|
|
|
|
|
EXPECT_DOUBLE_EQ(-2.0, difference.Y().value());
|
2019-07-24 02:57:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(Translation2dTest, RotateBy) {
|
2022-05-06 08:41:23 -07:00
|
|
|
const Translation2d another{3_m, 0_m};
|
|
|
|
|
const auto rotated = another.RotateBy(Rotation2d(90_deg));
|
2019-07-24 02:57:39 -04:00
|
|
|
|
2022-05-06 08:41:23 -07:00
|
|
|
EXPECT_NEAR(0.0, rotated.X().value(), 1e-9);
|
|
|
|
|
EXPECT_DOUBLE_EQ(3.0, rotated.Y().value());
|
2019-07-24 02:57:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(Translation2dTest, Multiplication) {
|
2022-05-06 08:41:23 -07:00
|
|
|
const Translation2d original{3_m, 5_m};
|
2019-07-24 02:57:39 -04:00
|
|
|
const auto mult = original * 3;
|
|
|
|
|
|
2022-05-06 08:41:23 -07:00
|
|
|
EXPECT_DOUBLE_EQ(9.0, mult.X().value());
|
|
|
|
|
EXPECT_DOUBLE_EQ(15.0, mult.Y().value());
|
2019-07-24 02:57:39 -04:00
|
|
|
}
|
|
|
|
|
|
2021-09-21 06:12:50 -07:00
|
|
|
TEST(Translation2dTest, Division) {
|
2022-05-06 08:41:23 -07:00
|
|
|
const Translation2d original{3_m, 5_m};
|
2019-07-24 02:57:39 -04:00
|
|
|
const auto div = original / 2;
|
|
|
|
|
|
2022-05-06 08:41:23 -07:00
|
|
|
EXPECT_DOUBLE_EQ(1.5, div.X().value());
|
|
|
|
|
EXPECT_DOUBLE_EQ(2.5, div.Y().value());
|
2019-07-24 02:57:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(Translation2dTest, Norm) {
|
2022-05-06 08:41:23 -07:00
|
|
|
const Translation2d one{3_m, 5_m};
|
|
|
|
|
EXPECT_DOUBLE_EQ(std::hypot(3.0, 5.0), one.Norm().value());
|
2019-07-24 02:57:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(Translation2dTest, Distance) {
|
2019-08-17 01:00:33 -04:00
|
|
|
const Translation2d one{1_m, 1_m};
|
|
|
|
|
const Translation2d two{6_m, 6_m};
|
2022-05-06 08:41:23 -07:00
|
|
|
EXPECT_DOUBLE_EQ(5.0 * std::sqrt(2.0), one.Distance(two).value());
|
2019-07-24 02:57:39 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(Translation2dTest, UnaryMinus) {
|
2019-08-17 01:00:33 -04:00
|
|
|
const Translation2d original{-4.5_m, 7_m};
|
2019-07-24 02:57:39 -04:00
|
|
|
const auto inverted = -original;
|
|
|
|
|
|
2022-05-06 08:41:23 -07:00
|
|
|
EXPECT_DOUBLE_EQ(4.5, inverted.X().value());
|
|
|
|
|
EXPECT_DOUBLE_EQ(-7.0, inverted.Y().value());
|
2019-07-24 02:57:39 -04:00
|
|
|
}
|
2019-09-08 14:20:26 -04:00
|
|
|
|
|
|
|
|
TEST(Translation2dTest, Equality) {
|
|
|
|
|
const Translation2d one{9_m, 5.5_m};
|
|
|
|
|
const Translation2d two{9_m, 5.5_m};
|
|
|
|
|
EXPECT_TRUE(one == two);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TEST(Translation2dTest, Inequality) {
|
|
|
|
|
const Translation2d one{9_m, 5.5_m};
|
|
|
|
|
const Translation2d two{9_m, 5.7_m};
|
|
|
|
|
EXPECT_TRUE(one != two);
|
|
|
|
|
}
|
2020-10-21 00:22:41 -04:00
|
|
|
|
|
|
|
|
TEST(Translation2dTest, PolarConstructor) {
|
2022-05-06 08:41:23 -07:00
|
|
|
Translation2d one{std::sqrt(2) * 1_m, Rotation2d{45_deg}};
|
|
|
|
|
EXPECT_DOUBLE_EQ(1.0, one.X().value());
|
|
|
|
|
EXPECT_DOUBLE_EQ(1.0, one.Y().value());
|
2020-10-21 00:22:41 -04:00
|
|
|
|
2022-05-06 08:41:23 -07:00
|
|
|
Translation2d two{2_m, Rotation2d{60_deg}};
|
|
|
|
|
EXPECT_DOUBLE_EQ(1.0, two.X().value());
|
|
|
|
|
EXPECT_DOUBLE_EQ(std::sqrt(3.0), two.Y().value());
|
2020-10-21 00:22:41 -04:00
|
|
|
}
|