blob: 6e546a38c0d3d94d03ffcad64e29a4acff597c3f [file] [log] [blame]
Comran Morshed5323ecb2015-12-26 20:50:55 +00001#ifndef FRC971_CONTROL_LOOPS_DRIVETRAIN_CONSTANTS_H_
2#define FRC971_CONTROL_LOOPS_DRIVETRAIN_CONSTANTS_H_
3
4#include <functional>
5
6#include "frc971/shifter_hall_effect.h"
7#include "frc971/control_loops/state_feedback_loop.h"
8
9namespace frc971 {
10namespace control_loops {
11namespace drivetrain {
12
13enum class ShifterType : int32_t {
14 HALL_EFFECT_SHIFTER = 0, // Detect when inbetween gears.
Adam Snaider18f44172016-10-22 15:30:21 -070015 SIMPLE_SHIFTER = 1, // Switch gears without speedmatch logic.
16 NO_SHIFTER = 2, // Only one gear ratio.
Comran Morshed5323ecb2015-12-26 20:50:55 +000017};
18
Comran Morshed76ca8f52016-02-21 17:26:28 +000019enum class LoopType : int32_t {
Adam Snaider18f44172016-10-22 15:30:21 -070020 OPEN_LOOP = 0, // Only use open loop logic.
Comran Morshed76ca8f52016-02-21 17:26:28 +000021 CLOSED_LOOP = 1, // Add in closed loop calculation.
22};
23
Campbell Crowley2527ed22017-02-17 21:10:02 -080024enum class GyroType : int32_t {
25 SPARTAN_GYRO = 0, // Use the gyro on the spartan board.
26 IMU_X_GYRO = 1, // Use the x-axis of the gyro on the IMU.
27 IMU_Y_GYRO = 2, // Use the y-axis of the gyro on the IMU.
28 IMU_Z_GYRO = 3, // Use the z-axis of the gyro on the IMU.
29 FLIPPED_SPARTAN_GYRO = 4, // Use the gyro on the spartan board.
30};
31
Diana Burgessd0180f12018-03-21 21:24:17 -070032enum class IMUType : int32_t {
33 IMU_X = 0, // Use the x-axis of the IMU.
34 IMU_Y = 1, // Use the y-axis of the IMU.
35};
36
Austin Schuhbcce26a2018-03-26 23:41:24 -070037template <typename Scalar = double>
Comran Morshed5323ecb2015-12-26 20:50:55 +000038struct DrivetrainConfig {
39 // Shifting method we are using.
40 ShifterType shifter_type;
41
Comran Morshed76ca8f52016-02-21 17:26:28 +000042 // Type of loop to use.
43 LoopType loop_type;
44
Campbell Crowley2527ed22017-02-17 21:10:02 -080045 // Type of gyro to use.
46 GyroType gyro_type;
47
Diana Burgessd0180f12018-03-21 21:24:17 -070048 // Type of IMU to use.
49 IMUType imu_type;
50
Comran Morshed5323ecb2015-12-26 20:50:55 +000051 // Polydrivetrain functions returning various controller loops with plants.
Austin Schuhbcce26a2018-03-26 23:41:24 -070052 ::std::function<StateFeedbackLoop<4, 2, 2, Scalar>()> make_drivetrain_loop;
53 ::std::function<StateFeedbackLoop<2, 2, 2, Scalar>()> make_v_drivetrain_loop;
54 ::std::function<StateFeedbackLoop<7, 2, 4, Scalar>()> make_kf_drivetrain_loop;
Comran Morshed5323ecb2015-12-26 20:50:55 +000055
Austin Schuhbcce26a2018-03-26 23:41:24 -070056 Scalar dt; // Control loop time step.
57 Scalar robot_radius; // Robot radius, in meters.
58 Scalar wheel_radius; // Wheel radius, in meters.
59 Scalar v; // Motor velocity constant.
Comran Morshed5323ecb2015-12-26 20:50:55 +000060
Austin Schuh09fa9bb2016-02-16 11:47:40 -080061 // Gear ratios, from wheel to motor shaft.
Austin Schuhbcce26a2018-03-26 23:41:24 -070062 Scalar high_gear_ratio;
63 Scalar low_gear_ratio;
Comran Morshed5323ecb2015-12-26 20:50:55 +000064
65 // Hall effect constants. Unused if not applicable to shifter type.
66 constants::ShifterHallEffect left_drive;
67 constants::ShifterHallEffect right_drive;
Adam Snaiderbc918b62016-02-27 21:03:39 -080068
69 // Variable that holds the default gear ratio. We use this in ZeroOutputs().
70 // (ie. true means high gear is default).
71 bool default_high_gear;
Austin Schuh889fee82016-04-13 22:16:36 -070072
Austin Schuhbcce26a2018-03-26 23:41:24 -070073 Scalar down_offset;
Adam Snaider94a52372016-10-19 20:06:01 -070074
Austin Schuhbcce26a2018-03-26 23:41:24 -070075 Scalar wheel_non_linearity;
Adam Snaider94a52372016-10-19 20:06:01 -070076
Austin Schuhbcce26a2018-03-26 23:41:24 -070077 Scalar quickturn_wheel_multiplier;
Austin Schuhd91c0d22016-10-15 21:24:28 -070078
Austin Schuhbcce26a2018-03-26 23:41:24 -070079 Scalar wheel_multiplier;
Austin Schuhe8a54c02018-03-05 00:25:58 -080080
Austin Schuhd91c0d22016-10-15 21:24:28 -070081 // Converts the robot state to a linear distance position, velocity.
Austin Schuhbcce26a2018-03-26 23:41:24 -070082 static Eigen::Matrix<Scalar, 2, 1> LeftRightToLinear(
83 const Eigen::Matrix<Scalar, 7, 1> &left_right) {
84 Eigen::Matrix<Scalar, 2, 1> linear;
Austin Schuhd91c0d22016-10-15 21:24:28 -070085 linear(0, 0) = (left_right(0, 0) + left_right(2, 0)) / 2.0;
86 linear(1, 0) = (left_right(1, 0) + left_right(3, 0)) / 2.0;
87 return linear;
88 }
89 // Converts the robot state to an anglular distance, velocity.
Austin Schuhbcce26a2018-03-26 23:41:24 -070090 Eigen::Matrix<Scalar, 2, 1> LeftRightToAngular(
91 const Eigen::Matrix<Scalar, 7, 1> &left_right) const {
92 Eigen::Matrix<Scalar, 2, 1> angular;
Austin Schuhd91c0d22016-10-15 21:24:28 -070093 angular(0, 0) =
94 (left_right(2, 0) - left_right(0, 0)) / (this->robot_radius * 2.0);
95 angular(1, 0) =
96 (left_right(3, 0) - left_right(1, 0)) / (this->robot_radius * 2.0);
97 return angular;
98 }
99
100 // Converts the linear and angular position, velocity to the top 4 states of
101 // the robot state.
Austin Schuhbcce26a2018-03-26 23:41:24 -0700102 Eigen::Matrix<Scalar, 4, 1> AngularLinearToLeftRight(
103 const Eigen::Matrix<Scalar, 2, 1> &linear,
104 const Eigen::Matrix<Scalar, 2, 1> &angular) const {
105 Eigen::Matrix<Scalar, 2, 1> scaled_angle =
Austin Schuhd91c0d22016-10-15 21:24:28 -0700106 angular * this->robot_radius;
Austin Schuhbcce26a2018-03-26 23:41:24 -0700107 Eigen::Matrix<Scalar, 4, 1> state;
Austin Schuhd91c0d22016-10-15 21:24:28 -0700108 state(0, 0) = linear(0, 0) - scaled_angle(0, 0);
109 state(1, 0) = linear(1, 0) - scaled_angle(1, 0);
110 state(2, 0) = linear(0, 0) + scaled_angle(0, 0);
111 state(3, 0) = linear(1, 0) + scaled_angle(1, 0);
112 return state;
113 }
Comran Morshed5323ecb2015-12-26 20:50:55 +0000114};
Comran Morshed5323ecb2015-12-26 20:50:55 +0000115} // namespace drivetrain
116} // namespace control_loops
117} // namespace frc971
118
119#endif // FRC971_CONTROL_LOOPS_DRIVETRAIN_CONSTANTS_H_