// 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. #include #include "frc/geometry/Pose2d.h" #include "frc/geometry/Rotation2d.h" #include "frc/geometry/Transform2d.h" #include "frc/geometry/Translation2d.h" #include "gtest/gtest.h" using namespace frc; TEST(Transform2dTest, Inverse) { const Pose2d initial{1_m, 2_m, 45_deg}; const Transform2d transform{{5_m, 0_m}, 5_deg}; auto transformed = initial + transform; auto untransformed = transformed + transform.Inverse(); EXPECT_NEAR(initial.X().value(), untransformed.X().value(), 1e-9); EXPECT_DOUBLE_EQ(initial.Y().value(), untransformed.Y().value()); EXPECT_DOUBLE_EQ(initial.Rotation().Degrees().value(), untransformed.Rotation().Degrees().value()); } TEST(Transform2dTest, Composition) { const Pose2d initial{1_m, 2_m, 45_deg}; const Transform2d transform1{{5_m, 0_m}, 5_deg}; const Transform2d transform2{{0_m, 2_m}, 5_deg}; auto transformedSeparate = initial + transform1 + transform2; auto transformedCombined = initial + (transform1 + transform2); EXPECT_DOUBLE_EQ(transformedSeparate.X().value(), transformedCombined.X().value()); EXPECT_DOUBLE_EQ(transformedSeparate.Y().value(), transformedCombined.Y().value()); EXPECT_DOUBLE_EQ(transformedSeparate.Rotation().Degrees().value(), transformedCombined.Rotation().Degrees().value()); }