Comran Morshed | 5323ecb | 2015-12-26 20:50:55 +0000 | [diff] [blame] | 1 | #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 | |
| 9 | namespace frc971 { |
| 10 | namespace control_loops { |
| 11 | namespace drivetrain { |
| 12 | |
| 13 | enum class ShifterType : int32_t { |
| 14 | HALL_EFFECT_SHIFTER = 0, // Detect when inbetween gears. |
Adam Snaider | 18f4417 | 2016-10-22 15:30:21 -0700 | [diff] [blame] | 15 | SIMPLE_SHIFTER = 1, // Switch gears without speedmatch logic. |
| 16 | NO_SHIFTER = 2, // Only one gear ratio. |
Comran Morshed | 5323ecb | 2015-12-26 20:50:55 +0000 | [diff] [blame] | 17 | }; |
| 18 | |
Comran Morshed | 76ca8f5 | 2016-02-21 17:26:28 +0000 | [diff] [blame] | 19 | enum class LoopType : int32_t { |
Adam Snaider | 18f4417 | 2016-10-22 15:30:21 -0700 | [diff] [blame] | 20 | OPEN_LOOP = 0, // Only use open loop logic. |
Comran Morshed | 76ca8f5 | 2016-02-21 17:26:28 +0000 | [diff] [blame] | 21 | CLOSED_LOOP = 1, // Add in closed loop calculation. |
| 22 | }; |
| 23 | |
Campbell Crowley | 2527ed2 | 2017-02-17 21:10:02 -0800 | [diff] [blame^] | 24 | enum 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 | |
Comran Morshed | 5323ecb | 2015-12-26 20:50:55 +0000 | [diff] [blame] | 32 | struct DrivetrainConfig { |
| 33 | // Shifting method we are using. |
| 34 | ShifterType shifter_type; |
| 35 | |
Comran Morshed | 76ca8f5 | 2016-02-21 17:26:28 +0000 | [diff] [blame] | 36 | // Type of loop to use. |
| 37 | LoopType loop_type; |
| 38 | |
Campbell Crowley | 2527ed2 | 2017-02-17 21:10:02 -0800 | [diff] [blame^] | 39 | // Type of gyro to use. |
| 40 | GyroType gyro_type; |
| 41 | |
Comran Morshed | 5323ecb | 2015-12-26 20:50:55 +0000 | [diff] [blame] | 42 | // Polydrivetrain functions returning various controller loops with plants. |
| 43 | ::std::function<StateFeedbackLoop<4, 2, 2>()> make_drivetrain_loop; |
| 44 | ::std::function<StateFeedbackLoop<2, 2, 2>()> make_v_drivetrain_loop; |
| 45 | ::std::function<StateFeedbackLoop<7, 2, 3>()> make_kf_drivetrain_loop; |
| 46 | |
Adam Snaider | 18f4417 | 2016-10-22 15:30:21 -0700 | [diff] [blame] | 47 | double dt; // Control loop time step. |
Comran Morshed | 5323ecb | 2015-12-26 20:50:55 +0000 | [diff] [blame] | 48 | double robot_radius; // Robot radius, in meters. |
| 49 | double wheel_radius; // Wheel radius, in meters. |
Adam Snaider | 18f4417 | 2016-10-22 15:30:21 -0700 | [diff] [blame] | 50 | double v; // Motor velocity constant. |
Comran Morshed | 5323ecb | 2015-12-26 20:50:55 +0000 | [diff] [blame] | 51 | |
Austin Schuh | 09fa9bb | 2016-02-16 11:47:40 -0800 | [diff] [blame] | 52 | // Gear ratios, from wheel to motor shaft. |
Comran Morshed | 5323ecb | 2015-12-26 20:50:55 +0000 | [diff] [blame] | 53 | double high_gear_ratio; |
| 54 | double low_gear_ratio; |
| 55 | |
| 56 | // Hall effect constants. Unused if not applicable to shifter type. |
| 57 | constants::ShifterHallEffect left_drive; |
| 58 | constants::ShifterHallEffect right_drive; |
Adam Snaider | bc918b6 | 2016-02-27 21:03:39 -0800 | [diff] [blame] | 59 | |
| 60 | // Variable that holds the default gear ratio. We use this in ZeroOutputs(). |
| 61 | // (ie. true means high gear is default). |
| 62 | bool default_high_gear; |
Austin Schuh | 889fee8 | 2016-04-13 22:16:36 -0700 | [diff] [blame] | 63 | |
| 64 | double down_offset; |
Adam Snaider | 94a5237 | 2016-10-19 20:06:01 -0700 | [diff] [blame] | 65 | |
| 66 | double wheel_non_linearity; |
| 67 | |
| 68 | double quickturn_wheel_multiplier; |
Austin Schuh | d91c0d2 | 2016-10-15 21:24:28 -0700 | [diff] [blame] | 69 | |
| 70 | // Converts the robot state to a linear distance position, velocity. |
| 71 | static Eigen::Matrix<double, 2, 1> LeftRightToLinear( |
| 72 | const Eigen::Matrix<double, 7, 1> &left_right) { |
| 73 | Eigen::Matrix<double, 2, 1> linear; |
| 74 | linear(0, 0) = (left_right(0, 0) + left_right(2, 0)) / 2.0; |
| 75 | linear(1, 0) = (left_right(1, 0) + left_right(3, 0)) / 2.0; |
| 76 | return linear; |
| 77 | } |
| 78 | // Converts the robot state to an anglular distance, velocity. |
| 79 | Eigen::Matrix<double, 2, 1> LeftRightToAngular( |
| 80 | const Eigen::Matrix<double, 7, 1> &left_right) const { |
| 81 | Eigen::Matrix<double, 2, 1> angular; |
| 82 | angular(0, 0) = |
| 83 | (left_right(2, 0) - left_right(0, 0)) / (this->robot_radius * 2.0); |
| 84 | angular(1, 0) = |
| 85 | (left_right(3, 0) - left_right(1, 0)) / (this->robot_radius * 2.0); |
| 86 | return angular; |
| 87 | } |
| 88 | |
| 89 | // Converts the linear and angular position, velocity to the top 4 states of |
| 90 | // the robot state. |
| 91 | Eigen::Matrix<double, 4, 1> AngularLinearToLeftRight( |
| 92 | const Eigen::Matrix<double, 2, 1> &linear, |
| 93 | const Eigen::Matrix<double, 2, 1> &angular) const { |
| 94 | Eigen::Matrix<double, 2, 1> scaled_angle = |
| 95 | angular * this->robot_radius; |
| 96 | Eigen::Matrix<double, 4, 1> state; |
| 97 | state(0, 0) = linear(0, 0) - scaled_angle(0, 0); |
| 98 | state(1, 0) = linear(1, 0) - scaled_angle(1, 0); |
| 99 | state(2, 0) = linear(0, 0) + scaled_angle(0, 0); |
| 100 | state(3, 0) = linear(1, 0) + scaled_angle(1, 0); |
| 101 | return state; |
| 102 | } |
Comran Morshed | 5323ecb | 2015-12-26 20:50:55 +0000 | [diff] [blame] | 103 | }; |
| 104 | |
| 105 | } // namespace drivetrain |
| 106 | } // namespace control_loops |
| 107 | } // namespace frc971 |
| 108 | |
| 109 | #endif // FRC971_CONTROL_LOOPS_DRIVETRAIN_CONSTANTS_H_ |