mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-20 00:51:42 +00:00
37 lines
1.1 KiB
C++
37 lines
1.1 KiB
C++
|
|
/*----------------------------------------------------------------------------*/
|
||
|
|
/* Copyright (c) 2019-2020 FIRST. All Rights Reserved. */
|
||
|
|
/* Open Source Software - may be modified and shared by FRC teams. The code */
|
||
|
|
/* must be accompanied by the FIRST BSD license file in the root directory of */
|
||
|
|
/* the project. */
|
||
|
|
/*----------------------------------------------------------------------------*/
|
||
|
|
|
||
|
|
#include <gtest/gtest.h>
|
||
|
|
|
||
|
|
#include <cmath>
|
||
|
|
|
||
|
|
#include "Eigen/Core"
|
||
|
|
#include "frc/controller/LinearPlantInversionFeedforward.h"
|
||
|
|
#include "units/time.h"
|
||
|
|
|
||
|
|
namespace frc {
|
||
|
|
|
||
|
|
TEST(LinearPlantInversionFeedforwardTest, Calculate) {
|
||
|
|
Eigen::Matrix<double, 2, 2> A;
|
||
|
|
A << 1, 0, 0, 1;
|
||
|
|
|
||
|
|
Eigen::Matrix<double, 2, 1> B;
|
||
|
|
B << 0, 1;
|
||
|
|
|
||
|
|
frc::LinearPlantInversionFeedforward<2, 1> feedforward{A, B,
|
||
|
|
units::second_t(0.02)};
|
||
|
|
|
||
|
|
Eigen::Matrix<double, 2, 1> r;
|
||
|
|
r << 2, 2;
|
||
|
|
Eigen::Matrix<double, 2, 1> nextR;
|
||
|
|
nextR << 3, 3;
|
||
|
|
|
||
|
|
EXPECT_NEAR(47.502599, feedforward.Calculate(r, nextR)(0, 0), 0.002);
|
||
|
|
}
|
||
|
|
|
||
|
|
} // namespace frc
|