Tyler Chatow | e51334a | 2019-01-20 16:58:16 -0800 | [diff] [blame] | 1 | #include "y2019/control_loops/superstructure/superstructure.h" |
| 2 | |
| 3 | #include "aos/controls/control_loops.q.h" |
| 4 | #include "frc971/control_loops/control_loops.q.h" |
Theo Bafrali | 00e4227 | 2019-02-12 01:07:46 -0800 | [diff] [blame] | 5 | #include "frc971/control_loops/static_zeroing_single_dof_profiled_subsystem.h" |
Tyler Chatow | e51334a | 2019-01-20 16:58:16 -0800 | [diff] [blame] | 6 | |
| 7 | namespace y2019 { |
| 8 | namespace control_loops { |
| 9 | namespace superstructure { |
| 10 | |
Austin Schuh | e835475 | 2019-02-17 14:59:05 -0800 | [diff] [blame] | 11 | void Superstructure::HandleSuction(const SuctionGoal *unsafe_goal, |
| 12 | float suction_pressure, |
| 13 | SuperstructureQueue::Output *output, |
| 14 | bool *has_piece) { |
| 15 | constexpr double kPumpVoltage = 12.0; |
| 16 | constexpr double kPumpHasPieceVoltage = 8.0; |
John Park | bdc8612 | 2019-02-10 12:35:25 -0800 | [diff] [blame] | 17 | |
Austin Schuh | e835475 | 2019-02-17 14:59:05 -0800 | [diff] [blame] | 18 | // TODO(austin): Low pass filter on pressure. |
| 19 | *has_piece = suction_pressure < 0.70; |
| 20 | |
| 21 | if (unsafe_goal && output) { |
| 22 | const bool evacuate = unsafe_goal->top || unsafe_goal->bottom; |
| 23 | if (evacuate) { |
| 24 | vacuum_count_ = 200; |
John Park | bdc8612 | 2019-02-10 12:35:25 -0800 | [diff] [blame] | 25 | } |
Austin Schuh | e835475 | 2019-02-17 14:59:05 -0800 | [diff] [blame] | 26 | // TODO(austin): High speed pump a bit longer after we detect we have the |
| 27 | // game piece. |
| 28 | // Once the vacuum evacuates, the pump speeds up because there is no |
| 29 | // resistance. So, we want to turn it down to save the pump from |
| 30 | // overheating. |
| 31 | output->pump_voltage = |
| 32 | (vacuum_count_ > 0) ? (*has_piece ? kPumpHasPieceVoltage : kPumpVoltage) |
| 33 | : 0.0; |
| 34 | output->intake_suction_top = unsafe_goal->top; |
| 35 | output->intake_suction_bottom = unsafe_goal->bottom; |
John Park | bdc8612 | 2019-02-10 12:35:25 -0800 | [diff] [blame] | 36 | } |
Austin Schuh | e835475 | 2019-02-17 14:59:05 -0800 | [diff] [blame] | 37 | vacuum_count_ = ::std::max(0, vacuum_count_ - 1); |
John Park | bdc8612 | 2019-02-10 12:35:25 -0800 | [diff] [blame] | 38 | } |
| 39 | |
Austin Schuh | 55a13dc | 2019-01-27 22:39:03 -0800 | [diff] [blame] | 40 | Superstructure::Superstructure(::aos::EventLoop *event_loop, |
| 41 | const ::std::string &name) |
Theo Bafrali | 00e4227 | 2019-02-12 01:07:46 -0800 | [diff] [blame] | 42 | : aos::controls::ControlLoop<SuperstructureQueue>(event_loop, name), |
| 43 | elevator_(constants::GetValues().elevator.subsystem_params), |
| 44 | wrist_(constants::GetValues().wrist.subsystem_params), |
| 45 | intake_(constants::GetValues().intake), |
| 46 | stilts_(constants::GetValues().stilts.subsystem_params) {} |
Tyler Chatow | e51334a | 2019-01-20 16:58:16 -0800 | [diff] [blame] | 47 | |
Theo Bafrali | 00e4227 | 2019-02-12 01:07:46 -0800 | [diff] [blame] | 48 | void Superstructure::RunIteration(const SuperstructureQueue::Goal *unsafe_goal, |
| 49 | const SuperstructureQueue::Position *position, |
| 50 | SuperstructureQueue::Output *output, |
| 51 | SuperstructureQueue::Status *status) { |
Tyler Chatow | e51334a | 2019-01-20 16:58:16 -0800 | [diff] [blame] | 52 | if (WasReset()) { |
| 53 | LOG(ERROR, "WPILib reset, restarting\n"); |
Theo Bafrali | 00e4227 | 2019-02-12 01:07:46 -0800 | [diff] [blame] | 54 | elevator_.Reset(); |
| 55 | wrist_.Reset(); |
| 56 | intake_.Reset(); |
| 57 | stilts_.Reset(); |
Tyler Chatow | e51334a | 2019-01-20 16:58:16 -0800 | [diff] [blame] | 58 | } |
Theo Bafrali | 00e4227 | 2019-02-12 01:07:46 -0800 | [diff] [blame] | 59 | |
| 60 | elevator_.Iterate(unsafe_goal != nullptr ? &(unsafe_goal->elevator) : nullptr, |
| 61 | &(position->elevator), |
| 62 | output != nullptr ? &(output->elevator_voltage) : nullptr, |
| 63 | &(status->elevator)); |
| 64 | |
| 65 | wrist_.Iterate(unsafe_goal != nullptr ? &(unsafe_goal->wrist) : nullptr, |
| 66 | &(position->wrist), |
| 67 | output != nullptr ? &(output->wrist_voltage) : nullptr, |
| 68 | &(status->wrist)); |
| 69 | |
Theo Bafrali | 09517b9 | 2019-02-16 15:59:17 -0800 | [diff] [blame] | 70 | intake_.Iterate(unsafe_goal != nullptr ? &(unsafe_goal->intake) : nullptr, |
| 71 | &(position->intake_joint), |
| 72 | output != nullptr ? &(output->intake_joint_voltage) : nullptr, |
| 73 | &(status->intake)); |
Theo Bafrali | 00e4227 | 2019-02-12 01:07:46 -0800 | [diff] [blame] | 74 | |
| 75 | stilts_.Iterate(unsafe_goal != nullptr ? &(unsafe_goal->stilts) : nullptr, |
| 76 | &(position->stilts), |
| 77 | output != nullptr ? &(output->stilts_voltage) : nullptr, |
| 78 | &(status->stilts)); |
| 79 | |
Austin Schuh | e835475 | 2019-02-17 14:59:05 -0800 | [diff] [blame] | 80 | HandleSuction(unsafe_goal != nullptr ? &(unsafe_goal->suction) : nullptr, |
| 81 | position->suction_pressure, output, &(status->has_piece)); |
| 82 | |
Theo Bafrali | 00e4227 | 2019-02-12 01:07:46 -0800 | [diff] [blame] | 83 | status->zeroed = status->elevator.zeroed && status->wrist.zeroed && |
| 84 | status->intake.zeroed && status->stilts.zeroed; |
| 85 | |
| 86 | status->estopped = status->elevator.estopped || status->wrist.estopped || |
| 87 | status->intake.estopped || status->stilts.estopped; |
| 88 | |
Theo Bafrali | 09517b9 | 2019-02-16 15:59:17 -0800 | [diff] [blame] | 89 | if (output) { |
Austin Schuh | 85e2e91 | 2019-02-17 15:04:29 -0800 | [diff] [blame] | 90 | if (unsafe_goal && status->intake.position > kMinIntakeAngleForRollers) { |
| 91 | output->intake_roller_voltage = unsafe_goal->roller_voltage; |
Theo Bafrali | 09517b9 | 2019-02-16 15:59:17 -0800 | [diff] [blame] | 92 | } else { |
| 93 | output->intake_roller_voltage = 0.0; |
| 94 | } |
| 95 | } |
| 96 | |
Theo Bafrali | 00e4227 | 2019-02-12 01:07:46 -0800 | [diff] [blame] | 97 | // TODO(theo) move these up when Iterate() is split |
| 98 | // update the goals |
| 99 | collision_avoidance_.UpdateGoal(status, unsafe_goal); |
| 100 | |
| 101 | elevator_.set_min_position(collision_avoidance_.min_elevator_goal()); |
| 102 | wrist_.set_min_position(collision_avoidance_.min_wrist_goal()); |
| 103 | wrist_.set_max_position(collision_avoidance_.max_wrist_goal()); |
| 104 | intake_.set_min_position(collision_avoidance_.min_intake_goal()); |
| 105 | intake_.set_max_position(collision_avoidance_.max_intake_goal()); |
Tyler Chatow | e51334a | 2019-01-20 16:58:16 -0800 | [diff] [blame] | 106 | } |
| 107 | |
| 108 | } // namespace superstructure |
| 109 | } // namespace control_loops |
Austin Schuh | 55a13dc | 2019-01-27 22:39:03 -0800 | [diff] [blame] | 110 | } // namespace y2019 |