blob: a88e552068b29fb0ba98ac6019bd6abc560038dc [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);
Austin Schuh0e209102022-03-13 19:39:42 -070061const ButtonLocation kClimberIntakes(4, 5);
Austin Schuh8507c9f2022-03-13 18:08:28 -070062
milind-u37dc40b2022-03-08 19:51:27 -080063const ButtonLocation kIntakeFrontOut(4, 10);
64const ButtonLocation kIntakeBackOut(4, 9);
Milind Upadhyay9a4ae572022-03-12 12:52:06 -080065const ButtonLocation kSpit(3, 3);
milind-u37dc40b2022-03-08 19:51:27 -080066
James Kuszmaul7fc03ce2022-03-12 15:31:24 -080067const ButtonLocation kRedLocalizerReset(4, 14);
68const ButtonLocation kBlueLocalizerReset(4, 13);
milind-u37dc40b2022-03-08 19:51:27 -080069const ButtonLocation kLocalizerReset(3, 8);
70#endif
Henry Speiser0b9b0052022-03-02 23:07:40 -080071
milind-u086d7262022-01-19 20:44:18 -080072class Reader : public ::frc971::input::ActionJoystickInput {
73 public:
74 Reader(::aos::EventLoop *event_loop)
75 : ::frc971::input::ActionJoystickInput(
76 event_loop,
77 ::y2022::control_loops::drivetrain::GetDrivetrainConfig(),
78 ::frc971::input::DrivetrainInputReader::InputType::kPistol, {}),
79 superstructure_goal_sender_(
80 event_loop->MakeSender<superstructure::Goal>("/superstructure")),
Henry Speiser0b9b0052022-03-02 23:07:40 -080081 localizer_control_sender_(
82 event_loop->MakeSender<
83 ::frc971::control_loops::drivetrain::LocalizerControl>(
84 "/drivetrain")),
milind-u086d7262022-01-19 20:44:18 -080085 superstructure_status_fetcher_(
Henry Speiser0b9b0052022-03-02 23:07:40 -080086 event_loop->MakeFetcher<superstructure::Status>("/superstructure")),
87 setpoint_fetcher_(
88 event_loop->MakeFetcher<Setpoint>("/superstructure")) {}
89
James Kuszmaul7fc03ce2022-03-12 15:31:24 -080090 // Localizer reset positions are with front of robot pressed up against driver
91 // station in the middle of the field side-to-side.
Henry Speiser0b9b0052022-03-02 23:07:40 -080092 void BlueResetLocalizer() {
93 auto builder = localizer_control_sender_.MakeBuilder();
94
95 frc971::control_loops::drivetrain::LocalizerControl::Builder
96 localizer_control_builder = builder.MakeBuilder<
97 frc971::control_loops::drivetrain::LocalizerControl>();
James Kuszmaul7fc03ce2022-03-12 15:31:24 -080098 localizer_control_builder.add_x(-7.9);
99 localizer_control_builder.add_y(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800100 localizer_control_builder.add_theta_uncertainty(10.0);
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800101 localizer_control_builder.add_theta(M_PI);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800102 localizer_control_builder.add_keep_current_theta(false);
103 if (builder.Send(localizer_control_builder.Finish()) !=
104 aos::RawSender::Error::kOk) {
105 AOS_LOG(ERROR, "Failed to reset blue localizer.\n");
106 }
107 }
108
109 void RedResetLocalizer() {
110 auto builder = localizer_control_sender_.MakeBuilder();
111
112 frc971::control_loops::drivetrain::LocalizerControl::Builder
113 localizer_control_builder = builder.MakeBuilder<
114 frc971::control_loops::drivetrain::LocalizerControl>();
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800115 localizer_control_builder.add_x(7.9);
116 localizer_control_builder.add_y(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800117 localizer_control_builder.add_theta_uncertainty(10.0);
James Kuszmaul7fc03ce2022-03-12 15:31:24 -0800118 localizer_control_builder.add_theta(0.0);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800119 localizer_control_builder.add_keep_current_theta(false);
120 if (builder.Send(localizer_control_builder.Finish()) !=
121 aos::RawSender::Error::kOk) {
122 AOS_LOG(ERROR, "Failed to reset red localizer.\n");
123 }
124 }
125
126 void ResetLocalizer() {
127 const frc971::control_loops::drivetrain::Status *drivetrain_status =
128 this->drivetrain_status();
129 if (drivetrain_status == nullptr) {
130 return;
131 }
132 // Get the current position
133 // Snap to heading.
134 auto builder = localizer_control_sender_.MakeBuilder();
135
136 // TODO<Henry> Put our starting location here.
137 frc971::control_loops::drivetrain::LocalizerControl::Builder
138 localizer_control_builder = builder.MakeBuilder<
139 frc971::control_loops::drivetrain::LocalizerControl>();
140 localizer_control_builder.add_x(drivetrain_status->x());
141 localizer_control_builder.add_y(drivetrain_status->y());
142 const double new_theta =
143 frc971::zeroing::Wrap(drivetrain_status->theta(), 0, M_PI);
144 localizer_control_builder.add_theta(new_theta);
145 localizer_control_builder.add_theta_uncertainty(10.0);
146 if (builder.Send(localizer_control_builder.Finish()) !=
147 aos::RawSender::Error::kOk) {
148 AOS_LOG(ERROR, "Failed to reset localizer.\n");
149 }
150 }
milind-u086d7262022-01-19 20:44:18 -0800151
152 void AutoEnded() override { AOS_LOG(INFO, "Auto ended.\n"); }
153
154 void HandleTeleop(
Austin Schuh39f26f62022-02-24 21:34:46 -0800155 const ::frc971::input::driver_station::Data &data) override {
milind-u086d7262022-01-19 20:44:18 -0800156 superstructure_status_fetcher_.Fetch();
157 if (!superstructure_status_fetcher_.get()) {
158 AOS_LOG(ERROR, "Got no superstructure status message.\n");
159 return;
160 }
Austin Schuh39f26f62022-02-24 21:34:46 -0800161
Henry Speiser0b9b0052022-03-02 23:07:40 -0800162 setpoint_fetcher_.Fetch();
Austin Schuh39f26f62022-02-24 21:34:46 -0800163
Henry Speiser0b9b0052022-03-02 23:07:40 -0800164 // Default to the intakes in
Austin Schuh0e209102022-03-13 19:39:42 -0700165 constexpr double kIntakeUpPosition = 1.47;
166 double intake_front_pos = kIntakeUpPosition;
167 double intake_back_pos = kIntakeUpPosition;
Milind Upadhyayb1a74ea2022-03-09 20:34:35 -0800168 double transfer_roller_front_speed = 0.0;
169 double transfer_roller_back_speed = 0.0;
James Kuszmaul40526952022-03-13 15:56:38 -0700170 std::optional<control_loops::superstructure::RequestedIntake>
171 requested_intake;
Austin Schuh39f26f62022-02-24 21:34:46 -0800172
Henry Speiser0b9b0052022-03-02 23:07:40 -0800173 double roller_front_speed = 0.0;
174 double roller_back_speed = 0.0;
Austin Schuh39f26f62022-02-24 21:34:46 -0800175
James Kuszmaul40526952022-03-13 15:56:38 -0700176 std::optional<double> turret_pos = 0.0;
Austin Schuh39f26f62022-02-24 21:34:46 -0800177
Austin Schuh8507c9f2022-03-13 18:08:28 -0700178 double climber_position = 0.01;
179
milind-u37dc40b2022-03-08 19:51:27 -0800180 double catapult_pos = 0.03;
181 double catapult_speed = 18.0;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800182 double catapult_return_pos = 0.0;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800183 bool fire = false;
Austin Schuh39f26f62022-02-24 21:34:46 -0800184
Henry Speiser0b9b0052022-03-02 23:07:40 -0800185 if (data.PosEdge(kLocalizerReset)) {
186 ResetLocalizer();
187 }
188
189 if (data.PosEdge(kRedLocalizerReset)) {
190 RedResetLocalizer();
191 }
192 if (data.PosEdge(kBlueLocalizerReset)) {
193 BlueResetLocalizer();
194 }
195
Austin Schuh8507c9f2022-03-13 18:08:28 -0700196 if (data.IsPressed(kClimberExtend)) {
197 climber_position = 0.50;
198 } else {
199 climber_position = 0.01;
200 }
201
milind-u37dc40b2022-03-08 19:51:27 -0800202 if (data.IsPressed(kTurret)) {
Milind Upadhyay9cb14212022-03-11 21:42:35 -0800203 if (setpoint_fetcher_.get()) {
204 turret_pos = setpoint_fetcher_->turret();
205 } else {
206 turret_pos = -1.5;
207 }
milind-u37dc40b2022-03-08 19:51:27 -0800208 }
209
Milind Upadhyay9cb14212022-03-11 21:42:35 -0800210 if (setpoint_fetcher_.get()) {
211 catapult_pos = setpoint_fetcher_->catapult_position();
212 catapult_speed = setpoint_fetcher_->catapult_velocity();
213 }
214
Austin Schuh445ae832022-03-05 22:52:23 -0800215 // Keep the catapult return position at the shot one if kCatapultPos is
216 // pressed
217 if (data.IsPressed(kCatapultPos)) {
218 catapult_return_pos = 0.3;
219 } else {
milind-u37dc40b2022-03-08 19:51:27 -0800220 catapult_return_pos = -0.908;
Austin Schuh445ae832022-03-05 22:52:23 -0800221 }
222
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800223 constexpr double kRollerSpeed = 8.0;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800224 constexpr double kTransferRollerSpeed = 12.0;
Austin Schuhc9b42db2022-03-12 12:03:29 -0800225 constexpr double kIntakePosition = -0.02;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800226 constexpr size_t kIntakeCounterIterations = 25;
227
Austin Schuh445ae832022-03-05 22:52:23 -0800228 // Extend the intakes and spin the rollers
229 if (data.IsPressed(kIntakeFrontOut)) {
Austin Schuhc9b42db2022-03-12 12:03:29 -0800230 intake_front_pos = kIntakePosition;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800231 transfer_roller_front_speed = kTransferRollerSpeed;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800232
233 intake_front_counter_ = kIntakeCounterIterations;
James Kuszmaul40526952022-03-13 15:56:38 -0700234 intake_back_counter_ = 0;
Austin Schuh445ae832022-03-05 22:52:23 -0800235 } else if (data.IsPressed(kIntakeBackOut)) {
Austin Schuhc9b42db2022-03-12 12:03:29 -0800236 intake_back_pos = kIntakePosition;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800237 transfer_roller_back_speed = kTransferRollerSpeed;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800238
239 intake_back_counter_ = kIntakeCounterIterations;
James Kuszmaul40526952022-03-13 15:56:38 -0700240 intake_front_counter_ = 0;
Milind Upadhyay9a4ae572022-03-12 12:52:06 -0800241 } else if (data.IsPressed(kSpit)) {
242 transfer_roller_front_speed = -kTransferRollerSpeed;
243 transfer_roller_back_speed = -kTransferRollerSpeed;
244
245 intake_front_counter_ = 0;
246 intake_back_counter_ = 0;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800247 }
248
249 // Keep spinning the rollers a bit after they let go
250 if (intake_front_counter_ > 0) {
251 intake_front_counter_--;
252 roller_front_speed = kRollerSpeed;
James Kuszmaul40526952022-03-13 15:56:38 -0700253 requested_intake = control_loops::superstructure::RequestedIntake::kFront;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800254 }
255 if (intake_back_counter_ > 0) {
256 intake_back_counter_--;
257 roller_back_speed = kRollerSpeed;
James Kuszmaul40526952022-03-13 15:56:38 -0700258 requested_intake = control_loops::superstructure::RequestedIntake::kBack;
Austin Schuh445ae832022-03-05 22:52:23 -0800259 }
260
261 if (data.IsPressed(kFire)) {
262 fire = true;
James Kuszmaul916982d2022-03-13 19:53:10 -0700263 // Provide a default turret goal.
264 turret_pos = 0.0;
Austin Schuh445ae832022-03-05 22:52:23 -0800265 }
266
Austin Schuh0e209102022-03-13 19:39:42 -0700267 if (data.IsPressed(kClimberIntakes)) {
268 intake_back_pos = kIntakeUpPosition;
269 intake_front_pos = kIntakePosition;
270 }
271
Henry Speiser0b9b0052022-03-02 23:07:40 -0800272 {
273 auto builder = superstructure_goal_sender_.MakeBuilder();
274
275 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
276 intake_front_offset =
277 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
278 *builder.fbb(), intake_front_pos,
Austin Schuh445ae832022-03-05 22:52:23 -0800279 CreateProfileParameters(*builder.fbb(), 8.0, 40.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800280 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
281 intake_back_offset =
282 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
283 *builder.fbb(), intake_back_pos,
Austin Schuh445ae832022-03-05 22:52:23 -0800284 CreateProfileParameters(*builder.fbb(), 8.0, 40.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800285
286 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
James Kuszmaul40526952022-03-13 15:56:38 -0700287 turret_offset;
288 if (turret_pos.has_value()) {
289 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
290 *builder.fbb(), turret_pos.value(),
291 CreateProfileParameters(*builder.fbb(), 12.0, 20.0));
292 }
Henry Speiser0b9b0052022-03-02 23:07:40 -0800293
294 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
295 catapult_return_offset =
296 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
297 *builder.fbb(), catapult_return_pos,
milind-u37dc40b2022-03-08 19:51:27 -0800298 frc971::CreateProfileParameters(*builder.fbb(), 9.0, 50.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800299
Austin Schuh8507c9f2022-03-13 18:08:28 -0700300 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
301 climber_offset = CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
302 *builder.fbb(), climber_position,
303 frc971::CreateProfileParameters(*builder.fbb(), 1.0, 5.0));
304
Henry Speiser0b9b0052022-03-02 23:07:40 -0800305 superstructure::CatapultGoal::Builder catapult_builder =
306 builder.MakeBuilder<superstructure::CatapultGoal>();
307 catapult_builder.add_return_position(catapult_return_offset);
308 catapult_builder.add_shot_position(catapult_pos);
309 catapult_builder.add_shot_velocity(catapult_speed);
310 flatbuffers::Offset<superstructure::CatapultGoal> catapult_offset =
311 catapult_builder.Finish();
312
313 superstructure::Goal::Builder superstructure_goal_builder =
314 builder.MakeBuilder<superstructure::Goal>();
315
316 superstructure_goal_builder.add_intake_front(intake_front_offset);
317 superstructure_goal_builder.add_intake_back(intake_back_offset);
318 superstructure_goal_builder.add_turret(turret_offset);
Austin Schuh8507c9f2022-03-13 18:08:28 -0700319 superstructure_goal_builder.add_climber(climber_offset);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800320 superstructure_goal_builder.add_catapult(catapult_offset);
321 superstructure_goal_builder.add_fire(fire);
322
323 superstructure_goal_builder.add_roller_speed_front(roller_front_speed);
324 superstructure_goal_builder.add_roller_speed_back(roller_back_speed);
Milind Upadhyayb1a74ea2022-03-09 20:34:35 -0800325 superstructure_goal_builder.add_transfer_roller_speed_front(
326 transfer_roller_front_speed);
327 superstructure_goal_builder.add_transfer_roller_speed_back(
James Kuszmauld9959e02022-03-11 22:53:00 -0800328 transfer_roller_back_speed);
James Kuszmaul40526952022-03-13 15:56:38 -0700329 superstructure_goal_builder.add_auto_aim(data.IsPressed(kAutoAim));
330 if (requested_intake.has_value()) {
331 superstructure_goal_builder.add_turret_intake(requested_intake.value());
332 }
Henry Speiser0b9b0052022-03-02 23:07:40 -0800333
334 if (builder.Send(superstructure_goal_builder.Finish()) !=
335 aos::RawSender::Error::kOk) {
336 AOS_LOG(ERROR, "Sending superstructure goal failed.\n");
337 }
Austin Schuh39f26f62022-02-24 21:34:46 -0800338 }
milind-u086d7262022-01-19 20:44:18 -0800339 }
340
341 private:
342 ::aos::Sender<superstructure::Goal> superstructure_goal_sender_;
343
Henry Speiser0b9b0052022-03-02 23:07:40 -0800344 ::aos::Sender<frc971::control_loops::drivetrain::LocalizerControl>
345 localizer_control_sender_;
346
milind-u086d7262022-01-19 20:44:18 -0800347 ::aos::Fetcher<superstructure::Status> superstructure_status_fetcher_;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800348
349 ::aos::Fetcher<Setpoint> setpoint_fetcher_;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800350
351 size_t intake_front_counter_ = 0;
352 size_t intake_back_counter_ = 0;
milind-u086d7262022-01-19 20:44:18 -0800353};
354
355} // namespace joysticks
356} // namespace input
357} // namespace y2022
358
359int main(int argc, char **argv) {
360 ::aos::InitGoogle(&argc, &argv);
361
362 aos::FlatbufferDetachedBuffer<aos::Configuration> config =
Austin Schuhc5fa6d92022-02-25 14:36:28 -0800363 aos::configuration::ReadConfig("aos_config.json");
milind-u086d7262022-01-19 20:44:18 -0800364
365 ::aos::ShmEventLoop event_loop(&config.message());
366 ::y2022::input::joysticks::Reader reader(&event_loop);
367
368 event_loop.Run();
369
370 return 0;
371}