[wpimath] Add remaining struct and protobuf implementations (#5953)

This commit is contained in:
Joseph Eng
2024-07-29 07:55:44 -07:00
committed by GitHub
parent 3e1e3fb4ca
commit 073192d513
112 changed files with 3989 additions and 45 deletions

View File

@@ -0,0 +1,32 @@
// 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 <gtest/gtest.h>
#include "../../ProtoTestBase.h"
#include "frc/spline/CubicHermiteSpline.h"
using namespace frc;
struct CubicHermiteSplineProtoTestData {
using Type = CubicHermiteSpline;
inline static const Type kTestData{
wpi::array<double, 2>{{0.1, 0.2}}, wpi::array<double, 2>{{0.3, 0.4}},
wpi::array<double, 2>{{0.5, 0.6}}, wpi::array<double, 2>{{0.7, 0.8}}};
static void CheckEq(const Type& testData, const Type& data) {
EXPECT_EQ(testData.GetInitialControlVector().x,
data.GetInitialControlVector().x);
EXPECT_EQ(testData.GetFinalControlVector().x,
data.GetFinalControlVector().x);
EXPECT_EQ(testData.GetInitialControlVector().y,
data.GetInitialControlVector().y);
EXPECT_EQ(testData.GetFinalControlVector().y,
data.GetFinalControlVector().y);
}
};
INSTANTIATE_TYPED_TEST_SUITE_P(CubicHermiteSpline, ProtoTest,
CubicHermiteSplineProtoTestData);

View File

@@ -0,0 +1,33 @@
// 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 <gtest/gtest.h>
#include "../../ProtoTestBase.h"
#include "frc/spline/QuinticHermiteSpline.h"
using namespace frc;
struct QuinticHermiteSplineProtoTestData {
using Type = QuinticHermiteSpline;
inline static const Type kTestData{wpi::array<double, 3>{{0.01, 0.02, 0.03}},
wpi::array<double, 3>{{0.04, 0.05, 0.06}},
wpi::array<double, 3>{{0.07, 0.08, 0.09}},
wpi::array<double, 3>{{0.10, 0.11, 0.11}}};
static void CheckEq(const Type& testData, const Type& data) {
EXPECT_EQ(testData.GetInitialControlVector().x,
data.GetInitialControlVector().x);
EXPECT_EQ(testData.GetFinalControlVector().x,
data.GetFinalControlVector().x);
EXPECT_EQ(testData.GetInitialControlVector().y,
data.GetInitialControlVector().y);
EXPECT_EQ(testData.GetFinalControlVector().y,
data.GetFinalControlVector().y);
}
};
INSTANTIATE_TYPED_TEST_SUITE_P(QuinticHermiteSpline, ProtoTest,
QuinticHermiteSplineProtoTestData);

View File

@@ -0,0 +1,32 @@
// 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 <gtest/gtest.h>
#include "../../StructTestBase.h"
#include "frc/spline/CubicHermiteSpline.h"
using namespace frc;
struct CubicHermiteSplineStructTestData {
using Type = CubicHermiteSpline;
inline static const Type kTestData{
wpi::array<double, 2>{{0.1, 0.2}}, wpi::array<double, 2>{{0.3, 0.4}},
wpi::array<double, 2>{{0.5, 0.6}}, wpi::array<double, 2>{{0.7, 0.8}}};
static void CheckEq(const Type& testData, const Type& data) {
EXPECT_EQ(testData.GetInitialControlVector().x,
data.GetInitialControlVector().x);
EXPECT_EQ(testData.GetFinalControlVector().x,
data.GetFinalControlVector().x);
EXPECT_EQ(testData.GetInitialControlVector().y,
data.GetInitialControlVector().y);
EXPECT_EQ(testData.GetFinalControlVector().y,
data.GetFinalControlVector().y);
}
};
INSTANTIATE_TYPED_TEST_SUITE_P(CubicHermiteSpline, StructTest,
CubicHermiteSplineStructTestData);

View File

@@ -0,0 +1,33 @@
// 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 <gtest/gtest.h>
#include "../../StructTestBase.h"
#include "frc/spline/QuinticHermiteSpline.h"
using namespace frc;
struct QuinticHermiteSplineStructTestData {
using Type = QuinticHermiteSpline;
inline static const Type kTestData{wpi::array<double, 3>{{0.01, 0.02, 0.03}},
wpi::array<double, 3>{{0.04, 0.05, 0.06}},
wpi::array<double, 3>{{0.07, 0.08, 0.09}},
wpi::array<double, 3>{{0.10, 0.11, 0.11}}};
static void CheckEq(const Type& testData, const Type& data) {
EXPECT_EQ(testData.GetInitialControlVector().x,
data.GetInitialControlVector().x);
EXPECT_EQ(testData.GetFinalControlVector().x,
data.GetFinalControlVector().x);
EXPECT_EQ(testData.GetInitialControlVector().y,
data.GetInitialControlVector().y);
EXPECT_EQ(testData.GetFinalControlVector().y,
data.GetFinalControlVector().y);
}
};
INSTANTIATE_TYPED_TEST_SUITE_P(QuinticHermiteSpline, StructTest,
QuinticHermiteSplineStructTestData);