001// Copyright (c) FIRST and other WPILib contributors.
002// Open Source Software; you can modify and/or share it under the terms of
003// the WPILib BSD license file in the root directory of this project.
004
005package edu.wpi.first.wpilibj.drive;
006
007import edu.wpi.first.wpilibj.MotorSafety;
008
009/**
010 * Common base class for drive platforms.
011 *
012 * <p>{@link edu.wpi.first.wpilibj.MotorSafety} is enabled by default.
013 */
014public abstract class RobotDriveBase extends MotorSafety {
015  /** Default input deadband. */
016  public static final double kDefaultDeadband = 0.02;
017
018  /** Default maximum output. */
019  public static final double kDefaultMaxOutput = 1.0;
020
021  /** Input deadband. */
022  protected double m_deadband = kDefaultDeadband;
023
024  /** Maximum output. */
025  protected double m_maxOutput = kDefaultMaxOutput;
026
027  /** The location of a motor on the robot for the purpose of driving. */
028  public enum MotorType {
029    /** Front left motor. */
030    kFrontLeft(0),
031    /** Front right motor. */
032    kFrontRight(1),
033    /** Rear left motor. */
034    kRearLeft(2),
035    /** Rear right motor. */
036    kRearRight(3),
037    /** Left motor. */
038    kLeft(0),
039    /** Right motor. */
040    kRight(1),
041    /** Back motor. */
042    kBack(2);
043
044    /** MotorType value. */
045    public final int value;
046
047    MotorType(int value) {
048      this.value = value;
049    }
050  }
051
052  /** RobotDriveBase constructor. */
053  @SuppressWarnings("this-escape")
054  public RobotDriveBase() {
055    setSafetyEnabled(true);
056  }
057
058  /**
059   * Sets the deadband applied to the drive inputs (e.g., joystick values).
060   *
061   * <p>The default value is {@value #kDefaultDeadband}. Inputs smaller than the deadband are set to
062   * 0.0 while inputs larger than the deadband are scaled from 0.0 to 1.0. See {@link
063   * edu.wpi.first.math.MathUtil#applyDeadband}.
064   *
065   * @param deadband The deadband to set.
066   */
067  public void setDeadband(double deadband) {
068    m_deadband = deadband;
069  }
070
071  /**
072   * Configure the scaling factor for using drive methods with motor controllers in a mode other
073   * than PercentVbus or to limit the maximum output.
074   *
075   * <p>The default value is {@value #kDefaultMaxOutput}.
076   *
077   * @param maxOutput Multiplied with the output percentage computed by the drive functions.
078   */
079  public void setMaxOutput(double maxOutput) {
080    m_maxOutput = maxOutput;
081  }
082
083  /**
084   * Feed the motor safety object. Resets the timer that will stop the motors if it completes.
085   *
086   * @see MotorSafety#feed()
087   */
088  public void feedWatchdog() {
089    feed();
090  }
091
092  @Override
093  public abstract void stopMotor();
094
095  @Override
096  public abstract String getDescription();
097
098  /**
099   * Normalize all wheel speeds if the magnitude of any wheel is greater than 1.0.
100   *
101   * @param wheelSpeeds List of wheel speeds to normalize.
102   */
103  protected static void normalize(double[] wheelSpeeds) {
104    double maxMagnitude = Math.abs(wheelSpeeds[0]);
105    for (int i = 1; i < wheelSpeeds.length; i++) {
106      double temp = Math.abs(wheelSpeeds[i]);
107      if (maxMagnitude < temp) {
108        maxMagnitude = temp;
109      }
110    }
111    if (maxMagnitude > 1.0) {
112      for (int i = 0; i < wheelSpeeds.length; i++) {
113        wheelSpeeds[i] = wheelSpeeds[i] / maxMagnitude;
114      }
115    }
116  }
117}