mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-25 01:41:43 +00:00
* Use explicit this capture required by C++20 * Use C++20 span * Replace wpi::numbers with std::numbers * Fix C++20 clang-tidy warning false positive in fmt * Remove ciso646 include since C++20 removed that header * Fix global-buffer-overflow asan warnings in ntcore tests * Add DIOSetProxy constructor to HAL * Upgrade MSVC compiler to 2022 * Bump native-utils to 2023.2.7 (changes to std=c++20) Co-authored-by: Peter Johnson <johnson.peter@gmail.com>
66 lines
2.4 KiB
C++
66 lines
2.4 KiB
C++
// Copyright (c) FIRST and other WPILib contributors.
|
|
// Open Source Software; you can modify and/or share it under the terms of
|
|
// the WPILib BSD license file in the root directory of this project.
|
|
|
|
#include "frc2/command/PIDCommand.h"
|
|
|
|
#include <utility>
|
|
|
|
using namespace frc2;
|
|
|
|
PIDCommand::PIDCommand(PIDController controller,
|
|
std::function<double()> measurementSource,
|
|
std::function<double()> setpointSource,
|
|
std::function<void(double)> useOutput,
|
|
std::initializer_list<Subsystem*> requirements)
|
|
: m_controller{std::move(controller)},
|
|
m_measurement{std::move(measurementSource)},
|
|
m_setpoint{std::move(setpointSource)},
|
|
m_useOutput{std::move(useOutput)} {
|
|
AddRequirements(requirements);
|
|
}
|
|
|
|
PIDCommand::PIDCommand(PIDController controller,
|
|
std::function<double()> measurementSource,
|
|
std::function<double()> setpointSource,
|
|
std::function<void(double)> useOutput,
|
|
std::span<Subsystem* const> requirements)
|
|
: m_controller{std::move(controller)},
|
|
m_measurement{std::move(measurementSource)},
|
|
m_setpoint{std::move(setpointSource)},
|
|
m_useOutput{std::move(useOutput)} {
|
|
AddRequirements(requirements);
|
|
}
|
|
|
|
PIDCommand::PIDCommand(PIDController controller,
|
|
std::function<double()> measurementSource,
|
|
double setpoint, std::function<void(double)> useOutput,
|
|
std::initializer_list<Subsystem*> requirements)
|
|
: PIDCommand(
|
|
controller, measurementSource, [setpoint] { return setpoint; },
|
|
useOutput, requirements) {}
|
|
|
|
PIDCommand::PIDCommand(PIDController controller,
|
|
std::function<double()> measurementSource,
|
|
double setpoint, std::function<void(double)> useOutput,
|
|
std::span<Subsystem* const> requirements)
|
|
: PIDCommand(
|
|
controller, measurementSource, [setpoint] { return setpoint; },
|
|
useOutput, requirements) {}
|
|
|
|
void PIDCommand::Initialize() {
|
|
m_controller.Reset();
|
|
}
|
|
|
|
void PIDCommand::Execute() {
|
|
m_useOutput(m_controller.Calculate(m_measurement(), m_setpoint()));
|
|
}
|
|
|
|
void PIDCommand::End(bool interrupted) {
|
|
m_useOutput(0);
|
|
}
|
|
|
|
PIDController& PIDCommand::GetController() {
|
|
return m_controller;
|
|
}
|