blob: ed5ac48eaa2f81d5dd6394f70ebdb12196787ccd [file] [log] [blame]
Niko Sohmers3860f8a2024-01-12 21:05:19 -08001#include <unistd.h>
2
3#include <array>
4#include <chrono>
5#include <cinttypes>
Niko Sohmers3860f8a2024-01-12 21:05:19 -08006#include <cstdio>
7#include <cstring>
8#include <functional>
9#include <memory>
10#include <mutex>
11#include <thread>
12
Niko Sohmers3860f8a2024-01-12 21:05:19 -080013#include "frc971/wpilib/ahal/AnalogInput.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080014#include "frc971/wpilib/ahal/DriverStation.h"
15#include "frc971/wpilib/ahal/Encoder.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080016#include "frc971/wpilib/ahal/TalonFX.h"
17#include "frc971/wpilib/ahal/VictorSP.h"
18#undef ERROR
19
20#include "ctre/phoenix/cci/Diagnostics_CCI.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080021
22#include "aos/commonmath.h"
23#include "aos/containers/sized_array.h"
24#include "aos/events/event_loop.h"
25#include "aos/events/shm_event_loop.h"
26#include "aos/init.h"
27#include "aos/logging/logging.h"
28#include "aos/realtime.h"
29#include "aos/time/time.h"
30#include "aos/util/log_interval.h"
31#include "aos/util/phased_loop.h"
32#include "aos/util/wrapping_counter.h"
33#include "frc971/autonomous/auto_mode_generated.h"
34#include "frc971/can_configuration_generated.h"
Niko Sohmers1259b2a2024-01-29 18:00:37 -080035#include "frc971/constants/constants_sender_lib.h"
Maxwell Hendersonf75800f2024-01-12 19:52:05 -080036#include "frc971/control_loops/drivetrain/drivetrain_can_position_static.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080037#include "frc971/control_loops/drivetrain/drivetrain_position_generated.h"
38#include "frc971/input/robot_state_generated.h"
39#include "frc971/queues/gyro_generated.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080040#include "frc971/wpilib/buffered_pcm.h"
41#include "frc971/wpilib/buffered_solenoid.h"
Maxwell Hendersonf75800f2024-01-12 19:52:05 -080042#include "frc971/wpilib/can_drivetrain_writer.h"
43#include "frc971/wpilib/can_sensor_reader.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080044#include "frc971/wpilib/dma.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080045#include "frc971/wpilib/encoder_and_potentiometer.h"
Niko Sohmers1259b2a2024-01-29 18:00:37 -080046#include "frc971/wpilib/generic_can_writer.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080047#include "frc971/wpilib/joystick_sender.h"
48#include "frc971/wpilib/logging_generated.h"
49#include "frc971/wpilib/loop_output_handler.h"
50#include "frc971/wpilib/pdp_fetcher.h"
51#include "frc971/wpilib/sensor_reader.h"
Maxwell Hendersonf75800f2024-01-12 19:52:05 -080052#include "frc971/wpilib/talonfx.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080053#include "frc971/wpilib/wpilib_robot_base.h"
54#include "y2024/constants.h"
Niko Sohmers1259b2a2024-01-29 18:00:37 -080055#include "y2024/constants/constants_generated.h"
56#include "y2024/control_loops/superstructure/superstructure_can_position_static.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080057#include "y2024/control_loops/superstructure/superstructure_output_generated.h"
58#include "y2024/control_loops/superstructure/superstructure_position_generated.h"
Niko Sohmers1259b2a2024-01-29 18:00:37 -080059#include "y2024/control_loops/superstructure/superstructure_position_static.h"
Niko Sohmers3860f8a2024-01-12 21:05:19 -080060
61DEFINE_bool(ctre_diag_server, false,
62 "If true, enable the diagnostics server for interacting with "
63 "devices on the CAN bus using Phoenix Tuner");
64
65using ::aos::monotonic_clock;
66using ::frc971::CANConfiguration;
Maxwell Hendersonf75800f2024-01-12 19:52:05 -080067using ::frc971::control_loops::drivetrain::CANPositionStatic;
68using ::frc971::wpilib::TalonFX;
Niko Sohmers3860f8a2024-01-12 21:05:19 -080069using ::y2024::constants::Values;
70namespace superstructure = ::y2024::control_loops::superstructure;
71namespace drivetrain = ::y2024::control_loops::drivetrain;
72namespace chrono = ::std::chrono;
73using std::make_unique;
74
Stephan Pleinesf63bde82024-01-13 15:59:33 -080075namespace y2024::wpilib {
Niko Sohmers3860f8a2024-01-12 21:05:19 -080076namespace {
77
78constexpr double kMaxBringupPower = 12.0;
79
Filip Kujawa749f2442024-02-04 01:12:35 -080080double climber_pot_translate(double voltage) {
Maxwell Hendersonce232a92024-02-18 12:17:37 -080081 return voltage * Values::kClimberPotMetersPerVolt();
Filip Kujawa749f2442024-02-04 01:12:35 -080082}
83
Filip Kujawad75252a2024-02-10 16:54:35 -080084double extend_pot_translate(double voltage) {
85 return voltage * Values::kExtendPotMetersPerVolt();
86}
87
Niko Sohmers27d92c62024-02-19 14:15:07 -080088double catapult_pot_translate(double voltage) {
89 return voltage * Values::kCatapultPotRadiansPerVolt();
90}
91
92double turret_pot_translate(double voltage) {
93 return voltage * Values::kTurretPotRadiansPerVolt();
94}
95
96double altitude_pot_translate(double voltage) {
97 return voltage * Values::kAltitudePotRadiansPerVolt();
98}
99
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800100double drivetrain_velocity_translate(double in) {
101 return (((1.0 / in) / Values::kDrivetrainCyclesPerRevolution()) *
102 (2.0 * M_PI)) *
103 Values::kDrivetrainEncoderRatio() *
104 control_loops::drivetrain::kWheelRadius;
105}
106
107constexpr double kMaxFastEncoderPulsesPerSecond = std::max({
108 Values::kMaxDrivetrainEncoderPulsesPerSecond(),
Maxwell Henderson1de15492024-02-07 11:09:47 -0800109 Values::kMaxIntakePivotEncoderPulsesPerSecond(),
Filip Kujawa749f2442024-02-04 01:12:35 -0800110 Values::kMaxClimberEncoderPulsesPerSecond(),
Filip Kujawad75252a2024-02-10 16:54:35 -0800111 Values::kMaxExtendEncoderPulsesPerSecond(),
Niko Sohmers27d92c62024-02-19 14:15:07 -0800112 Values::kMaxCatapultEncoderPulsesPerSecond(),
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800113});
Niko Sohmers27d92c62024-02-19 14:15:07 -0800114
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800115static_assert(kMaxFastEncoderPulsesPerSecond <= 1300000,
116 "fast encoders are too fast");
117
118} // namespace
119
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800120// Class to send position messages with sensor readings to our loops.
121class SensorReader : public ::frc971::wpilib::SensorReader {
122 public:
123 SensorReader(::aos::ShmEventLoop *event_loop,
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800124 const Constants *robot_constants)
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800125 : ::frc971::wpilib::SensorReader(event_loop),
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800126 robot_constants_(CHECK_NOTNULL(robot_constants)),
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800127 auto_mode_sender_(
128 event_loop->MakeSender<::frc971::autonomous::AutonomousMode>(
129 "/autonomous")),
130 superstructure_position_sender_(
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800131 event_loop->MakeSender<superstructure::PositionStatic>(
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800132 "/superstructure")),
133 drivetrain_position_sender_(
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800134 event_loop->MakeSender<
135 ::frc971::control_loops::drivetrain::PositionStatic>(
136 "/drivetrain")),
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800137 gyro_sender_(event_loop->MakeSender<::frc971::sensors::GyroReading>(
138 "/drivetrain")){};
139 void Start() override { AddToDMA(&imu_yaw_rate_reader_); }
140
141 // Auto mode switches.
142 void set_autonomous_mode(int i, ::std::unique_ptr<frc::DigitalInput> sensor) {
143 autonomous_modes_.at(i) = ::std::move(sensor);
144 }
145
146 void set_yaw_rate_input(::std::unique_ptr<frc::DigitalInput> sensor) {
147 imu_yaw_rate_input_ = ::std::move(sensor);
148 imu_yaw_rate_reader_.set_input(imu_yaw_rate_input_.get());
149 }
150
151 void RunIteration() override {
152 {
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800153 aos::Sender<superstructure::PositionStatic>::StaticBuilder builder =
154 superstructure_position_sender_.MakeStaticBuilder();
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800155
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800156 CopyPosition(intake_pivot_encoder_, builder->add_intake_pivot(),
157 Values::kIntakePivotEncoderCountsPerRevolution(),
Niko Sohmers74b0ad52024-02-03 18:00:31 -0800158 Values::kIntakePivotEncoderRatio(), /* reversed: */ false);
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800159
Filip Kujawa749f2442024-02-04 01:12:35 -0800160 CopyPosition(climber_encoder_, builder->add_climber(),
161 Values::kClimberEncoderCountsPerRevolution(),
Maxwell Hendersonce232a92024-02-18 12:17:37 -0800162 Values::kClimberEncoderMetersPerRevolution(),
163 climber_pot_translate, true,
Filip Kujawa749f2442024-02-04 01:12:35 -0800164 robot_constants_->robot()
165 ->climber_constants()
166 ->potentiometer_offset());
167
Filip Kujawad75252a2024-02-10 16:54:35 -0800168 CopyPosition(extend_encoder_, builder->add_extend(),
169 Values::kClimberEncoderCountsPerRevolution(),
170 Values::kClimberEncoderMetersPerRevolution(),
171 extend_pot_translate, true,
172 robot_constants_->robot()
173 ->extend_constants()
174 ->potentiometer_offset());
175
Niko Sohmers27d92c62024-02-19 14:15:07 -0800176 CopyPosition(catapult_encoder_, builder->add_catapult(),
177 Values::kCatapultEncoderCountsPerRevolution(),
178 Values::kCatapultEncoderRatio(), catapult_pot_translate,
179 true,
180 robot_constants_->robot()
181 ->catapult_constants()
182 ->potentiometer_offset());
183
184 CopyPosition(turret_encoder_, builder->add_turret(),
185 Values::kTurretEncoderCountsPerRevolution(),
186 Values::kTurretEncoderRatio(), turret_pot_translate, true,
187 robot_constants_->robot()
188 ->turret_constants()
189 ->potentiometer_offset());
190
191 CopyPosition(altitude_encoder_, builder->add_altitude(),
192 Values::kAltitudeEncoderCountsPerRevolution(),
193 Values::kAltitudeEncoderRatio(), altitude_pot_translate,
194 true,
195 robot_constants_->robot()
196 ->altitude_constants()
197 ->potentiometer_offset());
198
Niko Sohmersed7ffc42024-02-03 16:05:19 -0800199 builder->set_transfer_beambreak(transfer_beam_break_->Get());
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800200 builder.CheckOk(builder.Send());
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800201 }
202
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800203 SendDrivetrainPosition(drivetrain_position_sender_.MakeStaticBuilder(),
204 drivetrain_velocity_translate,
205 constants::Values::DrivetrainEncoderToMeters, false,
206 false);
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800207
208 {
209 auto builder = gyro_sender_.MakeBuilder();
210 ::frc971::sensors::GyroReading::Builder gyro_reading_builder =
211 builder.MakeBuilder<::frc971::sensors::GyroReading>();
212 // +/- 2000 deg / sec
213 constexpr double kMaxVelocity = 4000; // degrees / second
214 constexpr double kVelocityRadiansPerSecond =
215 kMaxVelocity / 360 * (2.0 * M_PI);
216
217 // Only part of the full range is used to prevent being 100% on or off.
218 constexpr double kScaledRangeLow = 0.1;
219 constexpr double kScaledRangeHigh = 0.9;
220
221 constexpr double kPWMFrequencyHz = 200;
222 double velocity_duty_cycle =
223 imu_yaw_rate_reader_.last_width() * kPWMFrequencyHz;
224
225 constexpr double kDutyCycleScale =
226 1 / (kScaledRangeHigh - kScaledRangeLow);
227 // scale from 0.1 - 0.9 to 0 - 1
228 double rescaled_velocity_duty_cycle =
229 (velocity_duty_cycle - kScaledRangeLow) * kDutyCycleScale;
230
231 if (!std::isnan(rescaled_velocity_duty_cycle)) {
232 gyro_reading_builder.add_velocity((rescaled_velocity_duty_cycle - 0.5) *
233 kVelocityRadiansPerSecond);
234 }
235 builder.CheckOk(builder.Send(gyro_reading_builder.Finish()));
236 }
237
238 {
239 auto builder = auto_mode_sender_.MakeBuilder();
240
241 uint32_t mode = 0;
242 for (size_t i = 0; i < autonomous_modes_.size(); ++i) {
243 if (autonomous_modes_[i] && autonomous_modes_[i]->Get()) {
244 mode |= 1 << i;
245 }
246 }
247
248 auto auto_mode_builder =
249 builder.MakeBuilder<frc971::autonomous::AutonomousMode>();
250
251 auto_mode_builder.add_mode(mode);
252
253 builder.CheckOk(builder.Send(auto_mode_builder.Finish()));
254 }
255 }
256
Maxwell Henderson62917832024-02-07 11:08:11 -0800257 void set_intake_pivot(::std::unique_ptr<frc::Encoder> encoder,
Niko Sohmers74b0ad52024-02-03 18:00:31 -0800258 ::std::unique_ptr<frc::DigitalInput> absolute_pwm) {
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800259 fast_encoder_filter_.Add(encoder.get());
260 intake_pivot_encoder_.set_encoder(::std::move(encoder));
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800261 intake_pivot_encoder_.set_absolute_pwm(::std::move(absolute_pwm));
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800262 }
263
Niko Sohmersed7ffc42024-02-03 16:05:19 -0800264 void set_transfer_beambreak(::std::unique_ptr<frc::DigitalInput> sensor) {
265 transfer_beam_break_ = ::std::move(sensor);
266 }
267
Filip Kujawa749f2442024-02-04 01:12:35 -0800268 void set_climber(::std::unique_ptr<frc::Encoder> encoder,
269 ::std::unique_ptr<frc::DigitalInput> absolute_pwm,
270 ::std::unique_ptr<frc::AnalogInput> potentiometer) {
271 fast_encoder_filter_.Add(encoder.get());
272 climber_encoder_.set_encoder(::std::move(encoder));
273 climber_encoder_.set_absolute_pwm(::std::move(absolute_pwm));
274 climber_encoder_.set_potentiometer(::std::move(potentiometer));
275 }
276
Filip Kujawad75252a2024-02-10 16:54:35 -0800277 void set_extend(::std::unique_ptr<frc::Encoder> encoder,
278 ::std::unique_ptr<frc::DigitalInput> absolute_pwm,
279 ::std::unique_ptr<frc::AnalogInput> potentiometer) {
280 fast_encoder_filter_.Add(encoder.get());
281 extend_encoder_.set_encoder(::std::move(encoder));
282 extend_encoder_.set_absolute_pwm(::std::move(absolute_pwm));
283 extend_encoder_.set_potentiometer(::std::move(potentiometer));
284 }
285
Niko Sohmers27d92c62024-02-19 14:15:07 -0800286 void set_catapult(::std::unique_ptr<frc::Encoder> encoder,
287 ::std::unique_ptr<frc::DigitalInput> absolute_pwm,
288 ::std::unique_ptr<frc::AnalogInput> potentiometer) {
289 fast_encoder_filter_.Add(encoder.get());
290 catapult_encoder_.set_encoder(::std::move(encoder));
291 catapult_encoder_.set_absolute_pwm(::std::move(absolute_pwm));
292 catapult_encoder_.set_potentiometer(::std::move(potentiometer));
293 }
294
295 void set_turret(::std::unique_ptr<frc::Encoder> encoder,
296 ::std::unique_ptr<frc::DigitalInput> absolute_pwm,
297 ::std::unique_ptr<frc::AnalogInput> potentiometer) {
298 fast_encoder_filter_.Add(encoder.get());
299 turret_encoder_.set_encoder(::std::move(encoder));
300 turret_encoder_.set_absolute_pwm(::std::move(absolute_pwm));
301 turret_encoder_.set_potentiometer(::std::move(potentiometer));
302 }
303
304 void set_altitude(::std::unique_ptr<frc::Encoder> encoder,
305 ::std::unique_ptr<frc::DigitalInput> absolute_pwm,
306 ::std::unique_ptr<frc::AnalogInput> potentiometer) {
307 fast_encoder_filter_.Add(encoder.get());
308 altitude_encoder_.set_encoder(::std::move(encoder));
309 altitude_encoder_.set_absolute_pwm(::std::move(absolute_pwm));
310 altitude_encoder_.set_potentiometer(::std::move(potentiometer));
311 }
312
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800313 private:
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800314 const Constants *robot_constants_;
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800315
316 aos::Sender<frc971::autonomous::AutonomousMode> auto_mode_sender_;
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800317 aos::Sender<superstructure::PositionStatic> superstructure_position_sender_;
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800318 aos::Sender<frc971::control_loops::drivetrain::PositionStatic>
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800319 drivetrain_position_sender_;
320 ::aos::Sender<::frc971::sensors::GyroReading> gyro_sender_;
321
322 std::array<std::unique_ptr<frc::DigitalInput>, 2> autonomous_modes_;
323
Niko Sohmersed7ffc42024-02-03 16:05:19 -0800324 std::unique_ptr<frc::DigitalInput> imu_yaw_rate_input_, transfer_beam_break_;
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800325
Niko Sohmers74b0ad52024-02-03 18:00:31 -0800326 frc971::wpilib::AbsoluteEncoder intake_pivot_encoder_;
Niko Sohmers27d92c62024-02-19 14:15:07 -0800327 frc971::wpilib::AbsoluteEncoderAndPotentiometer climber_encoder_,
328 catapult_encoder_, turret_encoder_, altitude_encoder_, extend_encoder_;
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800329
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800330 frc971::wpilib::DMAPulseWidthReader imu_yaw_rate_reader_;
331};
332
333class WPILibRobot : public ::frc971::wpilib::WPILibRobotBase {
334 public:
335 ::std::unique_ptr<frc::Encoder> make_encoder(int index) {
336 return make_unique<frc::Encoder>(10 + index * 2, 11 + index * 2, false,
337 frc::Encoder::k4X);
338 }
339
340 void Run() override {
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800341 aos::FlatbufferDetachedBuffer<aos::Configuration> config =
342 aos::configuration::ReadConfig("aos_config.json");
343
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800344 frc971::constants::WaitForConstants<y2024::Constants>(&config.message());
345
346 ::aos::ShmEventLoop constant_fetcher_event_loop(&config.message());
347 frc971::constants::ConstantsFetcher<Constants> constants_fetcher(
348 &constant_fetcher_event_loop);
349 const Constants *robot_constants = &constants_fetcher.constants();
350
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800351 // Thread 1.
352 ::aos::ShmEventLoop joystick_sender_event_loop(&config.message());
353 ::frc971::wpilib::JoystickSender joystick_sender(
354 &joystick_sender_event_loop);
355 AddLoop(&joystick_sender_event_loop);
356
357 // Thread 2.
358 ::aos::ShmEventLoop pdp_fetcher_event_loop(&config.message());
359 ::frc971::wpilib::PDPFetcher pdp_fetcher(&pdp_fetcher_event_loop);
360 AddLoop(&pdp_fetcher_event_loop);
361
362 // Thread 3.
363 ::aos::ShmEventLoop sensor_reader_event_loop(&config.message());
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800364 SensorReader sensor_reader(&sensor_reader_event_loop, robot_constants);
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800365 sensor_reader.set_pwm_trigger(true);
366 sensor_reader.set_drivetrain_left_encoder(make_encoder(1));
367 sensor_reader.set_drivetrain_right_encoder(make_encoder(0));
368 sensor_reader.set_yaw_rate_input(make_unique<frc::DigitalInput>(0));
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800369 // TODO: (niko) change values once robot is wired
Maxwell Henderson62917832024-02-07 11:08:11 -0800370 sensor_reader.set_intake_pivot(make_encoder(4),
Niko Sohmers74b0ad52024-02-03 18:00:31 -0800371 make_unique<frc::DigitalInput>(4));
Niko Sohmersed7ffc42024-02-03 16:05:19 -0800372 sensor_reader.set_transfer_beambreak(make_unique<frc::DigitalInput>(7));
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800373
Filip Kujawa749f2442024-02-04 01:12:35 -0800374 sensor_reader.set_climber(make_encoder(5),
375 make_unique<frc::DigitalInput>(5),
376 make_unique<frc::AnalogInput>(5));
Niko Sohmers27d92c62024-02-19 14:15:07 -0800377 sensor_reader.set_extend(make_encoder(7), make_unique<frc::DigitalInput>(7),
378 make_unique<frc::AnalogInput>(7));
379 sensor_reader.set_catapult(make_encoder(2),
380 make_unique<frc::DigitalInput>(2),
381 make_unique<frc::AnalogInput>(2));
382 sensor_reader.set_turret(make_encoder(3), make_unique<frc::DigitalInput>(3),
383 make_unique<frc::AnalogInput>(3));
384 sensor_reader.set_altitude(make_encoder(6),
385 make_unique<frc::DigitalInput>(6),
386 make_unique<frc::AnalogInput>(6));
Filip Kujawad75252a2024-02-10 16:54:35 -0800387
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800388 AddLoop(&sensor_reader_event_loop);
389
390 // Thread 4.
391 // Set up CAN.
392 if (!FLAGS_ctre_diag_server) {
393 c_Phoenix_Diagnostics_SetSecondsToStart(-1);
394 c_Phoenix_Diagnostics_Dispose();
395 }
396
Niko Sohmers84273952024-02-14 18:40:55 -0800397 std::vector<ctre::phoenix6::BaseStatusSignal *> canivore_signal_registry;
398 std::vector<ctre::phoenix6::BaseStatusSignal *> rio_signal_registry;
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800399
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800400 const CurrentLimits *current_limits =
401 robot_constants->common()->current_limits();
402
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800403 std::shared_ptr<TalonFX> right_front = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800404 2, false, "Drivetrain Bus", &canivore_signal_registry,
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800405 current_limits->drivetrain_supply_current_limit(),
406 current_limits->drivetrain_stator_current_limit());
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800407 std::shared_ptr<TalonFX> right_back = std::make_shared<TalonFX>(
Niko Sohmers84273952024-02-14 18:40:55 -0800408 1, false, "Drivetrain Bus", &canivore_signal_registry,
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800409 current_limits->drivetrain_supply_current_limit(),
410 current_limits->drivetrain_stator_current_limit());
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800411 std::shared_ptr<TalonFX> left_front = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800412 4, false, "Drivetrain Bus", &canivore_signal_registry,
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800413 current_limits->drivetrain_supply_current_limit(),
414 current_limits->drivetrain_stator_current_limit());
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800415 std::shared_ptr<TalonFX> left_back = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800416 5, false, "Drivetrain Bus", &canivore_signal_registry,
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800417 current_limits->drivetrain_supply_current_limit(),
418 current_limits->drivetrain_stator_current_limit());
419 std::shared_ptr<TalonFX> intake_pivot = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800420 3, false, "Drivetrain Bus", &canivore_signal_registry,
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800421 current_limits->intake_pivot_stator_current_limit(),
422 current_limits->intake_pivot_supply_current_limit());
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800423 // TODO(max): Assign these proper ids
Niko Sohmers27d92c62024-02-19 14:15:07 -0800424 std::shared_ptr<TalonFX> altitude = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800425 6, false, "Drivetrain Bus", &canivore_signal_registry,
Niko Sohmers27d92c62024-02-19 14:15:07 -0800426 current_limits->altitude_stator_current_limit(),
427 current_limits->altitude_supply_current_limit());
428 std::shared_ptr<TalonFX> turret = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800429 7, false, "Drivetrain Bus", &canivore_signal_registry,
Niko Sohmers27d92c62024-02-19 14:15:07 -0800430 current_limits->turret_stator_current_limit(),
431 current_limits->turret_supply_current_limit());
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800432 std::shared_ptr<TalonFX> intake_roller = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800433 8, false, "rio", &rio_signal_registry,
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800434 current_limits->intake_roller_stator_current_limit(),
435 current_limits->intake_roller_supply_current_limit());
436 std::shared_ptr<TalonFX> transfer_roller = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800437 9, false, "rio", &rio_signal_registry,
Maxwell Hendersonfb3bfea2024-02-03 19:24:46 -0800438 current_limits->transfer_roller_stator_current_limit(),
439 current_limits->transfer_roller_supply_current_limit());
Filip Kujawa749f2442024-02-04 01:12:35 -0800440 std::shared_ptr<TalonFX> climber = std::make_shared<TalonFX>(
Maxwell Henderson7be07d52024-02-20 07:59:16 -0800441 10, false, "rio", &rio_signal_registry,
Filip Kujawa749f2442024-02-04 01:12:35 -0800442 current_limits->climber_stator_current_limit(),
443 current_limits->climber_supply_current_limit());
444
Filip Kujawad75252a2024-02-10 16:54:35 -0800445 std::shared_ptr<TalonFX> extend = std::make_shared<TalonFX>(
Niko Sohmers27d92c62024-02-19 14:15:07 -0800446 8, false, "rio", &rio_signal_registry,
Filip Kujawad75252a2024-02-10 16:54:35 -0800447 current_limits->extend_stator_current_limit(),
448 current_limits->extend_supply_current_limit());
449
450 std::shared_ptr<TalonFX> extend_roller = std::make_shared<TalonFX>(
Niko Sohmers27d92c62024-02-19 14:15:07 -0800451 9, false, "rio", &rio_signal_registry,
Filip Kujawad75252a2024-02-10 16:54:35 -0800452 current_limits->extend_roller_stator_current_limit(),
453 current_limits->extend_roller_supply_current_limit());
454
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800455 ctre::phoenix::platform::can::CANComm_SetRxSchedPriority(
456 constants::Values::kDrivetrainRxPriority, true, "Drivetrain Bus");
457 ctre::phoenix::platform::can::CANComm_SetTxSchedPriority(
458 constants::Values::kDrivetrainTxPriority, true, "Drivetrain Bus");
459
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800460 ::aos::ShmEventLoop can_sensor_reader_event_loop(&config.message());
461 can_sensor_reader_event_loop.set_name("CANSensorReader");
462
Niko Sohmers84273952024-02-14 18:40:55 -0800463 ::aos::ShmEventLoop rio_sensor_reader_event_loop(&config.message());
464 rio_sensor_reader_event_loop.set_name("RioSensorReader");
465
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800466 // Creating list of talonfx for CANSensorReader
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800467 std::vector<std::shared_ptr<TalonFX>> drivetrain_talonfxs;
Niko Sohmers84273952024-02-14 18:40:55 -0800468 std::vector<std::shared_ptr<TalonFX>> canivore_talonfxs;
469 std::vector<std::shared_ptr<TalonFX>> rio_talonfxs;
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800470
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800471 for (auto talonfx : {right_front, right_back, left_front, left_back}) {
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800472 drivetrain_talonfxs.push_back(talonfx);
Niko Sohmers84273952024-02-14 18:40:55 -0800473 canivore_talonfxs.push_back(talonfx);
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800474 }
475
Niko Sohmers27d92c62024-02-19 14:15:07 -0800476 for (auto talonfx : {intake_pivot, altitude, turret}) {
Niko Sohmers84273952024-02-14 18:40:55 -0800477 canivore_talonfxs.push_back(talonfx);
478 }
479
Filip Kujawad75252a2024-02-10 16:54:35 -0800480 for (auto talonfx :
481 {intake_roller, transfer_roller, climber, extend, extend_roller}) {
Niko Sohmers84273952024-02-14 18:40:55 -0800482 rio_talonfxs.push_back(talonfx);
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800483 }
484
485 aos::Sender<frc971::control_loops::drivetrain::CANPositionStatic>
486 drivetrain_can_position_sender =
487 can_sensor_reader_event_loop.MakeSender<
488 frc971::control_loops::drivetrain::CANPositionStatic>(
489 "/drivetrain");
490
491 aos::Sender<y2024::control_loops::superstructure::CANPositionStatic>
492 superstructure_can_position_sender =
493 can_sensor_reader_event_loop.MakeSender<
494 y2024::control_loops::superstructure::CANPositionStatic>(
Niko Sohmers84273952024-02-14 18:40:55 -0800495 "/superstructure/canivore");
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800496
Niko Sohmers84273952024-02-14 18:40:55 -0800497 frc971::wpilib::CANSensorReader canivore_can_sensor_reader(
498 &can_sensor_reader_event_loop, std::move(canivore_signal_registry),
499 canivore_talonfxs,
Niko Sohmers27d92c62024-02-19 14:15:07 -0800500 [drivetrain_talonfxs, &intake_pivot, &altitude, &turret,
501 &drivetrain_can_position_sender, &superstructure_can_position_sender](
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800502 ctre::phoenix::StatusCode status) {
503 aos::Sender<frc971::control_loops::drivetrain::CANPositionStatic>::
504 StaticBuilder drivetrain_can_builder =
505 drivetrain_can_position_sender.MakeStaticBuilder();
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800506
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800507 auto drivetrain_falcon_vector =
Maxwell Henderson563efed2024-02-17 21:11:33 -0800508 CHECK_NOTNULL(drivetrain_can_builder->add_talonfxs());
Maxwell Henderson9116e5b2024-01-21 12:14:26 -0800509
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800510 for (auto talonfx : drivetrain_talonfxs) {
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800511 talonfx->SerializePosition(
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800512 drivetrain_falcon_vector->emplace_back(),
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800513 control_loops::drivetrain::kHighOutputRatio);
514 }
515
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800516 drivetrain_can_builder->set_timestamp(
517 drivetrain_talonfxs.front()->GetTimestamp());
518 drivetrain_can_builder->set_status(static_cast<int>(status));
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800519
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800520 drivetrain_can_builder.CheckOk(drivetrain_can_builder.Send());
521
522 aos::Sender<y2024::control_loops::superstructure::CANPositionStatic>::
523 StaticBuilder superstructure_can_builder =
524 superstructure_can_position_sender.MakeStaticBuilder();
525
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800526 intake_pivot->SerializePosition(
527 superstructure_can_builder->add_intake_pivot(),
Niko Sohmers27d92c62024-02-19 14:15:07 -0800528 control_loops::drivetrain::kHighOutputRatio);
529 altitude->SerializePosition(
530 superstructure_can_builder->add_altitude(),
531 control_loops::drivetrain::kHighOutputRatio);
532 turret->SerializePosition(
533 superstructure_can_builder->add_turret(),
534 control_loops::drivetrain::kHighOutputRatio);
Niko Sohmers84273952024-02-14 18:40:55 -0800535
536 superstructure_can_builder->set_timestamp(
537 intake_pivot->GetTimestamp());
538 superstructure_can_builder->set_status(static_cast<int>(status));
539 superstructure_can_builder.CheckOk(superstructure_can_builder.Send());
540 });
541
542 aos::Sender<y2024::control_loops::superstructure::CANPositionStatic>
543 superstructure_rio_position_sender =
544 rio_sensor_reader_event_loop.MakeSender<
545 y2024::control_loops::superstructure::CANPositionStatic>(
546 "/superstructure/rio");
547
548 frc971::wpilib::CANSensorReader rio_can_sensor_reader(
549 &rio_sensor_reader_event_loop, std::move(rio_signal_registry),
550 rio_talonfxs,
Filip Kujawad75252a2024-02-10 16:54:35 -0800551 [&intake_roller, &transfer_roller, &climber, &extend, &extend_roller,
Niko Sohmers84273952024-02-14 18:40:55 -0800552 &superstructure_rio_position_sender](
553 ctre::phoenix::StatusCode status) {
554 aos::Sender<y2024::control_loops::superstructure::CANPositionStatic>::
555 StaticBuilder superstructure_can_builder =
556 superstructure_rio_position_sender.MakeStaticBuilder();
557
558 intake_roller->SerializePosition(
559 superstructure_can_builder->add_intake_roller(),
Filip Kujawace385c32024-02-16 10:39:49 -0800560 constants::Values::kIntakeRollerOutputRatio);
Niko Sohmersed7ffc42024-02-03 16:05:19 -0800561 transfer_roller->SerializePosition(
562 superstructure_can_builder->add_transfer_roller(),
Filip Kujawace385c32024-02-16 10:39:49 -0800563 constants::Values::kIntakeRollerOutputRatio);
564 climber->SerializePosition(superstructure_can_builder->add_climber(),
565 superstructure::climber::kOutputRatio);
Filip Kujawad75252a2024-02-10 16:54:35 -0800566 extend->SerializePosition(superstructure_can_builder->add_extend(),
567 superstructure::extend::kOutputRatio);
568 extend_roller->SerializePosition(
569 superstructure_can_builder->add_extend_roller(),
Filip Kujawace385c32024-02-16 10:39:49 -0800570 constants::Values::kExtendRollerOutputRatio);
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800571
572 superstructure_can_builder->set_timestamp(
573 intake_roller->GetTimestamp());
574 superstructure_can_builder->set_status(static_cast<int>(status));
575 superstructure_can_builder.CheckOk(superstructure_can_builder.Send());
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800576 });
577
578 AddLoop(&can_sensor_reader_event_loop);
Niko Sohmers84273952024-02-14 18:40:55 -0800579 AddLoop(&rio_sensor_reader_event_loop);
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800580
581 // Thread 5.
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800582 ::aos::ShmEventLoop can_output_event_loop(&config.message());
583 can_output_event_loop.set_name("CANOutputWriter");
584
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800585 frc971::wpilib::CANDrivetrainWriter can_drivetrain_writer(
586 &can_output_event_loop);
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800587
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800588 frc971::wpilib::GenericCANWriter<control_loops::superstructure::Output>
589 can_superstructure_writer(
590 &can_output_event_loop,
591 [](const control_loops::superstructure::Output &output,
592 const std::map<std::string_view, std::shared_ptr<TalonFX>>
593 &talonfx_map) {
594 talonfx_map.find("intake_pivot")
595 ->second->WriteVoltage(output.intake_pivot_voltage());
596 talonfx_map.find("intake_roller")
597 ->second->WriteVoltage(output.intake_roller_voltage());
Niko Sohmersed7ffc42024-02-03 16:05:19 -0800598 talonfx_map.find("transfer_roller")
599 ->second->WriteVoltage(output.transfer_roller_voltage());
Filip Kujawa749f2442024-02-04 01:12:35 -0800600 talonfx_map.find("climber")->second->WriteVoltage(
601 output.climber_voltage());
Filip Kujawad75252a2024-02-10 16:54:35 -0800602 talonfx_map.find("extend")->second->WriteVoltage(
603 output.extend_voltage());
604 talonfx_map.find("extend_roller")
605 ->second->WriteVoltage(output.extend_roller_voltage());
Niko Sohmers27d92c62024-02-19 14:15:07 -0800606 talonfx_map.find("altitude")
607 ->second->WriteVoltage(output.altitude_voltage());
608 talonfx_map.find("turret")->second->WriteVoltage(
609 output.turret_voltage());
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800610 });
611
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800612 can_drivetrain_writer.set_talonfxs({right_front, right_back},
613 {left_front, left_back});
614
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800615 can_superstructure_writer.add_talonfx("intake_pivot", intake_pivot);
616 can_superstructure_writer.add_talonfx("intake_roller", intake_roller);
Niko Sohmersed7ffc42024-02-03 16:05:19 -0800617 can_superstructure_writer.add_talonfx("transfer_roller", transfer_roller);
Filip Kujawa749f2442024-02-04 01:12:35 -0800618 can_superstructure_writer.add_talonfx("climber", climber);
Filip Kujawad75252a2024-02-10 16:54:35 -0800619 can_superstructure_writer.add_talonfx("extend", extend);
620 can_superstructure_writer.add_talonfx("extend_roller", extend_roller);
Niko Sohmers27d92c62024-02-19 14:15:07 -0800621 can_superstructure_writer.add_talonfx("altitude", altitude);
622 can_superstructure_writer.add_talonfx("turret", turret);
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800623
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800624 can_output_event_loop.MakeWatcher(
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800625 "/roborio", [&can_drivetrain_writer, &can_superstructure_writer](
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800626 const frc971::CANConfiguration &configuration) {
627 can_drivetrain_writer.HandleCANConfiguration(configuration);
Niko Sohmers1259b2a2024-01-29 18:00:37 -0800628 can_superstructure_writer.HandleCANConfiguration(configuration);
Maxwell Hendersonf75800f2024-01-12 19:52:05 -0800629 });
630
631 AddLoop(&can_output_event_loop);
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800632
633 // Thread 6
634
635 RunLoops();
636 }
637};
638
Stephan Pleinesf63bde82024-01-13 15:59:33 -0800639} // namespace y2024::wpilib
Niko Sohmers3860f8a2024-01-12 21:05:19 -0800640
641AOS_ROBOT_CLASS(::y2024::wpilib::WPILibRobot);