WPILibC++ 2024.3.2
|
Class for counting the number of ticks on a digital input channel. More...
#include <frc/Counter.h>
Public Types | |
enum | Mode { kTwoPulse = 0 , kSemiperiod = 1 , kPulseLength = 2 , kExternalDirection = 3 } |
Public Types inherited from frc::CounterBase | |
enum | EncodingType { k1X , k2X , k4X } |
Public Member Functions | |
Counter (Mode mode=kTwoPulse) | |
Create an instance of a counter where no sources are selected. More... | |
Counter (int channel) | |
Create an instance of a Counter object. More... | |
Counter (DigitalSource *source) | |
Create an instance of a counter from a Digital Source (such as a Digital Input). More... | |
Counter (std::shared_ptr< DigitalSource > source) | |
Create an instance of a counter from a Digital Source (such as a Digital Input). More... | |
Counter (const AnalogTrigger &trigger) | |
Create an instance of a Counter object. More... | |
Counter (EncodingType encodingType, DigitalSource *upSource, DigitalSource *downSource, bool inverted) | |
Create an instance of a Counter object. More... | |
Counter (EncodingType encodingType, std::shared_ptr< DigitalSource > upSource, std::shared_ptr< DigitalSource > downSource, bool inverted) | |
Create an instance of a Counter object. More... | |
~Counter () override | |
Counter (Counter &&)=default | |
Counter & | operator= (Counter &&)=default |
void | SetUpSource (int channel) |
Set the upsource for the counter as a digital input channel. More... | |
void | SetUpSource (AnalogTrigger *analogTrigger, AnalogTriggerType triggerType) |
Set the up counting source to be an analog trigger. More... | |
void | SetUpSource (std::shared_ptr< AnalogTrigger > analogTrigger, AnalogTriggerType triggerType) |
Set the up counting source to be an analog trigger. More... | |
void | SetUpSource (DigitalSource *source) |
void | SetUpSource (std::shared_ptr< DigitalSource > source) |
Set the source object that causes the counter to count up. More... | |
void | SetUpSource (DigitalSource &source) |
Set the source object that causes the counter to count up. More... | |
void | SetUpSourceEdge (bool risingEdge, bool fallingEdge) |
Set the edge sensitivity on an up counting source. More... | |
void | ClearUpSource () |
Disable the up counting source to the counter. More... | |
void | SetDownSource (int channel) |
Set the down counting source to be a digital input channel. More... | |
void | SetDownSource (AnalogTrigger *analogTrigger, AnalogTriggerType triggerType) |
Set the down counting source to be an analog trigger. More... | |
void | SetDownSource (std::shared_ptr< AnalogTrigger > analogTrigger, AnalogTriggerType triggerType) |
Set the down counting source to be an analog trigger. More... | |
void | SetDownSource (DigitalSource *source) |
Set the source object that causes the counter to count down. More... | |
void | SetDownSource (DigitalSource &source) |
Set the source object that causes the counter to count down. More... | |
void | SetDownSource (std::shared_ptr< DigitalSource > source) |
void | SetDownSourceEdge (bool risingEdge, bool fallingEdge) |
Set the edge sensitivity on a down counting source. More... | |
void | ClearDownSource () |
Disable the down counting source to the counter. More... | |
void | SetUpDownCounterMode () |
Set standard up / down counting mode on this counter. More... | |
void | SetExternalDirectionMode () |
Set external direction mode on this counter. More... | |
void | SetSemiPeriodMode (bool highSemiPeriod) |
Set Semi-period mode on this counter. More... | |
void | SetPulseLengthMode (double threshold) |
Configure the counter to count in up or down based on the length of the input pulse. More... | |
void | SetReverseDirection (bool reverseDirection) |
Set the Counter to return reversed sensing on the direction. More... | |
void | SetSamplesToAverage (int samplesToAverage) |
Set the Samples to Average which specifies the number of samples of the timer to average when calculating the period. More... | |
int | GetSamplesToAverage () const |
Get the Samples to Average which specifies the number of samples of the timer to average when calculating the period. More... | |
int | GetFPGAIndex () const |
void | SetDistancePerPulse (double distancePerPulse) |
Set the distance per pulse for this counter. More... | |
double | GetDistance () const |
Read the current scaled counter value. More... | |
double | GetRate () const |
Get the current rate of the Counter. More... | |
int | Get () const override |
Read the current counter value. More... | |
void | Reset () override |
Reset the Counter to zero. More... | |
units::second_t | GetPeriod () const override |
Get the Period of the most recent count. More... | |
void | SetMaxPeriod (units::second_t maxPeriod) final |
Set the maximum period where the device is still considered "moving". More... | |
void | SetUpdateWhenEmpty (bool enabled) |
Select whether you want to continue updating the event timer output when there are no samples captured. More... | |
bool | GetStopped () const override |
Determine if the clock is stopped. More... | |
bool | GetDirection () const override |
The last direction the counter value changed. More... | |
void | InitSendable (wpi::SendableBuilder &builder) override |
Initializes this Sendable object. More... | |
Public Member Functions inherited from frc::CounterBase | |
CounterBase ()=default | |
virtual | ~CounterBase ()=default |
CounterBase (CounterBase &&)=default | |
CounterBase & | operator= (CounterBase &&)=default |
virtual int | Get () const =0 |
virtual void | Reset ()=0 |
virtual units::second_t | GetPeriod () const =0 |
virtual void | SetMaxPeriod (units::second_t maxPeriod)=0 |
virtual bool | GetStopped () const =0 |
virtual bool | GetDirection () const =0 |
Public Member Functions inherited from wpi::Sendable | |
virtual | ~Sendable ()=default |
virtual void | InitSendable (SendableBuilder &builder)=0 |
Initializes this Sendable object. More... | |
Public Member Functions inherited from wpi::SendableHelper< Counter > | |
SendableHelper (const SendableHelper &rhs)=default | |
SendableHelper (SendableHelper &&rhs) | |
SendableHelper & | operator= (const SendableHelper &rhs)=default |
SendableHelper & | operator= (SendableHelper &&rhs) |
Protected Attributes | |
std::shared_ptr< DigitalSource > | m_upSource |
Makes the counter count up. More... | |
std::shared_ptr< DigitalSource > | m_downSource |
Makes the counter count down. More... | |
hal::Handle< HAL_CounterHandle > | m_counter |
The FPGA counter object. More... | |
Friends | |
class | DMA |
class | DMASample |
class | DigitalGlitchFilter |
Additional Inherited Members | |
Protected Member Functions inherited from wpi::SendableHelper< Counter > | |
SendableHelper ()=default | |
~SendableHelper () | |
Class for counting the number of ticks on a digital input channel.
This is a general purpose class for counting repetitive events. It can return the number of counts, the period of the most recent cycle, and detect when the signal being counted has stopped by supplying a maximum cycle time.
All counters will immediately start counting - Reset() them if you need them to be zeroed before use.
enum frc::Counter::Mode |
Create an instance of a counter where no sources are selected.
They all must be selected by calling functions to specify the upsource and the downsource independently.
This creates a ChipObject counter and initializes status variables appropriately.
The counter will start counting immediately.
mode | The counter mode |
|
explicit |
Create an instance of a Counter object.
Create an up-Counter instance given a channel.
The counter will start counting immediately.
channel | The DIO channel to use as the up source. 0-9 are on-board, 10-25 are on the MXP |
|
explicit |
Create an instance of a counter from a Digital Source (such as a Digital Input).
This is used if an existing digital input is to be shared by multiple other objects such as encoders or if the Digital Source is not a Digital Input channel (such as an Analog Trigger).
The counter will start counting immediately.
source | A pointer to the existing DigitalSource object. It will be set as the Up Source. |
|
explicit |
Create an instance of a counter from a Digital Source (such as a Digital Input).
This is used if an existing digital input is to be shared by multiple other objects such as encoders or if the Digital Source is not a Digital Input channel (such as an Analog Trigger).
The counter will start counting immediately.
source | A pointer to the existing DigitalSource object. It will be set as the Up Source. |
|
explicit |
Create an instance of a Counter object.
Create an instance of a simple up-Counter given an analog trigger. Use the trigger state output from the analog trigger.
The counter will start counting immediately.
trigger | The reference to the existing AnalogTrigger object. |
frc::Counter::Counter | ( | EncodingType | encodingType, |
DigitalSource * | upSource, | ||
DigitalSource * | downSource, | ||
bool | inverted | ||
) |
Create an instance of a Counter object.
Creates a full up-down counter given two Digital Sources.
encodingType | The quadrature decoding mode (1x or 2x) |
upSource | The pointer to the DigitalSource to set as the up source |
downSource | The pointer to the DigitalSource to set as the down source |
inverted | True to invert the output (reverse the direction) |
frc::Counter::Counter | ( | EncodingType | encodingType, |
std::shared_ptr< DigitalSource > | upSource, | ||
std::shared_ptr< DigitalSource > | downSource, | ||
bool | inverted | ||
) |
Create an instance of a Counter object.
Creates a full up-down counter given two Digital Sources.
encodingType | The quadrature decoding mode (1x or 2x) |
upSource | The pointer to the DigitalSource to set as the up source |
downSource | The pointer to the DigitalSource to set as the down source |
inverted | True to invert the output (reverse the direction) |
|
override |
|
default |
void frc::Counter::ClearDownSource | ( | ) |
Disable the down counting source to the counter.
void frc::Counter::ClearUpSource | ( | ) |
Disable the up counting source to the counter.
|
overridevirtual |
Read the current counter value.
Read the value at this instant. It may still be running, so it reflects the current value. Next time it is read, it might have a different value.
Implements frc::CounterBase.
|
overridevirtual |
The last direction the counter value changed.
Implements frc::CounterBase.
double frc::Counter::GetDistance | ( | ) | const |
Read the current scaled counter value.
Read the value at this instant, scaled by the distance per pulse (defaults to 1).
int frc::Counter::GetFPGAIndex | ( | ) | const |
|
overridevirtual |
Get the Period of the most recent count.
Returns the time interval of the most recent count. This can be used for velocity calculations to determine shaft speed.
Implements frc::CounterBase.
double frc::Counter::GetRate | ( | ) | const |
Get the current rate of the Counter.
Read the current rate of the counter accounting for the distance per pulse value. The default value for distance per pulse (1) yields units of pulses per second.
int frc::Counter::GetSamplesToAverage | ( | ) | const |
Get the Samples to Average which specifies the number of samples of the timer to average when calculating the period.
Perform averaging to account for mechanical imperfections or as oversampling to increase resolution.
|
overridevirtual |
Determine if the clock is stopped.
Determine if the clocked input is stopped based on the MaxPeriod value set using the SetMaxPeriod method. If the clock exceeds the MaxPeriod, then the device (and counter) are assumed to be stopped and it returns true.
Implements frc::CounterBase.
|
overridevirtual |
|
overridevirtual |
Reset the Counter to zero.
Set the counter value to zero. This doesn't effect the running state of the counter, just sets the current value to zero.
Implements frc::CounterBase.
void frc::Counter::SetDistancePerPulse | ( | double | distancePerPulse | ) |
Set the distance per pulse for this counter.
This sets the multiplier used to determine the distance driven based on the count value from the encoder. Set this value based on the Pulses per Revolution and factor in any gearing reductions. This distance can be in any units you like, linear or angular.
distancePerPulse | The scale factor that will be used to convert pulses to useful units. |
void frc::Counter::SetDownSource | ( | AnalogTrigger * | analogTrigger, |
AnalogTriggerType | triggerType | ||
) |
Set the down counting source to be an analog trigger.
analogTrigger | The analog trigger object that is used for the Down Source |
triggerType | The analog trigger output that will trigger the counter. |
void frc::Counter::SetDownSource | ( | DigitalSource & | source | ) |
Set the source object that causes the counter to count down.
Set the down counting DigitalSource.
source | Reference to the DigitalSource object to set as the down source |
void frc::Counter::SetDownSource | ( | DigitalSource * | source | ) |
Set the source object that causes the counter to count down.
Set the down counting DigitalSource.
source | Pointer to the DigitalSource object to set as the down source |
void frc::Counter::SetDownSource | ( | int | channel | ) |
Set the down counting source to be a digital input channel.
channel | The DIO channel to use as the up source. 0-9 are on-board, 10-25 are on the MXP |
void frc::Counter::SetDownSource | ( | std::shared_ptr< AnalogTrigger > | analogTrigger, |
AnalogTriggerType | triggerType | ||
) |
Set the down counting source to be an analog trigger.
analogTrigger | The analog trigger object that is used for the Down Source |
triggerType | The analog trigger output that will trigger the counter. |
void frc::Counter::SetDownSource | ( | std::shared_ptr< DigitalSource > | source | ) |
void frc::Counter::SetDownSourceEdge | ( | bool | risingEdge, |
bool | fallingEdge | ||
) |
Set the edge sensitivity on a down counting source.
Set the down source to either detect rising edges or falling edges.
risingEdge | True to trigger on rising edges |
fallingEdge | True to trigger on falling edges |
void frc::Counter::SetExternalDirectionMode | ( | ) |
Set external direction mode on this counter.
Counts are sourced on the Up counter input. The Down counter input represents the direction to count.
|
finalvirtual |
Set the maximum period where the device is still considered "moving".
Sets the maximum period where the device is considered moving. This value is used to determine the "stopped" state of the counter using the GetStopped method.
maxPeriod | The maximum period where the counted device is considered moving in seconds. |
Implements frc::CounterBase.
void frc::Counter::SetPulseLengthMode | ( | double | threshold | ) |
Configure the counter to count in up or down based on the length of the input pulse.
This mode is most useful for direction sensitive gear tooth sensors.
threshold | The pulse length beyond which the counter counts the opposite direction. Units are seconds. |
void frc::Counter::SetReverseDirection | ( | bool | reverseDirection | ) |
Set the Counter to return reversed sensing on the direction.
This allows counters to change the direction they are counting in the case of 1X and 2X quadrature encoding only. Any other counter mode isn't supported.
reverseDirection | true if the value counted should be negated. |
void frc::Counter::SetSamplesToAverage | ( | int | samplesToAverage | ) |
Set the Samples to Average which specifies the number of samples of the timer to average when calculating the period.
Perform averaging to account for mechanical imperfections or as oversampling to increase resolution.
samplesToAverage | The number of samples to average from 1 to 127. |
void frc::Counter::SetSemiPeriodMode | ( | bool | highSemiPeriod | ) |
Set Semi-period mode on this counter.
Counts up on both rising and falling edges.
void frc::Counter::SetUpdateWhenEmpty | ( | bool | enabled | ) |
Select whether you want to continue updating the event timer output when there are no samples captured.
The output of the event timer has a buffer of periods that are averaged and posted to a register on the FPGA. When the timer detects that the event source has stopped (based on the MaxPeriod) the buffer of samples to be averaged is emptied. If you enable the update when empty, you will be notified of the stopped source and the event time will report 0 samples. If you disable update when empty, the most recent average will remain on the output until a new sample is acquired. You will never see 0 samples output (except when there have been no events since an FPGA reset) and you will likely not see the stopped bit become true (since it is updated at the end of an average and there are no samples to average).
enabled | True to enable update when empty |
void frc::Counter::SetUpDownCounterMode | ( | ) |
Set standard up / down counting mode on this counter.
Up and down counts are sourced independently from two inputs.
void frc::Counter::SetUpSource | ( | AnalogTrigger * | analogTrigger, |
AnalogTriggerType | triggerType | ||
) |
Set the up counting source to be an analog trigger.
analogTrigger | The analog trigger object that is used for the Up Source |
triggerType | The analog trigger output that will trigger the counter. |
void frc::Counter::SetUpSource | ( | DigitalSource & | source | ) |
Set the source object that causes the counter to count up.
Set the up counting DigitalSource.
source | Reference to the DigitalSource object to set as the up source |
void frc::Counter::SetUpSource | ( | DigitalSource * | source | ) |
void frc::Counter::SetUpSource | ( | int | channel | ) |
Set the upsource for the counter as a digital input channel.
channel | The DIO channel to use as the up source. 0-9 are on-board, 10-25 are on the MXP |
void frc::Counter::SetUpSource | ( | std::shared_ptr< AnalogTrigger > | analogTrigger, |
AnalogTriggerType | triggerType | ||
) |
Set the up counting source to be an analog trigger.
analogTrigger | The analog trigger object that is used for the Up Source |
triggerType | The analog trigger output that will trigger the counter. |
void frc::Counter::SetUpSource | ( | std::shared_ptr< DigitalSource > | source | ) |
Set the source object that causes the counter to count up.
Set the up counting DigitalSource.
source | Pointer to the DigitalSource object to set as the up source |
void frc::Counter::SetUpSourceEdge | ( | bool | risingEdge, |
bool | fallingEdge | ||
) |
Set the edge sensitivity on an up counting source.
Set the up source to either detect rising edges or falling edges or both.
risingEdge | True to trigger on rising edges |
fallingEdge | True to trigger on falling edges |
|
friend |
|
friend |
|
friend |
|
protected |
The FPGA counter object.
|
protected |
Makes the counter count down.
|
protected |
Makes the counter count up.