blob: e2acb8bbeab97f5518811f72d1e059be1651e518 [file] [log] [blame]
Comran Morshed41ed7c22015-11-04 21:03:37 +00001#include <stdio.h>
2#include <string.h>
3#include <unistd.h>
4#include <math.h>
5
John Park398c74a2018-10-20 21:17:39 -07006#include "aos/init.h"
Brian Silvermanc2065732015-11-28 22:55:30 +00007#include "aos/input/joystick_input.h"
John Park33858a32018-09-28 23:05:48 -07008#include "aos/input/driver_station_data.h"
9#include "aos/logging/logging.h"
10#include "aos/util/log_interval.h"
11#include "aos/time/time.h"
Comran Morshed41ed7c22015-11-04 21:03:37 +000012
Austin Schuh0b560152019-01-04 17:02:27 -080013#include "aos/input/drivetrain_input.h"
14#include "frc971/autonomous/auto.q.h"
15#include "frc971/autonomous/base_autonomous_actor.h"
Adam Snaider83eae562016-09-10 16:47:33 -070016#include "frc971/control_loops/drivetrain/drivetrain.q.h"
Austin Schuh0b560152019-01-04 17:02:27 -080017#include "frc971/queues/gyro.q.h"
18#include "y2014_bot3/control_loops/drivetrain/drivetrain_base.h"
Comran Morshed41ed7c22015-11-04 21:03:37 +000019#include "y2014_bot3/control_loops/rollers/rollers.q.h"
20
Adam Snaider83eae562016-09-10 16:47:33 -070021using ::frc971::control_loops::drivetrain_queue;
Comran Morshed41ed7c22015-11-04 21:03:37 +000022using ::y2014_bot3::control_loops::rollers_queue;
23using ::frc971::sensors::gyro_reading;
24
25using ::aos::input::driver_station::ButtonLocation;
26using ::aos::input::driver_station::POVLocation;
27using ::aos::input::driver_station::JoystickAxis;
28using ::aos::input::driver_station::ControlBit;
Austin Schuh0b560152019-01-04 17:02:27 -080029using ::aos::input::DrivetrainInputReader;
Comran Morshed41ed7c22015-11-04 21:03:37 +000030
31namespace y2014_bot3 {
32namespace input {
33namespace joysticks {
34
35// Joystick & button addresses.
36const JoystickAxis kSteeringWheel(1, 1), kDriveThrottle(2, 2);
Adam Snaider83eae562016-09-10 16:47:33 -070037const ButtonLocation kShiftHigh(2, 3), kShiftHigh2(2, 2), kShiftLow(2, 1);
Comran Morshed41ed7c22015-11-04 21:03:37 +000038const ButtonLocation kQuickTurn(1, 5);
39
Adam Snaider83eae562016-09-10 16:47:33 -070040const ButtonLocation kTurn1(1, 7);
41const ButtonLocation kTurn2(1, 11);
42
Comran Morshed41ed7c22015-11-04 21:03:37 +000043const ButtonLocation kFrontRollersIn(3, 8);
44const ButtonLocation kBackRollersIn(3, 7);
45const ButtonLocation kFrontRollersOut(3, 6);
46const ButtonLocation kBackRollersOut(4, 12);
47const ButtonLocation kHumanPlayer(4, 11);
48
49class Reader : public ::aos::input::JoystickInput {
50 public:
Austin Schuh3e45c752019-02-02 12:19:11 -080051 Reader(::aos::EventLoop *event_loop)
52 : ::aos::input::JoystickInput(event_loop) {
Austin Schuh0b560152019-01-04 17:02:27 -080053 drivetrain_input_reader_ = DrivetrainInputReader::Make(
54 DrivetrainInputReader::InputType::kSteeringWheel,
55 ::y2014_bot3::control_loops::drivetrain::GetDrivetrainConfig());
56 }
Comran Morshed41ed7c22015-11-04 21:03:37 +000057
58 virtual void RunIteration(const ::aos::input::driver_station::Data &data) {
59 bool last_auto_running = auto_running_;
60 auto_running_ = data.GetControlBit(ControlBit::kAutonomous) &&
61 data.GetControlBit(ControlBit::kEnabled);
62 if (auto_running_ != last_auto_running) {
63 if (auto_running_) {
64 StartAuto();
65 } else {
66 StopAuto();
67 }
68 }
69
70 if (!data.GetControlBit(ControlBit::kAutonomous)) {
71 HandleDrivetrain(data);
72 HandleTeleop(data);
73 }
Austin Schuh0b560152019-01-04 17:02:27 -080074
75 action_queue_.Tick();
Comran Morshed41ed7c22015-11-04 21:03:37 +000076 }
77
78 void HandleDrivetrain(const ::aos::input::driver_station::Data &data) {
Austin Schuh0b560152019-01-04 17:02:27 -080079 drivetrain_input_reader_->HandleDrivetrain(data);
Comran Morshed41ed7c22015-11-04 21:03:37 +000080 }
81
82 void HandleTeleop(const ::aos::input::driver_station::Data &data) {
Austin Schuh0b560152019-01-04 17:02:27 -080083 if (!data.GetControlBit(ControlBit::kEnabled)) {
84 action_queue_.CancelAllActions();
85 LOG(DEBUG, "Canceling\n");
86 }
87
Comran Morshed41ed7c22015-11-04 21:03:37 +000088 // Rollers.
89 auto rollers_goal = control_loops::rollers_queue.goal.MakeMessage();
90 rollers_goal->Zero();
91 if (data.IsPressed(kFrontRollersIn)) {
92 rollers_goal->intake = 1;
93 } else if (data.IsPressed(kFrontRollersOut)) {
94 rollers_goal->low_spit = 1;
95 } else if (data.IsPressed(kBackRollersIn)) {
96 rollers_goal->intake = -1;
97 } else if (data.IsPressed(kBackRollersOut)) {
98 rollers_goal->low_spit = -1;
99 } else if (data.IsPressed(kHumanPlayer)) {
100 rollers_goal->human_player = true;
101 }
102 if (!rollers_goal.Send()) {
103 LOG(WARNING, "Sending rollers values failed.\n");
104 }
105 }
106
107 private:
108 void StartAuto() {
109 LOG(INFO, "Starting auto mode.\n");
Austin Schuh0b560152019-01-04 17:02:27 -0800110 ::frc971::autonomous::AutonomousActionParams params;
111 params.mode = 0;
112 action_queue_.EnqueueAction(
113 ::frc971::autonomous::MakeAutonomousAction(params));
Comran Morshed41ed7c22015-11-04 21:03:37 +0000114 }
115
116 void StopAuto() {
117 LOG(INFO, "Stopping auto mode\n");
Austin Schuh0b560152019-01-04 17:02:27 -0800118 action_queue_.CancelAllActions();
Comran Morshed41ed7c22015-11-04 21:03:37 +0000119 }
120
121 bool auto_running_ = false;
122
Comran Morshed41ed7c22015-11-04 21:03:37 +0000123 ::aos::util::SimpleLogInterval no_drivetrain_status_ =
Austin Schuh61bdc602016-12-04 19:10:10 -0800124 ::aos::util::SimpleLogInterval(::std::chrono::milliseconds(200), WARNING,
Comran Morshed41ed7c22015-11-04 21:03:37 +0000125 "no drivetrain status");
Austin Schuh0b560152019-01-04 17:02:27 -0800126
127 ::aos::common::actions::ActionQueue action_queue_;
128
129 ::std::unique_ptr<DrivetrainInputReader> drivetrain_input_reader_;
Comran Morshed41ed7c22015-11-04 21:03:37 +0000130};
131
132} // namespace joysticks
133} // namespace input
134} // namespace y2014_bot3
135
136int main() {
Brian Silverman5090c432016-01-02 14:44:26 -0800137 ::aos::Init(-1);
Austin Schuh3e45c752019-02-02 12:19:11 -0800138 ::aos::ShmEventLoop event_loop;
139 ::y2014_bot3::input::joysticks::Reader reader(&event_loop);
Comran Morshed41ed7c22015-11-04 21:03:37 +0000140 reader.Run();
141 ::aos::Cleanup();
142}