/* * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #pragma once #include "okapi/api/control/controllerOutput.hpp" #include "okapi/api/device/rotarysensor/continuousRotarySensor.hpp" #include namespace okapi { class AbstractMotor : public ControllerOutput { public: /** * Indicates the 'brake mode' of a motor. */ enum class brakeMode { coast = 0, ///< Motor coasts when stopped, traditional behavior brake = 1, ///< Motor brakes when stopped hold = 2, ///< Motor actively holds position when stopped invalid = INT32_MAX }; /** * Indicates the units used by the motor encoders. */ enum class encoderUnits { degrees = 0, ///< degrees rotations = 1, ///< rotations counts = 2, ///< counts invalid = INT32_MAX ///< invalid }; /** * Indicates the internal gear ratio of a motor. */ enum class gearset { red = 100, ///< 36:1, 100 RPM, Red gear set green = 200, ///< 18:1, 200 RPM, Green gear set blue = 600, ///< 6:1, 600 RPM, Blue gear set invalid = INT32_MAX }; /** * A simple structure representing the full ratio between motor and wheel. */ struct GearsetRatioPair { /** * A simple structure representing the full ratio between motor and wheel. * * The ratio is `motor rotation : wheel rotation`, e.x., if one motor rotation * corresponds to two wheel rotations, the ratio is `1.0/2.0`. * * @param igearset The gearset in the motor. * @param iratio The ratio of motor rotation to wheel rotation. */ GearsetRatioPair(const gearset igearset, const double iratio = 1) : internalGearset(igearset), ratio(iratio) { } ~GearsetRatioPair() = default; gearset internalGearset; double ratio = 1; }; virtual ~AbstractMotor(); /******************************************************************************/ /** Motor movement functions **/ /** **/ /** These functions allow programmers to make motors move **/ /******************************************************************************/ /** * Sets the target absolute position for the motor to move to. * * This movement is relative to the position of the motor when initialized or * the position when it was most recently reset with setZeroPosition(). * * @note This function simply sets the target for the motor, it does not block program execution * until the movement finishes. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param iposition The absolute position to move to in the motor's encoder units * @param ivelocity The maximum allowable velocity for the movement in RPM * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t moveAbsolute(double iposition, std::int32_t ivelocity) = 0; /** * Sets the relative target position for the motor to move to. * * This movement is relative to the current position of the motor. Providing 10.0 as the position * parameter would result in the motor moving clockwise 10 units, no matter what the current * position is. * * @note This function simply sets the target for the motor, it does not block program execution * until the movement finishes. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param iposition The relative position to move to in the motor's encoder units * @param ivelocity The maximum allowable velocity for the movement in RPM * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t moveRelative(double iposition, std::int32_t ivelocity) = 0; /** * Sets the velocity for the motor. * * This velocity corresponds to different actual speeds depending on the gearset * used for the motor. This results in a range of +-100 for pros::c::red, * +-200 for green, and +-600 for blue. The velocity * is held with PID to ensure consistent speed, as opposed to setting the motor's * voltage. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param ivelocity The new motor velocity from -+-100, +-200, or +-600 depending on the motor's * gearset * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t moveVelocity(std::int16_t ivelocity) = 0; /** * Sets the voltage for the motor from -12000 to 12000. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param ivoltage The new voltage value from -12000 to 12000 * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t moveVoltage(std::int16_t ivoltage) = 0; /** * Changes the output velocity for a profiled movement (moveAbsolute or moveRelative). This will * have no effect if the motor is not following a profiled movement. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param ivelocity The new motor velocity from -+-100, +-200, or +-600 depending on the motor's * gearset * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t modifyProfiledVelocity(std::int32_t ivelocity) = 0; /******************************************************************************/ /** Motor telemetry functions **/ /** **/ /** These functions allow programmers to collect telemetry from motors **/ /******************************************************************************/ /** * Gets the target position set for the motor by the user. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return The target position in its encoder units or PROS_ERR_F if the operation failed, * setting errno. */ virtual double getTargetPosition() = 0; /** * Gets the absolute position of the motor in its encoder units. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's absolute position in its encoder units or PROS_ERR_F if the operation * failed, setting errno. */ virtual double getPosition() = 0; /** * Gets the positional error (target position minus actual position) of the motor in its encoder * units. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's positional error in its encoder units or PROS_ERR_F if the operation * failed, setting errno. */ double getPositionError(); /** * Sets the "absolute" zero position of the motor to its current position. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t tarePosition() = 0; /** * Gets the velocity commanded to the motor by the user. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return The commanded motor velocity from +-100, +-200, or +-600, or PROS_ERR if the operation * failed, setting errno. */ virtual std::int32_t getTargetVelocity() = 0; /** * Gets the actual velocity of the motor. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's actual velocity in RPM or PROS_ERR_F if the operation failed, setting * errno. */ virtual double getActualVelocity() = 0; /** * Gets the difference between the target velocity of the motor and the actual velocity of the * motor. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's velocity error in RPM or PROS_ERR_F if the operation failed, setting * errno. */ double getVelocityError(); /** * Gets the current drawn by the motor in mA. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's current in mA or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t getCurrentDraw() = 0; /** * Gets the direction of movement for the motor. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return 1 for moving in the positive direction, -1 for moving in the negative direction, and * PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t getDirection() = 0; /** * Gets the efficiency of the motor in percent. * * An efficiency of 100% means that the motor is moving electrically while * drawing no electrical power, and an efficiency of 0% means that the motor * is drawing power but not moving. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's efficiency in percent or PROS_ERR_F if the operation failed, setting errno. */ virtual double getEfficiency() = 0; /** * Checks if the motor is drawing over its current limit. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return 1 if the motor's current limit is being exceeded and 0 if the current limit is not * exceeded, or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t isOverCurrent() = 0; /** * Checks if the motor's temperature is above its limit. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return 1 if the temperature limit is exceeded and 0 if the the temperature is below the limit, * or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t isOverTemp() = 0; /** * Checks if the motor is stopped. * * Although this function forwards data from the motor, the motor presently does not provide any * value. This function returns PROS_ERR with errno set to ENOSYS. * * @return 1 if the motor is not moving, 0 if the motor is moving, or PROS_ERR if the operation * failed, setting errno */ virtual std::int32_t isStopped() = 0; /** * Checks if the motor is at its zero position. * * Although this function forwards data from the motor, the motor presently does not provide any * value. This function returns PROS_ERR with errno set to ENOSYS. * * @return 1 if the motor is at zero absolute position, 0 if the motor has moved from its absolute * zero, or PROS_ERR if the operation failed, setting errno */ virtual std::int32_t getZeroPositionFlag() = 0; /** * Gets the faults experienced by the motor. Compare this bitfield to the bitmasks in * pros::motor_fault_e_t. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return A currently unknown bitfield containing the motor's faults. 0b00000100 = Current Limit * Hit */ virtual uint32_t getFaults() = 0; /** * Gets the flags set by the motor's operation. Compare this bitfield to the bitmasks in * pros::motor_flag_e_t. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return A currently unknown bitfield containing the motor's flags. These seem to be unrelated * to the individual get_specific_flag functions */ virtual uint32_t getFlags() = 0; /** * Gets the raw encoder count of the motor at a given timestamp. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @param timestamp A pointer to a time in milliseconds for which the encoder count will be * returned. If NULL, the timestamp at which the encoder count was read will not be supplied * * @return The raw encoder count at the given timestamp or PROS_ERR if the operation failed. */ virtual std::int32_t getRawPosition(std::uint32_t *timestamp) = 0; /** * Gets the power drawn by the motor in Watts. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's power draw in Watts or PROS_ERR_F if the operation failed, setting errno. */ virtual double getPower() = 0; /** * Gets the temperature of the motor in degrees Celsius. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's temperature in degrees Celsius or PROS_ERR_F if the operation failed, * setting errno. */ virtual double getTemperature() = 0; /** * Gets the torque generated by the motor in Newton Metres (Nm). * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's torque in NM or PROS_ERR_F if the operation failed, setting errno. */ virtual double getTorque() = 0; /** * Gets the voltage delivered to the motor in millivolts. * * This function uses the following values of errno when an error state is * reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's voltage in V or PROS_ERR_F if the operation failed, setting errno. */ virtual std::int32_t getVoltage() = 0; /******************************************************************************/ /** Motor configuration functions **/ /** **/ /** These functions allow programmers to configure the behavior of motors **/ /******************************************************************************/ /** * Sets one of brakeMode to the motor. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param imode The new motor brake mode to set for the motor * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t setBrakeMode(brakeMode imode) = 0; /** * Gets the brake mode that was set for the motor. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return One of brakeMode, according to what was set for the motor, or brakeMode::invalid if the * operation failed, setting errno. */ virtual brakeMode getBrakeMode() = 0; /** * Sets the current limit for the motor in mA. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param ilimit The new current limit in mA * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t setCurrentLimit(std::int32_t ilimit) = 0; /** * Gets the current limit for the motor in mA. * * The default value is 2500 mA. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return The motor's current limit in mA or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t getCurrentLimit() = 0; /** * Sets one of encoderUnits for the motor encoder. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param iunits The new motor encoder units * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t setEncoderUnits(encoderUnits iunits) = 0; /** * Gets the encoder units that were set for the motor. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return One of encoderUnits according to what is set for the motor or encoderUnits::invalid if * the operation failed. */ virtual encoderUnits getEncoderUnits() = 0; /** * Sets one of gearset for the motor. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param igearset The new motor gearset * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t setGearing(gearset igearset) = 0; /** * Gets the gearset that was set for the motor. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @return One of gearset according to what is set for the motor, or gearset::invalid if the * operation failed. */ virtual gearset getGearing() = 0; /** * Sets the reverse flag for the motor. * * This will invert its movements and the values returned for its position. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param ireverse True reverses the motor, false is default * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t setReversed(bool ireverse) = 0; /** * Sets the voltage limit for the motor in Volts. * * This function uses the following values of errno when an error state is reached: * EACCES - Another resource is currently trying to access the port. * * @param ilimit The new voltage limit in Volts * @return 1 if the operation was successful or PROS_ERR if the operation failed, setting errno. */ virtual std::int32_t setVoltageLimit(std::int32_t ilimit) = 0; /** * Returns the encoder associated with this motor. * * @return the encoder for this motor */ virtual std::shared_ptr getEncoder() = 0; }; AbstractMotor::GearsetRatioPair operator*(AbstractMotor::gearset gearset, double ratio); } // namespace okapi