motor#
Initializing the motor Class#
An EXP Motor can be instantiated in different ways using one of the following constructors:
This motor
constructor creates a motor object with gears
defaulting to ratio18_1
.
Parameter |
Description |
---|---|
|
The Port on the EXP Brain the Motor is connected to. |
|
A boolean value to reverse the direction the Motor spins forward in. The default is |
// Construct a Motor connected to Port 1 which runs
// in reverse.
motor Motor1 = motor(PORT1, true);
This motor
constructor creates a motor object with reverse
defaulting to false
.
Parameter |
Description |
---|---|
|
The Port on the EXP Brain the Motor is connected to. |
|
The gear setting inserted in the motor. |
// Construct a Motor connected to Port 1 with a 6:1
// High Speed Motor Cartridge.
motor Motor1 = motor(PORT1, ratio6_1);
This motor
constructor creates a motor object with no default parameter values.
Parameter |
Description |
---|---|
|
The Port on the EXP Brain the Motor is connected to. |
|
The gear setting inserted in the motor. |
|
A boolean value to reverse the direction the Motor spins forward in. |
// Construct an EXP Motor with a 36:1 Torque Gear Cartridge
// that runs in reverse.
motor Motor1 = motor(PORT1, ratio36_1, true);
This Motor1
object will be used in all subsequent examples throughout this API documentation when referring to motor class methods.
Class Methods#
spin()#
This is a non-waiting function and allows the next command to run without delay.
This method is called in the following ways:
The spin(dir)
command is used to spin a Motor in the specified direction forever at the default velocity set by the setVelocity()
command, until a spin or stop command is used, or the project is stopped.
Parameters |
Description |
---|---|
dir |
A valid DirectionType. |
Returns: None.
// Spin Motor1 forward.
Motor1.spin(forward);
The spin(dir, velocity, units)
command is used to spin a Motor in the specified direction forever at a specified velocity until a spin or stop command is used, or the project is stopped.
Parameters |
Description |
---|---|
dir |
A valid DirectionType. |
velocity |
The velocity at which the Motor will spin. |
units |
A valid VelocityUnit or |
Returns: None.
// Spin Motor1 forward at 100 rpm.
Motor1.spin(forward, 100, rpm);
The spin(dir, voltage, units)
command is used to spin a Motor in the specified direction forever at a specified voltage until a spin or stop command is used, or the project is stopped.
Parameters |
Description |
---|---|
dir |
A valid DirectionType. |
voltage |
The voltage at which the Motor will spin. |
units |
A valid VoltageUnit. |
Returns: None.
// Spin Motor1 forward at 100 millivolts.
Motor1.spin(forward, 100, voltageUnits::mV);
spinToPosition()#
This function can be a waiting or non-waiting command depending on if the waitForCompletion
parameter is used.
This method is called in the following ways:
The spinToPosition(rotation, units, waitForCompletion)
command is used to spin a Motor to an absolute rotation in the specified units.
Parameters |
Description |
---|---|
rotation |
The position to spin the Motor to. |
units |
A valid RotationUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the motor has reached the target rotation.
// Spin Motor1 to the absolute position 1080 degrees.
Motor1.spinToPosition(1080, degrees);
The spinToPosition(rotation, units, velocity, units_v, waitForCompletion)
command is used to spin a Motor to an absolute rotation in the specified units.
Parameters |
Description |
---|---|
rotation |
The position to spin the Motor to. |
units |
A valid RotationUnit. |
velocity |
The velocity with which the Motor will spin. |
units_v |
A valid VelocityUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the motor has reached the target rotation.
// Spin Motor1 to the absolute position 1080 degrees
// at 100 percent velocity.
Motor1.spinToPosition(1080, degrees, 100, percent);
spinFor()#
This can be a waiting or non-waiting command depending on if the waitForCompletion
parameter is used.
This method is called in the following ways:
The spinFor(time, units)
command is used to spin the Motor for a specified duration.
Parameters |
Description |
---|---|
time |
The amount of time to spin the Motor for. |
units |
A valid TimeUnit. |
Returns: A Boolean that signifies when the motor has reached the target rotation.
// Spin Motor1 for 10 seconds
Motor1.spinFor(10, seconds);
The spinFor(dir, time, units)
command is used to spin the Motor for a specified duration in a specified direction.
Parameters |
Description |
---|---|
dir |
A valid DirectionType. |
time |
The amount of time to spin the Motor for. |
units |
A valid TimeUnit. |
// Spin Motor1 forward for 10 seconds
Motor1.spinFor(forward, 10, seconds);
The spinFor(time, units, velocity, units_v)
command is used to spin the Motor for a specified duration at a specified velocity.
Parameters |
Description |
---|---|
time |
The amount of time to spin the Motor for. |
units |
A valid TimeUnit. |
velocity |
The velocity with which the Motor will spin. |
units_v |
A valid VelocityUnit. |
// Spin Motor1 for 10 seconds at 100 rpm.
Motor1.spinFor(10, seconds, 100, rpm);
The spinFor(dir, time, units, velocity, units_v)
command is used to spin the Motor for a specified duration at a specified velocity in a specified direction.
Parameters |
Description |
---|---|
dir |
A valid DirectionType. |
time |
The amount of time to spin the Motor for. |
units |
A valid TimeUnit. |
velocity |
The velocity with which the Motor will spin. |
units_v |
A valid VelocityUnit. |
Returns: A Boolean that signifies when the motor has reached the target rotation.
// Spin Motor1 forward for 10 seconds at 100 rpm.
Motor1.spinFor(forward, 10, seconds, 100, rpm);
The spinFor(rotation, units, waitForCompletion)
command is used to spin the Motor for a specific rotation. The rotation is relative to the current rotation of the Motor.
Parameters |
Description |
---|---|
rotation |
The rotation value for the motor to spin for. |
units |
A valid RotationUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the motor has reached the target rotation.
// Spin Motor1 for 1000 degrees.
Motor1.spinFor(1000, degrees);
The spinFor(dir, rotation, units, waitForCompletion)
command is used to spin the Motor for a specific rotation in a specific direction. The rotation is relative to the current rotation of the Motor.
Parameters |
Description |
---|---|
dir |
A valid DirectionType. |
rotation |
The rotation value for the motor to spin for. |
units |
A valid RotationUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the motor has reached the target rotation.
// Spin Motor1 forward for 1000 degrees.
Motor1.spinFor(forward, 1000, degrees);
The spinFor(rotation, units, velocity, units_v, waitForCompletion)
command is used to spin the Motor for a specific rotation. The rotation is relative to the current rotation of the Motor.
Parameters |
Description |
---|---|
rotation |
The rotation value for the Motor to spin for. |
units |
A valid RotationUnit. |
velocity |
The velocity with which the Motor will spin. |
units_v |
A valid VelocityUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the motor has reached the target rotation.
// Spin Motor1 for 1000 degrees at 25 rpm.
Motor1.spinFor(1000, degrees, 25, rpm);
The spinFor(dir, rotation, units, velocity, units_v, waitForCompletion)
command is used to spin the Motor for a specific rotation in a specific direction. The rotation is relative to the current rotation of the Motor.
Parameters |
Description |
---|---|
dir |
A valid DirectionType. |
rotation |
The rotation value for the motor to spin for. |
units |
A valid RotationUnit. |
velocity |
The velocity with which the Motor will spin. |
units_v |
A valid VelocityUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the motor has reached the target rotation.
// Spin Motor1 forard for 1000 degrees at 25 rpm.
Motor1.spinFor(forward, 1000, degrees, 25, rpm);
stop()#
This is a non-waiting command and allows the next command to run without delay.
This method is called in the following ways:
The stop()
command is used to stop a Motor, setting the Motor to 0 velocity and configuring the current stopping mode. The default Brake Type is coast
, unless previously changed using the setStopping()
command.
Returns: None.
// Spin Motor1 for 2.5 seconds.
Motor1.spin(forward);
wait(2.5 seconds);
// Stop Motor1.
Motor1.stop();
The stop(mode)
command is used to stop a Motor using a specific Brake Type.
Parameters |
Description |
---|---|
mode |
A valid BrakeType. |
Returns: None.
// Spin Motor1 for 2.5 seconds.
Motor1.spin(forward);
wait(2.5 seconds);
// Stop Motor1 using the hold Brake Type.
Motor1.stop(hold);
setVelocity()#
The setVelocity(velocity, units)
command is used to set the default velocity for a Motor. This velocity setting will be used for subsequent calls to any motion functions if a specific velocity is not provided.
Parameters |
Description |
---|---|
velocity |
The new velocity to set for the Motor. |
units |
A valid VelocityUnit or |
Returns: None.
setReversed()#
The setReversed(value)
command sets the Motor direction to be reversed. Constructing a Motor with the reverse
parameter set to true
has the same result as Motor1.setReversed(true)
.
Parameters |
Description |
---|---|
value |
A Boolean value to set the Motor direction reversed or not. |
Returns: None.
setStopping()#
The setStopping(mode)
command is used to set the stopping mode for a Motor. This will be the stopping mode used when the stop()
command is called.
Parameters |
Description |
---|---|
mode |
A valid BrakeType. |
Returns: None.
resetPosition()#
The resetPosition()
command resets the Motor’s encoder value to 0.
Returns: None.
setPosition()#
The setPosition(value, units)
command is used to set the value of a Motor’s encoder to a specific value. The position that is returned by the position()
command will be updated to this new value.
Parameters |
Description |
---|---|
value |
The new position to set for the Motor’s encoder. |
units |
A valid RotationUnit. |
Returns: None.
setTimeout()#
The setTimeout(value, units)
command is used to set the timeout for motor commands. If a Motor does not reach its’ commanded position prior to the completion of the timeout, the Motor will stop.
Parameters |
Description |
---|---|
value |
The new timeout to set for the Motor. |
units |
A valid TimeUnit. |
Returns: None.
isSpinning()#
The isSpinning()
command returns if the Motor is currently rotating to a specific target.
Returns: true
if the Motor is on and is rotating to a target. false
if it is done rotating to a target.
isDone()#
The isDone()
command returns if the Motor is done rotating to a specific target.
Returns: true
if the Motor is done rotating to a target. false
if it is on and rotating to a target.
setMaxTorque()#
This method is called in the following ways:
The setMaxTorque(value, units)
command is used to set the maximum torque for a Motor.
Parameters |
Description |
---|---|
value |
The new maximum torque for a Motor. |
units |
A valid TorqueUnit. |
Returns: None.
// Set maximum torque to 2 Newton Meters.
Motor1.set_max_torque(2, Nm);
The setMaxTorque(value, units)
command is used to set the maximum torque for a Motor.
Parameters |
Description |
---|---|
value |
The new maximum torque for a Motor. |
units |
The only valid unit is |
Returns: None.
// Set maximum torque to ,05 amps.
Motor1.set_max_torque(.05, amp);
The setMaxTorque(value, units)
command is used to set the maximum torque for a Motor as a percentage.
Parameters |
Description |
---|---|
value |
The new maximum torque for a Motor. |
units |
The only valid unit is |
Returns: None.
// Set maximum torque to 75 percent.
Motor1.set_max_torque(75, percent);
convertVelocity()#
The convertVelocity(velocity, units, unitsout)
command converts the velocity in the given units to the given output units based on the Motor gearing.
Parameters |
Description |
---|---|
velocity |
The velocity to convert. |
units |
A valid VeloctyUnit for the input velocity. |
unitsout |
A valid VeloctyUnit for the output velocity. |
Returns: A double representing the velocity converted to the specified output units.
getMotorCartridge()#
The getMotorCartridge()
command returns the gear cartridge setting for the Motor.
Returns: The gear cartridge setting of the Motor.
direction()#
The direction()
command returns the current direction the Motor is spinning in as a directionType.
Returns: A DirectionType value representing current direction that the Motor is spinning in.
position()#
The position(units)
command returns the current rotation of the Motor.
Parameters |
Description |
---|---|
units |
A valid RotationUnit. |
Returns: A double representing the current rotation of the Motor in the specified units.
velocity()#
The velocity(units)
command returns the current velocity of the Motor.
Parameters |
Description |
---|---|
units |
A valid VelocityUnit or |
Returns: A double representing the current velocity of the Motor in the specified units.
current()#
The current(units)
command returns the current being used by the Motor.
Parameters |
Description |
---|---|
units |
The only valid units for current are |
Returns: A double representing the current being drawn by the Motor in the specified units.
voltage()#
The voltage(units)
command returns the electrical voltage of the Motor.
Parameters |
Description |
---|---|
units |
A valid VoltageUnit. The default is |
Returns: A double representing the electrical voltage of the Motor in the specified units.
power()#
The power(units)
command returns the power being consumed by the Motor.
Parameters |
Description |
---|---|
units |
The only valid unit for power is |
Returns: A double representing the current power of the Motor in the specified units.
torque()#
The torque(units)
command returns the torque of the Motor.
Parameters |
Description |
---|---|
units |
A valid TorqueUnit. |
Returns: The torque of the Motor in the specified units.
efficiency()#
The efficiency(units)
command returns the efficiency of the Motor.
Parameters |
Description |
---|---|
units |
The only valid unit for efficiency is |
Returns: The efficiency of the Motor as a percent.
temperature()#
The temperature(units)
command returns the current temperature of the Motor.
Parameters |
Description |
---|---|
units |
A valid TemperatureUnit or |
Returns: The current temperature of the Motor in the specified units.
installed()#
The installed()
command returns if the Motor is connected to the EXP Brain.
Returns: true
if the Motor is connected to the EXP Brain. false
if it is not.