blob: 4b5351e9a40f9dbca7ac5deebb7bd0488b9d4aad [file] [log] [blame]
milind-u086d7262022-01-19 20:44:18 -08001#ifndef Y2022_CONSTANTS_H_
2#define Y2022_CONSTANTS_H_
3
4#include <array>
5#include <cmath>
6#include <cstdint>
7
8#include "frc971/constants.h"
9#include "frc971/control_loops/pose.h"
10#include "frc971/control_loops/static_zeroing_single_dof_profiled_subsystem.h"
Ravago Jones3283ce02022-03-09 19:31:29 -080011#include "frc971/shooter_interpolation/interpolation.h"
milind-u086d7262022-01-19 20:44:18 -080012#include "y2022/control_loops/drivetrain/drivetrain_dog_motor_plant.h"
Austin Schuh39f26f62022-02-24 21:34:46 -080013#include "y2022/control_loops/superstructure/catapult/catapult_plant.h"
Henry Speiser55aa3ba2022-02-21 23:21:12 -080014#include "y2022/control_loops/superstructure/climber/climber_plant.h"
Yash Chainani997a7492022-01-29 15:48:56 -080015#include "y2022/control_loops/superstructure/intake/intake_plant.h"
Henry Speiser55aa3ba2022-02-21 23:21:12 -080016#include "y2022/control_loops/superstructure/turret/turret_plant.h"
milind-u086d7262022-01-19 20:44:18 -080017
Ravago Jones3283ce02022-03-09 19:31:29 -080018using ::frc971::shooter_interpolation::InterpolationTable;
19
milind-u086d7262022-01-19 20:44:18 -080020namespace y2022 {
21namespace constants {
22
23struct Values {
24 static const int kZeroingSampleSize = 200;
25
26 static constexpr double kDrivetrainCyclesPerRevolution() { return 512.0; }
27 static constexpr double kDrivetrainEncoderCountsPerRevolution() {
28 return kDrivetrainCyclesPerRevolution() * 4;
29 }
James Kuszmaulc2b2a802022-02-25 21:59:31 -080030 static constexpr double kDrivetrainEncoderRatio() { return 1.0; }
milind-u086d7262022-01-19 20:44:18 -080031 static constexpr double kMaxDrivetrainEncoderPulsesPerSecond() {
32 return control_loops::drivetrain::kFreeSpeed / (2.0 * M_PI) *
33 control_loops::drivetrain::kHighOutputRatio /
34 constants::Values::kDrivetrainEncoderRatio() *
35 kDrivetrainEncoderCountsPerRevolution();
36 }
James Kuszmaul53507e12022-02-12 18:36:40 -080037
38 static double DrivetrainEncoderToMeters(int32_t in) {
39 return ((static_cast<double>(in) /
40 kDrivetrainEncoderCountsPerRevolution()) *
41 (2.0 * M_PI)) *
Henry Speiser55aa3ba2022-02-21 23:21:12 -080042 kDrivetrainEncoderRatio() * control_loops::drivetrain::kWheelRadius;
Yash Chainani997a7492022-01-29 15:48:56 -080043 }
Siddhant Kanwar0e37f592022-02-21 19:26:50 -080044
milind-u086d7262022-01-19 20:44:18 -080045 // Climber
Siddhant Kanwar0e37f592022-02-21 19:26:50 -080046 static constexpr ::frc971::constants::Range kClimberRange() {
47 return ::frc971::constants::Range{
milind-u6e7d8d42022-04-06 18:30:43 -070048 .lower_hard = -0.01, .upper_hard = 0.59, .lower = 0.003, .upper = 0.555};
Siddhant Kanwar0e37f592022-02-21 19:26:50 -080049 }
50 static constexpr double kClimberPotMetersPerRevolution() {
51 return 22 * 0.25 * 0.0254;
52 }
53 static constexpr double kClimberPotRatio() { return 1.0; }
54
55 struct PotConstants {
56 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
57 ::frc971::zeroing::RelativeEncoderZeroingEstimator>
58 subsystem_params;
59 double potentiometer_offset;
60 };
61
62 PotConstants climber;
Milo Lin6b5e4582022-01-29 14:51:37 -080063
64 // Intake
65 // two encoders with same gear ratio for intake
Henry Speiser55aa3ba2022-02-21 23:21:12 -080066 static constexpr double kIntakeEncoderCountsPerRevolution() { return 4096.0; }
Milo Lin6b5e4582022-01-29 14:51:37 -080067
68 static constexpr double kIntakeEncoderRatio() {
Austin Schuh275f9812022-03-05 14:02:37 -080069 return (16.0 / 64.0) * (18.0 / 62.0);
Milo Lin6b5e4582022-01-29 14:51:37 -080070 }
71
Henry Speiser55aa3ba2022-02-21 23:21:12 -080072 static constexpr double kIntakePotRatio() { return 16.0 / 64.0; }
73
74 static constexpr double kMaxIntakeEncoderPulsesPerSecond() {
75 return control_loops::superstructure::intake::kFreeSpeed / (2.0 * M_PI) *
76 control_loops::superstructure::intake::kOutputRatio /
77 kIntakeEncoderRatio() * kIntakeEncoderCountsPerRevolution();
78 }
79
80 struct PotAndAbsEncoderConstants {
81 ::frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemParams<
82 ::frc971::zeroing::PotAndAbsoluteEncoderZeroingEstimator>
83 subsystem_params;
84 double potentiometer_offset;
85 };
86
87 PotAndAbsEncoderConstants intake_front;
88 PotAndAbsEncoderConstants intake_back;
89
90 // TODO (Yash): Constants need to be tuned
91 static constexpr ::frc971::constants::Range kIntakeRange() {
92 return ::frc971::constants::Range{
Austin Schuh465a2882022-03-05 15:39:04 -080093 .lower_hard = -0.85, // Back Hard
94 .upper_hard = 1.85, // Front Hard
95 .lower = -0.400, // Back Soft
96 .upper = 1.57 // Front Soft
Henry Speiser55aa3ba2022-02-21 23:21:12 -080097 };
98 }
99
100 // Intake rollers
101 static constexpr double kIntakeRollerSupplyCurrentLimit() { return 40.0; }
102 static constexpr double kIntakeRollerStatorCurrentLimit() { return 60.0; }
103
Ravago Jones5da06352022-03-04 20:26:24 -0800104 // Transfer rollers
Milind Upadhyayb1a74ea2022-03-09 20:34:35 -0800105 static constexpr double kTransferRollerVoltage() { return 12.0; }
Ravago Jones5da06352022-03-04 20:26:24 -0800106
107 // Voltage to wiggle the transfer rollers and keep a ball in.
Milind Upadhyayb1a74ea2022-03-09 20:34:35 -0800108 static constexpr double kTransferRollerWiggleVoltage() { return 3.0; }
109
Henry Speiser55aa3ba2022-02-21 23:21:12 -0800110 // Turret
111 PotAndAbsEncoderConstants turret;
112
113 // TODO (Yash): Constants need to be tuned
114 static constexpr ::frc971::constants::Range kTurretRange() {
115 return ::frc971::constants::Range{
Austin Schuh7a43d072022-03-13 21:19:06 -0700116 .lower_hard = -7.0, // Back Hard
milind-u6e7d8d42022-04-06 18:30:43 -0700117 .upper_hard = 3.4, // Front Hard
Austin Schuh7a43d072022-03-13 21:19:06 -0700118 .lower = -6.5, // Back Soft
milind-u6e7d8d42022-04-06 18:30:43 -0700119 .upper = 3.15 // Front Soft
Henry Speiser55aa3ba2022-02-21 23:21:12 -0800120 };
121 }
122
Austin Schuh42d7e5f2022-03-16 23:35:09 -0700123 static constexpr double kTurretBackIntakePos() { return -M_PI; }
Milind Upadhyay47e0d032022-03-05 23:06:25 -0800124 static constexpr double kTurretFrontIntakePos() { return 0; }
Ravago Jones5da06352022-03-04 20:26:24 -0800125
Henry Speiser55aa3ba2022-02-21 23:21:12 -0800126 static constexpr double kTurretPotRatio() { return 27.0 / 110.0; }
127 static constexpr double kTurretEncoderRatio() { return kTurretPotRatio(); }
128 static constexpr double kTurretEncoderCountsPerRevolution() { return 4096.0; }
129
130 static constexpr double kMaxTurretEncoderPulsesPerSecond() {
131 return control_loops::superstructure::turret::kFreeSpeed / (2.0 * M_PI) *
132 control_loops::superstructure::turret::kOutputRatio /
133 kTurretEncoderRatio() * kTurretEncoderCountsPerRevolution();
134 }
Griffin Buibcbef482022-02-23 15:32:10 -0800135
136 // Flipper arms
milind-u37dc40b2022-03-08 19:51:27 -0800137 static constexpr double kFlipperArmSupplyCurrentLimit() { return 40.0; }
138 static constexpr double kFlipperArmStatorCurrentLimit() { return 60.0; }
Griffin Buibcbef482022-02-23 15:32:10 -0800139
Ravago Jones5da06352022-03-04 20:26:24 -0800140 // Voltage to open the flippers for firing
141 static constexpr double kFlipperOpenVoltage() { return 3.0; }
142 // Voltage to keep the flippers open for firing once they already are
Austin Schuh465a2882022-03-05 15:39:04 -0800143 static constexpr double kFlipperHoldVoltage() { return 2.5; }
Ravago Jones5da06352022-03-04 20:26:24 -0800144 // Voltage to feed a ball from the transfer rollers to the catpult with the
145 // flippers
Milind Upadhyay47e0d032022-03-05 23:06:25 -0800146 static constexpr double kFlipperFeedVoltage() { return -12.0; }
Ravago Jones5da06352022-03-04 20:26:24 -0800147
148 // Ball is fed into catapult for atleast this time no matter what
149 static constexpr std::chrono::milliseconds kExtraLoadingTime() {
150 return std::chrono::milliseconds(100);
151 }
152 // If we have been trying to transfer the ball for this amount of time, it
153 // probably got lost so abort
154 static constexpr std::chrono::seconds kBallLostTime() {
155 return std::chrono::seconds(2);
156 }
157 // If the flippers took more than this amount of time to open for firing,
158 // reseat the ball
159 static constexpr std::chrono::milliseconds kFlipperOpeningTimeout() {
milind-u37dc40b2022-03-08 19:51:27 -0800160 return std::chrono::milliseconds(1000);
Ravago Jones5da06352022-03-04 20:26:24 -0800161 }
162 // Don't use flipper velocity readings more than this amount of time in the
163 // past
164 static constexpr std::chrono::milliseconds kFlipperVelocityValidTime() {
165 return std::chrono::milliseconds(100);
166 }
167
Griffin Buibcbef482022-02-23 15:32:10 -0800168 // TODO: (Griffin) this needs to be set
169 static constexpr ::frc971::constants::Range kFlipperArmRange() {
170 return ::frc971::constants::Range{
Austin Schuh465a2882022-03-05 15:39:04 -0800171 .lower_hard = -0.01, .upper_hard = 0.4, .lower = 0.0, .upper = 0.5};
Griffin Buibcbef482022-02-23 15:32:10 -0800172 }
Ravago Jones5da06352022-03-04 20:26:24 -0800173 // Position of the flippers when they are open
Austin Schuh6b1e4d92022-03-12 12:02:46 -0800174 static constexpr double kFlipperOpenPosition() { return 0.20; }
Ravago Jones5da06352022-03-04 20:26:24 -0800175 // If the flippers were open but now moved back, reseat the ball if they go
176 // below this position
Austin Schuh465a2882022-03-05 15:39:04 -0800177 static constexpr double kReseatFlipperPosition() { return 0.1; }
Griffin Buibcbef482022-02-23 15:32:10 -0800178
179 static constexpr double kFlipperArmsPotRatio() { return 16.0 / 36.0; }
180
181 PotConstants flipper_arm_left;
182 PotConstants flipper_arm_right;
Austin Schuh39f26f62022-02-24 21:34:46 -0800183
184 // Catapult.
185 static constexpr double kCatapultPotRatio() { return (12.0 / 33.0); }
186 static constexpr double kCatapultEncoderRatio() {
187 return kCatapultPotRatio();
188 }
189 static constexpr double kCatapultEncoderCountsPerRevolution() {
190 return 4096.0;
191 }
192
193 static constexpr double kMaxCatapultEncoderPulsesPerSecond() {
194 return control_loops::superstructure::catapult::kFreeSpeed / (2.0 * M_PI) *
195 control_loops::superstructure::catapult::kOutputRatio /
196 kCatapultEncoderRatio() * kCatapultEncoderCountsPerRevolution();
197 }
198 static constexpr ::frc971::constants::Range kCatapultRange() {
199 return ::frc971::constants::Range{
Milind Upadhyay47e0d032022-03-05 23:06:25 -0800200 .lower_hard = -1.0,
Austin Schuh39f26f62022-02-24 21:34:46 -0800201 .upper_hard = 2.0,
milind-u37dc40b2022-03-08 19:51:27 -0800202 .lower = -0.91,
Austin Schuh39f26f62022-02-24 21:34:46 -0800203 .upper = 1.57,
204 };
205 }
206
207 PotAndAbsEncoderConstants catapult;
milind-ucafdd5d2022-03-01 19:58:57 -0800208
209 // TODO(milind): set this
210 static constexpr double kImuHeight() { return 0.0; }
Ravago Jones3283ce02022-03-09 19:31:29 -0800211
212 struct ShotParams {
213 // Measured in radians
214 double shot_angle;
215 // Muzzle velocity (m/s) of the ball as it is released from the catapult.
216 double shot_velocity;
217
218 static ShotParams BlendY(double coefficient, ShotParams a1, ShotParams a2) {
219 using ::frc971::shooter_interpolation::Blend;
220 return ShotParams{
James Kuszmaulb9ba9a52022-03-31 22:16:01 -0700221 .shot_angle = Blend(coefficient, a1.shot_angle, a2.shot_angle),
222 .shot_velocity =
223 Blend(coefficient, a1.shot_velocity, a2.shot_velocity),
Ravago Jones3283ce02022-03-09 19:31:29 -0800224 };
225 }
226 };
227
James Kuszmaulb9ba9a52022-03-31 22:16:01 -0700228 struct ShotVelocityParams {
229 // Speed over ground to use for shooting-on-the-fly.
230 double shot_speed_over_ground;
231
232 static ShotVelocityParams BlendY(double coefficient, ShotVelocityParams a1,
233 ShotVelocityParams a2) {
234 using ::frc971::shooter_interpolation::Blend;
235 return ShotVelocityParams{Blend(coefficient, a1.shot_speed_over_ground,
236 a2.shot_speed_over_ground)};
237 }
238 };
239
Ravago Jones3283ce02022-03-09 19:31:29 -0800240 InterpolationTable<ShotParams> shot_interpolation_table;
James Kuszmaulb9ba9a52022-03-31 22:16:01 -0700241
242 InterpolationTable<ShotVelocityParams> shot_velocity_interpolation_table;
milind-u086d7262022-01-19 20:44:18 -0800243};
244
Henry Speiser55aa3ba2022-02-21 23:21:12 -0800245// Creates and returns a Values instance for the constants.
246// Should be called before realtime because this allocates memory.
247// Only the first call to either of these will be used.
248Values MakeValues(uint16_t team);
milind-u086d7262022-01-19 20:44:18 -0800249
Henry Speiser55aa3ba2022-02-21 23:21:12 -0800250// Calls MakeValues with aos::network::GetTeamNumber()
251Values MakeValues();
milind-u086d7262022-01-19 20:44:18 -0800252
253} // namespace constants
254} // namespace y2022
255
256#endif // Y2022_CONSTANTS_H_