# **CIO-DAS16/330**

# **USERS MANUAL**



**Revision 5A** 

April, 2001

# **Trademark and Copyright Information**

Measurement Computing Corporation, InstaCal, Universal Library, and the Measurement Computing logo are either trademarks or registered trademarks of Measurement Computing Corporation. Refer to the Copyrights & Trademarks section on <u>mccdaq.com/legal</u> for more information about Measurement Computing trademarks. Other product and company names mentioned herein are trademarks or trade names of their respective companies.

© 2001 Measurement Computing Corporation. All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form by any means, electronic, mechanical, by photocopying, recording, or otherwise without the prior written permission of Measurement Computing Corporation.

#### Notice

Measurement Computing Corporation does not authorize any Measurement Computing Corporation product for use in life support systems and/or devices without prior written consent from Measurement Computing Corporation. Life support devices/systems are devices or systems that, a) are intended for surgical implantation into the body, or b) support or sustain life and whose failure to perform can be reasonably expected to result in injury. Measurement Computing Corporation products are not designed with the components required, and are not subject to the testing required to ensure a level of reliability suitable for the treatment and diagnosis of people.

© Copyright 2001 Measurement Computing Corp.

HM CIO-DAS16\_330.lwp

# Table of Contents

| 1 INTRODUCTION11.1 INITIATING ENHANCED MODE11.2 THIRD PARTY SOFTWARE1                                               |
|---------------------------------------------------------------------------------------------------------------------|
| <b>2 INSTALLATION</b>                                                                                               |
| 2.2 HARDWARE 2   2.2.1 BASE ADDRESS 2                                                                               |
| 2.2.2 MODE SWITCH 2   2.2.3 DMA LEVEL SELECT 3   2.2.4 1/10 MU WITCH 3                                              |
| 2.2.4 1/10 MHz XTAL JUMPER 3   2.2.5 8/16 CHANNEL SELECT 4   2.2.6 INSTALLING THE BOARD IN THE COMPUTER 4           |
| <b>3 SIGNAL CONNECTION</b> 5<br>3.1 CONNECTOR DIAGRAM 5                                                             |
| 3.2 ANALOG INPUTS 6   3.3 SINGLE-ENDED 6                                                                            |
| 3.4 FLOATING DIFFERENTIAL 7   3.5 DIFFERENTIAL 7   2.6 DIGITAL OUTPUTS % DIDUTS 7                                   |
| 3.6 DIGITAL OUTPUTS & INPUTS 7   4 REGISTER ARCHITECTURE 8   8 8                                                    |
| 4.1 DATA TRANSFERS 8   4.2 FIFO DATA BUFFER 8   4.3 CONTROL & DATA REGISTERS 8                                      |
| 4.4A/D DATA & CHANNEL REGISTERS104.5CHANNEL MUX SCAN LIMITS REGISTER10                                              |
| 4.6 FOUR-BIT DIGITAL I/O REGISTERS 11   4.7 STATUS REGISTER 11   4.8 DMA NITEDDUPT % TRUCCED CONTROL                |
| 4.8 DMA, INTERRUPT & TRIGGER CONTROL 12   4.9 PACER CLOCK CONTROL REGISTER 12   4.10 ANALOG INPUT RANGE REGISTER 13 |
| 4.11 PACER CLOCK DATA & CONTROL REGISTERS154.12 ENHANCED FEATURES PACER CLOCK DATA & CONTROL REGISTERS16            |
| 4.13 ANALOG INPUT 16   4.14 DIGITAL INPUT & OUTPUT 17   4.14 1 OUTPUT                                               |
| 4.14.1 OUTFOT                                                                                                       |
| 4.16 DMA CONTROL LOGIC 18   5 SPECIFICATIONS 19                                                                     |
| 6 ANALOG ELECTRONICS 21<br>6 1 VOL TAGE DIVIDERS 21                                                                 |
| 6.2 DIFFERENTIAL & SINGLE ENDED INPUTS226.3 LOW PASS FILTERS25                                                      |
| 6.4 A/D RESOLUTION & ENGINEERING UNITS 25   6.5 ENGINEERING UNITS 26   6.6 CURRENT LOOP 4-20 mA 26                  |

# Table of Contents

| 6.7 N | IOISE               | 27 |
|-------|---------------------|----|
| 6.7.  | 1 SOURCES OF NOISE  | 27 |
| 6.7.  | 2 SIGNAL WIRE NOISE | 27 |
| 6.7.  | 3 SENSOR NOISE      | 28 |
| 6.7.  | 4 SMOOTHING DATA    | 28 |

The CIO-DAS16/330 is two architectures on one A/D board; one having standard DAS-16 registers and one having extended registers.

To maintain compatibility with existing software written for the DAS-16, a complete set of DAS-16 (CIO-DAS16) compatible registers exists at BASE + 0 through BASE + 15. When in Compatible Mode, the CIO-DAS16/330 behaves as a CIO-DAS16 (DAS-16G) would except that it is capable of a much faster sample rate.

A second set of registers exists at BASE + 16 through BASE + 24.

In addition, a special register at BASE + 11 opens up when the CIO-DAS16/330 is in the Enhanced mode.

# 1.1 INITIATING ENHANCED MODE

The CIO-DAS16/330 is placed in enhanced mode by setting one switch, then by writing to a specific address. When in enhanced mode, the CIO-DAS16/330 occupies 32 I/O addresses and so may only be placed on even hex 20 I/O address boundaries. Examples of achievable base addresses are; 300h, 320h, 340h. Addresses such as 310h and 330h are not possible in enhanced mode.

Enhanced mode opens up additional counters and control registers which allow:

- 16-bit bus transfers.
- Transfer rates of 330 kHz using the REP-INSW command.
- Pre-trigger and post-trigger sample buffers.

Enhanced mode is fully supported by the optional Universal Library<sup>TM</sup>. Using it, you can acquire data at rates to 330 kHz and store pre/post trigger buffers limited only by system RAM size.

# 1.2 THIRD PARTY SOFTWARE

Software packages such as Labtech Notebook support the enhanced features of the CIO-DAS16/330.

Because the CIO-DAS16/330 remains compatible with the DAS-16 even when the enhanced mode features are activated, all third party software compatible with the DAS-16 will operate regardless of the mode switch position.

# **2 INSTALLATION**

# 2.1 SOFTWARE

Before you open your computer and install the board, install and run *Insta*Cal<sup>TM</sup>, the installation, calibration and test utility included with your board. *Insta*Cal<sup>TM</sup> will guide you through switch and jumper settings for your board. Detailed information regarding these settings can be found below. Refer to the *Software Installation* manual for *Insta*Cal<sup>TM</sup> installation instructions.

#### 2.2 HARDWARE

The CIO-DAS16/330 has one bank of base address plus mode switches, two single function switches and one jumper block which must be set before installation of the board inside your computer.

#### 2.2.1 BASE ADDRESS

The base address is set at the factory to 300 hex as shown in figure 2.1. Unless there is already a board in your system which uses address 300h (768 decimal), leave the switches as they are set at the factory.

The switch numbers here refer to the number printed on the board itself, not the switch body.

The "8 BIT" switch is a MODE SWITCH and has no effect on the base address itself, only the address boundary as detailed below.

| _ | 9 | 8 | 7 | 6 | 5 | 4 | 8 BIT | SW         | HEX |
|---|---|---|---|---|---|---|-------|------------|-----|
|   |   |   |   |   |   |   |       | A9         | 200 |
|   |   |   |   |   |   |   |       | A8         | 100 |
|   |   |   |   |   |   |   |       | <b>A</b> 7 | 80  |
|   | 1 | 1 |   |   |   |   |       | A6         | 40  |
|   | Ţ | Ţ | T | Ī | T | T | T     | <b>A</b> 5 | 20  |
|   | • | • | • | • | • | • | •     | A4         | 10  |

BASE ADDRESS & MODE SWITCHES Address 300h shown. Set the "8 BIT" mode switch up for compatibility. Set it down for enhanced mode.

Figure 2-1. Base Address and Mode Select Switches

#### 2.2.2 MODE SWITCH

The "8-bit" switch of the base address switch block is the mode switch. The mode switch enables and disables extended addresses and other features of the CIO-DAS16/330. The extended features are those associated with addresses base + 15 through base + 31. When the mode switch is up, no features associated with those registers are available.

NOTE: When the mode switch is DOWN (enhanced mode), the address 4 switch must be UP (zero).

The state of the mode switch can be read back at Base Address + 11. When the mode switch is UP, Base Address + 11, BIT 4 reads back as a zero. When the mode switch is down, Base Address + 11, BIT 4 reads back as a one.

When the switch is UP, the board is compatible with the MetraByte DAS-16 and Measurement Computings CIO-DAS16.

Because only 16 I/O addresses are used when the mode switch is UP, the board can be placed on 16-bit boundaries, such as 300h, 310h 320h, 330h and 340h.

When the mode switch is DOWN, the board is in extended features mode, or full PC/AT mode. Additional control bits are present in the upper nibble of Base Address + 11 and a second 8254 counter is addressable for pre/post trigger control. When the mode switch is down, base addresses such as 300h, 320h and 340h are available while addresses such as 310h and 330h are not. In enhanced mode, the CIO-DAS16/330 occupies 32 I/O addresses.

# 2.2.3 DMA LEVEL SELECT

First, determine the kind of computer you installing the board in. If it is an XT, there are only two DMA levels available and level 3 is probably used by the hard disk controller in your XT computer. Set the DMA level switch to the level 1 position.

If you have an AT or 386 type computer the hard disk controller is not at level 1 or 3 so either level may be used.

There are other boards that use DMA levels. Some network boards do and so do some IEEE-488 interface boards. If you have other boards in your computer with DMA level switches on them, make sure they don't conflict.



# DMA LEVEL SELECT - DMA Level 1 is selected.

Figure 2-2. DMA Level Select Jumper

# 2.2.4 1/10 MHz XTAL JUMPER

The 1/10 MHz XTAL jumper selects the frequency of the source applied to the on board pacer (Counter 2).

This jumper is on the board because the original DAS-16, designed in 1984, had a 1 MHz crystal. When MetraByte redesigned the DAS-16 and added the faster 10 MHz crystal, a jumper was provided to maintain compatibility with older software. The CIO-DAS16/330 has the jumper because the DAS-16 has the jumper and some software requires the jumper to be in the 1 MHz position and some software requires the 10 MHz position.





The CIO-DAS16/330 is shipped with the jumper in the 1 MHz position.

Older software programs may require that the jumper be in the 1 MHz position. Please refer to the software program user's manual for guidance. Use the 10 MHz setting for any new development for better rate resolution when programming the on board pacer.

### 2.2.5 8/16 CHANNEL SELECT

The CIO-DAS16/330 can be configured for eight differential or 16 single-ended analog inputs. Using differential inputs allows up to 10 volts of common mode (ground loop) rejection and is more immune to RFI and EMI.

The board comes from the factory with the 8/16 Channel Select switch set for eight differential inputs (Figure 2-4). Set it for the type (and number) of inputs you require.



8/16 CHANNEL SELECT - 8 Differential inputs selected.

Figure 2-4. 8 or 16 Channels Select Switch

# 2.2.6 INSTALLING THE BOARD IN THE COMPUTER

- 1. Turn the power off.
- 2. Remove the cover of your computer. Please be careful not to dislodge any of the cables installed on the boards in your computer as you slide the cover off.
- 3. Locate an empty expansion slot in your computer.
- 4. Push the board firmly down into the expansion bus connector. If it is not seated fully it may fail to work and could short circuit the PC bus power onto a PC bus signal. This could damage the motherboard in your PC as well as the CIO-DAS16/330.
- 5. Turn the PC power back on and verify proper installation by running *Insta*Cal Test (refer to the *Software Installation Manual* for information on running *Insta*Cal.

This section presents 'how to connect' common signals while avoiding discussion of electrical theory and special symbols.

# 3.1 CONNECTOR DIAGRAM

The CIO-DAS16/330 analog connector is a 37-pin, D-type connector accessible from the rear of the PC through the expansion backplate. With the exception of pins 8, 9, 10, 26 and 27 (D/A signals on the DAS-16, no connect on the CIO-DAS16/330), the signals available are identical to the DAS-16. An additional signal, SS&H OUT, can be accessed at pin 26.





The connector accepts female 37-pin, D-type connectors, such as those on the C73FF-2, 2 foot cable with connectors.

If frequent changes to signal connections or signal conditioning is required, please refer to the information on the CIO-MINI37 or CIO-TERMINAL screw terminal boards, CIO-EXP32 32 channel analog MUX/AMP, CIO-SSH16 16 channel simultaneous sample & hold board or the ISO-RACK08 5B isolation module interface rack.

# 3.2 ANALOG INPUTS

Analog inputs to the CIO-DAS16/330 may be connected in three different configurations. These are single-ended, floating differential, and differential.

#### WARNING - PLEASE READ

Measure the voltage between the ground signal at the signal source and the PC. Use a volt meter and place the red probe on the PC ground and the black probe on the signal ground. If the voltage is more than 10 volts, do not connect the CIO-DAS16/330 to this signal source because you will not be able to make a valid reading. If the difference is more than 30 volts, DO NOT connect this signal to the CIO-DAS16/330 because it will damage the board and possibly the computer.

# 3.3 SINGLE ENDED

A single ended input is two wires connected to the board; a channel high (CH# HIGH) and a Low Level Ground (LLGND). The LLGND signal must be the same ground the PC is on. The CH# HIGH is the voltage signal source (Figure 3-2).



Figure 3-2. Single-Ended Input

# 3.4 FLOATING DIFFERENTIAL

A floating differential input is two wires from the signal source and a 10K ground reference resistor installed at the board input. The two signals from the signal source are Signal High (CH# HIGH) and Signal Low (CH# LOW).

The reference resistor is connected between the CIO-DAS16/330 CH# LOW and LLGND pins (Figure 3-3).

A floating differential hookup is handy when the signal source is floating with respect to ground, such as a battery, 4-20 mA transmitter or and the lead lengths are long or subject to EMI interference.

The floating differential input will reject up to 10V of EMI energy on the signal wires.



CIO-DAS16 CONNECTOR 8 CHANNEL DIFFERENTIAL

Figure 3-3. Differential Input - Floating Source

#### WARNING!

Is the signal source really floating? Check it with an ohmmeter before risking the board and the PC!

# 3.5 DIFFERENTIAL

A differential signal has three wires from the signal source; Signal High (CH# HIGH), Signal Low (CH# LOW) and Signal Ground (LLGND) See Figure 3-4.

A differential connection allows you to connect the board to a signal source with a ground that is different than the PC ground, but has less than a 10V difference, and still make a true measurement of the signal between CH# HIGH and CH# LOW.



CIO-DAS16 CONNECTOR 8 CHANNEL DIFFERENTIAL

Figure 3-4. Differential Input

#### EXAMPLE:

A laboratory instrument with its own wall plug. There are sometimes differences in wall GND between outlets.

# 3.6 DIGITAL OUTPUTS & INPUTS

All the digital inputs and outputs on the CIO-DAS16/330 are TTL level. TTL is an electronics industry term, short for Transistor Transistor Logic, with describes a standard for digital signals which are either at 0V or 5V (nominal). The binary logic inside the PC is all TTL or LSTTL (Low power Schotky TTL).

# 4.1 DATA TRANSFERS

The CIO-DAS16/330 bus interface is a PC/XT/AT bus interface. In compatibility mode (mode switch up) it interfaces to the XT bus only. In enhanced mode (mode switch DOWN), the CIO-DAS16/330 employs the full 16-bit PC/AT bus.

Because 16-bit data transfers are faster, the CIO-DAS16/330 can transfer A/D samples taken with old DAS-16 software at speeds over 150 kHz. Old DAS-16 software uses DMA to transfer A/D data.

Of course, using the REP INS command (which can only be done by the CIO-DAS16/330), data transfers of 330 kHz and sample sets of any size up to the size of available memory may be taken.

# 4.2 FIFO DATA BUFFER

The First In First Out (FIFO) buffer is a specialized memory 1024 samples deep. After each conversion, the A/D data is transferred to the FIFO memory. Samples are retrieved from the FIFO data buffer by the computer program which stores the data in the PC's memory. This may be a language program, or an application program.

The FIFO is active all the time, regardless of mode. The FIFO does not affect compatibility with existing software, in fact, it does enhance it by allowing data to be transferred asynchronously, therefore at higher speeds.

In addition to enhancing standard interrupt and DMA operations, the FIFO makes possible the use of advanced instructions like REP-INSW, a block transfer.

# 4.3 CONTROL & DATA REGISTERS

The CIO-DAS16/330 is controlled and monitored by writing to and reading from 16 or 20 consecutive 8-bit I/O addresses. The first address, or BASE ADDRESS, is determined by setting a bank of switches on the board.

Usually, register manipulation is best left to experienced programmers with a specific need for low level control as most of the CIO-DAS16/330 possible functions are implemented in the easy to use Universal Library<sup>TM</sup> for DOS and Windows languages.

The register descriptions have the following format:

| 7    | 6     | 5     | 4     | 3   | 2   | 1   | 0   |
|------|-------|-------|-------|-----|-----|-----|-----|
| A/D9 | A/D10 | A/D11 | A/D12 | CH8 | CH4 | CH2 | CH1 |
|      |       |       | LSB   |     |     |     |     |

Where the numbers along the top row are the bit positions within the 8-bit byte and the numbers and symbols in the bottom row are the functions associated with that bit.

To write to or read from a register in decimal or HEX, the weights in Table 4-1 apply.

Table 4-1. Bit Weights

| <b>BIT POSITION</b> | DECIMAL VALUE | HEX VALUE |
|---------------------|---------------|-----------|
| 0                   | 1             | 1         |
| 1                   | 2             | 2         |
| 2                   | 4             | 4         |
| 3                   | 8             | 8         |
| 4                   | 16            | 10        |
| 5                   | 32            | 20        |
| 6                   | 64            | 40        |
| 7                   | 128           | 80        |

To write control or data to a register, the individual bits are set to 0 or 1 then combined to form a Byte. The method of programming required to set/read bits from bytes is beyond the scope of this manual.

The board registers and their function are listed on Table 4-2.

| ADDRESS   | <b>READ FUNCTION - ALL MODES</b> | WRITE FUNCTION                    |
|-----------|----------------------------------|-----------------------------------|
| BASE      | A/D Bits 9-12 (LSB) & Channel #  | Start A/D Conversion              |
| BASE + 1  | A/D Bits 1 (MSB) - 8             | None                              |
| BASE + 2  | Channel MUX                      | Channel MUX Set, Clear FIFO       |
| BASE + 3  | Digital 4 Bit Input              | Digital 4 Bit Output              |
| BASE + 4  | None                             | None                              |
| BASE + 5  | None                             | None                              |
| BASE + 6  | None                             | None                              |
| BASE + 7  | None                             | None                              |
| BASE + 8  | Status EOC, UNI/BIP, Current Ch. | None                              |
| BASE + 9  | DMA, Interrupt & Trigger Control | Set DMA, INT etc                  |
| BASE + 10 | None                             | Pacer clock control register      |
| BASE + 11 | Gain setting read-back           | Gain, Enhanced Mode, DT Conn.     |
| BASE + 12 | Counter 0 Data                   | Counter 0 Data                    |
| BASE + 13 | CTR 1 Data - A/D Pacer Clock     | CTR 1 Data - A/D Pacer            |
| BASE + 14 | CTR2 Data - A/D Pacer Clock      | CTR 2 Data - A/D Pacer            |
| BASE + 15 | None. No read back on 8254       | Pacer Clock Control (8254)        |
|           | ENHANCED MODE ONLY               |                                   |
| BASE + 11 | Upper nibble, enhanced features  | Upper nibble, enhanced features   |
|           | status                           | control                           |
| BASE + 16 | Total sample MS Counter          | CTR 0. Total counter (1/2)        |
| BASE + 17 | Total sample LS Counter          | CTR 1. Total counter (1/2)        |
| BASE + 18 | Pre-trigger count                | CTR 2. Pre-trigger counter        |
| BASE + 19 | None. No read back on 8254       | Advanced features counter control |
|           |                                  | (8254)                            |

| Table 4-2. I | Register | Functions |
|--------------|----------|-----------|
|--------------|----------|-----------|

# 4.4 A/D DATA & CHANNEL REGISTERS

Note: When in enhanced mode, the bus interface is 16 bits wide and BASE +0 and BASE +1 should be read as a 16 bit pair. To whit, the register at BASE + 1 should be read as the most significant eight bits of a 16-bit read to BASE + 0.

#### BASE ADDRESS

| 7    | 6     | 5     | 4     | 3   | 2   | 1   | 0   |
|------|-------|-------|-------|-----|-----|-----|-----|
| A/D9 | A/D10 | A/D11 | A/D12 | CH8 | CH4 | CH2 | CH1 |
|      |       |       | LSB   |     |     |     |     |

A read/write register.

READ

On read, it contains two types of data. The least significant four digits of the analog input data and the associated channel number.

These four bits of analog input data must be combined with the eight bits of analog input data in BASE + 1, forming a complete 12-bit number. The data is in the format 0 = minus full scale. 4095 = +FS.

The channel number is binary. The weights are shown in the table above. If the current channel were 5, then bits CH4 and CH1 would be high, CH8 and CH2 would be low.

#### WRITE

Writing any data to the register causes an immediate A/D conversion.

#### BASE ADDRESS +1

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|------|------|------|------|------|------|------|------|
| A/D1 | A/D2 | A/D3 | A/D4 | A/D5 | A/D6 | A/D7 | A/D8 |
| MSB  |      |      |      |      |      |      |      |

A Read-only register.

On read, the most significant A/D byte is read.

# 4.5 CHANNEL MUX SCAN LIMITS REGISTER

#### BASE ADDRESS +2

| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| CH H8 | CH H4 | CH H2 | CH H1 | CH L8 | CH L4 | CH L2 | CH L1 |

A read and write register.

#### READ

The current channel scan limits are read as one byte. The high channel number scan limit is in the most significant four bits. The low channel scan limit is in the least significant four bits.

#### WRITE

The channel scan limits desired are written as one byte. The high channel number scan limit is in the most significant four bits. The low channel scan limit is in the least significant four bits.

Bits 3-0 contain the starting channel number and bits 7-4 contain the ending channel number. If you wanted to scan channels 1, 2, 3 in that order, you could do so by placing the 3 in bits 7-4 and the 1 in bits 3-0.

#### NOTE

Every write to this register sets the current A/D channel MUX setting to the number in bits 0-3. See BASE + 8. Every write to this register clears the FIFO buffer.

# 4.6 FOUR- BIT DIGITAL I/O REGISTERS

#### BASE ADDRESS +3

When read...

| 7 | 6 | 5 | 4 | 3   | 2    | 1   | 0    |
|---|---|---|---|-----|------|-----|------|
| 0 | 0 | 0 | 0 | DI3 | DI2, | DI1 | DI0, |
|   |   |   |   |     | CTR0 |     | TRIG |
|   |   |   |   |     | GATE |     |      |

#### READ

The signals present at the inputs are read as one byte, the most significant four bits of which are always zero. The pins 25 (digital input 0) and 24 (digital input 2) digital inputs have two functions each.

The TRIG function of digital input 0 may be used to hold off the first sample of an A/D set by holding it low (0V) until you are ready to take samples, which are then paced by the 8254. It can also be used as the source of an external start conversion pulse, synchronizing A/D conversions to some external event.

#### When written to...

| 7 | 6 | 5 | 4 | 3   | 2   | 1   | 0   |
|---|---|---|---|-----|-----|-----|-----|
| Х | Х | Х | Х | DO3 | DO2 | DO1 | DO0 |

#### WRITE

The upper four bits are ignored. The lower four bits are latched TTL outputs. Once written, the state of the inputs cannot be read back because a read back would read the separate digital input lines (see above).

#### 4.7 STATUS REGISTER

#### BASE ADDRESS +8

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| EOC | U/B | MUX | INT | CH8 | CH4 | CH2 | CH1 |

A read mostly, one-function-write register.

#### READ

EOC = 1, the A/D converter is busy. EOC = 0, it is free.

U/B = 1, the amplifier is in Unipolar mode. U/B = 0, is bipolar.

MUX = 1, Channels are configured 16 single ended. MUX = 0, 8 differential.

INT = 1, an external pulse has been received. INT = 0, the flip-flop is ready to receive a pulse.

There is a flip-flop on the TRIGGER input (pin 25) which will latch a pulse as short as 200 ns. After being triggered, this flip-flop must be reset by a write to this register. Your interrupt service routine must do this before another interrupt trigger can be received.

CH8, CH4, CH2 & CH1 are a binary number between 0 and 15 indicating the channel number that the MUX is currently set to and is valid only when EOC = 0. The channel MUX increments shortly after EOC = 1 so may be in a state of transition when EOC = 1. The binary weight of each bit is shown in the table above.

#### WRITE

A write of any data to this register resets the flip-flop on the pin 25 input and sets the INT bit to 0.

# 4.8 DMA, INTERRUPT & TRIGGER CONTROL

#### BASE ADDRESS +9

| 7    | 6   | 5   | 4   | 3          | 2   | 1   | 0   |
|------|-----|-----|-----|------------|-----|-----|-----|
| INTE | IR4 | IR2 | IR1 | Don't Care | DMA | TS1 | TS0 |

A read and write register.

#### READ

INTE = 1, Interrupts are enabled. An interrupt generated will be placed on the PC bus interrupt level selected by IR4, IR2 & IR1. INTE = 0, interrupts are disabled.

IR4, IR2, IR1 are bits in a binary number between 0 and 7 which map interrupts onto the PC bus interrupt levels 2 - 7. Interrupts 0 & 1 map into interrupts 10 and 11.

DMA = 1, DMA transfers are enabled. DMA = 0, DMA transfers are disabled. It is worth noting that this bit only allows the CIO-DAS16/330 to assert a DMA request to the PC on the DMA request level selected by the DMA switch on the CIO-DAS16/330. Before this bit is set to 1, the PC's 8237 (or appropriate) DMA controller chip must be set up.

TS1 & TS0 control the source of the A/D start conversion trigger according to Table 4-4.

# 4.9 PACER CLOCK CONTROL REGISTER

#### BASE ADDRESS +10

| 7 | 6 | 5 | 4 | 3 | 2 | 1    | 0     |
|---|---|---|---|---|---|------|-------|
| Х | Х | Х | Х | Х | Х | CTR0 | TRIG0 |

#### Write only

CTR0 = 1. When CTR0 = 1, an on-board 100 kHz clock signal is ANDed with the COUNTER 0 CLOCK INPUT (pin 21). A high on pin 21 will allow pulses from the on-board source into the 8254 Counter 0 input.

CTR0 = 0. When CTR0 = 0, the input to 8254 Counter 0 is entirely dependent on pulses at pin 21, COUNTER 0 CLOCK INPUT.

TRIG0 = 1. When TRIG0 = 1, the TRIGGER input at pin 25 is ANDed with TRIG0 which must be high for the pulses from the on-board pacer clock (8254) to start A/D conversions. The input at pin 25 is pulled up and will always be high unless pulled low externally.

TRIG0 = 0. When TRIG0 = 0, the GATEs of counter 1 & 2 are held high, preventing signals at pin 25 from gating off the on board pacer.

Figure 4-1 may help understand these registers, and is further explained in the section covering the 8254.



#### CIO-AD16 8254 PACER CLOCK & CONTROL

Figure 4-1. Pacer Clock and Control

# 4.10 ANALOG INPUT RANGE REGISTER

BASE ADDRESS +11 - Compatible Mode

| 7 | 6 | 5 | 4 | 3     | 2       | 1  | 0  |
|---|---|---|---|-------|---------|----|----|
| Х | Х | Х | Х | Range | Uni/Bip | G1 | G0 |

A write to this register sets the analog input range for all 8/16 analog inputs. The lower four bits set the analog input range. The upper four bits are not used in compatible mode (Table 4-3).

| Table 4- | 3.  | Input    | Range | Coding   |
|----------|-----|----------|-------|----------|
| 10010 .  | ••• | 1110 000 |       | e e anno |

| Range | Uni/Bip | G1 | <b>G0</b> | Input Range | Decimal |
|-------|---------|----|-----------|-------------|---------|
| 1     | 0       | 0  | 0         | +/-10V      | 8       |
| 0     | 0       | 0  | 0         | +/-5V       | 0       |
| 0     | 0       | 0  | 1         | +/-2.5V     | 1       |
| 0     | 0       | 1  | 0         | +/-1.25V    | 2       |
| 0     | 0       | 1  | 1         | +/-0.625    | 3       |
| 0     | 1       | 0  | 0         | 0 to 10V    | 4       |
| 0     | 1       | 0  | 1         | 0 to 5V     | 5       |
| 0     | 1       | 1  | 0         | 0 to 2.5V   | 6       |
| 0     | 1       | 1  | 1         | 0 to 1.25V  | 7       |

To set the analog input range of the CIO-DAS16/330 programmatically, write the correct input range code to the base address + 11. For example, from BASIC:

If the board's base address is 300h (768 decimal), then the gain register is at 768 + 11 = 779

100 OUT 779, 5 'Set analog output range to 0 to 5V

The decimal range codes are in the far right column above.

#### **BASE ADDRESS +11 - Enhanced Mode**

A write to this register sets the analog input range for all 8/16 analog inputs as well as enabling and disabling extended features and controlling extended features for pre-triggering and DT-CONNECT. The lower four bits set the analog input range. The upper four bits control and provide status of enhanced features.

| 7       | 6       | 5       | 4        | 3     | 2       | 1  | 0  |
|---------|---------|---------|----------|-------|---------|----|----|
| DT-     | Pre-    | Overrun | Set/Read | Range | Uni/Bip | G1 | G0 |
| Connect | Trigger | Status  | Mode     |       |         |    |    |
| Enable  | Enable  |         |          |       |         |    |    |

GAINS: Gain control is identical in both compatible and enhanced mode.

BIT 4 - Set Compatible/Enhanced Mode. Read Mode Status

WRITE: 0 =disable enhanced mode. 1 =enable enhanced mode (mode switch must be down).

READ: 0 = Switch 7 of base address switch, the mode switch, is up. It is not possible to enable enhanced features when the mode switch is up. When Bit 4 = 1, the mode switch is down and enhanced features can be enabled.

#### BIT 5 - Set Pretrigger, DT-Connect. Read FIFO, Overrun

READ: 0 = No overrun. 1 = FIFO buffer full (> 1024 samples) or DT-CONNECT overrun if DT-CONNECT is enabled. This signal is the logical OR of these two possible overrun signals. To determine the source of the overrun error: If DT-Connect is not enabled then the overrun is FIFO. If DT-CONNECT is enabled, issue a clear to the FIFO then reread the status bit. If still active, the overrun was at the DT-CONNECT.

WRITE: Enable channel gain queue mode. Access to Base + 2 is inhibited when the channel gain queue is enabled.

BIT 6 - Pre-Trigger Enable. Trigger Status.

WRITE: 0 = Disable pre-trigger mode. 1 = enable pre-trigger. The trigger index counter (CTR 2 of 2nd 8254) is gated to the packet interrupt. Because it is gated to the FIFO packet interrupt, the trigger flushes the FIFO at the instant of the trigger, ensuring the only samples prior to and all samples prior to the trigger are in the pre-trigger buffer.

READ: Valid only when pre-trigger is enabled. 0 = Trigger has not yet occurred. 1 = Trigger occurred.

BIT 7 - DT-CONNECT Enable/Disable & Status

WRITE: 0 = Disable DT-Connect. 1 = Enable DT-CONNECT.

For DT-Connect to operate, the Total Counter output must be forced low. The simplest way to do this is to write the value 16 to Base +19 (both decimal).

READ: 0 = DT-CONNECT is disabled. 1 = DT-CONNECT is enabled.

#### 4.11 PACER CLOCK DATA & CONTROL REGISTERS

# 8254 COUNTER 0 DATA

#### BASE ADDRESS + 12

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 |

#### 8254 COUNTER 1 DATA

**BASE ADDRESS + 13** 

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 |

#### 8254 COUNTER 2 DATA

#### BASE ADDRESS + 14

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 |

The three 8254 counter/timer data registers may be written to and read from. Because each counter will count to 65,535, loading or reading the counter data is a multi-step process. The operation of the 8254 is explained in the section on the counter/time and the Intel 8254 data sheet.

#### 8254 COUNTER CONTROL

#### BASE ADDRESS + 15

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 |

This register controls the operation and loading/reading of the counters. The configuration of the 8254 codes which control the 8254 chip is explained in the section on the counter timer and the Intel 8254 data sheet.

# 4.12 ENHANCED FEATURES PACER CLOCK DATA & CONTROL REGISTERS

#### 8254 COUNTER 0 DATA - Total Count MS Counter

#### Chained from counter 1

#### BASE ADDRESS +16

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 |

#### 8254 COUNTER 1 DATA - Total Count LS Counter

Clocked by Pacer (See XTAL jumper) - Chained to counter 0

#### BASE ADDRESS +17

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 |

#### 8254 COUNTER 2 DATA - Pretrigger Index Counter

#### BASE ADDRESS +18

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 |

The three 8254 counter/timer data registers may be written to and read from. Because each counter will count to 65,535, loading or reading the counter data is a multi-step process. The operation of the 8254 is explained in the section on the counter/time and the Intel 8254 data sheet.

#### 8254 COUNTER CONTROL

#### BASE ADDRESS + 19

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 |

This register controls the operation and loading/reading of the counters. The configuration of the 8254 codes which control the 8254 chip is explained in the Intel 8254 data sheet.

# 4.13 ANALOG INPUT

Analog signals connected to P3, the 37-pin, D-type connector, are first fed into the two HI-0508 analog multiplexers. A multiplexer's function is to select one of eight inputs and connect that input to the MUX output. MUX U27 connects CH0-CH7 high inputs. MUX U28 connects CH0-CH7 Low input (differential input mode) or CH8-CH15 High inputs (single-ended mode) depending on the state of the channel configuration switch located at the upper right of the board and marked 8/16.

From the output of the MUX, the analog signal is fed into a programmable differential amplifier.

The A/D converter chip has an integral sample & hold circuit, greatly simplifying design and improving signal integrity. The A/D converter is capable of sampling rates to 330 kHz.

# 4.14 DIGITAL INPUT & OUTPUT

There are four bits of output only and four bits of input only on the CIO-DAS16/330 analog connector. From the original DAS-16 design, these were the only eight bits of digital I/O.

For complete programming information refer to the section on CIO-DAS16/330 registers.

#### **4.14.1 OUTPUT**

The output bits are part of chip U39, a 74LS197 output buffer. The other half of the chip is used for on-board control. If the digital output lines are blown by overload or high voltage connection, you can replace the chip.

#### 4.14.2 INPUT

The input bits are part of chip U38, a 74LS244 buffer. The other half of this chip is used for on-board functions. This chip is socketed.

# 4.15 INTERRUPT & TRIGGER CONTROL

The interrupt and trigger control is accessible via programming at register BASE + 9. Interrupts are enabled by setting bit 7. The PC bus interrupt number, 2 to 7, 10, and 11, is register-programmed. The source, either from the 8254 or external, is programmed also.

#### **BASE ADDRESS +9**

| 7    | 6   | 5   | 4   | 3          | 2   | 1   | 0   |
|------|-----|-----|-----|------------|-----|-----|-----|
| INTE | IR4 | IR2 | IR1 | Don't Care | DMA | TS1 | TS0 |

A read and write register.

READ

INTE = 1, Interrupts are enabled. An interrupt generated will be placed on the PC bus interrupt level selected by IR4, IR2, and IR1. When INTE = 0, interrupts are disabled.

IR4, IR2, IR1 are bits in a binary number between 0 and 7 which map interrupts onto the PC bus interrupt levels 2 - 7. Interrupts 0 maps into 10 and interrupt 1 maps into 11.

TS1 & TS0 control the source of the A/D start conversion trigger according to Table 4-4 below.

| Table 4-4. A | D Start | Conversion | Source | Coding |
|--------------|---------|------------|--------|--------|
|              |         |            |        | 0      |

| TS1 | TS0 |                                                            |
|-----|-----|------------------------------------------------------------|
| 0   | Х   | Software triggered A/D only.                               |
| 1   | 0   | Start on rising TRIGGER (Digital input 0, Pin 25)          |
| 1   | 1   | Start on Pacer Clock Pulse (CTR 2 OUT, no external access) |

# 4.16 DMA CONTROL LOGIC

The Direct Memory Access (DMA) controller is on the personal computer CPU board, not on the CIO-DAS16/330. The CIO-DAS16/330 has the logic on board to request a DMA transfer. In addition to the on board logic, the DMA controller must be programmed.

Complete register specifications for the CIO-DAS16/330 DMA control registers will be found in the previous section on the CIO-DAS16/330 control registers.



DMA LEVEL SELECT - DMA Level 1 Is selected.

Figure 4-2. DMA Level Select Switch

# SPECIFICATIONS

| Power consumption                          |                                                                                                         |
|--------------------------------------------|---------------------------------------------------------------------------------------------------------|
| +5V:                                       | 900 mA typical, mA max                                                                                  |
| Analog input section                       |                                                                                                         |
| A/D converter type                         | AD7800                                                                                                  |
| Resolution                                 | 12 bits                                                                                                 |
| Number of channels                         | 8 differential or 16 single-ended, switch-selectable                                                    |
| Programmable ranges                        | ±10V, ±5V, ±2.5V, ±1.25V, ±0.625V, 0 to 10V, 0 to 5V, 0 to 2.5V,                                        |
|                                            | 0 to 1.25V, 0 to 0.625V, fully programmable                                                             |
| Polarity                                   | Unipolar/Bipolar, software-selectable                                                                   |
| A/D pacing                                 | Programmable: internal counter or external source (DIG. IN 0 / TRIGGER, rising edge) or software-polled |
| A/D Trigger sources                        | External hardware/software (DIG. IN 0 / TRIGGER, active high)                                           |
| A/D Inggening Modes                        | Catad manage approximately a cata must be disabled by approximately                                     |
| Digital:                                   | trigger event.)                                                                                         |
| Data transfer                              | From 1024 sample FIFO via REPINSW, interrupt, DMA or software polled                                    |
| DMA                                        | Channel 1 or 3, switch-selectable                                                                       |
| A/D conversion time                        | 3 μs                                                                                                    |
| Throughput                                 | 330 kHz                                                                                                 |
| Absolute accuracy                          | 0.01% of reading ±1 LSB                                                                                 |
| Differential Linearity error               | ±1 LSB                                                                                                  |
| Integral Linearity error                   | ±1 LSB                                                                                                  |
| No missing codes guaranteed                | 12 bits                                                                                                 |
| Gain drift (A/D specs)                     | ±25 ppm/°C                                                                                              |
| Zero drift (A/D specs)                     | ±10 ppm/°C                                                                                              |
| Common Mode Range                          | ±10V                                                                                                    |
| CMRR @ 60 Hz                               | -72dB                                                                                                   |
| Input leakage current (@25 Deg C)          | 200 nA                                                                                                  |
| Input impedance                            | 10 MegOhms min                                                                                          |
| Absolute maximum input voltage             | ±35V                                                                                                    |
| <u>Digital Input / Output</u>              |                                                                                                         |
| Digital type                               | Input: 74LS367                                                                                          |
|                                            | Output: 74LS197                                                                                         |
| Configuration                              | Two ports, 4 input bits and 4 output bits                                                               |
| Input low voltage                          | 0.8V max                                                                                                |
| Input high voltage                         | 2.0V min                                                                                                |
| Output low voltage (IOL = $8 \text{ mA}$ ) | 0.5V max                                                                                                |
| Output high voltage (IOH = $-0.4$ mA)      | 2.7V min                                                                                                |
| Absolute maximum input voltage             | -0.5V, +7V                                                                                              |
| Interrupts                                 | 2 through 7, 10 and 11, programmable                                                                    |
| Interrupt enable                           | Programmable                                                                                            |
| Interrupt sources                          | A/D End-of-conversion, A/D FIFO-half-full, Residual counter, DMA terminal count                         |

# **Counter section**

| Counter type 82C               | 54                                                                      |
|--------------------------------|-------------------------------------------------------------------------|
| Configuration                  | Two 82C54 devices, 3 down counters each device, 16 bits each            |
| C                              | 82C54A:                                                                 |
|                                | Counter 0 - Independent, available to user                              |
|                                | Source: 100 kHz on board clock or external (CTR 0 Clock In)             |
|                                | Gate: External (Dig In 2 / CTR 0 Gate)                                  |
|                                | Output: Available at user connector (CTR 0 Out)                         |
|                                | Counter 1 - ADC Pacer Lower Divider                                     |
|                                | Source: 1 or 10 MHz oscillator, jumper-selectable                       |
|                                | Gate: Tied to Counter 2 gate, programmable source (internal or external |
|                                | (Dig In 0 / Trigger)                                                    |
|                                | Output: Chained to Counter 2 Clock                                      |
|                                | Counter 2 - ADC Pacer Upper Divider                                     |
|                                | Source: Counter 1 Output                                                |
|                                | Gate: Tied to Counter 1 gate programmable source: internal or external  |
|                                | (Dig In 0 / Trigger)                                                    |
|                                | Output: ADC Pacer clock available at user connector (CTR 2 Out)         |
|                                | 82C5/R·                                                                 |
|                                | Counter () Total samples (residual) counter upper divider               |
|                                | Source: Counter 1 output (total samples lower divider)                  |
|                                | Gate: Internal                                                          |
|                                | Output: Internal                                                        |
|                                | Counter 1 Total samples (residual) counter lower divider                |
|                                | Source: ADC conversion complete                                         |
|                                | Gate: Tied to Counter 2 gate internal source                            |
|                                | Output: Counter 0 input (total samples upper divider)                   |
|                                | Counter 2. Trigger index counter                                        |
|                                | Counter 2 - Ingger index counter                                        |
|                                | Source: ADC conversion complete                                         |
|                                | Gate: The to Counter T gate, internal source.                           |
|                                | Output: Not used                                                        |
| Clock input frequency          | 10 MHz max                                                              |
| High pulse width (clock input) | 30 ns min                                                               |
| Low pulse width (clock input)  | 50 ns min                                                               |
| Gate width high                | 50 ns min                                                               |
| Gate width low                 | 50 ns min                                                               |
| Input low voltage              | 0.8V max                                                                |
| Input high voltage             | 2.0V min                                                                |
| Output low voltage             | 0.4V max                                                                |
| Output high voltage            | 3.0V min                                                                |
| Crystal oscillator             |                                                                         |
| Frequency                      | 10 MHz                                                                  |
| Frequency accuracy             | 100 ppm                                                                 |
| Environmental                  |                                                                         |
| Operating temperature range    | 0 to $50^{\circ}$ C                                                     |
| Storage temperature range      | $-20$ to $70^{\circ}$ C                                                 |
| Humidity                       | 0 to 90% non-condensing                                                 |
|                                |                                                                         |

This short introduction to the analog electronics most often needed by data acquisition board users covers a few key concepts. They are:

- Voltage dividers.
- Differential vs. Single Ended Inputs.
- Isolation vs. Common Mode Range
- Low pass filters for analog and digital inputs.
- A/D Resolution
- Conversion to Engineering units.
- 4-20 mA inputs
- Noise; sources and solutions.

Each deals with the impact on measurements made with data acquisition boards.

# 6.1 VOLTAGE DIVIDERS

If you wish to measure a signal which varies over a range greater than the input range of an analog or digital input, a voltage divider can drop the voltage of the input signal to the level the analog or digital input can measure (Figure 6-1).

A voltage divider takes advantage of Ohm's law, which states,

Voltage = Current \* Resistance

and Kirkoff's voltage law which states,

The sum of the voltage drops around a circuit will be equal to the voltage drop for the entire circuit.





Implied in the above is that any variation in the voltage drop for the circuit as a whole will have a proportional variation in all the voltage drops in the circuit.

A voltage divider takes advantage of the fact that the voltage across one of the resistors in a circuit is proportional to the voltage across the total resistance in the circuit.

The trick to using a voltage divider is to choose two resistors with the proper proportions relative to the full scale of the analog or digital input and the maximum signal voltage.

The phenomena of dropping the voltage proportionally is often called attenuation.

The formula for attenuation is:

| Attenuation = $\frac{R1 + R2}{R2}$ | The variable Attenuation is the proportional difference between the signal voltage max and the full scale of the analog input.                                                                  |
|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2 = 10K + 10K<br>10K               | For example, if the signal varies between 0<br>and 20 volts and you wish to measure that<br>with an analog input with a full scale range of<br>0 to 10 volts, the Attenuation is 2:1 or just 2. |
| R1 = (A-1) * R2                    | For a given attenuation, pick a handy resistor<br>and call it R2, the use this formula to<br>calculate R1.                                                                                      |

Digital inputs also make use of voltage dividers, for example, if you wish to measure a digital signal that is at 0 volts when off and 24 volts when on, you cannot connect that directly to the CIO-AD digital inputs. The voltage must be dropped to 5 volts max when on. The Attenuation is 24:5 or 4.8. Use the equation above to find an appropriate R1 if R2 is 1K. Remember that a TTL input is 'on' when the input voltage is greater than 2.5 volts.

#### **IMPORTANT NOTE**

The resistors, R1 and R2, are going to dissipate all the power in the divider circuit according to the equation  $W=I^2 \times R$  (Power (Watts) = Current Squared times Resistance). The higher the value of the resistance (R1 + R2) the less power dissipated by the divider circuit. Here is a simple rule:

For Attenuation of 5:1 or less, no resistor should be less than 10K.

For Attenuation of greater than 5:1, no resistor should be less than 1K.

The CIO-TERMINAL has the circuitry on board to create custom voltage dividers. The CIO-TERMINAL is a 16" by 4" screw terminal board with two 37 pin D type connectors and 56 screw terminals (12 - 22 AWG). Designed for table top, wall or rack mounting, the board provides prototype, divider circuit, filter circuit and pull-up resistor positions which you may complete with the proper value components for your application.

# 6.2 DIFFERENTIAL & SINGLE ENDED INPUTS

The two types of analog inputs commonly found on A/D boards are differential and single-ended.

#### **COMMON MODE RANGE**

Differential inputs have a common mode range (CMR). Single-ended inputs have no CMR. Common mode range is the voltage range over which differences in the low side of the signal and A/D input ground have no impact on the A/D's measurement of the signal voltage. A differential input can reject voltage differences between signal ground and PC ground.



Figure 6-2. Differential Input

Figure 6-2 shows the differential mode (multiplexer not shown).

A single-ended input has no common mode range because there is only one LOW wire, the level of which is assumed to be the same, signal source and A/D board (Figure 6-3).



Figure 6-3. Single-Ended Input

The maximum difference which can be rejected is the CMR.

For example, the CIO-DAS16/330 has a common mode plus signal range of 11.5 volts, common mode not to exceed 10 volts.



Figure 6-4. Cumulative Signal Range

Most manufactures of A/D boards specify the CMR directly from the component data sheet, ignoring the effect of the board level system on that specification. A data sheet of that type might claim 10 volts of CMR. Although this is a factual specification and the designer of the board (or other EE) would be able to translate that into a systems specification, most A/D board owners are confused or mislead by such specs.

#### COMMON MISUNDERSTANDINGS

The CMR specification of a differential input is often confused with an isolation specification, which it is not. It makes sense. doesn't it, that 10 volts of CMR is the same as 10 volts of isolation? No. The graph above shows why.

Also, failure to specify the common mode plus signal system specification leads people to believe that a DC offset equal to the component CMR can be rejected regardless of the input signal voltage. It cannot as the graph above illustrates.

When is a differential input useful? The best answer is whenever electromagnetic interference (EMI) or radio frequency interference (RFI) may be present in the path of the signal wires. EMI and RFI can induce voltages on both signal wires and the effect on single ended inputs is generally a voltage fluctuation between signal high and signal ground.

A differential input is not affected in that way. When the signal high and signal low of a differential input have EMI or RFI voltage induced on them, that common mode voltage is rejected, subject to the system constraint that common mode plus signal not exceed the A/D board's CSR specification.

#### **GROUND LOOPS**

Ground loops are circuits ( $E=I^*R$ ) created when the signal ground and the PC ground are not the same. Ground loop inducing voltage differential may be a few volts of hundreds of volts. They may be constant or transient (spikes). A differential input will prevent a ground loop as long as the CSR specifications is not exceeded.

If ground differences greater than the CMR are encountered, isolation is required.

#### WHY USE SINGLE ENDED?

The reason is connector space. Single ended inputs require one analog high input per channel and one LLGND shared by all inputs. Differential inputs require signal high and signal low inputs for each channel and one common shared LLGND.

Single ended inputs save connector space, parts cost and in all cases where there is no common mode or EMI/RFI they work just as well as differential inputs and are less complex to wire up.

# 6.3 LOW PASS FILTERS

A low pass filter is placed on the signal wires between a signal and an A/D board. It stops frequencies greater than the cut-off frequency from entering the A/D board's analog or digital inputs.

The key term in a low pass filter circuit is cut off frequency. The cut-off frequency is that frequency above which no variation of voltage with respect to time may enter

variation of voltage with respect to time may enter the circuit. For example, if a low pass filter had a cut off frequency of 30 Hz, the kind of interference associated with line voltage (60 Hz) would be filtered out but a signal of 25 Hz would be allowed to pass.

Also, in a digital circuit, a low pass filter might be used to de-bounce an input from a mechanical switch.

A low pass filter may be constructed from one resistor (R) and one capacitor (C) (Figure 6-5).

The cut-off frequency is determined according to the formula:

 $F_{c} = \underline{1}$  2\*Pi\*R\*C  $R = \underline{1}$   $2*Pi*C*F_{c}$ 



Figure 6-5. Low Pass Filter

# 6.4 A/D RESOLUTION & ENGINEERING UNITS

Resolution is determined by the number of bits of data, such as 8, 10 or 12 bits. The 12 bits are a power of two indicating the number of divisions of full scale the converter can resolve. For example, a 12-bit converter can resolve  $(2^{12} - 1) = 4095$  divisions of full scale. If the input of the board were +/- 5 volts full scale (10V span), each of the 4095 steps is equal to 0.00244 volts (10/4096).

Examples of readings from a 12 bit A/D converter are in Table 6-1.

| Converter # | Volts   |
|-------------|---------|
| 4095        | 4.9976  |
| 4094        | 4.9951  |
| 4093        | 4.9927  |
| 2048        | 0.0     |
| 1           | -4.9976 |
| 0           | -5.0    |

Table 6-1. Examples of Converter Output vs Input Volts

The specification of resolution is the ability to differentiate between one voltage and another. Thus, the more bits of resolution (13 bits = 8192 counts), the more divisions of full scale. The more divisions of full scale, the *higher* the resolution

# 6.5 ENGINEERING UNITS

When a program uses an A/D board to acquire data, the data file is filled with numbers like those above.

To translate the A/D numbers back into the engineering units of the original measurement, we need to know:

The sensor's voltage output per engineering unit.

The full scale range of the board at the time the measurement was made.

The resolution of the converter.

Here is an example from the application note on interfacing a Voland TA to a PC found elsewhere in this manual.

The TA measures resistance in grams between +500 and -500 grams.

The voltage output of the instruments is +2.5 volts to -2.5 volts.

The voltage output corresponds to the grams of pressure exactly, so:

Span = +/- 500 grams = 1000 grams.

Span  $\pm -2.5$  volts = 5 volts.

5 volts / 1000 grams = 0.005 volts per gram.

The A/D was set for  $\pm -2.5$  volts = 5 volts full scale.

5 volts / 4096 counts = 0.00122 volts per bit.

If the number in the file for one reading was 3061, then

3061 \* 0.00122 = 3.7632 volts.

3.7632 volts / 0.005 volts per gram = 735 grams.

Now shift from full scale to +/- scale.

735 grams full scale - 500 = 235 grams of positive pressure.

It may look like a lot of steps because it is presented that way here for clarity only. It could be expressed as a single equation in a spreadsheet.

#### 6.6 CURRENT LOOP 4-20 MA

Although the inputs of a CIO-AD board are voltage inputs, it is easy to convert a current to a proportional voltage which may be measured by the CIO-AD board. The current is converted to a proportional voltage by the formula  $V=I^*R$ .

For example, if the CIO-AD board is set up to read 0 to 5 volts, then:

5 volts / 0.02 Amps = 250 Ohm shunt resistor (Figure 6-6).

So a full 20 mA will register 5 volts and 4 mA will register 1 volt.



#### 4-20 mA TO VOLTAGE CONVERTER

Figure 6-6. Current to Voltage Conversion

To hook up the CIO-AD analog inputs to a 4-20 mA transducer or signal source, place the shunt resistor across the plus and minus terminals or signal wires of the 4-20 mA. After the resistor is in place, connect the analog input CH# HIGH to the plus terminal and the analog input CH# LOW to the minus input.

If they are backward, the A/D reading will be 0 or minus volts. Reverse the connection.

# 6.7 NOISE

Noise is unavoidable in PC-based data acquisition systems. There is board induced noise which can be measured by shorting an analog input to ground and taking a series of readings and plotting them in a histogram. There is EMI and RFI induced noise along the path of the signal wires. There is also noise at the signal source itself. All these sources of noise combine to create a region of uncertainty around the signal value.

Our objective here is to discover the sources of noise and discuss the means to reduce it.

#### **6.7.1 SOURCES OF NOISE**

The first source of noise is the board itself. Manufacturers of A/D boards quote component specifications in their data sheets but rarely quote a system specification for general accuracy and noise. The reasons the system is not specified are that the system specification would be less accurate than component specification and that system specifications must also specify the conditions under which the specification was made. That means the PC, the PC's power supply and the connection to the front end.

Take some very good components, put them on a circuit board and place that board in a PC and the system will be less accurate than the individual components.

The system specification for the CIO-DAS16/330 is plus or minus 1 LSB. That means that if an analog input is tied to ground and the CIO-DAS16/330 is on a bipolar scale, the reading will be 2048 90% of the time. The other 10% of the readings will be 2047 and 2049, which is +/- count (LSB). This is actually not very different from the component specifications.

You can verify this by grounding an analog input channel to LLGND and taking 1000 readings then plotting a histogram of those readings.

If your histogram is not +/- 1 LSB, check the +/- 12V PC power supply voltages.

## 6.7.2 SIGNAL WIRE NOISE

Signal wires, especially single-ended inputs, are subject to EMI and RFI, both of which can induce noise on the wires carrying the transducer signal to the CIO-AD board. Fortunately, signal wire noise is often localized and can be reduced by repositioning the signal wire run, shielding the wires and using twisted-pairs.

To check for signal wire noise, first, short analog channel 0 to low level ground at the connector and take 10,000 samples and plot the histogram. This is the best the signal can be and is what you will try to achieve with the signal wires in place.

After you have an ideal case histogram, remove the short between analog input 0 and low level ground. Attach the signal wires to the CIO-AD board inputs and run them to the sensor. Do not connect the sensor yet, just short the analog input(s) to LLGND.

Take data for the histogram and compare it to the best case data taken previously. If it shows noise, you can try to eliminate the noise by doing the following:

- Move the signal wires, trying to locate a 'quiet' run.
- Use a shielded twisted pair as the signal wire. Attach the shield at the PC only. If the shield is attached at both the PC and the sensor it may create a ground loop and add to signal interference.

#### 6.7.3 SENSOR NOISE

When the signal wires have been tested and characterized for signal quality, connect the sensor and provide a known level to the sensor (ice bath for temp., etc.) then take data for the histogram plot. If additional noise has been introduced by the sensor which exceeds the sensor specifications, you can try moving the sensor or electrically isolating it from the device it is measuring.

## 6.7.4 SMOOTHING DATA

It is not always possible to eliminate all noise, especially with very low level sensors, but noise when plotted is undesirable and can raise doubts about otherwise excellent data.

There are two simple ways to eliminate noise from the data:

1) Apply a moving average to the data if you want to retain the same apparent accuracy.

2) Remove the information from the noisy range. For example, if the A/D is capable of , or, shift the data by the number of counts of noise. For example, if a 12-bit A/D converter is at +/- 5Volts (10Volts full scale) then one LSB = 10 / 4095 = 0.00244mV. If your system is inducing +/- 0.007mV of noise (+/- 3 counts), then round all the readings by +/- 3 counts. In this way the reading's value reflects the true accuracy of the system.

#### **EC Declaration of Conformity**

We, Measurement Computing Corp., declare under sole responsibility that the product:

| CIO-DAS16/330                                                    |                                                                                                                                                                                                               |
|------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Part Number                                                      | Description                                                                                                                                                                                                   |
| to which this declaration rela<br>the relevant EC Directives lis | tes, meets the essential requirements, is in conformity with, and CE marking has been applied according to sted below using the relevant section of the following EC standards and other normative documents: |

EU EMC Directive 89/336/EEC: Essential requirements relating to electromagnetic compatibility.

EU 55022 Class B: Limits and methods of measurements of radio interference characteristics of information technology equipment.

EN 50082-1: EC generic immunity requirements.

IEC 801-2: Electrostatic discharge requirements for industrial process measurement and control equipment.

IEC 801-3: Radiated electromagnetic field requirements for industrial process measurements and control equipment.

IEC 801-4: Electrically fast transients for industrial process measurement and control equipment.

Carl Haapaoja, Director of Quality Assurance

Measurement Computing Corporation 10 Commerce Way Suite 1008 Norton, Massachusetts 02766 (508) 946-5100 Fax: (508) 946-9500 E-mail: info@mccdaq.com www.mccdaq.com