blob: baaa2eebf6d2f9f19031bc17b12ef27f5d0eed08 [file] [log] [blame]
milind-u086d7262022-01-19 20:44:18 -08001#include <unistd.h>
2
3#include <cmath>
4#include <cstdio>
5#include <cstring>
6
7#include "aos/actions/actions.h"
8#include "aos/init.h"
9#include "aos/logging/logging.h"
10#include "aos/network/team_number.h"
11#include "aos/util/log_interval.h"
12#include "frc971/autonomous/base_autonomous_actor.h"
Henry Speiser0b9b0052022-03-02 23:07:40 -080013#include "frc971/control_loops/drivetrain/localizer_generated.h"
Austin Schuh39f26f62022-02-24 21:34:46 -080014#include "frc971/control_loops/profiled_subsystem_generated.h"
milind-u086d7262022-01-19 20:44:18 -080015#include "frc971/input/action_joystick_input.h"
16#include "frc971/input/driver_station_data.h"
17#include "frc971/input/drivetrain_input.h"
18#include "frc971/input/joystick_input.h"
Henry Speiser0b9b0052022-03-02 23:07:40 -080019#include "frc971/zeroing/wrap.h"
20#include "y2022/constants.h"
milind-u086d7262022-01-19 20:44:18 -080021#include "y2022/control_loops/drivetrain/drivetrain_base.h"
22#include "y2022/control_loops/superstructure/superstructure_goal_generated.h"
23#include "y2022/control_loops/superstructure/superstructure_status_generated.h"
Henry Speiser0b9b0052022-03-02 23:07:40 -080024#include "y2022/setpoint_generated.h"
milind-u086d7262022-01-19 20:44:18 -080025
Henry Speiser0b9b0052022-03-02 23:07:40 -080026using frc971::CreateProfileParameters;
27using frc971::control_loops::CreateStaticZeroingSingleDOFProfiledSubsystemGoal;
Austin Schuh39f26f62022-02-24 21:34:46 -080028using frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemGoal;
milind-u086d7262022-01-19 20:44:18 -080029using frc971::input::driver_station::ButtonLocation;
30using frc971::input::driver_station::ControlBit;
31using frc971::input::driver_station::JoystickAxis;
32using frc971::input::driver_station::POVLocation;
33
34namespace y2022 {
35namespace input {
36namespace joysticks {
37
38namespace superstructure = y2022::control_loops::superstructure;
39
milind-u37dc40b2022-03-08 19:51:27 -080040#if 0
Austin Schuh445ae832022-03-05 22:52:23 -080041const ButtonLocation kCatapultPos(4, 3);
42const ButtonLocation kFire(3, 4);
milind-u37dc40b2022-03-08 19:51:27 -080043const ButtonLocation kTurret(4, 15);
Milind Upadhyay9a4ae572022-03-12 12:52:06 -080044const ButtonLocation kAutoAim(4, 2);
Henry Speiser0b9b0052022-03-02 23:07:40 -080045
Austin Schuh445ae832022-03-05 22:52:23 -080046const ButtonLocation kIntakeFrontOut(4, 10);
47const ButtonLocation kIntakeBackOut(4, 9);
Milind Upadhyay29dcc172022-04-02 19:21:30 -070048const ButtonLocation kSpitFront(3, 3);
49const ButtonLocation kSpitBack(2, 3);
Henry Speiser0b9b0052022-03-02 23:07:40 -080050
51const ButtonLocation kRedLocalizerReset(3, 13);
52const ButtonLocation kBlueLocalizerReset(3, 14);
53const ButtonLocation kLocalizerReset(3, 8);
milind-u37dc40b2022-03-08 19:51:27 -080054#else
55
56const ButtonLocation kCatapultPos(4, 3);
57const ButtonLocation kFire(4, 1);
58const ButtonLocation kTurret(4, 15);
Austin Schuh92908812022-03-27 14:14:05 -070059const ButtonLocation kAutoAim(4, 16);
milind-u37dc40b2022-03-08 19:51:27 -080060
Austin Schuh8507c9f2022-03-13 18:08:28 -070061const ButtonLocation kClimberExtend(4, 6);
Austin Schuh0e209102022-03-13 19:39:42 -070062const ButtonLocation kClimberIntakes(4, 5);
Austin Schuh8507c9f2022-03-13 18:08:28 -070063
milind-u37dc40b2022-03-08 19:51:27 -080064const ButtonLocation kIntakeFrontOut(4, 10);
65const ButtonLocation kIntakeBackOut(4, 9);
Milind Upadhyay29dcc172022-04-02 19:21:30 -070066const ButtonLocation kSpitFront(3, 3);
Austin Schuhb4dd9282022-04-02 22:40:40 -070067const ButtonLocation kSpitBack(3, 1);
milind-u37dc40b2022-03-08 19:51:27 -080068
James Kuszmaul7fc03ce2022-03-12 15:31:24 -080069const ButtonLocation kRedLocalizerReset(4, 14);
70const ButtonLocation kBlueLocalizerReset(4, 13);
milind-u37dc40b2022-03-08 19:51:27 -080071const ButtonLocation kLocalizerReset(3, 8);
72#endif
Henry Speiser0b9b0052022-03-02 23:07:40 -080073
milind-u086d7262022-01-19 20:44:18 -080074class Reader : public ::frc971::input::ActionJoystickInput {
75 public:
76 Reader(::aos::EventLoop *event_loop)
77 : ::frc971::input::ActionJoystickInput(
78 event_loop,
79 ::y2022::control_loops::drivetrain::GetDrivetrainConfig(),
80 ::frc971::input::DrivetrainInputReader::InputType::kPistol, {}),
81 superstructure_goal_sender_(
82 event_loop->MakeSender<superstructure::Goal>("/superstructure")),
Henry Speiser0b9b0052022-03-02 23:07:40 -080083 localizer_control_sender_(
84 event_loop->MakeSender<
85 ::frc971::control_loops::drivetrain::LocalizerControl>(
86 "/drivetrain")),
milind-u086d7262022-01-19 20:44:18 -080087 superstructure_status_fetcher_(
Henry Speiser0b9b0052022-03-02 23:07:40 -080088 event_loop->MakeFetcher<superstructure::Status>("/superstructure")),
89 setpoint_fetcher_(
90 event_loop->MakeFetcher<Setpoint>("/superstructure")) {}
91
James Kuszmaul7fc03ce2022-03-12 15:31:24 -080092 // Localizer reset positions are with front of robot pressed up against driver
93 // station in the middle of the field side-to-side.
Henry Speiser0b9b0052022-03-02 23:07:40 -080094 void BlueResetLocalizer() {
95 auto builder = localizer_control_sender_.MakeBuilder();
96
97 frc971::control_loops::drivetrain::LocalizerControl::Builder
98 localizer_control_builder = builder.MakeBuilder<
99 frc971::control_loops::drivetrain::LocalizerControl>();
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800100 localizer_control_builder.add_x(-7.9);
101 localizer_control_builder.add_y(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800102 localizer_control_builder.add_theta_uncertainty(10.0);
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800103 localizer_control_builder.add_theta(M_PI);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800104 localizer_control_builder.add_keep_current_theta(false);
105 if (builder.Send(localizer_control_builder.Finish()) !=
106 aos::RawSender::Error::kOk) {
107 AOS_LOG(ERROR, "Failed to reset blue localizer.\n");
108 }
109 }
110
111 void RedResetLocalizer() {
112 auto builder = localizer_control_sender_.MakeBuilder();
113
114 frc971::control_loops::drivetrain::LocalizerControl::Builder
115 localizer_control_builder = builder.MakeBuilder<
116 frc971::control_loops::drivetrain::LocalizerControl>();
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800117 localizer_control_builder.add_x(7.9);
118 localizer_control_builder.add_y(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800119 localizer_control_builder.add_theta_uncertainty(10.0);
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800120 localizer_control_builder.add_theta(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800121 localizer_control_builder.add_keep_current_theta(false);
122 if (builder.Send(localizer_control_builder.Finish()) !=
123 aos::RawSender::Error::kOk) {
124 AOS_LOG(ERROR, "Failed to reset red localizer.\n");
125 }
126 }
127
128 void ResetLocalizer() {
129 const frc971::control_loops::drivetrain::Status *drivetrain_status =
130 this->drivetrain_status();
131 if (drivetrain_status == nullptr) {
132 return;
133 }
134 // Get the current position
135 // Snap to heading.
136 auto builder = localizer_control_sender_.MakeBuilder();
137
138 // TODO<Henry> Put our starting location here.
139 frc971::control_loops::drivetrain::LocalizerControl::Builder
140 localizer_control_builder = builder.MakeBuilder<
141 frc971::control_loops::drivetrain::LocalizerControl>();
142 localizer_control_builder.add_x(drivetrain_status->x());
143 localizer_control_builder.add_y(drivetrain_status->y());
144 const double new_theta =
145 frc971::zeroing::Wrap(drivetrain_status->theta(), 0, M_PI);
146 localizer_control_builder.add_theta(new_theta);
147 localizer_control_builder.add_theta_uncertainty(10.0);
148 if (builder.Send(localizer_control_builder.Finish()) !=
149 aos::RawSender::Error::kOk) {
150 AOS_LOG(ERROR, "Failed to reset localizer.\n");
151 }
152 }
milind-u086d7262022-01-19 20:44:18 -0800153
154 void AutoEnded() override { AOS_LOG(INFO, "Auto ended.\n"); }
155
156 void HandleTeleop(
Austin Schuh39f26f62022-02-24 21:34:46 -0800157 const ::frc971::input::driver_station::Data &data) override {
milind-u086d7262022-01-19 20:44:18 -0800158 superstructure_status_fetcher_.Fetch();
159 if (!superstructure_status_fetcher_.get()) {
160 AOS_LOG(ERROR, "Got no superstructure status message.\n");
161 return;
162 }
Austin Schuh39f26f62022-02-24 21:34:46 -0800163
Henry Speiser0b9b0052022-03-02 23:07:40 -0800164 setpoint_fetcher_.Fetch();
Austin Schuh39f26f62022-02-24 21:34:46 -0800165
Henry Speiser0b9b0052022-03-02 23:07:40 -0800166 // Default to the intakes in
Austin Schuh0e209102022-03-13 19:39:42 -0700167 constexpr double kIntakeUpPosition = 1.47;
168 double intake_front_pos = kIntakeUpPosition;
169 double intake_back_pos = kIntakeUpPosition;
Milind Upadhyay29dcc172022-04-02 19:21:30 -0700170 double transfer_roller_speed = 0.0;
James Kuszmaul40526952022-03-13 15:56:38 -0700171 std::optional<control_loops::superstructure::RequestedIntake>
172 requested_intake;
Austin Schuh39f26f62022-02-24 21:34:46 -0800173
Henry Speiser0b9b0052022-03-02 23:07:40 -0800174 double roller_front_speed = 0.0;
175 double roller_back_speed = 0.0;
Austin Schuh39f26f62022-02-24 21:34:46 -0800176
Austin Schuh92908812022-03-27 14:14:05 -0700177 std::optional<double> turret_pos = std::nullopt;
Austin Schuh39f26f62022-02-24 21:34:46 -0800178
Austin Schuh8507c9f2022-03-13 18:08:28 -0700179 double climber_position = 0.01;
180
milind-u37dc40b2022-03-08 19:51:27 -0800181 double catapult_pos = 0.03;
182 double catapult_speed = 18.0;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800183 double catapult_return_pos = 0.0;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800184 bool fire = false;
Austin Schuh39f26f62022-02-24 21:34:46 -0800185
Henry Speiser0b9b0052022-03-02 23:07:40 -0800186 if (data.PosEdge(kLocalizerReset)) {
187 ResetLocalizer();
188 }
189
190 if (data.PosEdge(kRedLocalizerReset)) {
191 RedResetLocalizer();
192 }
193 if (data.PosEdge(kBlueLocalizerReset)) {
194 BlueResetLocalizer();
195 }
196
Austin Schuh8507c9f2022-03-13 18:08:28 -0700197 if (data.IsPressed(kClimberExtend)) {
198 climber_position = 0.50;
199 } else {
200 climber_position = 0.01;
201 }
202
milind-u37dc40b2022-03-08 19:51:27 -0800203 if (data.IsPressed(kTurret)) {
Milind Upadhyay9cb14212022-03-11 21:42:35 -0800204 if (setpoint_fetcher_.get()) {
205 turret_pos = setpoint_fetcher_->turret();
206 } else {
207 turret_pos = -1.5;
208 }
milind-u37dc40b2022-03-08 19:51:27 -0800209 }
210
Milind Upadhyay9cb14212022-03-11 21:42:35 -0800211 if (setpoint_fetcher_.get()) {
212 catapult_pos = setpoint_fetcher_->catapult_position();
213 catapult_speed = setpoint_fetcher_->catapult_velocity();
214 }
215
Austin Schuh445ae832022-03-05 22:52:23 -0800216 // Keep the catapult return position at the shot one if kCatapultPos is
217 // pressed
218 if (data.IsPressed(kCatapultPos)) {
Austin Schuhda7e3e12022-03-26 15:14:31 -0700219 catapult_return_pos = 0.7;
Austin Schuh445ae832022-03-05 22:52:23 -0800220 } else {
milind-u37dc40b2022-03-08 19:51:27 -0800221 catapult_return_pos = -0.908;
Austin Schuh445ae832022-03-05 22:52:23 -0800222 }
223
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800224 constexpr double kRollerSpeed = 8.0;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800225 constexpr double kTransferRollerSpeed = 12.0;
Austin Schuhc9b42db2022-03-12 12:03:29 -0800226 constexpr double kIntakePosition = -0.02;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800227 constexpr size_t kIntakeCounterIterations = 25;
228
Milind Upadhyay2a490f82022-04-02 22:20:55 -0700229 // Extend the intakes and spin the rollers.
230 // Don't let this happen if there is a ball in the other intake, because
231 // that would spit this one out.
232 if (data.IsPressed(kIntakeFrontOut) &&
233 !superstructure_status_fetcher_->back_intake_has_ball()) {
Austin Schuhc9b42db2022-03-12 12:03:29 -0800234 intake_front_pos = kIntakePosition;
Milind Upadhyay29dcc172022-04-02 19:21:30 -0700235 transfer_roller_speed = kTransferRollerSpeed;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800236
237 intake_front_counter_ = kIntakeCounterIterations;
James Kuszmaul40526952022-03-13 15:56:38 -0700238 intake_back_counter_ = 0;
Milind Upadhyay2a490f82022-04-02 22:20:55 -0700239 } else if (data.IsPressed(kIntakeBackOut) &&
240 !superstructure_status_fetcher_->front_intake_has_ball()) {
Austin Schuhc9b42db2022-03-12 12:03:29 -0800241 intake_back_pos = kIntakePosition;
Milind Upadhyay29dcc172022-04-02 19:21:30 -0700242 transfer_roller_speed = -kTransferRollerSpeed;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800243
244 intake_back_counter_ = kIntakeCounterIterations;
James Kuszmaul40526952022-03-13 15:56:38 -0700245 intake_front_counter_ = 0;
Milind Upadhyay29dcc172022-04-02 19:21:30 -0700246 } else if (data.IsPressed(kSpitFront)) {
247 transfer_roller_speed = -kTransferRollerSpeed;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800248 intake_front_counter_ = 0;
Milind Upadhyay29dcc172022-04-02 19:21:30 -0700249 } else if (data.IsPressed(kSpitBack)) {
250 transfer_roller_speed = kTransferRollerSpeed;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800251 intake_back_counter_ = 0;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800252 }
253
254 // Keep spinning the rollers a bit after they let go
255 if (intake_front_counter_ > 0) {
256 intake_front_counter_--;
257 roller_front_speed = kRollerSpeed;
James Kuszmaul40526952022-03-13 15:56:38 -0700258 requested_intake = control_loops::superstructure::RequestedIntake::kFront;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800259 }
260 if (intake_back_counter_ > 0) {
261 intake_back_counter_--;
262 roller_back_speed = kRollerSpeed;
James Kuszmaul40526952022-03-13 15:56:38 -0700263 requested_intake = control_loops::superstructure::RequestedIntake::kBack;
Austin Schuh445ae832022-03-05 22:52:23 -0800264 }
265
266 if (data.IsPressed(kFire)) {
267 fire = true;
James Kuszmaul916982d2022-03-13 19:53:10 -0700268 // Provide a default turret goal.
Austin Schuh445ae832022-03-05 22:52:23 -0800269 }
270
Austin Schuh0e209102022-03-13 19:39:42 -0700271 if (data.IsPressed(kClimberIntakes)) {
272 intake_back_pos = kIntakeUpPosition;
273 intake_front_pos = kIntakePosition;
274 }
275
Henry Speiser0b9b0052022-03-02 23:07:40 -0800276 {
277 auto builder = superstructure_goal_sender_.MakeBuilder();
278
279 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
280 intake_front_offset =
281 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
282 *builder.fbb(), intake_front_pos,
Austin Schuh445ae832022-03-05 22:52:23 -0800283 CreateProfileParameters(*builder.fbb(), 8.0, 40.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800284 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
285 intake_back_offset =
286 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
287 *builder.fbb(), intake_back_pos,
Austin Schuh445ae832022-03-05 22:52:23 -0800288 CreateProfileParameters(*builder.fbb(), 8.0, 40.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800289
290 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
James Kuszmaul40526952022-03-13 15:56:38 -0700291 turret_offset;
292 if (turret_pos.has_value()) {
Austin Schuhc9481b82022-03-13 21:19:47 -0700293 turret_offset = CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
James Kuszmaul40526952022-03-13 15:56:38 -0700294 *builder.fbb(), turret_pos.value(),
295 CreateProfileParameters(*builder.fbb(), 12.0, 20.0));
296 }
Henry Speiser0b9b0052022-03-02 23:07:40 -0800297
298 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
299 catapult_return_offset =
300 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
301 *builder.fbb(), catapult_return_pos,
milind-u37dc40b2022-03-08 19:51:27 -0800302 frc971::CreateProfileParameters(*builder.fbb(), 9.0, 50.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800303
Austin Schuh8507c9f2022-03-13 18:08:28 -0700304 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
305 climber_offset = CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
306 *builder.fbb(), climber_position,
307 frc971::CreateProfileParameters(*builder.fbb(), 1.0, 5.0));
308
Henry Speiser0b9b0052022-03-02 23:07:40 -0800309 superstructure::CatapultGoal::Builder catapult_builder =
310 builder.MakeBuilder<superstructure::CatapultGoal>();
311 catapult_builder.add_return_position(catapult_return_offset);
312 catapult_builder.add_shot_position(catapult_pos);
313 catapult_builder.add_shot_velocity(catapult_speed);
314 flatbuffers::Offset<superstructure::CatapultGoal> catapult_offset =
315 catapult_builder.Finish();
316
317 superstructure::Goal::Builder superstructure_goal_builder =
318 builder.MakeBuilder<superstructure::Goal>();
319
320 superstructure_goal_builder.add_intake_front(intake_front_offset);
321 superstructure_goal_builder.add_intake_back(intake_back_offset);
Austin Schuhc9481b82022-03-13 21:19:47 -0700322 if (!turret_offset.IsNull()) {
323 superstructure_goal_builder.add_turret(turret_offset);
324 }
Austin Schuh8507c9f2022-03-13 18:08:28 -0700325 superstructure_goal_builder.add_climber(climber_offset);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800326 superstructure_goal_builder.add_catapult(catapult_offset);
327 superstructure_goal_builder.add_fire(fire);
328
329 superstructure_goal_builder.add_roller_speed_front(roller_front_speed);
330 superstructure_goal_builder.add_roller_speed_back(roller_back_speed);
Milind Upadhyay29dcc172022-04-02 19:21:30 -0700331 superstructure_goal_builder.add_transfer_roller_speed(
332 transfer_roller_speed);
James Kuszmaul40526952022-03-13 15:56:38 -0700333 superstructure_goal_builder.add_auto_aim(data.IsPressed(kAutoAim));
334 if (requested_intake.has_value()) {
335 superstructure_goal_builder.add_turret_intake(requested_intake.value());
336 }
Henry Speiser0b9b0052022-03-02 23:07:40 -0800337
338 if (builder.Send(superstructure_goal_builder.Finish()) !=
339 aos::RawSender::Error::kOk) {
340 AOS_LOG(ERROR, "Sending superstructure goal failed.\n");
341 }
Austin Schuh39f26f62022-02-24 21:34:46 -0800342 }
milind-u086d7262022-01-19 20:44:18 -0800343 }
344
345 private:
346 ::aos::Sender<superstructure::Goal> superstructure_goal_sender_;
347
Henry Speiser0b9b0052022-03-02 23:07:40 -0800348 ::aos::Sender<frc971::control_loops::drivetrain::LocalizerControl>
349 localizer_control_sender_;
350
milind-u086d7262022-01-19 20:44:18 -0800351 ::aos::Fetcher<superstructure::Status> superstructure_status_fetcher_;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800352
353 ::aos::Fetcher<Setpoint> setpoint_fetcher_;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800354
355 size_t intake_front_counter_ = 0;
356 size_t intake_back_counter_ = 0;
milind-u086d7262022-01-19 20:44:18 -0800357};
358
359} // namespace joysticks
360} // namespace input
361} // namespace y2022
362
363int main(int argc, char **argv) {
364 ::aos::InitGoogle(&argc, &argv);
365
366 aos::FlatbufferDetachedBuffer<aos::Configuration> config =
Austin Schuhc5fa6d92022-02-25 14:36:28 -0800367 aos::configuration::ReadConfig("aos_config.json");
milind-u086d7262022-01-19 20:44:18 -0800368
369 ::aos::ShmEventLoop event_loop(&config.message());
370 ::y2022::input::joysticks::Reader reader(&event_loop);
371
372 event_loop.Run();
373
374 return 0;
375}