# USB-6451 and USB-6451 (OEM) User Manual



# **Contents**

| USB-6451 and USB-6451 (OEM) User Manual              | 5  |
|------------------------------------------------------|----|
| Overview                                             | 6  |
| Driver Support                                       | 7  |
| System Components                                    | 8  |
| Theory of Operation                                  | 11 |
| Block Diagram                                        | 14 |
| Examples                                             | 18 |
| Front Panel                                          | 28 |
| Rear Panel                                           | 31 |
| USB-6451 Pinouts                                     | 33 |
| +5 V Power Source                                    | 40 |
| ID Pin                                               | 41 |
| Analog Input Measurements                            | 45 |
| Analog Input Range                                   | 45 |
| Working Voltage Range                                | 46 |
| Analog Input Terminal Configurations                 | 47 |
| Dual-Channel Scanning                                | 49 |
| Analog Input Data Acquisition Methods                | 53 |
| Analog Input Signal Connections                      | 54 |
| Floating Signal Sources Connections                  | 56 |
| Ground-Referenced Signal Sources Connections         | 61 |
| Field Wiring Considerations for Analog Input Signals | 65 |
| Analog Input Timing Engine                           | 66 |
| Analog Input Timing Signals                          | 68 |
| Analog Triggering                                    | 76 |
| Onboard Temperature Sensing                          | 79 |
| Analog Output Measurements                           | 80 |
| Analog Output Data Generation Methods                | 80 |
| Analog Output Signal Connections                     | 81 |
| Analog Output Timing Engine                          |    |
| Analog Output Timing Signals                         |    |
| Minimizing Glitches on the Output Signal             | 88 |

| Di | gital Input/Output Measurements                             | . 89 |
|----|-------------------------------------------------------------|------|
|    | Digital Input Data Acquisition Methods                      | . 89 |
|    | Digital Waveform Acquisition                                | 90   |
|    | Digital Input Change Detection                              | 91   |
|    | Digital Input Timing Signals                                | 92   |
|    | Digital Output Data Generation Methods                      | 100  |
|    | Digital Waveform Generation                                 | 102  |
|    | Digital Output Timing Signals                               | 102  |
|    | I/O Protection                                              | 107  |
|    | Digital I/O Signal Connections                              | 108  |
|    | Using Digital I/O Terminals as Timing Input Signals         | 109  |
|    | Using Digital I/O Terminals to Export Timing Output Signals | 110  |
|    | Filters for Digital Input                                   | 111  |
|    | Filters for Counter and Timer Signals                       | 114  |
|    | Watchdog Timer                                              | 115  |
|    | Digital Input/Output Logic Families                         | 116  |
|    | Programmable Power-Up States                                | 117  |
| Cd | ounters                                                     | 119  |
|    | Counter Timing Engine                                       | 120  |
|    | Counter Input Applications                                  | 121  |
|    | Counter Output Applications                                 | 141  |
|    | Counter Timing Signals                                      | 151  |
|    | Counter Triggering                                          | 157  |
|    | Cascading Counters                                          | 158  |
|    | Counter Signal Prescaling                                   | 158  |
|    | Counter Signal Synchronization Modes                        |      |
| In | stalling the USB-6451                                       | 161  |
|    | Unpacking the Kit                                           | 161  |
|    | Installing Software                                         | 161  |
|    | Wiring the USB-6451                                         | 162  |
|    | Verifying the Installation                                  | 162  |
| М  | ounting the USB-6451                                        | 165  |
|    | Mounting the USB-6451 on a DIN Rail                         | 165  |
|    | Mounting the USB-6451 on a Wall or Panel                    | 170  |
|    | Mounting the USB-6451 in a Rack                             | 172  |
|    | Mounting the USB-6451 with Zip Ties                         | 173  |

| Migrating from Previous Products              | 176 |
|-----------------------------------------------|-----|
| USB-6451 (OEM)                                | 177 |
| USB-6451 (OEM) Parts                          | 177 |
| USB-6451 (OEM) Pinouts                        | 180 |
| USB-6451 (OEM) Connectors                     | 189 |
| Attaching External LEDs to the USB-6451 (OEM) | 189 |
| Mounting the USB-6451 (OEM)                   | 190 |
| Adding a Locking Screw                        | 192 |

# USB-6451 and USB-6451 (OEM) User Manual

The USB-6451 and USB-6451 (OEM) User Manual provides detailed descriptions of the product functionality and the step by step processes for use.

#### **Looking for Something Else?**

For information not found in the User Manual for your product, such as specifications and API reference, browse **Related Information**.

#### **Related information:**

- <u>USB-6451 Specifications</u>
- NI-DAQmx User Manual
- Software and Driver Downloads
- Release Notes
- License Setup and Activation
- <u>Dimensional Drawings</u>
- Product Certifications
- Letter of Volatility
- Discussion Forums
- NI Learning Center

## **USB-6451 Overview**

The USB-6451 is a multifunction Data Acquisition (DAQ) device featuring a combination of analog input, analog output, digital I/O, and counter/timers. Use the USB-6451 for a wide range of electromechanical test and measurement applications.

#### **USB-6451** Key Features

- 16 single-ended and 8 differential analog input channels
- Simultaneous sampling on up to 8 analog input channels
- 2 analog output channels
- 16 digital input/output channels
- 1 MS/s sampling rate on analog input
- 250 kS/s sampling rate on analog output channels
- 20-bit resolution on analog input channels
- 16-bit resolution on analog output channels
- 4 counters
- Compact and rugged enclosure with removable spring terminals for direct signal connection
- Multiple mounting options, including on a desktop, rack, DIN rail, or wall

.

# USB-6451 Driver Support

Determine the earliest driver version supported for your product.



**Tip** To optimize product performance, update to the most recent driver

Table 1. Earliest Driver Version Support

| Product  | Driver Name | Earliest Version Support |
|----------|-------------|--------------------------|
| USB-6451 | NI-DAQmx    | 2024 Q3.1                |

#### Related tasks:

• Installing Software

# Components of a USB-6451 System

The USB-6451 is designed for use in a system that may require hardware, drivers, and software to optimize USB-6451 for your application. Use the minimum required USB-6451 system components as a starting point for building your system.

Table 2. Minimum Required USB-6451 System Components

| Component                                | Description and Recommendations                                                                                                                                                                                                                             |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Computer                                 | The USB-6451 connects to a computer through USB for power and communication.                                                                                                                                                                                |
| USB-6451                                 | Your USB DAQ device.                                                                                                                                                                                                                                        |
| USB Cable                                | Connects your USB DAQ device to your computer.                                                                                                                                                                                                              |
| Mounting<br>Accessories                  | <ul> <li>The USB-6451 supports a number of mounting configurations including:</li> <li>Resting on a flat surface, unmounted</li> <li>Mounting to a DIN rail, wall, or panel</li> <li>Mounting in a rack</li> <li>Securing in place with zip ties</li> </ul> |
| Backshells<br>for<br>Connector<br>Blocks | You can install backshells over the spring-terminal connector blocks to protect the wiring and provide strain relief. The USB-6451 shipping kit includes backshells, but you can order more separately.                                                     |
| NI-DAQmx                                 | Instrument driver software that provides functions to interact with the USB-6451 and execute measurements using the USB-6451.                                                                                                                               |
|                                          | Note For optimal performance, use the most current version of NI-DAQmx with the USB-6451.                                                                                                                                                                   |
| NI<br>Applications                       | NI-DAQmx offers driver support for the following applications:  LabVIEW LabVIEW Real-Time Module FlexLogger LabWindows/CVI LabWindows/CVI Real-Time Module NI-DAQmx Measurement Studio Integration (Measurement Studio 2019)                                |

| Component | Description and Recommendations                     |
|-----------|-----------------------------------------------------|
|           | <ul><li>C/C++</li><li>.NET</li><li>Python</li></ul> |

### **Part Numbers for Recommended Accessories**

Use part numbers to purchase the cables and accessories NI recommends to optimize the performance of the USB-6451.

Table 3. Part Numbers for Recommended Accessories

| Accessory                                                    | Description                                                                                                                                                               | Part Number |
|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| USB-64xx Mounting Kit for DIN<br>Rail                        | Use to mount the USB-6451 on a DIN rail horizontally.                                                                                                                     | 789986-01   |
| USB-64xx Mounting Kit for DIN<br>Rail, Wall, or Panel Mount  | Use to mount the USB-6451 on<br>a DIN rail vertically or to mount<br>it on a wall or a panel. Includes<br>a right-angle USB Type-C cable<br>for mounting close to a wall. | 789955-01   |
| USB-64xx Rack Mount Shelf                                    | Use to mount up to two USB-6451 in a 19-in. rack. Uses 1U of rack height. Includes two right-angle, 2 m USB Type-C cables.                                                | 789953-01   |
| Spring-terminal connector                                    | Use to wire the USB-6451.                                                                                                                                                 | 785502-01   |
| Backshell for spring-terminal connector                      | Use to protect the wiring and provide strain relief.                                                                                                                      | 785080-01   |
| USB Cable, Type-C to Type-C<br>with Screw, USB 3.2 Gen 1, 2m | Use to connect the USB-6451 to a computer. One end of the cable has a locking thumb screw for securing the cable to the USB-6451.                                         | 789956-02   |

### **Additional Cabling and Accessory Guidance**

NI recommends the following:

• Using individually shielded, twisted-pair wires that are 2 m or less to connect AI signals to the USB-6451.

#### Related tasks:

- Mounting the USB-6451 on a DIN Rail
- Mounting the USB-6451 on a Wall or Panel
- Mounting the USB-6451 in a Rack

# USB-6451 Theory of Operation

The USB-6451 is a simultaneously-sampled multifunction I/O Data Acquisition (DAQ) device that connects to a computer via a USB Type-C interface. This single USB Type-C cable provides power as well as USB 3.0 SuperSpeed communication.

#### **NI Signal Streaming**

NI signal streaming technology performs the USB communication. NI signal streaming technology allows for efficient, high-speed, bidirectional data streaming to and from the host computer. NI signal streaming uses USB bandwidth efficiently to support data transfer from the different analog input, analog output, and digital I/O subsystems on the USB-6451.

#### **Analog Input**

The USB-6451 analog input provides 16 single-ended or 8 differential input channels that are connected to 8 simultaneously-sampled, 20-bit ADCs. Each differential channel pair has its own programmable gain instrumentation amplifier, multiplexers, and ADC. This design enables high-speed simultaneous sampling of all differential channels up to the maximum rate of 1 MS/s on all channels. Multiplexers allow you to sample the differential input pair as two separate single-ended channels for additional flexibility. In this single-ended mode, the maximum sample rate drops to 500 kS/s on all channels.

The maximum input range of ±10 V is suitable for connecting to a wide variety of electronics or sensors with conditioned outputs. A programmable gain instrumentation amplifier with four different ranges delivers a scaled signal to the 20-bit ADC to maximize resolution for lower voltage signals.

An accurate, low-drift onboard reference plus integrated self-calibration circuitry ensures that the 16 single-ended or 8 differential inputs perform accurately across time and temperature.

#### **Analog Output**

The analog output circuitry consists of two independent 16-bit, ±10 V analog outputs. You can use these outputs for stimulus or simple control. You can also make single-point updates or generate waveforms.

#### Digital I/O, Counters, and Timers

The USB-6451 has 16 digital I/O lines. You can configure each line as input or output individually. You can use the digital I/O lines for either single-point updates or high-speed waveform input/output.

The USB-6451 also has four 32-bit counters that you can route to the digital I/O lines. These counters can count events, measure frequency, measure using an incremental encoder, generate frequency, generate a pulse train, and more.

Flexible routing allows you to route any counter to any of the digital I/O lines.

#### Timing, Triggering, and Synchronization

Independent timing engines control how each device subsystem operates. This functionality allows the subsystems to either run independently or synchronously.

You can route timing and trigger signals to or from the digital I/O lines to synchronize with other equipment or DAQ devices. The timing and trigger signals include signals such as a Start Trigger to control when an operation starts or a Sample Clock, which toggles each time a sample is acquired.

#### **Enclosure and Connectivity**

All this functionality is housed in a rugged metal enclosure. You can use the enclosure as-is on a desk or mount it to equipment with built-in zip-tie mounting slots. Optional DIN rail, wall-mount, and rack-mount kits are available for mounting in other environments.

I/O connections are made through removable spring-terminal connectors. These connector blocks use push-in technology that enables you to wire of input signals

rapidly. You can use the included backshells to protect the wiring and provide strain relief.

# USB-6451 Block Diagram

Use the USB-6451 block diagram to learn more about the different analog input, analog output, and digital I/O subsystems of the USB-6451 work together.

Figure 1. USB-6451 Block Diagram



## **Analog Input Block Diagram**

The following figure shows the analog input circuitry of the USB-6451.

Every differential channel pair has its own instrumentation amplifier, multiplexers, and ADC. This allows high-speed simultaneous sampling of all differential channels up to the maximum rate of 1 MS/s on all channels. For additional flexibility, multiplexers allow sampling the differential input pair as 2 separate single-ended channels. In this single-ended mode, the maximum sample rate drops to 500 kS/s on all channels.



Figure 2. USB-6451 Analog Input Block Diagram

- I/O Connector—You can connect analog input signals to the USB-6451 through the I/O connector.
- AI Terminal Configuration—These multiplexers configure the input mode to either differential, referenced single-ended (RSE), or non-referenced single-ended (NRSE).
- Instrumentation Amplifier (NI-PGIA)—The NI programmable gain instrumentation amplifier (NI-PGIA) can amplify or attenuate an AI signal to ensure that you get the maximum resolution of the ADC. The NI-PGIA also allows you to select the input range.
- ADC—The analog-to-digital converter (ADC) digitizes the AI signal by converting the analog voltage into a digital number.
- Analog Input Timing Signals—For information about the analog input timing signals available on USB-6451 devices, refer to the **Analog Input Timing Signals** section.
- AI FIFO—The USB-6451 can perform both single and multiple A/D conversions of a fixed or infinite number of samples. A large first-in-first-out (FIFO) buffer holds data during A/D conversions to ensure that no data is lost. The USB-6451 can handle multiple A/D conversion operations with DMA or programmed I/O.

#### **Related concepts:**

• Analog Input Timing Signals

### **Analog Output Block Diagram**

The USB-6451 has two voltage output channels capable of either software-timed single-point updates or hardware-timed waveform generation.

Figure 3. USB-6451 Analog Output Block Diagram



The main blocks featured in the USB-6451 analog output circuitry are as follows:

- Digital-to-analog converters (DACs)—Convert digital codes to analog voltages.
- AO FIFO—Enables analog output waveform generation. It is a first-in-first-out (FIFO) memory buffer between the computer and the DACs. It allows you to either stream a waveform with new data continuously provided from USB or download an entire waveform to the USB-6451 where it can be regenerated entirely from the onboard buffer.
- AO Sample Clock—Reads a sample from the AO FIFO and generates the AO voltage.

## Digital I/O Block Diagram

The USB-6451 has 16 bidirectional digital I/O signals that are grouped together in software as a single port referred to as Port 0.

These signals can function as digital I/O as well as counter, timer, or triggering I/O. When used as counter, timer, or triggering I/O, the lines are referred to as **Programmable Function Interface (PFI)** lines. The digital I/O lines on the USB-6451 support the following features:

- Direction and function of each terminal individually controllable
- Static digital input and output
- High-speed digital waveform generation
- · High-speed digital waveform acquisition
- Digital input change detection trigger/interrupt
- · Timing input signal for analog input, analog output, digital input, digital output, or counter/timer functions
- Timing output signal from analog input, analog output, digital input, digital output, or counter/timer functions
- Shared I/O voltage logic family selection: 1.8 V, 2.5 V, 3.3 V, or 5 V (shared for all lines)

The following figure shows the circuitry of one digital I/O line. Each digital I/O line is similar.

Figure 4. USB-6451 Digital I/O Block Diagram



In software, these channels are referred to as port0/line0:15 when used as digital I/O and PFI 0:15 when used for other purposes, such as timing I/O.

# **USB-6451 Examples**

NI installs example code with your software or driver that demonstrates the functionality of USB-6451. Use these examples to learn about the product or accelerate your own application development.

Most NI products install examples that you can access directly or from within NI software. The example experience can differ slightly across products and versions.

#### **LabVIEW Examples**

USB-6451 LabVIEW examples are located in the %ProgramFiles%\NI\LVAddons\nidaqmx\1\examples\NI-DAQmx directory.

Table 4. Common USB-6451 LabVIEW Examples

| Example Name                             | Description                                                                                                                                                                                            |
|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Voltage (with Events) - Continuous Input | Demonstrates how to continuously acquire buffered voltage measurements. It uses software events to ensure that the program does not become unresponsive while waiting for samples to become available. |
| Voltage - Continuous Input               | Demonstrates how to continuously acquire voltage measurement.                                                                                                                                          |
| Voltage - Finite Input                   | Demonstrates how to acquire a single buffer of voltage measurements.                                                                                                                                   |
| Voltage - SW-Timed Input                 | Demonstrates how to acquire a voltage based off of software timing.                                                                                                                                    |
| Voltage - Continuous Output              | Demonstrates how to continuously re-generate analog output data from a buffer in your computer's memory.                                                                                               |
| Voltage - Finite Output                  | Demonstrates how to output a voltage based on a finite amount of data from a buffer in your computer's memory.                                                                                         |
| Voltage - On Demand Output               | Demonstrates how to generate a user-defined voltage using the analog output.                                                                                                                           |

| Example Name                                               | Description                                                                                                                                                                    |
|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Counter - Count Edges                                      | Demonstrates how to continuously read back<br>the number of digital edges that have been<br>counted by a counter input.                                                        |
| Counter - Read Encoder                                     | Demonstrates how to use a counter to continually monitor the angular position of an encoder.                                                                                   |
| Counter - Read Pulse Duty Cycle and Frequency (Continuous) | Demonstrates how to configure a pulse measurement to acquire frequency and duty cycle based off of an external clock.                                                          |
| Counter - Continuous Output                                | Demonstrates how to continuously generate digital pulses using a counter output.                                                                                               |
| Counter - Finite Output                                    | Demonstrates how to generate a finite number of digital pulses using a counter output. On some hardware, this requires the use of a second counter to generate a gate signal.  |
| Counter - Single Pulse Output                              | Demonstrates how to generate a single pulse using a counter output. The single pulse may be triggered once or repeatedly from an external source.                              |
| Digital - Change Detection                                 | Demonstrates how to acquire a continuous amount of digital data based off of the changes of an external signal across one or many lines on either the rising or falling edges. |
| Digital - Continuous Input                                 | Demonstrates how to acquire a continuous amount of digital data based off of a sample clock.                                                                                   |
| Digital - SW-Timed Input                                   | Demonstrates how to acquire the state of digital lines based off of software timing.                                                                                           |
| Digital - Continuous Output                                | Demonstrates how to generate a continuous amount of digital data based off of a sample clock.                                                                                  |
| Digital - Finite Output                                    | Demonstrates how to generate a finite amount of digital data based off of a sample clock.                                                                                      |
| Digital - SW-Timed Output                                  | Demonstrates how to generate digital output data using software timing.                                                                                                        |

| Example Name                    | Description                                                                                                                                                                                                 |  |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                 | Demonstrates how to continuously acquire temperature measurements.                                                                                                                                          |  |
| Thermocouple - Continuous Input | Note The input range switches to the lowest input range (0.2 V) by default. Choose the thermocouple type and onboard cold-junction compensation sensing to compensate for the internal cold-junction error. |  |

## **Python Examples in**

 $\begin{tabular}{ll} USB-6451 \ Python \ examples \ are \ located \ in \ GitHub \ at \ github. com/ni/nidaqmx-python/tree/master/examples. \end{tabular}$ 

Table 5. Common USB-6451 Python Examples

| Example Name                                                            | Description                                                                                                                                                                                          |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <pre>analog_in/cont_voltage_acq_int_clk.py</pre>                        | Demonstrates how to acquire a continuous amount of data using the USB-6451's internal clock.                                                                                                         |
| <pre>analog_in/ cont_voltage_acq_int_clk_every_n_samples_event.py</pre> | Demonstrates how to use Every N Samples events to acquire a continuous amount of data using the USB-6451's internal clock. The Every N Samples events indicate when data is available from NI-DAQmx. |
| analog_in/voltage_acq_int_clk.py                                        | Demonstrates how to acquire a finite amount of DATA                                                                                                                                                  |

| Example Name                                                                 | Description                                                                                                                                                                                                                                            |
|------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                              | using the USB-6451's internal clock.                                                                                                                                                                                                                   |
| analog_in/voltage_sample.py                                                  | Demonstrates how<br>to acquire a voltage<br>measurement using<br>software timing.                                                                                                                                                                      |
| <pre>analog_out/cont_gen_voltage_wfm_int_clk.py</pre>                        | Demonstrates how<br>to output a<br>continuous periodic<br>waveform using an<br>internal sample<br>clock.                                                                                                                                               |
| <pre>analog_out/ cont_gen_voltage_wfm_int_clk_every_n_samples_event.py</pre> | Demonstrates how to use a Every N Samples events to output a continuous periodic waveform to an Analog Output Channel using an internal sample clock. The Every N Samples events indicate when the specified number of samples generation is complete. |
| analog_out/gen_voltage_wfm_int_clk.py                                        | Demonstrates how<br>to output a finite<br>number of voltage<br>samples to an<br>Analog Output<br>Channel using an<br>internal sample<br>clock.                                                                                                         |
| analog_out/voltage_update.py                                                 | Demonstrates how<br>to output a single<br>Voltage Update<br>(Sample) to an<br>Analog Output                                                                                                                                                            |

| Example Name                                       | Description                                                                                                                                                  |  |
|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                    | Channel.                                                                                                                                                     |  |
| <pre>counter_in/cnt_dig_event.py</pre>             | Demonstrates how to count digital events on a Counter Input Channel. You can configure the Initial Count, Count Direction, and Edge.                         |  |
| counter_in/read_pulse_freq.py                      | Demonstrates how to configure a pulse measurement to acquire frequency and duty cycle.                                                                       |  |
| <pre>counter_out/cont_gen_dig_pulse_train.py</pre> | Demonstrates how to generate a continuous digital pulse train from a Counter Output Channel. You can configure the Frequency, Duty Cycle, and Idle State.    |  |
| <pre>counter_out/write_single_dig_pulse.py</pre>   | Demonstrates how to generate a single digital pulse from a Counter Output Channel. You can configure the Initial Delay, High Time, Low Time, and Idle State. |  |
| digital_in/acq_dig_port_int_clk.py                 | Demonstrates how<br>to input a finite<br>digital pattern using<br>the USB-6451's<br>internal clock.                                                          |  |
| digital_in/cont_acq_dig_lines_int_clk.py           | Demonstrates how to acquire a                                                                                                                                |  |

| Example Name                             | Description                                                                                           |
|------------------------------------------|-------------------------------------------------------------------------------------------------------|
|                                          | continuous digital waveform using the USB-6451's internal clock.                                      |
| digital_in/read_dig_lines.py             | Demonstrates how<br>to read values from<br>one or more digital<br>input channels.                     |
| digital_in/read_dig_port.py              | Demonstrates how to read values from a digital input port.                                            |
| digital_out/cont_gen_dig_port_int_clk.py | Demonstrates how<br>to output a<br>continuous digital<br>pattern using the<br>USB-6451's clock.       |
| digital_out/gen_dig_line_int_clk.py      | Demonstrates how<br>to output a finite<br>digital waveform<br>using the USB-6451's<br>internal clock. |
| digital_out/write_dig_lines.py           | Demonstrates how to write values to a digital output channel.                                         |
| digital_out/write_dig_port.py            | Demonstrates how to write values to a digital output port.                                            |
| system_properties.py                     | Demonstrates how<br>to use system<br>properties in NI-<br>DAQmx.                                      |

## .NET Examples

 $\textbf{USB-6451} \ examples \ in \ . \textbf{NET} \ are \ located \ in \ the \ \texttt{Users} \\ \texttt{Public} \\ \texttt{Public}$ 

Documents\National Instruments\NI-DAQ\Examples\...directory.

Table 6. Common USB-6451 .NET Examples

| Example Name                                                                                            | Description                                                                                                                                             |  |  |
|---------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Analog In\Measure Voltage\ AcqMultVoltageSamples_SWTimed\CS\ AcqMultVoltageSamples_SWTimed.sln          | Demonstrates how to acquire a finite amount of data using a software timer.                                                                             |  |  |
| Analog In\Measure Voltage\ AcqOneVoltageSample\CS\ AcqOneVoltageSample.sln                              | Demonstrates how to acquire a single reading from a constant or slowly varying signal.                                                                  |  |  |
| Analog In\Measure Voltage\ AcqVoltageSamples_IntClk\CS\ AcqVoltageSamples_IntClk.sln                    | Demonstrates how to acquire a finite amount of data using an internal clock.                                                                            |  |  |
| <pre>Analog In\Measure Voltage\ ContAcqVoltageSamples_IntClk\CS\ ContAcqVoltageSamples_IntClk.sln</pre> | Demonstrates how to acquire a continuous amount of data using the USB-6451's internal clock.                                                            |  |  |
| Analog In\Measure Voltage\ ContAcqVoltageSamples_SWTimed\CS\ ContAcqVoltageSamples_SWTimed.sln          | Demonstrates how to acquire a continuous amount of data using a software timer.                                                                         |  |  |
| Analog Out\Generate Voltage\ ContGenVoltageWfm_IntClk\CS\ ContGenVoltageWfm_IntClk.sln                  | Demonstrates how to continuously output a periodic waveform using an internal sample clock.                                                             |  |  |
| Analog Out\Generate Voltage\ GenMultVoltUpdates_IntClk\CS\ GenMultVoltUpdates_IntClk.sln                | Demonstrates how to output multiple voltage updates (samples) to an analog output channel.                                                              |  |  |
| Analog Out\Generate Voltage\ GenMultVoltUpdates_SWTimed\CS\ GenMultVoltUpdates_SWTimed.sln              | Demonstrates how to output multiple voltage updates (samples) to an analog output channel in a software timed loop.                                     |  |  |
| Analog Out\Generate Voltage\ GenVoltageUpdate\CS\ GenVoltageUpdate.sln                                  | Demonstrates how to output a single voltage update (sample) to an analog output channel.                                                                |  |  |
| Counter\Count Digital Events\ CountDigEvents\CS\CountDigEvents.sln                                      | Demonstrates how to count digital events on a Counter Input Channel. You can configure the Initial Count, Count Direction, and Edge. This example shows |  |  |

| Example Name                                          | Description                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                       | how to count edges on the counter's default source pin, but you could easily expand it to count edges on any PFI or internal signal.  You can also use a digital pause trigger for counting non-buffered digital events.  To add a digital pause trigger to this example, configure the trigger object for the task.     |
|                                                       | Demonstrates how to count buffered digital events on a Counter Input channel. You can configure the initial count, count direction, edge, and sample clock source. Edges are counted on the counter's default input terminal, but you could easily modify it to count edges on a PFI line.                               |
|                                                       | Note For buffered event counting, an external sample clock is necessary to signal when a sample should be inserted into the buffer.  Specify the source terminal of the external clock in the clock source text box when you run the example.                                                                            |
| Counter\Generate Pulse\GenDigPulse\CS\GenDigPulse.sln | Demonstrates how to generate a single digital pulse from a counter output channel. You can configure the initial delay, high time, low time, and idle state in software. This example shows how to configure the pulse in terms of time, but you can easily modify it to generate a pulse in terms of frequency and duty |

| Example Name                                                                            | Description                                                                                                                                                                                                                                                                                                               |  |
|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                         | cycle or ticks.                                                                                                                                                                                                                                                                                                           |  |
| Counter\Generate Pulse\ GenDigPulseTrain_Continuous\CS\ GenDigPulseTrain_Continuous.sln | Demonstrates how to generate a continuous digital pulse train from a counter output channel. You can configure the frequency, duty cycle, and idle state. This example shows how to configure the pulse in terms of frequency and duty cycle, but you can easily modify it to generate a pulse in terms of time or ticks. |  |
| <pre>Digital\Generate Values\WriteDigChan\ CS\WriteDigChan.sln</pre>                    | Demonstrates how to write values to a digital output channel.                                                                                                                                                                                                                                                             |  |
| <pre>Digital\Generate Values\WriteDigPort\ CS\WriteDigPort.sln</pre>                    | Demonstrates how to write values to a digital output port.                                                                                                                                                                                                                                                                |  |
| Digital\Read Values\ReadDigChan\CS\ ReadDigChan.sln                                     | Demonstrates how to read values from one or more digital input channels.                                                                                                                                                                                                                                                  |  |
| Digital\Read Values\ReadDigPort\CS\ ReadDigPort.sln                                     | Demonstrates how to read a single value from a digital port.                                                                                                                                                                                                                                                              |  |

## Browsing and Searching for Examples in NI Example Finder

Use NI Example Finder to browse and to search for examples.

You can use NI Example Finder to find examples for the following products.

- LabVIEW
- LabWindows/CVI
- NI drivers accessible from LabVIEW
- NI drivers accessible from LabWindows/CVI
- 1. Launch LabVIEW or LabWindows/CVI.
- 2. Open NI Example Finder.

| Option  | Description                                |
|---------|--------------------------------------------|
| LabVIEW | Select Help » Find Examples. from the menu |

| Option         | Description                                                               |
|----------------|---------------------------------------------------------------------------|
|                | bar.                                                                      |
| LabWindows/CVI | Click <b>Find Examples</b> from the Examples section of the Welcome Page. |

NI Example Finder launches.

- 3. Optional: Configure NI Example Finder for LabWindows/CVI.
  - a. Click **Setup**. Configure Example Finder opens.
  - b. In Configure Example Finder, click Software, then select LabWindows/CVI, and click OK.

NI Example Finder updates with all the examples for LabWindows/CVI.

4. Search the example VIs for your product.

| Option                | Description                                                                                                                                                                                                                    |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Click the Browse tab. | Choose <b>Browse</b> when you want to drill down through folders to find examples organized by task category.                                                                                                                  |
|                       | Tip Examples installed with NI drivers or third-party drivers are often found within the Hardware Input and Output folder. Examples installed with toolkits or modules are often found within the Toolkits and Modules folder. |
| Click the Search tab. | Choose <b>Search</b> when you want to find examples by searching for topics, products, or modules relevant to your application.                                                                                                |

5. To open an example, double-click the folder or the example.



**Tip** You can modify an example VI to fit your application. You can also copy and paste from one or more examples into a VI that you create.

# **USB-6451 Front Panel**

Use the front panel to identify the connectors and LEDs of the USB-6451.

Figure 5. USB-6451 Front Panel



- 1. USB PWR LED
- 2. Al connector
- 3. AO/DIO connector
- 4. USER LED

#### **USB PWR LED**

The USB PWR LED indicates the power status and communication activity.

Table 7. USB-6451 USB PWR LED Indicator Status

| Color | Pattern  | Meaning                                                                           |
|-------|----------|-----------------------------------------------------------------------------------|
| Off   | _        | The USB-6451 is not powered or not ready                                          |
| Green | Solid    | The USB-6451 is powered and ready but not actively communicating with the host PC |
|       | Blinking | USB-6451 is powered on and actively communicating with the host PC                |

#### Why Is the USB PWR LED Off?

The USB PWR LED remains off when the USB-6451 is not powered or ready for operation.

This could be caused by the following reasons:

- The USB cable is not connected.
- The upstream PC or hub is not connected.
- The PC has put the USB-6451 into a low-power suspend or sleep state.
- The PC does not have a version of NI-DAQmx installed that supports the USB-6451.
- The USB-6451 is busy updating firmware.



**Note** When you connect the USB-6451 to a computer that has a different version of NI-DAQmx installed than the computer that the USB-6451 was connected to previously, NI-DAQmx checks to see if the USB-6451 requires a firmware update. If it does, the USB-6451 automatically updates the firmware. This update may take several minutes. During this time, the LED will remain off until the USB-6451 is ready. Leave the USB-6451 connected to the computer during this time.

#### **AI Connector**

Provides pins for analog input signal connections.

#### **Related reference:**

• <u>USB-6451 Al Connector Pinout</u>

#### **AO/DIO Connector**

Provides pins for analog output and digital I/O signal connections.

#### Related reference:

USB-6451 AO/DIO Connector Pinout

#### **USER LED**

You can program the USER LED to communicate status information specific to your application.

The USER LED is off by default. You can configure it to the following settings.

- Off
- Solid green
- Solid yellow
- Solid red
- Blinking green
- · Blinking yellow
- Blinking red

#### Configuring the User LED in Hardware Configuration Utility

Complete the following steps to configure the USER LED in Hardware Configuration Utility.

- 1. Select the USB-6451 from the list of connected devices in the System Pane.
- 2. In the Configuration Pane, select an option from the LED Settings drop-down list.

## USB-6451 Rear Panel

Use the rear panel to identify the features and connectors of the USB-6451.

Figure 6. USB-6451



- 1. Chassis ground lug
- 2. USB Type-C connector
- 3. USB Type-C jack socket
- 4. Security lock slot
- 5. Setup QR code

#### **Chassis Ground Lug**

Use the chassis ground lug to connect the USB-6451 to earth ground. Ensure this screw is always attached during operation because it also secures the USB connector.

#### **USB Type-C Connector**

Use the USB Type-C connector to connect the USB-6451 to a host computer through a USB Type-C cable.

## **Security Lock**

Insert a security cable to secure the USB-6451.

## **Setup QR Code**

Use the QR code on the USB-6451 to access the setup page. You can also access the

setup page by going to ni.com/64xx-setup.

# **USB-6451 Pinouts**

#### **USB-6451 AI Connector Pinout**

Use the pinout to connect to analog input terminals on the USB-6451.

Figure 7. USB-6451 Al Connector Pinout



Table 8. USB-6451 AI Connector Pin Assignments

| Pin | Signal     |
|-----|------------|
| 1   | AI 8       |
| 2   | AI 9       |
| 3   | AI 10      |
| 4   | AI 11      |
| 5   | AI 12      |
| 6   | AI 13      |
| 7   | AI 14      |
| 8   | AI 15      |
| 9   | AI GND     |
| 10  | No connect |
| 11  | No connect |
| 12  | No connect |
| 13  | No connect |
| 14  | No connect |

| Pin | Signal        |
|-----|---------------|
| 15  | No connect    |
| 16  | No connect    |
| 17  | No connect    |
| 18  | CHSGND        |
| 19  | AI 0          |
| 20  | Al 1          |
| 21  | AI 2          |
| 22  | AI 3          |
| 23  | Al 4          |
| 24  | AI 5          |
| 25  | AI 6          |
| 26  | AI 7          |
| 27  | NR (AI SENSE) |
| 28  | No connect    |
| 29  | No connect    |
| 30  | No connect    |
| 31  | No connect    |
| 32  | No connect    |
| 33  | No connect    |
| 34  | No connect    |
| 35  | No connect    |
| 36  | ID 0          |

Table 9. USB-6451 AI Connector Signal Descriptions

| ·       |                       |           |           |                                                                                       |
|---------|-----------------------|-----------|-----------|---------------------------------------------------------------------------------------|
| Signal  | Function              | Reference | Direction | Description                                                                           |
| AI <07> | Analog input channels | Varies    | Input     | Supports differential or single-ended measurement modes. The default configuration is |

| Signal           | Function                  | Reference | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------|---------------------------|-----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |                           |           |           | differential mode.  In differential mode, these channels are the positive input for the differential pair. The negative input of the differential pair is located directly beneath the positive input.  In single-ended mode, each signal is a separate analog input voltage channel. The ground reference in single-ended mode is configurable. In referenced single-ended (RSE) mode, AI GND is the reference for the voltage measurement. In non-referenced single-ended (NRSE) mode, the NR pin is the reference.  Note You can configure the input mode per channel. |
| AI<br><815>      | Analog input channels     | Varies    | Input     | Supports single-ended measurements only. The default configuration is RSE mode. In RSE mode, AI GND is the reference for the voltage measurement. In NRSE mode, the NR pin is the reference.  For differential measurements, refer to the descriptions for AI <07>.                                                                                                                                                                                                                                                                                                       |
| AI GND           | Analog input ground       | _         | _         | The reference point for single-ended measurements in RSE mode and the bias current return point for differential measurements.  AI GND, AO GND, D GND, and CHSGND are all connected internally.                                                                                                                                                                                                                                                                                                                                                                           |
| NR (AI<br>SENSE) | AI SENSE for<br>NRSE mode | _         | Input     | The AI SENSE pin is labeled "NR" because it is used when the input terminal is configured to NRSE mode. In NRSE mode, AI SENSE acts as a remote sense of a reference voltage that can be at a different voltage potential than AI GND.                                                                                                                                                                                                                                                                                                                                    |

| Signal | Function                                        | Reference | Direction       | Description                                                                                                                                                                               |
|--------|-------------------------------------------------|-----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CHSGND | Chassis<br>ground                               | _         | _               | Connects directly to the chassis ground of the USB-6451 enclosure. It can be used as a termination point for shielded cables to help improve measurement quality.                         |
| ID 0   | Identification<br>pin 0 for the<br>Al connector | D GND     | Input or output | Can be connected to a 1-wire EEPROM for storing test setup identification information. Leave this pin open if you do not use it. Refer to the <i>ID Pin</i> section for more information. |

#### **Related reference:**

- Analog Input Terminal Configurations
- USB-6451 ID Pin

## **USB-6451 AO/DIO Connector Pinout**

Use the pinout to connect to analog output and digital input/output terminals on the USB-6451.

Figure 8. USB-6451 AO/DIO Connector Pinout



Table 10. USB-6451 AO/DIO Connector Pin Assignments

| Pin | Signal |
|-----|--------|
| 1   | CHSGND |
| 2   | AO GND |
| 3   | AO GND |
| 4   | AO GND |

| Pin | Signal                      |  |
|-----|-----------------------------|--|
| 5   | AO GND                      |  |
| 6   | D GND                       |  |
| 7   | D GND                       |  |
| 8   | PFI 8/P0.8 (port0/line8)    |  |
| 9   | PFI 9/P0.9 (port0/line9)    |  |
| 10  | D GND                       |  |
| 11  | PFI 10/P0.10 (port0/line10) |  |
| 12  | PFI 11/P0.11 (port0/line11) |  |
| 13  | D GND                       |  |
| 14  | PFI 12/P0.12 (port0/line12) |  |
| 15  | PFI 13/P0.13 (port0/line13) |  |
| 16  | D GND                       |  |
| 17  | PFI 14/P0.14 (port0/line14) |  |
| 18  | PFI 15/P0.15 (port0/line15) |  |
| 19  | ID 1                        |  |
| 20  | AO 0                        |  |
| 21  | AO 1                        |  |
| 22  | No connect                  |  |
| 23  | No connect                  |  |
| 24  | +5 V                        |  |
| 25  | PFI 0/P0.0 (port0/line0)    |  |
| 26  | PFI 1/P0.1 (port0/line1)    |  |
| 27  | D GND                       |  |
| 28  | PFI 2/P0.2 (port0/line2)    |  |
| 29  | PFI 3/P0.3 (port0/line3)    |  |
| 30  | D GND                       |  |
| 31  | PFI 4/P0.4 (port0/line4)    |  |

| Pin | Signal                   |
|-----|--------------------------|
| 32  | PFI 5/P0.5 (port0/line5) |
| 33  | D GND                    |
| 34  | PFI 6/P0.6 (port0/line6) |
| 35  | PFI 7/P0.7 (port0/line7) |
| 36  | D GND                    |

Table 11. USB-6451 AO/DIO Connector Signal Descriptions

| Signal                | Function                       | Reference | Direction       | Description                                                                                                                                                                                                                                                                                                   |
|-----------------------|--------------------------------|-----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AO <01>               | Analog<br>output<br>channels   | AO GND    | Output          | Supplies the voltage output of the AO channels.                                                                                                                                                                                                                                                               |
| AO GND                | Analog<br>output<br>ground     | _         | _               | AO GND is the reference for the AO channels.  AI GND, AO GND, D GND, and CHSGND are all connected internally.                                                                                                                                                                                                 |
| +5 V                  | +5 V power source              | D GND     | Output          | Provides current limited +5 V power output that can be used to power external circuitry. Refer to the +5 V Power Source section for more information. Leave this pin open if you do not use it.                                                                                                               |
| PFI<br><015>/P0.<015> | Port 0 digital<br>I/O channels | D GND     | Input or output | Digital channels that can be individually configured as input or output.  These channels are referred to as port0/line0:15 in software when used as digital I/O. They are referred to as PFI 0:15 when used for other purposes, like timing I/O.  Can also be individually configured for the following uses. |

| Signal | Function                                               | Reference | Direction       | Description                                                                                                                                                                                                                                                         |
|--------|--------------------------------------------------------|-----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                                                        |           |                 | <ul> <li>Digital I/O</li> <li>Counter/timer input</li> <li>Counter/timer output</li> <li>External timing or trigger signal input for AI, AO, DI, DO, counter, or timers</li> <li>Timing or trigger signal output from AI, AO, DI, DO, counter, or timers</li> </ul> |
| D GND  | Digital<br>ground                                      | _         | _               | Supplies the reference for the P0.<015> pins and +5 V pin.  AI GND, AO GND, D GND, and CHSGND are all connected internally.                                                                                                                                         |
| CHSGND | Chassis<br>ground                                      | _         | _               | Connects directly to the chassis ground of the USB-6451 enclosure. It can be used as a termination point for shielded cables to help improve measurement quality.                                                                                                   |
| ID 1   | Identification<br>pin 1 for the<br>AO/DIO<br>connector | D GND     | Input or output | Can be connected to a 1-wire EEPROM for storing test setup identification information. Leave this pin open if you do not use it. Refer to the <i>ID Pin</i> section for more information.                                                                           |

### **Related reference:**

- USB-6451 +5 V Power Source
- <u>USB-6451 ID Pin</u>

# USB-6451 +5 V Power Source

The +5 V terminals on the I/O connector supply +5 V referenced to D GND. Use these terminals to power external circuitry.



**Notice** Never connect the +5 V power terminals to analog or digital ground or to any other voltage source on the USB-6451 or any other device. Doing so can damage the device and the computer. NI is not liable for damage resulting from such a connection.

Refer to the *USB-6451 Specifications* for more information about the USB-6451 power rating.

#### **Related information:**

• USB-6451 Specifications

# USB-6451 ID Pin

Use the ID pin to connect the USB-6451 to a 1-wire EEPROM.

The ID pin on the USB-6451 allows you to read from and to write to a 1-wire EEPROM. You can use it to build systems that can support the following workflows and more.

- Confirm the identity of the DUT connected to the USB-6451.
- Confirm that cables are connected properly.
- Read and save fixture-specific information, such as calibration constants, mating cycles, and more.
- Read and save setup information from a connected information, such as wiring or virtual channel information.

The ID pin API is available in LabVIEW, C, C#, and Python.

## **Supported EEPROM Families**

The USB-6451 supports a limited number of EEPROM families. Verify that the family code of your EEPROM is compatible before using it.

Refer to the following table for a list of supported family codes.

Table 12. EEPROM Family Codes Supported by the USB-6451

| Family Code | Example Device | EEPROM Size |
|-------------|----------------|-------------|
| 0x01        | DS2401+        | N/A         |
| 0x14        | DS2430A+       | 32 bytes    |
| 0x2D        | DS2431+        | 128 bytes   |
| 0x23        | DS24B33+       | 512 bytes   |
| 0x43        | DS28EC20+      | 2,560 bytes |

## Connecting the ID Pin to an EEPROM

1. Verify that the family code of the EEPROM is compatible with the USB-6451.

- 2. Connect the I/O pin of a supported 1-wire EEPROM to the ID pin.
- 3. Connect the ground of a supported 1-wire EEPROM to digital ground.

Figure 9. USB-6451 ID Pin to 1-Wire EEPROM Connection Diagram





**Note** NI recommends connecting to digital ground, but you can connect to chassis ground instead for convenience.

#### Related reference:

- USB-6451 AO/DIO Connector Pinout
- USB-6451 Al Connector Pinout

## VIs for Reading from and Writing to the EEPROM

Use the DAQmx Read ID Pin Memory and DAQmx Write ID Pin Memory VIs to read from and write to the EEPROM connected to the ID pin on the USB-6451.

The DAQmx Read ID Pin Memory VI reads and returns the data stored in the memory attached to the specified ID pin. Use the DAQmx Read ID Pin Memory VI to read the following information from the EEPROM connected to the USB-6451.

- The format code of the data.
- The data itself.

Figure 10. DAQmx Read ID Pin Memory VI

DAQmx Read ID Pin Memory.vi



The DAQmx Writes ID Pin Memory VI writes the supplied data and format code to the EEPROM connected to the specified ID pin. Use the DAQmx Write ID Pin Memory VI to write the following information from the EEPROM connected to the USB-6451.

- Format code of the data.
- · The data itself.

Figure 11. DAQmx Write ID Pin Memory VI DAQmx Write ID Pin Memory.vi



The following image shows an example of a simple VI to write to and read from a connected EEPROM.

Figure 12. Example VI



- 1. DAQmx device property node that you can use to access the ID pin properties.
- 2. Format code that denotes a UTF-8 string.
- 3. Loop through each ID pin.
- 4. Only access the ID pin if it is connected to the EEPROM.
- 5. DAQmx Read ID Pin Memory reads from the selected ID pin.
- 6. DAQmx Write ID Pin Memory writes to the selected ID pin.
- 7. Function that converts data from a string to a binary array.

The following table lists the data format codes that are supported by the USB-6451.

Table 13. Data Format Codes Supported by the USB-6451

| Format Code | Description         |
|-------------|---------------------|
| 0x01        | UTF-8 String        |
| 0x100x7F    | Available for users |
| other       | Reserved            |

You can use property nodes to store the following information. To find the properties related to the ID pin, right-click the DAQmx device property node and select **Identification** » **ID Pin**.

- Family code of the EEPROM.
- Size of the EEPROM.
- Serial number of the EEPROM.

# Analog Input Measurements

Learn about making analog input measurements with the USB-6451.

## Analog Input Range

Input range refers to the set of input voltages that an analog input channel can digitize with the specified accuracy. The NI-PGIA amplifies or attenuates the AI signal depending on the input range. You can individually program the input range of each AI channel on your USB-6451.

The input range affects the resolution of the USB-6451 for an AI channel. Resolution refers to the voltage of one ADC code. For example, a 20-bit ADC converts analog inputs into one of 1,048,576 possible digital values. These values are spread fairly evenly across the input range. So, for an input range of -10 V to 10 V the voltage of each code of a 20-bit ADC is:

$$\frac{10 \ V - (-10 \ V)}{2^{20}} = 19.07 \ \mu \ V$$

The USB-6451 uses a calibration method that requires some codes to lie outside of the specified range. This calibration method improves absolute accuracy, but it increases the nominal resolution of input ranges by about 4% over what the formula shown above would indicate.

Choose an input range that matches the expected input range of your signal. A large input range can accommodate a large signal variation, but reduces the voltage resolution. Choosing a smaller input range improves the voltage resolution, but may result in the input signal going out of range.

Table 14. USB-6451 Input Range and Nominal Resolution

| Input Range (V) | Nominal Resolution (μV) |  |
|-----------------|-------------------------|--|
| 10              | 19.87                   |  |
| 5               | 9.94                    |  |
| 2.5             | 4.97                    |  |

| Input Range (V) | Nominal Resolution (μV) |
|-----------------|-------------------------|
| 0.2             | 0.40                    |

## Working Voltage Range

The NI programmable gain instrumentation amplifier (NI-PGIA) operates normally by amplifying signals of interest while rejecting common-mode signals under certain conditions.

- Common-mode voltage (*Vcm*)—The voltage of measurement reference potential versus AI GND. It depends on the configuration of the input terminal.
- **Signal voltage** (*Vs*)—The value you are trying to measure. It depends on the configuration of the input terminal.
- Total working voltage of the positive input—Equivalent to (*Vcm* + *Vs*), or subtracting AI GND from AI <0..x>+. Must be less than the maximum working range specified in the *USB-6451 Specifications*.

If any of these conditions are exceeded, the input voltage is clamped until the fault condition is removed.

Table 15. Common-Mode Voltage, Vcm

| Input Terminal Configuration            | Condition                                                                                                                                                                                                                |
|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Differential Mode                       | <b>Vcm</b> is equal to the voltage on AI <x>- vs. AI GND, where AI<x>- is the negative half of the differential pair. Refer to the <b>Differential Connections for Ground-Referenced Signal Sources</b> section.</x></x> |
| Referenced Single-Ended (RSE) Mode      | Vcm is equal to 0 V since AI GND is the reference for the measurement. Refer to the Non-Referenced Single-Ended (NRSE) Connections for Ground-Referenced Signal Sources section.                                         |
| Non-referenced Single-Ended (NRSE) Mode | <b>Vcm</b> is equal to the voltage on the NR pin vs. AI GND.                                                                                                                                                             |

Table 16. Signal Voltage, *Vs* 

| Input Terminal Configuration | Condition                                                                                                           |
|------------------------------|---------------------------------------------------------------------------------------------------------------------|
| Differential Mode            | <b>Vs</b> is equal to AI <x>+ minus AI<x>-, where AI<x>- is the negative half of the differential pair.</x></x></x> |
| RSE Mode                     | <b>Vs</b> is equal to AI <x> minus AI GND.</x>                                                                      |
| NRSE Mode                    | <b>Vs</b> is equal to AI <x> minus the voltage on the NR pin.</x>                                                   |

#### **Related concepts:**

- <u>Differential Connections for Ground-Referenced Signal Sources</u>
- Non-Referenced Single-Ended (NRSE) Connections for Ground-Referenced Signal **Sources**

## **Analog Input Terminal Configurations**

The USB-6451 supports three analog input terminal configurations: differential mode, referenced single-ended mode, and non-referenced single-ended mode.

- Differential mode—The USB-6451 measures the difference in voltage between two AI signals
- Referenced single-ended (RSE) mode—The USB-6451 measures the voltage of an Al signal relative to Al GND.
- Non-referenced single-ended (NRSE) mode—The USB-6451 measures the voltage of an AI signal relative to the NR pin (AI SENSE).

The AI terminal configuration determines the ground reference for your measurement and affects how you should connect your AI signals to the USB-6451.

Ground-reference settings are programmed on a per-channel basis. For example, you might configure the USB-6451 to scan 12 channels—four differentially-configured channels and eight single-ended channels.

The following table shows how signals are routed to the NI programmable gain instrumentation amplifier (NI-PGIA) on the USB-6451.

Table 17. Signals Routed to the NI-PGIA on the USB-6451

| Al Ground-Reference Settings | Signals Routed to the Positive Input of the NI-PGIA (Vin+) | Signals Routed to the Negative Input of the NI-PGIA (Vin-) |
|------------------------------|------------------------------------------------------------|------------------------------------------------------------|
| RSE                          | AI <015>                                                   | AI GND                                                     |
| NRSE                         | AI <015>                                                   | NR (AI SENSE)                                              |
| Differential                 | AI <07>                                                    | AI <815>                                                   |



**Note** You can only include a channel a single time in a given scan. When a specific channel is configured for differential mode, you cannot use the positive or negative inputs from that same channel for referenced single-ended or non-referenced single-ended measurements.



**Note** All channels must share the same measurement reference, either referenced single-ended or non-referenced single-ended, when performing single-ended measurements.

For differential measurements, AI 0 and AI 8 are the positive and negative inputs of differential analog input channel 0.



**Notice** The maximum input voltages rating of AI signals with respect to ground (and for signal pairs in differential mode with respect to each other) are listed in the device specifications. Exceeding the maximum input voltage of AI signals distorts the measurement results. Exceeding the maximum input voltage rating can also damage the device and the computer. NI is not liable for any damage resulting from such signal connections. AI ground-reference setting is sometimes referred to as AI terminal configuration.

#### **Related reference:**

• Analog Input Signal Connections

### **USB-6451 Differential Mode Pairs**

• AI <0, 8>

- Al <1, 9>
- Al <2, 10>
- AI <3, 11>
- AI <4, 12>
- AI <5, 13>
- AI <6, 14>
- AI <7, 15>

## **Dual-Channel Scanning**

The USB-6451 uses dual-channel scanning mode to sample both channels of a differential pair as two separate single-ended channels.

In dual-channel scanning mode, the USB-6451 samples the positive channel first then samples the negative channel later. An AI Convert Clock Signal, which is generated internally, controls the time between the positive channel and negative channel samples. This signal is not available for routing or triggering.

Dual-channel scanning mode is enabled automatically any time you are using two separate single-ended channels that are connected to a single analog-to-digital converter (ADC). In dual-channel scanning mode, the NI programmable gain instrumentation amplifier (NI-PGIA) is configured to the same gain and range for both channels. The NI-PGIA uses a range large enough to work for both channels.

To control the timing of the AI Convert Clock Signal, use the NI-DAQmx property node Al Convert Rate.

### Al Convert Rate

The AI Convert Rate property directly affects the settling time when switching between channels.

**Settling time** refers to the time it takes the NI-PGIA to amplify the channel signal to the desired accuracy before it is sampled by the ADC.

By default, NI-DAQmx chooses the fastest conversion rate possible based on the speed of the ADC. NI-DAQmx adds 10 µs of padding between each channel to allow for

sufficient settling time. This scheme enables the channels to approximate simultaneous sampling and still allow for sufficient settling time. If the sample clock rate is too fast to allow for this 10 µs of padding, NI-DAQmx chooses the conversion rate so that the convert clock pulses are spaced evenly throughout the sample.

For example, the USB-6451 has a maximum sample rate of 1 MS/s, which is the maximum speed of the ADC. The time for a conversion at this rate is 1  $\mu$ s. Taking into account the additional 10  $\mu$ s padding, a single channel of data acquisition will require an 11  $\mu$ s period or a frequency of 90.909 kHz when scanning dual channels.

Once your aggregate rate exceeds 90.909 kHz, there will not be enough time between samples to acquire both channels and still add 10 µs of delay per channel. In this case, the convert clock rate is equal to twice the sample rate. For example, if the sample clock rate is 500 kS/s, then the convert clock rate will be 1 MS/s.

At a slower acquisition rate, such as 10 kHz with dual channels, the convert clock is faster than your aggregate rate of 20 kS/s (10 kS/s/ch \* 2 ch). The convert clock will pulse 1  $\mu$ s to signal the first conversion, wait for 10  $\mu$ s to settle, pulse for 1  $\mu$ s to signal the second conversion, then wait another 10  $\mu$ s to settle. At this point, the convert clock stays LOW until the next rising edge of the sample clock.

For application that require a settling time greater than 10  $\mu$ s, use the NI-DAQmx AI Convert Clock Rate property node or function to increase the convert period or decrease the convert rate to meet the settling time requirement. To have balanced settling time for dual-scanned channels at a rate slower than 90.909 kHz, set the convert clock to aggregate rate so that the convert clock pulses are evenly spaced throughout the sample.



**Notice** Setting the conversion rate higher than the maximum rate specified for your device will result in errors.

## **Guidelines for Fast Settling Time**

Settling time affects accuracy in dual-channel scanning mode.

The USB-6451 is designed to have fast settling times. However, several factors can increase the settling time, which decreases the accuracy of your measurements. To

ensure fast settling times, do the following (in order of importance):

- 1. Use low-impedance sources.
- 2. Use short, high-quality cabling.
- 3. Carefully choose the channel scanning order.
- 4. Avoid scanning faster than necessary.

#### **Use Low-Impedance Sources**

Your signal sources should have an impedance of  $<1 \text{ k}\Omega$  to ensure fast settling times. Large source impedances increase the settling time of the NI-PGIA, and so decrease the accuracy at fast scanning rates.

Settling times increase when scanning high-impedance signals due to a phenomenon called *charge injection*. Multiplexers contain switches, usually made of switched capacitors. When one of the channels, for example channel 0, is selected in a multiplexer, those capacitors accumulate charge. When the next channel, for example channel 1, is selected, the accumulated charge leaks backward through channel 1. If the output impedance of the source connected to channel 1 is high enough, the resulting reading of channel 1 can be partially affected by the voltage on channel 0. This effect is referred to as **ghosting**.

If your source impedance is high, you can decrease the scan rate to allow the NI-PGIA more time to settle. Another option is to use a voltage follower circuit external to the USB-6451 to decrease the impedance seen by the USB-6451.

### **Use Short, High-Quality Cabling**

Using short, high-quality cables can minimize several effects that degrade accuracy including crosstalk, transmission line effects, and noise.

The capacitance of the cable can also increase the settling time. NI recommends using individually shielded, twisted-pair wires that are 2 m or less to connect AI signals to the USB-6451.

### **Carefully Choose the Channel Scanning Order**

### Minimize Voltage Step between Adjacent Channels

When scanning between channels that have the same input range, the settling time increases with the voltage step between the channels. If you know the expected input range of your signals, you can group signals with similar expected ranges together in your scan list. For example, group the input channel connection with closest voltage level in the same input range in pair for the scanning.

#### **Avoid Scanning Faster Than Necessary**

Designing your system to scan at slower speeds gives the NI-PGIA more time to settle to a more accurate level.

## Example 1

Averaging many AI samples can increase the accuracy of the reading by decreasing noise effects. In general, the more points you average, the more accurate the final result. However, you may choose to decrease the number of points you average and slow down the scanning rate.

Suppose you want to sample 10 channels over a period of 20 ms and average the results. You could acquire 500 points from each channel at a scan rate of 250 kS/s. Another method would be to acquire 1,000 points from each channel at a scan rate of 500 kS/s. Both methods take the same amount of time. Doubling the number of samples averaged (from 500 to 1,000) decreases the effect of noise by a factor of 1.4 (the square root of 2). However, doubling the number of samples (in this example) decreases the time the NI-PGIA has to settle from 4  $\mu$ s to 2  $\mu$ s. In some cases, the slower scan rate system returns more accurate results.

## Example 2

If the time relationship between channels is not critical, you can sample from the same channel multiple times and scan less frequently. For example, suppose an application requires averaging 100 points from channel 0 and averaging 100 points from channel 1. You could alternate reading between channels—that is, read one point from channel 0, then one point from channel 1, and so on. You also could read all 100 points

from channel 0 then read 100 points from channel 1. The second method switches between channels much less often and is affected much less by settling time.

## Analog Input Data Acquisition Methods

When performing analog input measurements, you either can perform software-timed or hardware-timed acquisitions.

## **Software-Timed Acquisitions**

With a software-timed acquisition, software controls the rate of the acquisition.

Software sends a separate command to the hardware to initiate each ADC conversion. In NI-DAQmx, software-timed acquisitions are referred to as having **on-demand** timing. Software-timed acquisitions are also referred to as immediate or static acquisitions and are typically used for reading a single sample of data.

## **Hardware-Timed Acquisitions**

With hardware-timed acquisitions, a digital hardware signal controls the rate of the acquisition. This signal can be generated internally on the USB-6451 or provided externally.

Hardware-timed acquisitions have several advantages over software-timed acquisitions:

- The time between samples can be much shorter.
- The timing between samples is deterministic.
- Hardware-timed acquisitions can use hardware triggering.

Hardware-timed operations are buffered. In a buffered acquisition, data is moved efficiently from the onboard FIFO memory of the USB-6451 to a PC buffer using USB signal streaming before it is transferred to application memory. Buffered acquisitions typically allow for much faster transfer rates than non-buffered acquisitions because data is moved in large blocks, rather than one point at a time.

One property of buffered I/O operations is the sample mode. The sample mode can be

#### either finite or continuous.

- **Finite sample mode**—Acquires a specific, predetermined number of data samples. After the specified number of samples has been read in, the acquisition stops. If you use a reference trigger, you must use finite sample mode.
- Continuous sample mode—Acquires an unspecified number of samples. Instead of acquiring a set number of data samples and stopping, a continuous acquisition continues until you stop the operation.

If data cannot be transferred across the bus fast enough, or if the user program does not read data out of the PC buffer fast enough to keep up with the data transfer, the buffer could reach an overflow condition, causing an error to be generated.



**Note** The USB-6451 does not support hardware-timed single-point mode.

## Analog Input Signal Connections

You can connect floating signal sources and ground-referenced signal sources to the USB-6451.

## Floating Signal Sources (Not Connected to Building Ground)

Examples of floating signal sources include ungrounded thermocouples, signal conditioning with isolated outputs, and battery devices.

Figure 13. Differential Mode Floating Signal Sources Connections
Signal Source USB-64xx



Figure 14. Non-Referenced Single-Ended (NRSE) Mode Floating Signal Sources Connections



Figure 15. Referenced Single-Ended (RSE) Mode Floating Signal Sources Connections Signal Source



## **Ground-Referenced Signal Sources**

Examples of ground-references signal sources include plug-in instruments with nonisolated outputs.

Figure 16. DIFF Mode Ground-Referenced Signal Sources Connections



Figure 17. NRSE Mode Ground-Referenced Signal Sources Connections



NI does no recommend connecting ground-referenced signal sources in RSE mode.

Figure 18. RSE Mode Ground-Referenced Signal Sources Connections

#### **NOT RECOMMENDED**



Ground-loop potential  $(V_A - V_B)$  are added to measured signal.

Refer to the following sections for more information on connecting signals to the USB-6451

#### Related reference:

Analog Input Terminal Configurations

## Floating Signal Sources Connections

A **floating signal source** is a signal source that is not connected to the building ground system, but has an isolated ground-reference point.

Some examples of floating signal sources are outputs of transformers, thermocouples, battery-powered devices, optical isolators, and isolation amplifiers. An instrument or device that has an isolated output is a floating signal source.

### **Differential Connections for Floating Signal Sources**

Differential signal connections reduce noise pickup and increase common-mode noise rejection. Differential signal connections also allow input signals to float within the common-mode limits of the NI programmable gain instrumentation amplifier (NI-PGIA).

Use differential input connections for any channel that meets any of the following conditions:

- The input signal is low level (less than 1 V).
- The leads connecting the signal to the USB-6451 are greater than 3 m (10 ft).
- The input signal requires a separate ground-reference point or return signal.
- The signal leads travel through noisy environments.
- Two analog input channels, AI+ and AI-, are available for the signal.

It is important to connect the negative lead of a floating source to AI GND (either directly or through a bias resistor). Otherwise, the source may float out of the maximum working voltage range of the NI-PGIA and the USB-6451 returns erroneous data.

The easiest way to reference the source to AI GND is to connect the positive side of the signal to AI+ and connect the negative side of the signal to AI GND as well as to AIwithout using resistors. This connection works well for DC-coupled sources with low source impedance (less than 100  $\Omega$ ).

Figure 19. Differential Connections for Floating Signal Sources without Bias Resistors



However, for larger source impedances, this connection leaves the differential signal path significantly off balance. Noise that couples electrostatically onto the positive line does not couple onto the negative line because it is connected to ground. This noise appears as a differential mode signal instead of a common-mode signal, and thus appears in your data. In this case, instead of directly connecting the negative line to AI GND, connect the negative line to AI GND through a resistor that is about 100 times the equivalent source impedance. The resistor puts the signal path nearly in balance, so that about the same amount of noise couples onto both connections, yielding better rejection of electrostatically coupled noise. This configuration does not load down the source (other than the very high input impedance of the NI-PGIA).

Figure 20. Differential Connections for Floating Signal Sources with Single Bias Resistor



You can fully balance the signal path by connecting another resistor of the same value between the positive input and AI GND, as shown in the following figure. This fully balanced configuration offers slightly better noise rejection, but has the disadvantage of loading the source down with the series combination (sum) of the two resistors. If, for example, the source impedance is  $2 \text{ k}\Omega$  and each of the two resistors is  $100 \text{ k}\Omega$ , the resistors load down the source with  $200 \text{ k}\Omega$  and produce a -1% gain error.

Figure 21. Differential Connections for Floating Signal Sources with Balanced Bias Resistors



Both inputs of the NI-PGIA require a DC path to ground in order for the NI-PGIA to work. If the source is AC coupled (capacitively coupled), the NI-PGIA needs a resistor between the positive input and AI GND. If the source has low-impedance, choose a

resistor that is large enough not to significantly load the source, but small enough not to produce significant input offset voltage as a result of input bias current (typically 100 k $\Omega$  to 1 M $\Omega$ ). In this case, connect the negative input directly to AI GND. If the source has high output impedance, balance the signal path as previously described using the same value resistor on both the positive and negative inputs; be aware that there is some gain error from loading down the source, as shown in the following figure.

Figure 22. Differential Connections for AC Coupled Floating Sources with Balanced Bias Resistors



## Non-Referenced Single-Ended (NRSE) Connections for Floating Signal Sources

Only use NRSE input connections if the input signal meets the following conditions:

- The input signal is high-level (greater than 1 V).
- The leads connecting the signal to the USB-6451 are less than 3 m (10 ft).

Differential input connections are recommended for greater signal integrity for any input signal that does not meet the preceding conditions.

In the single-ended modes, more electrostatic and magnetic noise couples into the signal connections than in differential configurations. The coupling is the result of differences in the signal path. Magnetic coupling is proportional to the area between the two signal conductors. Electrical coupling is a function of how much the electric field differs between the two conductors.

With this type of connection, the NI programmable gain instrumentation amplifier (NI-PGIA) rejects both the common-mode noise in the signal and the ground potential difference between the signal source and the device ground.

It is important to connect the negative lead of a floating signals source to AI GND (either directly or through a resistor). Otherwise the source may float out of the valid input range of the NI-PGIA and the USB-6451 returns erroneous data.

The following figure shows a floating source connected to the USB-6451 in NRSE mode.

Figure 23. NRSE Connections for Floating Signal Sources



All of the bias resistor configurations discussed in the *Differential Connections for Floating Signal Sources* section apply to the NRSE bias resistors as well. Replace AI- with AI SENSE in the figures included in that section for configurations with zero to two bias resistors. The noise rejection of NRSE mode is better than RSE mode because the AI SENSE connection is made remotely near the source. However, the noise rejection of NRSE mode is worse than differential mode because the AI SENSE connection is shared with all channels rather than being cabled in a twisted pair with the AI+ signal.

You can use the DAQ Assistant to configure the channels for RSE or NRSE input modes.

### Referenced Single-Ended (RSE) Connections for Floating Signal Sources

Only use RSE input connections if the input signal meets the following conditions:

- The input signal can share a common reference point, AI GND, with other signals that use RSE.
- The input signal is high-level (greater than 1 V).
- The leads connecting the signal to the USB-6451 are less than 3 m (10 ft).

Differential input connections are recommended for greater signal integrity for any input signal that does not meet the preceding conditions.

In the single-ended modes, more electrostatic and magnetic noise couples into the signal connections than in differential configurations. The coupling is the result of differences in the signal path. Magnetic coupling is proportional to the area between the two signal conductors. Electrical coupling is a function of how much the electric field differs between the two conductors.

With this type of connection, the NI programmable gain instrumentation amplifier (NI-PGIA) rejects both the common-mode noise in the signal and the ground potential difference between the signal source and the device ground.

The following figure shows how to connect a floating signal source to the USB-6451 configured for RSE mode.



Figure 24. RSE Connections for Floating Signal Sources

You can use the DAQ Assistant to configure the channels for RSE or non-referenced single-ended (NRSE) input modes.

## **Ground-Referenced Signal Sources Connections**

A **ground-referenced signal source** is a signal source connected to the building system ground.

A ground-referenced signal source is already connected to a common ground point with respect to the USB-6451, assuming that the computer is plugged into the same power system as the source. Non-isolated outputs of instruments and devices that plug into the building power system fall into this category.

The difference in ground potential between two instruments connected to the same building power system is typically between 1 and 100 mV, but the difference can be much higher if power distribution circuits are improperly connected. If a grounded signal source is incorrectly measured, this difference can appear as measurement error. Follow the connection instructions for grounded signal sources to eliminate this ground potential difference from the measured signal.

### **Differential Connections for Ground-Referenced Signal Sources**

Differential signal connections reduce noise pickup and increase common-mode noise rejection. Differential signal connections also allow input signals to float within the common-mode limits of the NI-PGIA.

Use differential input connections for any channel that meets any of the following conditions.

- The input signal is low level (less than 1 V).
- The leads connecting the signal to the USB-6451 are greater than 3 m (10 ft).
- The input signal requires a separate ground-reference point or return signal.
- The signal leads travel through noisy environments.
- Two analog input channels, AI+ and AI-, are available for the signal.

The following figure shows how to connect a ground-referenced signal source to the USB-6451 configured in differential mode.



Figure 25. Differential Connections for Ground-Referenced Signal Sources

With this type of connection, the NI-PGIA rejects both the common-mode noise in the signal and the ground potential difference between the signal source and the device ground, shown as Vcm in the figure.

AI+ and AI- must both remain less than the maximum working range specified in the USB-6451 Specifications.

## Non-Referenced Single-Ended (NRSE) Connections for Ground-**Referenced Signal Sources**

Only use non-referenced signal-ended connections if the input signal meets the following conditions:

- The input signal is high-level (greater than 1 V).
- The leads connecting the signal to the USB-6451 are less than 3 m (10 ft).
- The input signal can share a common reference point with other signals.

Differential input connections are recommended for greater signal integrity for any input signal that does not meet the preceding conditions.

In the single-ended modes, more electrostatic and magnetic noise couples into the signal connections than in differential configurations. The coupling is the result of differences in the signal path. Magnetic coupling is proportional to the area between the two signal conductors. Electrical coupling is a function of how much the electric field differs between the two conductors.

With this type of connection, the NI Programmable Gain Instrumentation Amplifier (NI-PGIA) rejects both the common-mode noise in the signal and the ground potential difference between the signal source and the device ground.

The following figure shows how to connect ground-reference signal sources in NRSE mode.



Figure 26. Single-Ended Connections for Ground-Referenced Signal Sources (NRSE Configuration)

AI<0..15> and AI SENSE must both remain less than the maximum working range specified in the *USB-6451 Specifications*.

In this mode, NR (AI SENSE) is internally connected to the negative input of the NI-PGIA. Therefore, the ground point of the signal connects to the negative input of the NI-PGIA.

Any potential difference between the device ground and the signal ground appears as a common-mode signal at both the positive and negative inputs of the NI-PGIA, and this difference is rejected by the amplifier. If the input circuitry of a device were

referenced to ground, as it is in the RSE ground-reference setting, this difference in ground potentials would appear as an error in the measured voltage.

Using the DAQ Assistant, you can configure the channels for RSE or NRSE input modes.

## Referenced Single-Ended (RSE) Connections with Ground-Referenced **Signal Sources**

Do not use RSE connections with ground-referenced signal sources. Use nonreferenced single-ended or differential connections instead.

As illustrated in *Analog Input Signal Connections*, there can be a potential difference between AI GND and the ground of the sensor. In RSE mode, this ground loop causes measurement errors.

#### **Related reference:**

• Analog Input Signal Connections

## Field Wiring Considerations for Analog Input Signals

Environmental noise can seriously affect the measurement accuracy of the USB-6451 if you do not take proper care when running signal wires between signal sources and the USB-6451.

The following recommendations apply mainly to AI signal routing to the USB-6451, although they also apply to signal routing in general.

Minimize noise pickup and maximize measurement accuracy by taking the following precautions:

- Use differential analog input connections to reject common-mode noise.
- Use individually shielded, twisted-pair wires to connect AI signals to the USB-6451. With this type of wire, the signals attached to the positive and negative input channels are twisted together and then covered with a shield. You then connect this shield only at one point to the signal source ground. This kind of connection is required for signals traveling through areas with large magnetic fields or high electromagnetic interference.

#### **Related information:**

• Field Wiring and Noise Considerations for Analog Signals

## Analog Input Timing Engine

The USB-6451 has a flexible timing engine.

The following figure summarizes all of the timing options provided by the analog input timing engine.

Figure 27. USB-6451 Analog Input Timing Options



The USB-6451 uses AI Sample Clock (ai/SampleClock) to perform simultaneous sampling on all active analog channels. Since there is one ADC per channel, AI Sample Clock controls the sample period on all the channels in the task. The USB-6451 also uses AI Sample Clock (ai/SampleClock) and AI Convert Clock (ai/ConvertClock) to perform interval sampling in dual-channel scan mode.

As the following figure shows, AI Sample Clock controls the sample period, which is determined by the following equation:

1 | SamplePeriod = SampleRate

Figure 28. Interval Sampling



AI Convert Clock controls the Convert Period, which is determined by the following equation:

#### 1 | ConvertPeriod = ConvertRate

An acquisition with post-trigger data allows you to view data that is acquired after a trigger event is received. A typical post-trigger DAQ sequence is shown in the following figure. The sample counter is loaded with the specified number of post-trigger samples, in this example, five. The value decrements with each pulse on AI Sample Clock, until all desired samples have been acquired.

Figure 29. Typical Post-triggered DAQ Sequence



An acquisition with pre-trigger data allows you to view data that is acquired before the trigger of interest, in addition to data acquired after the trigger. The following figure shows a typical pre-trigger DAQ sequence. The AI Start Trigger signal (ai/StartTrigger) can be either a hardware or software signal. If AI Start Trigger is set up to be a software start trigger, an output pulse appears on the ai/StartTrigger line when the acquisition begins. When the AI Start Trigger pulse occurs, the sample counter is loaded with the number of pre-trigger samples, in this example, four. The value decrements with each pulse on AI Sample Clock. The sample counter is then loaded with the number of posttrigger samples, in this example, three.

Al Start Trigger

Al Reference Trigger

Al Sample Clock

1

2

0

2

2

Figure 30. Typical Pre-triggered DAQ Sequence

## **Analog Input Timing Signals**

The USB-6451 features six analog input timing signals.

2

• AI Sample Clock Signal

Sample Counter

- AI Sample Clock Timebase Signal
- AI Hold Complete Event Signal
- AI Start Trigger Signal
- AI Reference Trigger Signal
- Al Pause Trigger Signal

## AI Sample Clock Signal

Use the AI Sample Clock (ai/SampleClock) signal to initiate a set of measurements.

The USB-6451 samples the AI signals of every channel in the task once for every AI Sample Clock. A measurement acquisition consists of one or more samples.

You can specify an internal or external source for AI Sample Clock. You can also specify whether the measurement sample begins on the rising edge or falling edge of AI Sample Clock.

## Using an Internal Source

One of the following internal signals can drive AI Sample Clock:

- Counter *n* Internal Output
- AI Sample Clock Timebase (divided down)
- · A pulse initiated by host software

- Change Detection Event
- Counter **n** Sample Clock
- AO Sample Clock (ao/SampleClock)
- DI Sample Clock (di/SampleClock)
- DO Sample Clock (do/SampleClock)

A programmable internal counter divides down the sample clock timebase.

Several other internal signals can be routed to AI Sample Clock through internal routes.

### **Using an External Source**

Use DIO <0..15> as the source of AI Sample Clock.

### Routing AI Sample Clock Signal to an Output Terminal

You can route AI Sample Clock out to any DIO <0..15> terminal. This pulse is always active high.

### **Other Timing Requirements**

The USB-6451 only acquires data during an acquisition. It ignores AI Sample Clock when a measurement acquisition is not in progress. During a measurement acquisition, you can cause the USB-6451 to ignore AI Sample Clock using the AI Pause Trigger signal.

A counter/timing engine on your device internally generates AI Sample Clock unless you select some external source. AI Start Trigger starts this counter and either software or hardware can stop it once a finite acquisition completes. When using the AI timing engine, you can also specify a configurable delay from AI Start Trigger to the first AI Sample Clock pulse. By default, this delay is set to four ticks of the AI Sample Clock Timebase signal.

The following figure shows the relationship of AI Sample Clock to AI Start Trigger.

Figure 31. Al Sample Clock and Al Start Trigger



## AI Sample Clock Timebase Signal

Use the AI Sample Clock Timebase (ai/SampleClockTimebase) signal to specify a higher frequency timebase that will be divided down to produce the AI Sample Clock.

You can route any of the following signals to be the AI Sample Clock Timebase (ai/SampleClockTimebase) signal:

- 100 MHz Timebase (default)
- 20 MHz Timebase
- 100 kHz Timebase
- DIO <0..15>

AI Sample Clock Timebase is not available as an output on the I/O connector. AI Sample Clock Timebase is divided down to provide one of the possible sources for AI Sample Clock. You can configure the polarity selection for AI Sample Clock Timebase as either rising or falling edge, except on 100 MHz Timebase or 20 MHz Timebase.

## AI Hold Complete Event Signal

Use the AI Hold Complete Event (ai/HoldCompleteEvent) signal to generate a pulse after each A/D conversion begins.

You can route AI Hold Complete Event out to any DIO <0..15>.

The polarity of AI Hold Complete Event is software-selectable, but it is typically configured so that a low-to-high leading edge can clock external AI multiplexers indicating when the input signal has been sampled and can be removed.

## Al Start Trigger Signal

Use the AI Start Trigger (ai/StartTrigger) signal to begin a measurement acquisition.

A measurement acquisition consists of one or more samples. If you do not use triggers, begin a measurement with a software command. Once the acquisition begins, configure the acquisition to stop:

- When a certain number of points are sampled (in finite mode)
- After a hardware reference trigger (in finite mode)
- With a software command (in continuous mode)

An acquisition that uses a start trigger (but not a reference trigger) is sometimes referred to as a post-triggered acquisition.

## **Retriggerable Analog Input**

The AI Start Trigger is configurable as retriggerable. When the AI Start Trigger is configured as retriggerable, the timing engine generates the sample and convert clocks for the configured acquisition in response to each pulse on an AI Start Trigger signal.

The timing engine ignores the AI Start Trigger signal while the clock generation is in progress. After the clock generation is finished, the counter waits for another Start Trigger to begin another clock generation. The following figure shows a retriggerable analog input with three AI channels and four samples per trigger.





Note Waveform information from LabVIEW does not reflect the delay between triggers. They are treated as a continuous acquisition with constant t0 and t1 information.

Reference triggers are not retriggerable.

### **Using a Digital Source**

To use AI Start Trigger with a digital source, specify a source and an edge. The source can be any of the following signals:

- DIO <0..15>
- Counter *n* Internal Output

The source can also be one of several other internal signals on your DAQ device. Refer to **Device Routing in MAX** for more information.

You can also specify whether the measurement acquisition begins on the rising edge or falling edge of AI Start Trigger.

### **Routing AI Start Trigger to an Output Terminal**

You can route AI Start Trigger out to any DIO <0..15> terminal. The output is an active high pulse.

The USB-6451 also uses AI Start Trigger to initiate pre-triggered DAQ operations. In most pre-triggered applications, a software trigger generates AI Start Trigger.

Refer to the *Al Reference Trigger Signal* section for a complete description of the use of Al Start Trigger and Al Reference Trigger in a pre-triggered DAQ operation.

#### **Related information:**

• Device Routing in MAX

## Al Reference Trigger Signal

Use the AI Reference Trigger (ai/ReferenceTrigger) signal to stop a measurement acquisition.

To use a reference trigger, specify a buffer of finite size and a number of pre-trigger samples (samples that occur before the reference trigger). The number of post-trigger

samples (samples that occur after the reference trigger) desired is the buffer size minus the number of pre-trigger samples.

Once the acquisition begins, the USB-6451 writes samples to the buffer. After USB-6451 captures the specified number of pre-trigger samples, it begins to look for the reference trigger condition. If the reference trigger condition occurs before the USB-6451 captures the specified number of pre-trigger samples, it ignores the condition.

If the buffer becomes full, the USB-6451 continuously discards the oldest samples in the buffer to make space for the next sample. This data can be accessed (with some limitations) before the USB-6451 discards it. Refer to Can a Pre-triggered Analog **Acquisition be Continuous?** for more information.

When the reference trigger occurs, the USB-6451 continues to write samples to the buffer until the buffer contains the number of post-trigger samples desired. The following figure shows the final buffer.

Figure 33. Reference Trigger Final Buffer



#### **Using a Digital Source**

To use AI Reference Trigger with a digital source, specify a source and an edge. The source can be any of the following signals:

- DIO <0..15>
- Change Detection Event
- Counter *n* Internal Output
- DI Reference Trigger (di/ReferenceTrigger)
- DO Start Trigger (do/StartTrigger)
- AO Start Trigger (ao/StartTrigger)

The source can also be one of several internal signals on the USB-6451. Refer to **Device Routing in MAX** for more information.

You can also specify whether the measurement acquisition stops on the rising edge or falling edge of AI Reference Trigger.

## **Routing AI Reference Trigger Signal to an Output Terminal**

You can route AI Reference Trigger out to any DIO <0..15> terminal.

#### **Related information:**

- Device Routing in MAX
- Can a Pretriggered Analog Acquisition be Continuous?

## Al Pause Trigger Signal

Use the AI Pause Trigger (ai/PauseTrigger) signal to pause and resume a measurement acquisition.

The internal sample clock pauses while the external trigger signal is active and resumes when the signal is inactive. You can program the active level of the pause trigger to be high or low, as shown in the following figure. In the figure, T represents the period, and A represents the unknown time between the clock pulse and the post-trigger.



Figure 34. Halt (Internal Clock) and Free Running (External Clock)

### **Using a Digital Source**

To use AI Pause Trigger, specify a source and a polarity. The source can be one of the following signals:

- DIO <0..15>
- Counter *n* Internal Output
- Counter *n* Gate
- AO Pause Trigger (ao/PauseTrigger)
- DO Pause Trigger (do/PauseTrigger)
- DI Pause Trigger (di/PauseTrigger)

The source can also be one of several other internal signals on your DAQ device. Refer to **Device Routing in MAX** for more information.

### Routing AI Pause Trigger Signal to an Output Terminal

You can route AI Pause Trigger out to any DIO <0..15> terminal.



Note Pause triggers are only sensitive to the level of the source, not the edge.

#### **Related information:**

#### • Device Routing in MAX

# **Analog Triggering**

You can configure the analog trigger circuitry of the USB-6451 to monitor any analog input channel from which you acquire data.

Choosing an analog input channel as the trigger channel does not influence its acquisition capabilities.

You can use the analog trigger signal as a reference trigger only. This restriction is because the analog trigger circuit operates on digitized ADC data, requiring the acquisition to be running for the analog trigger circuit to operate. In a reference-triggered acquisition, you configure the device to acquire a certain number of pre-trigger samples and post-trigger samples.

The trigger circuit generates an internal digital trigger based on the input signal and the trigger levels you define.

For example, you can configure the USB-6451 to generate an analog comparison event after the input signal crosses a specific threshold. You can also route the resulting reference trigger event to other internal subsystems to synchronize the subsystems.

During repetitive triggering on a waveform, you might observe jitter. This jitter is caused by the uncertainty of where a trigger level falls compared to the actual digitized data. Although this trigger jitter is never greater than one sample period, it might be significant when the sample rate is only twice the bandwidth of interest. This jitter usually has no effect on data processing. You can decrease this jitter by sampling at a higher rate. Sampling at a rate less than twice the bandwidth of interest might cause the USB-6451 to detect the trigger signal less reliably.

You can use the following analog triggering modes with the USB-6451.

- Rising edge
- Rising edge with hysteresis
- Falling edge
- Falling edge with hysteresis
- · Entering window

Leaving window

**Analog Comparison** 

Reference Trigger

## **Analog Edge Triggering**

For analog edge triggering, configure the USB-6451 to detect a certain rising or falling signal level and slope.

The following figure shows an example of rising edge analog triggering. The trigger asserts when the signal starts below level and then crosses above level.



Figure 35. Analog Trigger Level on Rising Edge

## **Analog Edge Triggering with Hysteresis**

When you add hysteresis to analog edge triggering, you add a window above or below the trigger level.

You can use this trigger to reduce false triggering due to noise or jitter in the signal. For example, if you add a hysteresis of 1 V to the example in the figure above, which uses a level of 3.2 V, the signal must start at or drop below 2.2 V to arm the trigger. The trigger asserts when the signal rises above 3.2 V and deasserts when it falls below 2.2 V, as shown in the following figure.

Figure 36. Analog Edge Triggering with Hysteresis on Rising Slope



When using hysteresis with a falling slope, the trigger is armed when the signal starts above Level, plus the hysteresis value, and asserts when the signal crosses below level. For example, if you add a hysteresis of 1 V to a level of 3.2 V, the signal must start at or rise above 4.2 V to arm the trigger. The trigger asserts as the signal falls below 3.2 V and deasserts when it rises above 4.2 V, as shown in the following figure.

Figure 37. Analog Edge Triggering with Hysteresis on Falling Slope



### **Window Triggers**

A window trigger occurs when an analog signal either passes into (enters) or passes out of (leaves) a window defined by two levels.

Specify the levels by setting a value for the top and bottom window boundaries. The following figure demonstrates a trigger that acquires data when the signal enters the window. You can also program the trigger circuit to acquire data when the signal leaves the window.

Figure 38. Window Triggering with Enter Window



# **Onboard Temperature Sensing**

You can connect a twisted pair of thermocouples to any analog input channel in differential, NRSE, or RSE mode to measure temperature.

Use onboard temperature sensing in differential mode for better wire arrangement. Refer to the Analog Input Signal Connections section for more information on differential, NRSE, and RSE mode configurations.

When measuring thermocouples, the overall temperature measurement error is the sum of three factors.

- Cold-junction compensation (CJC) accuracy
- Measurement error due to the analog input range absolute accuracy
- Thermocouple error, which depends on the type of thermocouple you are using

NI recommends using a PXI or C Series thermocouple input module for taking the most accurate temperature measurements.

#### Related reference:

• Analog Input Signal Connections

# **Analog Output Measurements**

Learn more about making analog output measurements with the USB-6451.

## Analog Output Data Generation Methods

When performing an analog output operation, you can perform software-timed or hardware-timed generations.

#### **Software-Timed Generations**

With a software-timed generation, software controls the rate at which data is generated.

Software sends a separate command to the hardware to initiate each DAC conversion. In NI-DAQmx, software-timed generations are referred to as **on-demand timing**. Software-timed generations are also referred to as **immediate** or **static** operations. They are typically used for writing a single value out, such as a constant DC voltage.

### **Hardware-Timed Generations**

With a hardware-timed generation, a digital hardware signal controls the rate of the generation. This signal can be generated internally on the USB-6451 or provided externally.

Hardware-timed generations have several advantages over software-timed generations:

- The time between samples can be much shorter.
- The timing between samples can be deterministic.
- Hardware-timed acquisitions can use hardware triggering.

Hardware-timed operations transfer data to the USB-6451 more efficiently by transferring a larger block of data rather than one point at a time, allowing for much higher update rates. The sample mode can be either *finite* or *continuous*.

- Finite sample mode—Generates a specific, predetermined number of data samples. Once the specified number of samples has been written out, the generation stops.
- Continuous sample mode—Generates an unspecified number of samples. Instead of generating a set number of data samples and stopping, a continuous generation continues until you stop the operation.

There are three different methods of continuous generation that control what data is written. These methods are *regeneration*, *FIFO regeneration*, and *non*regeneration modes:

- Regeneration—Repeats data that is already in the buffer. Standard regeneration is when data from the PC buffer is continually downloaded to the FIFO to be written out. New data can be written to the PC buffer at any time without disrupting the output. Use the NI-DAQmx write property RegenMode to allow (or not allow) regeneration. The NI-DAQmx default is to allow regeneration.
- FIFO regeneration—Downloads the entire buffer to the FIFO and regenerates it from there. Once the data is downloaded, new data cannot be written to the FIFO. To use FIFO regeneration, the entire buffer must fit within the FIFO size. The advantage of using FIFO regeneration is that it does not require communication with the main host memory once the operation is started, thereby preventing any problems that may occur due to excessive bus traffic. Use the NI-DAQmx DO channel property UseOnlyOnBoardMemory to enable or disable FIFO regeneration.
- Non-regeneration—Does not repeat old data. New data must be continually written to the buffer. If the program does not write new data to the buffer at a fast enough rate to keep up with the generation, the buffer underflows and causes an error.

# **Analog Output Signal Connections**

The following figure shows how to make analog output connections to the USB-6451.

Figure 39. USB-6451 Analog Output Signal Connections



To minimize crosstalk between AO channels, use a separate AO GND return wire for each channel. Connect the return wire for each channel to the AO GND pin directly beneath the AO channel output on the connector.

# Analog Output Timing Engine

The following figure summarizes all of the timing options provided by the analog output timing engine.

Figure 40. USB-6451 Analog Output Timing Options



# Analog Output Timing Signals

The USB-6451 features four analog output (waveform generation) timing signals.

- AO Start Trigger Signal
- AO Pause Trigger Signal
- AO Sample Clock Signal
- AO Sample Clock Timebase Signal

## **AO Start Trigger Signal**

Use the AO Start Trigger (ao/StartTrigger) signal to initiate a waveform generation.

If you do not use triggers, you can begin a generation with a software command.

### **Retriggerable Analog Output**

The AO Start Trigger is configurable as retriggerable. The timing engine generates the sample clock for the configured generation in response to each pulse on an AO Start Trigger signal.

The timing engine ignores the AO Start Trigger signal while the clock generation is in progress. After the clock generation is finished, the counter waits for another Start Trigger to begin another clock generation.

The following figure shows a retriggerable AO generation of four samples.



#### **Using a Digital Source**

To use AO Start Trigger with a digital source, specify a source and an edge. The source can be one of the following signals:

- A pulse initiated by host software
- DIO <0..15>

AO Sample Clock

- Al Start Trigger (ai/StartTrigger)
- Al Reference Trigger (ai/ReferenceTrigger)
- Counter *n* Internal Output
- Change Detection Event
- DI Start Trigger (di/StartTrigger)
- DI Reference Trigger (di/ReferenceTrigger)
- DO Start Trigger (do/StartTrigger)

The source can also be one of several other internal signals on the USB-6451. Refer to **Device Routing in MAX** for more information.

You can also specify whether the measurement acquisition begins on the rising edge or falling edge of AO Start Trigger.

### **Routing AO Start Trigger Signal to an Output Terminal**

You can route AO Start Trigger out to any DIO <0..15> terminal. The output is an active high pulse.

#### **Related information:**

• Device Routing in MAX

## **AO Pause Trigger Signal**

Use the AO Pause Trigger (ao/PauseTrigger) signal to mask off samples in a DAQ sequence.

When AO Pause Trigger is active, no samples occur. AO Pause Trigger does not stop a sample that is in progress. The pause does not take effect until the beginning of the next sample.

When you generate analog output signals, the generation pauses as soon as the pause trigger is asserted. If the source of your sample clock is the onboard clock, the generation resumes as soon as the pause trigger is deasserted, as shown in the following figure.

Figure 42. AO Pause Trigger with the Onboard Clock Source



If you are using any signal other than the onboard clock as the source of your sample clock, the generation resumes as soon as the pause trigger is deasserted and another

edge of the sample clock is received, as shown in the following figure.

Figure 43. AO PauseTrigger with Other Signal Source



#### **Using a Digital Source**

To use AO Pause Trigger, specify a source and a polarity. The source can be any of the following signals:

- DIO <0..15>
- Counter *n* Internal Output
- Counter **n** Gate
- Al Pause Trigger (ai/PauseTrigger)
- AO Pause Trigger (ao/PauseTrigger)
- DO Pause Trigger (do/PauseTrigger)

The source can also be one of several other internal signals on USB-6451. Refer to **Device Routing in MAX** for more information.

You can also specify whether the samples are paused when AO Pause Trigger is at a logic high or low level.

#### Routing AO Pause Trigger Signal to an Output Terminal

You can route AO Pause Trigger out to any <DIO 0..15> terminal.

#### **Related information:**

Device Routing in MAX

## **AO Sample Clock Signal**

Use the AO Sample Clock (ao/SampleClock) signal to initiate AO samples.

Each AO Sample Clock edge simultaneously updates all of the DACs for channels in the task. You can specify an internal or external source for AO Sample Clock. You can also specify whether the DAC update begins on the rising edge or falling edge of AO Sample Clock.

#### **Using an Internal Source**

One of the following internal signals can drive AO Sample Clock:

- AO Sample Clock Timebase (divided down)
- Counter *n* Internal Output
- Change Detection Event
- Counter *n* Sample Clock
- AI Convert Clock (ai/ConvertClock)
- AI Sample Clock (ai/SampleClock)
- DI Sample Clock (di/SampleClock)
- DO Sample Clock (do/SampleClock)

A programmable internal counter divides down the AO Sample Clock Timebase signal.

Several other internal signals can be routed to AO Sample Clock through internal routes. Refer to **Device Routing in MAX** for more information.

### **Using an External Source**

Use DIO <0..15> as the source of AO Sample Clock.

### Routing AO Sample Clock Signal to an Output Terminal

You can route AO Sample Clock (as an active low signal) out to any DIO <0..15> terminal.

### **Other Timing Requirements**

The AO timing engine on the USB-6451 internally generates AO Sample Clock unless you select some external source. AO Start Trigger starts the timing engine and either the software or hardware can stop it once a finite generation completes. When using

the AO timing engine, you can also specify a configurable delay from AO Start Trigger to the first AO Sample Clock pulse. By default, this delay is two ticks of AO Sample Clock Timebase. The following figure shows the relationship of AO Sample Clock to AO Start Trigger.

Figure 44. AO Sample Clock and AO Start Trigger



#### **Related information:**

• Device Routing in MAX

## **AO Sample Clock Timebase Signal**

Use the AO Sample Clock Timebase (ao/SampleClockTimebase) signal to specify a higher frequency clock source to divide down to produce the desired AO Sample Clock rate.

You can route any of the following signals to be the AO Sample Clock Timebase signal:

- 100 MHz Timebase (default)
- 20 MHz Timebase
- 100 kHz Timebase
- DIO <0..15>

AO Sample Clock Timebase is not available as an output on the I/O connector.

You can use an external sample clock signal as AO Sample Clock Timebase signal by dividing the signal down in a DAQ device. You can also use it as AO Sample Clock signal without dividing the signal.

# Minimizing Glitches on the Output Signal

You might observe glitches on the output signal when you use a DAC to generate a waveform.

These glitches are normal; when a DAC switches from one voltage to another, it produces glitches due to released charges. The largest glitches occur when the most significant bit of the DAC code changes. You can build a lowpass deglitching filter to remove some of these glitches, depending on the frequency and nature of the output signal.

# Digital Input/Output Measurements

Learn more about making digital input/output measurements with the USB-6451.

## Digital Input Data Acquisition Methods

When performing digital input measurements, you either can perform software-timed or hardware-timed acquisitions.

## **Software-Timed Acquisitions**

With a software-timed acquisition, software controls the rate of the acquisition.

Software sends a separate command to the hardware to initiate each acquisition. In NI-DAQmx, software-timed acquisitions are referred to as having **on-demand** timing. Software-timed acquisitions are also referred to as immediate or static acquisitions. They are typically used for reading a single sample of data.

Each of the USB-6451 DIO lines can be used as a static DI or DO line. You can use static DIO lines to monitor or control digital signals. Each DIO can be individually configured as a digital input (DI) or digital output (DO).

All samples of static DI lines and updates of static DO lines are software-timed.

## **Hardware-Timed Acquisitions**

With hardware-timed acquisitions, a digital hardware signal controls the rate of the acquisition.

This signal can be generated internally on the USB-6451 or provided externally.

Hardware-timed acquisitions have several advantages over software-timed acquisitions.

The time between samples can be much shorter.

- The timing between samples is deterministic.
- Hardware-timed acquisitions can use hardware triggering.

Hardware-timed operations transfer data to the USB-6451 more efficiently by transferring a larger block of data rather than one point at a time, allowing for much higher sample rates. The sample mode can be either *finite* or *continuous*.

- Finite sample mode—Acquires a specific, predetermined number of data samples. Once the specified number of samples has been read in, the acquisition stops. If you use a reference trigger, you must use finite sample mode.
- Continuous sample mode—Acquires an unspecified number of samples. Instead
  of acquiring a set number of data samples and stopping, a continuous acquisition
  continues until you stop the operation. Continuous acquisition is also referred to
  as double-buffered or circular-buffered acquisition.

If data cannot be transferred across the bus fast enough, the FIFO becomes full. New acquisitions overwrites data in the FIFO before it can be transferred to host memory, which causes the USB-6451 to generate an error. With continuous operations, if the user program does not read data out of the PC buffer fast enough to keep up with the data transfer, the buffer could reach an overflow condition, causing an error to be generated.

# Digital Waveform Acquisition

You can acquire digital waveforms on the digital I/O lines. You can configure each digital I/O line to be an output, a static input, or a digital waveform acquisition input.

The digital input waveform acquisition FIFO stores the digital samples. The USB-6451 samples the digital I/O lines on each rising or falling edge of a clock signal, DI Sample Clock.

The following figure summarizes all of the timing options provided by the digital input timing engine.



# Digital Input Change Detection

You can configure the USB-6451 to detect changes on all 16 digital input lines (P0).

The following figure shows a block diagram of the digital I/O change detection circuitry.

Figure 45. Digital Input Change Detection



You can enable the digital I/O change detection circuitry to detect rising edges, falling edges, or either edge individually on each digital I/O line. The USB-6451 synchronizes each digital input signal to the 100 MHz Timebase, and then sends the signal to the change detectors. The circuitry ORs the output of all enabled change detectors from every digital input signal. The result of this OR is the Change Detection Event signal.

Change detection performs bus correlation by considering all changes within a 50 ns window one change detection event, which keeps signals on the same bus synchronized in samples and prevents overruns.

The Change Detection Event signal can do the following:

- Drive any DIO <0..15> signal
- Drive the DO Sample Clock or DI Sample Clock
- Generate an interrupt

The Change Detection Event signal can also be used to detect changes on digital output events.

### **DI Change Detection Applications**

The digital I/O change detection circuitry can interrupt a user program when one of several digital I/O signals changes state.

You can also use the output of the digital I/O change detection circuitry to trigger a digital input or counter acquisition on the logical OR of several digital signals. By routing the Change Detection Event signal to a counter, you can also capture the relative time between bus changes.

You can also use the Change Detection Event signal to trigger digital output or counter generations.

## **Digital Input Timing Signals**

The USB-6451 features five digital input timing signals.

- DI Sample Clock Signal
- DI Sample Clock Timebase Signal
- DI Start Trigger Signal
- DI Reference Trigger Signal

• DI Pause Trigger Signal

## DI Sample Clock Signal

The USB-6451 uses the DI Sample Clock (di/SampleClock) signal to sample the Port 0 terminals and store the result in the DI waveform acquisition FIFO.

You can specify an internal or external source for DI Sample Clock. You can also specify whether the measurement sample begins on the rising edge or falling edge of DI Sample Clock.

If the USB-6451 receives a DI Sample Clock when the FIFO is full, it reports an overflow error to the host software.

### **Using an Internal Source**

To use DI Sample Clock with an internal source, specify the signal source and the polarity of the signal. The source can be any of the following signals:

- DI Sample Clock (di/SampleClock)
- DO Sample Clock (do/SampleClock)
- AI Sample Clock (ai/SampleClock)
- AI Convert Clock (ai/ConvertClock)
- AO Sample Clock (ao/SampleClock)
- Counter **n** Sample Clock
- Counter *n* Internal Output
- Frequency Output
- DI Change Detection output

Several other internal signals can be routed to DI Sample Clock through internal routes. Refer to **Device Routing in MAX** for more information.

#### **Using an External Source**

You can route any DIO <0..15> signals as DI Sample Clock. You can sample data on the rising or falling edge of DI Sample Clock.

### **Routing DI Sample Clock to an Output Terminal**

You can route DI Sample Clock out to any DIO <0..15> terminal. The DIO circuitry inverts the polarity of DI Sample Clock before driving the DIO terminal.

#### **Other Timing Requirements**

The USB-6451 only acquires data during an acquisition. It ignores DI Sample Clock when a measurement acquisition is not in progress. During a measurement acquisition, you can cause the USB-6451 to ignore DI Sample Clock using the DI Pause Trigger signal.

The DI timing engine on the USB-6451 internally generates DI Sample Clock unless you select an external source. DI Start Trigger starts the timing engine and either software or hardware can stop it once a finite acquisition completes. When using the DI timing engine, you can also specify a configurable delay from DI Start Trigger to the first DI Sample Clock pulse.

By default, this delay is set to two ticks of the DI Sample Clock Timebase signal.



Figure 46. DI Sample Clock and DI Start Trigger

#### **Related information:**

• Device Routing in MAX

## **DI Sample Clock Timebase Signal**

You can route any of the following signals to be the DI Sample Clock Timebase (di/SampleClockTimebase) signal:

- 100 MHz Timebase (default)
- 20 MHz Timebase
- 100 kHz Timebase
- DIO <0..15>

Refer to the device routing table in MAX for all additional routable signals. To find the device routing table for your device, launch MAX and select **Devices and Interfaces**.» NI-DAQmx Devices. Click a device to open a tabbed window in the middle pane. Click the **Device Routes** tab at the bottom of the pane to display the device routing table.

DI Sample Clock Timebase is not available as an output on the I/O connector. DI Sample Clock Timebase is divided down to provide one of the possible sources for DI Sample Clock. You can configure the polarity selection for DI Sample Clock Timebase as either rising or falling edge except for the 100 MHz Timebase or 20 MHz Timebase.

You might use DI Sample Clock Timebase if you want to use an external sample clock signal, but need to divide the signal down. If you want to use an external sample clock signal, but do not need to divide the signal, then you should use DI Sample Clock rather than DI Sample Clock Timebase.

## **DI Start Trigger Signal**

Use the DI Start Trigger (di/StartTrigger) signal to begin a measurement acquisition.

A measurement acquisition consists of one or more samples. If you do not use triggers, begin a measurement with a software command. Once the acquisition begins, configure the acquisition to stop:

- When a certain number of points are sampled (in finite mode)
- After a hardware reference trigger (in finite mode)
- With a software command (in continuous mode)

An acquisition that uses a start trigger (but not a reference trigger) is sometimes referred to as a post-triggered acquisition.

#### Retriggerable DI

The DI Start Trigger is configurable as retriggerable. When the DI Start Trigger is

configured as retriggerable, the timing engine generates the sample and convert clocks for the configured acquisition in response to each pulse on a DI Start Trigger signal.

The timing engine ignores the DI Start Trigger signal while the clock generation is in progress. After the clock generation is finished, the timing engine waits for another Start Trigger to begin another clock generation. The following figure shows a retriggerable DI of four samples.







**Note** Waveform information from LabVIEW does not reflect the delay between triggers. They are treated as a continuous acquisition with constant t0 and dt information.

Reference triggers are not retriggerable.

#### **Using a Digital Source**

To use DI Start Trigger with a digital source, specify a source and an edge. The source can be any of the following signals:

- DIO <0..15>
- Counter *n* Internal Output
- Change Detection Event
- Al Start Trigger (ai/StartTrigger)
- AO Start Trigger (ao/StartTrigger)
- DO Start Trigger (do/StartTrigger)

The source can also be one of several other internal signals on the USB-6451. Refer to **Device Routing in MAX** for more information.

You can also specify whether the measurement acquisition begins on the rising edge or falling edge of DI Start Trigger.

#### **Routing DI Start Trigger to an Output Terminal**

You can route DI Start Trigger out to any DIO <0..15> terminal. The output is an active high pulse. All digital I/O terminals are configured as inputs by default.

The USB-6451 also uses DI Start Trigger to initiate pre-triggered DAQ operations. In most pre-triggered applications, a software trigger generates DI Start Trigger. Refer to the **DI Reference Trigger Signal** section for a complete description of the use of DI Start Trigger and DI Reference Trigger in a pre-triggered DAQ operation.

#### **Related information:**

Device Routing in MAX

### **DI Reference Trigger Signal**

Use the DI Reference Trigger (di/ReferenceTrigger) signal to stop a measurement acquisition.

To use a reference trigger, specify a buffer of finite size and a number of pre-trigger samples (samples that occur before the reference trigger). The number of post-trigger samples (samples that occur after the reference trigger) desired is the buffer size minus the number of pre-trigger samples.

Once the acquisition begins, the USB-6451 writes samples to the buffer. After the USB-6451 captures the specified number of pre-trigger samples, it begins to look for the reference trigger condition. If the reference trigger condition occurs before the USB-6451 captures the specified number of pre-trigger samples, the USB-6451 ignores the condition.

If the buffer becomes full, the USB-6451 continuously discards the oldest samples in the buffer to make space for the next sample. This data can be accessed (with some limitations) before the USB-6451 discards it. Refer to the document Can a **Pretriggered Analog Acquisition be Continuous?** for more information.

When the reference trigger occurs, the USB-6451 continues to write samples to the buffer until the buffer contains the number of post-trigger samples desired. The following figure shows the final buffer.

Figure 48. Reference Trigger Final Buffer



### **Using a Digital Source**

To use DI Reference Trigger with a digital source, specify a source and an edge. The source can be any of the following signals:

- DIO < 0..15>
- Change Detection Event
- Counter *n* Internal Output
- Al Reference Trigger (ai/ReferenceTrigger)
- AO Start Trigger (ao/StartTrigger)
- DO Start Trigger (do/StartTrigger)

The source can also be one of several internal signals on the USB-6451. Refer to **Device Routing in MAX** for more information.

You can also specify whether the measurement acquisition stops on the rising or falling edge or falling edge of DI Reference Trigger.

#### Routing DI Reference Trigger Signal to an Output Terminal

You can route DI Reference Trigger out to any DIO <0..15> terminal.

#### **Related information:**

- Device Routing in MAX
- Can a Pretriggered Analog Acquisition be Continuous?

## DI Pause Trigger Signal

Use the DI Pause Trigger (di/PauseTrigger) signal to pause and resume a measurement acquisition.

The internal sample clock pauses while the external trigger signal is active and resumes when the signal is inactive. You can program the active level of the pause trigger to be high or low, as shown in the following figure. In the figure, T represents the period, and A represents the unknown time between the clock pulse and the posttrigger.



Figure 49. Halt (Internal Clock) and Free Running (External Clock)

### **Using a Digital Source**

To use DI Pause Trigger, specify a source and a polarity. The source can be any of the following signals:

- DIO <0..15>
- Counter *n* Internal Output
- Counter *n* Gate
- Al Pause Trigger (ai/PauseTrigger)
- AO Pause Trigger (ao/PauseTrigger)
- DO Pause Trigger (do/PauseTrigger)

The source can also be one of several other internal signals on the USB-6451. Refer to **Device Routing in MAX** for more information.

### **Routing DI Pause Trigger Signal to an Output Terminal**

You can route DI Pause Trigger out to any DIO <0..15> terminal.



**Note** Pause triggers are only sensitive to the level of the source, not the edge.

#### **Related information:**

• Device Routing in MAX

# Digital Output Data Generation Methods

When performing a digital waveform operation, you either can perform software-timed or hardware-timed generations.

#### **Software-Timed Generations**

With a software-timed generation, software controls the rate at which data is generated.

Software sends a separate command to the hardware to initiate each update. In NI-DAQmx, software-timed generations are referred to as **on-demand timing**. Software-timed generations are also referred to as **immediate** or **static** operations. They are typically used for writing a single value out, such as a constant digital value.

### **Hardware-Timed Generations**

With a hardware-timed generation, a digital hardware signal controls the rate of the generation. This signal can be generated internally on the USB-6451 or provided externally.

Hardware-timed generations have several advantages over software-timed generations:

• The time between samples can be much shorter.

- The timing between samples can be deterministic.
- Hardware-timed acquisitions can use hardware triggering.

Hardware-timed operations transfer data to the USB-6451 more efficiently by transferring a larger block of data rather than one point at a time, allowing for much higher update rates. The sample mode can be either *finite* or *continuous*.

- Finite sample mode—Generates a specific, predetermined number of data samples. Once the specified number of samples has been written out, the generation stops.
- Continuous sample mode—Generates an unspecified number of samples. Instead of generating a set number of data samples and stopping, a continuous generation continues until you stop the operation.

There are three different methods of continuous generation that control what data is written. These methods are regeneration, FIFO regeneration, and nonregeneration modes:

- Regeneration—Repeats data that is already in the buffer. Standard regeneration is when data from the PC buffer is continually downloaded to the FIFO to be written out. New data can be written to the PC buffer at any time without disrupting the output. Use the NI-DAQmx write property RegenMode to allow (or not allow) regeneration. The NI-DAQmx default is to allow regeneration.
- FIFO regeneration—Downloads the entire buffer to the FIFO and regenerates it from there. Once the data is downloaded, new data cannot be written to the FIFO. To use FIFO regeneration, the entire buffer must fit within the FIFO size. The advantage of using FIFO regeneration is that it does not require communication with the main host memory once the operation is started, thereby preventing any problems that may occur due to excessive bus traffic. Use the NI-DAQmx DO channel property UseOnlyOnBoardMemory to enable or disable FIFO regeneration.
- Non-regeneration—Does not repeat old data. New data must be continually written to the buffer. If the program does not write new data to the buffer at a fast enough rate to keep up with the generation, the buffer underflows and causes an error.

## Digital Waveform Generation

You can generate digital waveforms on the digital I/O lines. The digital output waveform generation FIFO stores the digital samples.

The USB-6451 has a DMA controller dedicated to moving data from the system memory to the DO waveform generation FIFO. The USB-6451 moves samples from the FIFO to the digital I/O terminals on each rising or falling edge of a clock signal, DO Sample Clock. You can configure each digital I/O signal to be an input, a static output, or a digital waveform generation output.

The FIFO supports a retransmit mode. In the retransmit mode, after all the samples in the FIFO have been clocked out, the FIFO begins outputting all of the samples again in the same order. For example, if the FIFO contains five samples, the pattern generated consists of sample #1, #2, #3, #4, #5, #1, #2, #3, #4, #5, #1, and so on.

# Digital Output Timing Signals

The USB-6451 features four digital output (waveform generation) timing signals.

- DO Sample Clock Signal
- DO Sample Clock Timebase Signal
- DO Start Trigger Signal
- DO Pause Trigger Signal

## **DO Sample Clock Signal**

The USB-6451 uses the DO Sample Clock (do/SampleClock) signal to update the DO terminals with the next sample from the DO waveform generation FIFO.

You can specify an internal or external source for DO Sample Clock. You can also specify whether the DAC update begins on the rising edge or falling edge of DO Sample Clock. If the USB-6451 receives a DO Sample Clock when the FIFO is empty, the USB-6451 reports an underflow error to the host software.

### **Using an Internal Source**

One of the following internal signals can drive DO Sample Clock:

- DI Sample Clock (di/SampleClock)
- DO Sample Clock (do/SampleClock)
- AI Sample Clock (ai/SampleClock)
- AI Convert Clock (ai/ConvertClock)
- AO Sample Clock (ao/SampleClock)
- Counter *n* Sample Clock
- Counter *n* Internal Output
- Frequency Output
- DI Change Detection output

Several other internal signals can be routed to DO Sample Clock through internal routes. Refer to **Device Routing in MAX** for more information.

#### **Using an External Source**

Use DIO <0..15> as the source of DO Sample Clock.

### **Routing DO Sample Clock to an Output Terminal**

You can route DO Sample Clock (as an active low signal) out to any DIO <0..15> terminal.

#### **Other Timing Requirements**

The DO timing engine on the USB-6451 internally generates DO Sample Clock unless you select some external source. DO Start Trigger starts the timing engine and either the software or hardware can stop it once a finite generation completes. When using the DO timing engine, you can also specify a configurable delay from DO Start Trigger to the first DO Sample Clock pulse. By default, this delay is two ticks of DO Sample Clock Timebase. The following figure shows the relationship of DO Sample Clock to DO Start Trigger

Figure 50. DO Sample Clock and DO Start Trigger



#### **Related information:**

Device Routing in MAX

## DO Sample Clock Timebase Signal

The DO Sample Clock Timebase (do/SampleClockTimebase) signal is divided down to provide a source for DO Sample Clock.

You can route any of the following signals to be the DO Sample Clock Timebase signal:

- 100 MHz Timebase (default)
- 20 MHz Timebase
- 100 kHz Timebase
- DIO <0..15>

DO Sample Clock Timebase is not available as an output on the I/O connector.

You might use DO Sample Clock Timebase if you want to use an external sample clock signal, but need to divide the signal down. If you want to use an external sample clock signal, but do not need to divide the signal, then you should use DO Sample Clock rather than DO Sample Clock Timebase.

## **DO Start Trigger Signal**

Use the DO Start Trigger (do/StartTrigger) signal to initiate a waveform generation. If you do not use triggers, you can begin a generation with a software command.

#### Retriggerable DI

The DO Start Trigger is configurable as retriggerable. When DO Start Trigger is configured as retriggerable, the timing engine generates the sample clocks for the configured generation in response to each pulse on a DO Start Trigger signal.

The timing engine ignores the DO Start Trigger signal while the clock generation is in progress. After the clock generation is finished, the timing engine waits for another start trigger to begin another clock generation. The following figure shows a retriggerable DO of four samples.



### **Using a Digital Source**

To use DO Start Trigger with a digital source, specify a source and an edge. The source can be any of the following signals:

- A pulse initiated by host software
- DIO <0..15>
- Al Start Trigger (ai/StartTrigger)
- Al Reference Trigger (ai/Reference Trigger)
- AO Start Trigger (ao/StartTrigger)
- Counter *n* Internal Output
- DI Start Trigger (do/StartTrigger)
- DI Reference Trigger (di/ReferenceTrigger)
- Change Detection Event

The source can also be one of several other internal signals on the USB-6451. Refer to **Device Routing in MAX** for more information.

You can also specify whether the measurement acquisition begins on the rising edge or falling edge of DI Start Trigger.

### **Routing DO Start Trigger to an Output Terminal**

You can route DO Start Trigger out to any DIO <0..15> terminal. The output is an active high pulse. All DIO terminals are configured as inputs by default.

#### **Related information:**

Device Routing in MAX

## **DO Pause Trigger Signal**

Use the DO Pause Trigger (do/PauseTrigger) signal to mask off samples in a DAQ sequence. That is, when DO Pause Trigger is active, no samples occur.

DO Pause Trigger does not stop a sample that is in progress. The pause does not take effect until the beginning of the next sample.

When you generate digital output signals, the generation pauses as soon as the pause trigger is asserted. If the source of your sample clock is the onboard clock, the generation resumes as soon as the pause trigger is deasserted, as shown in the following figure.

Figure 52. DO Pause Trigger with the Onboard Clock Source



If you are using any signal other than the onboard clock as the source of your sample clock, the generation resumes as soon as the pause trigger is deasserted and another edge of the sample clock is received, as shown in the following figure.

Figure 53. DO Pause Trigger with Other Signal Source



### **Using a Digital Source**

To use DO Pause Trigger, specify a source and a polarity. The source can be one of the following signals:

- DIO <0..15>
- Counter *n* Internal Output
- Counter **n** Gate
- Al Pause Trigger (ai/PauseTrigger)
- AO Pause Trigger (ao/PauseTrigger)
- DI Pause Trigger (di/PauseTrigger)

The source can also be one of several other internal signals on the USB-6451. Refer to **Device Routing in MAX** for more information.

You can also specify whether the samples are paused when DO Pause Trigger is at a logic high or low level.

#### Routing DI Pause Trigger Signal to an Output Terminal

You can route DI Pause Trigger out to any DIO <0..15> terminal.

#### **Related information:**

Device Routing in MAX

# I/O Protection

Each digital I/O signal is protected against overvoltage, undervoltage, and overcurrent conditions as well as electrostatic discharge (ESD) events.

Follow these guidelines to avoid these fault conditions:

- If you configure a digital I/O line as an output, do not connect it to any external signal source, ground, or power supply.
- If you configure a digital I/O line as an output, understand the current requirements of the load connected to these signals. Do not exceed the specified current output limits of the USB-6451. NI has several signal conditioning solutions for digital applications requiring high current drive.
- If you configure a digital I/O line as an input, do not drive the line with voltages outside of its normal operating range. The digital I/O lines have a smaller operating range than the AI signals.
- Treat the USB-6451 as you would treat any static sensitive device. Always properly
  ground yourself and the equipment when handling the USB-6451 or connecting to
  it.

# Digital I/O Signal Connections

The digital I/O signals are referenced to D GND. You can individually program each line as an input or output.

The following figure shows P0.<4..7> configured for digital input and P0.<0..3> configured for digital output, the switch receiving TTL signals and sensing external device states, and the LED sending TTL signals and driving external devices.

Figure 54. Digital I/O Connections





Notice Exceeding the maximum input voltage ratings, which are listed in the USB-6451 Specifications, can damage the USB-6451 and the computer. NI is not liable for any damage resulting from such signal connections.

For best signal integrity on high-speed digital signals, use twisted pair wiring and twist each signal wire with a D GND wire. Connect the D GND wire to the D GND pin closest to the signal pin. Note that this requires sharing one D GND pin for every two signals.

#### **Related information:**

USB-6451 Specifications

# Using Digital I/O Terminals as Timing Input Signals

Use digital I/O terminals to route external timing signals to many different functions.

Each digital I/O terminal can be routed to any of the following signals:

- AI Convert Clock (ai/ConvertClock)
- AI Sample Clock (ai/SampleClock)
- AI Sample Clock Timebase (ai/SampleClockTimebase)
- Al Start Trigger (ai/StartTrigger)

- Al Reference Trigger (ai/ReferenceTrigger)
- Al Pause Trigger (ai/PauseTrigger)
- AO Start Trigger (ao/StartTrigger)
- AO Sample Clock (ao/SampleClock)
- AO Sample Clock Timebase (ao/SampleClockTimebase)
- AO Pause Trigger (ao/PauseTrigger)
- Counter input signals for all counters—Source, Gate, Aux, HW\_Arm, A, B, Z
- Counter **n** Sample Clock
- DI Sample Clock (di/SampleClock)
- DI Sample Clock Timebase (di/SampleClockTimebase)
- DI Reference Trigger (di/ReferenceTrigger)
- DO Sample Clock (do/SampleClock)

Most functions allow you to configure the polarity of digital I/O inputs and whether the input is edge or level sensitive.

# Using Digital I/O Terminals to Export Timing Output Signals

You can route any of the following timing signals to any digital I/O terminal configured as an output:

- AI Convert Clock\* (ai/ConvertClock)
- AI Hold Complete Event (ai/HoldCompleteEvent)
- Al Reference Trigger (ai/ReferenceTrigger)
- AI Sample Clock (ai/SampleClock)
- Al Start Trigger (ai/StartTrigger)
- Al Pause Trigger (ai/PauseTrigger)
- AO Sample Clock\* (ao/SampleClock)
- AO Start Trigger (ao/StartTrigger)
- AO Pause Trigger (ao/PauseTrigger)
- DI Sample Clock (di/SampleClock)
- DI Start Trigger (di/StartTrigger)
- DI Reference Trigger (di/ReferenceTrigger)
- DI Pause Trigger (di/PauseTrigger)
- DO Sample Clock\* (do/SampleClock)

- DO Start Trigger (do/StartTrigger)
- DO Pause Trigger (do/PauseTrigger)
- Counter *n* Source
- Counter *n* Gate
- Counter *n* Internal Output
- Counter *n* Sample Clock
- Counter *n* Counter *n* HW Arm
- Frequency Output
- Change Detection Event



**Note** Signals with an \* are inverted before being driven to a terminal; that is, these signals are active low.

# Filters for Digital Input

You can enable a programmable debouncing filter on each digital line on Port 0. These filters are available when you use the digital line for input.

When the filters are enabled, your device samples the input on each rising edge of a filter clock. The USB-6451 divides down the onboard 100 MHz or 100 kHz clocks to generate the filter clock. The following is an example of low-to-high transitions of the input signal. High-to-low transitions work similarly.

Assume that an input terminal has been low for a long time. The input terminal then changes from low-to-high, but glitches several times. When the filter clock has sampled the signal high on two consecutive edges, and the signal remained stable in between, the low-to-high transition is propagated to the rest of the circuit.

Table 21. Filters

| Filter Setting | Filter Clock | Pulse Width Guaranteed to<br>Pass Filter | Pulse Width Guaranteed to<br>Not Pass Filter |
|----------------|--------------|------------------------------------------|----------------------------------------------|
| Short          | 12.5 MHz     | 160 ns                                   | 80 ns                                        |
| Medium         | 195.3125 kHz | 10.24 μs                                 | 5.12 μs                                      |
| High           | 390.625 Hz   | 5.12 ms                                  | 2.56 ms                                      |

| Filter Setting | Filter Clock | Pulse Width Guaranteed to<br>Pass Filter | Pulse Width Guaranteed to<br>Not Pass Filter |
|----------------|--------------|------------------------------------------|----------------------------------------------|
| None           | _            | _                                        | _                                            |

The filter setting for each input can be configured independently. On power up, the filters are disabled. The following figure shows an example of a low-to-high transition on an input.



When multiple lines are configured with the same filter settings, they are considered a bus. There are two filtering modes for use with multiple lines: line filtering and bus filtering.

- **Line filtering**—Each line transitions independently of the other lines in the bus and acts like the behavior described above.
- Bus filtering—If any line in the bus has jitter, then all lines in the bus hold the state until the bus becomes stable.

Each individual line only waits one extra filter tick before changing, which prevents a noisy line from holding a valid transition indefinitely. With bus mode, if all the bus line transitions become stable in less than one filter clock period and the bus period is more than two filter clock periods, then all the bus lines are guaranteed to be correlated at the output of the filter.

You can think of the behavior for each transition as a state machine. If a line transitions and stays high for two consecutive filter clock edges, then one of two options occurs:

#### Case 1

If no transitions have occurred on the other lines, the transition propagates on the second filtered clock edge, as shown in the following figure.

Figure 56. Case 1



#### Case 2

If an additional line on the bus also has a transition during the filter clock period, the change is not propagated until the next filter clock edge, as shown in the following figure.

Figure 57. Case 2



The following figure illustrates the difference between line and bus filtering.





# Filters for Counter and Timer Signals

You can enable programmable debouncing filters on each DIO <0..15> signal. These filters are available when you use a DIO <0..15> signal as a counter, timer, or trigger signal.

When the filters are enabled, USB-6451 samples the input on each rising edge of a filter clock. The USB-6451 uses an onboard oscillator to generate the filter clock.

The following is an example of low-to-high transitions of the input signal. High-to-low transitions work similarly.

Assume that an input terminal has been low for a long time. The input terminal then changes from low to high, but glitches several times. When the filter clock samples the signal high on N consecutive edges, the low-to-high transition propagates to the rest of the circuit. The value of N depends on the filter setting as illustrated in the following table.

Table 22. Filters

| Filter Setting   | Filter Clock      | N (Filter Clocks<br>Needed to Pass<br>Signal) | Pulse Width<br>Guaranteed to<br>Pass Filter | Pulse Width<br>Guaranteed to<br>Not Pass Filter |
|------------------|-------------------|-----------------------------------------------|---------------------------------------------|-------------------------------------------------|
| None             | _                 | _                                             | _                                           | _                                               |
| 90 ns (short)    | 100 MHz           | 9                                             | 90 ns                                       | 80 ns                                           |
| 5.12 μs (medium) | 100 MHz           | 512                                           | 5.12 μs                                     | 5.11 μs                                         |
| 2.56 ms (high)   | 100 kHz           | 256                                           | 2.56 ms                                     | 2.55 ms                                         |
| Custom           | User configurable | N                                             | N/timebase                                  | (N - 1)/timebase                                |

The filter setting for each input can be configured independently. On power up, the filters are disabled. The following figure shows an example of a low to high transition on an input that has a custom filter set to N = 5.



Enabling filters introduces jitter on the input signal. The maximum jitter is one period of the timebase.

# Watchdog Timer

Use the watchdog timer to set critical outputs to a safe state if software fails, a system crashes, or the application loses communication with the USB-6451.

Enabling the watchdog timer sets the USB-6451 to go to a safe state you define if the USB-6451 does not receive a watchdog reset software command within an amount of time you specify. You can set a watchdog timer for all digital I/O lines.

The USB-6451 will remain in the defined safe state until you disarm it. The signal that indicates an expired watchdog timer continues to assert until you disarm the watchdog timer. After the watchdog timer expires, the USB-6451 ignores any digital

writes until you disarm the watchdog timer.



**Note** When the watchdog timer is enabled and the computer enters a fault condition, ports that are set to tri-state remain tri-stated and do not go to user-defined safe states.

You can set the watchdog timer timeout period to specify the amount of time that must elapse before the watchdog timer expires. You can configure the counter on the watchdog timer up to  $(2^{32} - 1) \times 8$  ns (approximately 34 seconds) before it expires.

# **Disarming the Watchdog Timer**

You can disarm the watchdog timer on the USB-6451 in multiple ways.

To disarm the watchdog timer, complete one of the following actions.

- Reset the USB-6451
- Restart the computer

#### **Related information:**

- Watchdog Timers
- DAQmx Watchdog VIs and Function
- DAQmx Watchdog Properties
- How to Use and Implement the Watchdog Timer With NI-DAQmx

# Digital Input/Output Logic Families

You can configure the digital voltage of the USB-6451 by selecting logic families on the USB-6451. The logic family configuration affects the digital input, digital output, counter input, counter output, and trigger functions.

**Logic families** are groups of logic circuits with standardized voltage levels that constitute a valid logic state.

The USB-6451 supports four logic families. The USB-6451 is configured to 5 V by

#### default.

Table 23. USB-6451 Logic Families

| Logic Family | Description                              |
|--------------|------------------------------------------|
| 1.8 V        | Compatible with 1.8 V CMOS signals       |
| 2.5 V        | Compatible with 2.5 V CMOS signals       |
| 3.3 V        | Compatible with LVTTL signals            |
| 5 V          | Compatible with TTL and 5 V CMOS signals |

# **Configuring the Logic Family**

- 1. Add the DAQmx Physical Property node to your block diagram. The DAQmx Physical Property node is located on the DAQmx Constants & Property Nodes palette under Measurement I/ODAQmx - Data AcquisitionDAQmx AdvancedDAQmx Constants & Property Nodes.
- 2. Set the ActivePhysicalChans property to show digital input channels.
  - a. Right-click the ActivePhysicalChans and select Create » Constant to add a constant.
  - b. Right-click the constant and select I/O Name Filters.
  - c. In the Filter Names dialog box, set I/O Type to Digital Input or Digital Output and Port/Line Filtering to Ports Only.
  - d. Click OK.
  - e. Set the constant to **Device Name/port0**, where Device Name represents the name of your device.
- 3. Select **Digital** » **Port Logic Family** to add the Dig.PortLogicFamily property node.
- 4. Right-click the Dig.PortLogicFamily and select **Create** » **Constant** to add a constant.
- 5. Select a logic family on the constant.

# Programmable Power-Up States

At system start up and reset, the hardware sets all digital I/O lines to high-impedance inputs by default.

The USB-6451 does not drive the signal high or low. Each line has a weak pull-down resistor connected to it.

NI-DAQmx supports programmable power-up states for digital I/O lines. Software can program any value at power up to the P0 line. You can set the digital I/O lines in the following ways:

- A high-impedance input with a weak pull-down resistor (default)
- An output driving a 0
- An output driving a 1

#### **Related information:**

- DAQmx Set Power Up States (VI)
- DAQmx Get Power Up States (VI)

# Counters

The USB-6451 has four general-purpose 32-bit counter/timers and one frequency generator. The general-purpose counter/timers can be used for many measurement and pulse generation applications.

The following figure shows the USB-6451 Counter 0 and the frequency generator. All four counters on the USB-6451 are identical.



Figure 60. USB-6451 Counter 0 and Frequency Generator

Counters have eight input signals, although in most applications only a few inputs are used.

Each counter has a FIFO that can be used for buffered acquisition and generation. Each counter also contains an embedded counter (Embedded Ctrn) for use in what are traditionally two-counter measurements and generations. The embedded counters cannot be programmed independent of the main counter; signals from the embedded counters are not routable.

# **Counter Timing Engine**

USB-6451 counters do not have the ability to divide down a timebase to produce an internal counter sample clock. For sample clocked operations, an external signal must be provided to supply a clock source.

The source can be any of the following signals:

- AI Sample Clock
- Al Start Trigger
- Al Reference Trigger
- AO Sample Clock
- DI Sample Clock
- DI Start Trigger
- DO Sample Clock
- CTR *n* Internal Output
- Freq Out
- DIO < 0..15>
- · Change Detection Event

Not all timed counter operations require a sample clock. For example, a simple buffered pulse width measurement latches in data on each edge of a pulse. For this measurement, the measured signal determines when data is latched in. These operations are referred to as implicit timed operations. However, many of the same measurements can be clocked at an interval with a sample clock. These are referred to as sample clocked operations. The following table shows the different options for the different measurements.

Table 24. Counter Timing Measurements

| Measurement          | Implicit Timing<br>Support | Sample Clocked<br>Timing Support |
|----------------------|----------------------------|----------------------------------|
| Buffered Edge Count  | X                          | ✓                                |
| Buffered Pulse Width | ✓                          | ✓                                |
| Buffered Pulse       | ✓                          | ✓                                |
| Buffered Semi-Period | ✓                          | X                                |

| Measurement                         | Implicit Timing<br>Support | Sample Clocked<br>Timing Support |
|-------------------------------------|----------------------------|----------------------------------|
| Buffered Frequency                  | ✓                          | ✓                                |
| Buffered Period                     | ✓                          | ✓                                |
| Buffered Position                   | X                          | ✓                                |
| Buffered Two-Signal Edge Separation | ✓                          | ✓                                |

# **Counter Input Applications**

Refer to the following sections for more information on the various counter input applications available on the USB-6451.

# **Counting Edges**

In edge counting applications, the counter counts edges on its Source after the counter is armed. You can configure the counter to count rising or falling edges on its Source input.

You can also control the direction of counting (up or down), as described in the Controlling the Direction of Counting section. The counter values can be read on demand or with a sample clock.

# Single Point (On-Demand) Edge Counting

With single point (on-demand) edge counting, the counter counts the number of edges on the Source input after the counter is armed.

On-demand refers to the fact that software can read the counter contents at any time without disturbing the counting process. The following figure shows an example of single point edge counting.

Figure 61. Single Point (On-Demand) Edge Counting
Counter Armed



You can also use a pause trigger to pause (or gate) the counter. When the pause trigger is active, the counter ignores edges on its Source input. When the pause trigger is inactive, the counter counts edges normally.

You can route the pause trigger to the Gate input of the counter. You can configure the counter to pause counting when the pause trigger is high or when it is low. The following figure shows an example of on-demand edge counting with a pause trigger.

Figure 62. Single Point (On-Demand) Edge Counting with Pause Trigger



## **Buffered (Sample Clock) Edge Counting**

With buffered edge counting (edge counting using a sample clock), the counter counts the number of edges on the Source input after the counter is armed.

The value of the counter is sampled on each active edge of a sample clock and stored in the FIFO. A direct memory access (DMA) controller transfers the sampled values to host memory.

The count values returned are the cumulative counts since the counter armed event. That is, the sample clock does not reset the counter.

You can configure the counter to sample on the rising or falling edge of the sample clock.

The following figure shows an example of buffered edge counting. Notice that counting begins when the counter is armed, which occurs before the first active edge

#### on Sample Clock.

Figure 63. Buffered (Sample Clock) Edge Counting



#### **Controlling the Direction of Counting**

In edge counting applications, the counter can count up or down. You can configure the counter to do the following:

- Always count up
- · Always count down
- Count up when the Counter 0 B input is high; count down when it is low

#### **Pulse-Width Measurement**

In pulse-width measurements, the counter measures the width of a pulse on its Gate input signal. You can configure the counter to measure the width of high pulses or low pulses on the Gate signal.

You can route an internal or external periodic clock signal (with a known period) to the Source input of the counter. The counter counts the number of rising (or falling) edges on the Source signal while the pulse on the Gate signal is active.

You can calculate the pulse width by multiplying the period of the Source signal by the number of edges returned by the counter.

A pulse-width measurement is accurate even if the counter is armed while a pulse train is in progress. If a counter is armed while the pulse is in the active state, it waits for the next transition to the active state to begin the measurement.

#### Single Pulse-Width Measurement

With single pulse-width measurement, the counter counts the number of edges on the Source input while the Gate input remains active.

When the Gate input goes inactive, the counter stores the count in the FIFO and ignores other edges on the Gate and Source inputs. Software then reads the stored count. The following figure shows an example of a single pulse-width measurement.

Figure 64. Single Pulse-Width Measurement



#### Implicit Buffered Pulse-Width Measurement

An implicit buffered pulse-width measurement is similar to single pulse-width measurement, but buffered pulse-width measurement takes measurements over multiple pulses.

The counter counts the number of edges on the Source input while the Gate input remains active. On each trailing edge of the Gate signal, the counter stores the count in the counter FIFO. A DMA controller transfers the stored values to host memory. The following figure shows an example of an implicit buffered pulse-width measurement.

Figure 65. Implicit Buffered Pulse-Width Measurement



#### Sample Clocked Buffered Pulse-Width Measurement

A Sample Clocked Buffered pulse-width measurement is similar to single pulse-width measurement, but buffered pulse-width measurement takes measurements over multiple pulses correlated to a sample clock.

The counter counts the number of edges on the Source input while the Gate input remains active. On each sample clock edge, the counter stores the count in the FIFO of the last pulse width to complete. A DMA controller transfers the stored values to host memory. The following figure shows an example of a sample clocked buffered pulsewidth measurement.

Figure 66. Sample Clocked Buffered Pulse-Width Measurement



#### **Pulse versus Semi-Period Measurements**

In hardware, pulse measurement and semi-period are the same measurement. Both measure the high and low times of a pulse. The functional difference between the two measurements is how the data is returned.

In a semi-period measurement, each high or low time is considered one point of data and returned in units of seconds or ticks. In a pulse measurement, each pair of high and low times is considered one point of data and returned as a paired sample in units of frequency and duty cycle, high and low time or high and low ticks. When reading data, 10 points in a semi-period measurement gets an array of five high times and five low times. When you read 10 points in a pulse measurement, you get an array of 10 pairs of high and low times.

Also, pulse measurements support sample clock timing while semi-period measurements do not.

# **Pulse Measurement**

In pulse measurements, the counter measures the high and low time of a pulse on its

Gate input signal after the counter is armed.

A pulse is defined in terms of its high and low time, high and low ticks or frequency and duty cycle, which is similar to the pulse-width measurement, except that the inactive pulse is measured as well.

You can route an internal or external periodic clock signal (with a known period) to the Source input of the counter. The counter counts the number of rising (or falling) edges occurring on the Source input between two edges of the Gate signal.

You can calculate the high and low time of the Gate input by multiplying the period of the Source signal by the number of edges returned by the counter.

#### Single Pulse Measurement

Single (on-demand) pulse measurement is equivalent to two single pulse-width measurements on the high (H) and low (L) ticks of a pulse.

The following figure shows an example of a single (on-demand) pulse measurement.



Figure 67. Single (On-Demand) Pulse Measurement

# Implicit Buffered Pulse Measurement

In an implicit buffered pulse measurement, on each edge of the Gate signal, the counter stores the count in the FIFO. A DMA controller transfers the stored values to host memory.

The counter begins counting when it is armed. The arm usually occurs between edges on the Gate input, but the counting does not start until the desired edge. You can select whether to read the high pulse or low pulse first using the StartingEdge property in NI-DAQmx.

The following figure shows an example of an implicit buffered pulse measurement.

Figure 68. Implicit Buffered Pulse Measurement



# Sample Clocked Buffered Pulse Measurement

A sample clocked buffered pulse measurement is similar to single pulse measurement, but a buffered pulse measurement takes measurements over multiple pulses correlated to a sample clock.

The counter performs a pulse measurement on the Gate. On each sample clock edge, the counter stores the high and low ticks in the FIFO of the last pulse to complete. A DMA controller transfers the stored values to host memory.

The following figure shows an example of a sample clocked buffered pulse measurement.

Figure 69. Sample Clocked Buffered Pulse Measurement



# **Semi-Period Measurement**

In semi-period measurements, the counter measures a semi-period on its Gate input signal after the counter is armed. A semi-period is the time between any two consecutive edges on the Gate input.

You can route an internal or external periodic clock signal (with a known period) to the

Source input of the counter. The counter counts the number of rising (or falling) edges occurring on the Source input between two edges of the Gate signal.

You can calculate the semi-period of the Gate input by multiplying the period of the Source signal by the number of edges returned by the counter.

#### **Single Semi-Period Measurement**

Single semi-period measurement is equivalent to single pulse-width measurement.

#### Implicit Buffered Semi-Period Measurement

In implicit buffered semi-period measurement, on each edge of the Gate signal, the counter stores the count in the FIFO. A DMA controller transfers the stored values to host memory.

The counter begins counting when it is armed. The arm usually occurs between edges on the Gate input. You can select whether to read the first active low or active high semi period using the CI.SemiPeriod.StartingEdge property in NI-DAQmx. The following figure shows an example of an implicit buffered semi-period measurement.

Counter Starting Armed Edge

Gate

Source

1 2 3 1 1 2 1

Buffer

3 3 1 1 2 1

2 2

Figure 70. Implicit Buffered Semi-Period Measurement

# **Frequency Measurement**

You can use the counters to measure frequency in several different ways.

## Low Frequency with One Counter

For low frequency measurements with one counter, you measure one period of your

signal using a known timebase. You can route the signal to measure (fx) to the Gate of a counter.

You can route a known timebase (fk) to the Source of the counter. The known timebase can be an onboard timebase, such as 100 MHz Timebase, 20 MHz Timebase, or 100 kHz Timebase, or any other signal with a known rate.

You can configure the counter to measure one period of the gate signal. The frequency of fx is the inverse of the period. The following figure illustrates this method.

Figure 71. Low Frequency with One Counter



## **High Frequency with Two Counters**

For high frequency measurements with two counters, you measure one pulse of a known width using your signal and derive the frequency of your signal from the result.



**Note** Counter 0 is always paired with Counter 1. Counter 2 is always paired with Counter 3.

In this method, you route a pulse of known duration (T) to the Gate of a counter. You can generate the pulse using a second counter. You can also generate the pulse externally and connect it to a DIO terminal. You only need to use one counter if you generate the pulse externally.

Route the signal to measure (fx) to the Source of the counter. Configure the counter for a single pulse-width measurement. If you measure the width of pulse T to be N periods of fx, the frequency of fx is N/T. The following figure illustrates this method.

Figure 72. High Frequency with Two Counters



Another option is to measure the width of a known period instead of a known pulse.

#### Large Range of Frequencies with Two Counters

By using two counters, you can accurately measure a signal that might be high or low frequency. This technique is called reciprocal frequency measurement.

When measuring a large range of frequencies with two counters, you generate a long pulse using the signal to measure. You then measure the long pulse with a known timebase. The USB-6451 can measure this long pulse more accurately than the faster input signal.



**Note** Counter 0 is always paired with Counter 1. Counter 2 is always paired with Counter 3.

You can route the signal to measure to the Source input of Counter 0, as shown in the following figure. Assume this signal to measure has frequency fx. NI-DAQmx automatically configures Counter 0 to generate a single pulse that is the width of N periods of the source input signal.

Figure 73. Large Range of Frequencies with Two Counters



NI-DAQmx then routes the Counter 0 Internal Output signal to the gate of Counter 1. You can then route a signal of known frequency (fk) as a counter timebase to the Counter 1 Source input. NI-DAQmx configures Counter 1 to perform a single pulsewidth measurement. Suppose the result is that the pulse width is J periods of the fk clock.

From Counter 0, the length of the pulse is N/fx. From Counter 1, the length of the same pulse is J/fk. Therefore, the frequency of fx is given by fk = fk \* (N/J).

# **Choosing a Method for Measuring Frequency**

The best method to measure frequency depends on several factors including the expected frequency of the signal to measure, the desired accuracy, how many counters are available, and how long the measurement can take.

#### Which Method is Best?

This depends on the frequency to be measured, the rate at which you want to monitor the frequency and the accuracy you desire.

- Low frequency measurements with one counter is a good method for many applications. However, the accuracy of the measurement decreases as the frequency increases.
- High frequency measurements with two counters is accurate for high frequency signals. However, the accuracy decreases as the frequency of the signal to measure decreases. At very low frequencies, this method may be too inaccurate for your application. Another disadvantage of this method is that it requires two counters (if you cannot provide an external signal of known width). An advantage of high frequency measurements with two counters is that the measurement completes in a known amount of time.
- Measuring a large range of frequencies with two counters measures high and low frequency signals accurately. However, it requires two counters, and it has a variable sample time and variable error % dependent on the input signal.

The following table summarizes some of the differences in methods of measuring frequency.

| Method                                       | Number of<br>Counters<br>Used | Number of<br>Measurements<br>Returned | Measures High<br>Frequency<br>Signals<br>Accurately | Measures Low<br>Frequency<br>Signals<br>Accurately |
|----------------------------------------------|-------------------------------|---------------------------------------|-----------------------------------------------------|----------------------------------------------------|
| Low frequency with one counter               | 1                             | 1                                     | Poor                                                | Good                                               |
| High frequency with two counters             | 1 or 2                        | 1                                     | Good                                                | Poor                                               |
| Large range of frequencies with two counters | 2                             | 1                                     | Good                                                | Good                                               |
| Sample clocked (averaged)                    | 1                             | 1                                     | Good                                                | Good                                               |

# **Considerations for Choosing Frequency Measurement Method**

For all frequency measurement methods, assume the following:

| fx | is the frequency to be measured if no error |
|----|---------------------------------------------|
|----|---------------------------------------------|

| fk                   | is the known source or gate frequency                                                   |
|----------------------|-----------------------------------------------------------------------------------------|
| measurement time (T) | is the time it takes to measure a single sample                                         |
| Divide down (N)      | is the integer to divide down measured frequency, only used in large range two counters |
| fs                   | is the sample clock rate, only used in sample clocked frequency measurements            |

Here is how these variables apply to each method, with a summary in the following table:

- One counter—With one counter measurements, a known timebase is used for the source frequency (fk). The measurement time is the period of the frequency to be measured, or 1/fk.
- Two counter high frequency—With the two counter high frequency method, the second counter provides a known measurement time. The gate frequency equals 1/measurement time.
- **Two counter large range**—The two counter larger range measurement is the same as a one counter measurement, but now the user has an integer divide down of the signal. An internal timebase is still used for the source frequency (fk), but the divide down means that the measurement time is the period of the divided down signal, or N/fx where N is the divide down.

Table 26. Frequency measurement methods

| Variable             | One Counter                        | Two Counter        |                                             |  |
|----------------------|------------------------------------|--------------------|---------------------------------------------|--|
| variable             |                                    | High Frequency     | Large Range                                 |  |
| fk                   | Known timebase                     | 1<br>gating period | Known timebase                              |  |
| Measurement time     | $\frac{1}{fx}$                     | gating period      | $\frac{N}{fx}$                              |  |
| Max. frequency error | $f_X \times \frac{f_X}{f_K - f_X}$ | fk                 | $f_X \times \frac{f_X}{N \times f_k - f_X}$ |  |
| Max. error %         | $\frac{fx}{fk - fx}$               | $\frac{fk}{fx}$    | $\frac{fx}{N \times fk - fx}$               |  |



Note Accuracy equations do not take clock stability into account. Refer to

#### your device specifications for clock stability.

For a practical example, consider measuring a 50 kHz signal. Assuming that the measurement times for the sample clocked (with averaging) and two counter frequency measurements are configured the same, the following table summarizes the results.

Table 27. 50 kHz Frequency Measurement Methods

| Variable                  | One Counter | Two Counter    |             |  |
|---------------------------|-------------|----------------|-------------|--|
| variable                  |             | High Frequency | Large Range |  |
| fx                        | 50,000      | 50,000         | 50,000      |  |
| fk                        | 100 M       | 1,000          | 100 M       |  |
| Measurement time (ms)     | .02         | 1              | 1           |  |
| N                         | _           | _              | 50          |  |
| Max. frequency error (Hz) | 25          | 1,000          | .5          |  |
| Max. error %              | .05         | 2              | .001        |  |

From these results, you can see that while the measurement time for one counter is shorter, the accuracy is best in the sample clocked and two counter large range measurements. For another example, the following table shows the results for 5 MHz.

Table 28. 5 MHz Frequency Measurement Methods

| Variable                  | One Counter | Two Counter    |             |  |
|---------------------------|-------------|----------------|-------------|--|
|                           |             | High Frequency | Large Range |  |
| fx                        | 5 M         | 5 M            | 5 M         |  |
| fk                        | 100 M       | 1,000          | 100 M       |  |
| Measurement time (ms)     | .0002       | 1              | 1           |  |
| N                         | _           | _              | 5,000       |  |
| Max. Frequency error (Hz) | 263 k       | 1,000          | 50          |  |
| Max. Error %              | 5.26        | .02            | .001        |  |

The following table summarizes some of the differences in methods of measuring frequency.

Table 29. Frequency Measurement Method Comparison

| Method                                       | Number of<br>Counters Used | Number of<br>Measurements<br>Returned | Measures High<br>Frequency<br>Signals<br>Accurately | Measures Low<br>Frequency<br>Signals<br>Accurately |
|----------------------------------------------|----------------------------|---------------------------------------|-----------------------------------------------------|----------------------------------------------------|
| Low frequency with one counter               | 1                          | 1                                     | Poor                                                | Good                                               |
| High frequency with two counters             | 1 or 2                     | 1                                     | Good                                                | Poor                                               |
| Large range of frequencies with two counters | 2                          | 1                                     | Good                                                | Good                                               |

#### **Period Measurement**

In period measurements, the counter measures a period on its Gate input signal after the counter is armed. You can configure the counter to measure the period between two rising edges or two falling edges of the Gate input signal.

You can route an internal or external periodic clock signal (with a known period) to the Source input of the counter. The counter counts the number of rising (or falling) edges occurring on the Source input between the two active edges of the Gate signal.

You can calculate the period of the Gate input by multiplying the period of the Source signal by the number of edges returned by the counter.

Period measurements return the inverse results of frequency measurements.

# **Position Measurement**

You can use the counters to perform position measurements with quadrature encoders or two-pulse encoders. You can measure angular position with X1, X2, and X4 angular encoders. Linear position can be measured with two-pulse encoders.

You can choose to do either a single point (on-demand) position measurement or a buffered (sample clock) position measurement. You must arm a counter to begin position measurements.

#### Measurements Using Quadrature Encoders with X1, X2, or X3 encoding

The counters can perform measurements of quadrature encoders that use X1, X2, or X4 encoding. A quadrature encoder can have up to three channels—channels A, B, and Z.

# X1 Encoding

When channel A leads channel B in a quadrature cycle, the counter increments. When channel B leads channel A in a quadrature cycle, the counter decrements. The amount of increments and decrements per cycle depends on the type of encoding—X1, X2, or X4.

The following figure shows a quadrature cycle and the resulting increments and decrements for X1 encoding. When channel A leads channel B, the increment occurs on the rising edge of channel A. When channel B leads channel A, the decrement occurs on the falling edge of channel A.



## X2 Encoding

The same behavior holds for X2 encoding except the counter increments or decrements on each edge of channel A, depending on which channel leads the other. Each cycle results in two increments or decrements, as shown in the following figure.



# X4 Encoding

Similarly, the counter increments or decrements on each edge of channels A and B for X4 encoding. Whether the counter increments or decrements depends on which channel leads the other. Each cycle results in four increments or decrements, as shown in the following figure.



#### Channel Z Behavior

Some quadrature encoders have a third channel, channel Z, which is also referred to as the index channel. A high level on channel Z causes the counter to be reloaded with a specified value in a specified phase of the quadrature cycle. You can program the counter reload to occur in any one of the four phases in a quadrature cycle.

Channel Z behavior—when it goes high and how long it stays high—differs with quadrature encoder designs. You must refer to the documentation for your quadrature encoder to obtain timing of channel Z with respect to channels A and B. You must then ensure that channel Z is high during at least a portion of the phase you specify for reload. For instance, in Figure 7-21, channel Z is never high when channel A is high and channel B is low. Thus, the reload must occur in some other phase.

In the following figure, the reload phase is when both channel A and channel B are low. The reload occurs when the phase is true and channel Z is high. Incrementing and decrementing takes priority over reloading. Thus, when the channel B goes low to enter the reload phase, the increment occurs first. The reload occurs within one maximum timebase period after the reload phase becomes true. After the reload occurs, the counter continues to count as before. The following figure illustrates channel Z reload with X4 decoding.

Figure 77. Channel Z Reload with X4 Decoding



## **Measurements Using Two Pulse Encoders**

The counter supports two pulse encoders that have two channels—channels A and B.

The counter increments on each rising edge of channel A. The counter decrements on each rising edge of channel B, as shown in the following figure.

Figure 78. Measurements Using Two Pulse Encoders



#### **Buffered (Sample Clock) Position Measurement**

With buffered position measurement (position measurement using a sample clock), the counter increments based on the encoding used after the counter is armed.

The value of the counter is sampled on each active edge of a sample clock. A DMA controller transfers the sampled values to host memory. The count values returned are the cumulative counts since the counter armed event; that is, the sample clock does not reset the counter. You can route the counter sample clock to the Gate input of the counter. You can configure the counter to sample on the rising or falling edge of the sample clock.

The following figure shows an example of a buffered X1 position measurement.

Figure 79. Buffered Position Measurement



# Two-Signal Edge-Separation Measurement

Two-signal edge-separation measurement is similar to pulse-width measurement, except that there are two measurement signals—Aux and Gate.

An active edge on the Aux input starts the counting and an active edge on the Gate input stops the counting. You must arm a counter to begin a two edge separation measurement.

After the counter has been armed and an active edge occurs on the Aux input, the counter counts the number of rising (or falling) edges on the Source. The counter ignores additional edges on the Aux input.

The counter stops counting upon receiving an active edge on the Gate input. The counter stores the count in the FIFO.

You can configure the rising or falling edge of the Aux input to be the active edge. You can configure the rising or falling edge of the Gate input to be the active edge.

Use this measurement type to count events or measure the time that occurs between edges on two signals. This type of measurement is sometimes referred to as start/stop trigger measurement, second gate measurement, or A-to-B measurement.

# Single Two-Signal Edge-Separation Measurement

With single two-signal edge-separation measurement, the counter counts the number of rising (or falling) edges on the Source input occurring between an active edge of the Gate signal and an active edge of the Aux signal.

The counter then stores the count in the FIFO and ignores other edges on its inputs. Software then reads the stored count. The following figure shows an example of a single two-signal edge-separation measurement.

Counter
Armed

Measured Interval

AUX

GATE

SOURCE

Counter Value

0 0 0 0 1 2 3 4 5 6 7 8 8 8

Figure 80. Single Two-Signal Edge-Separation Measurement

## Implicit Buffered Two-Signal Edge-Separation Measurement

Implicit buffered and single two-signal edge-separation measurements are similar, but implicit buffered measurement measures multiple intervals.

8

The counter counts the number of rising (or falling) edges on the Source input occurring between an active edge of the Gate signal and an active edge of the Aux signal. The counter then stores the count in the FIFO. On the next active edge of the Gate signal, the counter begins another measurement. A DMA controller transfers the stored values to host memory. The following figure shows an example of an implicit buffered two-signal edge-separation measurement.



Figure 81. Implicit Buffered Two-Signal Edge-Separation Measurement

## Sample Clocked Buffered Two-Signal Separation Measurement

A sample clocked buffered two-signal separation measurement is similar to single two-signal separation measurement, but buffered two-signal separation measurement

Latched Value

takes measurements over multiple intervals correlated to a sample clock.

The counter counts the number of rising (or falling) edges on the Source input occurring between an active edge of the Gate signal and an active edge of the Aux signal. The counter then stores the count in the FIFO on a sample clock edge. On the next active edge of the Gate signal, the counter begins another measurement. A DMA controller transfers the stored values to host memory.

The following figure shows an example of a sample clocked buffered two-signal separation measurement.



Figure 82. Sample Clocked Buffered Two-Signal Separation Measurement

# **Counter Output Applications**

Refer to the following sections for more information on the various counter output applications available on the USB-6451.

# Simple Pulse Generation

The USB-6451 supports the following methods of simple pulse generation.

# **Single Pulse Generation**

The counter can output a single pulse. The pulse appears on the Counter **n** Internal Output signal of the counter.

You can specify a delay from when the counter is armed to the beginning of the pulse. The delay is measured in terms of a number of active edges of the Source input.

You can specify a pulse width. The pulse width is also measured in terms of a number of active edges of the Source input. You can also specify the active edge of the Source input (rising or falling).

The following figure shows a generation of a pulse with a pulse delay of four and a pulse width of three (using the rising edge of Source).

Figure 83. Single Pulse Generation



## Single Pulse Generation with Start Trigger

The counter can output a single pulse in response to one pulse on a hardware Start Trigger signal. The pulse appears on the Counter *n* Internal Output signal of the counter.

You can route the Start Trigger signal to the Gate input of the counter. You can specify a delay from the Start Trigger to the beginning of the pulse. You can also specify the pulse width. The delay and pulse width are measured in terms of a number of active edges of the Source input.

After the Start Trigger signal pulses once, the counter ignores the Gate input.

The following figure shows a generation of a pulse with a pulse delay of four and a pulse width of three (using the rising edge of Source).

Figure 84. Single Pulse Generation with Start Trigger



#### **Pulse Train Generation**

The USB-6451 supports the following methods of pulse train generation.

#### **Finite Pulse Train Generation**

Finite pulse train generation creates a train of pulses with programmable frequency and duty cycle for a predetermined number of pulses

With USB-6451 counters, the primary counter generates the specified pulse train and the embedded counter counts the pulses generated by the primary counter. When the embedded counter reaches the specified tick count, it generates a trigger that stops the primary counter generation. The following figure shows an example of finite pulse train generation.

Figure 85. Finite Pulse Train Generation: Four Ticks Initial Delay, Four Pulses



In Legacy Mode, the counter operation requires two counters and does not use the embedded counter. For example, to generate four pulses on Counter 0, Counter 0 generates the pulse train, which is gated by the paired second counter. The paired counter, Counter 1, generates a pulse of desired width.



Note Counter 0 is always paired with Counter 1. Counter 2 is always paired with Counter 3.

The routing is done internally. The following figure shows an example finite pulse train timing diagram.

Figure 86. Finite Pulse Train Timing in Legacy Mode



#### **Retriggerable Pulse or Pulse Train Generation**

The counter can output a single pulse or multiple pulses in response to each pulse on a hardware Start Trigger signal. The generated pulses appear on the Counter  $\boldsymbol{n}$  Internal Output signal of the counter.

You can route the start trigger signal to the gate input of the counter. You can specify a delay from the start trigger to the beginning of each pulse. You can also specify the pulse width. The delay and pulse width are measured in terms of a number of active edges of the source input. You can apply the initial delay to only the first trigger or to all triggers using the CO.EnableInitalDelayOnRetrigger property. The default for a single pulse is true, while the default for finite pulse trains is false.

The counter ignores the gate input while a pulse generation is in progress. After the pulse generation is finished, the counter waits for another start trigger signal to begin another pulse generation. For retriggered pulse generation, pause triggers are not allowed since the pause trigger also uses the gate input.

The following figure shows a generation of two pulses with a pulse delay of five and a pulse width of three (using the rising edge of Source) with CO.EnableInitalDelayOnRetrigger set to the default true.

Figure 87. Retriggerable Single Pulse Generation with Initial Delay on Retrigger



The following figure shows the same pulse train with CO.EnableInitalDelayOnRetrigger

set to the default false.

Figure 88. Retriggerable Single Pulse Generation with Initial Delay on Retrigger Set to False



The minimum time between the trigger and the first active edge is two ticks of the source.

#### **Continuous Pulse Train Generation**

Continuous pulse train generation creates a train of pulses with programmable frequency and duty cycle. The pulses appear on the Counter *n* Internal Output signal of the counter.

You can specify a delay from when the counter is armed to the beginning of the pulse train. The delay is measured in terms of a number of active edges of the source input.

You specify the high and low pulse widths of the output signal. The pulse widths are also measured in terms of a number of active edges of the source input. You can also specify the active edge of the source input (rising or falling).

The counter can begin the pulse train generation as soon as the counter is armed or in response to a hardware start trigger. You can route the start trigger to the gate input of the counter.

You can also use the gate input of the counter as a pause trigger (if it is not used as a start trigger). The counter pauses pulse generation when the pause trigger is active. The following figure shows a continuous pulse train generation (using the rising edge of source).

Figure 89. Continuous Pulse Train Generation



Continuous pulse train generation is sometimes called frequency division. If the high and low pulse widths of the output signal are M and N periods, then the frequency of the Counter  $\boldsymbol{n}$  Internal Output signal is equal to the frequency of the source input divided by M + N.

### **Finite Implicit Buffered Pulse Train Generation**

Finite implicit buffered pulse train generation creates a predetermined number of pulses with variable idle and active times.

Each point you write generates a single pulse. The number of pairs of idle and active times (pulse specifications) you write determines the number of pulses that are generated. All points are generated back to back to create a user-defined pulse train.

The following table and figure detail a finite implicit generation of three samples.

Table 30. Finite Implicit Buffered Pulse Train Generation

| Sample | Idle Ticks | Active Ticks |
|--------|------------|--------------|
| 1      | 2          | 2            |
| 2      | 3          | 4            |
| 3      | 2          | 2            |

Figure 90. Finite Implicit Buffered Pulse Train Generation



### **Continuous Buffered Implicit Pulse Train Generation**

Continuous buffered implicit pulse train generation creates a continuous train of pulses with variable idle and active times.

Instead of generating a set number of data samples and stopping, a continuous generation continues until you stop the operation. Each point you write generates a single pulse. All points are generated back to back to create a user-defined pulse train.

### Finite Buffered Sample Clocked Pulse Train Generation

Finite buffered sample clocked pulse train generation creates a predetermined number of pulse train updates. Each point you write defines pulse specifications that are updated with each sample clock.

When a sample clock occurs, the current pulse (idle followed by active) finishes generation and the next pulse updates with the next sample specifications.



Note When the last sample is generated, the pulse train continues to generate with these specifications until the task is stopped.

The following table and figure detail a finite sample clocked generation of three samples where the pulse specifications from the create channel are two ticks idle, two ticks active, and three ticks initial delay.

Table 31. Finite Buffered Sample Clocked Pulse Train Generation

| Sample | Idle Ticks | Active Ticks |
|--------|------------|--------------|
| 1      | 3          | 3            |
| 2      | 2          | 2            |
| 3      | 3          | 3            |



Figure 91. Finite Implicit Buffered Pulse Train Generation

The USB-6451 supports three methods of continuous generation for controlling what data is written: *regeneration*, *FIFO regeneration*, and *non-regeneration*.

- Regeneration—Data that is already in the buffer repeats. Data from the PC buffer is continually downloaded to the FIFO to be written out. New data can be written to the PC buffer at any time without disrupting the output.
- **FIFO Regeneration**—The entire buffer is downloaded to the FIFO and regenerated from the FIFO. Once the data is downloaded, new data cannot be written to the FIFO. To use FIFO regeneration, the entire buffer must fit within the FIFO size. The advantage of using FIFO regeneration is that it does not require communication with the main host memory once the operation starts, thereby preventing any problems that might occur due to excessive bus traffic.
- Non-Regeneration—Old data is not repeated. New data must be continually
  written to the buffer. If the program does not write new data to the buffer at a fast
  enough rate to keep up with the generation, the buffer underflows and causes an
  error.

### **Continuous Buffered Sample Clocked Pulse Train Generation**

Continuous buffered sample clocked pulse train generation creates a continuous train of pulses with variable idle and active times.

Instead of generating a set number of data samples and stopping, a continuous generation continues until you stop the operation. Each point you write specifies pulse specifications that are updated with each sample clock. When a sample clock occurs, the current pulse finishes generation and the next pulse uses the next sample specifications.

### **Frequency Generation**

You can generate a frequency by using a counter in pulse train generation mode or by

using the frequency generator circuit.

The frequency generator can output a square wave at many different frequencies. The frequency generator is independent of the four general-purpose 32-bit counter/timer modules on the USB-6451.

The following figure shows a block diagram of the frequency generator.

Figure 92. Frequency Generator Block Diagram



The frequency generator generates the Frequency Output signal. The Frequency Output signal is the Frequency Output Timebase divided by a number you select from 1 to 16. The Frequency Output Timebase can be either the 20 MHz Timebase, the 20 MHz Timebase divided by 2, or the 100 kHz Timebase.

The duty cycle of Frequency Output is 50% if the divider is either 1 or an even number. For an odd divider, suppose the divider is set to D. In this case, Frequency Output is low for (D + 1)/2 cycles and high for (D - 1)/2 cycles of the Frequency Output Timebase.

The following figure shows the output waveform of the frequency generator when the divider is set to 5.

Figure 93. Frequency Generator Output Waveform



Frequency Output can be routed out to any DIO <0..15> terminal. All digital I/O terminals are set to high-impedance at startup. The FREQ OUT signal can also be routed to many internal timing signals.

In software, program the frequency generator as you would program one of the

counters for pulse train generation.

### **Frequency Division**

The counters can generate a signal with a frequency that is a fraction of an input signal. This function is equivalent to continuous pulse train generation.

### **Pulse Generation for ETS**

In the equivalent time sampling (ETS) application, the counter produces a pulse on the output a specified delay after an active edge on Gate.

After each active edge on Gate, the counter cumulatively increments the delay between the Gate and the pulse on the output by a specified amount. Thus, the delay between the Gate and the pulse produced successively increases.

The increase in the delay value can be between 0 and 255. For instance, if you specify the increment to be 10, the delay between the active Gate edge and the pulse on the output increases by 10 every time a new pulse is generated.

Suppose you program your counter to generate pulses with a delay of 100 and pulse width of 200 each time it receives a trigger. Furthermore, suppose you specify the delay increment to be 10. On the first trigger, your pulse delay is 100, on the second it is 110, on the third it is 120; the process repeats until the counter is disarmed. The counter ignores any Gate edge that is received while the pulse triggered by the previous Gate edge is in progress.

The waveform thus produced at the counter's output can be used to provide timing for under sampling applications where a digitizing system can sample repetitive waveforms that are higher in frequency than the Nyquist frequency of the system. The following figure shows an example of pulse generation for ETS; the delay from the trigger to the pulse increases after each subsequent Gate active edge.

Figure 94. Pulse Generation for ETS



# Counter Timing Signals

The USB-6451 features nine counter timing signals.

- Counter **n** Source Signal
- Counter *n* Gate Signal
- Counter **n** Aux Signal
- Counter **n** A, Counter **n** B, and Counter **n** Z Signals
- Counter *n* Up\_Down Signal
- Counter *n* HW Arm Signal
- Counter **n** Sample Clock Signal
- Counter *n* Internal Output and Counter *n* TC Signals
- Frequency Output Signal

In this section, *n* refers to the USB-6451 Counter 0, 1, 2, or 3. For example, Counter *n* Source refers to four signals—Counter 0 Source (the source input to Counter 0), Counter 1 Source (the source input to Counter 1), Counter 2 Source (the source input to Counter 2), or Counter 3 Source (the source input to Counter 3).

### Counter *n* Source Signal

The selected edge of the Counter *n* Source signal increments and decrements the counter value depending on the application the counter is performing.

The following table lists how the terminal is used in various applications.

Table 32. Counter Applications and Counter *n* Source

| Application                   | Purpose of Source Terminal |
|-------------------------------|----------------------------|
| Pulse Generation              | Counter Timebase           |
| One Counter Time Measurements | Counter Timebase           |
| Two Counter Time Measurements | Input Terminal             |
| Non-Buffered Edge Counting    | Input Terminal             |
| Buffered Edge Counting        | Input Terminal             |
| Two-Edge Separation           | Counter Timebase           |

### Routing a Signal to Counter *n* Source

Each counter has independent input selectors for the Counter **n** Source signal. Any of the following signals can be routed to the Counter **n** Source input:

- 100 MHz Timebase
- 20 MHz Timebase
- 100 kHz Timebase
- DIO <0..15>
- · Change Detection Event

In addition, TC or Gate from a counter can be routed to a different counter source.

Some of these options may not be available in some driver software.

### Routing Counter *n* Source to an Output Terminal

You can route Counter **n** Source out to any DIO <0..15> terminal. All PFIs are set to high-impedance at startup.

# Counter *n* Gate Signal

The Counter *n* Gate signal can perform many different operations depending on the application including starting and stopping the counter, and saving the counter contents.

### Routing a Signal to Counter **n** Gate

Each counter has independent input selectors for the Counter *n* Gate signal. Any of the following signals can be routed to the Counter **n** Gate input:

- DIO < 0..15>
- Al Reference Trigger (ai/ReferenceTrigger)
- Al Start Trigger (ai/StartTrigger)
- AO Sample Clock (ao/SampleClock)
- DI Sample Clock (di/SampleClock)
- DI Reference Trigger (di/ReferenceTrigger)
- DO Sample Clock (do/SampleClock)
- · Change Detection Event

In addition, a counter's Internal Output or Source can be routed to a different counter's gate.

Some of these options may not be available in some driver software.

### Routing Counter *n* Gate to an Output Terminal

You can route Counter **n** Gate out to any DIO <0..15> terminal. All PFIs are set to highimpedance at startup.

### Counter *n* Aux Signal

The Counter **n** Aux signal indicates the first edge in a two-signal edge-separation measurement.

### Routing a Signal to Counter **n** Aux

Each counter has independent input selectors for the Counter *n* Aux signal. Any of the following signals can be routed to the Counter *n* Aux input:

- DIO < 0..15>
- Al Reference Trigger (ai/ReferenceTrigger)
- Al Start Trigger (ai/StartTrigger)

### · Change Detection Event

In addition, a counter's Internal Output, Gate or Source can be routed to a different counter's Aux. A counter's own gate can also be routed to its Aux input.

Some of these options may not be available in some driver software.

# Counter **n** A, Counter **n** B, and Counter **n** Z Signals

Counter **n** B can control the direction of counting in edge counting applications. Use the A, B, and Z inputs to each counter when measuring quadrature encoders or measuring two pulse encoders.

### Routing Signals to A, B, and Z Counter Inputs

Each counter has independent input selectors for each of the A, B, and Z inputs. DIO <0..15> signals can be routed to each input:

### Routing Counter *n* Z Signal to an Output Terminal

You can route Counter **n** Z out to any DIO <0..15> terminal.

# Counter n Up\_Down Signal

Counter **n** Up\_Down is another name for the Counter **n** B signal.

# Counter *n* HW Arm Signal

The Counter *n* HW Arm signal enables a counter to begin an input or output function.

To begin any counter input or output function, you must first enable, or arm, the counter. In some applications, such as a buffered edge count, the counter begins counting when it is armed. In other applications, such as single pulse-width measurement, the counter begins waiting for the Gate signal when it is armed. Counter output operations can use the arm signal in addition to a start trigger.

Software can arm a counter or configure counters to be armed on a hardware signal.

Software calls this hardware signal the Arm Start Trigger. Internally, software routes the Arm Start Trigger to the Counter **n** HW Arm input of the counter.

### Routing Signals to Counter **n** HW Arm Input

Any of the following signals can be routed to the Counter *n* HW Arm input:

- DIO < 0..15>
- Al Reference Trigger (ai/ReferenceTrigger)
- Al Start Trigger (ai/StartTrigger)
- Change Detection Event

A counter's Internal Output can be routed to a different counter's HW Arm.

Some of these options may not be available in some driver software.

# Counter *n* Sample Clock Signal

Use the Counter **n** Sample Clock (Ctr**n**SampleClock) signal to perform sample clocked acquisitions and generations.

You can specify an internal or external source for Counter *n* Sample Clock. You can also specify whether the measurement sample begins on the rising edge or falling edge of Counter *n* Sample Clock.

If the USB-6451 receives a Counter **n** Sample Clock when the FIFO is full, it reports an overflow error to the host software.

### **Using an Internal Source**

To use Counter **n** Sample Clock with an internal source, specify the signal source and the polarity of the signal. The source can be any of the following signals:

- DI Sample Clock (di/SampleClock)
- DO Sample Clock (do/SampleClock)
- AI Sample Clock (ai/SampleClock)
- AI Convert Clock (ai/ConvertClock)

- AO Sample Clock (ao/SampleClock)
- DI Change Detection output

Several other internal signals can be routed to Counter *n* Sample Clock through internal routes. Refer to *Device Routing in MAX* for more information.

### **Using an External Source**

You can route DIO <0..15> as Counter *n* Sample Clock.

You can sample data on the rising or falling edge of Counter *n* Sample Clock.

### Routing Counter *n* Sample Clock to an Output Terminal

You can route Counter **n** Sample Clock out to any DIO <0..15> terminal. The DIO circuitry inverts the polarity of Counter **n** Sample Clock before driving the DIO terminal.

### Counter *n* Internal Output and Counter *n* TC Signals

The Counter *n* Internal Output signal changes in response to Counter *n* TC.

The two software-selectable output options are pulse output on TC and toggle output on TC. The output polarity is software-selectable for both options.

With pulse or pulse train generation tasks, the counter drives the pulse(s) on the Counter *n* Internal Output signal. The Counter *n* Internal Output signal can be internally routed to be a counter/timer input or an "external" source for AI, AO, DI, or DO timing signals.

### Routing Counter *n* Internal Output to an Output Terminal

You can route Counter *n* Internal Output to any DIO <0..15> terminal. All PFIs are set to high-impedance at startup.

# Frequency Output Signal

The Frequency Output (FREQ OUT) signal is the output of the frequency output generator.

# **Counter Triggering**

Counters supports start and pause triggering actions.

### **Start Trigger**

For counter output operations, a start trigger can be configured to begin a finite or continuous pulse generation. Once a continuous generation has triggered, the pulses continue to generate until you stop the operation in software. For finite generations, the specified number of pulses is generated and the generation stops unless you use the retriggerable attribute. When you use this attribute, subsequent start triggers cause the generation to restart.

When using a start trigger, the start trigger source is routed to the Counter n Gate signal input of the counter.

Counter input operations can use the arm start trigger to have start trigger-like behavior.

### **Pause Trigger**

You can use pause triggers in edge counting and continuous pulse generation applications. For edge counting acquisitions, the counter stops counting edges while the external trigger signal is low and resumes when the signal goes high or vice versa. For continuous pulse generations, the counter stops generating pulses while the external trigger signal is low and resumes when the signal goes high or vice versa.

When using a pause trigger, the pause trigger source is routed to the Counter **n** Gate signal input of the counter.

# **Cascading Counters**

You can internally route the Counter *n* Internal Output and Counter *n* TC signals of each counter to the Gate inputs of the other counter. By cascading two counters together, you can effectively create a 64-bit counter.

By cascading counters, you can also enable other applications. For example, to improve the accuracy of frequency measurements, use reciprocal frequency measurement, as described in the frequency generation *Large Range of Frequencies with Two Counters* section.

### **Related concepts:**

• Large Range of Frequencies with Two Counters

# Counter Signal Prescaling

Prescaling allows the counter to count a signal that is faster than the maximum timebase of the counter. The USB-6451 offers 8X and 2X prescaling on each counter (prescaling can be disabled). Each prescaler consists of a small, simple counter that counts to eight (or two) and rolls over. This counter can run faster than the larger counters, which simply count the rollovers of this smaller counter. Thus, the prescaler acts as a frequency divider on the Source and puts out a frequency that is one-eighth (or one-half) of what it is accepting.

The following figure illustrates prescaling.



Prescaling is intended to be used for frequency measurement where the measurement is made on a continuous, repetitive signal. The prescaling counter cannot be read; therefore, you cannot determine how many edges have occurred since the previous

rollover. Prescaling can be used for event counting provided it is acceptable to have an error of up to seven (or one) ticks. Prescaling can be used when the counter Source is an external signal. Prescaling is not available if the counter Source is one of the internal timebases (100 MHz timebase, 20 MHz timebase, or 100k Hz timebase).

# Counter Signal Synchronization Modes

The 32-bit counter counts up or down synchronously with the Source signal. The Gate signal and other counter inputs are asynchronous to the Source signal, so the USB-6451 synchronizes these signals before presenting them to the internal counter.

#### 100 MHz Source Mode

In 100 MHz source mode, the USB-6451 synchronizes signals on the rising edge of the source, and counts on the third rising edge of the source. Edges are pipelined so no counts are lost, as shown in the following figure.



#### External Source Greater than 25 MHz

With an external source greater than 25 MHz, the USB-6451 synchronizes signals on the rising edge of the source, and counts on the third rising edge of the source. Edges are pipelined so no counts are lost, as shown in the following figure.



### External or Internal Source Less than 25 MHz

With an external or internal source less than 25 MHz, the USB-6451 generates a delayed Source signal by delaying the Source signal by several nanoseconds. The USB-6451

synchronizes signals on the rising edge of the delayed Source signal, and counts on the following rising edge of the source, as shown in the following figure.

Figure 98. External or Internal Source Less than 25 MHz



# Installing the USB-6451

Complete the following steps to install the USB-6451.

- 1. Unpacking the Kit
- 2. Installing Software

Before installing the USB-6451, you must install the software you plan to use with it.

- 3. Wiring the USB-6451
- 4. Verifying the Installation

Before using the USB-6451, verify that it is installed correctly through Hardware Configuration Utility or Measurement & Automation Explorer (MAX).

# Unpacking the Kit

1. Remove the device from the package and inspect the device for loose components or any other sign of damage.



**Notice** Never touch the exposed pins of connectors.



**Note** Do not install a device if it appears damaged in any way.

2. Unpack any other items and documentation from the kit.

# **Installing Software**

Before installing the USB-6451, you must install the software you plan to use with it.

- 1. Install your application software, such as LabVIEW or FlexLogger.
- 2. Install NI-DAQmx.



Note FlexLogger installs NI-DAQmx by default if you install it with the recommended settings. Therefore, you might not need to install NI-DAQmx separately if you installed FlexLogger as your application software.

#### Related reference:

• USB-6451 Driver Support

#### **Related information:**

- Download LabVIEW
- Download FlexLogger
- Download NI-DAQmx

# Wiring the USB-6451

### What to Use

• 0.14 mm<sup>2</sup> to 1.5 mm<sup>2</sup> (26 AWG to 16 AWG) copper conductor wire with 10 mm (0.394 in.) of insulation stripped from the end

#### What to Do

Refer to the following table for how to insert a wire into a terminal depending on what type of wire you are using or if you are using a ferrule.

| Option                                                  | Description                                                                             |
|---------------------------------------------------------|-----------------------------------------------------------------------------------------|
| When using a solid wire or stranded wire with a ferrule | Push the wire into the terminal when using a solid wire or stranded wire with a ferrule |
| When using a stranded wire without a ferrule            | Press the push button and then push the wire into the terminal                          |



**Note** You must use 2-wire ferrules to create a secure connection when connecting more than one wire to a single terminal.

# Verifying the Installation

Before using the USB-6451, verify that it is installed correctly through Hardware Configuration Utility or Measurement & Automation Explorer (MAX).

# Verifying the Installation in Hardware Configuration Utility

NI recommends using Hardware Configuration Utility to perform and to validate initial hardware configuration.

- 1. Open Hardware Configuration Utility. The USB-6451 appears in the system pane automatically.
- 2. Record the name that Hardware Configuration Utility assigns to the USB-6451 or provide a custom name.
  - Use this name when programming the USB-6451.
- 3. Validate that your instrument is installed correctly: select the USB-6451 module in the system pane, expand the **Troubleshooting** area of the configuration pane, and click Self-test.
  - Hardware Configuration Utility reports when it has validated the hardware setup.

# Verifying the Installation in MAX

To configure your NI hardware, use Measurement & Automation Explorer (MAX). MAX informs other programs about the NI hardware products in the system and their hardware configuration. MAX is automatically installed with NI-DAQmx.



**Note** MAX is not available on Linux.

- Launch MAX.
- 2. In the configuration tree, expand **Devices and Interfaces** to see the list of installed NI hardware.



Note If you do not see the device in the list, press <F5> to refresh the list of installed devices. If the device is still not listed, power off the system, ensure that the device is correctly installed, and restart.

- 3. Record the name MAX assigns to the hardware. Use this identifier when programming the USB-6451.
- 4. Self-test the hardware by selecting the item in the configuration tree and clicking Self-Test in the MAX toolbar.
  - MAX self-test performs a basic verification of hardware resources.

# What Do I Do If the USB-6451 Does Not Appear in Hardware Configuration Utility or MAX?

1. Check if you must refresh the connection between the hardware and the software.

| Software                       | Description                                                                                                                     |  |
|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--|
| Hardware Configuration Utility | Click the refresh button ( ).                                                                                                   |  |
| MAX                            | <ul> <li>a. In the MAX configuration tree, expand</li> <li>Devices and Interfaces.</li> </ul>                                   |  |
|                                | <ul> <li>b. To see the list of installed hardware,<br/>expand the Chassis tree and press F5 to<br/>refresh the list.</li> </ul> |  |

- 2. If the USB-6451 is still not listed, complete the following steps.
  - a. Power off the system.
  - b. Ensure that all hardware is correctly installed.
  - c. Check that the USB cable is intact and fully inserted. If using a USB hub, validate connections and power to the hub.
  - d. Restart the system.

### What Should I Do If the USB-6451 Fails the Self-Test?

- 1. Reset the USB-6451 through Hardware Configuration Utility or MAX and then perform the self-test again.
- 2. Restart the system, and then perform the self-test again.
- 3. Unplug and re-plug the USB Type-C cable from the computer.
- 4. Perform the self-test again.



**Note** If the module fails the self-test again, contact NI or visit <u>ni.com/</u> <u>support</u> for further troubleshooting information.

# Mounting the USB-6451

You can mount the USB-6451 in several ways.

Refer to the following sections for more information on mounting options for the USB-6451.

# Mounting the USB-6451 on a DIN Rail

You can mount the USB-6451 on a DIN rail vertically or horizontally.

The mounting kit you need depends on which orientation you plan to mount the USB-6451.

Table 33. USB-6451 Mounting Kit Options

| Mounting Orientation                             | Mounting Kit                                                | Part Number |
|--------------------------------------------------|-------------------------------------------------------------|-------------|
| Horizontal, connectors facing upward or downward | USB-64xx Mounting Kit for DIN<br>Rail                       | 789986-01   |
| Vertical, connectors facing outward              | USB-64xx Mounting Kit for DIN<br>Rail, Wall, or Panel Mount | 789955-01   |

#### Related reference:

Part Numbers for Recommended Accessories

# Mounting the USB-6451 on a DIN Rail Horizontally

You can mount the USB-6451 on a DIN rail with the USB-64xx Mounting Kit for DIN Rail.

#### What to Use

- USB-6451
- USB-64xx Mounting Kit for DIN Rail (P/N 789986-01)
  - DIN rail clip
  - ∘ #6-32 × 5/16 in. screws (x2)

• #2 Phillips screwdriver

### What to Do

1. Fasten the DIN rail clip to the bottom of the USB-6451 using two #6-32  $\times$  5/16 in. screws with a number #2 Phillips screwdriver.

Figure 99. USB-6451 DIN Rail Clip Installation



2. Clip the USB-6451 onto the DIN rail with the larger lip of the DIN rail clip positioned up.

Figure 100. DIN Rail Clip Parts



- 1. DIN rail clip
- 2. DIN rail spring
- 3. DIN rail

# Mounting the USB-6451 on a DIN Rail Vertically

You can mount the USB-6451 on a DIN rail vertically with the USB-64xx Mounting Kit for DIN Rail, Wall, or Panel Mount.

#### What to Use

- USB-6451
- USB-64xx Mounting Kit for DIN Rail, Wall, or Panel Mount (P/N 789955-01)
  - Mounting bracket
  - DIN rail clip
  - ∘ #6-32 × 5/16 in. Screws (x4)
  - Right-angle USB Type-C cable
- #2 Phillips screwdriver

#### What to Do

1. Choose which set of mounting bracket screw holes to use.

| Option | Description                                                                                                                              |  |
|--------|------------------------------------------------------------------------------------------------------------------------------------------|--|
| Set A  | Use these screw holes to position the USB-6451 as close to the wall as possible.                                                         |  |
|        | Note The USB cable cannot be installed or removed after mounting when using these mounting holes.                                        |  |
| Set B  | Use these screw holes to position the USB-6451 slightly farther from the wall to allow clearance access to the USB cable after mounting. |  |

- 2. Install the right-angle USB Type-C cable now if you are using the closest set of mounting screw holes (Set A). Connect the right-angle end of the USB Type-C cable to the USB-6451.
- 3. Fasten the mounting bracket to the USB-6451 using a #2 Phillips screwdriver and screws.

1

Figure 101. USB-6451 Mounting Bracket Installation

- 1. Mounting bracket
- 2. Screw
- 3. Mounting bracket screw holes set A
- 4. Mounting bracket screw holes set B
- 5. USB-6451
- 4. Fasten the DIN rail clip to the wall bracket using two #6-32  $\times$  5/16 in. screws with a number #2 Phillips screwdriver.

Figure 102. USB-6451 DIN Rail Clip Installation



- 1. Screws
- 2. DIN rail clip
- 3. Mounting bracket
- 4. USB-6451
- 5. Clip the USB-6451 onto the DIN rail with the larger lip of the DIN rail clip positioned up.

Figure 103. DIN Rail Clip Parts



- 1. DIN rail clip
- 2. DIN rail spring
- 3. DIN rail

# Mounting the USB-6451 on a Wall or Panel

You can mount the USB-6451 on a wall or panel with the USB-64xx Mounting Kit for DIN Rail, Wall, or Panel Mount.

#### What to Use

- USB-6451
- USB-64xx Mounting Kit for DIN Rail, Wall, or Panel Mount (P/N 789955-01)
  - Mounting bracket
  - #6-32 × 5/16 in. screws (x2)
  - Right-angle USB Type-C cable
- #2 Phillips screwdriver

#### What to Do

1. Choose which set of mounting bracket screw to use.

| Option | Description                                                                                                                              |
|--------|------------------------------------------------------------------------------------------------------------------------------------------|
| Set A  | Use these screw holes to position the USB-6451 as close to the wall as possible.                                                         |
|        | Note The USB cable cannot be installed or removed after mounting when using these mounting holes.                                        |
| Set B  | Use these screw holes to position the USB-6451 slightly farther from the wall to allow clearance access to the USB cable after mounting. |

- 2. Install the right-angle USB Type-C cable now if you are using the closest set of mounting screw holes (Set A). Connect the right-angle end of the USB Type-C cable to the USB-6451.
- 3. Fasten the mounting bracket to the USB-6451 using a #2 Phillips screwdriver and screws.

Figure 104. USB-6451 Mounting Bracket Installation



- 1. Mounting bracket
- 2. Screw
- 3. Mounting bracket screw holes set A
- 4. Mounting bracket screw holes set B
- 5. USB-6451
- 4. Fasten the mounting bracket to a wall or panel using the keyhole slots with M4 or 8-32 pan head screws. Position the screws on the wall using the dimensions below as a guide.

#### **Related reference:**

• Part Numbers for Recommended Accessories

# **USB-6451 Mounting Bracket Dimensions**

The mounting bracket is included in the USB-64xx Mounting Kit for DIN Rail, Wall, or Panel Mount (P/N 789955-01).

Figure 105. USB-6451 Mounting Bracket Dimensions



# Mounting the USB-6451 in a Rack

You can mount up to two USB-6451 devices in a 19-in. rack with the USB-64xx Rack Mount Shelf.

### What to Use

- USB-6451
- USB-64xx Rack Mount Shelf (P/N 789953-01)
  - Rack mount shelf
  - Screws (x2)



**Note** Two screws are required per device. You can mount up to two devices per shelf.

#### What to Do

1. Place the USB-6451 on the rack mount shelf. Figure 106. USB-6451 Rack Mount Shelf Installation



- 1. USB-6451
- 2. Rack mount shelf
- 3. Screws
- 4. Removable filler panel
- 2. Insert two screws through the bottom of the rack mount shelf and tighten with a screwdriver to fasten the USB-6451 to the rack mount shelf.
- 3. If you are mounting more than one USB-6451, remove the filler panel by loosening the screws with a screwdriver.
- 4. If your USB connection is on the front of the rack, feed the USB Type-C cable through the holes on the front panel.

#### Related reference:

• Part Numbers for Recommended Accessories

# Mounting the USB-6451 with Zip Ties

The USB-6451 has four holes that allow you to use zip ties to mount it.

Figure 107. USB-6451 Zip Tie Holes Location



1. Holes for zip ties

### What to Use

- USB-6451
- Zip ties

### What to Do

- 1. Place the USB-6451.
- 2. Secure the USB-6451 by threading zip ties through the holes and fastening them.

# **USB-6451 Zip Tie Holes Dimensions**

Figure 108. USB-6451 Zip Tie Holes Dimensions



# Migrating from Previous Products

The USB-6451 shares core I/O capabilities and NI-DAQmx programming API with previous generations of NI multifunction I/O products such as M Series and X Series. In many cases, you can run existing application on the USB-6451 with no or minimal modifications.

The following steps explain the general process for porting an application.

- 1. Review specifications and channel count to ensure that the USB-6451 provides enough analog input, analog output, or digital input/output for your application.
- 2. Re-wire the system to connect the USB-6451 to your I/O.
- 3. Upgrade NI-DAQmx on your system to a version that supports the USB-6451.
- 4. Plug in the USB-6451 and run your application using the USB-6451.
- 5. Identify and fix any issues.

# USB-6451 (OEM)

The USB-6451 is available in an OEM option. The USB-6451 (OEM) has 50-pin connectors.

Refer to the following sections to learn more about using the USB-6451 (OEM).

# USB-6451 (OEM) Parts

The USB-6451 (OEM) features two LEDs, a USB Type-C connector, and two 50-pin connectors.



- 1. USB PWR LED
- 2. USER LED

- 3. USB Type-C connector
- 4. Chassis ground lug
- 5. Al connector
- 6. AO/DIO connector

#### **USB PWR LED**

The USB PWR LED indicates the power status and communication activity.

Table 34, USB-6451 USB PWR LED Indicator Status

| Color | Pattern  | Meaning                                                                           |
|-------|----------|-----------------------------------------------------------------------------------|
| Off   | _        | The USB-6451 is not powered or not ready                                          |
| Green | Solid    | The USB-6451 is powered and ready but not actively communicating with the host PC |
|       | Blinking | USB-6451 is powered on and actively communicating with the host PC                |

### Why Is the USB PWR LED Off?

The USB PWR LED remains off when the USB-6451 is not powered or ready for operation.

This could be caused by the following reasons:

- The USB cable is not connected.
- The upstream PC or hub is not connected.
- The PC has put the USB-6451 into a low-power suspend or sleep state.
- The PC does not have a version of NI-DAQmx installed that supports the USB-6451.
- The USB-6451 is busy updating firmware.



**Note** When you connect the USB-6451 to a computer that has a different version of NI-DAQmx installed than the computer that the USB-6451 was

connected to previously, NI-DAQmx checks to see if the USB-6451 requires a firmware update. If it does, the USB-6451 automatically updates the firmware. This update may take several minutes. During this time, the LED will remain off until the USB-6451 is ready. Leave the USB-6451 connected to the computer during this time.

### **USER LED**

You can program the USER LED to communicate status information specific to your application.

The USER LED is off by default. You can configure it to the following settings.

- Off
- Solid green
- Solid yellow
- Solid red
- Blinking green
- Blinking yellow
- · Blinking red

### Configuring the User LED in Hardware Configuration Utility

Complete the following steps to configure the USER LED in Hardware Configuration Utility.

- 1. Select the USB-6451 from the list of connected devices in the System Pane.
- 2. In the Configuration Pane, select an option from the LED Settings drop-down list.

### Configuring the USER LED in MAX

Complete the following steps to configure the USER LED in Measurement & Automation Explorer (MAX).

- 1. In the configuration tree, expand **Devices and Interfaces** to see the list of installed NI hardware.
- 2. Select the USB-6451.
- 3. Select an option from the LED State drop-down list.

#### 4. Click Save.

### **USB Type-C Connector**

Use the USB Type-C connector to connect the USB-6451 to a host computer through a USB Type-C cable.

# **Chassis Ground Lug**

Use the chassis ground lug to connect the USB-6451 to earth ground. If you are using a rear panel with a USB Type-C cutout, ensure this screw is always attached during operation.

### **Al Connector**

Provides pins for analog input signal connections.

# **AO/DIO Connector**

Provides pins for analog output and digital I/O signal connections.

# USB-6451 (OEM) Pinouts

# **USB-6451 (OEM) AI Connector Pinout**

Use the pinout to connect to analog input terminals on the USB-6451 (OEM).

Figure 110. USB-6451 (OEM) AI Connector Pinout



Table 35. USB-6451 (OEM) AI Connector Pin Assignments

| Pin | Signal        |  |
|-----|---------------|--|
| 1   | AI 8          |  |
| 2   | AI 0          |  |
| 3   | AI 9          |  |
| 4   | Al 1          |  |
| 5   | AI GND        |  |
| 6   | AI GND        |  |
| 7   | AI 10         |  |
| 8   | AI 2          |  |
| 9   | AI 11         |  |
| 10  | AI 3          |  |
| 11  | AI GND        |  |
| 12  | AI GND        |  |
| 13  | AI 12         |  |
| 14  | Al 4          |  |
| 15  | AI 13         |  |
| 16  | AI 5          |  |
| 17  | AI GND        |  |
| 18  | AI GND        |  |
| 19  | AI 14         |  |
| 20  | AI 6          |  |
| 21  | AI 15         |  |
| 22  | AI 7          |  |
| 23  | AI GND        |  |
| 24  | NR (AI SENSE) |  |
| 25  | AI GND        |  |
| 26  | NR (AI SENSE) |  |

| Pin | Signal     |
|-----|------------|
| 27  | No connect |
| 28  | No connect |
| 29  | No connect |
| 30  | No connect |
| 31  | AI GND     |
| 32  | AI GND     |
| 33  | No connect |
| 34  | No connect |
| 35  | No connect |
| 36  | No connect |
| 37  | AI GND     |
| 38  | AI GND     |
| 39  | No connect |
| 40  | No connect |
| 41  | No connect |
| 42  | No connect |
| 43  | AI GND     |
| 44  | AI GND     |
| 45  | No connect |
| 46  | No connect |
| 47  | No connect |
| 48  | No connect |
| 49  | CHSGND     |
| 50  | ID 0       |

Table 36. USB-6451 (OEM) AI Connector Signal Descriptions

| Signal           | Function                  | Reference | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|------------------|---------------------------|-----------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| AI <07>          | Analog input<br>channels  | Varies    | Input     | Supports differential or single-ended measurement modes. The default configuration is differential mode.  In differential mode, these channels are the positive input for the differential pair. The negative input of the differential pair is located directly beneath the positive input.  In single-ended mode, each signal is a separate analog input voltage channel. The ground reference in single-ended mode is configurable. In referenced single-ended (RSE) mode, AI GND is the reference for the voltage measurement. In non-referenced single-ended (NRSE) mode, the NR pin is the reference.  Note You can configure the input mode per channel. |  |  |
| AI<br><815>      | Analog input channels     | Varies    | Input     | Supports single-ended measurements only. The default configuration is RSE mode. In RSE mode, AI GND is the reference for the voltage measurement. In NRSE mode, the NR pin is the reference.  For differential measurements, refer to the descriptions for AI <07>.                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| AI GND           | Analog input ground       | _         | _         | The reference point for single-ended measurements in RSE mode and the bias current return point for differential measurements.  AI GND, AO GND, D GND, and CHSGND are all connected internally.                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| NR (AI<br>SENSE) | AI SENSE for<br>NRSE mode | _         | Input     | The AI SENSE pin is labeled "NR" because it is used when the input terminal is configured to NRSE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |

| Signal | Function                                        | Reference | Direction       | tion Description                                                                                                                                                                          |  |  |
|--------|-------------------------------------------------|-----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|        |                                                 |           |                 | mode. In NRSE mode, AI SENSE acts as a remote sense of a reference voltage that can be at a different voltage potential than AI GND.                                                      |  |  |
| CHSGND | Chassis<br>ground                               | _         | _               | Connects directly to the chassis ground lug of the USB-6451 (OEM). It can be used as a termination point for shielded cables to help improve measurement quality.                         |  |  |
| ID 0   | Identification<br>pin 0 for the<br>Al connector | D GND     | Input or output | Can be connected to a 1-wire EEPROM for storing test setup identification information. Leave this pin open if you do not use it. Refer to the <i>ID Pin</i> section for more information. |  |  |

#### **Related reference:**

• <u>USB-6451 ID Pin</u>

### **USB-6451 (OEM) AO/DIO Connector Pinout**

Use the pinout to connect to analog output and digital input/output terminals on the USB-6451 (OEM).

Figure 111. USB-6451 (OEM) AO/DIO Connector Pinout



Table 37. USB-6451 (OEM) AO/DIO Connector Pin Assignments

| Pin | Signal                      |  |
|-----|-----------------------------|--|
| 1   | CHSGND                      |  |
| 2   | ID 1                        |  |
| 3   | AO GND                      |  |
| 4   | AO 0                        |  |
| 5   | AO GND                      |  |
| 6   | AO 1                        |  |
| 7   | AO GND                      |  |
| 8   | No connect                  |  |
| 9   | AO GND                      |  |
| 10  | No connect                  |  |
| 11  | D GND                       |  |
| 12  | +5 V                        |  |
| 13  | PFI 8/P0.8 (port0/line8)    |  |
| 14  | PFI 0/P0.0 (port0/line0)    |  |
| 15  | D GND                       |  |
| 16  | D GND                       |  |
| 17  | PFI 9/P0.9 (port0/line9)    |  |
| 18  | PFI 1/P0.1 (port0/line1)    |  |
| 19  | D GND                       |  |
| 20  | D GND                       |  |
| 21  | PFI 10/P0.10 (port0/line10) |  |
| 22  | PFI 2/P0.2 (port0/line2)    |  |
| 23  | D GND                       |  |
| 24  | D GND                       |  |
| 25  | PFI 11/P0.11 (port0/line11) |  |
| 26  | PFI 3/P0.3 (port0/line3)    |  |

| Pin | Signal                      |
|-----|-----------------------------|
| 27  | D GND                       |
| 28  | D GND                       |
| 29  | PFI 12/P0.12 (port0/line12) |
| 30  | PFI 4/P0.4 (port0/line4)    |
| 31  | D GND                       |
| 32  | D GND                       |
| 33  | PFI 13/P0.13 (port0/line13) |
| 34  | PFI 5/P0.5 (port0/line5)    |
| 35  | D GND                       |
| 36  | D GND                       |
| 37  | PFI 14/P0.14 (port0/line14) |
| 38  | PFI 6/P0.6 (port0/line6)    |
| 39  | D GND                       |
| 40  | D GND                       |
| 41  | PFI 15/P0.15 (port0/line15) |
| 42  | PFI 7/P0.7 (port0/line7)    |
| 43  | PWR_GR                      |
| 44  | PWR_RED                     |
| 45  | USER_GR                     |
| 46  | USER_RED                    |
| 47  | No connect                  |
| 48  | No connect                  |
| 49  | No connect                  |
| 50  | No connect                  |

Table 38. USB-6451 (OEM) AO/DIO Connector Signal Descriptions

| Signal             | Function                       | Reference | Direction       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|--------------------|--------------------------------|-----------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| AO <01>            | Analog<br>output<br>channels   | AO GND    | Output          | Supplies the voltage output of the AO channels.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| AO GND             | Analog<br>output<br>ground     | _         | _               | AO GND is the reference for the AO channels.  AI GND, AO GND, D GND, and CHSGND are all connected internally.                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| +5 V               | +5 V power source              | D GND     | Output          | Provides current limited +5 V power output that can be used to power external circuitry. Refer to the +5 V Power Source section for more information. Leave this pin open if you do not use it.                                                                                                                                                                                                                                                                                                                            |  |
| PFI <015>/P0.<015> | Port 0 digital<br>I/O channels | D GND     | Input or output | Digital channels that can be individually configured as input or output.  These channels are referred to as port0/line0:15 in software when used as digital I/O. They are referred to as PFI 0:15 when used for other purposes, like timing I/O.  Can also be individually configured for the following uses.  Digital I/O Counter/timer input Counter/timer output External timing or trigger signal input for AI, AO, DI, DO, counter, or timers Timing or trigger signal output from AI, AO, DI, DO, counter, or timers |  |
| D GND              | Digital                        | _         | _               | Supplies the reference for the P0.<015>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |

| Signal   | Function                      | Reference | Direction | Description                                                                                                                                                                     |
|----------|-------------------------------|-----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | ground                        |           |           | pins and +5 V pin.  AI GND, AO GND, D GND, and CHSGND are all connected internally.                                                                                             |
| CHSGND   | Chassis<br>ground             | _         | _         | Connects directly to the chassis ground lug of the USB-6451 (OEM). It can be used as a termination point for shielded cables to help improve measurement quality.               |
| PWR_GR   | USB PWR<br>LED green<br>color | D GND     | Output    | Digital logic control signal that is high when the USB PWR LED is green or yellow. You can use this signal to drive an external LED.  Leave this pin open if you do not use it. |
| PWR_RED  | USB PWR<br>LED red color      | D GND     | Output    | Digital logic control signal that is high when the USB PWR LED is red or yellow. You can use this signal to drive an external LED.  Leave this pin open if you do not use it.   |
| USER_GR  | User LED<br>green color       | D GND     | Output    | Digital logic control signal that is high when the USER LED is green or yellow. You can use this signal to drive an external LED.  Leave this pin open if you do not use it.    |
| USER_RED | User LED red<br>color         | D GND     | Output    | Digital logic control signal that is high<br>when the USER LED is red or yellow. You<br>can use this signal to drive an external<br>LED.                                        |

| Signal | Function                                               | Reference | Direction       | ection Description                                                                                                                                                                        |  |
|--------|--------------------------------------------------------|-----------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|        |                                                        |           |                 | Leave this pin open if you do not use it.                                                                                                                                                 |  |
| ID 1   | Identification<br>pin 1 for the<br>AO/DIO<br>connector | D GND     | Input or output | Can be connected to a 1-wire EEPROM for storing test setup identification information. Leave this pin open if you do not use it. Refer to the <i>ID Pin</i> section for more information. |  |

#### Related reference:

USB-6451 ID Pin

### USB-6451 (OEM) Connectors

You can connect the following I/O connectors on the USB-6451 (OEM) using a 0.100 in. x 0.100 in. pitch ribbon cable or PCB socket. Refer to the manufacturer's data sheet for compatibility information.

Table 39. USB-6451 (OEM) Connectors

| Connector | Component                                | Reference | Manufacturer | Manufacturer |  |
|-----------|------------------------------------------|-----------|--------------|--------------|--|
| Connector | Connector Component Designator(s) on PCB |           | Manufacturer | Part Number  |  |
| AI        | 50-pin header                            | P1        | 3M           | N2550-6002RB |  |
| AO/DIO    | 50-pin header                            | P2        | 3M           | N2550-6002RB |  |

#### **Related reference:**

- USB-6451 (OEM) AI Connector Pinout
- USB-6451 (OEM) AO/DIO Connector Pinout

# Attaching External LEDs to the USB-6451 (OEM)

You can duplicate the device state reflected by the USB PWR and USER LEDs by attaching external LEDs or any other circuitry to the four I/O pins on the AO/DIO

#### connector.

Complete the following steps to connect an external LED or any other circuitry to the USB-6451 (OEM).



**Note** The current of each of the four I/O pins is limited by a 470  $\Omega$  resettable fuse to the 3.3 V internal supply. This configuration limits the current to approximately 5 mA into a single external LED with 1 V forward voltage. These pins are protected up to  $\pm 20$  V. Leave the pins open if you do not use them.

- 1. Connect the LED anode to one of the four I/O pins of the AO/DIO connector as the positive connection.
- 2. Connect the LED cathode to any DGND as the negative connection. Figure 112. Attaching External LEDs to the USB-6451 (OEM)



#### **Related reference:**

- USB-6451 (OEM) AO/DIO Connector Pinout
- <u>USB-6451 (OEM) Parts</u>

# Mounting the USB-6451 (OEM)

The USB-6451 (OEM) has four screw holes, located in the corners, for mounting.

#### What to Use

- USB-6451 (OEM)
- 4-40 or M3 screws
- Screwdriver

#### What to Do

- 1. Place the USB-6451 (OEM) in position.
- 2. Insert the screw through the screw holes and tighten them to secure the USB-6451 (OEM) in place. The following figure shows the locations of the mounting screw holes on the USB-6451 (OEM).

Figure 113. USB-6451 (OEM) Screw Holes Locations



1. Mounting screw holes

### **USB-6451 (OEM) Dimensions**

Use the dimensions of the USB-6451 (OEM) to design your system configuration.

The following figure shows the dimensions of the USB-6451 (OEM). Unless otherwise specified, dimensions are in millimeters and [inches].

You can use the center location for the LEDs, USB connector, and grounding lug to integrate the USB-6451 (OEM) in a custom enclosure. The grounding lug is positioned to attach to a 2 mm thick (or thinner) panel to ensure that you can connect a USB cable without interference. The grounding lug ships with a 6-32 Phillips/Standard Slot combo screw pre-installed.



Figure 114. USB-6451 (OEM) Dimensions

## Adding a Locking Screw

You can add a locking screw to your enclosure to secure the USB Type-C cable to the USB-6451 (OEM).

Center an M2 thread above the USB Type-C connector on the USB-6451 (OEM) and 6.8 mm from the center line of the USB Type-C connector.

Refer to the *Universal Serial Bus Type-C Connectors and Cable Assemblies*Compliance Document, section Single Screw USB Type-C Locking Plug

Additional Dimensional Requirements for illustrations.

### **Related information:**

• Universal Serial Bus Type-C Connectors and Cable Assemblies Compliance **Document**