motor_group#
Initializing the motor_group Class#
An EXP motor_group object is created by using the following constructor:
The motor_group
constructor creates a motor_group object.
You can create a motor_group with any number of Motors.
// Create 2 Motors, Motor1 and Motor2 in
// Ports 1 and 2 respectively.
Motor1 = motor(PORT1);
Motor1 = motor(PORT2);
// Using the two previously created Motors, create a
// motor_group named MotorGroup1.
motor_group MotorGroup1 = motor_group(Motor1, Motor2);
This MotorGroup1
object will be used in all subsequent examples throughout this API documentation when referring to MotorGroup 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 the Motors 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 MotorGroup1 forward.
MotorGroup1.spin(forward);
The spin(dir, velocity, units)
command is used to spin the Motors 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 Motors will spin. |
units |
A valid VelocityUnit or |
Returns: None.
// Spin MotorGroup1 forward at 100 rpm.
MotorGroup1.spin(forward, 100, rpm);
The spin(dir, voltage, units)
command is used to spin the Motors 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 Motors will spin. |
units |
A valid VoltageUnit. |
Returns: None.
// Spin MotorGroup1 forward at 100 millivolts.
MotorGroup1.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 the Motors to an absolute rotation in the specified units.
Parameters |
Description |
---|---|
rotation |
The position to spin the Motors to. |
units |
A valid RotationUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 to the absolute position 1080 degrees.
MotorGroup1.spinToPosition(1080, degrees);
The spinToPosition(rotation, units, velocity, units_v, waitForCompletion)
command is used to spin the Motors to an absolute rotation in the specified units.
Parameters |
Description |
---|---|
rotation |
The position to spin the Motors to. |
units |
A valid RotationUnit. |
velocity |
The velocity with which the Motors will spin. |
units_v |
A valid VelocityUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 to the absolute position 1080 degrees
// at 100 percent velocity.
MotorGroup1.spinToPosition(1080, degrees, 100, velocityUnits::pct);
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 Motors for a specified duration.
Parameters |
Description |
---|---|
time |
The amount of time to spin the Motors for. |
units |
A valid TimeUnit. |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 for 10 seconds
MotorGroup1.spinFor(10, seconds);
The spinFor(dir, time, units)
command is used to spin the Motors for a specified duration in a specified direction.
Parameters |
Description |
---|---|
dir |
A valid DirectionType. |
time |
The amount of time to spin the Motors for. |
units |
A valid TimeUnit. |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 forward for 10 seconds
MotorGroup1.spinFor(forward, 10, seconds);
The spinFor(time, units, velocity, units_v)
command is used to spin the Motors for a specified duration at a specified velocity.
Parameters |
Description |
---|---|
time |
The amount of time to spin the Motors for. |
units |
A valid TimeUnit. |
velocity |
The velocity with which the Motors will spin. |
units_v |
A valid VelocityUnit. |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 for 10 seconds at 100 rpm.
MotorGroup1.spinFor(10, seconds, 100, rpm);
The spinFor(dir, time, units, velocity, units_v)
command is used to spin the Motors 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 Motors for. |
units |
A valid TimeUnit. |
velocity |
The velocity with which the Motors will spin. |
units_v |
A valid VelocityUnit. |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 forward for 10 seconds at 100 rpm.
MotorGroup1.spinFor(forward, 10, seconds, 100, rpm);
The spinFor(rotation, units, waitForCompletion)
command is used to spin the Motors for a specific rotation. The rotation is relative to the current rotation of the Motor.
Parameters |
Description |
---|---|
rotation |
The rotation value for the Motors to spin for. |
units |
A valid RotationUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 for 1000 degrees.
MotorGroup1.spinFor(1000, degrees);
The spinFor(dir, rotation, units, waitForCompletion)
command is used to spin the Motors 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 Motors to spin for. |
units |
A valid RotationUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 forward for 1000 degrees.
MotorGroup1.spinFor(forward, 1000, degrees);
The spinFor(rotation, units, velocity, units_v, waitForCompletion)
command is used to spin the Motors for a specific rotation. The rotation is relative to the current rotation of the Motor.
Parameters |
Description |
---|---|
rotation |
The rotation value for the Motors to spin for. |
units |
A valid RotationUnit. |
velocity |
The velocity with which the Motors will spin. |
units_v |
A valid VelocityUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the Motors have reached the target rotation.
// Spin MotorGroup1 for 1000 degrees at 25 rpm.
MotorGroup1.spinFor(1000, degrees, 25, rpm);
The spinFor(dir, rotation, units, velocity, units_v, waitForCompletion)
command is used to spin the Motors 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 Motors to spin for. |
units |
A valid RotationUnit. |
velocity |
The velocity with which the Motors will spin. |
units_v |
A valid VelocityUnit. |
waitForCompletion |
Determines whether the command will block subsequent commands ( |
Returns: A Boolean that signifies when the Motors has reached the target rotation.
// Spin MotorGroup1 forard for 1000 degrees at 25 rpm.
MotorGroup1.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 the Motors, setting them 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 MotorGroup1 for 2.5 seconds.
MotorGroup1.spin(forward);
wait(2.5 seconds);
// Stop MotorGroup1.
MotorGroup1.stop();
The stop(mode)
command is used to stop the Motors using a specific Brake Type.
Parameters |
Description |
---|---|
mode |
A valid BrakeType. |
Returns: None.
// Spin MotorGroup1 for 2.5 seconds.
MotorGroup1.spin(forward);
wait(2.5 seconds);
// Stop MotorGroup1 using the hold Brake Type.
MotorGroup1.stop(hold);
count()#
The count()
command returns the number of Motors in a Motor Group.
Returns: The number of Motors in the Motor Group.
setVelocity()#
The setVelocity(velocity, units)
command is used to set the default velocity for the Motors. 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 Motors. |
units |
A valid VelocityUnit or |
Returns: None.
setStopping()#
The setStopping(mode)
command is used to set the stopping mode for the Motors. This will be the stopping mode used when the stop()
command is called without specifying a brakeType.
Parameters |
Description |
---|---|
mode |
A valid BrakeType. |
Returns: None.
resetPosition()#
The resetPosition()
command resets the value of all Motor encoders to 0.
Returns: None.
setPosition()#
The setPosition(value, units)
command is used to set the value of all Motor encoders to a specified value. The position that is returned by the position()
command will be updated to this new value.
Parameters |
Description |
---|---|
value |
The new value to set for all Motor encoders. |
units |
A valid RotationUnit. |
Returns: None.
setTimeout()#
The setTimeout(value, units)
command is used to set the timeout for Motor Group commands. If a Motor does not reach its’ commanded position prior to the completion of the timeout, the Motors will stop.
Parameters |
Description |
---|---|
value |
The new timeout to set for the Motors. |
units |
A valid TimeUnit. |
Returns: None.
isSpinning()#
The isSpinning()
command returns if any Motor is currently rotating to a specific target.
Returns: true
if any Motor is on and is rotating to a target. false
if all Motors are done rotating to a target.
isDone()#
The isDone()
command returns if all Motors are done rotating to a specific target.
Returns: true
if all Motors are done rotating to a target. false
if any Motor 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 the Motors in torqueUnits.
Parameters |
Description |
---|---|
value |
The new maximum torque for the Motors. |
units |
A valid TorqueUnit. |
Returns: None.
// Set maximum torque to 2 Newton Meters.
MotorGroup1.set_max_torque(2, Nm);
The setMaxTorque(value, units)
command is used to set the maximum torque for the Motors in currentUnits.
Parameters |
Description |
---|---|
value |
The new maximum torque for the Motors. |
units |
The only valid unit is |
Returns: None.
// Set maximum torque to ,05 amps.
MotorGroup1.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 the Motors. |
units |
The only valid unit is |
Returns: None.
// Set maximum torque to 75 percent.
MotorGroup1.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 of the first Motor in the Group.
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 first Motor in the Group.
Returns: The gear cartridge setting of the Motor.
direction()#
The direction()
command returns the current direction the first Motor in the Group is spinning in as a directionType.
Returns: A DirectionType value representing current direction that the first Motor in the Group is spinning in.
position()#
The position(units)
command returns the current rotation of the first Motor in the Group.
Parameters |
Description |
---|---|
units |
A valid RotationUnit. |
Returns: A double representing the current rotation of the first Motor in the Group in the specified units.
velocity()#
The velocity(units)
command returns the current velocity of the first Motor in the Group.
Parameters |
Description |
---|---|
units |
A valid VelocityUnit or |
Returns: A double representing the current velocity of the first Motor in the Group in the specified units.
current()#
The current(units)
command returns the current being used by the first Motor in the Group.
Parameters |
Description |
---|---|
units |
The only valid units for current are |
Returns: A double representing the current being drawn by the first Motor in the Group in the specified units.
voltage()#
The voltage(units)
command returns the voltage of the first Motor in the Group.
Parameters |
Description |
---|---|
units |
A valid VoltageUnit. The default is |
Returns: A double representing the voltage of the first Motor in the Group in the specified units.
power()#
The power(units)
command returns the power being consumed by the first Motor in the Group.
Parameters |
Description |
---|---|
units |
The only valid unit for power is |
Returns: A double representing the current power of the first Motor in the Group in the specified units.
torque()#
The torque(units)
command returns the torque of the first Motor in the Group.
Parameters |
Description |
---|---|
units |
A valid TorqueUnit. |
Returns: The torque of the first Motor in the Group in the specified units.
efficiency()#
The efficiency(units)
command returns the efficiency of the first Motor in the Group.
Parameters |
Description |
---|---|
units |
The only valid unit for efficiency is |
Returns: The efficiency of the first Motor in the Group as a percent.
temperature()#
The temperature(units)
command returns the current temperature of the first Motor in the Group.
Parameters |
Description |
---|---|
units |
A valid TemperatureUnit or |
Returns: The current temperature of the first Motor in the Group in the specified units.