blob: cc2c6e9c2755af235ddc5b4a43ec39fac963e181 [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;
James Kuszmaul916982d2022-03-13 19:53:10 -0700261 // Provide a default turret goal.
262 turret_pos = 0.0;
Austin Schuh445ae832022-03-05 22:52:23 -0800263 }
264
Henry Speiser0b9b0052022-03-02 23:07:40 -0800265 {
266 auto builder = superstructure_goal_sender_.MakeBuilder();
267
268 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
269 intake_front_offset =
270 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
271 *builder.fbb(), intake_front_pos,
Austin Schuh445ae832022-03-05 22:52:23 -0800272 CreateProfileParameters(*builder.fbb(), 8.0, 40.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800273 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
274 intake_back_offset =
275 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
276 *builder.fbb(), intake_back_pos,
Austin Schuh445ae832022-03-05 22:52:23 -0800277 CreateProfileParameters(*builder.fbb(), 8.0, 40.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800278
279 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
James Kuszmaul40526952022-03-13 15:56:38 -0700280 turret_offset;
281 if (turret_pos.has_value()) {
282 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
283 *builder.fbb(), turret_pos.value(),
284 CreateProfileParameters(*builder.fbb(), 12.0, 20.0));
285 }
Henry Speiser0b9b0052022-03-02 23:07:40 -0800286
287 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
288 catapult_return_offset =
289 CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
290 *builder.fbb(), catapult_return_pos,
milind-u37dc40b2022-03-08 19:51:27 -0800291 frc971::CreateProfileParameters(*builder.fbb(), 9.0, 50.0));
Henry Speiser0b9b0052022-03-02 23:07:40 -0800292
Austin Schuh8507c9f2022-03-13 18:08:28 -0700293 flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal>
294 climber_offset = CreateStaticZeroingSingleDOFProfiledSubsystemGoal(
295 *builder.fbb(), climber_position,
296 frc971::CreateProfileParameters(*builder.fbb(), 1.0, 5.0));
297
Henry Speiser0b9b0052022-03-02 23:07:40 -0800298 superstructure::CatapultGoal::Builder catapult_builder =
299 builder.MakeBuilder<superstructure::CatapultGoal>();
300 catapult_builder.add_return_position(catapult_return_offset);
301 catapult_builder.add_shot_position(catapult_pos);
302 catapult_builder.add_shot_velocity(catapult_speed);
303 flatbuffers::Offset<superstructure::CatapultGoal> catapult_offset =
304 catapult_builder.Finish();
305
306 superstructure::Goal::Builder superstructure_goal_builder =
307 builder.MakeBuilder<superstructure::Goal>();
308
309 superstructure_goal_builder.add_intake_front(intake_front_offset);
310 superstructure_goal_builder.add_intake_back(intake_back_offset);
311 superstructure_goal_builder.add_turret(turret_offset);
Austin Schuh8507c9f2022-03-13 18:08:28 -0700312 superstructure_goal_builder.add_climber(climber_offset);
Henry Speiser0b9b0052022-03-02 23:07:40 -0800313 superstructure_goal_builder.add_catapult(catapult_offset);
314 superstructure_goal_builder.add_fire(fire);
315
316 superstructure_goal_builder.add_roller_speed_front(roller_front_speed);
317 superstructure_goal_builder.add_roller_speed_back(roller_back_speed);
Milind Upadhyayb1a74ea2022-03-09 20:34:35 -0800318 superstructure_goal_builder.add_transfer_roller_speed_front(
319 transfer_roller_front_speed);
320 superstructure_goal_builder.add_transfer_roller_speed_back(
James Kuszmauld9959e02022-03-11 22:53:00 -0800321 transfer_roller_back_speed);
James Kuszmaul40526952022-03-13 15:56:38 -0700322 superstructure_goal_builder.add_auto_aim(data.IsPressed(kAutoAim));
323 if (requested_intake.has_value()) {
324 superstructure_goal_builder.add_turret_intake(requested_intake.value());
325 }
Henry Speiser0b9b0052022-03-02 23:07:40 -0800326
327 if (builder.Send(superstructure_goal_builder.Finish()) !=
328 aos::RawSender::Error::kOk) {
329 AOS_LOG(ERROR, "Sending superstructure goal failed.\n");
330 }
Austin Schuh39f26f62022-02-24 21:34:46 -0800331 }
milind-u086d7262022-01-19 20:44:18 -0800332 }
333
334 private:
335 ::aos::Sender<superstructure::Goal> superstructure_goal_sender_;
336
Henry Speiser0b9b0052022-03-02 23:07:40 -0800337 ::aos::Sender<frc971::control_loops::drivetrain::LocalizerControl>
338 localizer_control_sender_;
339
milind-u086d7262022-01-19 20:44:18 -0800340 ::aos::Fetcher<superstructure::Status> superstructure_status_fetcher_;
Henry Speiser0b9b0052022-03-02 23:07:40 -0800341
342 ::aos::Fetcher<Setpoint> setpoint_fetcher_;
Milind Upadhyay1c6ec5e2022-03-12 10:52:34 -0800343
344 size_t intake_front_counter_ = 0;
345 size_t intake_back_counter_ = 0;
milind-u086d7262022-01-19 20:44:18 -0800346};
347
348} // namespace joysticks
349} // namespace input
350} // namespace y2022
351
352int main(int argc, char **argv) {
353 ::aos::InitGoogle(&argc, &argv);
354
355 aos::FlatbufferDetachedBuffer<aos::Configuration> config =
Austin Schuhc5fa6d92022-02-25 14:36:28 -0800356 aos::configuration::ReadConfig("aos_config.json");
milind-u086d7262022-01-19 20:44:18 -0800357
358 ::aos::ShmEventLoop event_loop(&config.message());
359 ::y2022::input::joysticks::Reader reader(&event_loop);
360
361 event_loop.Run();
362
363 return 0;
364}