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
005// THIS FILE WAS AUTO-GENERATED BY ./wpilibj/generate_pwm_motor_controllers.py. DO NOT MODIFY
006
007package edu.wpi.first.wpilibj.motorcontrol;
008
009import edu.wpi.first.hal.FRCNetComm.tResourceType;
010import edu.wpi.first.hal.HAL;
011import edu.wpi.first.wpilibj.PWM;
012
013/**
014 * AndyMark Koors40 Motor Controller.
015 *
016 * <p>Note that the Koors40 uses the following bounds for PWM values. These values should work
017 * reasonably well for most controllers, but if users experience issues such as asymmetric behavior
018 * around the deadband or inability to saturate the controller in either direction, calibration is
019 * recommended. The calibration procedure can be found in the Koors40 User Manual available from
020 * AndyMark.
021 *
022 * <ul>
023 *   <li>2.004ms = full "forward"
024 *   <li>1.520ms = the "high end" of the deadband range
025 *   <li>1.500ms = center of the deadband range (off)
026 *   <li>1.480ms = the "low end" of the deadband range
027 *   <li>0.997ms = full "reverse"
028 * </ul>
029 */
030public class Koors40 extends PWMMotorController {
031  /**
032   * Constructor.
033   *
034   * @param channel The PWM channel that the Koors40 is attached to. 0-9 are on-board, 10-19
035   *     are on the MXP port
036   */
037  @SuppressWarnings("this-escape")
038  public Koors40(final int channel) {
039    super("Koors40", channel);
040
041    m_pwm.setBoundsMicroseconds(2004, 1520, 1500, 1480, 997);
042    m_pwm.setPeriodMultiplier(PWM.PeriodMultiplier.k4X);
043    m_pwm.setSpeed(0.0);
044    m_pwm.setZeroLatch();
045
046    HAL.report(tResourceType.kResourceType_Koors40, getChannel() + 1);
047  }
048}