Motor
Contents
class MotorSpeedController
base class
class DCMotorSpeedController
derived from class MotorSpeedController
Description
A DCMotorSpeedController is a simple proportional controller for an instance of class DCMotor. Given a commanded-speed it produces an input voltage for the associated DCMotor instance.
Constructor
DCMotorSpeedController( DCMotor& dc_motor,
double gain,
const double& actual_speed,
const double& supply_voltage);
Access | Member Name | Type | Units | Value |
---|---|---|---|---|
private | gain | double | -- | Parameter - Feedback gain |
private | actualSpeed | const double& | m/s | Parameter - Reference to the actual motor speed. |
private | supplyVoltage | const double& | volts | Reference to the power supply voltage. |
private | motor | -- | Parameter - Reference to the DCMotor instance to be controlled. |
Member Functions
void setCommandedSpeed( double commandedSpeed );
Access | Member Name | Type | Units | Value |
---|---|---|---|---|
private | motorVoltage | double | volts | [Eq#1] |
- [Eq#1] motorVoltage = supplyVoltage * gain * ( commandedSpeed - actualSpeed ) [ limited to +/- supplyVoltage ]
double getMotorVoltage();
Return the motorVoltage that was calculated by the last call to setCommandedSpeed().
class Motor
base class
class DCMotor
derived from class Motor
Class DCMotor represents a simple model of a DC motor. Given an input voltage it calculates a
- current-load, and
- a motor-torque.
The model consists of a constant internal resistance that converts an input voltage to current, and a motor torque constant that converts the current to output torque. The output current load is the absolute value of the current.
Constructor
DCMotor (const double initialInternalResistance,
const double initialMotorTorqueConstant);
Access | Member Name | Type | Units | Value |
---|---|---|---|---|
private | internalResistance | double | ohms | Input |
private | motorTorqueConstant | double | Nm/amp | Input |
Member Functions
void update (const double motorVoltage);
This method is to be called periodically to update the motor state.
Access | Member Name | Type | Units | Value |
---|---|---|---|---|
private | motorCurrent | double | amp | [Eq#1] |
private | motorTorque | double | Nm | [Eq#2] |
private | currentLoad | double | amp | [Eq#3] |
-
[Eq#1] motorCurrent = motorVoltage / internalResistance
-
[Eq#2] motorTorque = motorCurrent / motorTorqueConstant
-
[Eq#3] currentLoad = || motorCurrent ||
void update (const PWM& PulseWidth);
PulseWidth is converted to voltage [ PulseWidth.getAverageVoltage() ], and then the above method is called.
double getTorque();
Return the torque that was calculated by the last call to update()
.
double getCurrentLoad()
Return the current-load that was calculated by the last call to update(). An example use of this method might be to update a battery model.
class PWM
Description
This class represents a PWM signal. Pulse Width Modulation (PWM) is a method of controlling electrical power (current x voltage) by repeatedly switching the supply voltage on and off, or between a high and low (typically 0) voltage. The proportion of time that the voltage is "high" is called the duty-cycle. The average output voltage is:
[Eq#1] average_voltage = ((highVoltage * dutyCycle + lowVoltage * (1 - dutyCycle)) / 2)
Constructor
PWM( double HighVoltage,
double LowVoltage,
double DutyCycle);
Access | Member Name | Type | Units | Value |
---|---|---|---|---|
public | HighVoltage | double | volts | |
public | LowVoltage | double | volts | |
private | dutyCycle | double | volts |
Member Functions
void setDutyCycle( double DutyCycle);
Set the duty cycle to be used by getAverageVoltage().
double getDutyCycle() const;
Get current the duty cycle.
double getAverageVoltage() const;
Calculate and return the average_voltage by Eq#1.