2022-10-25 15:28:36 -04: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.
|
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
2023-06-19 17:10:39 -07:00
|
|
|
#include <wpi/MathExtras.h>
|
2022-10-25 15:28:36 -04:00
|
|
|
#include <wpi/SymbolExports.h>
|
|
|
|
|
|
|
|
|
|
#include "frc/geometry/Rotation2d.h"
|
|
|
|
|
#include "units/angle.h"
|
|
|
|
|
#include "units/length.h"
|
|
|
|
|
#include "units/math.h"
|
|
|
|
|
|
|
|
|
|
namespace frc {
|
|
|
|
|
/**
|
|
|
|
|
* Represents the position of one swerve module.
|
|
|
|
|
*/
|
|
|
|
|
struct WPILIB_DLLEXPORT SwerveModulePosition {
|
|
|
|
|
/**
|
|
|
|
|
* Distance the wheel of a module has traveled
|
|
|
|
|
*/
|
|
|
|
|
units::meter_t distance = 0_m;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Angle of the module.
|
|
|
|
|
*/
|
|
|
|
|
Rotation2d angle;
|
2023-01-08 17:29:35 -07:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Checks equality between this SwerveModulePosition and another object.
|
|
|
|
|
*
|
|
|
|
|
* @param other The other object.
|
|
|
|
|
* @return Whether the two objects are equal.
|
|
|
|
|
*/
|
|
|
|
|
bool operator==(const SwerveModulePosition& other) const;
|
2023-06-19 17:10:39 -07:00
|
|
|
|
|
|
|
|
SwerveModulePosition Interpolate(const SwerveModulePosition& endValue,
|
|
|
|
|
double t) const {
|
|
|
|
|
return {wpi::Lerp(distance, endValue.distance, t),
|
|
|
|
|
wpi::Lerp(angle, endValue.angle, t)};
|
|
|
|
|
}
|
2022-10-25 15:28:36 -04:00
|
|
|
};
|
|
|
|
|
} // namespace frc
|
2023-11-21 13:14:06 -05:00
|
|
|
|
|
|
|
|
#include "frc/kinematics/proto/SwerveModulePositionProto.h"
|
|
|
|
|
#include "frc/kinematics/struct/SwerveModulePositionStruct.h"
|