jerrym | f157933 | 2013-02-07 01:56:28 +0000 | [diff] [blame] | 1 | /*----------------------------------------------------------------------------*/
|
| 2 | /* Copyright (c) FIRST 2008. All Rights Reserved. */
|
| 3 | /* Open Source Software - may be modified and shared by FRC teams. The code */
|
| 4 | /* must be accompanied by the FIRST BSD license file in $(WIND_BASE)/WPILib. */
|
| 5 | /*----------------------------------------------------------------------------*/
|
| 6 |
|
| 7 | #ifndef ANALOG_TRIGGER_OUTPUT_H_
|
| 8 | #define ANALOG_TRIGGER_OUTPUT_H_
|
| 9 |
|
| 10 | #include "DigitalSource.h"
|
| 11 |
|
| 12 | class AnalogTrigger;
|
| 13 |
|
| 14 | /**
|
| 15 | * Class to represent a specific output from an analog trigger.
|
| 16 | * This class is used to get the current output value and also as a DigitalSource
|
| 17 | * to provide routing of an output to digital subsystems on the FPGA such as
|
| 18 | * Counter, Encoder, and Interrupt.
|
| 19 | *
|
| 20 | * The TriggerState output indicates the primary output value of the trigger. If the analog
|
| 21 | * signal is less than the lower limit, the output is false. If the analog value is greater
|
| 22 | * than the upper limit, then the output is true. If the analog value is in between, then
|
| 23 | * the trigger output state maintains its most recent value.
|
| 24 | *
|
| 25 | * The InWindow output indicates whether or not the analog signal is inside the range defined
|
| 26 | * by the limits.
|
| 27 | *
|
| 28 | * The RisingPulse and FallingPulse outputs detect an instantaneous transition from above the
|
| 29 | * upper limit to below the lower limit, and vise versa. These pulses represent a rollover
|
| 30 | * condition of a sensor and can be routed to an up / down couter or to interrupts. Because
|
| 31 | * the outputs generate a pulse, they cannot be read directly. To help ensure that a rollover
|
| 32 | * condition is not missed, there is an average rejection filter available that operates on the
|
| 33 | * upper 8 bits of a 12 bit number and selects the nearest outlyer of 3 samples. This will reject
|
| 34 | * a sample that is (due to averaging or sampling) errantly between the two limits. This filter
|
| 35 | * will fail if more than one sample in a row is errantly in between the two limits. You may see
|
| 36 | * this problem if attempting to use this feature with a mechanical rollover sensor, such as a
|
| 37 | * 360 degree no-stop potentiometer without signal conditioning, because the rollover transition
|
| 38 | * is not sharp / clean enough. Using the averaging engine may help with this, but rotational speeds of
|
| 39 | * the sensor will then be limited.
|
| 40 | */
|
| 41 | class AnalogTriggerOutput: public DigitalSource
|
| 42 | {
|
| 43 | friend class AnalogTrigger;
|
| 44 | public:
|
| 45 | typedef enum {kInWindow=0, kState=1, kRisingPulse=2, kFallingPulse=3} Type;
|
| 46 |
|
| 47 | virtual ~AnalogTriggerOutput();
|
| 48 | bool Get();
|
| 49 |
|
| 50 | // DigitalSource interface
|
| 51 | virtual UINT32 GetChannelForRouting();
|
| 52 | virtual UINT32 GetModuleForRouting();
|
| 53 | virtual bool GetAnalogTriggerForRouting();
|
| 54 | virtual void RequestInterrupts(tInterruptHandler handler, void *param=NULL); ///< Asynchronus handler version.
|
| 55 | virtual void RequestInterrupts(); ///< Synchronus Wait version.
|
| 56 | protected:
|
| 57 | AnalogTriggerOutput(AnalogTrigger *trigger, Type outputType);
|
| 58 |
|
| 59 | private:
|
| 60 | AnalogTrigger *m_trigger;
|
| 61 | Type m_outputType;
|
| 62 | };
|
| 63 |
|
| 64 |
|
| 65 | #endif
|