blob: a911e4b2beb60116fb3a529306e3992ef9e92037 [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 Upadhyay9a4ae572022-03-12 12:52:06 -080048const ButtonLocation kSpit(3, 3);
Henry Speiser0b9b0052022-03-02 23:07:40 -080049
50const ButtonLocation kRedLocalizerReset(3, 13);
51const ButtonLocation kBlueLocalizerReset(3, 14);
52const ButtonLocation kLocalizerReset(3, 8);
milind-u37dc40b2022-03-08 19:51:27 -080053#else
54
55const ButtonLocation kCatapultPos(4, 3);
56const ButtonLocation kFire(4, 1);
57const ButtonLocation kTurret(4, 15);
Milind Upadhyay9a4ae572022-03-12 12:52:06 -080058const ButtonLocation kAutoAim(4, 2);
milind-u37dc40b2022-03-08 19:51:27 -080059
Austin Schuh8507c9f2022-03-13 18:08:28 -070060const ButtonLocation kClimberExtend(4, 6);
61
milind-u37dc40b2022-03-08 19:51:27 -080062const ButtonLocation kIntakeFrontOut(4, 10);
63const ButtonLocation kIntakeBackOut(4, 9);
Milind Upadhyay9a4ae572022-03-12 12:52:06 -080064const ButtonLocation kSpit(3, 3);
milind-u37dc40b2022-03-08 19:51:27 -080065
James Kuszmaul7fc03ce2022-03-12 15:31:24 -080066const ButtonLocation kRedLocalizerReset(4, 14);
67const ButtonLocation kBlueLocalizerReset(4, 13);
milind-u37dc40b2022-03-08 19:51:27 -080068const ButtonLocation kLocalizerReset(3, 8);
69#endif
Henry Speiser0b9b0052022-03-02 23:07:40 -080070
milind-u086d7262022-01-19 20:44:18 -080071class Reader : public ::frc971::input::ActionJoystickInput {
72 public:
73 Reader(::aos::EventLoop *event_loop)
74 : ::frc971::input::ActionJoystickInput(
75 event_loop,
76 ::y2022::control_loops::drivetrain::GetDrivetrainConfig(),
77 ::frc971::input::DrivetrainInputReader::InputType::kPistol, {}),
78 superstructure_goal_sender_(
79 event_loop->MakeSender<superstructure::Goal>("/superstructure")),
Henry Speiser0b9b0052022-03-02 23:07:40 -080080 localizer_control_sender_(
81 event_loop->MakeSender<
82 ::frc971::control_loops::drivetrain::LocalizerControl>(
83 "/drivetrain")),
milind-u086d7262022-01-19 20:44:18 -080084 superstructure_status_fetcher_(
Henry Speiser0b9b0052022-03-02 23:07:40 -080085 event_loop->MakeFetcher<superstructure::Status>("/superstructure")),
86 setpoint_fetcher_(
87 event_loop->MakeFetcher<Setpoint>("/superstructure")) {}
88
James Kuszmaul7fc03ce2022-03-12 15:31:24 -080089 // Localizer reset positions are with front of robot pressed up against driver
90 // station in the middle of the field side-to-side.
Henry Speiser0b9b0052022-03-02 23:07:40 -080091 void BlueResetLocalizer() {
92 auto builder = localizer_control_sender_.MakeBuilder();
93
94 frc971::control_loops::drivetrain::LocalizerControl::Builder
95 localizer_control_builder = builder.MakeBuilder<
96 frc971::control_loops::drivetrain::LocalizerControl>();
James Kuszmaul7fc03ce2022-03-12 15:31:24 -080097 localizer_control_builder.add_x(-7.9);
98 localizer_control_builder.add_y(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -080099 localizer_control_builder.add_theta_uncertainty(10.0);
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800100 localizer_control_builder.add_theta(M_PI);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800101 localizer_control_builder.add_keep_current_theta(false);
102 if (builder.Send(localizer_control_builder.Finish()) !=
103 aos::RawSender::Error::kOk) {
104 AOS_LOG(ERROR, "Failed to reset blue localizer.\n");
105 }
106 }
107
108 void RedResetLocalizer() {
109 auto builder = localizer_control_sender_.MakeBuilder();
110
111 frc971::control_loops::drivetrain::LocalizerControl::Builder
112 localizer_control_builder = builder.MakeBuilder<
113 frc971::control_loops::drivetrain::LocalizerControl>();
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800114 localizer_control_builder.add_x(7.9);
115 localizer_control_builder.add_y(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800116 localizer_control_builder.add_theta_uncertainty(10.0);
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800117 localizer_control_builder.add_theta(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800118 localizer_control_builder.add_keep_current_theta(false);
119 if (builder.Send(localizer_control_builder.Finish()) !=
120 aos::RawSender::Error::kOk) {
121 AOS_LOG(ERROR, "Failed to reset red localizer.\n");
122 }
123 }
124
125 void ResetLocalizer() {
126 const frc971::control_loops::drivetrain::Status *drivetrain_status =
127 this->drivetrain_status();
128 if (drivetrain_status == nullptr) {
129 return;
130 }
131 // Get the current position
132 // Snap to heading.
133 auto builder = localizer_control_sender_.MakeBuilder();
134
135 // TODO<Henry> Put our starting location here.
136 frc971::control_loops::drivetrain::LocalizerControl::Builder
137 localizer_control_builder = builder.MakeBuilder<
138 frc971::control_loops::drivetrain::LocalizerControl>();
139 localizer_control_builder.add_x(drivetrain_status->x());
140 localizer_control_builder.add_y(drivetrain_status->y());
141 const double new_theta =
142 frc971::zeroing::Wrap(drivetrain_status->theta(), 0, M_PI);
143 localizer_control_builder.add_theta(new_theta);
144 localizer_control_builder.add_theta_uncertainty(10.0);
145 if (builder.Send(localizer_control_builder.Finish()) !=
146 aos::RawSender::Error::kOk) {
147 AOS_LOG(ERROR, "Failed to reset localizer.\n");
148 }
149 }
milind-u086d7262022-01-19 20:44:18 -0800150
151 void AutoEnded() override { AOS_LOG(INFO, "Auto ended.\n"); }
152
153 void HandleTeleop(
Austin Schuh39f26f62022-02-24 21:34:46 -0800154 const ::frc971::input::driver_station::Data &data) override {
milind-u086d7262022-01-19 20:44:18 -0800155 superstructure_status_fetcher_.Fetch();
156 if (!superstructure_status_fetcher_.get()) {
157 AOS_LOG(ERROR, "Got no superstructure status message.\n");
158 return;
159 }
Austin Schuh39f26f62022-02-24 21:34:46 -0800160
Henry Speiser0b9b0052022-03-02 23:07:40 -0800161 setpoint_fetcher_.Fetch();
Austin Schuh39f26f62022-02-24 21:34:46 -0800162
Henry Speiser0b9b0052022-03-02 23:07:40 -0800163 // Default to the intakes in
milind-u37dc40b2022-03-08 19:51:27 -0800164 double intake_front_pos = 1.47;
165 double intake_back_pos = 1.47;
Milind Upadhyayb1a74ea2022-03-09 20:34:35 -0800166 double transfer_roller_front_speed = 0.0;
167 double transfer_roller_back_speed = 0.0;
James Kuszmaul40526952022-03-13 15:56:38 -0700168 std::optional<control_loops::superstructure::RequestedIntake>
169 requested_intake;
Austin Schuh39f26f62022-02-24 21:34:46 -0800170
Henry Speiser0b9b0052022-03-02 23:07:40 -0800171 double roller_front_speed = 0.0;
172 double roller_back_speed = 0.0;
Austin Schuh39f26f62022-02-24 21:34:46 -0800173
James Kuszmaul40526952022-03-13 15:56:38 -0700174 std::optional<double> turret_pos = 0.0;
Austin Schuh39f26f62022-02-24 21:34:46 -0800175
Austin Schuh8507c9f2022-03-13 18:08:28 -0700176 double climber_position = 0.01;
177
milind-u37dc40b2022-03-08 19:51:27 -0800178 double catapult_pos = 0.03;
179 double catapult_speed = 18.0;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800180 double catapult_return_pos = 0.0;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800181 bool fire = false;
Austin Schuh39f26f62022-02-24 21:34:46 -0800182
Henry Speiser0b9b0052022-03-02 23:07:40 -0800183 if (data.PosEdge(kLocalizerReset)) {
184 ResetLocalizer();
185 }
186
187 if (data.PosEdge(kRedLocalizerReset)) {
188 RedResetLocalizer();
189 }
190 if (data.PosEdge(kBlueLocalizerReset)) {
191 BlueResetLocalizer();
192 }
193
Austin Schuh8507c9f2022-03-13 18:08:28 -0700194 if (data.IsPressed(kClimberExtend)) {
195 climber_position = 0.50;
196 } else {
197 climber_position = 0.01;
198 }
199
milind-u37dc40b2022-03-08 19:51:27 -0800200 if (data.IsPressed(kTurret)) {
Milind Upadhyay9cb14212022-03-11 21:42:35 -0800201 if (setpoint_fetcher_.get()) {
202 turret_pos = setpoint_fetcher_->turret();
203 } else {
204 turret_pos = -1.5;
205 }
milind-u37dc40b2022-03-08 19:51:27 -0800206 }
207
Milind Upadhyay9cb14212022-03-11 21:42:35 -0800208 if (setpoint_fetcher_.get()) {
209 catapult_pos = setpoint_fetcher_->catapult_position();
210 catapult_speed = setpoint_fetcher_->catapult_velocity();
211 }
212
Austin Schuh445ae832022-03-05 22:52:23 -0800213 // Keep the catapult return position at the shot one if kCatapultPos is
214 // pressed
215 if (data.IsPressed(kCatapultPos)) {
216 catapult_return_pos = 0.3;
217 } else {
milind-u37dc40b2022-03-08 19:51:27 -0800218 catapult_return_pos = -0.908;
Austin Schuh445ae832022-03-05 22:52:23 -0800219 }
220
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800221 constexpr double kRollerSpeed = 8.0;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800222 constexpr double kTransferRollerSpeed = 12.0;
Austin Schuhc9b42db2022-03-12 12:03:29 -0800223 constexpr double kIntakePosition = -0.02;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800224 constexpr size_t kIntakeCounterIterations = 25;
225
Austin Schuh445ae832022-03-05 22:52:23 -0800226 // Extend the intakes and spin the rollers
227 if (data.IsPressed(kIntakeFrontOut)) {
Austin Schuhc9b42db2022-03-12 12:03:29 -0800228 intake_front_pos = kIntakePosition;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800229 transfer_roller_front_speed = kTransferRollerSpeed;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800230
231 intake_front_counter_ = kIntakeCounterIterations;
James Kuszmaul40526952022-03-13 15:56:38 -0700232 intake_back_counter_ = 0;
Austin Schuh445ae832022-03-05 22:52:23 -0800233 } else if (data.IsPressed(kIntakeBackOut)) {
Austin Schuhc9b42db2022-03-12 12:03:29 -0800234 intake_back_pos = kIntakePosition;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800235 transfer_roller_back_speed = kTransferRollerSpeed;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800236
237 intake_back_counter_ = kIntakeCounterIterations;
James Kuszmaul40526952022-03-13 15:56:38 -0700238 intake_front_counter_ = 0;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800239 } else if (data.IsPressed(kSpit)) {
240 transfer_roller_front_speed = -kTransferRollerSpeed;
241 transfer_roller_back_speed = -kTransferRollerSpeed;
242
243 intake_front_counter_ = 0;
244 intake_back_counter_ = 0;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800245 }
246
247 // Keep spinning the rollers a bit after they let go
248 if (intake_front_counter_ > 0) {
249 intake_front_counter_--;
250 roller_front_speed = kRollerSpeed;
James Kuszmaul40526952022-03-13 15:56:38 -0700251 requested_intake = control_loops::superstructure::RequestedIntake::kFront;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800252 }
253 if (intake_back_counter_ > 0) {
254 intake_back_counter_--;
255 roller_back_speed = kRollerSpeed;
James Kuszmaul40526952022-03-13 15:56:38 -0700256 requested_intake = control_loops::superstructure::RequestedIntake::kBack;
Austin Schuh445ae832022-03-05 22:52:23 -0800257 }
258
259 if (data.IsPressed(kFire)) {
260 fire = true;
261 }
262
Henry Speiser0b9b0052022-03-02 23:07:40 -0800263 {
264 auto builder = superstructure_goal_sender_.MakeBuilder();
265
266 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
267 intake_front_offset =
268 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
269 *builder.fbb(), intake_front_pos,
Austin Schuh445ae832022-03-05 22:52:23 -0800270 CreateProfileParameters(*builder.fbb(), 8.0, 40.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800271 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
272 intake_back_offset =
273 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
274 *builder.fbb(), intake_back_pos,
Austin Schuh445ae832022-03-05 22:52:23 -0800275 CreateProfileParameters(*builder.fbb(), 8.0, 40.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800276
277 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
James Kuszmaul40526952022-03-13 15:56:38 -0700278 turret_offset;
279 if (turret_pos.has_value()) {
280 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
281 *builder.fbb(), turret_pos.value(),
282 CreateProfileParameters(*builder.fbb(), 12.0, 20.0));
283 }
Henry Speiser0b9b0052022-03-02 23:07:40 -0800284
285 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
286 catapult_return_offset =
287 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
288 *builder.fbb(), catapult_return_pos,
milind-u37dc40b2022-03-08 19:51:27 -0800289 frc971::CreateProfileParameters(*builder.fbb(), 9.0, 50.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800290
Austin Schuh8507c9f2022-03-13 18:08:28 -0700291 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
292 climber_offset = CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
293 *builder.fbb(), climber_position,
294 frc971::CreateProfileParameters(*builder.fbb(), 1.0, 5.0));
295
Henry Speiser0b9b0052022-03-02 23:07:40 -0800296 superstructure::CatapultGoal::Builder catapult_builder =
297 builder.MakeBuilder<superstructure::CatapultGoal>();
298 catapult_builder.add_return_position(catapult_return_offset);
299 catapult_builder.add_shot_position(catapult_pos);
300 catapult_builder.add_shot_velocity(catapult_speed);
301 flatbuffers::Offset<superstructure::CatapultGoal> catapult_offset =
302 catapult_builder.Finish();
303
304 superstructure::Goal::Builder superstructure_goal_builder =
305 builder.MakeBuilder<superstructure::Goal>();
306
307 superstructure_goal_builder.add_intake_front(intake_front_offset);
308 superstructure_goal_builder.add_intake_back(intake_back_offset);
309 superstructure_goal_builder.add_turret(turret_offset);
Austin Schuh8507c9f2022-03-13 18:08:28 -0700310 superstructure_goal_builder.add_climber(climber_offset);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800311 superstructure_goal_builder.add_catapult(catapult_offset);
312 superstructure_goal_builder.add_fire(fire);
313
314 superstructure_goal_builder.add_roller_speed_front(roller_front_speed);
315 superstructure_goal_builder.add_roller_speed_back(roller_back_speed);
Milind Upadhyayb1a74ea2022-03-09 20:34:35 -0800316 superstructure_goal_builder.add_transfer_roller_speed_front(
317 transfer_roller_front_speed);
318 superstructure_goal_builder.add_transfer_roller_speed_back(
James Kuszmauld9959e02022-03-11 22:53:00 -0800319 transfer_roller_back_speed);
James Kuszmaul40526952022-03-13 15:56:38 -0700320 superstructure_goal_builder.add_auto_aim(data.IsPressed(kAutoAim));
321 if (requested_intake.has_value()) {
322 superstructure_goal_builder.add_turret_intake(requested_intake.value());
323 }
Henry Speiser0b9b0052022-03-02 23:07:40 -0800324
325 if (builder.Send(superstructure_goal_builder.Finish()) !=
326 aos::RawSender::Error::kOk) {
327 AOS_LOG(ERROR, "Sending superstructure goal failed.\n");
328 }
Austin Schuh39f26f62022-02-24 21:34:46 -0800329 }
milind-u086d7262022-01-19 20:44:18 -0800330 }
331
332 private:
333 ::aos::Sender<superstructure::Goal> superstructure_goal_sender_;
334
Henry Speiser0b9b0052022-03-02 23:07:40 -0800335 ::aos::Sender<frc971::control_loops::drivetrain::LocalizerControl>
336 localizer_control_sender_;
337
milind-u086d7262022-01-19 20:44:18 -0800338 ::aos::Fetcher<superstructure::Status> superstructure_status_fetcher_;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800339
340 ::aos::Fetcher<Setpoint> setpoint_fetcher_;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800341
342 size_t intake_front_counter_ = 0;
343 size_t intake_back_counter_ = 0;
milind-u086d7262022-01-19 20:44:18 -0800344};
345
346} // namespace joysticks
347} // namespace input
348} // namespace y2022
349
350int main(int argc, char **argv) {
351 ::aos::InitGoogle(&argc, &argv);
352
353 aos::FlatbufferDetachedBuffer<aos::Configuration> config =
Austin Schuhc5fa6d92022-02-25 14:36:28 -0800354 aos::configuration::ReadConfig("aos_config.json");
milind-u086d7262022-01-19 20:44:18 -0800355
356 ::aos::ShmEventLoop event_loop(&config.message());
357 ::y2022::input::joysticks::Reader reader(&event_loop);
358
359 event_loop.Run();
360
361 return 0;
362}