Sabina Davis | edf8947 | 2020-02-17 15:27:37 -0800 | [diff] [blame] | 1 | #ifndef Y2020_CONTROL_LOOPS_SHOOTER_SHOOTER_H_ |
| 2 | #define Y2020_CONTROL_LOOPS_SHOOTER_SHOOTER_H_ |
| 3 | |
James Kuszmaul | 6175066 | 2021-06-21 21:32:33 -0700 | [diff] [blame] | 4 | #include "frc971/control_loops/control_loop.h" |
Maxwell Henderson | 3424299 | 2024-01-07 12:39:11 -0800 | [diff] [blame^] | 5 | #include "frc971/control_loops/flywheel/flywheel_controller.h" |
Sabina Davis | edf8947 | 2020-02-17 15:27:37 -0800 | [diff] [blame] | 6 | #include "frc971/control_loops/state_feedback_loop.h" |
Sabina Davis | edf8947 | 2020-02-17 15:27:37 -0800 | [diff] [blame] | 7 | #include "y2020/control_loops/superstructure/superstructure_goal_generated.h" |
| 8 | #include "y2020/control_loops/superstructure/superstructure_output_generated.h" |
| 9 | #include "y2020/control_loops/superstructure/superstructure_position_generated.h" |
| 10 | #include "y2020/control_loops/superstructure/superstructure_status_generated.h" |
| 11 | |
| 12 | namespace y2020 { |
| 13 | namespace control_loops { |
| 14 | namespace superstructure { |
| 15 | namespace shooter { |
| 16 | |
| 17 | // Handles all flywheels together. |
| 18 | class Shooter { |
| 19 | public: |
milind-u | 78f21b7 | 2021-10-10 13:47:28 -0700 | [diff] [blame] | 20 | static constexpr double kVelocityToleranceFinisher = 3.0; |
| 21 | static constexpr double kVelocityToleranceAccelerator = 4.0; |
| 22 | |
Sabina Davis | edf8947 | 2020-02-17 15:27:37 -0800 | [diff] [blame] | 23 | Shooter(); |
| 24 | |
| 25 | flatbuffers::Offset<ShooterStatus> RunIteration( |
| 26 | const ShooterGoal *goal, const ShooterPosition *position, |
Sabina Davis | 0f31d3f | 2020-02-20 20:41:00 -0800 | [diff] [blame] | 27 | flatbuffers::FlatBufferBuilder *fbb, OutputT *output, |
| 28 | const aos::monotonic_clock::time_point position_timestamp); |
| 29 | |
Austin Schuh | 01d81c3 | 2021-11-06 22:59:56 -0700 | [diff] [blame] | 30 | bool ready() const { return finisher_ready() && accelerator_ready(); } |
milind-u | 0beb7dc | 2021-10-16 19:31:33 -0700 | [diff] [blame] | 31 | bool finisher_ready() const { return finisher_ready_; } |
| 32 | bool accelerator_ready() const { return accelerator_ready_; } |
Sabina Davis | edf8947 | 2020-02-17 15:27:37 -0800 | [diff] [blame] | 33 | |
Austin Schuh | 263dead | 2021-04-04 21:19:19 -0700 | [diff] [blame] | 34 | float finisher_goal() const { return finisher_.goal(); } |
| 35 | float accelerator_goal() const { return accelerator_left_.goal(); } |
| 36 | |
Sabina Davis | edf8947 | 2020-02-17 15:27:37 -0800 | [diff] [blame] | 37 | private: |
milind-u | 7baf734 | 2021-08-25 18:31:26 -0700 | [diff] [blame] | 38 | // Minumum difference between the last local maximum finisher angular velocity |
| 39 | // and the current finisher angular velocity when we have a ball in the |
| 40 | // flywheel, in radians/s. This arises because the flywheel slows down when |
| 41 | // there is a ball in it. We can use this to determine when a ball is in the |
| 42 | // flywheel and when it gets shot. |
| 43 | static constexpr double kMinFinisherVelocityDipWithBall = 5.0; |
| 44 | |
Maxwell Henderson | 3424299 | 2024-01-07 12:39:11 -0800 | [diff] [blame^] | 45 | frc971::control_loops::flywheel::FlywheelController finisher_, |
| 46 | accelerator_left_, accelerator_right_; |
Sabina Davis | edf8947 | 2020-02-17 15:27:37 -0800 | [diff] [blame] | 47 | |
Austin Schuh | 01d81c3 | 2021-11-06 22:59:56 -0700 | [diff] [blame] | 48 | void UpToSpeed(const ShooterGoal *goal); |
milind-u | 0beb7dc | 2021-10-16 19:31:33 -0700 | [diff] [blame] | 49 | bool finisher_ready_ = false; |
| 50 | bool accelerator_ready_ = false; |
Sabina Davis | 0f31d3f | 2020-02-20 20:41:00 -0800 | [diff] [blame] | 51 | |
milind-u | 7baf734 | 2021-08-25 18:31:26 -0700 | [diff] [blame] | 52 | int balls_shot_ = 0; |
| 53 | bool finisher_goal_changed_ = false; |
| 54 | bool ball_in_finisher_ = false; |
| 55 | // Last local maximum in the finisher angular velocity |
| 56 | double last_finisher_velocity_max_ = 0.0; |
| 57 | // True if the finisher's average acceleration over the last dt is positive |
| 58 | bool finisher_accelerating_ = false; |
| 59 | |
Sabina Davis | edf8947 | 2020-02-17 15:27:37 -0800 | [diff] [blame] | 60 | DISALLOW_COPY_AND_ASSIGN(Shooter); |
| 61 | }; |
| 62 | |
| 63 | } // namespace shooter |
| 64 | } // namespace superstructure |
| 65 | } // namespace control_loops |
| 66 | } // namespace y2020 |
| 67 | |
| 68 | #endif // Y2020_CONTROL_LOOPS_SHOOTER_SHOOTER_H_ |