Serial Wombat Arduino Library
Loading...
Searching...
No Matches
SerialWombatAbstractScaledOutput Class Referenceabstract

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>

Inheritance diagram for SerialWombatAbstractScaledOutput:

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.
 

Detailed Description

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:

  • Read the source pin's or data source's public data (Note that the Host can also provide the input value by setting the source pin to the output pin and writing that pin's public data. In this case the output value of the pin will not be written to the pin's public data)
  • Scale the inputs from a specified Min/Max range to 0 to 65535
  • Invert if configured by subtracting the scaled value from 65535
  • Pass the input value to the specified control algorithm (PID, Hysteresis or PassThrough) to determine the output value
  • Check to see if a communication timeout has occurred if configured. If so, substitute the default output value
  • Perform output filtering if configured to smooth transitions in the output value
  • Scale the output value from 0-65535 to some other range if configured. This is useful for example if a servo is physically limited to a portion of its normal rotation.
  • Write the output data to the output pin's publc data (unless the pin is configured to use its own public data as an input source)
  • Write the output data to the underlying pin mode (Servo, PWM, etc) so that the physical output is updated

Definition at line 62 of file SerialWombatAbstractScaledOutput.h.

Member Enumeration Documentation

◆ Period

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.

◆ RampMode

Enumerator
RAMP_MODE_BOTH 
RAMP_MODE_INCREMENT 
RAMP_MODE_DECREMENT 

Definition at line 86 of file SerialWombatAbstractScaledOutput.h.

Constructor & Destructor Documentation

◆ SerialWombatAbstractScaledOutput()

SerialWombatAbstractScaledOutput::SerialWombatAbstractScaledOutput ( SerialWombatChip & sw)
inline

Constructor for the SerialWombatAbstractScaledOutput Class.

Parameters
swA reference to a previously declared SerialWombatPin to which the output is connected.

Definition at line 70 of file SerialWombatAbstractScaledOutput.h.

Member Function Documentation

◆ Enable2DLookupOutputScaling()

int16_t SerialWombatAbstractScaledOutput::Enable2DLookupOutputScaling ( uint16_t IndexInUserMemory)
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.

Returns
Returns a negative error code if configuration generated an error.
Parameters
IndexInUserMemoryIndex in user memory where 2d lookup table is located

Definition at line 686 of file SerialWombatAbstractScaledOutput.h.

◆ PIDGetLastDerivativeEffort()

int32_t SerialWombatAbstractScaledOutput::PIDGetLastDerivativeEffort ( )
inline

Definition at line 626 of file SerialWombatAbstractScaledOutput.h.

◆ PIDGetLastEffort()

int32_t SerialWombatAbstractScaledOutput::PIDGetLastEffort ( )
inline

Definition at line 643 of file SerialWombatAbstractScaledOutput.h.

◆ PIDGetLastError()

int32_t SerialWombatAbstractScaledOutput::PIDGetLastError ( )
inline

Definition at line 557 of file SerialWombatAbstractScaledOutput.h.

◆ PIDGetLastIntegrator()

int32_t SerialWombatAbstractScaledOutput::PIDGetLastIntegrator ( )
inline

Definition at line 575 of file SerialWombatAbstractScaledOutput.h.

◆ PIDGetLastIntegratorEffort()

int32_t SerialWombatAbstractScaledOutput::PIDGetLastIntegratorEffort ( )
inline

Definition at line 592 of file SerialWombatAbstractScaledOutput.h.

◆ PIDGetLastProportionalEffort()

int32_t SerialWombatAbstractScaledOutput::PIDGetLastProportionalEffort ( )
inline

Definition at line 609 of file SerialWombatAbstractScaledOutput.h.

◆ pin()

virtual uint8_t SerialWombatAbstractScaledOutput::pin ( )
pure virtual

◆ readLastOutputValue()

uint16_t SerialWombatAbstractScaledOutput::readLastOutputValue ( )
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)

Returns
Last 16 bit value output to hardware

Definition at line 527 of file SerialWombatAbstractScaledOutput.h.

◆ ReadLastTarget()

uint16_t SerialWombatAbstractScaledOutput::ReadLastTarget ( )
inline

Definition at line 660 of file SerialWombatAbstractScaledOutput.h.

◆ swPinModeNumber()

virtual uint8_t SerialWombatAbstractScaledOutput::swPinModeNumber ( )
pure virtual

◆ write1stOrderFiltering()

int16_t SerialWombatAbstractScaledOutput::write1stOrderFiltering ( Period sampleRate,
uint16_t filterConstant )
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

Parameters
samplePeriodHow often the output is updated (enumerated type)
filterConstantA value from 0 to 65535 indicating the amount of filtering. Higher is more filtering.
Returns
returns 0 or higher if success, or a negative error code

Definition at line 294 of file SerialWombatAbstractScaledOutput.h.

◆ writeHysteresis()

int16_t SerialWombatAbstractScaledOutput::writeHysteresis ( uint16_t lowLimit,
uint16_t lowOutputValue,
uint16_t highLimit,
uint16_t highOutputValue,
uint16_t initialOutputValue )
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.

Parameters
lowLimitIf the input source is at or below this level the output value is lowOutputValue
lowOutputValueif the input source is at or below lowLimit then this value becomes the output
highLimitif the input source is at or above this level then the output value is highOutputValue
highOutputValueif the input source is at or above highLimit then this value becomes the output
initialOutputValueif the input source is between lowLimit and highLimit at initialization then this value is output
Returns
returns 0 or higher if success, or a negative error code

Definition at line 336 of file SerialWombatAbstractScaledOutput.h.

◆ writeInputScaling()

int16_t SerialWombatAbstractScaledOutput::writeInputScaling ( uint16_t inputMin,
uint16_t inputMax )
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

Parameters
minThe minimum value of the input range. Input values less than or equal to that will be scaled to 0
maxThe maximum value of the input range. Input values greater or equal to that will be scaled to 65535
Returns
returns 0 or higher if success, or a negative error code

Definition at line 159 of file SerialWombatAbstractScaledOutput.h.

◆ writeOutputScaling()

int16_t SerialWombatAbstractScaledOutput::writeOutputScaling ( uint16_t outputMin,
uint16_t outputMax )
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.

Parameters
outputMinThe value to which a calculated output of 0 will map
outputMaxThe value to which a calculated output of 65535 will map
Returns
returns 0 or higher if success, or a negative error code

Definition at line 186 of file SerialWombatAbstractScaledOutput.h.

◆ writePID()

int16_t SerialWombatAbstractScaledOutput::writePID ( uint16_t kp,
uint16_t ki,
uint16_t kd,
uint16_t target,
Period samplePeriod,
uint8_t targetPin = 255,
bool biDirectional = false )
inline

Configure the scaled output block into PID control mode.

Returns
returns 0 or higher if success, or a negative error code

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

Parameters
kpThe proportional constant applied to the sum of the error, 1/ki * error sum, and kd * derivative. Scaled to 1/256ths .
kiThe integral constant applied to the integral. Scaled to 1/16384ths, as typically you want this value to be less than 1.0
kdThe derivative contant applied to the derivative. This value is scaled to 1/16384.
targetThe value the output will attempt to control the input to
samplePeriodan 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.
Returns
returns 0 or higher if success, or a negative error code

Definition at line 462 of file SerialWombatAbstractScaledOutput.h.

◆ writeRamp()

int16_t SerialWombatAbstractScaledOutput::writeRamp ( uint16_t slowIncrement,
uint16_t incrementThreshold,
uint16_t fastIncrement,
Period samplePeriod,
RampMode rampMode )
inline

Configure the scaled output block into Ramp control mode.

Returns
returns 0 or higher if success, or a negative error code

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.

Parameters
slowIncrementThe value added to the output each sample period if the difference between input and target is less than incrementThreshold
incrementThresholdThe difference between input and target below which slowIncrement should be used
fastIncrementThe value added to the output each sample period if the difference between input and target is greater than incrementThreshold
rampModeThe derivative contant applied to the derivative. This value is scaled to 1/16384.
samplePeriodan 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.
Returns
returns 0 or higher if success, or a negative error code

Definition at line 392 of file SerialWombatAbstractScaledOutput.h.

◆ writeRateControl()

int16_t SerialWombatAbstractScaledOutput::writeRateControl ( Period samplePeriod,
uint16_t maximumChangecounts )
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

Parameters
samplePeriodHow often the output is updated (enumerated type)
maximumChangecountsThe maximum number of counts of change allowed over samplePeriod
Returns
returns 0 or higher if success, or a negative error code

Definition at line 253 of file SerialWombatAbstractScaledOutput.h.

◆ writeScalingEnabled()

int16_t SerialWombatAbstractScaledOutput::writeScalingEnabled ( bool enabled,
uint8_t sourcePin )
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.

Parameters
enabledEnables the Scaled Output block. If false then the current pin's public data value is used as the setting for the output
sourcePinThe 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.

◆ writeScalingInvertedInput()

int16_t SerialWombatAbstractScaledOutput::writeScalingInvertedInput ( bool inverted)
inline

if enabled subtract the input value from 65535 before doing any other processing.

Parameters
invertedFalse - input value isn't changed. True- input value is subtracted from 65535
Returns
returns 0 or higher if success, or a negative error code

Definition at line 205 of file SerialWombatAbstractScaledOutput.h.

◆ writeScalingTargetValue()

int16_t SerialWombatAbstractScaledOutput::writeScalingTargetValue ( uint16_t target)
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.

Parameters
targetThe 16 bit value the system will attempt to achieve by varying the output
Returns
returns 0 or higher if success, or a negative error code

Definition at line 229 of file SerialWombatAbstractScaledOutput.h.

◆ writeScalingTargetValueResetIntegrator()

int16_t SerialWombatAbstractScaledOutput::writeScalingTargetValueResetIntegrator ( uint16_t target)
inline

Definition at line 547 of file SerialWombatAbstractScaledOutput.h.

◆ writeTimeout()

int16_t SerialWombatAbstractScaledOutput::writeTimeout ( uint16_t timeout_mS,
uint16_t timeoutOutputValue )
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.

Parameters
timeout_mSHow long in mS before the timeout occurs. Set to zero to disable the timeout
timeoutOutputValueThe 16 bit value that should be output if a timeout occurs
Returns
returns 0 or higher if success, or a negative error code

Definition at line 108 of file SerialWombatAbstractScaledOutput.h.