blob: dcc528f773340c7ca3eca190d3e6eb7dbab6d7ea [file] [log] [blame]
Comran Morshed9a9948c2016-01-16 15:58:04 +00001#include <stdio.h>
2#include <string.h>
3#include <unistd.h>
4#include <math.h>
5
6#include "aos/linux_code/init.h"
7#include "aos/input/joystick_input.h"
8#include "aos/common/input/driver_station_data.h"
9#include "aos/common/logging/logging.h"
10#include "aos/common/util/log_interval.h"
11#include "aos/common/time.h"
12#include "aos/common/actions/actions.h"
13
14#include "frc971/control_loops/drivetrain/drivetrain.q.h"
Comran Morshed200dd4b2016-02-16 17:54:58 +000015#include "y2016/control_loops/shooter/shooter.q.h"
16#include "y2016/control_loops/superstructure/superstructure.q.h"
Austin Schuh45d07f62016-03-13 15:33:31 -070017#include "y2016/control_loops/superstructure/superstructure.h"
Comran Morshedaa0573c2016-03-05 19:05:54 +000018#include "y2016/queues/ball_detector.q.h"
Austin Schuhadd6d792016-03-19 01:20:01 -070019#include "y2016/vision/vision.q.h"
Comran Morshed200dd4b2016-02-16 17:54:58 +000020
Comran Morshed6c6a0a92016-01-17 12:45:16 +000021#include "y2016/constants.h"
Comran Morshed9a9948c2016-01-16 15:58:04 +000022#include "frc971/queues/gyro.q.h"
23#include "frc971/autonomous/auto.q.h"
Comran Morshede68e3732016-03-12 14:12:11 +000024#include "y2016/actors/autonomous_actor.h"
Austin Schuh18799112016-03-16 22:09:54 -070025#include "y2016/actors/vision_align_actor.h"
Austin Schuhd52df772016-03-19 15:38:41 -070026#include "y2016/control_loops/drivetrain/drivetrain_base.h"
Comran Morshed9a9948c2016-01-16 15:58:04 +000027
28using ::frc971::control_loops::drivetrain_queue;
Comran Morshed200dd4b2016-02-16 17:54:58 +000029using ::y2016::control_loops::shooter::shooter_queue;
30using ::y2016::control_loops::superstructure_queue;
Comran Morshed9a9948c2016-01-16 15:58:04 +000031
32using ::aos::input::driver_station::ButtonLocation;
Comran Morshed9a9948c2016-01-16 15:58:04 +000033using ::aos::input::driver_station::ControlBit;
Austin Schuh4ea06c12016-03-12 17:54:31 -080034using ::aos::input::driver_station::JoystickAxis;
35using ::aos::input::driver_station::POVLocation;
Comran Morshed9a9948c2016-01-16 15:58:04 +000036
Comran Morshed6c6a0a92016-01-17 12:45:16 +000037namespace y2016 {
Comran Morshed9a9948c2016-01-16 15:58:04 +000038namespace input {
39namespace joysticks {
40
Austin Schuh45d07f62016-03-13 15:33:31 -070041namespace {
42
43constexpr double kMaxIntakeAngleBeforeArmInterference = control_loops::
44 superstructure::CollisionAvoidance::kMaxIntakeAngleBeforeArmInterference;
45
46} // namespace
47
Comran Morshed9a9948c2016-01-16 15:58:04 +000048const JoystickAxis kSteeringWheel(1, 1), kDriveThrottle(2, 2);
Campbell Crowley5b27f022016-02-20 16:55:35 -080049const ButtonLocation kShiftHigh(2, 3), kShiftHigh2(2, 2), kShiftLow(2, 1);
Comran Morshed9a9948c2016-01-16 15:58:04 +000050const ButtonLocation kQuickTurn(1, 5);
51
Austin Schuh781cdcc2016-03-12 13:03:12 -080052const ButtonLocation kTurn1(1, 7);
53const ButtonLocation kTurn2(1, 11);
54
Comran Morshed200dd4b2016-02-16 17:54:58 +000055// Buttons on the lexan driver station to get things running on bring-up day.
Austin Schuh4ea06c12016-03-12 17:54:31 -080056const ButtonLocation kIntakeDown(3, 11);
57const POVLocation kFrontLong(3, 180);
Austin Schuh4105ac82016-03-26 19:44:43 -070058const ButtonLocation kHigherFrontLong(3, 6);
Austin Schuh4ea06c12016-03-12 17:54:31 -080059const POVLocation kBackLong(3, 0);
Austin Schuh45d07f62016-03-13 15:33:31 -070060const POVLocation kBackFender(3, 90);
61const POVLocation kFrontFender(3, 270);
Austin Schuh4ea06c12016-03-12 17:54:31 -080062const ButtonLocation kIntakeIn(3, 12);
Austin Schuh4ea06c12016-03-12 17:54:31 -080063const ButtonLocation kFire(3, 3);
Austin Schuh4ea06c12016-03-12 17:54:31 -080064const ButtonLocation kIntakeOut(3, 9);
Austin Schuh843412b2016-03-20 16:48:46 -070065const ButtonLocation kPortcullis(3, 7);
66const ButtonLocation kChevalDeFrise(3, 8);
Comran Morshed200dd4b2016-02-16 17:54:58 +000067
Austin Schuhadd6d792016-03-19 01:20:01 -070068const ButtonLocation kVisionAlign(3, 4);
Austin Schuhb0099642016-04-03 21:37:27 -070069constexpr double kDownOffset = 0.011;
Austin Schuh18799112016-03-16 22:09:54 -070070
Comran Morshed9a9948c2016-01-16 15:58:04 +000071class Reader : public ::aos::input::JoystickInput {
72 public:
73 Reader()
Austin Schuh94596dd2016-03-13 21:41:26 -070074 : is_high_gear_(true),
Comran Morshed200dd4b2016-02-16 17:54:58 +000075 intake_goal_(0.0),
76 shoulder_goal_(M_PI / 2.0),
Austin Schuhd52df772016-03-19 15:38:41 -070077 wrist_goal_(0.0),
78 dt_config_(control_loops::drivetrain::GetDrivetrainConfig()) {}
Comran Morshed9a9948c2016-01-16 15:58:04 +000079
80 void RunIteration(const ::aos::input::driver_station::Data &data) override {
81 bool last_auto_running = auto_running_;
82 auto_running_ = data.GetControlBit(ControlBit::kAutonomous) &&
83 data.GetControlBit(ControlBit::kEnabled);
84 if (auto_running_ != last_auto_running) {
85 if (auto_running_) {
86 StartAuto();
87 } else {
88 StopAuto();
89 }
90 }
91
Austin Schuh94596dd2016-03-13 21:41:26 -070092 if (!data.GetControlBit(ControlBit::kEnabled)) {
93 // If we are not enabled, reset the waiting for zero bit.
94 LOG(DEBUG, "Waiting for zero.\n");
95 waiting_for_zero_ = true;
96 is_high_gear_ = true;
97 }
98
Austin Schuhadd6d792016-03-19 01:20:01 -070099 vision_valid_ = false;
100
101 ::y2016::vision::vision_status.FetchLatest();
102
103 if (::y2016::vision::vision_status.get()) {
104 vision_valid_ = (::y2016::vision::vision_status->left_image_valid &&
105 ::y2016::vision::vision_status->right_image_valid);
Austin Schuhd52df772016-03-19 15:38:41 -0700106 last_angle_ = ::y2016::vision::vision_status->horizontal_angle;
Austin Schuhadd6d792016-03-19 01:20:01 -0700107 }
108
Austin Schuh94596dd2016-03-13 21:41:26 -0700109 if (!auto_running_) {
Comran Morshed9a9948c2016-01-16 15:58:04 +0000110 HandleDrivetrain(data);
111 HandleTeleop(data);
112 }
Austin Schuh81d71db2016-03-15 20:56:24 -0700113
114 // Process any pending actions.
115 action_queue_.Tick();
116 was_running_ = action_queue_.Running();
Comran Morshed9a9948c2016-01-16 15:58:04 +0000117 }
118
119 void HandleDrivetrain(const ::aos::input::driver_station::Data &data) {
120 bool is_control_loop_driving = false;
Austin Schuh781cdcc2016-03-12 13:03:12 -0800121 static double left_goal = 0.0;
122 static double right_goal = 0.0;
123
Comran Morshed9a9948c2016-01-16 15:58:04 +0000124 const double wheel = -data.GetAxis(kSteeringWheel);
125 const double throttle = -data.GetAxis(kDriveThrottle);
Austin Schuhb0099642016-04-03 21:37:27 -0700126 drivetrain_queue.status.FetchLatest();
Comran Morshed9a9948c2016-01-16 15:58:04 +0000127
Austin Schuhadd6d792016-03-19 01:20:01 -0700128 if (data.IsPressed(kVisionAlign) && vision_valid_ &&
129 !vision_action_running_) {
Austin Schuh18799112016-03-16 22:09:54 -0700130 actors::VisionAlignActionParams params;
131 action_queue_.EnqueueAction(actors::MakeVisionAlignAction(params));
Austin Schuhadd6d792016-03-19 01:20:01 -0700132 vision_action_running_ = true;
Austin Schuh18799112016-03-16 22:09:54 -0700133 }
134
135 if (data.NegEdge(kVisionAlign)) {
136 action_queue_.CancelAllActions();
137 }
Austin Schuhadd6d792016-03-19 01:20:01 -0700138 if (!data.IsPressed(kVisionAlign)) {
139 vision_action_running_ = false;
140 }
Austin Schuh18799112016-03-16 22:09:54 -0700141
142 // Don't do any normal drivetrain stuff if vision is in charge.
143 if (was_running_) {
144 return;
145 }
146
Austin Schuh781cdcc2016-03-12 13:03:12 -0800147 if (data.PosEdge(kTurn1) || data.PosEdge(kTurn2)) {
Austin Schuh781cdcc2016-03-12 13:03:12 -0800148 if (drivetrain_queue.status.get()) {
Austin Schuh45d07f62016-03-13 15:33:31 -0700149 left_goal = drivetrain_queue.status->estimated_left_position;
150 right_goal = drivetrain_queue.status->estimated_right_position;
Austin Schuh781cdcc2016-03-12 13:03:12 -0800151 }
152 }
153 if (data.IsPressed(kTurn1) || data.IsPressed(kTurn2)) {
154 is_control_loop_driving = true;
155 }
Comran Morshed9a9948c2016-01-16 15:58:04 +0000156 if (!drivetrain_queue.goal.MakeWithBuilder()
157 .steering(wheel)
158 .throttle(throttle)
159 .highgear(is_high_gear_)
160 .quickturn(data.IsPressed(kQuickTurn))
161 .control_loop_driving(is_control_loop_driving)
Austin Schuh45d07f62016-03-13 15:33:31 -0700162 .left_goal(left_goal - wheel * 0.5 + throttle * 0.3)
163 .right_goal(right_goal + wheel * 0.5 + throttle * 0.3)
Comran Morshed9a9948c2016-01-16 15:58:04 +0000164 .left_velocity_goal(0)
165 .right_velocity_goal(0)
166 .Send()) {
167 LOG(WARNING, "sending stick values failed\n");
168 }
Comran Morshed6c6a0a92016-01-17 12:45:16 +0000169
Campbell Crowley5b27f022016-02-20 16:55:35 -0800170 if (data.PosEdge(kShiftLow)) {
Comran Morshed9a9948c2016-01-16 15:58:04 +0000171 is_high_gear_ = false;
172 }
Comran Morshed6c6a0a92016-01-17 12:45:16 +0000173
Campbell Crowley5b27f022016-02-20 16:55:35 -0800174 if (data.PosEdge(kShiftHigh) || data.PosEdge(kShiftHigh2)) {
Comran Morshed9a9948c2016-01-16 15:58:04 +0000175 is_high_gear_ = true;
176 }
177 }
178
Comran Morshed9a9948c2016-01-16 15:58:04 +0000179 void HandleTeleop(const ::aos::input::driver_station::Data &data) {
Austin Schuh45d07f62016-03-13 15:33:31 -0700180 // Default the intake to up.
181 intake_goal_ = constants::Values::kIntakeRange.upper - 0.04;
182
183 bool force_lights_on = false;
Comran Morshed9a9948c2016-01-16 15:58:04 +0000184 if (!data.GetControlBit(ControlBit::kEnabled)) {
185 action_queue_.CancelAllActions();
Comran Morshed6c6a0a92016-01-17 12:45:16 +0000186 LOG(DEBUG, "Canceling\n");
Comran Morshed9a9948c2016-01-16 15:58:04 +0000187 }
188
Comran Morshed200dd4b2016-02-16 17:54:58 +0000189 superstructure_queue.status.FetchLatest();
190 if (!superstructure_queue.status.get()) {
191 LOG(ERROR, "Got no superstructure status packet.\n");
192 }
193
194 if (superstructure_queue.status.get() &&
195 superstructure_queue.status->zeroed) {
196 if (waiting_for_zero_) {
Austin Schuh94596dd2016-03-13 21:41:26 -0700197 LOG(DEBUG, "Zeroed! Starting teleop mode.\n");
Comran Morshed200dd4b2016-02-16 17:54:58 +0000198 waiting_for_zero_ = false;
199 }
200 } else {
201 waiting_for_zero_ = true;
202 }
203
Austin Schuhadd6d792016-03-19 01:20:01 -0700204 double intake_when_shooting = kMaxIntakeAngleBeforeArmInterference;
205 bool use_slow_profile = false;
206 if (vision_action_running_) {
207 use_slow_profile = true;
208 if (vision_valid_) {
209 intake_when_shooting -= 0.5;
210 }
211 }
212
Austin Schuh4105ac82016-03-26 19:44:43 -0700213 if (data.IsPressed(kHigherFrontLong)) {
214 // Forwards shot
215 shoulder_goal_ = M_PI / 2.0 + 0.1;
216 wrist_goal_ = M_PI + 0.43;
Austin Schuhb0099642016-04-03 21:37:27 -0700217 if (drivetrain_queue.status.get()) {
218 wrist_goal_ += drivetrain_queue.status->ground_angle + kDownOffset;
219 }
Austin Schuh4105ac82016-03-26 19:44:43 -0700220 shooter_velocity_ = 640.0;
221 intake_goal_ = intake_when_shooting;
222 } else if (data.IsPressed(kFrontLong)) {
Austin Schuh4ea06c12016-03-12 17:54:31 -0800223 // Forwards shot
Austin Schuh3d79cc02016-03-20 21:08:53 -0700224 shoulder_goal_ = M_PI / 2.0 + 0.1;
Austin Schuhb0099642016-04-03 21:37:27 -0700225 wrist_goal_ = M_PI + 0.41;
226 if (drivetrain_queue.status.get()) {
227 wrist_goal_ += drivetrain_queue.status->ground_angle + kDownOffset;
228 }
Austin Schuh4ea06c12016-03-12 17:54:31 -0800229 shooter_velocity_ = 640.0;
Austin Schuhadd6d792016-03-19 01:20:01 -0700230 intake_goal_ = intake_when_shooting;
Austin Schuh4ea06c12016-03-12 17:54:31 -0800231 } else if (data.IsPressed(kBackLong)) {
232 // Backwards shot
Austin Schuh3d79cc02016-03-20 21:08:53 -0700233 shoulder_goal_ = M_PI / 2.0 - 0.4;
234 wrist_goal_ = -0.62;
Austin Schuhb0099642016-04-03 21:37:27 -0700235 if (drivetrain_queue.status.get()) {
236 wrist_goal_ += drivetrain_queue.status->ground_angle + kDownOffset;
237 }
Austin Schuh4ea06c12016-03-12 17:54:31 -0800238 shooter_velocity_ = 640.0;
Austin Schuhadd6d792016-03-19 01:20:01 -0700239 intake_goal_ = intake_when_shooting;
Austin Schuh45d07f62016-03-13 15:33:31 -0700240 } else if (data.IsPressed(kBackFender)) {
241 // Fender shot back
242 shoulder_goal_ = 0.65;
Austin Schuh214164b2016-03-20 16:50:09 -0700243 wrist_goal_ = -1.20;
Austin Schuh45d07f62016-03-13 15:33:31 -0700244 shooter_velocity_ = 550.0;
Austin Schuhadd6d792016-03-19 01:20:01 -0700245 intake_goal_ = intake_when_shooting;
Austin Schuh45d07f62016-03-13 15:33:31 -0700246 } else if (data.IsPressed(kFrontFender)) {
247 // Fender shot back
248 shoulder_goal_ = 1.45;
249 wrist_goal_ = 2.5 + 1.7;
250 shooter_velocity_ = 550.0;
Austin Schuhadd6d792016-03-19 01:20:01 -0700251 intake_goal_ = intake_when_shooting;
Austin Schuhde802e92016-02-27 14:49:03 -0800252 } else {
Austin Schuh4ea06c12016-03-12 17:54:31 -0800253 wrist_goal_ = 0.0;
Austin Schuh3f0b1192016-03-12 13:03:56 -0800254 shoulder_goal_ = -0.010;
Austin Schuh4ea06c12016-03-12 17:54:31 -0800255 shooter_velocity_ = 0.0;
Comran Morshed200dd4b2016-02-16 17:54:58 +0000256 }
257
Comran Morshedaa0573c2016-03-05 19:05:54 +0000258 bool ball_detected = false;
259 ::y2016::sensors::ball_detector.FetchLatest();
260 if (::y2016::sensors::ball_detector.get()) {
261 ball_detected = ::y2016::sensors::ball_detector->voltage > 2.5;
262 }
263 if (data.PosEdge(kIntakeIn)) {
264 saw_ball_when_started_intaking_ = ball_detected;
265 }
266
Austin Schuh45d07f62016-03-13 15:33:31 -0700267 if (data.IsPressed(kIntakeIn)) {
268 is_intaking_ = (!ball_detected || saw_ball_when_started_intaking_);
269 if (ball_detected) {
270 force_lights_on = true;
271 }
272 } else {
273 is_intaking_ = false;
274 }
275
Austin Schuhd52df772016-03-19 15:38:41 -0700276 fire_ = false;
Austin Schuh4ea06c12016-03-12 17:54:31 -0800277 if (data.IsPressed(kFire) && shooter_velocity_ != 0.0) {
Austin Schuhd52df772016-03-19 15:38:41 -0700278 if (data.IsPressed(kVisionAlign)) {
279 // Make sure that we are lined up.
280 drivetrain_queue.status.FetchLatest();
281 drivetrain_queue.goal.FetchLatest();
282 if (drivetrain_queue.status.get() && drivetrain_queue.goal.get()) {
283 const double left_goal = drivetrain_queue.goal->left_goal;
284 const double right_goal = drivetrain_queue.goal->right_goal;
285 const double left_current =
286 drivetrain_queue.status->estimated_left_position;
287 const double right_current =
288 drivetrain_queue.status->estimated_right_position;
289 const double left_velocity =
290 drivetrain_queue.status->estimated_left_velocity;
291 const double right_velocity =
292 drivetrain_queue.status->estimated_right_velocity;
293 if (vision_action_running_ && ::std::abs(last_angle_) < 0.02 &&
294 ::std::abs((left_goal - right_goal) -
295 (left_current - right_current)) /
296 dt_config_.robot_radius / 2.0 <
297 0.02 &&
298 ::std::abs(left_velocity - right_velocity) < 0.01) {
299 ++ready_to_fire_;
300 } else {
301 ready_to_fire_ = 0;
302 }
Austin Schuh3d79cc02016-03-20 21:08:53 -0700303 if (ready_to_fire_ > 9) {
Austin Schuhd52df772016-03-19 15:38:41 -0700304 fire_ = true;
305 }
306 }
307 } else {
308 fire_ = true;
309 }
Comran Morshed200dd4b2016-02-16 17:54:58 +0000310 }
311
Austin Schuh4ea06c12016-03-12 17:54:31 -0800312 is_outtaking_ = data.IsPressed(kIntakeOut);
Austin Schuh5a6db4d2016-02-28 22:02:42 -0800313
Austin Schuhd52df772016-03-19 15:38:41 -0700314 if (is_intaking_ || is_outtaking_) {
315 recently_intaking_accumulator_ = 20;
316 }
317
318 if (data.IsPressed(kIntakeDown)) {
319 if (recently_intaking_accumulator_) {
320 intake_goal_ = 0.1;
321 } else {
322 intake_goal_ = -0.05;
323 }
324 }
325
326 if (recently_intaking_accumulator_ > 0) {
327 --recently_intaking_accumulator_;
328 }
329
Austin Schuh843412b2016-03-20 16:48:46 -0700330 if (data.IsPressed(kPortcullis)) {
331 traverse_unlatched_ = true;
332 traverse_down_ = true;
333 } else if (data.IsPressed(kChevalDeFrise)) {
334 traverse_unlatched_ = false;
335 traverse_down_ = true;
336 } else {
337 traverse_unlatched_ = true;
338 traverse_down_ = false;
339 }
340
Comran Morshed200dd4b2016-02-16 17:54:58 +0000341 if (!waiting_for_zero_) {
Austin Schuhadd6d792016-03-19 01:20:01 -0700342 auto new_superstructure_goal = superstructure_queue.goal.MakeMessage();
343 new_superstructure_goal->angle_intake = intake_goal_;
344 new_superstructure_goal->angle_shoulder = shoulder_goal_;
345 new_superstructure_goal->angle_wrist = wrist_goal_;
Austin Schuh3f0b1192016-03-12 13:03:56 -0800346
Austin Schuhadd6d792016-03-19 01:20:01 -0700347 new_superstructure_goal->max_angular_velocity_intake = 7.0;
348 new_superstructure_goal->max_angular_velocity_shoulder = 4.0;
349 new_superstructure_goal->max_angular_velocity_wrist = 10.0;
350 if (use_slow_profile) {
351 new_superstructure_goal->max_angular_acceleration_intake = 10.0;
352 } else {
Austin Schuh3f0b1192016-03-12 13:03:56 -0800353 new_superstructure_goal->max_angular_acceleration_intake = 40.0;
Austin Schuhadd6d792016-03-19 01:20:01 -0700354 }
355 new_superstructure_goal->max_angular_acceleration_shoulder = 10.0;
Austin Schuhb0099642016-04-03 21:37:27 -0700356 if (shoulder_goal_ > 1.0) {
357 new_superstructure_goal->max_angular_acceleration_wrist = 45.0;
358 } else {
359 new_superstructure_goal->max_angular_acceleration_wrist = 25.0;
360 }
Austin Schuh3f0b1192016-03-12 13:03:56 -0800361
Austin Schuhadd6d792016-03-19 01:20:01 -0700362 // Granny mode
363 /*
364 new_superstructure_goal->max_angular_velocity_intake = 0.2;
365 new_superstructure_goal->max_angular_velocity_shoulder = 0.2;
366 new_superstructure_goal->max_angular_velocity_wrist = 0.2;
367 new_superstructure_goal->max_angular_acceleration_intake = 1.0;
368 new_superstructure_goal->max_angular_acceleration_shoulder = 1.0;
369 new_superstructure_goal->max_angular_acceleration_wrist = 1.0;
370 */
371 if (is_intaking_) {
372 new_superstructure_goal->voltage_top_rollers = 12.0;
373 new_superstructure_goal->voltage_bottom_rollers = 12.0;
374 } else if (is_outtaking_) {
375 new_superstructure_goal->voltage_top_rollers = -12.0;
376 new_superstructure_goal->voltage_bottom_rollers = -7.0;
377 } else {
378 new_superstructure_goal->voltage_top_rollers = 0.0;
379 new_superstructure_goal->voltage_bottom_rollers = 0.0;
380 }
Comran Morshed200dd4b2016-02-16 17:54:58 +0000381
Austin Schuh843412b2016-03-20 16:48:46 -0700382 new_superstructure_goal->traverse_unlatched = traverse_unlatched_;
383 new_superstructure_goal->traverse_down = traverse_down_;
Austin Schuh1defd262016-04-03 16:13:32 -0700384 new_superstructure_goal->force_intake = true;
Austin Schuh843412b2016-03-20 16:48:46 -0700385
Austin Schuhadd6d792016-03-19 01:20:01 -0700386 if (!new_superstructure_goal.Send()) {
387 LOG(ERROR, "Sending superstructure goal failed.\n");
388 } else {
389 LOG(DEBUG, "sending goals: intake: %f, shoulder: %f, wrist: %f\n",
390 intake_goal_, shoulder_goal_, wrist_goal_);
391 }
Comran Morshed200dd4b2016-02-16 17:54:58 +0000392
Austin Schuhadd6d792016-03-19 01:20:01 -0700393 if (!shooter_queue.goal.MakeWithBuilder()
394 .angular_velocity(shooter_velocity_)
395 .clamp_open(is_intaking_ || is_outtaking_)
396 .push_to_shooter(fire_)
397 .force_lights_on(force_lights_on)
Austin Schuhb2c33382016-04-03 16:09:17 -0700398 .shooting_forwards(wrist_goal_ > 0)
Austin Schuhadd6d792016-03-19 01:20:01 -0700399 .Send()) {
400 LOG(ERROR, "Sending shooter goal failed.\n");
Comran Morshed200dd4b2016-02-16 17:54:58 +0000401 }
402 }
Comran Morshed9a9948c2016-01-16 15:58:04 +0000403 }
404
Comran Morshed9a9948c2016-01-16 15:58:04 +0000405 private:
406 void StartAuto() {
407 LOG(INFO, "Starting auto mode\n");
Comran Morshede68e3732016-03-12 14:12:11 +0000408
409 actors::AutonomousActionParams params;
Brian Silverman68cb5c22016-03-20 18:11:14 -0700410 actors::auto_mode.FetchLatest();
411 if (actors::auto_mode.get() != nullptr) {
412 params.mode = actors::auto_mode->mode;
413 } else {
414 LOG(WARNING, "no auto mode values\n");
415 params.mode = 0;
416 }
Comran Morshede68e3732016-03-12 14:12:11 +0000417 action_queue_.EnqueueAction(actors::MakeAutonomousAction(params));
Comran Morshed9a9948c2016-01-16 15:58:04 +0000418 }
419
420 void StopAuto() {
421 LOG(INFO, "Stopping auto mode\n");
Comran Morshede68e3732016-03-12 14:12:11 +0000422 action_queue_.CancelAllActions();
Comran Morshed9a9948c2016-01-16 15:58:04 +0000423 }
424
425 bool is_high_gear_;
Comran Morshed200dd4b2016-02-16 17:54:58 +0000426 // Whatever these are set to are our default goals to send out after zeroing.
427 double intake_goal_;
428 double shoulder_goal_;
429 double wrist_goal_;
Austin Schuhde802e92016-02-27 14:49:03 -0800430 double shooter_velocity_ = 0.0;
Comran Morshed200dd4b2016-02-16 17:54:58 +0000431
432 bool was_running_ = false;
Comran Morshed9a9948c2016-01-16 15:58:04 +0000433 bool auto_running_ = false;
434
Austin Schuh843412b2016-03-20 16:48:46 -0700435 bool traverse_unlatched_ = false;
436 bool traverse_down_ = false;
437
Comran Morshed200dd4b2016-02-16 17:54:58 +0000438 // If we're waiting for the subsystems to zero.
439 bool waiting_for_zero_ = true;
440
Comran Morshedaa0573c2016-03-05 19:05:54 +0000441 // If true, the ball was present when the intaking button was pressed.
442 bool saw_ball_when_started_intaking_ = false;
443
Austin Schuhde802e92016-02-27 14:49:03 -0800444 bool is_intaking_ = false;
Austin Schuh5a6db4d2016-02-28 22:02:42 -0800445 bool is_outtaking_ = false;
Austin Schuhde802e92016-02-27 14:49:03 -0800446 bool fire_ = false;
447
Austin Schuhadd6d792016-03-19 01:20:01 -0700448 bool vision_action_running_ = false;
449 bool vision_valid_ = false;
450
Austin Schuhd52df772016-03-19 15:38:41 -0700451 int recently_intaking_accumulator_ = 0;
452 double last_angle_ = 100;
453
454 int ready_to_fire_ = 0;
455
Comran Morshed9a9948c2016-01-16 15:58:04 +0000456 ::aos::common::actions::ActionQueue action_queue_;
457
Austin Schuhd52df772016-03-19 15:38:41 -0700458 const ::frc971::control_loops::drivetrain::DrivetrainConfig dt_config_;
459
Comran Morshed9a9948c2016-01-16 15:58:04 +0000460 ::aos::util::SimpleLogInterval no_drivetrain_status_ =
461 ::aos::util::SimpleLogInterval(::aos::time::Time::InSeconds(0.2), WARNING,
462 "no drivetrain status");
463};
464
465} // namespace joysticks
466} // namespace input
Comran Morshed6c6a0a92016-01-17 12:45:16 +0000467} // namespace y2016
Comran Morshed9a9948c2016-01-16 15:58:04 +0000468
469int main() {
470 ::aos::Init(-1);
Comran Morshed6c6a0a92016-01-17 12:45:16 +0000471 ::y2016::input::joysticks::Reader reader;
Comran Morshed9a9948c2016-01-16 15:58:04 +0000472 reader.Run();
473 ::aos::Cleanup();
474}