Serial Wombat Arduino Library
|
SerialWombatServo, SerialWombatPWM and other proportional ouptut classes inherit from this class. it provides control blocks for manipulating output based on input. More...
#include <SerialWombatAbstractScaledOutput.h>
Public Types | |
enum | Period { PERIOD_1mS = 0 , PERIOD_2mS = 1 , PERIOD_4mS = 2 , PERIOD_8mS = 3 , PERIOD_16mS = 4 , PERIOD_32mS = 5 , PERIOD_64mS = 6 , PERIOD_128mS = 7 , PERIOD_256mS = 8 , PERIOD_512mS = 9 , PERIOD_1024mS = 10 } |
enum | RampMode { RAMP_MODE_BOTH = 0 , RAMP_MODE_INCREMENT = 1 , RAMP_MODE_DECREMENT = 2 } |
Public Member Functions | |
SerialWombatAbstractScaledOutput (SerialWombatChip &sw) | |
Constructor for the SerialWombatAbstractScaledOutput Class. | |
int16_t | writeTimeout (uint16_t timeout_mS, uint16_t timeoutOutputValue) |
Enable a timeout value which will cause the output to go to a default value if not updated. | |
int16_t | writeScalingEnabled (bool enabled, uint8_t sourcePin) |
Enable scaling and set which pin or public data is used as the input source. | |
int16_t | writeInputScaling (uint16_t inputMin, uint16_t inputMax) |
Scale incoming values to a range of 0 to 65535. | |
int16_t | writeOutputScaling (uint16_t outputMin, uint16_t outputMax) |
Reduces the output range from 0 to 65535 to user specified range. | |
int16_t | writeScalingInvertedInput (bool inverted) |
if enabled subtract the input value from 65535 before doing any other processing. | |
int16_t | writeScalingTargetValue (uint16_t target) |
The target input value for PID control. | |
int16_t | writeRateControl (Period samplePeriod, uint16_t maximumChangecounts) |
int16_t | write1stOrderFiltering (Period sampleRate, uint16_t filterConstant) |
int16_t | writeHysteresis (uint16_t lowLimit, uint16_t lowOutputValue, uint16_t highLimit, uint16_t highOutputValue, uint16_t initialOutputValue) |
Controls the output based on hystersis control. | |
int16_t | writeRamp (uint16_t slowIncrement, uint16_t incrementThreshold, uint16_t fastIncrement, Period samplePeriod, RampMode rampMode) |
Configure the scaled output block into Ramp control mode. | |
int16_t | writePID (uint16_t kp, uint16_t ki, uint16_t kd, uint16_t target, Period samplePeriod, uint8_t targetPin=255, bool biDirectional=false) |
Configure the scaled output block into PID control mode. | |
uint16_t | readLastOutputValue () |
Request Last Output Value. | |
int16_t | writeScalingTargetValueResetIntegrator (uint16_t target) |
int32_t | PIDGetLastError () |
int32_t | PIDGetLastIntegrator () |
int32_t | PIDGetLastIntegratorEffort () |
int32_t | PIDGetLastProportionalEffort () |
int32_t | PIDGetLastDerivativeEffort () |
int32_t | PIDGetLastEffort () |
uint16_t | ReadLastTarget () |
int16_t | Enable2DLookupOutputScaling (uint16_t IndexInUserMemory) |
Set Up 2D Lookup Output Scaling. | |
virtual uint8_t | pin ()=0 |
Facilitates inheritance. | |
virtual uint8_t | swPinModeNumber ()=0 |
Facilitates inheritance. | |
SerialWombatServo, SerialWombatPWM and other proportional ouptut classes inherit from this class. it provides control blocks for manipulating output based on input.
This class encapsulates the Serial Wombat Scaled Output functional block. This block is included in all proportial output classes in the SerialWombat 18AB chip. Each pin's output block is separate from the others.
This block is designed to facilitate real time control of outputs based on configuration from the host without the need to issue additional commands after the initial configuration. The block also includes a timeout function which is capable of setting an output to pre-determined value if the host does not reset a countdown timer within a specified number of mS. This allows a controlled shutdown if the host crashes, the data bus becomes inoperable, etc. Because the output block is serviced every 1mS, real time control can be achived with higher performance than if control was performed over the data bus. This functionality also frees the host of the need to maintain timing sensitive communication with the Serial Wombat chip.
This block can limit output rate of change either by a limited amout of change per time, or by first-order filtering output changes. Rate limiting is useful to implement smooth motion over time (controlled within the Serial Wombat chip) such as a model railroad crossing gate attached to a servo. It also can prevent a current spike caused by requesting large changes in position at one time. First order filtering is useful to change position rapidly at the beginning, but slow near the end to reduce impact speed.
The target output value can be provided by the host, or the Scaled Output block can be configured to get its target value from another pin or a public data source such as the Serial Wombat 18AB chip's internal temperature sensor or source voltage measurement. This capability to act on another pin's data would be useful for example if one wanted to control a 6 DOF / 6 servo robotic arm with 6 potentiometer outputs. The Serial Wombat chip could filter user inputs to provide smooth movement as well as scale the outputs so that the full range of potentiometer travel can be mapped to each joint's range of servo motion in degrees. The Arduino or other host could monitor the controls and poentially intervene if higher level logic deemed it necessary, but would be freed of the need to constantly poll the pots and update servo pulse values.
The Scaled Output block can also do simple real-time control of an output based on an input. For instance, a heater could be set to pwm at some duty cycle if an analog input dropped below a threshold, then shut off when it rose above some other higher threshold. This is hystersis mode.
Another control method is Proportial/Integral/Derivative (PID) control. In this mode the host provides P I and D calibrations for the system, and specifies an input pin and target value. The output of the Scaled Output block is then controlled via PID to try and reach the target value. As an example, a motor's encoder output could be attached to a SerialWombatPulseInput pin configured to output the frequency of incoming pulses. The PID controller in the Scaled Output block could then vary the PWM driving a FET controlling the motor to keep the motor running at constant speed that adapts to changing motor load or source voltage. The PID controller requires that a postive output cause a positive input from the feedback system. If they are opposite then the invert function of the block can be used.
Scaling operations happen in the following sequence:
Definition at line 62 of file SerialWombatAbstractScaledOutput.h.
Enumerator | |
---|---|
PERIOD_1mS | |
PERIOD_2mS | |
PERIOD_4mS | |
PERIOD_8mS | |
PERIOD_16mS | |
PERIOD_32mS | |
PERIOD_64mS | |
PERIOD_128mS | |
PERIOD_256mS | |
PERIOD_512mS | |
PERIOD_1024mS |
Definition at line 72 of file SerialWombatAbstractScaledOutput.h.
Enumerator | |
---|---|
RAMP_MODE_BOTH | |
RAMP_MODE_INCREMENT | |
RAMP_MODE_DECREMENT |
Definition at line 86 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Constructor for the SerialWombatAbstractScaledOutput Class.
sw | A reference to a previously declared SerialWombatPin to which the output is connected. |
Definition at line 70 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Set Up 2D Lookup Output Scaling.
Configure 2d Lookup scaling based on an array of 16 bit unsigned numbers in user memory at index IndexInUserMemory . The first entry must be 0x0000 0xYYYY where YYYY is the output when 0x0000 is the input. The final entry must be 0xFFFF 0xZZZZ where ZZZZ is the output when 0xFFFF is the input. Any number of additional point pairs can come between 0x0000 and 0xFFFF. Point pairs must be in assending order by input.
IndexInUserMemory | Index in user memory where 2d lookup table is located |
Definition at line 686 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Definition at line 626 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Definition at line 643 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Definition at line 557 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Definition at line 575 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Definition at line 592 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Definition at line 609 of file SerialWombatAbstractScaledOutput.h.
|
pure virtual |
Facilitates inheritance.
Implemented in SerialWombatFrequencyOutput_18AB, SerialWombatHBridge_18AB, SerialWombatPWM_18AB, and SerialWombatServo_18AB.
|
inline |
Request Last Output Value.
This function is useful to see intermediate output values when the scaled output is using its same pin's public data for input (so the output value is not written back to public data)
Definition at line 527 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Definition at line 660 of file SerialWombatAbstractScaledOutput.h.
|
pure virtual |
Facilitates inheritance.
Implemented in SerialWombatFrequencyOutput_18AB, SerialWombatHBridge_18AB, SerialWombatPWM_18AB, and SerialWombatServo_18AB.
|
inline |
\begin Controls how fast an ouput can change based on filtering
This function allows configuration of how fast an output's value is allowed to change based on a first order filter. The Rate control runs on a fixed period based on the Period enumerated type. Every samplePeriod ms the target is reevaluated. The requested output is combined with the current output using filterConstant. Higher values for filterConstant cause heavier filtering
samplePeriod | How often the output is updated (enumerated type) |
filterConstant | A value from 0 to 65535 indicating the amount of filtering. Higher is more filtering. |
Definition at line 294 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Controls the output based on hystersis control.
Calling this function places the output in hysteresis mode. In this mode the input source is monitored and compared against a high and low threshold. If the input source is equal or greater to highLimit then the output becomes highOutputValue. If it is equal or less than lowLimit then lowOutputValue is output.
If the input source is between lowLimit and highLimit then no change occurs.
lowLimit | If the input source is at or below this level the output value is lowOutputValue |
lowOutputValue | if the input source is at or below lowLimit then this value becomes the output |
highLimit | if the input source is at or above this level then the output value is highOutputValue |
highOutputValue | if the input source is at or above highLimit then this value becomes the output |
initialOutputValue | if the input source is between lowLimit and highLimit at initialization then this value is output |
Definition at line 336 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Scale incoming values to a range of 0 to 65535.
This function allows configuration of an input scaling range that maps to 0-65535.
For example, if another pin or public data returns a range from 2000 to 5000, setting the minimum to 2000 and maximum to 5000 will cause values below 2000 to be 0, values above 5000 to be 65535, and values in between will be scaled accordingly. This allows a sensor or other input device to scale to the Serial Wombat philosophy of using a 16 bit resolution number to represent the the possible range of values
min | The minimum value of the input range. Input values less than or equal to that will be scaled to 0 |
max | The maximum value of the input range. Input values greater or equal to that will be scaled to 65535 |
Definition at line 159 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Reduces the output range from 0 to 65535 to user specified range.
This functionn is useful for scaling the 0 to 65535 full range to a specific output range to correspond to the desired output range of the actual physical output.
For instance, if a 180 degree servo needed to move through its center 90 degrees (45 degrees dead band, 90 degrees of movement, and 45 degrees of dead band) then minimum and maximum values of 16384 and 49152 could be used.
outputMin | The value to which a calculated output of 0 will map |
outputMax | The value to which a calculated output of 65535 will map |
Definition at line 186 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Configure the scaled output block into PID control mode.
This pin mode implements Propotional / Integral / Derivative (PID) control. It attempts to drive the input to a target value based on calibration constants provided by the host.
For a discussion of PID control in general, this link is suggested: https://www.ni.com/en-us/innovations/white-papers/06/pid-theory-explained.html
This block implements PID using the diagram shown in this link where the kP term is applied after the sum of the error, 1/ki * integration and kd * derivative sum. This is different from the order used in some PID algorithms. The net effect is the same but the values of the ki and kd are different than if the constants were all applied first and the sum taken afterwards. This was done to best distribute values so that calculations could be done using integral math rather than floating point due to the performance cost of floating point on small microcontrollers.
Note that kp, ki and kd are unsigned integers. For this reason it is necessary that an increase in controller output creates a positive change in the measurement of the plant. The writeScalingInvertedInput function can be used to invert the input if the system reacts negatively to a an increase in output.
See the pid() function in the Serial Wombat 18AB firmware to see exactly how the math is implemented: https://github.com/BroadwellConsultingInc/SerialWombat/blob/main/SerialWombat18A_18B/SerialWombat18A_18B.X/outputScale.c
kp | The proportional constant applied to the sum of the error, 1/ki * error sum, and kd * derivative. Scaled to 1/256ths . |
ki | The integral constant applied to the integral. Scaled to 1/16384ths, as typically you want this value to be less than 1.0 |
kd | The derivative contant applied to the derivative. This value is scaled to 1/16384. |
target | The value the output will attempt to control the input to |
samplePeriod | an enumerated time for how often the PID controller updates. This value should be based on how fast the system responds to change in output so that integral and derivative terms work correctly. |
Definition at line 462 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Configure the scaled output block into Ramp control mode.
Configure the scaled output block into Ramp control mode
This pin mode allows this pin's output to be incremented or decremented to chase an input.
It is useful for cases where the transfer function of the system is not predictable, such as a servo robot gripper with current feedback that needs to grip object of different sizes and densities.
The system increments a fast increment to get within a range of the input, then switches to slow increment to fine tune. The system can be set to increment and decrement to chase a value (BOTH), increment only, or decrement only.
slowIncrement | The value added to the output each sample period if the difference between input and target is less than incrementThreshold |
incrementThreshold | The difference between input and target below which slowIncrement should be used |
fastIncrement | The value added to the output each sample period if the difference between input and target is greater than incrementThreshold |
rampMode | The derivative contant applied to the derivative. This value is scaled to 1/16384. |
samplePeriod | an enumerated time for how often the PID controller updates. This value should be based on how fast the system responds to change in output so that integral and derivative terms work correctly. |
Definition at line 392 of file SerialWombatAbstractScaledOutput.h.
|
inline |
\begin Controls how fast an ouput can change in counts
This function allows configuration of how fast an output's value is allowed to change in counts on a 0-65535 scale. The Rate control runs on a fixed period based on the Period enumerated type. Every samplePeriod ms the target is reevaluated. If the expected output would change the output by more than maximumChangecounts, then the output only changes by maximumChangecounts
samplePeriod | How often the output is updated (enumerated type) |
maximumChangecounts | The maximum number of counts of change allowed over samplePeriod |
Definition at line 253 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Enable scaling and set which pin or public data is used as the input source.
This function should be called after all other desired configuration functions have been called.
enabled | Enables the Scaled Output block. If false then the current pin's public data value is used as the setting for the output |
sourcePin | The pin or public data id that should be read to drive the output value. Only used when enabled is set to true |
Definition at line 133 of file SerialWombatAbstractScaledOutput.h.
|
inline |
if enabled subtract the input value from 65535 before doing any other processing.
inverted | False - input value isn't changed. True- input value is subtracted from 65535 |
Definition at line 205 of file SerialWombatAbstractScaledOutput.h.
|
inline |
The target input value for PID control.
When configured to drive the output value via PID control the target value is the desired value for the input to reach based on modification of the output value. For example, in a system where an analog temperatue sensor was influnced by a heater attached to a PWM output, the input would be the actual temperature, the target would be the desired temperature, and the output would be the PWM driving the heater.
target | The 16 bit value the system will attempt to achieve by varying the output |
Definition at line 229 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Definition at line 547 of file SerialWombatAbstractScaledOutput.h.
|
inline |
Enable a timeout value which will cause the output to go to a default value if not updated.
When this function is called with a timeout value longer than 0 mS the timer becomes enabled. Internally a counter is set to 0 and increments each 1ms. If the counter reaches the timeout value then the output is set to timeoutOutputValue. Calling writeTimeout again resets the counter to 0, so it is intended to be called periodicallly to ensure that the timeout never occurs under normal circumstances. It can also be used to generate timed output which is active for some period of time then reverts to timeoutOutputValue . The length of this pulse may vary by a few hundred microseconds because it is done in software, not hardware.
timeout_mS | How long in mS before the timeout occurs. Set to zero to disable the timeout |
timeoutOutputValue | The 16 bit value that should be output if a timeout occurs |
Definition at line 108 of file SerialWombatAbstractScaledOutput.h.