blob: 6e48a21af6c5b2d904ea62a5597e45c29dec2779 [file] [log] [blame]
Sabina Davisedf89472020-02-17 15:27:37 -08001#include "y2020/control_loops/superstructure/shooter/shooter.h"
2
3#include <chrono>
4
5#include "aos/logging/logging.h"
6#include "y2020/control_loops/superstructure/accelerator/accelerator_plant.h"
7#include "y2020/control_loops/superstructure/finisher/finisher_plant.h"
8
9namespace y2020 {
10namespace control_loops {
11namespace superstructure {
12namespace shooter {
13
Sabina Davis0f31d3f2020-02-20 20:41:00 -080014namespace {
Austin Schuh43b9ae92020-02-29 23:08:38 -080015const double kVelocityTolerance = 20.0;
Sabina Davis0f31d3f2020-02-20 20:41:00 -080016} // namespace
17
Sabina Davisedf89472020-02-17 15:27:37 -080018Shooter::Shooter()
Austin Schuhe8ca06a2020-03-07 22:27:39 -080019 : finisher_(finisher::MakeIntegralFinisherLoop(), finisher::kBemf,
20 finisher::kResistance),
21 accelerator_left_(accelerator::MakeIntegralAcceleratorLoop(),
22 accelerator::kBemf, accelerator::kResistance),
23 accelerator_right_(accelerator::MakeIntegralAcceleratorLoop(),
24 accelerator::kBemf, accelerator::kResistance) {}
Sabina Davisedf89472020-02-17 15:27:37 -080025
Sabina Davis0f31d3f2020-02-20 20:41:00 -080026bool Shooter::UpToSpeed(const ShooterGoal *goal) {
27 return (
28 std::abs(goal->velocity_finisher() - finisher_.avg_angular_velocity()) <
29 kVelocityTolerance &&
30 std::abs(goal->velocity_accelerator() -
31 accelerator_left_.avg_angular_velocity()) < kVelocityTolerance &&
32 std::abs(goal->velocity_accelerator() -
33 accelerator_right_.avg_angular_velocity()) < kVelocityTolerance &&
34 std::abs(goal->velocity_finisher() - finisher_.velocity()) < kVelocityTolerance &&
35 std::abs(goal->velocity_accelerator() - accelerator_left_.velocity()) <
36 kVelocityTolerance &&
37 std::abs(goal->velocity_accelerator() - accelerator_right_.velocity()) <
38 kVelocityTolerance);
39}
40
Sabina Davisedf89472020-02-17 15:27:37 -080041flatbuffers::Offset<ShooterStatus> Shooter::RunIteration(
42 const ShooterGoal *goal, const ShooterPosition *position,
Sabina Davis0f31d3f2020-02-20 20:41:00 -080043 flatbuffers::FlatBufferBuilder *fbb, OutputT *output,
44 const aos::monotonic_clock::time_point position_timestamp) {
45 // Update position, output, and status for our two shooter sides.
46 finisher_.set_position(position->theta_finisher(), position_timestamp);
47 accelerator_left_.set_position(position->theta_accelerator_left(),
48 position_timestamp);
49 accelerator_right_.set_position(position->theta_accelerator_right(),
50 position_timestamp);
Sabina Davisedf89472020-02-17 15:27:37 -080051
Sabina Davis0f31d3f2020-02-20 20:41:00 -080052 // Update goal.
53 if (goal) {
54 finisher_.set_goal(goal->velocity_finisher());
55 accelerator_left_.set_goal(goal->velocity_accelerator());
56 accelerator_right_.set_goal(goal->velocity_accelerator());
Austin Schuh43b9ae92020-02-29 23:08:38 -080057 }
Sabina Davis0f31d3f2020-02-20 20:41:00 -080058
Austin Schuh43b9ae92020-02-29 23:08:38 -080059 finisher_.Update(output == nullptr);
60 accelerator_left_.Update(output == nullptr);
61 accelerator_right_.Update(output == nullptr);
62
63 if (goal) {
Sabina Davis0f31d3f2020-02-20 20:41:00 -080064 if (UpToSpeed(goal) && goal->velocity_finisher() > kVelocityTolerance &&
65 goal->velocity_accelerator() > kVelocityTolerance) {
66 ready_ = true;
67 } else {
68 ready_ = false;
69 }
70 }
71
Sabina Davisedf89472020-02-17 15:27:37 -080072 flatbuffers::Offset<FlywheelControllerStatus> finisher_status_offset =
73 finisher_.SetStatus(fbb);
74 flatbuffers::Offset<FlywheelControllerStatus> accelerator_left_status_offset =
75 accelerator_left_.SetStatus(fbb);
76 flatbuffers::Offset<FlywheelControllerStatus>
77 accelerator_right_status_offset = accelerator_right_.SetStatus(fbb);
78
79 ShooterStatusBuilder status_builder(*fbb);
80
81 status_builder.add_finisher(finisher_status_offset);
82 status_builder.add_accelerator_left(accelerator_left_status_offset);
83 status_builder.add_accelerator_right(accelerator_right_status_offset);
84
85 if (output) {
86 output->finisher_voltage = finisher_.voltage();
87 output->accelerator_left_voltage = accelerator_left_.voltage();
88 output->accelerator_right_voltage = accelerator_right_.voltage();
89 }
90
91 return status_builder.Finish();
92}
93
94} // namespace shooter
95} // namespace superstructure
96} // namespace control_loops
97} // namespace y2020