mirror of
https://github.com/wpilibsuite/allwpilib
synced 2026-06-19 00:41:43 +00:00
85 lines
2.0 KiB
C++
85 lines
2.0 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.
|
|
|
|
#pragma once
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
|
|
#include <wpi/span.h>
|
|
|
|
#include "frc/MotorSafety.h"
|
|
|
|
namespace frc {
|
|
|
|
/**
|
|
* Common base class for drive platforms.
|
|
*
|
|
* MotorSafety is enabled by default.
|
|
*/
|
|
class RobotDriveBase : public MotorSafety {
|
|
public:
|
|
/**
|
|
* The location of a motor on the robot for the purpose of driving.
|
|
*/
|
|
enum MotorType {
|
|
kFrontLeft = 0,
|
|
kFrontRight = 1,
|
|
kRearLeft = 2,
|
|
kRearRight = 3,
|
|
kLeft = 0,
|
|
kRight = 1,
|
|
kBack = 2
|
|
};
|
|
|
|
RobotDriveBase();
|
|
~RobotDriveBase() override = default;
|
|
|
|
RobotDriveBase(RobotDriveBase&&) = default;
|
|
RobotDriveBase& operator=(RobotDriveBase&&) = default;
|
|
|
|
/**
|
|
* Sets the deadband applied to the drive inputs (e.g., joystick values).
|
|
*
|
|
* The default value is 0.02. Inputs smaller than the deadband are set to 0.0
|
|
* while inputs larger than the deadband are scaled from 0.0 to 1.0. See
|
|
* frc::ApplyDeadband().
|
|
*
|
|
* @param deadband The deadband to set.
|
|
*/
|
|
void SetDeadband(double deadband);
|
|
|
|
/**
|
|
* Configure the scaling factor for using RobotDrive with motor controllers in
|
|
* a mode other than PercentVbus or to limit the maximum output.
|
|
*
|
|
* @param maxOutput Multiplied with the output percentage computed by the
|
|
* drive functions.
|
|
*/
|
|
void SetMaxOutput(double maxOutput);
|
|
|
|
/**
|
|
* Feed the motor safety object. Resets the timer that will stop the motors if
|
|
* it completes.
|
|
*
|
|
* @see MotorSafetyHelper::Feed()
|
|
*/
|
|
void FeedWatchdog();
|
|
|
|
void StopMotor() override = 0;
|
|
std::string GetDescription() const override = 0;
|
|
|
|
protected:
|
|
/**
|
|
* Renormalize all wheel speeds if the magnitude of any wheel is greater than
|
|
* 1.0.
|
|
*/
|
|
static void Desaturate(wpi::span<double> wheelSpeeds);
|
|
|
|
double m_deadband = 0.02;
|
|
double m_maxOutput = 1.0;
|
|
};
|
|
|
|
} // namespace frc
|