CConfigScan()

Configures a counter channel. This method only works with counter boards that have counter scan capability.

Member of the MccBoard class.

Function Prototype

VB .NET

Public Function CConfigScan(ByVal counterNum As Integer, ByVal mode As MccDaq.CounterMode, ByVal debounceTime As MccDaq.CounterDebounceTime, ByVal debounceMode As MccDaq.CounterDebounceMode, ByVal edgeDetection As MccDaq.CounterEdgeDetection, ByVal tickSize As MccDaq.CounterTickSize, ByVal mapCounter As Integer) As MccDaq.ErrorInfo


Public Function CConfigScan(ByVal counterNum As Integer, ByVal mode As MccDaq.CounterMode, ByVal debounceTime As MccDaq.CounterDebounceTime, ByVal debounceMode As MccDaq.CounterDebounceMode, ByVal edgeDetection As MccDaq.CounterEdgeDetection, ByVal tickSize As Integer, ByVal mapCounter As Integer) As MccDaq.ErrorInfo

C# .NET

public MccDaq.ErrorInfo CConfigScan(int counterNum, MccDaq.CounterMode mode, MccDaq.CounterDebounceTime debounceTime, MccDaq.CounterDebounceMode debounceMode, MccDaq.CounterEdgeDetection edgeDetection, MccDaq.CounterTickSize tickSize, int mapCounter)


public MccDaq.ErrorInfo CConfigScan(int counterNum, MccDaq.CounterMode mode, MccDaq.CounterDebounceTime debounceTime, MccDaq.CounterDebounceMode debounceMode, MccDaq.CounterEdgeDetection edgeDetection, int tickSize, int mapCounter)

Parameters

counterNum

The counter number to configure. This parameter is zero-based, so the first counter number is "0".

mode

Bit fields that control various options. All of the mode settings are MccDaq.CounterMode enumerated constants. Set it to one of the constants in the "mode parameter values" section below.

debounceTime

Used to bypass the debounce mode, or to set a channel's comparator output to one of 16 debounce times. Debounce is used to eliminate switch-induced transients typically associated with electromechanical devices including relays, proximity switches, and encoders.

All of the debounceTime settings are MccDaq.CounterDebounceTime enumerated constants. Set it to one of the constants in the "debounceTime parameter values" section below.

debounceMode

Sets the mode of the debounce module. The debounceMode settings are MccDaq.CounterDebounceMode enumerated constants. Set it to one of the constants in the "debounceMode parameter values" section below.

edgeDetection

Selects whether to detect a rising edge or falling edge. The edgeDetection settings are MccDaq.CounterEdgeDetection enumerated constants. Choices are RisingEdge and FallingEdge.

For counter devices that use channel mapping, if a counter is configured for FallingEdge, calling CIn() or CIn32() for that counter will result in a BADCOUNTERMODE error.

tickSize

Sets the tick size, which is the fundamental unit of time for period, pulsewidth, and timing measurements. All of the tickSize settings are MccDaq.CounterTickSize enumerated constants. Set it to one of the constants in the "tickSize parameter values" section below.

mapCounter

Used to select the mapped channel. A mapped channel is one of the counter input channels other than counterNum that can participate with the input signal of the counter defined by counterNum by gating the counter or decrementing the counter.

Returns

mode parameter values

Sets the specified counter to totalize mode. This mode may contain any combination of non-contradictory choices from the following list of options:

Bit32Selects a 32-bit counter for asynchronous mode. This argument value only affects counter resolution for asynchronous calls (CIn(), CIn32(), and CIn64()). Recommended for use only with CIn32(). (Using the Bit32 option with CIn() is not very useful, since the value returned by CIn() is only 16 bits. The effect is that the value returned by CIn() rolls over 4,294,967,295 times before stopping.)
Refer to board-specific information for the product you are using for details on how this affects asynchronous reads on a specific device.
Bit48Selects a 48-bit counter for asynchronous mode. This argument value only affects counter resolution for asynchronous calls (CIn(), CIn32(), and CIn64()). (Using the Bit48 option with CIn() and CIn32() is not very useful, since the value returned by CIn() is only 16 bits, and the value returned by CIn32() is only 32 bits. The effect is that the value returned by CIn() rolls over 4,294,967,295 times before stopping, and the value returned by CIn32() rolls over 65,535 times before stopping.)
Refer to board-specific information for the product you are using for details on how this affects asynchronous reads on a specific device.
ClearOnReadThe counter is cleared after every read.
CountDownOffThe counter counts up.
CountDownOnThe counter counts down.
DecrementOnAllows the mapped channel to decrement the counter. With this option, the main counter channel will increment the counter, and the mapped channel can be used to decrement the counter. By default, the counter decrement option is set to "off".

This mode is not compatible with CIn() or CIn32(). If a counter is configured for DecrementOn, calling CIn() or CIn32() for that counter will result in a BADCOUNTERMODE error.
GateClrsCtrThe gate input clears the counter. By default, the counter is cleared when the gate input is high.
GateControlsDirThe gate input controls the direction of the counter. By default, the counter increments when the gate pin is high, and decrements when the gate pin is low.
GateTrigSrcThe counter starts counting when the gate input goes active. By default, active is on the rising edge. The gate is re-armed when the counter is loaded and when CConfigScan() is called.
GatingOnSelects gating "on." When "on", the counter is enabled when the mapped channel or the gate pin that is used to gate the counter is high. When the mapped channel/gate pin is low, the counter is disabled but holds the count value. By default, the counter gating option is set to "off."

For counter devices that use channel mapping, this mode is not compatible with CIn() or CIn32(). If a counter is configured for GatingOn, calling CIn() or CIn32() for that returns a BADCOUNTERMODE error.
InvertGateInverts the polarity of the gate input.
LatchOnMapCauses the count to be latched by the signal on the mapped channel. By default, the count is latched by the internal "start of scan" signal, so the count is updated each time it's read.

This mode is not compatible with CIn() or CIn32(). If a counter is configured for LatchOnMap, calling CIn() or CIn32() for that counter will result in a BADCOUNTERMODE error.
ModuloNOnEnables modulo-n counting mode. In modulo-n mode, an upper limit is set by loading the max limit register with a maximum count. When counting up, the counter will roll-over to 0 when the maximum count is reached, and then continue counting up. Likewise when counting down, the counter will roll over to the maximum count (in the max limit register) whenever the count reaches 0, and then continue counting down.
NoRecycleOnEnables non-recycle counting mode. In non-recycle mode, the counter stops counting whenever a count overflow or underflow takes place. Counting restarts when a clear or a load operation is performed on the counter or the count direction changes.
OutputInitialStateHighSets the initial state of the counter output pin high.
OutputInitialStateLowSets the initial state of the counter output pin low.
OutputOnEnables the counter output. By default, the counter output goes high when the counter reaches the value of output register 0, and low when the counter reaches the value of output register 1. Use CLoad, CLoad32, or CLoad64 to set or read the value of the output registers.
RangeLimitOnEnables range limit counting mode. In range limit mode, an upper and lower limit is set, mimicking limit switches in the mechanical counterpart. Use CLoad, CLoad32, or CLoad64 to set the upper and lower limits – set the upper limit by loading the max limit register, and the lower limit by loading the min limit register. Note that on some devices the lower limit is programmable, but on other devices the lower limit is always 0.

When counting up, the counter rolls over to min limit when the max limit is reached. When counting down, the counter rolls over to max limit when the min limit is reached. When counting up with NoRecycleOn enabled, the counter freezes whenever the count reaches the value that was loaded into the max limit register. When counting down with NoRecycleOn enabled, the counter freezes whenever the count reaches the value that was loaded into the min limit register. Counting resumes if the counter is reset or the direction changes.
StopAtMaxThe counter will stop at the top of its count. For the CIn32() method, the top of the count depends on whether the Bit32 option is used. If it is, the top of the count is FFFFFFFF hex. If not, the top of the count is FFFF hex. By default, the counter counts upward and rolls over on the 32-bit boundary.
UpDownOnEnables up/down counting mode.

Sets the specified counter to encoder measurement mode. This mode may contain any combination of non-contradictory choices from the following list of options:

EncoderModeBit16Selects a 16-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn().
EncoderModeBit32Selects a 32-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn32(). (Using the EncoderModeBit32 option with CIn() is not very useful, since the value returned by CIn() is only 16 bits. The effect is that the value returned by CIn() rolls over 4,294,967,295 times before stopping.)
EncoderModeBit48Selects a 48-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn64(). (Using the EncoderModeBit48 option with CIn() and CIn32() is not very useful, since the value returned by CIn() is only 16 bits, and the value returned by CIn32() is only 32 bits. The effect is that the value returned by CIn() rolls over 4,294,967,295 times before stopping, and the value returned by CIn32() rolls over 65,535 times before stopping.)
EncoderModeClearOnZOnSelects "clear on Z" on. The counter is cleared when the index (Z input) goes active. By default, the "ClearOnZ" option is off, and the counter is not cleared.
EncoderModeLatchOnZSelects the Encoder Z mapped signal to latch the counter outputs. This allows the user to know the exact counter value when an edge is present on another counter.
EncoderModeModuloNOnEnables Modulo-N counting mode. In Modulo-N mode, an upper limit is set by loading the max limit register with a maximum count. When counting up, the counter will roll-over to 0 when the maximum count is reached, and then continue counting up. Likewise when counting down, the counter will roll over to the maximum count (in the max limit register) whenever the count reaches 0, and then continue counting down.
EncoderModeNoRecycleOnEnables Non-recycle counting mode. In Non-recycle mode, the counter is disabled whenever a count overflow or underflow takes place. The counter is re-enabled when a clear or a load operation is performed on the counter
EncoderModeRangeLimitOnEnables Range Limit counting mode. In Range Limit mode, an upper and lower limit is set, mimicking limit switches in the mechanical counterpart. The upper limit is set by loading the max limit register with the CLoad, CLoad32, or CLoad64 functions. The lower limit is always 0.

When counting up, the counter rolls over to min limit when the max limit is reached. When counting down, the counter rolls over to max limit when the min limit is reached. When counting up with EncoderModeNoRecycleOn enabled, the counter freezes whenever the count reaches the value that was loaded into the max limit register. When counting down with EncoderModeNoRecycleOn enabled, the counter freezes whenever the count reaches the value that was loaded into the min limit register. Counting resumes if the counter is reset or the direction changes.
EncoderModeX1Sets the encoder measurement mode to X1.
EncoderModeX2Sets the encoder measurement mode to X2.
EncoderModeX4Sets the encoder measurement mode to X4.

Sets the specified counter to period measurement mode. This mode may contain any combination of non-contradictory choices from the following list of options:

PeriodModeBit16Selects a 16-bit counter for asynchronous mode. This argument value only affects counter resolution for asynchronous calls (CIn(), CIn32(), and CIn64()). Recommended for use only with CIn().
PeriodModeBit32Selects a 32-bit counter for asynchronous mode. This argument value only affects counter resolution for asynchronous calls (CIn(), CIn32(), and CIn64()). Recommended for use only with CIn32(). (Using the PeriodModeBit32 option with CIn() is not very useful, since the value returned by CIn() is only 16 bits. The effect is that the value returned by CIn() rolls over at 64k 65,535 times before stopping.)
PeriodModeBit48Selects a 48-bit counter for asynchronous mode. This argument value only affects counter resolution for asynchronous calls (CIn(), CIn32(), and CIn64()). Recommended for use only with CIn64(). (Using the PeriodModeBit48 option with CIn() and CIn32() is not very useful, since the value returned by CIn() is only 16 bits, and the value returned by CIn32() is only 32 bits. The effect is that the value returned by CIn() rolls over 4,294,967,295 times before stopping, and the value returned by CIn32() rolls over 65,535 times before stopping.)
PeriodModeGatingOnSelects gating "on." When "on", the counter is enabled when the mapped channel or the gate pin that is used to gate the counter is high. When the mapped channel/gate pin is low, the counter is disabled but holds the count value. By default, the counter gating option is set to "off."

For counter devices that use channel mapping, this mode is not compatible with CIn() or CIn32(). If a counter is configured for PeriodModeGatingOn, calling CIn() or CIn32() for that returns a BADCOUNTERMODE error.
PeriodModeInvertGateInverts the polarity of the gate input.
PeriodModeX1The measurement is latched each time one complete period is observed.
PeriodModeX10The measurement is latched each time 10 complete periods are observed.
PeriodModeX100The measurement is latched each time 100 complete periods are observed.
PeriodModeX1000The measurement is latched each time 1000 complete periods are observed.

Sets the specified counter to Pulsewidth measurement mode. This mode may contain any combination of non-contradictory choices from the following list of options:

PulseWidthModeBit16Selects a 16-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn().
PulseWidthModeBit32Selects a 32-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn32(). (Using the PulseWidthModeBit32 option with CIn() and CIn32() is not very useful, since the value returned by CIn() is only 16 bits, and the value returned by CIn32() is only 32 bits. The effect is that the value returned by CIn() rolls over 4,294,967,295 times before stopping, and the value returned by CIn32() rolls over 65,535 times before stopping.)
PulseWidthModeBit48Selects a 48-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn64(). (Using the PulseWidthModeBit48 option with CIn() and CIn32() is not very useful, since the value returned by CIn() is only 16 bits, and the value returned by CIn32() is only 32 bits. The effect is that the value returned by CIn() rolls over 4,294,967,295 times before stopping, and the value returned by CIn32() rolls over 65,535 times before stopping.)
PulseWidthModeGatingOnSelects gating "on." When "on", the counter is enabled when the mapped channel or the gate pin that is used to gate the counter is high. When the mapped channel/gate pin is low, the counter is disabled but holds the count value. By default, the counter gating option is set to "off."

For counter devices that use channel mapping, this mode is not compatible with CIn() or CIn32(). If a counter is configured for PulseWidthModeGatingOn, calling CIn() or CIn32() for that returns a BADCOUNTERMODE error.
PulseWidthModeInvertGateInverts the polarity of the gate input.

Sets the specified counter to timing mode. This mode supports the following option:

TimingModeBit16Selects a 16-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn().
TimingModeBit32Selects a 32-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn32(). (Using the TimingModeBit32 option with CIn() is not very useful, since the value returned by CIn() is only 16 bits. The effect is that the value returned by CIn() rolls over at 64k 65,535 times before stopping.)
TimingModeBit48Selects a 48-bit counter for asynchronous mode. This argument value only affects CIn64(), CIn32(), and CIn(). Recommended for use only with CIn64(). (Using the TimingModeBit48 option with CIn() and CIn32() is not very useful, since the value returned by CIn() is only 16 bits, and the value returned by CIn32() is only 32 bits. The effect is that the value returned by CIn() rolls over 4,294,967,295 times before stopping, and the value returned by CIn32() rolls over 65,535 times before stopping.)
TimingModeInvertGateInverts the polarity of the gate input.

debounceTime parameter values

Debounce500nsSets the counter channel's comparator output to 500 ns.
Debounce1500nsSets the counter channel's comparator output to 1500 ns.
Debounce3500nsSets the counter channel's comparator output to 3500 ns.
Debounce7500nsSets the counter channel's comparator output to 7500 ns.
Debounce15500nsSets the counter channel's comparator output to 15500 ns.
Debounce31500nsSets the counter channel's comparator output to 31500 ns.
Debounce63500nsSets the counter channel's comparator output to 63500 ns.
Debounce127500nsSets the counter channel's comparator output to 127500 ns.
Debounce100usSets the counter channel's comparator output to 100 us.
Debounce300usSets the counter channel's comparator output to 300 us.
Debounce700usSets the counter channel's comparator output to 700 us.
Debounce1500usSets the counter channel's comparator output to 1500 us.
Debounce3100usSets the counter channel's comparator output to 3100 us.
Debounce6300usSets the counter channel's comparator output to 6300 us.
Debounce12700usSets the counter channel's comparator output to 12700 us.
Debounce25500usSets the counter channel's comparator output to 25500 us.
DebounceNoneDisables the debounce feature.

debounceMode parameter values

TriggerBeforeStableUse this mode when the input signal has groups of glitches and each group is to be counted as one. The trigger before stable mode will recognize and count the first glitch within a group but reject the subsequent glitches within the group if the debounce time is set accordingly. In this case the debounce time should be set to encompass one entire group of glitches.
TriggerAfterStableThis mode rejects glitches and only passes state transitions after a specified period of stability (the debounce time). This mode is used with electromechanical devices like encoders and mechanical switches to reject switch bounce and disturbances due to a vibrating encoder that is not otherwise moving. The debounce time should be set short enough to accept the desired input pulse but longer than the period of the undesired disturbance.

tickSize parameter values

Tick20nsSets the counter channel's tick size to 20 ns.
Tick20pt83nsSets the counter channel's tick size to 20.83 ns.
Tick200nsSets the counter channel's tick size to 200 ns.
Tick208pt3nsSets the counter channel's tick size to 208.3 ns.
Tick2000nsSets the counter channel's tick size to 2000 ns.
Tick2083pt3nsSets the counter channel's tick size to 2083.3 ns.
Tick20000nsSets the counter channel's tick size to 20000 ns.
Tick20833pt3nsSets the counter channel's tick size to 20833.3 ns.