Zebra Rapixo CL™



Installation and Hardware Reference

# Copyrights, Trademarks, Patents, Limitations of Liability, and Disclaimers

This section lists copyrights, acknowledgments, patent notices, limitations of liability, and disclaimers.

#### Copyright

© 2011-2024 Zebra Technologies Corp. and/or its affiliates.

3 Overlook Point, Lincolnshire, Illinois 60069, USA

#### **Proprietary Statement**

This manual contains proprietary information of Zebra Technologies Corporation and its subsidiaries ("Zebra Technologies"). It is intended solely for the information and use of parties operating and maintaining the equipment described herein. Such proprietary information may not be used, reproduced, or disclosed to any other parties for any other purpose without the express, written permission of Zebra Technologies.

#### Trademarks

ZEBRA and the stylized Zebra head are trademarks of Zebra Technologies Corp., registered in many jurisdictions worldwide. All other trademarks are the property of their respective owners.

#### Patents

This product might be protected by one or more patents. Patents <u>http://www.zebra.com/patents</u>.

#### Limitations of Liability

In no event will Zebra or its suppliers be liable for any indirect, special, incidental, economic, cover or consequential damages arising out of the use of or inability to use the product, user documentation or related technical support, including without limitation, damages or costs relating to the loss of profits, business, goodwill, even if advised of the possibility of such damages. In no event will Zebra and its suppliers' liability exceed the amount paid by you, for the product.

Because some jurisdictions do not allow the exclusion or limitation of liability for consequential or incidental damages, the above limitation may not apply to you.

#### Product Improvements

Continuous improvements of products is a policy of Zebra Technologies. All specifications and designs are subject to change without notice.

#### Disclaimer

Zebra reserves the right to make changes in specifications at any time and without notice. The information provided by this document is believed to be accurate and reliable. However, neither Zebra nor its suppliers assume any responsibility for its use; or for any infringements of patents or other rights of third parties resulting from its use. No license is granted under any patents or patent right of Zebra.

#### **Publication Date**

September 20, 2024

### Contents

| Chapter 1: Introduction                     | . 9 |
|---------------------------------------------|-----|
| Zebra Rapixo CL board                       |     |
| General acquisition features                |     |
| Acquisition memory                          |     |
| Frame burst technology 11                   |     |
| Additional functionality 11                 |     |
| Data transfer                               |     |
| Documentation conventions                   |     |
| Software                                    |     |
| Essentials to get started                   |     |
| Inspecting the Zebra Rapixo CL package15    |     |
| Standard items                              |     |
| Available separately                        |     |
| Handling components                         |     |
| Installation                                |     |
| Need help?                                  |     |
| Zebra Vision Academy 17                     |     |
| Chapter 2: Hardware installation            | 19  |
| Installing your Zebra Rapixo CL board       |     |
| Installing the cable adapter bracket        |     |
| Connecting video sources to Zebra Rapixo CL |     |

| Chapter 3: Using Zebra Rapixo CL boards with<br>Aurora Imaging Library                   | . 27 |  |
|------------------------------------------------------------------------------------------|------|--|
| Installation of SF or DB configuration firmware                                          |      |  |
| Installation of multiple boards 29   Simultaneous image capture from different boards 29 |      |  |
|                                                                                          |      |  |
| Zebra Rapixo CL hardware reference                                                       |      |  |
| Zebra Rapixo CL acquisition                                                              |      |  |
| Performance                                                                              |      |  |
| Acquisition                                                                              |      |  |
| Supported video sources                                                                  |      |  |
| Demultiplexers to support time-multiplexed video sources                                 |      |  |
| Communication                                                                            |      |  |
| UARTs                                                                                    |      |  |
| Acquisition Controller                                                                   |      |  |
| PSGs                                                                                     |      |  |
| Auxiliary signals                                                                        |      |  |
| Camera control and auxiliary signals for<br>Zebra Rapixo CL with DB firmware             |      |  |
| Camera control and auxiliary signals for<br>Zebra Rapixo CL with SF firmware             |      |  |
| Specifications of the auxiliary signals                                                  |      |  |
| Timers                                                                                   |      |  |
| Trigger                                                                                  |      |  |
| Quadrature decoder                                                                       |      |  |
| User signals                                                                             |      |  |
| Acquisition memory                                                                       |      |  |

| Frame burst technology                                                         |    |
|--------------------------------------------------------------------------------|----|
| Data conversion                                                                |    |
| Lookup tables                                                                  |    |
| Bayer color decoder                                                            |    |
| Color space converter and image formatter                                      |    |
| Host interface                                                                 |    |
| Appendix A: Glossary                                                           | 55 |
| Glossary                                                                       |    |
| Appendix B: Technical reference                                                | 61 |
| Board summary                                                                  |    |
| Global information                                                             |    |
| Technical features of Zebra Rapixo CL boards                                   |    |
| Electrical specifications                                                      |    |
| Dimensions and environmental specifications                                    |    |
| Connectors on Zebra Rapixo CL boards                                           |    |
| Camera Link video input connectors                                             |    |
| External auxiliary I/O connectors                                              |    |
| Pinouts for auxiliary I/O connectors of Zebra Rapixo CL in DB configuration 73 |    |
| Pinouts for auxiliary I/O connectors of Zebra Rapixo CL in SF configuration 76 |    |
| LEDs on Zebra Rapixo CL                                                        |    |
| PoCL LEDs                                                                      |    |
| Board status LEDs                                                              |    |

| Appendix C: Acknowledgments                   |    |  |
|-----------------------------------------------|----|--|
| UART copyright information                    |    |  |
| Appendix D: Listing of Zebra Rapixo CL boards | 83 |  |

Chapter

### Introduction

This chapter briefly describes the features of the Zebra Rapixo CL boards, as well as the software that can be used with the boards.

#### Zebra Rapixo CL board

Zebra Rapixo CL is a high-performance PCIe frame grabber that acquires images from Camera Link video sources compliant with Camera Link 2.1 specifications (or earlier)<sup>\*</sup>. The Zebra Rapixo CL is a full height, half-length PCIe x4 board that can be installed in a 2.x PCIe slot and above for maximum performance.

Depending on which firmware is installed on your Zebra Rapixo CL, you will either be able to support SF or DB configurations. The DB configuration supports acquisition from two Camera Link video source in Base configuration. The SF configuration supports acquisition from a Camera Link video source in Medium, Full, or 80-bit configuration. Zebra Rapixo CL supports power-over Camera Link (PoCL) compliant video sources and Camera Link frequencies of 20 MHz to 85 MHz.



\*. For information about Zebra Rapixo CL Pro, see the Zebra Rapixo CL Pro manual.

#### **General acquisition features**

Zebra Rapixo CL supports area-scan and line-scan, monochrome and color video sources. The color video sources can be RGB video sources or video sources with a Bayer color filter. Zebra Rapixo CL can decode Bayer color-encoded images and perform color space conversions while transferring the image to the Host.

#### **Acquisition memory**

Zebra Rapixo CL is equipped with 512 Mbytes of DDR3 SDRAM acquisition memory, which is used to store acquired images. The memory interface has multiple input ports, with a total interface data transfer rate of 4.25 Gbytes/sec.

#### Frame burst technology

All versions of Zebra Rapixo CL support frame burst technology. This technology allows you to grab a group of sequential frames into a multi-frame image buffer with one grab command; the defined number of frames are stored contiguously in the same buffer. The end-of-grab event only occurs once the entire group of frames has been grabbed, reducing the number of events that need to be handled. This is useful in cases where you have a high frame rate and need to ensure that no frames are missed.

#### **Additional functionality**

In addition to the core video capture capabilities, Zebra Rapixo CL incorporates a variety of features to simplify overall system integration. These features include:

- Color space converter and image formatter. This can convert data as it is being transferred to the Host. It can convert 8- or 16-bit monochrome or 24- or 48-bit packed BGR data to monochrome, packed BGR, packed BGRa, planar RGB, or YUV (YUYV) format. In addition, it can flip or subsample data sent to the Host.
- **Bayer decoder.** This can convert Bayer-encoded data to RGB. The following Bayer patterns are supported: GRBG, GBRG, BGGR, and RGGB.
- Auxiliary, multi-purpose signals. These are non-video signals that can support one or more functionalities (for example, trigger input or timer output), depending on the auxiliary signal.
- **Integrated quadrature decoders.** These can decode quadrature input received from a rotary or linear encoder.

#### **Data transfer**

Your Zebra Rapixo CL can send data to the Host at a maximum theoretical transfer rate of 2 Gbytes/sec. Optimum conditions for high speed transfer include using the board in a PCIe 2.x slot with 4 active lanes, using a 256-byte payload. DMA write performance is chipset and computer dependent, and is slightly affected by the image size and alignment in Host memory (frame start address and line pitch).

To measure the effective available bandwidth of the PCIe slot in your computer with your Zebra Rapixo CL board, Zebra provides the Rapixo CL Bench tool. This tool is integrated in the Aurora Imaging Configurator utility, which is shipped with software that supports Zebra Rapixo CL products (for example, Aurora Imaging Library).

#### **Documentation conventions**

This manual refers to the product as Zebra Rapixo CL. When necessary, this manual distinguishes between the SF and DB configurations on the board using its full name (for example, Zebra Rapixo CL SF or Zebra Rapixo CL DB), or its abbreviated forms (CL SF or CL DB).

Also note that, when the term Host is used in this manual, it refers to the host computer.

#### Software

|                                | To operate your Zebra Rapixo CL, you can use one or more Aurora Imaging<br>software products that supports the board. These are the Aurora Imaging Library<br>and its derivatives (for example, Aurora Imaging Library Lite and Aurora Imaging<br>Intellicam). All Zebra software is supported under Windows; Aurora Imaging<br>Library is also supported under Linux when using Zebra Rapixo CL. Consult your<br>software manual for supported versions of these operating systems.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Aurora Imaging<br>Library      | Aurora Imaging Library is a high-level programming library with an extensive set<br>of optimized functions for image capture, processing, analysis, transfer,<br>compression, display, and archiving. Image processing operations include<br>point-to-point, statistical, spatial filtering, morphological, geometric<br>transformation, and FFT operations. Analysis operations support camera<br>calibration, are performed with sub-pixel accuracy, and include pattern<br>recognition (normalized grayscale correlation and Geometric Model Finder), blob<br>analysis, edge extraction and analysis, measurement, image registration,<br>metrology, character recognition (template-based and for both normal and<br>dot-matrix text, feature based), code reading and verification (1D, 2D and<br>composite code types), bead (continuous strips of material) inspection, 3D<br>reconstruction, 3D processing, 3D analysis, classification, and color analysis. |
|                                | platforms and can be designed to take advantage of multi-processing and multi-threading environments.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| Aurora Imaging<br>Library Lite | Aurora Imaging Library Lite is a subset of Aurora Imaging Library. It includes all<br>the Aurora Imaging Library functions for image acquisition, transfer, display<br>control, and archiving. It also allows you to perform processing operations that<br>are typically useful to preprocess grabbed images.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Aurora Imaging<br>Intellicam   | Aurora Imaging Intellicam is an interactive Windows program that allows for fast<br>video source interfacing and provides interactive access to all the acquisition<br>features of your Zebra board. Aurora Imaging Intellicam also has the ability to<br>create custom digitizer configuration format (DCF) files, which Aurora Imaging<br>Library and its derivatives use to interface with specific non-standard video<br>sources. Aurora Imaging Intellicam is included with all Aurora Imaging software<br>products.                                                                                                                                                                                                                                                                                                                                                                                                                                            |

#### **Essentials to get started**

To begin using your Zebra Rapixo CL, you must have a computer with the following:

- An available PCIe 2.x x4<sup>\*</sup> slot. Note that a PCIe 2.x slot will ensure the fastest possible transfer of data to the Host.
- Processor with an Intel 64-bit architecture, or equivalent.
- Aurora Imaging Library or one of its derivatives.

Zebra does not guarantee compatibility with all computers that have the above specifications. Please consult with your local Zebra representative, local Zebra Imaging sales office, the Zebra web site, or the Zebra Customer Support Group at headquarters before using a specific computer.

Consult your software package for other computer requirements (for example, operating system and memory requirements).

<sup>\*.</sup> Note that you can install Zebra Rapixo CL in any mechanical PCIe slot that fits your board (for example, connecting to open-ended connectors). The mechanical width of the connector does not always indicate the amount of electrically connected lanes it has. For example, you can install a x4 board in a PCIe x1 slot that has a mechanical x4 connector; however, the maximum transfer rate between Zebra Rapixo CL and the Host is reduced by 75%. Also, if you install it in a PCIe slot that is of an earlier version than the capabilities of the board, then the maximum bandwidth/transfer rate will also be affected.

#### **Inspecting the Zebra Rapixo CL package**

You should check the contents of your Zebra Rapixo CL package when you first open it. If something is missing or damaged, contact your Zebra representative.

#### **Standard items**

You should receive the following items:

• The Zebra Rapixo CL board.



#### **Available separately**

You might have also ordered one or more of the following:

• A HD-15 cable adapter bracket, equipped with two HD-15 auxiliary I/O connectors.



• Aurora Imaging Library or Aurora Imaging Library Lite. Aurora Imaging Intellicam is included with both of these software packages.

#### **Handling components**

The electronic circuits in your computer and the circuits on your Zebra Rapixo CL are sensitive to static electricity and surges. Improper handling can seriously damage the circuits. Be sure to drain static electricity from your body by touching a metal fixture (or ground) before you touch any electronic component. In addition, do not let your clothing come in contact with the circuit boards or components.

WarningBefore you add or remove devices from your computer, always turn off the power<br/>to your computer and all peripherals.

#### Installation

The installation procedure consists of the following steps:

- 1. Complete the hardware installation procedure described in *Chapter 2: Hardware installation*.
- 2. Complete the software installation procedure described in the documentation accompanying your software package.

More informationFor information on installing the appropriate firmware and/or using multipleZebra Rapixo CL boards, refer to Chapter 3: Using Zebra Rapixo CL boards with<br/>Aurora Imaging Library.

For in-depth hardware information, refer to *Chapter 4: Zebra Rapixo CL hardware reference*; whereas for a summary of this information, as well as environmental and electrical specifications, and connector pinout descriptions, see *Appendix B: Technical reference*.

This manual occasionally makes reference to a Aurora Imaging Library Lite function. However, anything that can be accomplished with Aurora Imaging Library Lite can also be accomplished with Aurora Imaging Library.

#### **Need help?**

If you experience problems during installation or while using this product, you can refer to the support page on the Zebra web site: zebra.com/mv-support. This support page provides information on how to contact technical support.

To request support, you should first complete and submit the online Technical Support Request Form, accessible from the above-mentioned web page. Once you have submitted the information, a Zebra support agent will contact you shortly thereafter by email or phone, depending on the problem.

#### **Zebra Vision Academy**

The Zebra Vision Academy online training resource is also available to help customers visualize the steps involved in using various products. For access to these videos, visit zebra.com/vision-academy.

#### 18 Chapter 1: Introduction

Chapter 2

# Hardware installation

This chapter explains how to install your Zebra Rapixo CL board in your computer.

#### Installing your Zebra Rapixo CL board

Before you install your Zebra Rapixo CL board, some precautionary measures must be taken. Turn off the power to your computer and its peripherals, and drain static electricity from your body (by touching a metal part of the computer chassis).

Proceed with the following steps to install your board:

- 1. Remove the cover from your computer; refer to your computer's documentation for instructions.
- 2. Check that you have an empty PCIe 2.x<sup>\*</sup> slot in which to install your Zebra Rapixo CL. A PCIe 2.x x4 x8 or x16 slot will ensure the fastest possible transfer of data to the Host, depending on your model. If you use a PCIe 1.x slot, the transfer rate will be half of that of a PCIe 2.x slot.



<sup>\*.</sup> Note that you can install Zebra Rapixo CL in any mechanical PCIe slot that fits your board (for example, connecting to open-ended connectors). The mechanical width of the connector does not always indicate the amount of electrically connected lanes it has. For example, you can install a x4 board in a PCIe x1 slot that has a mechanical x4 connector; however, the maximum transfer rate between Zebra Rapixo CL and the Host is reduced by 75%. Also, if you install it in a PCIe slot that is of an earlier version than the capabilities of the board, then the maximum bandwidth/transfer rate will also be affected.

Zebra Rapixo CL might drop frames if the PCIe slot does not have the appropriate number of active lanes (for example, if a x4 board is connected to a PCIe x4 slot that has only one active lane<sup>\*</sup>). Verify with your motherboard manufacturer to find out the number of active lanes of each slot on the motherboard.

If you need to install the HD-15 cable adapter bracket, you will need an additional slot for the cable adapter bracket. The slot need not be adjacent to the Zebra Rapixo CL board. In addition, the cable adapter bracket does not plug into a slot's connector; it attaches only to the back of the computer's chassis.

Note that the external auxiliary I/O connectors on the cable adapter bracket are panel mount connectors. If you don't want to occupy an entire slot for the bracket, you can punch out two holes in the computer chassis, and then screw the connectors in the holes.



<sup>\*.</sup> After installing the board, you can verify in software the number of PCIe lanes that are currently active, using the Aurora Imaging Library Lite function MsysInquire() with M\_PCIE\_NUMER\_OF\_LANES.

- 3. If there is a metal plate at the back of the selected slots, remove it. Keep the screw from the top of the plate to anchor your board and cable adapter bracket once they are installed.
- 4. Position your Zebra Rapixo CL board in the selected PCIe slot. Align the connectors of your board with the opening at the back of the slot, and move the board until the connectors pass through the opening.
- ImportantWhen installing your Zebra Rapixo CL board in a PCIe x16 slot, special care must<br/>be taken to avoid damaging the board. Some PCIe x16 slots have a connector with<br/>a retainer. You should avoid touching the latch of this retainer with the board.<br/>Alternatively, you can remove the latch from the retainer.



- 5. Once the input connectors are in the opening of the chassis, press the board firmly but carefully straight down into the connector of the slot.
- 6. Anchor the board using the screw that you removed in step 3.
- 7. If required, install the cable adapter bracket, as described in the section *Installing the cable adapter bracket*, later in this chapter.
- 8. Install the correct firmware for your video source; see *Chapter 3: Using Zebra Rapixo CL boards with Aurora Imaging Library*.
- 9. Attach your video sources, as described in the section *Connecting video sources to Zebra Rapixo CL*, later in this chapter.
- 10. Turn on your computer.

- When you boot your computer under Windows, Windows' Plug-and-Play system will detect a new Multimedia Video Device and you will be asked to assign it a driver. At this point, you should click on Cancel.
- Under Windows and Linux, the driver will be installed during the installation of Zebra Rapixo CL software.
- 11. Disable active state power management (ASPM) for PCIe devices, to maximize the performance of Zebra Rapixo CL. In the BIOS, disable all ASPM (or equivalent) settings (typically accessible from the **Power management** sub-menu of the **Advanced Configurations** menu). In addition, if the operating system has an **ASPM for PCIe devices** option, disable this option as well. For example, under Microsoft Windows 10, open the **Power Options** dialog box from the Windows Control Panel. For the currently selected power plan, click on **Change Plan Settings** and then click on **Change Advanced Power Settings**. In the presented dialog, expand **PCI Express**, and then expand **Link State Power Management** and set it to **Off**.
- 12. Under Microsoft Windows, set the power plan option to high performance to maximize the performance of Zebra Rapixo CL and minimize the possibility of dropped frames. For example, under Microsoft Windows 10, open the **Power Options** dialog box from the Windows Control Panel and set the power plan option to **High Performance**.

#### Installing the cable adapter bracket

To install the cable adapter bracket, proceed with the following steps:

- 1. Make sure that your Zebra Rapixo CL board is fastened to the computer chassis.
- 2. Attach the cable adapter bracket to the internal auxiliary I/O connector on the Zebra Rapixo CL board. When attaching the flat ribbon cable of the adapter bracket, position the cable so that the black wire is on the same side as the bracket of the Zebra Rapixo CL board. Zebra Rapixo CL has one internal 32-pin auxiliary I/O connector.



- 3. Slide the bracket of the cable adapter bracket into the opening at the back of the selected slot.
- 4. Anchor the bracket to the chassis using the screw that you removed in the previous section.
  - Note that the external auxiliary I/O connectors on the cable adapter bracket are panel mount connectors. If you don't want to occupy an entire slot for the bracket, you can punch out two holes in the computer chassis, and then screw the connectors in the holes.

#### **Connecting video sources to Zebra Rapixo CL**

Before connecting a video source to Zebra Rapixo CL, ensure you have the correct firmware for your video source; see *Chapter 3: Using Zebra Rapixo CL boards with Aurora Imaging Library* for more information. When the correct firmware is installed for your video source, you can connect your video source(s) and I/Os using the following connectors on its bracket(s):

- Two mini Camera Link-compliant video input connectors (HDR/SDR). Used to receive video input, timing, and synchronization signals, from the video source. These are also used to transmit/receive communication signals between the video source and the frame grabber through a UART port.
- External auxiliary I/O connector A (HD-15). Used to transmit/receive auxiliary signals.

To access the signals of the internal auxiliary I/O connector, you might have installed a cable adapter bracket. It has the following connectors:

• External auxiliary I/O connectors C and D (panel mount HD-15). Each used to transmit/receive auxiliary signals.



# WarningEnsure that you have the correct firmware installed before connecting any cameras.<br/>Accidentally connecting a camera to the wrong firmware configuration can<br/>damage the board or your video source.

• Attach video sources to Zebra Rapixo CL as follows:

| Zebra Rapixo CL firmware | Camera Link connector 0                                       | Camera Link connector 1              |
|--------------------------|---------------------------------------------------------------|--------------------------------------|
| DB                       | Video source 0 in Base configuration                          | Video source 1 in Base configuration |
| SF                       | Video source 0 in Base, Medium, Full, or 80-bit configuration |                                      |



#### Warning

When connecting a video source in Full or 80-bit configuration, ensure that you are connecting its cables to the appropriate connector. Accidentally connecting the cables to the wrong connector can damage the board or your video source. The Camera Link connector's pins 2-5 and pins 15-18 are output pins on the top connector (0), while they are input pins on the bottom connector (1). For a pinout of the Camera Link connector, see *Camera Link video input connectors* in *Appendix B: Technical reference*.

To connect video sources to the Camera Link connectors on Zebra Rapixo CL, use Camera Link cables with a 26-pin male mini Camera Link connector (HDR/SDR). When connecting to PoCL-compliant video sources, you should use PoCL-compliant Camera Link cables (HDR/SDR). Camera Link cables are not available from Zebra; for possible sources, see the *Connectors on Zebra Rapixo CL boards* section in *Appendix B: Technical reference*.

If using both Camera Link connectors to connect to the same video source (Medium configuration or Full configuration), the cables you choose should be of the same type and length. Note, however, if they are not, Zebra Rapixo CL will adapt to any delay caused by reasonable differences in length. Chapter

# Using Zebra Rapixo CL boards with Aurora Imaging Library

This chapter explains how to change your Zebra Rapixo CL firmware, as well as using multiple Zebra Rapixo CL boards with Aurora Imaging Library.

# Installation of SF or DB configuration firmware

|         | Before connecting to any video source, ensure that you have the correct firmware<br>installed on your Zebra Rapixo CL board. Only DB cameras can be connected to<br>a Zebra Rapixo CL with firmware installed for DB configuration. Only an SF<br>camera can be connected to a Zebra Rapixo CL with firmware installed for SF<br>configuration. |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Warning | Accidentally connecting a camera to the wrong firmware configuration can damage the board or your video source.                                                                                                                                                                                                                                 |
|         | To install the required firmware:                                                                                                                                                                                                                                                                                                               |
| 1.      | Install the Aurora Imaging Library (or Aurora Imaging Library Lite) and launch the Aurora Imaging Control Center.                                                                                                                                                                                                                               |
| 2.      | Open the Aurora Imaging Configurator utility, expand <b>Rapixo</b> series under <b>Boards</b> , and select <b>CL</b> .                                                                                                                                                                                                                          |
| 3.      | Select the required firmware from the corresponding dropdown list, and then click<br>Install. The board will reboot.                                                                                                                                                                                                                            |
| 4.      | Confirm the status of your board with the LEDs; for information, see the <i>LEDs</i> on Zebra Rapixo CL section in Appendix B: Technical reference.                                                                                                                                                                                             |

#### Installation of multiple boards

You can install and use multiple Zebra Rapixo CL boards in one computer.

Install each additional Zebra Rapixo CL board as you installed the first board (refer to *Chapter 2: Hardware installation*). The number of Zebra Rapixo CL boards that you can install is primarily dependent on the number of physical slots in your computer, and your BIOS; your BIOS establishes how many PCIe devices can be mapped to the PCIe memory space of your computer.

Using Aurora Imaging Library Lite, you have to allocate an Aurora Imaging Library system for each board and allocate the resources of each system. For more information, see MsysAlloc() with M\_SYSTEM\_RAPIXOCL in the Aurora Imaging Library Reference.

## Simultaneous image capture from different boards

In addition to capturing images from multiple video sources with a single Zebra Rapixo CL board, you can also simultaneously capture images from video sources attached to multiple Zebra Rapixo CL boards. Note that the number of video sources from which you can simultaneously capture images is limited by the PCIe chipset on your computer.

The use of a high performance PCIe chipset is necessary to sustain PCIe transfers to Host memory. Ideally, a PCIe 2.x chipset should be used. A PCIe 2.x Host bus will optimize the speed of data transmission, and will minimize data loss.

To measure the effective available bandwidth of the PCIe slot in your computer with the Zebra Rapixo CL board, you can use the Rapixo CL Bench tool integrated in the Aurora Imaging Configurator utility. As a reference point, capturing from a 2K x 2K, 8-bit, 60 frames/sec video source will require a minimum bandwidth of 240 Mbytes/sec, plus an additional bandwidth margin of approximately 20%, for a bandwidth of 288 Mbytes/sec.

30 Chapter 3: Using Zebra Rapixo CL boards with Aurora Imaging Library

Chapter

# Zebra Rapixo CL hardware reference

This chapter explains the architecture, features, and modes of the Zebra Rapixo CL hardware.

#### Zebra Rapixo CL hardware reference

|                                   | This chapter provides information on the Zebra Rapixo CL hardware. It covers<br>the architecture, features, and modes of the board's acquisition section. In<br>addition, the chapter covers the Zebra Rapixo CL hardware related to the<br>formatting and transfer of data. A summary of the features of Zebra Rapixo CL,<br>as well as pin assignments for the various connectors, can be found in<br><i>Appendix B: Technical reference</i> .                                                                                                    |
|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Acquisition path                  | This manual uses the term acquisition path to refer to a path that has the capability to, for example, capture a component or stream of the video input signal. The term <i>independent acquisition path</i> is used to refer to an acquisition path that can, if required, acquire data from a video source independently from another such path on the same frame grabber.                                                                                                                                                                        |
| Digitizer                         | Aurora Imaging Library Lite uses the concept of an Aurora Imaging Library digitizer to represent the acquisition path(s) with which to grab from one input source of the specified type.                                                                                                                                                                                                                                                                                                                                                            |
| Digitizer<br>configuration format | To program the acquisition section, allocate an Aurora Imaging Library digitizer<br>using <b>MdigAlloc</b> () with an appropriate DCF (supplied or created) and digitizer<br>device number. If you find a DCF file that is suitable for your video source, but<br>you need to adjust some of the more common settings, you can do so directly,<br>without adjusting the file, using the appropriate Aurora Imaging Library Lite<br>function. For more specialized adjustments, use the Aurora Imaging Intellicam<br>program to adjust the DCF file. |



#### Zebra Rapixo CL acquisition

Zebra Rapixo CL can capture video from digital video sources compliant with the Camera Link 2.1 specification (or earlier). Zebra Rapixo CL can provide power over Camera Link to attached video sources.

Zebra Rapixo CL supports area-scan and line-scan monochrome and color video sources. The color video sources can be RGB video sources or video sources with a Bayer color filter. Zebra Rapixo CL can decode Bayer color-encoded images and perform color space conversions while transferring the image to the Host. Besides standard Camera Link video sources, Zebra Rapixo CL also supports additional types of video sources, including some time-multiplexed video sources.

Zebra Rapixo CL with SF firmware has one acquisition path that operates in Medium, Full, or 80-bit configuration. Zebra Rapixo CL with DB firmware has two independent acquisition paths that operates in Base configuration.

Each acquisition path can grab at Camera Link frequencies of 20 MHz to 85 MHz. Each acquisition path has its own programmable synchronization generator (PSG) and can operate at different acquisition rates.

The acquisition section of Zebra Rapixo CL supports a comprehensive set of general purpose I/O and serial ports to control cameras and other devices.

#### Performance

The video timing of each acquisition path is as follows:

|                                                       | Maximum |
|-------------------------------------------------------|---------|
| Number of pixels / line (including sync and blanking) | 64 K    |
| Number of lines / frame (including sync and blanking) | 64 K    |
| Pixel clock                                           | 85 Mhz  |

The maximum pixel clock frequency is dependent on the length of the cable used. Refer to the *Technical features of Zebra Rapixo CL boards* subsection of the *Board summary* section in *Appendix B: Technical reference*.

#### Acquisition

A Base-type acquisition path supports up to 24 bits of video data when acquiring from Camera Link-compliant video sources or up to 48 bits when acquiring from non-standard time-multiplexed video sources. Similarly, a Medium-type acquisition path can grab up to 48 bits of video data when acquiring from Camera Link-compliant sources or up to 64 bits when acquiring from non- standard time-multiplexed sources. A Full-type acquisition path supports up to 64 bits of video data when acquiring from camera Link-compliant video sources. An 80-bit-type acquisition path supports up to 80 bits of video data when acquiring from Camera Link-compliant video sources.

The video sources can be area-scan or line-scan video sources. Note that the acquisition paths in dual-Base mode are completely independent; therefore, the video sources do not need to be identical when running in these modes.

#### **Supported video sources**

Zebra Rapixo CL boards support all video sources that are Camera Link 2.1 compatible.

The following are some video sources that are supported when running in Base configuration:

|                      | Video sources supported per acquisition path |
|----------------------|----------------------------------------------|
| Camera Link Standard | • One tap 8/10/12/14/16-bit.                 |
|                      | • Two tap 8/10/12-bit.                       |
|                      | • One tap 3 x 8-bit (RGB).                   |

In addition to the above video sources, the following are some video sources that are supported when running in Medium configuration:

|                      | Video sources supported           | - |
|----------------------|-----------------------------------|---|
| Camera Link Standard | Two tap 14/16-bit.                |   |
|                      | • Three tap 12/14-bit.            |   |
|                      | • Three tap 16-bit <sup>*</sup> . |   |
|                      | • Four tap 8/10/12-bit.           |   |
|                      | • Five*/six tap 8-bit.            |   |

\*. Due to lack of demand, these modes are not natively supported with the current driver and/or firmware; however, support could be possible with an appropriate DCF. Contact Zebra customer support to have an appropriate DCF implemented.

In addition to the above video sources, the following are some video sources that are supported when running in Full configuration:

|                      | Video sources supported        |
|----------------------|--------------------------------|
| Camera Link Standard | • Four tap 14/16-bit.          |
|                      | • Five*/six tap 10/12-bit.     |
|                      | • Seven*/eight/nine tap 8-bit. |

\*. Due to lack of demand, these modes are not natively supported with the current driver and/or firmware; however, support could be possible with an appropriate DCF. Contact Zebra customer support to have an appropriate DCF implemented.

In addition to the above video sources, the following are some video sources that are supported when running in 72-bit configuration:

|                      | Video sources supported          |
|----------------------|----------------------------------|
| Camera Link Standard | • Five tap 14-bit <sup>*</sup> . |

\*. Due to lack of demand, these modes are not natively supported with the current driver and/or firmware; however, support could be possible with an appropriate DCF. Contact Zebra customer support to have an appropriate DCF implemented.

In addition to the above video sources, the following are some video sources that are supported when running in 80-bit configuration:

|                      | Video sources supported          |
|----------------------|----------------------------------|
| Camera Link Standard | • Five tap 16-bit <sup>*</sup> . |
|                      | • Seven*/eight tap 10-bit.       |
|                      | • 10 tap 8-bit.                  |

\*. Due to lack of demand, these modes are not natively supported with the current driver and/or firmware; however, support could be possible with an appropriate DCF. Contact Zebra customer support to have an appropriate DCF implemented.

Zebra Rapixo CL supports power-over-Camera Link (PoCL) video sources and video sources that use an external power supply. For compatibility with video sources that use an external power supply, Zebra Rapixo CL features SafePower mode to supply power only after determining whether the connected video source is PoCL compliant. The PoCL protection on-board fuse can sustain a current of 0.75 A.

### Demultiplexers to support time-multiplexed video sources

The acquisition paths of the board feature a demultiplexer. Each can deserialize input from time-multiplexed video sources on a clock cycle basis. Time-multiplexed video sources can output larger pixel depths and more taps than are possible with non-time-multiplexed video sources in the same configuration, but with a decrease in overall performance. When enabled, the demultiplexer assumes that two video streams share the same data path and that the streams are interleaved based on the clock cycle. The demultiplexer assumes that on one clock cycle, the data is from one stream and that on the next clock cycle, the data is from another stream. The demultiplexer can only deserialize video inputs that, when combined and, if necessary, expanded, total a maximum depth of 64 bits per acquisition path.

Expansion refers to the automatic addition of padding zeros on the most significant bits (MSB) of 10-, 12-, and 14-bit data to create byte aligned 16-bit data.

### Communication

For each acquisition path, two LVDS pairs are used to transmit and receive asynchronous serial communication between the video source and the board. These signals are handled by the Universal Asynchronous Receiver/Transmitters (UARTs).

For each acquisition path, four camera control output signals are also available. These are general-purpose signals that are sent to the video source.

#### UARTs

Zebra Rapixo CL offers an LVDS-compatible Zebra serial interface. Each interface is mapped as a COM port so that it can be accessed through the Microsoft Windows API. Each interface is comprised of both a transmit port and a receive port, permitting the interface to work in full-duplex (bidirectional) mode. The interfaces are located on the Camera Link connectors.

Each interface is controlled by a Universal Asynchronous Receiver-Transmitter (UART)<sup>\*</sup>. Each UART features independently programmable baud rates, supporting all standard baud rates from 300 baud up to 115200<sup>†</sup> baud.

<sup>\*.</sup> The UART implementation was derived from a design by Daniel Wallner. Please see *Appendix C: Acknowledgments* for copyright information.

### **Acquisition Controller**

The acquisition controller is responsible for reconstructing and storing image data in main on-board memory. When writing data to memory, the acquisition controller can perform line and frame reversal; it can flip the image horizontally and/or vertically. On Zebra Rapixo CL boards, the acquisition controller supports adjacent and non adjacent taps in any of the configurations (Base, Medium, Full, 72-bit, or 80-bit) supported by Camera Link 2.1.

On Zebra Rapixo CL with DB firmware, the acquisition controller can write up to three non-sequential memory regions (zones) per acquisition path.

On Zebra Rapixo CL with SF firmware, the acquisition controller can write to a maximum of the following number of non-sequential memory regions: 6 for Medium, 8 for Full, 9 for 72-bit, and 10 for 80-bit<sup>\*</sup>.

Note that the width of each region must be a multiple of the number of adjacent taps in that region.

To establish the number of non-sequential memory regions to which your video source must write, refer to the documentation accompanying your video source.

### PSGs

For each acquisition path, the acquisition controller provides a programmable synchronization generator (PSG). Each PSG allows for independent acquisition from one video source, since each PSG is responsible for managing all video timing and synchronization signals.

The PSGs are also responsible for managing the camera control and auxiliary signals supported by the board. These signals are configurable signals that can support one or several functions, one of which is user-defined for Zebra Rapixo CL; the table in the next subsection identifies the functions to which the camera control and auxiliary signals can be defined. The PSGs are also responsible for implementing the functionality to which these can be defined.

<sup>&</sup>lt;sup>†</sup>. In addition, the maximum baud rate is highly dependent on the amount of computer resources available.

<sup>\*.</sup> The 10 non-sequential memory regions in 80-bit configuration are only available with 8-bit taps.

## **Auxiliary signals**

The following subsections describe the auxiliary signals for Zebra Rapixo CL.

## Camera control and auxiliary signals for Zebra Rapixo CL with DB firmware

The following tables summarize the auxiliary functionality that the PSGs support, and the corresponding signals that the PSGs can receive/generate, for Zebra Rapixo CL with DB firmware. The table also documents the Aurora Imaging Library constants to use.

|                                                                                     |                     |     | LVDS c | am. ctrl              |     |     | LVDS c | am. ctrl              |     |
|-------------------------------------------------------------------------------------|---------------------|-----|--------|-----------------------|-----|-----|--------|-----------------------|-----|
|                                                                                     |                     |     |        | ra Link<br>ector<br>) |     |     |        | ra Link<br>ector<br>1 |     |
| M_CC_10 <i>n</i>                                                                    | n                   | 1   | 2      | 3                     | 4   | 1   | 2      | 3                     | 4   |
| for M_DEV <i>m</i> <sup>*</sup>                                                     | m                   | 0   | 0      | 0                     | 0   | 1   | 1      | 1                     | 1   |
| Functionality that can be routed                                                    | Acquisition<br>path | CC1 | CC2    | CC3                   | CC4 | CC1 | CC2    | CC3                   | CC4 |
| Timer                                                                               | 0                   | 1/2 | 1/2    | 1/2                   | 1/2 |     |        |                       |     |
| (M_TIMER <i>n</i> <sup>†</sup> )                                                    | 1                   |     |        |                       |     | 1/2 | 1/2    | 1/2                   | 1/2 |
| User output                                                                         | 0                   | 0/1 | 0/1    | 0/1                   | 0/1 |     |        |                       |     |
| (bit of Camera Link static-user-output<br>register M_USER_BIT_CC_IOn <sup>†</sup> ) | 1                   |     |        |                       |     | 0/1 | 0/1    | 0/1                   | 0/1 |

\*. Aurora Imaging Library constant, where n and m correspond to the number in the row. M\_DEVm is the required device number of the digitizer (MdigAlloc()) that you must use to access this signal.

|                                                    |                  |              |              |              |               |               | a I/O<br>nnea |               |               |               | ļ  |              | РТО<br>/0 С |              | In<br>ecto    | r             | LVDS Aux In<br>Aux I/O Connector |              |               |               |               |               | LVDS Aux<br>Out<br>Aux I/O<br>Connector |                |                |
|----------------------------------------------------|------------------|--------------|--------------|--------------|---------------|---------------|---------------|---------------|---------------|---------------|----|--------------|-------------|--------------|---------------|---------------|----------------------------------|--------------|---------------|---------------|---------------|---------------|-----------------------------------------|----------------|----------------|
|                                                    |                  |              | A            |              |               | C             |               |               | D             |               |    | 1            | 0           | ;            | 1             | )             |                                  | ٩.           | (             | C             | D             |               | Α                                       | C              | D              |
| M AUX IOn                                          | n                | 8            | 9            | 2            | 8             | 9             | 3             | 8             | 9             | 3             | 6  | 7            | 0           | 1            | 0             | 1             | 10                               | 11           | 4             | 5             | 4             | 5             | 12                                      | 12             | 13             |
| for M_DEV <i>m</i> <sup>*</sup>                    | m                | 0            | 0            | 0/1          | 1             | 1             | 0/1           | 3             | 3             | 2/3           | 0  | 0            | 0/1         | 0/1          | 2/3           | 2/3           | 0                                | 0            | 0/1           | 0/1           | 2/3           | 2/3           | 0                                       | 1              | 3              |
| Functionality that<br>can be routed or<br>received | Acquisition path | TTL_AUX_I0_4 | TTL_AUX_I0_5 | TTL_AUX_I0_6 | TTL_AUX_I0_12 | TTL_AUX_I0_13 | TTL_AUX_I0_14 | TTL_AUX_I0_28 | TTL_AUX_I0_29 | TTL_AUX_I0_30 |    | OPT0_AUX_IN1 |             | OPT0_AUX_IN9 | OPT0_AUX_IN24 | OPT0_AUX_IN25 |                                  | LVDS_AUX_IN3 | LVDS_AUX_IN10 | LVDS_AUX_IN11 | LVDS_AUX_IN26 | LVDS_AUX_IN27 | LVDS_AUX_OUT7                           | LVDS_AUX_OUT15 | LVDS_AUX_OUT31 |
| Timer                                              | 0                |              | 1            | 2            |               |               |               |               |               |               |    |              |             |              |               |               |                                  |              |               |               |               |               | 1/2                                     |                |                |
| (M_TIMERn <sup>†</sup> )                           | 1                |              |              |              |               | 1             | 2             |               |               |               |    |              |             |              |               |               |                                  |              |               |               |               |               |                                         | 1/2            |                |
| Trigger controller                                 | 0                | т0           | T1           | T2           |               |               | T3            |               |               |               | Т0 | T1           | T2          | T3           |               |               | T0                               | T1           | T2            | T3            |               |               |                                         |                |                |
| affected by<br>input signal <sup>†</sup>           | 1                |              |              | T2           | T0            | T1            | T3            |               |               |               |    |              | T0/<br>T2   | T1/<br>T3    |               |               |                                  |              | T0/<br>T2     | T1/<br>T3     |               |               |                                         |                |                |
| Timer-clock                                        | 0                |              |              |              |               |               |               |               |               |               |    |              |             |              |               |               |                                  | 0            |               |               |               |               |                                         |                |                |
| input                                              | 1                |              |              |              |               |               |               |               |               |               |    |              |             |              |               |               |                                  |              |               | 0             |               |               |                                         |                |                |
| Bit of quadrature                                  | 0                |              |              |              |               |               |               |               |               |               |    |              |             |              |               |               | 0                                | 1            |               |               |               |               |                                         |                |                |
| input <sup>‡</sup>                                 | 1                |              |              |              |               |               |               |               |               |               |    |              |             |              |               |               |                                  |              | 0             | 1             |               |               |                                         |                |                |
| User output (bit of                                | 0                | 2            | 3            | 4            |               |               | 5             |               |               |               |    |              |             |              |               |               |                                  |              |               |               |               |               | 0                                       |                |                |
| main<br>static-user-output<br>register             | 1                |              |              | 4            | 2             | 3             | 5             |               |               |               |    |              |             |              |               |               |                                  |              |               |               |               |               |                                         | 0              |                |
| M_USER_BIT <i>n</i> <sup>†</sup> )                 |                  |              |              |              |               |               |               |               |               |               |    |              |             |              |               |               |                                  |              |               |               |               |               |                                         |                |                |

\*. Aurora Imaging Library constant, where *n* and *m* correspond to the number in the row. M\_DEV*m* is the required device number of the digitizer (MdigAlloc()) that you must use to access this signal.

t. Note that there are only 4 trigger controllers per acquisition path.

1. A rotary encoder with quadrature output transmits a two-bit code. The table entries 0 and 1, therefore, denote bit position.

|                | Acquisition | LVDS cam. ctrl |        |         |     |         |        |     |     |  |  |  |  |  |
|----------------|-------------|----------------|--------|---------|-----|---------|--------|-----|-----|--|--|--|--|--|
| Type of signal | path        |                | CL cor | nect. O |     | CL conn | ect. 1 |     |     |  |  |  |  |  |
|                |             | CC1            | CC2    | CC3     | CC4 | CC1     | CC2    | CC3 | CC4 |  |  |  |  |  |
| VSYNC output   | 0           | 1              | 1      | 1       | 1   |         |        |     |     |  |  |  |  |  |
|                | 1           |                |        |         |     | 1       | 1      | 1   | 1   |  |  |  |  |  |
| HSYNC output   | 0           | 1              | 1      | 1       | 1   |         |        |     |     |  |  |  |  |  |
|                | 1           |                |        |         |     | 1       | 1      | 1   | 1   |  |  |  |  |  |
| Clock output   | 0           | 1              | 1      | 1       | 1   |         |        |     |     |  |  |  |  |  |
| Clock output   | 1           |                |        |         |     | 1       | 1      | 1   | 1   |  |  |  |  |  |

The following table lists the auxiliary input signals (or auxiliary I/O signals set to input) that can be rerouted onto output signals and the output signals onto which they can be rerouted.

|                                     |           |                  |   |    | LVI            | DS c | am. | ctrl |               |     |              |              |              | TTL           | Aux           | c I/O         |               |               |               | LV            | /DS A                  | ux             |
|-------------------------------------|-----------|------------------|---|----|----------------|------|-----|------|---------------|-----|--------------|--------------|--------------|---------------|---------------|---------------|---------------|---------------|---------------|---------------|------------------------|----------------|
|                                     |           |                  |   |    | ra Li<br>ectoi |      | I   |      | ra Li<br>ecto |     |              |              | Au           | x I/C         | ) Co          | nneo          | ctor          |               |               |               | Out<br>/ux I/<br>onnec |                |
|                                     |           |                  |   |    |                |      |     |      |               |     |              | A            |              |               | C             |               |               | D             |               | A             | C                      |                |
|                                     |           | X                |   |    |                |      | ⊢   |      |               |     | 8            | 9            | 2            | 8             | 9             | 3             | 8             | 9             | 3             | 12            | 12                     | 13             |
| M_AUX_IOx or                        |           | y                | 1 | 2  | 3              | 4    | 1   | 2    | 3             | 4   |              |              |              |               |               |               |               |               |               |               |                        |                |
| M_CC_IOy<br>for M_DEVz <sup>*</sup> |           | z                | 0 | 0  | 0              | 0    | 1   | 1    | 1             | 1   | 0            | 0            | 0/1          | 1             | 1             | 0/1           | 3             | 3             | 2/3           | 0             | 1                      | 3              |
|                                     |           |                  |   |    |                |      |     |      |               |     |              |              |              |               |               |               |               |               |               |               | 5                      |                |
| Auxiliary input signal (or          |           | oath             |   |    |                |      |     |      |               |     | 4            | പ്           | ؈            | 12            | <u>۳</u>      | 4             | 58            | 29            | 8             | LVDS_AUX_OUT7 | LVDS_AUX_OUT15         | LVDS_AUX_OUT31 |
| auxiliary I/O signal set to         | ĕ.        | ion p            | S | 23 | ទួ             | CC4  | 5   | CC2  | ទួ            | CC4 |              | 0_           | <u> </u>     | <u> </u>      | <u> </u>      | <u> </u>      | <u> </u>      | 0.            | <u> </u>      | З             | З'                     | Ň              |
| input)                              | M_AUX_IOx | Acquisition path |   |    |                |      | ٢   | -    |               |     | TTL_AUX_I0_4 | TTL_AUX_I0_5 | AU           | TTL_AUX_I0_12 | TTL_AUX_I0_13 | TTL_AUX_I0_14 | TTL_AUX_10_28 | TTL_AUX_I0_29 | TTL_AUX_10_30 | S_A           | SA                     | S_A            |
|                                     | M         | Acq              |   |    |                |      |     |      |               |     | Ę            | Ę            | TTL_AUX_I0_6 | Ę             | Ë.            | Ę.            | Ę.            | Ë.            | Ę             | Z             | R                      | LVD            |
| TTL_AUX_I0_4                        | 8         | 0                | ٠ | ٠  | •              | ٠    |     |      |               |     |              |              |              |               |               |               |               |               |               |               |                        |                |
| TTL_AUX_I0_5                        | 9         | 0                |   |    |                |      |     |      |               |     |              |              |              |               |               |               |               |               |               |               |                        |                |
| TTL_AUX_I0_6                        | 2         | 0/1              | ٠ | •  | •              | ٠    | •   | •    | •             | •   |              |              |              |               |               |               |               |               |               |               |                        |                |
| TTL_AUX_I0_12                       | 8         | 1                |   |    |                |      | •   | •    | •             | •   |              |              |              |               |               |               |               |               |               |               |                        |                |
| TTL_AUX_I0_13                       | 9         | 1                |   |    |                |      |     |      |               |     |              |              |              |               |               |               |               |               |               |               |                        |                |
| TTL_AUX_I0_14                       | 3         | 0/1              |   |    |                |      |     |      |               |     |              |              |              |               |               |               |               |               |               |               |                        |                |
| OPTO_AUX_IN0                        | 6         | 0                | ٠ | •  | •              | ٠    |     |      |               |     |              |              |              |               |               |               |               |               |               |               |                        |                |
| OPTO_AUX_IN1                        | 7         | 0                | ٠ | •  | •              | ٠    |     |      |               |     |              |              |              |               |               |               |               |               |               |               |                        |                |
| OPTO_AUX_IN8                        | 0         | 0/1              |   |    |                |      | •   | •    | •             | •   |              |              |              |               |               |               |               |               |               |               |                        |                |
| OPTO_AUX_IN9                        | 1         | 0/1              | ٠ | •  | •              | ٠    | •   | •    | •             | •   |              |              |              |               |               |               |               |               |               |               |                        |                |
| LVDS_AUX_IN2                        | 10        | 0                |   |    |                |      |     |      |               |     |              |              |              |               |               |               |               |               |               |               |                        |                |
| LVDS_AUX_IN3                        | 11        | 0                |   |    |                |      |     |      |               |     |              |              |              |               |               |               |               |               |               |               |                        |                |
| LVDS_AUX_IN10                       | 4         | 0/1              |   |    |                |      | •   | •    | •             | •   |              |              |              |               |               |               |               |               |               |               |                        |                |
| LVDS_AUX_IN11                       | 5         | 0/1              | ٠ | •  | •              | ٠    | •   | •    | •             | •   |              |              |              |               |               |               |               |               |               |               |                        |                |

\*. Aurora Imaging Library constant, where x, y, and z correspond to the numbers in the row. M\_DEVz is the required device number of the digitizer (MdigAlloc()) that you must use to access this signal.

## Camera control and auxiliary signals for Zebra Rapixo CL with SF firmware

The following tables summarize the auxiliary functionality that the PSGs support, and the corresponding signals that the PSGs can receive/generate, for Zebra Rapixo CL with SF firmware. The table also documents the Aurora Imaging Library constants to use.

|                                                                                 |                  |     |     | am. ctrl<br>Connector ( | )   |
|---------------------------------------------------------------------------------|------------------|-----|-----|-------------------------|-----|
| M_CC_I0 <i>n</i>                                                                | n                | 1   | 2   | 3                       | 4   |
| for M_DEV <i>m</i> *                                                            | m                | 0   | 0   | 0                       | 0   |
| Functionality that can be routed                                                | Acquisition path | CC1 | CC2 | CC3                     | CC4 |
| Timer                                                                           | 0                | 1/2 | 1/2 | 1/2                     | 1/2 |
| (M_TIMERn <sup>†</sup> )                                                        | 1                |     |     |                         |     |
| User output                                                                     | 0                | 0/1 | 0/1 | 0/1                     | 0/1 |
| (bit of Camera Link static-user-output register $M_USER_BIT_CC_10n^{\dagger}$ ) | 1                |     |     |                         |     |

\*. Aurora Imaging Library constant, where n and m correspond to the number in the row. M\_DEVm is the required device number of the digitizer (MdigAlloc()) that you must use to access this signal.

|                                                                                             |                  | A            | TTL Aux I/O<br>Aux I/O Connector |              |               |               |    |              | )PTO<br>1/0 ( |              |               |               |              | L<br>Aux     |               | LVDS<br>Aux Out<br>Aux I/O<br>Connector |               |               |               |
|---------------------------------------------------------------------------------------------|------------------|--------------|----------------------------------|--------------|---------------|---------------|----|--------------|---------------|--------------|---------------|---------------|--------------|--------------|---------------|-----------------------------------------|---------------|---------------|---------------|
|                                                                                             |                  |              | A                                |              | C             | D             |    | A            | (             | C            | 1             | D             |              | A            | (             | C                                       | 1             | D             | Α             |
| M AUX IOn                                                                                   | n                | 8            | 9                                | 2            | 3             | 3             | 6  | 7            | 0             | 1            | 0             | 1             | 10           | 11           | 4             | 5                                       | 4             | 5             | 12            |
| for M_DEV <i>m</i> <sup>*</sup>                                                             | m                | 0            | 0                                | 0            | 0             | 1             | 0  | 0            | 0             | 0            | 1             | 1             | 0            | 0            | 0             | 0                                       | 1             | 1             | 0             |
| Functionality that can be routed or received                                                | Acquisition path | TTL_AUX_I0_4 | TTL_AUX_I0_5                     | TTL_AUX_I0_6 | TTL_AUX_I0_14 | TTL_AUX_I0_30 |    | OPT0_AUX_IN1 | OPT0_AUX_IN8  | OPT0_AUX_IN9 | OPT0_AUX_IN24 | OPT0_AUX_IN25 | LVDS_AUX_IN2 | LVDS_AUX_IN3 | LVDS_AUX_IN10 | LVDS_AUX_IN11                           | LVDS_AUX_IN26 | LVDS_AUX_IN27 | LVDS_AUX_OUT7 |
| Timer (M_TIMERn <sup>†</sup> )                                                              | 0                |              | 1                                | 2            |               |               |    |              |               |              |               |               |              |              |               |                                         |               |               | 1/2           |
| Trigger controller<br>affected by input<br>signal <sup>†</sup>                              | 0                | T0           | T1                               | T2           | Т3            |               | T0 | T1           | T2            | Т3           |               |               | т0           | T1           | T2            | Т3                                      |               |               |               |
| Timer-clock input                                                                           | 0                |              |                                  |              |               |               |    |              |               |              |               |               |              | 0            |               |                                         |               |               |               |
| Bit of quadrature<br>input <sup>‡</sup>                                                     | 0                |              |                                  |              |               |               |    |              |               |              |               |               | 0            | 1            |               |                                         |               |               |               |
| User output (bit of<br>main<br>static-user-output<br>register<br>M_USER_BITn <sup>†</sup> ) | 0                | 2            | 3                                | 4            | 5             |               |    |              |               |              |               |               |              |              |               |                                         |               |               | 0             |

\*. Aurora Imaging Library constant, where n and m correspond to the number in the row. M\_DEVm is the required device number of the digitizer (MdigAlloc()) that you must use to access this signal.

t. Note that there are only 4 trigger controllers per acquisition path.

\$. A rotary encoder with quadrature output transmits a two-bit code. The table entries 0 and 1, therefore, denote bit position.

|                | path        |             |        |         | LVDS ( | am. ctrl |       |  |  |
|----------------|-------------|-------------|--------|---------|--------|----------|-------|--|--|
|                |             |             | CL cor | nect. O |        | CL conne | ct. 2 |  |  |
| Type of signal | Acquisition | CC1         | CC2    | CC3     | CC2    | CC3      | CC4   |  |  |
| VSYNC output   | 0           | 1           | 1      | 1       | 1      |          |       |  |  |
| HSYNC output   | 0           | 1           | 1      | 1       | 1      |          |       |  |  |
| Clock output   | 0           | 1 1 1 1   1 |        |         |        |          |       |  |  |

The following table lists the auxiliary input signals (or auxiliary I/O signals set to input) that can be rerouted onto output signals and the output signals onto which they can be rerouted.

|                                                                  |                   |                  |     |     |                 | /DS c |     |     |                 |     | TTL Aux I/O<br>Aux I/O Connector |              |              |               |               | LVDS<br>Aux Out<br>Aux I/O<br>Connector |
|------------------------------------------------------------------|-------------------|------------------|-----|-----|-----------------|-------|-----|-----|-----------------|-----|----------------------------------|--------------|--------------|---------------|---------------|-----------------------------------------|
|                                                                  |                   |                  |     |     | ra Lin<br>ector |       |     |     | ra Lir<br>ector |     |                                  | A            |              | c             | D             | А                                       |
|                                                                  |                   | X                |     |     |                 | _     |     |     |                 |     | 8                                | 9            | 2            | 3             | 3             | 12                                      |
| M_AUX_IOx or                                                     |                   | y                | 1   | 2   | 3               | 4     | 1   | 2   | 3               | 4   |                                  |              |              |               |               |                                         |
| M_CC_IO <i>y</i><br>for M_DEVz <sup>*</sup>                      |                   | z                | 0   | 0   | 0               | 0     | 1   | 1   | 1               | 1   | 0                                | 0            | 0            | 0             | 1             | 0                                       |
| Auxiliary input signal (or<br>auxiliary I/O signal set to input) | M_AUX_10 <i>x</i> | Acquisition path | CC1 | CC2 | CC3             | CC4   | CC1 | CC2 | CC3             | CC4 | TTL_AUX_I0_4                     | TTL_AUX_I0_5 | TTL_AUX_I0_6 | TTL_AUX_I0_14 | TTL_AUX_I0_30 | LVDS_AUX_OUT7                           |
| TTL_AUX_I0_4                                                     | 8                 | 0                | ٠   | •   | •               | •     |     |     |                 |     |                                  |              |              |               |               |                                         |
| TTL_AUX_I0_5                                                     | 9                 | 0                |     |     |                 |       |     |     |                 |     |                                  |              |              |               |               |                                         |
| TTL_AUX_I0_6                                                     | 2                 | 0                | ٠   | •   | •               | •     |     |     |                 |     |                                  |              |              |               |               |                                         |
| TTL_AUX_I0_14                                                    | 3                 | 0                |     |     |                 |       |     |     |                 |     |                                  |              |              |               |               |                                         |
| OPTO_AUX_IN0                                                     | 6                 | 0                |     |     |                 |       |     |     |                 |     |                                  |              |              |               |               |                                         |
| OPTO_AUX_IN1                                                     | 7                 | 0                | •   | •   | •               | •     |     |     |                 |     |                                  |              |              |               |               |                                         |
| OPTO_AUX_IN8                                                     | 0                 | 0                |     |     |                 |       |     |     |                 |     |                                  |              |              |               |               |                                         |
| OPTO_AUX_IN9                                                     | 1                 | 0                | ٠   | •   | •               | •     |     |     |                 |     |                                  |              |              |               |               |                                         |
| LVDS_AUX_IN2                                                     | 10                | 0                | ٠   | •   | •               | •     |     |     |                 |     |                                  |              |              |               |               |                                         |
| LVDS_AUX_IN3                                                     | 11                | 0                |     |     |                 |       |     |     |                 |     |                                  |              |              |               |               |                                         |
| LVDS_AUX_IN10                                                    | 4                 | 0                |     |     |                 |       |     |     |                 |     |                                  |              |              |               |               |                                         |
| LVDS_AUX_IN11                                                    | 5                 | 0                | •   | •   | •               | •     |     |     |                 |     |                                  |              |              |               |               |                                         |

\*. Aurora Imaging Library constant, where x, y, and z correspond to the numbers in the row. M\_DEVz is the required device number of the digitizer (MdigAlloc()) that you must use to access this signal.

### **Specifications of the auxiliary signals**

TTL auxiliary input or output signals

Opto-isolated auxiliary input signals

LVDS camera control output signals

LVDS auxiliary input signals

LVDS auxiliary output signals

|                     | Total # (             | of signals                                                    |                                                      |  |  |
|---------------------|-----------------------|---------------------------------------------------------------|------------------------------------------------------|--|--|
| CL with S           | F firmware            | CL with DB firmware                                           |                                                      |  |  |
| No cable<br>bracket | With cable<br>bracket | No cable<br>bracket                                           | With cable<br>bracket                                |  |  |
| 8                   | 24                    | 8                                                             | 24                                                   |  |  |
|                     | No cable<br>bracket   | CL with SF firmware<br>No cable With cable<br>bracket bracket | No cable With cable No cable bracket bracket bracket |  |  |

Zebra Rapixo CL has auxiliary signals in the following formats:

When you route an external signal to an auxiliary signal or vice versa, verify that the external signal meets the electrical specifications of the auxiliary signal.

When an auxiliary input signal is received in TTL format directly, it will be clamped at a maximum of 5.7 V and at a minimum of -0.7 V to protect the input buffer. Typically, the signal should have a maximum of 5 V and a minimum of 0 V. A signal over 2 V is considered high, while anything less than 0.8 V is considered low.

The opto-isolated auxiliary input signals pass through an opto-coupler, a device that protects the board from outside surges and different ground levels, and allows the frame grabber to be totally isolated. The voltage difference across the positive and negative components of the signal must be between 4.71 V and 9.165 V for logic high, and between -5.0 V and 0.8 V for logic low.

You can set the direction of an auxiliary I/O signal using the Aurora Imaging Library Lite function MdigControl() with M\_AUX\_SIGNAL\_MODE.

You can set up the auxiliary signals in the DCF. Alternatively, for most commonly used functionalities, you can configure the auxiliary signals using the Aurora Imaging Library Lite function MdigControl() (for example, with M\_IO..., M\_GRAB\_TRIGGER..., M\_TIMER..., or M\_ROTARY\_ENCODER...).

### Timers

Zebra Rapixo CL has four 16-bit timers when in DB configuration and two 16-bit timers when in SF configuration, which operate on a specified clock source. Timer output signals allow you to control the exposure time and other external events related to the video source (such as a strobe). A timer output signal can be output on any of the auxiliary output signals or auxiliary I/O signals in output mode.

The timers can use one of the following as a clock source:

- A 125 MHz internal clock source.
- A clock based on the output of another timer set in continuous mode.
- A clock based on the HSYNC or VSYNC signal of your camera.
- A clock based on the pixel clock signal of your camera.

To route a timer output on an auxiliary signal, use the Aurora Imaging Library Lite function MdigControl() with M\_IO\_SOURCE + M\_AUX\_IOn set to M\_TIMERm. To set up a timer, use MdigControl() with M\_TIMER\_....

### Trigger

You can use as a trigger any of the auxiliary input signals (or auxiliary I/O signals in input mode). A trigger signal can be used to initiate image acquisition or prompt an on-board event.

For Zebra Rapixo CL, each PSG has 4 trigger controllers. Each trigger controller can trigger the image acquisition, the timers, and/or the synchronization signals of the PSG's acquisition path. Only one auxiliary signal per trigger controller can be programmed as a trigger input signal. The auxiliary signals are restricted to specific trigger controllers.



**Timing requirements** When you use an auxiliary input signal as a trigger, the pulse width of the signal must be at least 16 nsec (2 clock periods at 125 MHz).

To enable grabbing upon a trigger, use the Aurora Imaging Library Lite function MdigControl() with M\_GRAB\_TRIGGER\_STATE. To set the signal used to trigger the grab, use MdigControl() with M\_GRAB\_TRIGGER\_SOURCE. To start a timer upon a trigger, use MdigControl() with M\_TIMER\_TRIGGER\_SOURCE.

### **Quadrature decoder**

Zebra Rapixo CL features quadrature decoders. They are used to decode quadrature input received from a rotary or linear encoder with quadrature output. A rotary encoder is a device that provides information about the position and direction of a rotating shaft (for example, that of a conveyor belt); a linear encoder is a device that provides information about the position and direction of a moving sensor along a scale. Encoders with quadrature output transmit a two-bit code (also known as Gray code) on two pairs of LVDS wires for each change in position of the rotating shaft, or of the sensor along the scale. For a given direction, the encoder outputs the code in a precise sequence (either 00 - 01 - 11 - 10 or 00 - 10 - 11 - 01, depending on how the encoder is attached). If the rotating shaft, or sensor moving along the scale, changes direction, the rotary encoder transmits the Gray code in the reverse sequence (00 - 10 - 11 - 01 or 00 - 01 - 11 - 10, respectively). Zebra Rapixo CL has one quadrature decoder for each acquisition path.

Upon decoding a Gray code, the quadrature decoder increments or decrements its 32-bit internal counter, depending on the direction of movement. You can configure which Gray code sequence represents forward movement and increments the counter; the reverse Gray code sequence will then represent the backward direction and decrement the counter. You can specify the direction of movement occurring when the Gray code sequence is 00 - 01 - 11 - 10, using MdigControl() with M\_ROTARY\_ENCODER\_DIRECTION.

The quadrature decoder supports encoder frequencies of up to 50 MHz. The LVDS receivers of the Zebra Rapixo CL board support an input voltage from -4 V to +5 V on either LVDS signal, and a maximum differential of 3 V between the two LVDS signals.

 Note that an external source must be used to power the rotary encoder (for example, your computer's 5 V power source).

You can configure the quadrature decoder's settings, using the Aurora Imaging Library Lite function MdigControl() with M\_ROTARY\_ENCODER..., or by modifying the DCF file with Aurora Imaging Intellicam.

### **User signals**

Auxiliary signals can also be used to transmit or receive application-specific user output and/or input.

If you want to start or stop an external event based on some calculation or analysis, you can manually set the state of any auxiliary output signal (or I/O signal set to output) to high or low. To do so, you set the state (on/off) of a bit in a user settable register (static-user-output register). When the bit is on, its associated auxiliary output signal will be high; when it is off, the auxiliary output signal will be low. This bit is referred to as a user-bit. To route the state of a user-bit to an auxiliary output signal, use MdigControl() with M\_IO\_SOURCE and M\_USER\_BITn; to set the state of a user-bit, use MdigControl() with M\_USER\_BIT\_STATE.

Your application can also act upon and interpret the state of an auxiliary input signal (or I/O signal set to input). The state of an auxiliary input signal is not associated with a user-bit; you poll the state of the signal directly. To poll the state of an auxiliary input signal, use MdigInquire() with M\_IO\_STATUS. The state of an auxiliary input signal can also generate an interrupt; to do so, use MdigControl() with M\_IO\_INTERRUPT\_STATE and then use MdigHookFunction() with M\_IO\_CHANGE to hook a function to this event (that is, to set up an event handler).

## **Acquisition memory**

Zebra Rapixo CL is equipped with 512 Mbytes of DDR3 SDRAM acquisition memory, which is used to store acquired images. The memory interface data transfer rate is 4.25 Gbytes/sec. The memory interface has multiple input ports.

Zebra Rapixo CL has 128 Mbytes of memory mapped onto the PCIe bus. You can use a Host pointer to access this memory, or you can access it directly from another PCIe bus master; this memory is referred to as shared memory. To allocate a buffer in shared memory, use the Aurora Imaging Library Lite function MbufAlloc...() with M\_ON\_BOARD + M\_SHARED.

## Frame burst technology

Some modes<sup>\*</sup> of Zebra Rapixo CL support frame burst technology. This technology allows you to grab a group of sequential frames into a multi-frame image buffer with one grab command; the defined number of frames are stored contiguously in the same buffer. The end-of-grab event only occurs once the entire group of frames has been grabbed, reducing the number of events that need to be handled. This is useful in cases where you have a high frame rate and need to ensure that no frames are dropped.

Since Zebra Rapixo CL will wait for the specified number of frames to complete before sending data to the Host, you could experience latency if the last frame has not reached the minimum frame count for a frame burst, or the acquisition of the last frame has stalled. To prevent frame-burst latency, you can use the state of an auxiliary I/O signal, adjust the frame count, or enable frame burst timeout.

To grab a group of sequential frames with one grab command (MdigGrab(), or one grab of MdigProcess()), grab into a multi-frame image buffer. To create such a buffer, allocate an image buffer with a height that is the product of the Y-size of an individual frame and the number of frames that will be grabbed into the buffer on each grab command. Then, set the number of frames to grab in the image buffer using MdigControl() with M\_GRAB\_GRAME\_BURST\_SIZE before calling the grab command.

<sup>\*.</sup> Frame burst is available when using modes with all the taps adjacent. For information or requests regarding other modes, please contact Zebra customer support.

### **Data conversion**

Data can be modified both before it is saved to on-board memory and as it is being transferred to the Host.

### Lookup tables

Zebra Rapixo CL has on-board lookup tables (LUTs) that can be used to precondition input data at acquisition time, before it is stored in memory.

There is one LUT palette available per acquisition path (CoaXPress connection) for 8- and 10-bit monochrome or color data; for color data, all color components map through the same LUT palette. For 12-bit monochrome or color data, all acquisition paths use the same palette; for color data, the same palette is used for all color components. For 14- and 16-bit data, a transparent LUT palette is used. The LUTs are programmed using the Aurora Imaging Library Lite function MdigControl() with M\_LUT\_ID.

### **Bayer color decoder**

As data from on-board memory is transmitted to the Host, it can pass through the Bayer color decoder. The Bayer color decoder converts Bayer color encoded images (GB, BG, GR, and RG pattern support) to multi-band RGB images using a 2x2 average demosaicing algorithm. The maximum line width for Bayer color conversion is 16 Kbytes.

### **Color space converter and image formatter**

As data from on-board memory or the Bayer color decoder is transmitted to the Host, is passes through the color space converter and image formatter. The color space converter and image formatter can convert data in the following ways:

• Subsampling. Image data can be subsampled.

The color space converter and image formatter can subsample in the horizontal and vertical directions by integer factors of 1 to 16. The color space converter and image formatter uses nearest-neighbor interpolation.

You can use any of the following Aurora Imaging Library Lite functions to subsample image data:

- MdigControl() with M\_GRAB\_SCALE\_X/Y and the subsampling factors.
- MimResize() with ScaleFactorX and ScaleFactorY set to the subsampling factors.
- MbufTransfer() with M\_COPY + M\_SCALE and setting the destination buffer size smaller than the original image.

Note that Zebra Rapixo CL does not support cropping in hardware. However, you can have image data cropped during transfer to Host using MdigControl() with M\_SOURCE\_SIZE\_X/Y and M\_SOURCE\_OFFSET\_X/Y.

- Flipping. Images can be flipped horizontally or vertically, using the Aurora Imaging Library Lite function MdigControl() with M\_GRAB\_DIRECTION\_X/Y or when calling MimFlip() from on-board buffer to Host.
- Color space conversion. The color space converter and image formatter formats an image based on its type and the bit-depth and color format of the destination buffer. You can set the bit depth and color format of the destination buffer when you allocate it using the Aurora Imaging Library Lite function MbufAlloc...(). The format of the source image is established in the DCF.

| Input format |                     |                      | Ou                      | tput forma               | ıt                      |                         |                         |                         |
|--------------|---------------------|----------------------|-------------------------|--------------------------|-------------------------|-------------------------|-------------------------|-------------------------|
|              | 8-bit<br>monochrome | 16-bit<br>monochrome | 24-bit<br>packed<br>BGR | 32-bit<br>packed<br>BGRa | 48-bit<br>packed<br>BGR | 16-bit<br>YUV<br>(YUYV) | 24-bit<br>RGB<br>planar | 48-bit<br>RGB<br>planar |
| 8-bit        | yes                 |                      | yes                     | yes                      |                         | yes                     | yes                     |                         |
| monochrome   |                     |                      |                         |                          |                         |                         |                         |                         |
| 16-bit       | yes                 | yes                  | yes                     | yes                      | yes                     | yes                     | yes                     | yes                     |
| monochrome   |                     |                      |                         |                          |                         |                         |                         |                         |
| 24-bit       | yes                 |                      | yes                     | yes                      |                         | yes                     | yes                     |                         |
| packed BGR   |                     |                      |                         |                          |                         |                         |                         |                         |
| 48-bit       | yes                 | yes                  | yes                     | yes                      | yes                     | yes                     | yes                     | yes                     |
| packed BGR   |                     |                      |                         |                          |                         |                         |                         |                         |

Image data can be converted as follows:

The equations for the YUV16 conversion are described in the following table. The value of *depth* is either 8 or 16 when converting BGR24 or BGR48 data, respectively. Note that while performing BGR48-to-YUV color space conversion, the operations are carried out on 16-bit data; then, each resulting YUV component is bit-shifted right by 8 bits ( >> (*depth* - 8) where the value of *depth* is 16).

| Color space conversion | Equations                                                          |
|------------------------|--------------------------------------------------------------------|
| BGR-to-YUV             | • Y = (0.114B + 0.587G +0.299R) >>(depth - 8)                      |
|                        | • U = $(0.500B - 0.331G - 0.169R + 2^{(depth-1)}) >>(depth - 8)$   |
|                        | • $V = (-0.081B - 0.419G + 0.500R + 2^{(depth-1)}) >> (depth - 8)$ |

## **Host interface**

The Zebra Rapixo CL PCIe 2.1 Host interface is capable of high-speed DMA transfers to Host memory, or other memory mapped onto the PCIe bus. The DMA write engine of the Host interface is capable of performing the transfers without the help of the Host CPU.

Zebra Rapixo CL uses PCIe 2.1 technology to communicate with the Host with up to a 256-byte payload (system dependent). The peak transfer rate is 2 Gbytes/sec<sup>\*</sup> in a 2.x slot with 4 active lanes.

DMA write performance is chipset and computer dependent, and is slightly affected by the image size and alignment in Host memory.

<sup>\*.</sup> Note that these are theoretical maximums. The actual maximum throughput is closer to 1.8 Gbytes/sec for CL DB and SF.

#### 54 Chapter 4: Zebra Rapixo CL hardware reference

# Appendix A: Glossary

This appendix defines some of the specialized terms used in the Zebra Rapixo CL documentation.

## Glossary

• Acquisition path.

A path that has the components to, for example, digitize or capture a video input signal. Some video sources require multiple acquisition paths.

• ASPM.

Active State Power Management. A hardware PCIe mechanism that autonomously controls power consumption of the PCIe connectors in a computer. The actual power consumed by a PCIe device depends on the PCIe traffic and on the power-saving level to which the PCIe slot is configured. The power-saving level of the PCIe slot is initialized by the operating system.

• Auxiliary I/O signals.

*Auxiliary input/output signals*. Non-video digital signals that can support one or more functionalities depending on the auxiliary signal (for example, trigger input or timer output).

### • Bandwidth.

A term describing the capacity to transfer data. Greater bandwidth is needed to sustain a higher transfer rate. Greater bandwidth can be achieved, for example, by using a wider bus or by increasing the clock frequency at which an interface or a processing core operates (for example, increasing the DDR3 SDRAM clock frequency).

• Camera Link.

A serial communication protocol standard designed for computer vision applications based on the National Semiconductor interface Channel-link. It was designed for the purpose of standardizing scientific and industrial video products including cameras, cables and frame grabbers.

### • Contiguous memory.

A block of memory occupying a single, unbroken series of addresses.

• DCF.

*Digitizer configuration format*. A format that defines how the video source and the frame grabber are configured. The video source and the frame grabber are set to the specified camera mode, which defines the format of transferred data. The DCF can also configure the triggers, timers, and quadrature decoders.

DCF files have a .dcf extension.

### • DDR3 SDRAM.

*Double-data-rate type 3 synchronous dynamic random-access memory.* A type of general purpose consumer RAM. DDR3 SDRAM allows for data transfer at very high speeds, which is important for I/O-bound functions. This type of memory is inexpensive, high density, and very efficient as long as the data is accessed contiguously.

• Digitizer configuration format.

See DCF.

• Dynamic range.

The range of values present in a buffer. An unsigned 8-bit buffer, for example, has an allowable range of 0 to 255; its dynamic range can be any range within these values.

• Exposure time.

Refers to the period during which the image sensor of a video source is exposed to light. As the length of this period increases, so does the image brightness.

• Frame.

A single image grabbed from a video source.

• Grab.

To acquire an image from a video source.

• Latency.

The time from when a command is sent to when its operation is started.

• Linear encoder.

A device that provides information about the linear position and direction of a moving sensor along a scale, either as an analog or digital code.

• LVDS.

*Low-voltage differential signaling*. LVDS offers a general-purpose, high bandwidth interface standard for serial and parallel data interfaces that require increased bandwidth at high speed, with low noise and power consumption.

• PCIe.

*Peripheral Component Interconnect Express.* The standard used for the computer bus that acts as an interface between hardware devices, such as Zebra Rapixo CL, and your computer.

• Payload.

The amount of data transmitted to the PCIe bus within each data packet. Common payload sizes are 128, 256, 512, 1024, 2048, and 4096 bytes.

• PoCL.

*Power-over-CameraLink*. Power-over-CameraLink is the term for power transmitted to a video source over a CameraLink cable using the CameraLink standard. Power can be provided to a video source, at up to 4.8 W per cable, at a nominal voltage of 12 V. An on-board fuse can sustain a current of 0.75 A.

• Quadrature decoder.

A device that decodes input received from a linear or rotary encoder with quadrature output.

### • Real-time processing.

The processing of an image at the same speed or faster than the speed at which images are grabbed. Real-time processing ensures that no frames are missed.

Also known as *live processing*.

### • Rotary encoder.

A device used to convert the angular position of a shaft or axle to an analog or digital code.

### • Timer output.

The signal generated by one of the programmable timers of the frame grabber. The timer output can be used to control external hardware. For example, it can be fed to the video source to control its exposure time or can be used to fire a strobe light.

#### 60 Appendix A: Glossary

# **Appendix B: Technical reference**

This appendix contains information that might be useful when installing your Zebra Rapixo CL board.

## **Board summary**

### **Global information**

- Operating system: See your software manual for supported versions of Microsoft Windows and Linux.
- Minimum computer requirements:
  - PCIe  $2.x \times 4 \operatorname{slot}^*$ .
  - Processor with an Intel 64-bit architecture, or equivalent.
  - A relatively up-to-date PCIe chipset. A chipset that supports the PCIe 2.x standard is preferable.
  - A proper power supply. Refer to the *Electrical specifications* section.

Zebra does not guarantee compatibility with all computers that have the above specifications. Please consult with your local Zebra representative, local Zebra sales office, the Zebra web site, or the Zebra Customer Support Group at headquarters before using a specific computer.

<sup>\*.</sup> Note that you can install Zebra Rapixo CL in any mechanical PCIe slot that fits your board (for example, connecting to open-ended connectors). The mechanical width of the connector does not always indicate the amount of electrically connected lanes it has. For example, you can install a x4 board in a PCIe x1 slot that has a mechanical x4 connector; however, the maximum transfer rate between Zebra Rapixo CL and the Host is reduced by 50%. Also, if you install it in a PCIe slot that is of an earlier version than the capabilities of the board, then the maximum bandwidth/transfer rate will also be affected.

### **Technical features of Zebra Rapixo CL boards**

- Has a PCIe 2.1 x4<sup>\*</sup> Host interface.
- Zebra Rapixo CL with DB firmware has two independent acquisition paths. Each acquisition path supports a video source in the Camera Link Base configuration.
- Zebra Rapixo CL with SF firmware has a single acquisition path that supports a video source in the Camera Link Medium, Full, or 80-bit configuration.
- Can provide power over Camera Link (PoCL) with SafePower. The PoCL protection on-board fuse can sustain a current of 0.75 A.
- Has four camera control signals (rerouting of specific auxiliary input signals, HSYNC output, VSYNC output, clock output, timer output, or user output) per acquisition path<sup>†</sup>.
- Supports Camera Link cables with a cable length up to 5 m at 85 MHz.
- Has up to 24 auxiliary signals that can be path independent or path dependent, depending on the functionality<sup>‡</sup> selected<sup>\*</sup>. When path dependent, there are:
  - Three TTL auxiliary I/O signals (trigger input or user input, or timer output or user output) per acquisition path.
  - One LVDS auxiliary output signal (timer output or user output) per acquisition path.
  - Two LVDS auxiliary input signals (trigger input, timer-clock input, quadrature input, or user input) per acquisition path.

‡. For example, for Zebra Rapixo CL DB, TTL\_AUX\_IO\_14 can be used as a trigger input when grabbing from acquisition path 0 or 1; however, you can only route timer 2 of acquisition path 1 to this signal.

<sup>\*.</sup> Be aware that if you install it in a PCIe slot that has less PCIe lanes or is of an earlier version than the capabilities of the board, then the maximum bandwidth transfer rate will be affected.

<sup>†.</sup> See the Camera control and auxiliary signals for Zebra Rapixo CL with DB firmware and Camera control and auxiliary signals for Zebra Rapixo CL with SF firmware sections in Chapter 4: Zebra Rapixo CL hardware reference chapter for supported functionality.

- Two opto-isolated auxiliary input signals (trigger input or user input) per acquisition path.
- Supports area-scan and line-scan video sources. The minimum and maximum number of pixels per line are 33 and 65535, respectively.
- Supports video sources with a Bayer color filter. Bayer color encoded images (GB, BG, GR, and RG pattern support) are converted to multi-band RGB images using a 2x2 average demosaicing algorithm. The maximum line width for Bayer color conversion is 16 Kbytes.
- Supports frame burst technology. This technology allows you to grab a group of sequential frames into a multi-frame image buffer with one grab command.
- Can convert 8- or 16-bit monochrome or 24- or 48-bit packed BGR data to monochrome, packed or planar BGR, packed BGRa, or YUV (YUYV) format.
- Can perform horizontal or vertical flipping.
- Can subsample image data by integer subsampling factors of 1 to 16.
- Supports external 5 V linear or rotary encoders with quadrature output, and frequencies of up to 50 MHz. Zebra Rapixo CL has one quadrature decoder for each acquisition path.
- Has a PoCL LED for each input connector, to identify whether the connector is receiving power. Zebra Rapixo CL DB and QB have four PoCL LEDs, Zebra Rapixo CL SF and DF have two, and Zebra Rapixo CL SB has one.
- Has five board status LEDs to indicate the status of each of the following: power, PCIe, FPGA configured, firmware type loaded.

## **Electrical specifications**

The following table describes the operating voltage and current for the different members of the Zebra Rapixo CL family.

| Operating voltage and curre | ent for Zebra Rapixo CL boards                                                                                                                                           |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Zebra Rapixo CL             | Max. PoCL per connector: 12.0 V, 400 mA: 4.8 W <sup>*</sup> (Current directly drawn from the slot. Power is not dissipated by the board; it is only used by the camera). |
|                             | Typical: 3.3 V, 1.4 A: 3.5 W                                                                                                                                             |
|                             | Typical 12.0 V, 1.0 A: 5.5 W                                                                                                                                             |
|                             | Total dissipated by the board: $3.5 \text{ W} + 5.5 \text{ W} = 9 \text{ W}$ (typical)                                                                                   |
|                             | Total dissipated by board and PoCL video sources = $9 \text{ W} + 9.6 \text{ W} = 18.6 \text{ W}$ (typical)                                                              |

\*. The PoCL protection fuse on Zebra Rapixo CL can sustain a current of 0.75 A.

The following table describes the specifications for the auxiliary I/O signals on Zebra Rapixo CL.

| I/O Specifications |                                                                                                                     |  |  |
|--------------------|---------------------------------------------------------------------------------------------------------------------|--|--|
| Minimum I/O jitter | +/- 8 ns, for any auxiliary input signal.                                                                           |  |  |
| Input signals in   | 100 Ohm differential termination.                                                                                   |  |  |
| LVDS format        | Input current: -10 μA (min) to +10 μA (max).                                                                        |  |  |
|                    | Common-mode: -4 V (min) to +5 V (max).                                                                              |  |  |
|                    | Differential input: 0.1 V (min) to $+3$ V (max).                                                                    |  |  |
|                    | Differential threshold: low of -50 mV (negative input voltage); high of +50 mV (positive input voltage).            |  |  |
| Output signals in  | No parallel termination.                                                                                            |  |  |
| LVDS format        | Output current: -10 μA to 10 μA.                                                                                    |  |  |
|                    | Output voltage: high (V <sub>oh</sub> ) 1.6 V (max), 1.33 V (typ); low (V <sub>ol</sub> ) 0.9 V (min), 1.02 V (typ) |  |  |
|                    | Differential output voltage (with load of 100 0hm): 250 mV (min) to 450 mV (max).                                   |  |  |
|                    | Offset voltage (common-mode): 1.125 V (min) to 1.375 V (max).                                                       |  |  |
|                    | Propagation delay: 2.8 ns (max).                                                                                    |  |  |
| Input signals in   | No series termination.Doc-10281                                                                                     |  |  |
| TTL format         | Pulled up to 3.3 V with 4.716 K Ohm.                                                                                |  |  |
|                    | Clamped to -0.7 V to +5.7 V.                                                                                        |  |  |
|                    | Input current: 5 $\mu$ A (max). Input voltage: low of 0.8 V (max); high of 2.0 V (min).                             |  |  |
| Output signals in  | 27 Ohm series termination.                                                                                          |  |  |
| TTL format         | High-level output current: -32 mA (max).                                                                            |  |  |
|                    | Low-level output current: +64 mA (max).                                                                             |  |  |
|                    | Output voltage: low of 0.55 V (max); high of 2.0 V (min).                                                           |  |  |
| Opto-coupled input | 511 Ohm series termination (connected on the anode inputs of the opto-coupler device).                              |  |  |
| signals*           | Input current: Iow: 250 µA (max); high: 5 mA (min (thresholded)) to 15 mA (max) (6.3 to 10 mA recommended).         |  |  |
|                    | Input voltage: low (V <sub>il</sub> ) of 0.8 V (max); high (V <sub>ih</sub> ) of 4.71 V (min) to 9.165 V (max).     |  |  |
|                    | Input forward voltage (at 25 degrees C): 1.3 V (min), 1.8 V (max).                                                  |  |  |
|                    | Propagation delay (at 25 degrees C): 100 ns (max).                                                                  |  |  |

\*. The Zebra Rapixo CL opto-couplers are manufactured by Agilent or Avago Technologies (P/N HCPL-0631).

## Dimensions and environmental specifications

- Dimensions from bottom edge of goldfinger to top edge of board. These values respect the dimensions of a PCIe half-length board:
  - Zebra Rapixo CL is a low profile board that comes with a full height bracket: 167.65mm (L) x 111.15 mm (H) from bottom edge of goldfinger to top edge of board (6.6" x 4.37").
- Ventilation: 150 LFM between boards.
- Minimum/maximum ambient operating temperature: 0°C to 55°C (32°F to 131°F).
- Minimum/maximum storage temperature: -40°C to 75°C (-40°F to 167°F).
- Operating relative humidity: up to 95% relative humidity (non-condensing).
- Storage humidity: up to 95% relative humidity (non-condensing).

## **Connectors on Zebra Rapixo CL boards**

On the Zebra Rapixo CL board, there are two Camera Link video input connectors and an auxiliary I/O connector.



On the Zebra Rapixo CL cable adapter bracket, there are two HD-15 auxiliary I/O connectors; this allows you to access the signals of the internal auxiliary I/O connector from outside the computer enclosure. See the *External auxiliary I/O connectors* section below for information on how to connect these adapter brackets.



### **Camera Link video input connectors**

The Camera Link video input connectors are 26-pin female mini Camera Link connectors. They are used to receive video input, timing, and synchronization signals and transmit/receive communication signals between the video source and the frame grabber.



The pinout of the Camera Link video input connectors depends on the firmware configuration of Zebra Rapixo CL. The pinout of these connectors follows the Camera Link standard.

Zebra Rapixo CL DB On Zebra Rapixo CL in DB configuration, each Camera Link connector supports one video source in Base configuration, and has the same pinout; this pinout is listed in the following table.

| Pin     | Hardware signal<br>name | Aurora Imaging<br>Library constant<br>for auxiliary signal | Description                                                                                                                                                                                                                                                          |
|---------|-------------------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1       | Inner shield            |                                                            | Ground (inner shield), or +12V to camera in PoCL mode.                                                                                                                                                                                                               |
| 3+,16-  | CC3                     | M_CC_103                                                   | Camera control output 3 for acquisition path n, which supports: timer output (M_TIMER1/M_TIMER2 on M_DEVn), user output (M_USER_BIT_CC_I00/M_USER_BIT_CC_I01 on M_DEVn), VSYNC, HSYNC, clock output, or rerouting of specific auxiliary input signals <sup>*</sup> . |
| 5+,18-  | CC1                     | M_CC_I01                                                   | Camera control output 1 for acquisition path n, which supports: timer output (M_TIMER1/M_TIMER2 on M_DEVn), user output (M_USER_BIT_CC_IO0/M_USER_BIT_CC_IO1 on M_DEVn), VSYNC, HSYNC, clock output, or rerouting of specific auxiliary input signals <sup>†</sup> . |
| 6+,19-  | SerTFG                  |                                                            | Serial port to frame grabber (UART).                                                                                                                                                                                                                                 |
| 8+,21-  | X3                      |                                                            | Video input data X3.                                                                                                                                                                                                                                                 |
| 9+,22-  | Xclk                    |                                                            | Clock input X.                                                                                                                                                                                                                                                       |
| 10+,23- | X2                      |                                                            | Video input data X2.                                                                                                                                                                                                                                                 |
| 11+,24- | X1                      |                                                            | Video input data X1.                                                                                                                                                                                                                                                 |
| 12+,25- | X0                      |                                                            | Video input data X0.                                                                                                                                                                                                                                                 |
| 13      | Inner shield            |                                                            | Ground.                                                                                                                                                                                                                                                              |
| 14      | Inner shield            |                                                            | Ground.                                                                                                                                                                                                                                                              |
| 15+,2-  | CC4                     | M_CC_104                                                   | Camera control output 4 for acquisition path n, which supports: timer output (M_TIMER1/M_TIMER2 on M_DEVn), user output (M_USER_BIT_CC_IO0/M_USER_BIT_CC_IO1 on M_DEVn), VSYNC, HSYNC, clock output, or rerouting of specific auxiliary input signals <sup>†</sup> . |
| 17+,4-  | CC2                     | M_CC_102                                                   | Camera control output 2 for acquisition path n, which supports: timer output (M_TIMER1/M_TIMER2 on M_DEVn), user output (M_USER_BIT_CC_I00/M_USER_BIT_CC_I01 on M_DEVn), VSYNC, HSYNC, clock output, or rerouting of specific auxiliary input signals <sup>†</sup> . |
| 20+,7-  | SerTC                   |                                                            | Serial port to video source (UART).                                                                                                                                                                                                                                  |
| 26      | Inner shield            |                                                            | Ground (inner shield), or +12V to camera in PoCL mode.                                                                                                                                                                                                               |

\*. See the table in the Auxiliary signals section of Chapter 4: Zebra Rapixo CL hardware reference for more information on which auxiliary input signals (or auxiliary I/O signals set to input) can be rerouted onto the camera control output signals. Also note that for Zebra Rapixo CL in DB configuration, n should be replaced by the number of the

Camera Link connector to which the video source is connected.

**Zebra Rapixo CL SF** On Zebra Rapixo CL in SF configuration, the two Camera Link connectors are treated as a pair (0-1). The Camera link connector pair can connect one video source in Medium, Full, or 80-bit configuration. The connector pair uses a single acquisition path. In Aurora Imaging Library, the (0-1) connector pair uses acquisition path 0 (M\_DEV0). The top Camera Link connector of the pair has the pinout described above (except replace n with 0), while the bottom Camera Link connector of the pair has the following pinout.

### Warning

When connecting a video source in Medium, Full, or 80-bit configuration, ensure that you are connecting its cables to the appropriate connector. Accidentally connecting the cables to the wrong connector can damage the board or your video source. Pins 2-5 and pins 15-18 are output pins on the top connector (0 and 1), while they are input pins on the bottom connector 1.

| Pin      | Hardware signal name | Description                                              |
|----------|----------------------|----------------------------------------------------------|
| 1        | GND or PWR_OUT       | Ground (inner shield), or $+12V$ to camera in PoCL mode. |
| 2+, 15-  | Z3                   | Video input data Z3.*                                    |
| 3+, 16-  | Zclk                 | Clock input Z.*                                          |
| 4+, 17-  | Z2                   | Video input data Z2.*                                    |
| 5+, 18-  | Z1                   | Video input data Z1.*                                    |
| 6+, 19-  | Z0                   | Video input data Z0.*                                    |
| 7        | terminated           | Unused.*                                                 |
| 8+, 21-  | Y3                   | Video input data Y3.                                     |
| 9+, 22-  | Yclk                 | Clock input Y.                                           |
| 10+, 23- | Y2                   | Video input data Y2.                                     |
| 11+, 24- | Y1                   | Video input data Y1.                                     |
| 12+, 25- | Y0                   | Video input data Y0.                                     |
| 13       | Inner shield         | Ground.                                                  |
| 14       | Inner shield         | Ground.                                                  |
| 20       | 100 Ω                | Unused.*                                                 |
| 26       | GND or PWR_OUT       | Ground (inner shield), or +12V to camera in PoCL mode.   |

\*. When the board is set to the Medium configuration, these pins are reserved.

To interface with the above connectors, use a standard Camera Link cable with a 26-pin male mini Camera Link connector (HDR or SDR) at one end. You can purchase such a cable from your video source manufacturer, Components Express inc., 3M Interconnect Solutions for Factory Automation, Intercon 1, or other third parties. Note that this cable is not available from Zebra.

If using both Camera Link connectors to connect to the same video source (Medium configuration or Full configuration), the cables you choose should be of the same type and length. Note, however, if they are not, Zebra Rapixo CL will adapt to any delay caused by reasonable differences in length.

### **External auxiliary I/O connectors**

The external auxiliary I/O connectors on the Zebra Rapixo CL bracket and the cable adapter bracket are high-density D-subminiature 15-pin (HD-15<sup>\*</sup>) male connectors.

The auxiliary I/O connectors on Zebra Rapixo CL are not compatible with display devices. Connecting one of the HD-15 connectors on Zebra Rapixo CL to a VGA monitor or any other display device might damage both the device and the Zebra Rapixo CL board.



The dual HD-15 connector must be connected to the 32-pin internal connector. On the cable adapter bracket, the connectors are panel mount connectors.

The auxiliary signals can be path independent or path dependent, depending on the functionality selected. For more information, see the *Camera control and auxiliary signals for Zebra Rapixo CL with DB firmware* and *Camera control and auxiliary signals for Zebra Rapixo CL with SF firmware* sections in *Chapter 4: Zebra Rapixo CL hardware reference* for supported functionality.

<sup>\*.</sup> Sometimes referred to as DB-15, but more accurately known as DE-15.

# Pinouts for auxiliary I/O connectors of Zebra Rapixo CL in DB configuration

The pinout for auxiliary I/O connector A is as follows for Zebra Rapixo CL in DB configuration.

| Pin on<br>HD-15 | Hardware signal<br>name | Aurora<br>Imaging<br>Library<br>constant for<br>auxiliary<br>signal | Digitizer<br>device<br>number for<br>auxiliary<br>signal | Description                                                                                                                                                                                                                                                                                          |
|-----------------|-------------------------|---------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | TTL_AUX_IO_4            | M_AUX_IO8                                                           | M_DEV0                                                   | TTL auxiliary signal (input/output) for acquisition path 0, which supports: user input, user output (M_USER_BIT2 on M_DEV0), trigger input (trigger controller 0 on acq path 0).                                                                                                                     |
| 2               | TTL_AUX_IO_5            | M_AUX_109                                                           | M_DEV0                                                   | TTL auxiliary signal (input/output) for acquisition path 0, which supports: timer output (M_TIMER1 on M_DEV0), trigger input (trigger controller 1 on acq path 0), user input, or user output (M_USER_BIT3 on M_DEV0).                                                                               |
| 3               | TTL_AUX_IO_6            | M_AUX_102                                                           | M_DEV0/<br>M_DEV1                                        | TTL auxiliary signal (input/output), shared between acquisition paths 0 and 1 for trigger input (trigger control 2 on acq path 0; 2 on acq path 1 <sup>*</sup> ), user input, user output (M_USER_BIT4 on M_DEV0/M_DEV1), and dedicated to acquisition path 0 for timer output (M_TIMER2 on M_DEV0). |
| 4+,5-           | LVDS_AUX_IN2            | M_AUX_IO10                                                          | M_DEV0                                                   | LVDS auxiliary signal (input) for acquisition path 0, which supports: trigger input (trigger controller 0 on acq path 0), user input, or quadrature input bit 0.                                                                                                                                     |
| 6+,8-           | LVDS_AUX_IN3            | M_AUX_I011                                                          | M_DEV0                                                   | LVDS auxiliary signal (input) for acquisition path 0, which supports: user input, trigger input (trigger controller 1 on acq path 0), timer-clock input, or quadrature input bit 1.                                                                                                                  |
| 7               | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                                                                                                                                              |
| 10              | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                                                                                                                                              |
| 12+,11-         | OPTO_AUX_IN1            | M_AUX_I07                                                           | M_DEV0                                                   | Opto-isolated auxiliary signal (input) for acquisition path 0, which supports: user input or trigger input (trigger controller 1 on acq path 0).                                                                                                                                                     |
| 13+,14-         | LVDS_AUX_OUT7           | M_AUX_I012                                                          | M_DEV0                                                   | LVDS auxiliary signal (output) for acquisition path 0, which supports: timer output (M_TIMER1/M_TIMER2 on M_DEV0) or user output (M_USER_BIT0 on M_DEV0).                                                                                                                                            |
| 15+,9-          | OPTO_AUX_IN0            | M_AUX_IO6                                                           | M_DEV0                                                   | Opto-isolated auxiliary signal (input) for acquisition path 0, which supports: user input or trigger input (trigger controller 0 on acq path 0).                                                                                                                                                     |

\*. Trigger controller 2 on acq path 1 is only supported on Zebra Rapixo CL DB (for hardware signal TTL\_AUX\_I0\_6).

The pinout for auxiliary I/O connector C is as follows for Zebra Rapixo CL in DB configuration. It can be accessed through an HD-15 connector using the adapter bracket.

| Pin on<br>HD-15 | Hardware signal<br>name | Aurora<br>Imaging<br>Library<br>constant for<br>auxiliary<br>signal | Digitizer<br>device<br>number for<br>auxiliary<br>signal | Description                                                                                                                                                                                                                                                                               |
|-----------------|-------------------------|---------------------------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | TTL_AUX_IO_12           | M_AUX_108                                                           | M_DEV1                                                   | TTL auxiliary signal (input/output) for acquisition path 1, which supports:<br>user input, user output (M_USER_BIT2 on M_DEV1), or trigger input<br>(trigger controller 0 on acq path 1).                                                                                                 |
| 2               | TTL_AUX_IO_13           | M_AUX_109                                                           | M_DEV1                                                   | TTL auxiliary signal (input/output) for acquisition path 1, which supports: timer output (M_TIMER1 on M_DEV1), trigger input (trigger controller 1 on acq path 1), user input, or user output (M_USER_BIT3 on M_DEV1).                                                                    |
| 3               | TTL_AUX_IO_14           | M_AUX_I03                                                           | M_DEV0/<br>M_DEV1                                        | TTL auxiliary signal (input/output), shared between acquisition paths 0 and 1 for trigger input (trigger controller 3 on acq path 0; 3 on acq path 1), user input, user output (M_USER_BIT5 on M_DEV0/M_DEV1), and dedicated to acquisition path 1 for timer output (M_TIMER2 on M_DEV1). |
| 4+,5-           | LVDS_AUX_IN10           | M_AUX_I04                                                           | M_DEV0/<br>M_DEV1                                        | LVDS auxiliary signal (input), shared between acquisition paths 0 and 1 for trigger input (trigger controller 2 on acq path 0; 2 or 0 on acq path 1) or user input, and dedicated to acquisition path 1 for quadrature input bit 0.                                                       |
| 6+,8-           | LVDS_AUX_IN11           | M_AUX_105                                                           | M_DEV0/<br>M_DEV1                                        | LVDS auxiliary signal (input), shared between acquisition paths 0 and 1 for trigger input (trigger controller 1 or 3 on acq path 1; 3 on acq path 0) or user input, and dedicated to acquisition path 1 for timer-clock input or quadrature input bit 1.                                  |
| 7               | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                                                                                                                                   |
| 10              | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                                                                                                                                   |
| 12+,11-         | OPTO_AUX_IN9            | M_AUX_I01                                                           | M_DEV0/<br>M_DEV1                                        | Opto-isolated auxiliary signal (input), shared between acquisition paths 0 and 1 for trigger input (trigger controller 1 or 3 on acq path 1; 3 on acq path 0) or user input.                                                                                                              |
| 13+,14-         | LVDS_AUX_OUT15          | M_AUX_I012                                                          | M_DEV1                                                   | LVDS auxiliary signal (output) for acquisition path 1, which supports:<br>timer output (M_TIMER1/M_TIMER2 on M_DEV1) or user output<br>(M_USER_BIT0 on M_DEV1).                                                                                                                           |
| 15+,9-          | OPTO_AUX_IN8            | M_AUX_IO0                                                           | M_DEV0/<br>M_DEV1                                        | Opto-isolated auxiliary signal (input), shared between acquisition paths 0 and 1 for trigger input (trigger controller 0 or 2 on acq path 1; 2 on acq path 0) or user input.                                                                                                              |
| -               | NC                      |                                                                     |                                                          | Not connected.                                                                                                                                                                                                                                                                            |
|                 |                         |                                                                     |                                                          |                                                                                                                                                                                                                                                                                           |

The pinout for auxiliary I/O connector D is as follows for Zebra Rapixo CL in DB configuration. It can be accessed through an HD-15 connector using the adapter bracket.

| Pin on<br>HD-15 | Hardware signal<br>name | Aurora<br>Imaging<br>Library<br>constant for<br>auxiliary<br>signal | Digitizer<br>device<br>number for<br>auxiliary<br>signal | Description                                                                                                                                                                                                                                                                               |
|-----------------|-------------------------|---------------------------------------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | TTL_AUX_IO_28           | M_AUX_IO8                                                           | M_DEV3                                                   | TTL auxiliary signal (input/output) for acquisition path 3, which supports:<br>user input, user output (M_USER_BIT2 on M_DEV3), or trigger input<br>(trigger controller 0 on acq path 3).                                                                                                 |
| 2               | TTL_AUX_I0_29           | M_AUX_IO9                                                           | M_DEV3                                                   | TTL auxiliary signal (input/output) for acquisition path 3, which supports: timer output (M_TIMER1 on M_DEV3), trigger input (trigger controller 1 on acq path 3), user input, or user output (M_USER_BIT3 on M_DEV3).                                                                    |
| 3               | TTL_AUX_IO_30           | M_AUX_103                                                           | M_DEV2/<br>M_DEV3                                        | TTL auxiliary signal (input/output), shared between acquisition paths 2 and 3 for trigger input (trigger controller 3 on acq path 2; 3 on acq path 3), user input, user output (M_USER_BIT5 on M_DEV2/M_DEV3), and dedicated to acquisition path 3 for timer output (M_TIMER2 on M_DEV3). |
| 4+,5-           | LVDS_AUX_IN26           | M_AUX_IO4                                                           | M_DEV2/<br>M_DEV3                                        | LVDS auxiliary signal (input), shared between acquisition paths 2 and 3 for trigger input (trigger controller 0 or 2 on acq path 3; 2 on acq path 2) or user input, and dedicated to acquisition path 3 for quadrature input bit 0.                                                       |
| 6+,8-           | LVDS_AUX_IN27           | M_AUX_I05                                                           | M_DEV2/<br>M_DEV3                                        | LVDS auxiliary signal (input), shared between acquisition paths 2 and 3 for trigger input (trigger controller 1 or 3 on acq path 3; 3 on acq path 2) or user input, and dedicated to acquisition path 3 for timer-clock input or quadrature input bit 1.                                  |
| 7               | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                                                                                                                                   |
| 10              | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                                                                                                                                   |
| 12+,11-         | OPTO_AUX_IN25           | M_AUX_IO1                                                           | M_DEV2/<br>M_DEV3                                        | Opto-isolated auxiliary signal (input), shared between acquisition paths 2<br>and 3 for trigger input (trigger controller 1 or 3 on acq path 3; 3 on acq<br>path 2) or user input.                                                                                                        |
| 13+,14-         | LVDS_AUX_OUT31          | M_AUX_I012                                                          | M_DEV3                                                   | LVDS auxiliary signal (output) for acquisition path 3, which supports: timer output (M_TIMER1/M_TIMER2 on M_DEV3) or user output (M_USER_BIT0 on M_DEV3).                                                                                                                                 |
| 15+,9-          | OPTO_AUX_IN24           | M_AUX_IO0                                                           | M_DEV2/<br>M_DEV3                                        | Opto-isolated auxiliary signal (input), shared between acquisition paths 2<br>and 3 for trigger input (trigger controller 0 or 2 on acq path 3; 2 on acq<br>path 2) or user input.                                                                                                        |
|                 | NC                      |                                                                     |                                                          | Not connected.                                                                                                                                                                                                                                                                            |

# Pinouts for auxiliary I/O connectors of Zebra Rapixo CL in SF configuration

The pinout for auxiliary I/O connector A is as follows for Zebra Rapixo CL in SF configuration.

| Pin on<br>HD-15 | Hardware signal<br>name | Aurora<br>Imaging<br>Library<br>constant for<br>auxiliary<br>signal | Digitizer<br>device<br>number for<br>auxiliary<br>signal | Description                                                                                                                                                                                                                 |
|-----------------|-------------------------|---------------------------------------------------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | TTL_AUX_IO_4            | M_AUX_I08                                                           | M_DEV0                                                   | TTL auxiliary signal (input/output) for acquisition path 0, which supports:<br>user input, user output (M_USER_BIT2 on M_DEV0), trigger input (trigger<br>controller 0 on acq path 0).                                      |
| 2               | TTL_AUX_IO_5            | M_AUX_109                                                           | M_DEV0                                                   | TTL auxiliary signal (input/output) for acquisition path 0, which supports: timer output (M_TIMER1 on M_DEV0), trigger input (trigger controller 1 on acq path 0), user input, or user output (M_USER_BIT3 on M_DEV0).      |
| 3               | TTL_AUX_IO_6            | M_AUX_I02                                                           | M_DEV0                                                   | TTL auxiliary signal (input/output), for acquisition paths 0, which supports:<br>trigger input (trigger control 2 on acq path 0), user input, user output<br>(M_USER_BIT4 on M_DEV0), or timer output (M_TIMER2 on M_DEV0). |
| 4+,5-           | LVDS_AUX_IN2            | M_AUX_I010                                                          | M_DEV0                                                   | LVDS auxiliary signal (input) for acquisition path 0, which supports: trigger input (trigger controller 0 on acq path 0), user input, or quadrature input bit 0.                                                            |
| 6+,8-           | LVDS_AUX_IN3            | M_AUX_I011                                                          | M_DEV0                                                   | LVDS auxiliary signal (input) for acquisition path 0, which supports: user input, trigger input (trigger controller 1 on acq path 0), timer-clock input, or quadrature input bit 1.                                         |
| 7               | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                                                                     |
| 10              | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                                                                     |
| 12+,11-         | OPTO_AUX_IN1            | M_AUX_IO7                                                           | M_DEV0                                                   | Opto-isolated auxiliary signal (input) for acquisition path 0, which supports: user input or trigger input (trigger controller 1 on acq path 0).                                                                            |
| 13+,14-         | LVDS_AUX_OUT7           | M_AUX_I012                                                          | M_DEV0                                                   | LVDS auxiliary signal (output) for acquisition path 0, which supports: timer output (M_TIMER1/M_TIMER2 on M_DEV0) or user output (M_USER_BIT0 on M_DEV0).                                                                   |
| 15+,9-          | OPTO_AUX_INO            | M_AUX_IO6                                                           | M_DEV0                                                   | Opto-isolated auxiliary signal (input) for acquisition path 0, which supports: user input or trigger input (trigger controller 0 on acq path 0).                                                                            |

The pinout for auxiliary I/O connector C is as follows for Zebra Rapixo CL in SF configuration. It can be accessed through an HD-15 connector using the adapter bracket.

| Pin on<br>HD-15 | Hardware signal<br>name | Aurora<br>Imaging<br>Library<br>constant for<br>auxiliary<br>signal | Digitizer<br>device<br>number for<br>auxiliary<br>signal | Description                                                                                                                                                                          |
|-----------------|-------------------------|---------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | RESERVED                |                                                                     |                                                          | Reserved. Do not connect.                                                                                                                                                            |
| 2               | RESERVED                |                                                                     |                                                          | Reserved. Do not connect.                                                                                                                                                            |
| 3               | TTL_AUX_IO_14           | M_AUX_103                                                           | M_DEV0                                                   | TTL auxiliary signal (input/output), for acquisition path 0, which supports: trigger input (trigger controller 3 on acq path 0), user input, or user output (M_USER_BIT5 on M_DEV0). |
| 4+,5-           | LVDS_AUX_IN10           | M_AUX_IO4                                                           | M_DEV0                                                   | LVDS auxiliary signal (input), for acquisition path 0, which supports: trigger input (trigger controller 2 on acq path 0) or user input.                                             |
| 6+,8-           | LVDS_AUX_IN11           | M_AUX_I05                                                           | M_DEV0                                                   | LVDS auxiliary signal (input), for acquisition path 0, which supports: trigger input (trigger controller 3 on acq path 0) or user input.                                             |
| 7               | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                              |
| 10              | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                              |
| 12+,11-         | OPTO_AUX_IN9            | M_AUX_I01                                                           | M_DEV0                                                   | Opto-isolated auxiliary signal (input), for acquisition path 0,which supports:<br>trigger input (trigger controller 3 on acq path 0) or user input.                                  |
| 13              | RESERVED                |                                                                     |                                                          | Reserved. Do not connect.                                                                                                                                                            |
| 14              | RESERVED                |                                                                     |                                                          | Reserved. Do not connect.                                                                                                                                                            |
| 15+,9-          | OPTO_AUX_IN8            | M_AUX_100                                                           | M_DEV0                                                   | Opto-isolated auxiliary signal (input), for acquisition path 0, which supports: trigger input (trigger controller 2 on acq path 0) or user input.                                    |
| -               | NC                      |                                                                     |                                                          | Not connected.                                                                                                                                                                       |

The pinout for auxiliary I/O connector D is as follows for Zebra Rapixo CL in DF configuration. It can be accessed through an HD-15 connector using the adapter bracket.

| Pin on<br>HD-15 | Hardware signal<br>name | Aurora<br>Imaging<br>Library<br>constant for<br>auxiliary<br>signal | Digitizer<br>device<br>number for<br>auxiliary<br>signal | Description                                                                                                                                                                          |
|-----------------|-------------------------|---------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1               | RESERVED                |                                                                     |                                                          | Reserved. Do not connect.                                                                                                                                                            |
| 2               | RESERVED                |                                                                     |                                                          | Reserved. Do not connect.                                                                                                                                                            |
| 3               | TTL_AUX_IO_30           | M_AUX_103                                                           | M_DEV1                                                   | TTL auxiliary signal (input/output), for acquisition path 1, which supports: trigger input (trigger controller 3 on acq path 1), user input, or user output (M_USER_BIT5 on M_DEV1). |
| 4+,5-           | LVDS_AUX_IN26           | M_AUX_IO4                                                           | M_DEV1                                                   | LVDS auxiliary signal (input), for acquisition path 1, which supports: trigger input (trigger controller 2 on acq path 1) or user input.                                             |
| 6+,8-           | LVDS_AUX_IN27           | M_AUX_I05                                                           | M_DEV1                                                   | LVDS auxiliary signal (input), for acquisition path 1, which supports: trigger input (trigger controller 3 on acq path 1) or user input.                                             |
| 7               | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                              |
| 10              | GND                     | N/A                                                                 | N/A                                                      | Ground.                                                                                                                                                                              |
| 12+,11-         | OPTO_AUX_IN25           | M_AUX_I01                                                           | M_DEV1                                                   | Opto-isolated auxiliary signal (input), for acquisition path 1, which supports: trigger input (trigger controller 3 on acq path 1) or user input.                                    |
| 13              | RESERVED                |                                                                     |                                                          | Reserved. Do not connect.                                                                                                                                                            |
| 14              | RESERVED                |                                                                     |                                                          | Reserved. Do not connect.                                                                                                                                                            |
| 15+,9-          | OPTO_AUX_IN24           | M_AUX_IO0                                                           | M_DEV1                                                   | Opto-isolated auxiliary signal (input), for acquisition path 1, which supports: trigger input (trigger controller 2 on acq path 1) or user input.                                    |
| -               | NC                      |                                                                     |                                                          | Not connected.                                                                                                                                                                       |

To build your own cable, you can purchase the following parts:

|               | Mating information |
|---------------|--------------------|
| Manufacturer: | NorComp, Inc.      |
| Connector:    | 180-015-203L001    |
| Backshell:    | 970-015-010-011    |

These parts can be purchased from third parties such as Digi-Key Corporation (www.digikey.com).

### **LEDs on Zebra Rapixo CL**

Zebra Rapixo CL has a series of LEDs to display the status of the PoCL connections, the on-board power, the board configuration, the PCIe (Host) slot, and the firmware configuration.

#### PoCL LEDs

The Zebra Rapixo CL board has two PoCL LEDs. Each LED indicates the status of the PoCL device attached to that connector.

| LED color and state | Description                                             |
|---------------------|---------------------------------------------------------|
| Off                 | Zebra Rapixo CL is not providing power to the camera.   |
| Red, solid          | Zebra Rapixo CL is sensing for a PoCL-compliant device. |
| Green, solid        | Zebra Rapixo CL is providing power to the camera.       |

#### **Board status LEDs**

Zebra Rapixo CL main board has five additional status LEDs to indicate the status of each of the following: the firmware configuration, the FPGA configuration, the power, and PCIe (Host) slot.



| LED type      | LED color and state | Description                                                                                                                               |
|---------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 3. Power      | Off/Red             | One or more of the on-board voltage regulators did not start.                                                                             |
|               |                     | If your computer is on and this LED state occurs, there is an issue<br>with the voltage regulators on your Zebra Rapixo CL. Contact Zebra |
|               | Green               | All of the on-board voltage regulators are working properly.                                                                              |
| 4. FPGA       | Green               | The FPGA is configured.                                                                                                                   |
| configuration | Red                 | The FPGA is not configured.                                                                                                               |
| 5.Firmware    | Off                 | The board is configured with the recommended user's firmware.                                                                             |
| configuration | Red                 | The board is configured with the golden firmware (a fall-back configuration).                                                             |
| 6. PCIe slot  | Off                 | The type of slot cannot be established. The PCIe link is down.                                                                            |
|               | Red, solid          | Slot is PCIe Gen 1 and all lanes are in use.                                                                                              |
|               | Red, blinking       | Slot is PCIe Gen 1 and less than the maximum lanes are in use.                                                                            |
|               | Orange, solid       | Slot is PCIe Gen 2 and all lanes are in use.                                                                                              |
|               | Orange, blinking    | Slot is PCIe Gen 2 and less than the maximum lanes are in use.                                                                            |
| 7. DB or SF   | Red                 | The Zebra Rapixo CL board has DB configuration firmware installed.                                                                        |
| configuration | Green               | The Zebra Rapixo CL board has SF configuration firmware installed.                                                                        |

The table below outlines the possible colors for each LED, and their definitions.

# Appendix C: Acknowledgments

This appendix lists the copyright information regarding third-party material used to implement components on the Zebra Rapixo CL board.

### **UART** copyright information

The following is the copyright notice for the UART design used on the Zebra Rapixo CL boards.

Copyright © 2002 Daniel Wallner (jesus@opencores.org)

All rights reserved.

Redistribution and use in source and synthesized forms, with or without modification, are permitted provided that the following conditions are met:

Redistributions of source code must retain the above copyright notice, this list of conditions, and the following disclaimer.

Redistributions in synthesized form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

Neither the name of the author nor the names of other contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

# Appendix D: Listing of Zebra Rapixo CL boards

This appendix lists the key feature changes to the Zebra Rapixo CL boards.

## Key feature changes

| Part number | Version | Description                                |  |
|-------------|---------|--------------------------------------------|--|
| RAP5MCL     | 101     | First shipping version of Zebra Rapixo CL. |  |



zebra.com