milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 1 | #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 Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 13 | #include "frc971/control_loops/drivetrain/localizer_generated.h" |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 14 | #include "frc971/control_loops/profiled_subsystem_generated.h" |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 15 | #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 Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 19 | #include "frc971/zeroing/wrap.h" |
| 20 | #include "y2022/constants.h" |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 21 | #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 Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 24 | #include "y2022/setpoint_generated.h" |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 25 | |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 26 | using frc971::CreateProfileParameters; |
| 27 | using frc971::control_loops::CreateStaticZeroingSingleDOFProfiledSubsystemGoal; |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 28 | using frc971::control_loops::StaticZeroingSingleDOFProfiledSubsystemGoal; |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 29 | using frc971::input::driver_station::ButtonLocation; |
| 30 | using frc971::input::driver_station::ControlBit; |
| 31 | using frc971::input::driver_station::JoystickAxis; |
| 32 | using frc971::input::driver_station::POVLocation; |
| 33 | |
| 34 | namespace y2022 { |
| 35 | namespace input { |
| 36 | namespace joysticks { |
| 37 | |
| 38 | namespace superstructure = y2022::control_loops::superstructure; |
| 39 | |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 40 | // TODO(henry) put actually button locations here |
| 41 | // TODO(milind): integrate with shooting statemachine and aimer |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 42 | #if 0 |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 43 | const ButtonLocation kCatapultPos(4, 3); |
| 44 | const ButtonLocation kFire(3, 4); |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 45 | const ButtonLocation kTurret(4, 15); |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 46 | |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 47 | const ButtonLocation kIntakeFrontOut(4, 10); |
| 48 | const ButtonLocation kIntakeBackOut(4, 9); |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 49 | |
| 50 | const ButtonLocation kRedLocalizerReset(3, 13); |
| 51 | const ButtonLocation kBlueLocalizerReset(3, 14); |
| 52 | const ButtonLocation kLocalizerReset(3, 8); |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 53 | #else |
| 54 | |
| 55 | const ButtonLocation kCatapultPos(4, 3); |
| 56 | const ButtonLocation kFire(4, 1); |
| 57 | const ButtonLocation kTurret(4, 15); |
| 58 | |
| 59 | const ButtonLocation kIntakeFrontOut(4, 10); |
| 60 | const ButtonLocation kIntakeBackOut(4, 9); |
| 61 | |
| 62 | const ButtonLocation kRedLocalizerReset(3, 13); |
| 63 | const ButtonLocation kBlueLocalizerReset(3, 14); |
| 64 | const ButtonLocation kLocalizerReset(3, 8); |
| 65 | #endif |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 66 | |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 67 | class Reader : public ::frc971::input::ActionJoystickInput { |
| 68 | public: |
| 69 | Reader(::aos::EventLoop *event_loop) |
| 70 | : ::frc971::input::ActionJoystickInput( |
| 71 | event_loop, |
| 72 | ::y2022::control_loops::drivetrain::GetDrivetrainConfig(), |
| 73 | ::frc971::input::DrivetrainInputReader::InputType::kPistol, {}), |
| 74 | superstructure_goal_sender_( |
| 75 | event_loop->MakeSender<superstructure::Goal>("/superstructure")), |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 76 | localizer_control_sender_( |
| 77 | event_loop->MakeSender< |
| 78 | ::frc971::control_loops::drivetrain::LocalizerControl>( |
| 79 | "/drivetrain")), |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 80 | superstructure_status_fetcher_( |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 81 | event_loop->MakeFetcher<superstructure::Status>("/superstructure")), |
| 82 | setpoint_fetcher_( |
| 83 | event_loop->MakeFetcher<Setpoint>("/superstructure")) {} |
| 84 | |
| 85 | void BlueResetLocalizer() { |
| 86 | auto builder = localizer_control_sender_.MakeBuilder(); |
| 87 | |
| 88 | frc971::control_loops::drivetrain::LocalizerControl::Builder |
| 89 | localizer_control_builder = builder.MakeBuilder< |
| 90 | frc971::control_loops::drivetrain::LocalizerControl>(); |
| 91 | localizer_control_builder.add_x(7.4); |
| 92 | localizer_control_builder.add_y(-1.7); |
| 93 | localizer_control_builder.add_theta_uncertainty(10.0); |
| 94 | localizer_control_builder.add_theta(0.0); |
| 95 | localizer_control_builder.add_keep_current_theta(false); |
| 96 | if (builder.Send(localizer_control_builder.Finish()) != |
| 97 | aos::RawSender::Error::kOk) { |
| 98 | AOS_LOG(ERROR, "Failed to reset blue localizer.\n"); |
| 99 | } |
| 100 | } |
| 101 | |
| 102 | void RedResetLocalizer() { |
| 103 | auto builder = localizer_control_sender_.MakeBuilder(); |
| 104 | |
| 105 | frc971::control_loops::drivetrain::LocalizerControl::Builder |
| 106 | localizer_control_builder = builder.MakeBuilder< |
| 107 | frc971::control_loops::drivetrain::LocalizerControl>(); |
| 108 | localizer_control_builder.add_x(-7.4); |
| 109 | localizer_control_builder.add_y(1.7); |
| 110 | localizer_control_builder.add_theta_uncertainty(10.0); |
| 111 | localizer_control_builder.add_theta(M_PI); |
| 112 | localizer_control_builder.add_keep_current_theta(false); |
| 113 | if (builder.Send(localizer_control_builder.Finish()) != |
| 114 | aos::RawSender::Error::kOk) { |
| 115 | AOS_LOG(ERROR, "Failed to reset red localizer.\n"); |
| 116 | } |
| 117 | } |
| 118 | |
| 119 | void ResetLocalizer() { |
| 120 | const frc971::control_loops::drivetrain::Status *drivetrain_status = |
| 121 | this->drivetrain_status(); |
| 122 | if (drivetrain_status == nullptr) { |
| 123 | return; |
| 124 | } |
| 125 | // Get the current position |
| 126 | // Snap to heading. |
| 127 | auto builder = localizer_control_sender_.MakeBuilder(); |
| 128 | |
| 129 | // TODO<Henry> Put our starting location here. |
| 130 | frc971::control_loops::drivetrain::LocalizerControl::Builder |
| 131 | localizer_control_builder = builder.MakeBuilder< |
| 132 | frc971::control_loops::drivetrain::LocalizerControl>(); |
| 133 | localizer_control_builder.add_x(drivetrain_status->x()); |
| 134 | localizer_control_builder.add_y(drivetrain_status->y()); |
| 135 | const double new_theta = |
| 136 | frc971::zeroing::Wrap(drivetrain_status->theta(), 0, M_PI); |
| 137 | localizer_control_builder.add_theta(new_theta); |
| 138 | localizer_control_builder.add_theta_uncertainty(10.0); |
| 139 | if (builder.Send(localizer_control_builder.Finish()) != |
| 140 | aos::RawSender::Error::kOk) { |
| 141 | AOS_LOG(ERROR, "Failed to reset localizer.\n"); |
| 142 | } |
| 143 | } |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 144 | |
| 145 | void AutoEnded() override { AOS_LOG(INFO, "Auto ended.\n"); } |
| 146 | |
| 147 | void HandleTeleop( |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 148 | const ::frc971::input::driver_station::Data &data) override { |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 149 | superstructure_status_fetcher_.Fetch(); |
| 150 | if (!superstructure_status_fetcher_.get()) { |
| 151 | AOS_LOG(ERROR, "Got no superstructure status message.\n"); |
| 152 | return; |
| 153 | } |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 154 | |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 155 | setpoint_fetcher_.Fetch(); |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 156 | |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 157 | // Default to the intakes in |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 158 | double intake_front_pos = 1.47; |
| 159 | double intake_back_pos = 1.47; |
Milind Upadhyay | b1a74ea | 2022-03-09 20:34:35 -0800 | [diff] [blame] | 160 | double transfer_roller_front_speed = 0.0; |
| 161 | double transfer_roller_back_speed = 0.0; |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 162 | |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 163 | double roller_front_speed = 0.0; |
| 164 | double roller_back_speed = 0.0; |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 165 | |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 166 | double turret_pos = 0.0; |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 167 | |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 168 | double catapult_pos = 0.03; |
| 169 | double catapult_speed = 18.0; |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 170 | double catapult_return_pos = 0.0; |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 171 | bool fire = false; |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 172 | |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 173 | if (data.PosEdge(kLocalizerReset)) { |
| 174 | ResetLocalizer(); |
| 175 | } |
| 176 | |
| 177 | if (data.PosEdge(kRedLocalizerReset)) { |
| 178 | RedResetLocalizer(); |
| 179 | } |
| 180 | if (data.PosEdge(kBlueLocalizerReset)) { |
| 181 | BlueResetLocalizer(); |
| 182 | } |
| 183 | |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 184 | if (data.IsPressed(kTurret)) { |
Milind Upadhyay | 9cb1421 | 2022-03-11 21:42:35 -0800 | [diff] [blame] | 185 | if (setpoint_fetcher_.get()) { |
| 186 | turret_pos = setpoint_fetcher_->turret(); |
| 187 | } else { |
| 188 | turret_pos = -1.5; |
| 189 | } |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 190 | } else { |
| 191 | turret_pos = 0.0; |
| 192 | } |
| 193 | |
Milind Upadhyay | 9cb1421 | 2022-03-11 21:42:35 -0800 | [diff] [blame] | 194 | if (setpoint_fetcher_.get()) { |
| 195 | catapult_pos = setpoint_fetcher_->catapult_position(); |
| 196 | catapult_speed = setpoint_fetcher_->catapult_velocity(); |
| 197 | } |
| 198 | |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 199 | // Keep the catapult return position at the shot one if kCatapultPos is |
| 200 | // pressed |
| 201 | if (data.IsPressed(kCatapultPos)) { |
| 202 | catapult_return_pos = 0.3; |
| 203 | } else { |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 204 | catapult_return_pos = -0.908; |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 205 | } |
| 206 | |
| 207 | // Extend the intakes and spin the rollers |
| 208 | if (data.IsPressed(kIntakeFrontOut)) { |
| 209 | intake_front_pos = 0.0; |
| 210 | roller_front_speed = 12.0; |
Milind Upadhyay | b1a74ea | 2022-03-09 20:34:35 -0800 | [diff] [blame] | 211 | transfer_roller_front_speed = 12.0; |
| 212 | transfer_roller_back_speed = -transfer_roller_front_speed; |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 213 | } else if (data.IsPressed(kIntakeBackOut)) { |
| 214 | roller_back_speed = 12.0; |
| 215 | intake_back_pos = 0.0; |
Milind Upadhyay | b1a74ea | 2022-03-09 20:34:35 -0800 | [diff] [blame] | 216 | transfer_roller_back_speed = 12.0; |
| 217 | transfer_roller_front_speed = -transfer_roller_back_speed; |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 218 | } |
| 219 | |
| 220 | if (data.IsPressed(kFire)) { |
| 221 | fire = true; |
| 222 | } |
| 223 | |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 224 | { |
| 225 | auto builder = superstructure_goal_sender_.MakeBuilder(); |
| 226 | |
| 227 | flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal> |
| 228 | intake_front_offset = |
| 229 | CreateStaticZeroingSingleDOFProfiledSubsystemGoal( |
| 230 | *builder.fbb(), intake_front_pos, |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 231 | CreateProfileParameters(*builder.fbb(), 8.0, 40.0)); |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 232 | flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal> |
| 233 | intake_back_offset = |
| 234 | CreateStaticZeroingSingleDOFProfiledSubsystemGoal( |
| 235 | *builder.fbb(), intake_back_pos, |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 236 | CreateProfileParameters(*builder.fbb(), 8.0, 40.0)); |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 237 | |
| 238 | flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal> |
| 239 | turret_offset = CreateStaticZeroingSingleDOFProfiledSubsystemGoal( |
| 240 | *builder.fbb(), turret_pos, |
Austin Schuh | 445ae83 | 2022-03-05 22:52:23 -0800 | [diff] [blame] | 241 | CreateProfileParameters(*builder.fbb(), 1.0, 10.0)); |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 242 | |
| 243 | flatbuffers::Offset<StaticZeroingSingleDOFProfiledSubsystemGoal> |
| 244 | catapult_return_offset = |
| 245 | CreateStaticZeroingSingleDOFProfiledSubsystemGoal( |
| 246 | *builder.fbb(), catapult_return_pos, |
milind-u | 37dc40b | 2022-03-08 19:51:27 -0800 | [diff] [blame] | 247 | frc971::CreateProfileParameters(*builder.fbb(), 9.0, 50.0)); |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 248 | |
| 249 | superstructure::CatapultGoal::Builder catapult_builder = |
| 250 | builder.MakeBuilder<superstructure::CatapultGoal>(); |
| 251 | catapult_builder.add_return_position(catapult_return_offset); |
| 252 | catapult_builder.add_shot_position(catapult_pos); |
| 253 | catapult_builder.add_shot_velocity(catapult_speed); |
| 254 | flatbuffers::Offset<superstructure::CatapultGoal> catapult_offset = |
| 255 | catapult_builder.Finish(); |
| 256 | |
| 257 | superstructure::Goal::Builder superstructure_goal_builder = |
| 258 | builder.MakeBuilder<superstructure::Goal>(); |
| 259 | |
| 260 | superstructure_goal_builder.add_intake_front(intake_front_offset); |
| 261 | superstructure_goal_builder.add_intake_back(intake_back_offset); |
| 262 | superstructure_goal_builder.add_turret(turret_offset); |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 263 | superstructure_goal_builder.add_catapult(catapult_offset); |
| 264 | superstructure_goal_builder.add_fire(fire); |
| 265 | |
| 266 | superstructure_goal_builder.add_roller_speed_front(roller_front_speed); |
| 267 | superstructure_goal_builder.add_roller_speed_back(roller_back_speed); |
Milind Upadhyay | b1a74ea | 2022-03-09 20:34:35 -0800 | [diff] [blame] | 268 | superstructure_goal_builder.add_transfer_roller_speed_front( |
| 269 | transfer_roller_front_speed); |
| 270 | superstructure_goal_builder.add_transfer_roller_speed_back( |
James Kuszmaul | d9959e0 | 2022-03-11 22:53:00 -0800 | [diff] [blame^] | 271 | transfer_roller_back_speed); |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 272 | |
| 273 | if (builder.Send(superstructure_goal_builder.Finish()) != |
| 274 | aos::RawSender::Error::kOk) { |
| 275 | AOS_LOG(ERROR, "Sending superstructure goal failed.\n"); |
| 276 | } |
Austin Schuh | 39f26f6 | 2022-02-24 21:34:46 -0800 | [diff] [blame] | 277 | } |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 278 | } |
| 279 | |
| 280 | private: |
| 281 | ::aos::Sender<superstructure::Goal> superstructure_goal_sender_; |
| 282 | |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 283 | ::aos::Sender<frc971::control_loops::drivetrain::LocalizerControl> |
| 284 | localizer_control_sender_; |
| 285 | |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 286 | ::aos::Fetcher<superstructure::Status> superstructure_status_fetcher_; |
Henry Speiser | 0b9b005 | 2022-03-02 23:07:40 -0800 | [diff] [blame] | 287 | |
| 288 | ::aos::Fetcher<Setpoint> setpoint_fetcher_; |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 289 | }; |
| 290 | |
| 291 | } // namespace joysticks |
| 292 | } // namespace input |
| 293 | } // namespace y2022 |
| 294 | |
| 295 | int main(int argc, char **argv) { |
| 296 | ::aos::InitGoogle(&argc, &argv); |
| 297 | |
| 298 | aos::FlatbufferDetachedBuffer<aos::Configuration> config = |
Austin Schuh | c5fa6d9 | 2022-02-25 14:36:28 -0800 | [diff] [blame] | 299 | aos::configuration::ReadConfig("aos_config.json"); |
milind-u | 086d726 | 2022-01-19 20:44:18 -0800 | [diff] [blame] | 300 | |
| 301 | ::aos::ShmEventLoop event_loop(&config.message()); |
| 302 | ::y2022::input::joysticks::Reader reader(&event_loop); |
| 303 | |
| 304 | event_loop.Run(); |
| 305 | |
| 306 | return 0; |
| 307 | } |