// 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; static constexpr double kEpsilon = 1E-9; TEST(Transform2dTest, Inverse) { const Pose2d initial{1_m, 2_m, Rotation2d(45.0_deg)}; const Transform2d transform{Translation2d{5.0_m, 0.0_m}, Rotation2d(5.0_deg)}; auto transformed = initial + transform; auto untransformed = transformed + transform.Inverse(); EXPECT_NEAR(initial.X().to(), untransformed.X().to(), kEpsilon); EXPECT_NEAR(initial.Y().to(), untransformed.Y().to(), kEpsilon); EXPECT_NEAR(initial.Rotation().Degrees().to(), untransformed.Rotation().Degrees().to(), kEpsilon); }