## LogiCORE IP YCrCb to RGB Color-Space Converter 4.0

**Product Guide** 

PG014 October 19, 2011



### **Table of Contents**

| Chapter 1: Overview                                        |
|------------------------------------------------------------|
| Applications                                               |
| Licensing                                                  |
| Performance                                                |
| <b>Resource Utilization</b>                                |
| Chapter 2: Core Interfaces and Register Space              |
| Core Symbol and Port Descriptions                          |
| Control Signals and Timing                                 |
|                                                            |
| Chapter 3: Customizing and Generating the Core             |
| Graphical User Interface (GUI) 14                          |
| Parameter Values in the XCO File 16                        |
| Output Generation 17                                       |
| Chapter 4: Designing with the Core                         |
| <b>RGB Color Space</b>                                     |
| <b>R'G'B' Color Space</b> 19                               |
| YUV Color Space         20                                 |
| YCrCb (or YCbCr) Color Space                               |
| Conversion Equations                                       |
| Clipping and Clamping                                      |
| Clocking                                                   |
| Resets                                                     |
| Chapter 5: Constraining the Core                           |
| Required Constraints                                       |
| <b>A</b>                                                   |
| Device, Package, and Speed Grade Selections                |
| Clock Frequencies                                          |
| Clock Management       26         Clock Placement       26 |
|                                                            |
| Banking.    26      Transceiver Placement    26            |
| I/O Standard and Placement                                 |
|                                                            |
| Chapter 6: Detailed Example Design                         |
| Demonstration Test Bench 27                                |

| Appendix A: Verification, Compliance, and Interoperability |
|------------------------------------------------------------|
| Simulation                                                 |
| Appendix B: Debugging                                      |
| Evaluation Core Timeout 30                                 |
| Appendix C: C Model Reference                              |
| <b>Features</b>                                            |
| <b>Overview</b>                                            |
| Unpacking and Model Contents 32                            |
| Installation                                               |
| Software Requirements                                      |
| Input and Output Video Structures                          |
| Initializing the Input Video Structure                     |
| C Model Example Code 37                                    |
| Appendix D: Additional Resources                           |
| Xilinx Resources                                           |
| Solution Centers                                           |
| <b>References</b>                                          |
| Technical Support 30                                       |

| References              |  |
|-------------------------|--|
| Technical Support       |  |
| Ordering Information    |  |
| <b>Revision History</b> |  |
| Notice of Disclaimer    |  |

# 

#### LogiCORE IP YCrCb to RGB Color-Space Converter v4.0 Product Guide

#### Introduction

The YCrCb to RGB Color-Space Converter is a simplified 3x3 matrix multiplier converting three input color samples to three output samples in a single clock cycle. The optimized structure uses only four XtremeDSP<sup>™</sup> slices by taking advantage of the dependencies between coefficients in the conversion matrix of most YCrCb or YUV to RGB standards.

#### Features

- Built in support for:
  - SD (ITU 601)
  - HD (*ITU 709*) PAL
  - HD (*ITU 709*) NTSC
  - YUV
- Support for user-defined conversion matrices
- Efficient use of DSP blocks
- 8-, 10-, and 12-bit input and output precision
- Delay match support for up to three sync signals

|                                              | LogiCORE IP Facts Table                                                                                                                   |  |  |  |  |
|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                              | Core Specifics                                                                                                                            |  |  |  |  |
| Supported<br>Device<br>Family <sup>(1)</sup> | Virtex $^{\ensuremath{\mathbb R}\xspace}$ -7, Virtex $^{\ensuremath{\mathbb R}\xspace}$ -6, Spartan $^{\ensuremath{\mathbb R}\xspace}$ -6 |  |  |  |  |
| Supported User<br>Interfaces                 | Constant Interface                                                                                                                        |  |  |  |  |
| Resources                                    | See Table 1-1 through Table 1-4.                                                                                                          |  |  |  |  |
|                                              | Provided with Core                                                                                                                        |  |  |  |  |
| Documentation                                | Product Specification                                                                                                                     |  |  |  |  |
| Design Files                                 | Netlists                                                                                                                                  |  |  |  |  |
| Example<br>Design                            | Not Provided                                                                                                                              |  |  |  |  |
| Test Bench                                   | VHDL <sup>(2)</sup>                                                                                                                       |  |  |  |  |
| Constraints File                             | Not Provided                                                                                                                              |  |  |  |  |
| Simulation<br>Models                         | VHDL and Verilog Structural, C Model <sup>(2)</sup>                                                                                       |  |  |  |  |
|                                              | Tested Design Tools                                                                                                                       |  |  |  |  |
| Design Entry<br>Tools                        | CORE Generator <sup>™</sup> tool, Platform Studio (XPS)                                                                                   |  |  |  |  |
| Simulation <sup>(3)</sup>                    | Mentor Graphics ModelSim, Xilinx <sup>®</sup> ISim 13.3                                                                                   |  |  |  |  |
| Synthesis Tools                              | Xilinx Synthesis Technology (XST) 13.3                                                                                                    |  |  |  |  |
| Support                                      |                                                                                                                                           |  |  |  |  |
| Provided by Xilinx, Inc.                     |                                                                                                                                           |  |  |  |  |

- 1. For a complete listing of supported devices, see the <u>release notes</u> for this core.
- 2. HDL test bench and C Model available on the product page on xilinx.com at:

www.xilinx.com/products/ipcenter/YCrCb\_to\_RGB.htm

3. For the supported versions of the tools, see the <u>ISE Design Suite</u> <u>13: Release Notes Guide</u>.



### Chapter 1

### **Overview**

A color space is a mathematical representation of a set of colors. The three most popular color models are:

- RGB or R'G'B', gamma corrected RGB, used in computer graphics
- YIQ, YUV and YCrCb used in video systems
- CMYK used in color printing

These color spaces are directly related to the intuitive notions of hue, saturation and brightness.

All color spaces can be derived from the RGB information supplied by devices such as cameras and scanners. Different color spaces have historically evolved for different applications. In each case, a color space was chosen for application-specific reasons.

A particular color space choice may be preferred because it requires less storage, bandwidth or computation in analog or digital domains.

The convergence of computers, the Internet, and a wide variety of video devices, all using different color representations, is forcing the digital designer today to convert between them. The objective is to have all inputs converted to a common color space before algorithms and processes are executed. Converters are useful for a number of markets, including image and video processing.

#### **Applications**

- Pre-processing block for image sensors
- Image compression
- Video surveillance
- Pre-processing block for video analytics

#### Licensing

The YCrCb to RGB core is provided at no cost with the ISE tools. You are not required to license the core before instantiating it in your design.

#### Performance

#### **Maximum Frequencies**

The following are typical clock frequencies for the target devices. The maximum achievable clock frequency can vary. The maximum achievable clock frequency and all resource counts can be affected by other tool options, additional logic in the Field Programmable Gate Array (FPGA) device, using a different version of Xilinx tools, and other factors.

- Virtex®-7 FPGA: 250 MHz •
- Kintex<sup>™</sup>-7 FPGA: 250 MHz
- Virtex-6 FPGA: 250 MHz
- Spartan®-6 FPGA: 150 MHz

#### Latency

The processing latency of the core is shown in the follow equation:

Latency = 5+ 1(if has clipping) + 1(if has clamping)

This example evaluates to seven clock cycles (Figure 2-2) for typical cases (unless in "custom" mode the clipping and/or clamping circuits are not used).

#### Throughput

The Color Space Converter core outputs one RGB sample per clock cycle.

#### **Resource Utilization**

The design was tested using ISE<sup>®</sup> 13.3 tools with default tool options for characterization data. As resource counts are functions of tool options (such as XST optimizations, map packing factor), the actual resource counts corresponding to the quoted operating frequencies are also listed.

For an accurate measure of the usage of device resources (for example, block RAMs, flip-flops, and LUTs) for a particular instance, click View Resource Utilization in CORE Generator software after generating the core.

The YcrCb to RGB core does not use any block RAMs or dedicated I/O or clock resources.

Table 1-1 through Table 1-4 provide the resource usage of the YCrCb to RGB core for different families with default parameterization for all permitted input/output width combinations.

| Input Width | Output Width | LUTs | FFs | DSP48E1 | Clock<br>Frequency<br>(MHz) |
|-------------|--------------|------|-----|---------|-----------------------------|
| 8           | 8            | 62   | 161 | 4       | 210                         |

185

173

Table 1-1: Spartan-6 XC6SLX4 xc6slx4,-2 (PRODUCTION 1.20 2011-09-27) CPG196

8

8

77

64

10

12

210

210

4

4

| •  |    |    | •   |   |     |
|----|----|----|-----|---|-----|
| 10 | 8  | 62 | 169 | 4 | 210 |
| 10 | 10 | 84 | 197 | 4 | 205 |
| 10 | 12 | 72 | 185 | 4 | 210 |
| 12 | 8  | 62 | 177 | 4 | 210 |
| 12 | 10 | 84 | 205 | 4 | 195 |
| 12 | 12 | 81 | 197 | 4 | 210 |

Table 1-1: Spartan-6 XC6SLX4 xc6slx4,-2 (PRODUCTION 1.20 2011-09-27) CPG196

#### Table 1-2: Virtex-6 XC6VLX75T xc6vlx75t,-1 (PRODUCTION 1.15 2011-09-27) FF484

| Input Width | Output Width | LUTs | FFs | DSP48E1 | Clock<br>Frequency<br>(MHz) |
|-------------|--------------|------|-----|---------|-----------------------------|
| 8           | 8            | 74   | 161 | 4       | 353                         |
| 8           | 10           | 88   | 185 | 4       | 353                         |
| 8           | 12           | 68   | 173 | 4       | 353                         |
| 10          | 8            | 73   | 169 | 4       | 369                         |
| 10          | 10           | 92   | 197 | 4       | 369                         |
| 10          | 12           | 80   | 185 | 4       | 369                         |
| 12          | 8            | 69   | 177 | 4       | 369                         |
| 12          | 10           | 94   | 205 | 4       | 369                         |
| 12          | 12           | 88   | 197 | 4       | 369                         |

Table 1-3: Virtex-7 XC7V585T xc7v585t,-1 (ADVANCED 1.02 2011-09-27) FFG1157

| Input Width | Output Width | LUTs | FFs | DSP48E1 | Clock<br>Frequency<br>(MHz) |
|-------------|--------------|------|-----|---------|-----------------------------|
| 8           | 8            | 70   | 161 | 4       | 365                         |
| 8           | 10           | 84   | 185 | 4       | 365                         |
| 8           | 12           | 76   | 173 | 4       | 365                         |
| 10          | 8            | 71   | 169 | 4       | 384                         |
| 10          | 10           | 90   | 197 | 4       | 375                         |
| 10          | 12           | 76   | 185 | 4       | 384                         |
| 12          | 8            | 69   | 177 | 4       | 389                         |
| 12          | 10           | 89   | 205 | 4       | 384                         |
| 12          | 12           | 92   | 197 | 4       | 389                         |

\_

| Input Width | Output Width | LUTs | FFs | DSP48E1 | Clock<br>Frequency<br>(MHz) |
|-------------|--------------|------|-----|---------|-----------------------------|
| 8           | 8            | 69   | 161 | 4       | 328                         |
| 8           | 10           | 81   | 185 | 4       | 370                         |
| 8           | 12           | 78   | 173 | 4       | 370                         |
| 10          | 8            | 69   | 169 | 4       | 377                         |
| 10          | 10           | 88   | 197 | 4       | 377                         |
| 10          | 12           | 82   | 185 | 4       | 377                         |
| 12          | 8            | 69   | 177 | 4       | 386                         |
| 12          | 10           | 96   | 205 | 4       | 386                         |
| 12          | 12           | 92   | 197 | 4       | 386                         |

Table 1-4: Kintex-XC7K70T 7xc7k70t,-1 (ADVANCED 1.02 2011-09-27) FBG484



### Chapter 2

### **Core Interfaces and Register Space**

#### **Core Symbol and Port Descriptions**

The YCrCb to RGB core uses a set of signals that is common to all of the Xilinx Video cores called the Xilinx Streaming Video Interface (XSVI). This core has no ports other than the Xilinx Streaming Video Interface, clk, ce, and sclr signals. The core symbol with the clk, ce, sclr, and XSVI signals is shown in Figure 2-1 and described in Table 2-1.

#### Xilinx Streaming Video Interface

The Xilinx Streaming Video Interface (XSVI) is a set of signals common to all of the Xilinx video cores used to stream video data between IP cores. XSVI can also be defined as an Embedded Development Kit (EDK) bus type. This allows the EDK tool to automatically create input and output connections to EDK pCores that include this interface definition, and provide an easy way to cascade connections of Xilinx Video IP cores.

**Note:** The YCrCb to RGB core is not currently available with a pCore interface. Consequently, the core cannot be directly added to an EDK project and the tool cannot directly recognize the XSVI bus type. To use this core in an EDK project, you must import the core (see Importing Color Space Conversion Cores into EDK as pCore with XSVI Bus) and define the signals as an XSVI bus type. The tool allows easy connection of the signals to other video IP cores with XSVI bus type.

The YCrCb to RGB IP Core uses the following subset of the XSVI signals:

- video\_data
- vblank
- hblank
- active\_video

Other XSVI signals on the XSVI bus, such as video\_clk, vsync, hsync, field\_id, and active\_chr do not affect the function of this core.

Note: These signals are neither propagated, nor driven on the XSVI output of this core.

Importing Color Space Conversion Cores into EDK as pCore with XSVI Bus

- 1. Parameterize and generate the core.
- 2. Create a wrapper file, using the provided instantiation template, either the .veo or .vho file.
- 3. Open EDK and follow the Create and Import Peripheral Wizard. This tool is documented in the <u>UG111: Embedded System Tools Reference Manual</u>.
- 4. Modify the .mpd file created by the Create and Import Peripheral Wizard. This file is in the Data directory created by the Create and Import Peripheral Wizard.

www.xilinx.com

You must define the XSVI bus type and appropriately tag the signals as shown in the following example. IWIDTH and OWIDTH are the values you selected when you generated the IP in Core Generator. (i.e. 8,10, or 12)

#### Input Side:

| BUS_INTERFACE BUS<br>= TARGET              | = XSVI_YCRCB2RGE | B_IN, BUS_ST | D = XSVI, BUS_TYPE |
|--------------------------------------------|------------------|--------------|--------------------|
| PORT active_video_in<br>XSVI_YCRCB2RGB_IN  | = active_video,  | DIR = IN,    | BUS =              |
| PORT hblank_in<br>XSVI_YCRCB2RGB_IN        | = hblank,        | DIR = IN,    | BUS =              |
| PORT vblank_in<br>XSVI_YCRCB2RGB_IN        | = vblank,        | DIR = IN,    | BUS =              |
| PORT video_data_in<br>= IN, BUS = XSVI_YCR |                  | VEC = [0:((  | IWIDTH*3)-1)], DIR |

#### Output Side:

BUS\_INTERFACE BUS = XSVI\_YCRCB2RGB\_OUT, BUS\_TYPE = INITIATOR, BUS\_STD = XSVI PORT active\_video\_out = active\_video, DIR = OUT, BUS = XSVI\_YCRCB2RGB\_OUT PORT hblank\_out = hblank, DIR = OUT, BUS = XSVI\_YCRCB2RGB\_OUT PORT vblank\_out = vblank, DIR = OUT, BUS = XSVI\_YCRCB2RGB\_OUT PORT video\_data\_out = video\_data, VEC = [0:((OWIDTH\*3)-1)], DIR = OUT, BUS = XSVI\_YCRCB2RGB\_OUT

For more information on the MPD format, see <u>UG642: Platform Specification Format</u> <u>Reference Manual</u>

The YCrCb to RGB IP core is fully synchronous to the core clock, clk. Consequently, the input XSVI bus is expected to be synchronous to the input clock, clk. Similarly, to avoid clock resampling issues, the output XSVI bus for this IP is synchronous to the core clock, clk. The video\_clk signals of the input and output XSVI buses are not used.



Figure 2-1: Core Symbol

| Port Name        | Port Width | Direction | Description                             |
|------------------|------------|-----------|-----------------------------------------|
| video_data_in    | 3*IWIDTH   | IN        | Data input bus                          |
| hblank_in        | 1          | IN        | Horizontal blanking input               |
| vblank_in        | 1          | IN        | Vertical blanking input                 |
| active_video_in  | 1          | IN        | Active video signal input               |
| video_data_out   | 3*OWIDTH   | OUT       | Data output bus                         |
| hblank_out       | 1          | OUT       | Horizontal blanking output              |
| vblank_out       | 1          | OUT       | Vertical blanking output                |
| active_video_out | 1          | OUT       | Active video signal output              |
| clk              | 1          | IN        | Rising-edge clock                       |
| се               | 1          | IN        | Clock enable (active high)              |
| sclr             | 1          | IN        | Synchronous clear – reset (active high) |

• **video\_data\_in**: This bus contains the three individual inputs in the following order. Luminance and chrominance values are expected in IWIDTH bits wide unsigned integer representation.

| Bits               | 3IWIDTH-1:2IWIDTH | 2IWIDTH-1:IWIDTH | IWIDTH-1:0 |  |
|--------------------|-------------------|------------------|------------|--|
| Video Data Signals | Cb                | Cr               | Y          |  |

- **hblank\_in:** The hblank\_in signal conveys information about the blank/non-blank regions of video scan lines. This signal is not actively used in the core, but passed through the core with a delay matching the latency of the corrected data.
- vblank\_in: The vblank\_in signal conveys information about the blank/non-blank regions of video frames. This signal is passed through the core with a delay matching the latency of the corrected data.

www.xilinx.com

- **active\_video\_in**: The active\_video\_in signal is high when valid data is presented at the input. This signal is not actively used in the core, but passed through the core with a delay matching the latency of the corrected data.
- **clk clock**: Master clock in the design, synchronous with, or identical to the video clock.
- **ce clock enable**: Pulling CE low suspends all operations within the core. Outputs are held, no input signals are sampled, except for reset (SCLR takes precedence over CE).
- sclr synchronous clear: Pulling SCLR high results in resetting all output ports to zero. Internal registers within the XtremeDSP slice and D-flip-flops are cleared. However, the core uses SRL16/SRL32 based delay lines for hblank, vblank and active\_video generation, which are not cleared by SCLR. This may result in non-zero outputs after SCLR is deasserted, until the contents of SRL16/SRL32s are flushed. Unwanted results can be avoided if SCLR is held active until SRL16/SRL32s are flushed. SCLR should be held active for the duration of the processing latency of the core. The latency is defined in the Control Signals and Timing section.
- **video\_data\_out**: This bus contains the three individual RGB color outputs in the following order from MSB to LSB [red: blue: green]. Color values are expected in OWIDTH bits wide unsigned integer representation.

| Bits               | 30WIDTH-1:20WIDTH | 20WIDTH-1:OWIDTH | OWIDTH-1:0 |
|--------------------|-------------------|------------------|------------|
| Video Data Signals | Red               | Blue             | Green      |

- **hblank\_out** and **vblank\_out**: The corresponding input signals are delayed so blanking outputs are in phase with the video data output, maintaining the integrity of the video stream. The blanking outputs are connected to the corresponding inputs via delay-lines matching the propagation delay of the video processing pipe. Unwanted blanking inputs should be tied high, and corresponding outputs left unconnected, which will result in the trimming of any unused logic within the core.
- active\_video\_out: The active\_video\_out signal is high when valid data is present at the output. The active\_video\_out signal is connected to active\_video\_in via delay-lines matching the propagation delay of the video processing pipe. The active\_video signal does not affect the processing behavior of the core. Asserting or deasserting it will not stall processing or the video stream, nor will it force video outputs to zero.

#### **Control Signals and Timing**



Figure 2-2: Timing Example

www.xilinx.com

The propagation delay of the YcrCb to RGB core is dependent on parameterization but independent of actual signal (video\_data, hblank, vblank, active\_video) values. Deasserting CE suspends processing, which may be useful to temporarily cease processing of a video stream in order to match the delay of other processing components.

See Core Symbol and Port Descriptions, page 9, for an explanation on how other ports may affect the timing behavior of the core.



### Chapter 3

### **Customizing and Generating the Core**

This chapter includes information on using Xilinx tools to customize and generate the core.

#### Graphical User Interface (GUI)

The main screen of the Graphical User Interface (GUI) of the CORE Generator, shown in Figure 3-1, allows quick implementation of standard YCrCb to RGB or YUV to RGB converters without having to manually enter values from Table 4-2, Table 4-3 and Table 4-4. The Color-Space Converter core also supports proprietary (non-standard) converter implementations, by selecting "custom" from the Standard Selection drop-down menu, as long as the custom conversion matrix can be transformed to the form of Equation 4-3. The front pages of the RGB to YCrCb and the YCrCb to RGB GUIs are very similar, allowing easy generation of complementing converter pairs.

|                | YCrCb to RGB Color-Space Converter                                                                                                                                                                                                                                                                                                                                               | - = ×                         |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| View Documents |                                                                                                                                                                                                                                                                                                                                                                                  |                               |
|                | VCrCb to RGB Color-Space Converter<br>VCrCb to RGB Color-Space<br>Converter<br>Component Name v_ycrcb2rgb_v4_0<br>Converter Type<br>This specifies the type of converter to be implemented.<br>Standard Selection SD ITU 601<br>Input Range Selection 16 to 240 for TV<br>Precision Settings<br>Input Data Width 8 ÷<br>Output Data Width 8 ÷<br>Coefficient Bits 18 Range: 8.18 | xilinx.com:ip:v_ycrcb2rgb:4.0 |
|                | Qatasheet<br>                                                                                                                                                                                                                                                                                                                                                                    | e <u>C</u> ancel <u>H</u> elp |

Figure 3-1: Color Space Converter Main Screen

www.xilinx.com

- **Component Name**: The component name is used as the base name of output files generated for the module. Names must begin with a letter and must be composed from characters: a to z, 0 to 9 and "\_".
- Converter Type
  - **Standard Selection**: Select the standard to be implemented. The offered standards are:
    - YCrCb ITU 601 (SD)
    - YCrCb *ITU 709* (HD) 1125/60 (PAL)
    - YCrCb ITU 709 (HD) 1250/50 (NTSC)
    - YUV
    - custom

Selecting "custom" enables the controls on page 2 of the GUI, so conversion settings can be customized. Otherwise, page 2 only displays the parameters to implement the selected standard.

- **Output Range Selection**: This selection governs the range of outputs R, G and B by affecting the conversion coefficients as well as the clipping and clamping values. The core supports typical output ranges:
  - 16 to 235, typical for studio equipment
  - 16 to 240, typical for broadcast or television
  - 0 to 255, typical for computer graphics

The previously-mentioned ranges are characteristic for 8-bit outputs. If 10- or 12-bit outputs are used, the ranges are extended proportionally. For example, 16 to 240 mode for 10-bit outputs will result in output values ranging from 64 to 960.

- Precision Settings
  - Input Width (IWIDTH): This field specifies the width of inputs Y, Cr and Cb.
  - Output Width (OWIDTH): This field specifies the width of outputs R, G and B.
  - **Coefficient Bits**: Sets the number of bits used to represent CA, CB, CC and CD. As displayed on Figure 4-2, the width of coefficients affects the width of multiplier results, which may affect the size of fabric-based adders further down the processing pipe. Reducing the coefficient size may save some slices by trading off precision with logic resources.

The Conversion Matrix, Offset Compensation, Clipping and Clamping screen (Figure 3-2), displays and enables editing of conversion coefficients, similar to Equation 4-3. Contents are editable only when "custom" is selected as the standard on page 1 (Figure 3-1).

|                                                                                                               | YCrCb to RGB Color-Space Converter                                                                                                             |
|---------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| View Documents                                                                                                |                                                                                                                                                |
| IP Symbol @ ®                                                                                                 | Logi CRF YCrCb to RGB Color-Space<br>Converter xilinx.com:ip:v_ycrcb2rgb:4.0                                                                   |
| cux —                                                                                                         | Conversion Matrix<br>$Y = R^{+}$ 0.299 + G * 0.587 + B * 0.114<br>$Cr = (R-Y)^{+}$ 0.713 Range: 0.00.9<br>$Cb = (B-Y)^{+}$ 0.564 Range: 0.00.9 |
| CE→<br>SCLR→<br>VIDEO_DATA_UIP30]<br>HBLANK_UIP→<br>VBLANK_UIP→<br>ACTIVE_VIDEO_UIP30]<br>ACTIVE_VIDEO_UIP30] | Offset Compensation Luma Offset 16 Range: 0255 Chroma Offset 128 Range: 0255 Clipping and Clamping                                             |
|                                                                                                               | Control Clipped  RGB Output Maximum 240  Range: 128.255  Outputs Clamped  RGB Output Minimum 16  Range: 0127                                   |
|                                                                                                               | Datasheet         < Back         Page 2 of 2         Next >         Generate         Cancel         Help                                       |

Figure 3-2: Conversion Matrix, Offset Compensation, Clipping and Clamping Screen

- **Conversion Matrix**: Enter floating-point conversion constants, ranging from 0 to 1, into the four fields representing CA, CB, CC and CD.
- Offset Compensation: Enter the offset compensation constants (OY and OC in Equation 4-17, Equation 4-18 and Equation 4-19). These constants are scaled to the output representation. If OY and OC are in the 0.0 1.0 range, and the output is represented as 10-bit unsigned integers, then luminance and chrominance offsets should be entered as integers in the 0 1023 range.
- **Outputs Clipped/Outputs Clamped**: These check boxes control whether clipping/ clamping logic will be instantiated in the generated netlist. The clipping/clamping logic ensures no arithmetic wrap-arounds happen at overflows, at the expense of extra slice-based logic resources.
- **Minimum and Maximum Values**: Similar to offset values, the edit boxes take unsigned integer values in the range permitted by the current output representation.

#### Parameter Values in the XCO File

 Table 3-1 defines valid entries for the XCO parameters. Xilinx strongly suggests that XCO parameters are not manually edited in the XCO file; instead, use the CORE Generator

software GUI to configure the core and perform range and parameter value checking. The XCO parameters are helpful in defining the interface to other Xilinx tools.

Table 3-1: XCO Parameters

| XCO Parameter  | Default Values   |
|----------------|------------------|
| component_name | v_ycrcb2rgb_v4_0 |
| iwidth         | 8                |
| owidth         | 8                |
| mwidth         | 18               |
| cwidth         | 17               |
| са             | 0.299            |
| cb             | 0.114            |
| сс             | 0.713            |
| c_d            | 0.564            |
| rgbmin         | 16               |
| rgbmax         | 240              |
| coffset        | 128              |
| yoffset        | 16               |
| has_clamp      | true             |
| has_clip       | true             |
| input_range    | 16_to_240_for TV |
| standard_sel   | SD_ITU_601       |

#### **Output Generation**

CORE Generator will output the core as a netlist that can be inserted into a processor interface wrapper or instantiated directly in an HDL design. The output is placed in the <project director>.

#### **File Details**

The CORE Generator output consists of some or all the following files.

| Name                                         | Description                                   |  |
|----------------------------------------------|-----------------------------------------------|--|
| <component_name>_readme.txt</component_name> | Readme file for the core.                     |  |
| <component_name>.ngc</component_name>        | The netlist for the core.                     |  |
| <component_name>.veo</component_name>        | The HDL template for instantiating the core   |  |
| <component_name>.vho</component_name>        | The TIDE template for instantiating the core. |  |

| Name                                  | Description                                                                                                                                                                         |
|---------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <component_name>.v</component_name>   | The structural simulation model for the core.                                                                                                                                       |
| <component_name>.vhd</component_name> | It is used for functionally simulating the core.                                                                                                                                    |
| <component_name>.xco</component_name> | Log file from CORE Generator software<br>describing which options were used to<br>generate the core. An XCO file can also be<br>used as an input to the CORE Generator<br>software. |





### Chapter 4

### Designing with the Core

#### **RGB Color Space**

The red, green and blue (RGB) color space is widely used throughout computer graphics. Red, green and blue are three primary additive colors: individual components are added together to form a desired color, and are represented by a three dimensional, Cartesian coordinate system, as shown in Figure 4-1.

Table 4-1 presents the RGB values for 100% saturated color bars, a common video test signal.

Table 4-1: 100% RGB Color Bars

|   | Normal<br>Range | White | Yellow | Cyan | Green | Magenta | Red | Blue | Black |
|---|-----------------|-------|--------|------|-------|---------|-----|------|-------|
| R | 0 to 255        | 255   | 255    | 0    | 0     | 255     | 255 | 0    | 0     |
| G | 0 to 255        | 255   | 255    | 255  | 255   | 0       | 0   | 0    | 0     |
| В | 0 to 255        | 255   | 0      | 255  | 0     | 255     | 0   | 255  | 0     |

The RGB color space is the most prevalent choice for computer graphics because color displays use red, green and blue to create the desired color. Also, a system that is designed using the RGB color space can take advantage of a large number of existing software algorithms.

However, RGB is not very efficient when dealing with real-world images. All three components need equal bandwidth to generate arbitrary colors within the RGB color cube. Also, processing an image in the RGB color space is usually not the most efficient method. For example, to modify the intensity or color of a given pixel, all three RGB values must be read, modified and written back to the frame buffer. If the system had access to the image stored in the intensity and color format, the process would be faster.

#### **R'G'B'** Color Space

While the RGB color space is ideal to represent computer graphics, 8-bit linear-light coding performs poorly for images to be viewed [Ref 2]. It is necessary to have 12 or 14 bits per component to achieve excellent quality. The best perceptual use is made of a limited number of bits by using nonlinear coding that mimics the nonlinear response of human vision. In video, JPEG, MPEG, computing, digital photography, and many other domains, a nonlinear transfer function is applied to the RGB signals to give nonlinearly coded gamma-corrected components, denoted with symbols R'G'B'. Excellent image quality can be obtained with 10-bit nonlinear coding with a transfer function similar to that of *Rec. 709* [Ref 4] or RGB.

#### **YUV Color Space**

The YUV color space is used by the analog PAL, NTSC and SECAM color video/TV standards. In the past, black and white systems used only the luminance (Y) information. Chrominance information (U and V) was added in such a way that a black and white receiver can still display a normal black and white picture.

#### YCrCb (or YCbCr) Color Space

The YCrCb or YCbCr color space was developed as part of the *ITU-R BT.601* [Ref 3] during the development of a world-wide digital component video standard. YCbCr is a scaled, offset version of the YUV color space. Y has a nominal range of 16-235; Cb and Cr have a nominal range of 16-240. There are several YCbCr sampling formats, such as 4:4:4, 4:2:2 and 4:2:0.



Figure 4-1: RGB and YCrCb Color Representations

#### **Conversion Equations**

#### **Derivation of Conversion Equations**

To generate the luminance (Y, or gray value) component, biometric experiments were employed to measure how the human eye perceives the intensities of the red, green and blue colors. Based on these experiments, optimal values for coefficients CA and CB were determined, such that:

$$Y = CA^*R + (1 - CA - CB)^*G + CB^*B$$
 Equation 4-1

Actual values for CA and CB differ slightly in different standards.

Conversion from the RGB color space to luminance and chrominance (differential color components) could be described with the following equation:

$$\begin{bmatrix} Y \\ R-Y \\ B-Y \end{bmatrix} = \begin{bmatrix} CA & 1-CA-CB & CB \\ 1-CA & CA+CB-1 & -CB \\ -CA & CA+CB-1 & 1-CB \end{bmatrix} \begin{bmatrix} R \\ G \\ B \end{bmatrix}$$
Equation 4-2

Coefficients CA and CB are chosen between 0 and 1, which guarantees that the range of Y is constrained between the maximum and the minimum RGB values permitted,  $RGB_{max}$  and  $RGB_{min}$  respectively.

In most practical implementations, the range of the luminance and chrominance components should be equal. There are two ways to accomplish this: the chrominance components (B-Y and R-Y) can be normalized (compressed and offset compensated), or values above and below the luminance range can be clipped/clamped.

Both clipping and dynamic range compression results in loss of information; however, the introduced artifacts are different. To leverage differences in the input (RGB) range, different standards choose different tradeoffs between clipping and normalization.

The YCrCb to RGB Color-Space Converter core supports only the conversions that fit the following general form:

$$\begin{bmatrix} Y \\ C_R \\ C_B \end{bmatrix} = \begin{bmatrix} CA & 1 - CA - CB & CB \\ CC(1 - CA) & CC(CA + CB - 1) & CC(-CB) \\ CD(-CA) & CD(CA + CB - 1) & CD(1 - CB) \end{bmatrix} \begin{bmatrix} R \\ G \\ B \end{bmatrix} + \begin{bmatrix} O_Y \\ O_C \\ O_C \end{bmatrix}$$
 Equation 4-3

CC and CD allow dynamic range compression for B-Y and R-Y, and constants  $O_Y$  and  $O_C$  facilitate offset compensation for the resulting CB and CR. To avoid arithmetic under- and overflows while converting from the RGB to the YCrCb domain, with RGB values in the [0.1] range, a choice for CC and CD is:

$$CC = \frac{1}{2(1 - CA)}$$
  $CD = \frac{1}{2(1 - CB)}$  Equation 4-4

The YCrCb to RGB core facilitates both range de-compression and optional clipping and clamping. Range, offset, clipping and clamping levels are parameterizable.

By inverting the transformation matrix in Equation 4-3, the transformation from the YCrCb color space to the RGB color space can be defined as:

$$\begin{bmatrix} R \\ G \\ B \end{bmatrix} = \begin{bmatrix} 1 & 1/CC & 0 \\ 1 & \frac{-CA}{CC(1-CA-CB)} & \frac{-CB}{CD(1-CA-CB)} \\ 1 & 0 & 1/CD \end{bmatrix} \begin{bmatrix} Y - O_Y \\ C_R - O_C \\ C_B - O_C \end{bmatrix}$$
 Equation 4-5

www.xilinx.com

#### Hardware Implementation

The YCrCb to RGB color-space transformation (Equation 4-5) can be expressed as:

$$R = Y - O_{Y} + ACOEF(C_{R} - O_{C})$$
 Equation 4-6

$$G = Y - O_Y + BCOEF(C_R - O_C) + CCOEF(C_B - O_C)$$
 Equation 4-7

$$B = Y - O_Y + DCOEF(C_B - O_C)$$
 Equation 4-8

This cannot efficiently utilize the MADD capabilities of XtremeDSP slices. As offsets and coefficients are constants, the preceding equations can be rewritten as:

$$R = ACOEF \bullet C_R + ROFFSET + Y$$
 Equation 4-9

$$G = BCOEF \bullet C_R + CCOEF \bullet C_B + GOFFSET + Y$$
 Equation 4-10

$$B = DCOEF \bullet C_{R} + BOFFSET + Y$$
 Equation 4-11

This can be directly mapped to the architecture shown in Figure 4-2. The blue and gray boxes represent logic blocks, which are always implemented using XtremeDSP slices.



Figure 4-2: YcrCb to RGB Schematic

#### Assigning Values to Design Parameters

The following section specifies parameter values for some widely used standards. Most parameter values, except for COEF and OFFSET parameters, can be assigned from Table 4-2, Table 4-3 and Table 4-4 directly. These parameters have to be calculated, scaled and rounded before assigning integer values to corresponding VHDL parameters, using the following equations:

$$ACOEF = \frac{1}{CC}$$
 Equation 4-12

$$BCOEF = \frac{-CA}{CC(1 - CA - CB)}$$
 Equation 4-13

$$CCOEF = \frac{-CB}{CD(1 - CA - CB)}$$
 Equation 4-14

$$DCOEF = \frac{1}{CD}$$
 Equation 4-15

Coefficients are passed to the core in CWIDTH bits wide two's complement format. Y, Cr and Cb are passed as IWIDTH bits wide unsigned integers. After multiplication, in devices without DSP blocks, results are truncated to MWIDTH bits. For these families, MWIDTH is user definable, and for families with DSP blocks, MWIDTH is preset to IWIDTH + CWIDTH.

ROUNDING CONST = 
$$2^{MWIDTH - OWDITH - 2}$$
 Equation 4-16

Equation 4-17

 $ROFFSET = ROUNDING_CONST - (ACOEF \bullet COFFSET + YOFSET) \bullet SCALE_M$ 

Equation 4-18

 $GOFFSET = ROUNDING_CONST - ((BOEF + CCOEF) \bullet COFFSET + YOFFSET) \bullet SCALE_M$ 

Equation 4-19

 $BOFFSET = ROUNDING_CONST - (DCOEF \bullet COFFSET + YOFFSET) \bullet SCALE_M$ 

SCALE\_M =  $2^{MWDITH - IWIDTH - CWIDTH}$  Equation 4-20

### ITU 601 (SD) and 709 - 1125/60 (NTSC) Standard Conversion Coefficients

#### Table 4-2: Parameterization Values for the SD (ITU 601) and NTSC HD (ITU 709) Standards

| Coefficient/ |                                                | Range  |                |
|--------------|------------------------------------------------|--------|----------------|
| Parameter    | 16-240                                         | 16-235 | 0-255          |
| CA           | 0.                                             | 299    | 0.2568         |
| СВ           | 0.114                                          |        | 0.0979         |
| CC           | 0.713                                          | 0.7295 | 0.5910         |
| CD           | 0.564 0.5772                                   |        | ).5772         |
| YOFFSET      | 2 <sup>OWIDTH-4</sup>                          |        |                |
| COFFSET      | 2 <sup>OWIDTH-1</sup>                          |        |                |
| YMAX         | 240*2 <sup>OWIDTH-8</sup> 235*2 <sup>OWI</sup> |        | 235*2 OWIDTH-8 |

| Coefficient/ |                     | Range   |                           |  |
|--------------|---------------------|---------|---------------------------|--|
| Parameter    | 16-240              | 16-235  | 0-255                     |  |
| CMAX         | 240*2 <sup>OW</sup> | /IDTH-8 | 235*2 <sup>OWIDTH-8</sup> |  |
| YMIN         | 16*2 OWIDTH-8       | 0       | 2 OWIDTH-1                |  |
| CMIN         | 16*2 OWIDTH-8       | 0       | 2 <sup>OWIDTH</sup> -1    |  |

#### Table 4-2: Parameterization Values for the SD (ITU 601) and NTSC HD (ITU 709) Standards (Cont'd)

#### Standard ITU 709 (HD) 1250/50 (PAL)

#### Table 4-3: Parameterization Values for the PAL HD (ITU 709) Standard

| Coefficient/ |                       | Input range           |            |  |  |
|--------------|-----------------------|-----------------------|------------|--|--|
| Parameter    | 16-240                | 16-235                | 0-255      |  |  |
| CA           | 0.2                   | 126                   | 0.1819     |  |  |
| СВ           | 0.0                   | 722                   | 0.0618     |  |  |
| CC           | 0.6350                | 0.6495                | 0.6495     |  |  |
| CD           | 0.5389                | 0.5512                |            |  |  |
| YOFFSET      | 2 <sup>OWIDTH-4</sup> |                       |            |  |  |
| COFFSET      |                       | 2 <sup>OWIDTH-1</sup> |            |  |  |
| YMAX         | 240*2 OWIDTH-8        | 235*2 OWIDTH-8        | 2 OWIDTH_1 |  |  |
| CMAX         | 240*2 OWIDTH-8        | 235*2 OWIDTH-8        | 2 OWIDTH_1 |  |  |
| YMIN         | 16*2 OWIDTH-8         |                       | 0          |  |  |
| CMIN         | 16*2 OWIDTH-8         |                       | 0          |  |  |

#### YUV Standard

#### Table 4-4: Parameterization Values for the YUV Standard

| Coefficient/ |                       | Value          |            |  |
|--------------|-----------------------|----------------|------------|--|
| Parameter    | 16-240                | 16-235         | 0-255      |  |
| CA           |                       | 0.299          |            |  |
| СВ           | 0.114                 |                |            |  |
| CC           | 0.877283              |                |            |  |
| CD           | 0.492111              |                |            |  |
| YOFFSET      | 2 <sup>OWIDTH-4</sup> |                |            |  |
| COFFSET      | 2 <sup>OWIDTH-1</sup> |                |            |  |
| YMAX         | 240*2 OWIDTH-8        | 235*2 OWIDTH-8 | 2 OWIDTH_1 |  |
| CMAX         | 240*2 OWIDTH-8        | 235*2 OWIDTH-8 | 2 OWIDTH_1 |  |
| YMIN         | 16*2 OWIDTH-8 0       |                |            |  |
| CMIN         | 16*2 <sup>OV</sup>    | VIDTH-8        | 0          |  |

#### **Clipping and Clamping**

#### **Output Quantization Noise**

Coefficients CC and CD in Equation 4-3 allow standard designers to trade off output quantization and clipping noise. Actual noise inserted depends on the probability statistics of the Cb and Cr variables, but in general if CC and CD are larger than the maximum values calculated in Equation 4-4, output values may clip, introducing clipping noise. However, the lower CC and CD values are chosen, the worse Cb and Cr values will use the available dynamic range, thus introducing more quantization noise. Therefore, the designer's task is to equalize output quantization and clipping noise insertion by carefully choosing CC and CD values based on knowing the statistics of Cb and Cr values. For instance, when probabilities of extreme chrominance values are small, it is beneficial to increase CC and CD values, as the extra noise inserted by occasional clipping is less than the gain in average signal power (and thus SQNR).

#### **Output Clipping Noise**

If coefficients CC and CD in Equation 4-3 are larger than the maximum values calculated in Equation 4-4, Cr and Cb output values may get larger (overflow) than the maximum or smaller (underflow) than minimum value the output representation can carry. If overflow occurs and the design does not have clipping logic, binary values wrap around and insert substantial noise to the output. If clamping/clipping logic is used, output values saturate and less noise is introduced, as shown in Figure 4-3. Use of clipping and clamping increases slice count of the design by approximately 6\*OWIDTH slices.

If a targeted standard limits output of values to a predefined range other than those of binary representation, such as *ITU-R BT.601-5* [Ref 3], use of clipping and clamping logic facilitates constraining output values to the predefined range by setting RGB<sub>max</sub> and RGB<sub>min</sub> values according to the standard specifications.



Figure 4-3: Wrap-Around and Saturation

#### Clocking

The Color Space Converter core has one clock ("clk") that is used to clock the entire core.

#### Resets

The Color Space Converter core has one reset ("sclr") that is used for the entire core. The reset is active high.



### Chapter 5

### **Constraining the Core**

#### **Required Constraints**

The clk pin should be constrained at the maximum pixel clock rate desired for the video stream.

#### **Device, Package, and Speed Grade Selections**

There are no device, package, or speed grade requirements for this core. This core has not been characterized for use in low power devices.

#### **Clock Frequencies**

The clk pin should be run at the required pixel clock frequency for the YCrCb to RGB core. See Maximum Frequency in Performance in Chapter 1.

#### **Clock Management**

There is only one clock for this core.

#### **Clock Placement**

There are no specific clock placement requirements for this core.

#### Banking

There are no specific banking rules for this core.

#### **Transceiver Placement**

There are no transceivers used in this core.

#### I/O Standard and Placement

There are no specific I/O standard or placement requirements.



### Chapter 6

### **Detailed Example Design**

#### **Demonstration Test Bench**

#### Overview

This chapter describes how to use the files that come with the demo testbench package for YCrCb to RGB Color-Space Converter v4.0.

This demo testbench is provided as a simple introductory package that enables core users to observe the core generated by Coregen operating in a waveform simulator. The user is encouraged to observe core-specific aspects in the waveform, make simple modifications to the test conditions, and observe the changes in the waveform.

#### Software Tools and System Requirements

- Xilinx ISE 13.3 or higher (Includes XST, ISIM, and Coregen).
- ModelSim v6.6d
- ISE Simulator 13.3

#### **Design File Hierarchy**

The directory structure underneath this top-level folder is described below:

- Expected
  - Contains the pre-generated expected/golden data used by the testbench to compare actual output data.
- Stimuli
  - Contains the pre-generated input data used by the testbench to stimulate the core (including register programming values).
- Results
  - Actual output data is written to a file in this folder.
- src
  - Contains the .vhd & .xco files of the core.

The .vhd file is a netlist generated using Coregen.

You can regenerate a new netlist using the .xco file in Coregen.

- tb\_src
  - Contains the top-level testbench design.

This directory also contains other packages used by the testbench.

- isim\_wave.wcfg Waveform configuration for ISIM
- mti\_wave.do Waveform configuration for ModelSim
- run\_isim.bat Runscript for iSim in Windows OS
- run\_isim.sh Runscript for iSim in Linux OS
- run\_mti.bat Runscript for ModelSim in Windows OS
- run\_mti.sh Runscript for ModelSim in Linux OS

#### **Operating Instructions**

- Simulation using ModelSim for Linux: From the console, Type "source run\_mti.sh".
- Simulation using ModelSim for Windows: Double click on "run\_mti.bat" file.
- Simulation using iSim for Linux: From the console, Type "source run\_isim.sh".
- Simulation using iSim for Windows: Double click on "run\_isim.bat" file.

#### Support

To obtain technical support for this reference design, go to www.xilinx.com/support to locate answers to known issues in the Xilinx Answers Database or to create a WebCase.



### Appendix A

# *Verification, Compliance, and Interoperability*

#### Simulation

A highly parameterizable test bench used to test the Color Space Converter core. Testing includes the following:

- Testing various coefficients
- Testing the clipping and clamping
- Testing of various data widths





### Appendix B

Debugging

#### **Evaluation Core Timeout**

The Color Space Converter hardware evaluation core times out after approximately 8 hours of operation. The output is driven to zero. This results in a black screen for RGB systems and a dark-green screen for YUV color systems.

See Solution Centers in Appendix D for information helpful to the debugging progress.



### Appendix C

### C Model Reference

This document introduces the bit accurate C model for the Xilinx<sup>®</sup> LogiCORE<sup>™</sup> IP YCrCb to RGB Color-Space Converter v4.0 core, which has been developed primarily for system modeling.

#### **Features**

- Bit accurate with the YCrCb to RGB Color-Space Converter v4.0 core
- Statically linked library (.lib, .o, .obj Windows)
- Dynamically linked library (.so Linux)
- Available for 32- and 64-bit Windows and 32- and 64-bit Linux platforms
- Supports all features of the YCrCb to RGB core that affect numerical results
- Designed for rapid integration into a larger system model
- Example C is provided to show how to use the function

#### Overview

The Xilinx LogiCORE IP YCrCb to RGB Color-Space Converter v4.0 has a bit accurate C model for 32- and 64-bit Windows and 32- and 64-bit Linux platforms. The model has an interface consisting of a set of C functions, which reside in a statically link library (shared library). An example piece of C code is provided to show how to call the model.

The model is bit accurate, as it produces exactly the same output data as the core on a frame-by-frame basis. However, the model is not cycle accurate, as it does not model the core's latency or its interface signals.

The latest version of the model is available for download on the Xilinx<sup>™</sup> LogiCORE IP YCrCb to RGB Color-Space Converter web page at:

http://www.xilinx.com/products/intellectual-property/YCrCb\_to\_RGB.htm

#### **Unpacking and Model Contents**

Unzip the <code>v\_ycrcb2rgb\_v4\_0\_bitacc\_model.zip</code> file, containing the bit accurate models for the YCrCb to RGB Color-Space Converter IP core. This creates the directory structure and files in Table C-1.

| Table C-1: | Directory Structure and Files of the YCrCb to RGB Color-Space |
|------------|---------------------------------------------------------------|
| Converter  | v4.0 Bit Accurate C Model                                     |

| File Name                                | Contents                                                                                                    |
|------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| README.txt                               | Release notes                                                                                               |
| pg014_v_ycrcb2rgb.pdf                    | LogiCORE IP YCrCb to RGB Color-Space<br>Converter Product Guide                                             |
| v_ycrcb2rgb_v4_0_bitacc_cmodel.h         | Model header file                                                                                           |
| rgb_utils.h                              | Header file declaring the RGB image/video container type and support functions                              |
| yuv_utils.h                              | Header file declaring the YUV (.yuv) image file I/O functions                                               |
| bmp_utils.h                              | Header file declaring the bitmap (.bmp)<br>image file I/O functions                                         |
| video_utils.h                            | Header file declaring the generalized image/video container type, I/O and support functions                 |
| run_bitacc_cmodel.c                      | Example code calling the C model                                                                            |
| kodim19_128x192.bmp                      | 128x192 sample test image of the lighthouse<br>image from the <u>True Color Kodak test</u><br><u>images</u> |
| /lin64                                   | Precompiled bit accurate ANSI C reference<br>model for simulation on 64-bit Linux<br>platforms              |
| libIp_v_ycrcb2rgb_v4_0_bitacc_cmodel.so  | Model shared object library                                                                                 |
| libstlport.so.5.1                        | STL library, referenced by<br>libIp_v_ycrcb2rgb_v4_0_bitacc_cmodel.so                                       |
| /nt32                                    | Precompiled bit accurate ANSI C reference<br>model for simulation on 32-bit Windows<br>platforms.           |
| libIp_v_ycrcb2rgb_v4_0_bitacc_cmodel.lib | Precompiled library file for win32 compilation                                                              |
| /lin32                                   | Precompiled bit accurate ANSI C reference<br>model for simulation on 32-bit Linux<br>platforms              |
| libIp_v_ycrcb2rgb_v4_0_bitacc_cmodel.so  | Model shared object library                                                                                 |
| libstlport.so.5.1                        | STL library, referenced by<br>libIp_v_ycrcb2rgb_v4_0_bitacc_cmodel.so                                       |

|                                          | Precompiled bit accurate ANSI C reference<br>model for simulation on 64-bit Windows<br>platforms. |
|------------------------------------------|---------------------------------------------------------------------------------------------------|
| libIp_v_ycrcb2rgb_v4_0_bitacc_cmodel.lib | Precompiled library file for nt64compilation                                                      |

### Table C-1: Directory Structure and Files of the YCrCb to RGB Color-Space Converter v4.0 Bit Accurate C Model

#### Installation

For Linux, make sure these files are in a directory that is in your \$LD\_LIBRARY\_PATH environment variable:

- libIp\_v\_ycrcb2rgb\_v4\_0\_bitacc\_cmodel.so
- libstlport.so.5.1

#### **Software Requirements**

The YCrCb to RGB Color-Space Converter v4.0 C models were compiled and tested with the software listed in Table C-2.

Table C-2: Compilation Tools for the Bit Accurate C Models

| Platform               | C Compiler                   |
|------------------------|------------------------------|
| 32- and 64-bit Linux   | GCC 4.1.1                    |
| 32- and 64-bit Windows | Microsoft Visual Studio 2005 |

The bit accurate C model is accessed through a set of functions and data structures that are declared in the v\_ycrcb2rgb\_v4\_0\_bitacc\_cmodel.h file. Before using the model, the structures holding the inputs, generics and output of the YCrCb to RGB Color-Space Converter instance must be defined:

struct xilinx\_ip\_v\_ycrcb2rgb\_v4\_0\_generics generics; struct xilinx\_ip\_v\_ycrcb2rgb\_v4\_0\_inputs inputs; struct xilinx\_ip\_v\_ycrcb2rgb\_v4\_0\_outputs outputs;

The declaration of these structures is in the v\_ycrcb2rgb\_v4\_0\_bitacc\_cmodel.h file. Table C-3 lists the generic parameters taken by the YCrCb to RGB Color-Space Converter v4.0 IP core bit accurate model, as well as the default values.

 Table C-3:
 Core Generic Parameters and Default Values

| Generic<br>Variable | Туре   | Default<br>Value | Range     | Description                                            |
|---------------------|--------|------------------|-----------|--------------------------------------------------------|
| IWIDTH              | int    | 8                | 8,10,12   | Input data width                                       |
| CWIDTH              | int    | 18               | 8-18      | Coefficient bits                                       |
| OWIDTH              | int    | 8                | 8,10,12   | Output width                                           |
| ACOEF               | double | 0.299            | 0.0 - 1.0 | A Coefficient <sup>1</sup> 0.0 < ACOEFF + BCOEFF < 1.0 |
| BCOEF               | double | 0.114            | 0.0 - 1.0 | B Coefficient <sup>1</sup> 0.0 < ACOEFF + BCOEFF < 1.0 |
| CCOEF               | double | 0.713            | 0.0 - 0.9 | C Coefficient <sup>1</sup>                             |

|         |        |       |                                                   | 1 /                                            |
|---------|--------|-------|---------------------------------------------------|------------------------------------------------|
| DCOEF   | double | 0.564 | 0.0 - 0.9                                         | D Coefficient <sup>1</sup>                     |
| YOFFSET | int    | 16    | 0 –2 <sup>OWIDTH</sup> -1                         | Offset for the Luminance Channel               |
| COFFSET | int    | 128   | 0 –2 <sup>OWIDTH</sup> -1                         | Offset for the Chrominance Channels            |
| YMIN    | int    | 16    | 0 –2 <sup>OWIDTH-1</sup> -1                       | Clamping value for the Luminance Channel       |
| CMIN    | int    | 16    | 0 –2 <sup>OWIDTH-1</sup> -1                       | Clamping value for the Chrominance<br>Channels |
| YMAX    | int    | 240   | 2 <sup>OWIDTH-1</sup> _<br>2 <sup>OWIDTH</sup> -1 | Clipping value for the Luminance Channel       |
| CMAX    | int    | 240   | 2 <sup>OWIDTH-1</sup> –<br>2 <sup>OWIDTH</sup> -1 | Clipping value for the Chrominance<br>Channels |

Table C-3: Core Generic Parameters and Default Values (Cont'd)

<sup>1</sup> For a detailed description of coefficients and other generic parameters, see the *LogiCORE IP YCrCb to RGB Color-Space Converter Data Shee*t (DS659).

Calling xilinx\_ip\_v\_ycrcb2rgb\_v4\_0\_get\_default\_generics (&generics) initializes the generics structure with the default value.

The inputs structure defines the actual input image. For the description of the input video structure, see Input and Output Video Structures.

Calling xilinx\_ip\_v\_ycrcb2rgb\_v4\_0\_get\_default\_inputs(&generics, &inputs) initializes the input video structure before it can be assigned an image or video sequence using the memory allocation or file I/O functions provided in the BMP, RGB or video utility functions.

**Note:** The video\_in variable is not initialized to point to a valid image / video container, as the container size depends on the actual test image to be simulated. The initialization of the video\_in structure is described in Initializing the Input Video Structure.

After the inputs are defined, the model can be simulated by calling this function:

```
int xilinx_ip_v_ycrcb2rgb_v4_0_bitacc_simulate(
struct xilinx_ip_v_ycrcb2rgb_v4_0_generics* generics,
struct xilinx_ip_v_ycrcb2rgb_v4_0_inputs* inputs,
struct xilinx_ip_v_ycrcb2rgb_v4_0_outputs* outputs).
```

Results are included in the outputs structure, which contains only one member, type video\_struct. After the outputs are evaluated and saved, dynamically allocated memory for input and output video structures must be released by calling this function:

```
void xilinx_ip_v_ycrcb2rgb_v4_0_destroy(
struct xilinx_ip_v_ycrcb2rgb_v4_0_inputs *input,
struct xilinx_ip_v_ycrcb2rgb_v4_0_outputs *output).
```

Successful execution of all provided functions, except for the destroy function, return value 0. A non-zero error code indicates that problems occurred during function calls.

#### Input and Output Video Structures

Input images or video streams can be provided to the YCrCb to RGB Color-Space Converter v4.0 reference model using the video\_struct structure, defined in video\_utils.h:

```
struct video_struct{
    int frames, rows, cols, bits_per_component, mode;
    uint16*** data[5]; };
```

| Member Variable    | Designation                                                                                                                                                                                                                                                                                                  |
|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| frames             | Number of video/image frames in the data structure.                                                                                                                                                                                                                                                          |
| rows               | Number of rows per frame. Pertaining to the image plane with<br>the most rows and columns, such as the luminance channel for<br>YUV data. Frame dimensions are assumed constant through all<br>frames of the video stream. However different planes, such as y,<br>u and v can have different dimensions.    |
| cols               | Number of columns per frame. Pertaining to the image plane<br>with the most rows and columns, such as the luminance channel<br>for YUV data. Frame dimensions are assumed constant through<br>all frames of the video stream. However different planes, such as<br>y, u and v can have different dimensions. |
| bits_per_component | Number of bits per color channel/component.All image planes<br>are assumed to have the same color/component representation.<br>Maximum number of bits per component is 16.                                                                                                                                   |
| mode               | Contains information about the designation of data planes.<br>Named constants to be assigned to mode are listed in Table C-5.                                                                                                                                                                                |
| data               | Set of five pointers to three dimensional arrays containing data<br>for image planes. Data is in 16-bit unsigned integer format<br>accessed as data[plane][frame][row][col].                                                                                                                                 |

Table C-4: Member Variables of the Video Structure

| Table C-5: Na | amed Video Modes with Corresponding Planes and Representation | ons <sup>1</sup> |
|---------------|---------------------------------------------------------------|------------------|
|---------------|---------------------------------------------------------------|------------------|

| Mode          | Planes | Video Representation                                                          |
|---------------|--------|-------------------------------------------------------------------------------|
| FORMAT_MONO   | 1      | Monochrome – Luminance only                                                   |
| FORMAT_RGB    | 3      | RGB image/video data                                                          |
| FORMAT_C444   | 3      | 444 YUV, or YCrCb image/video data                                            |
| FORMAT_C422   | 3      | 422 format YUV video, (u, v chrominance channels<br>horizontally sub-sampled) |
| FORMAT_C420   | 3      | 420 format YUV video, ( $u,v$ sub-sampled both horizontally and vertically )  |
| FORMAT_MONO_M | 3      | Monochrome (Luminance) video with Motion                                      |
| FORMAT_RGBA   | 4      | RGB image/video data with alpha (transparency) channel                        |
| FORMAT_C420_M | 5      | 420 YUV video with Motion                                                     |
| FORMAT_C422_M | 5      | 422 YUV video with Motion                                                     |
| FORMAT_C444_M | 5      | 444 YUV video with Motion                                                     |
| FORMAT_RGBM   | 5      | RGB video with Motion                                                         |

<sup>1</sup> The Color Space Conversion core C model supports FORMAT\_C444 for input data and FORMAT\_RGB for output data.

#### Initializing the Input Video Structure

The easiest way to assign stimuli values to the input video structure is to initialize it with an image or video. The yuv\_utils.h, bmp\_util.h and video\_util.h header files packaged with the bit accurate C models contain functions to facilitate file I/O.

#### **Bitmap Image Files**

The header bmp\_utils.h declares functions that help access files in Windows Bitmap format (<u>http://en.wikipedia.org/wiki/BMP\_file\_format</u>). However, this format limits color depth to a maximum of 8-bits per pixel, and operates on images with three planes (R,G,B). Consequently, the following functions operate on arguments type rgb8\_video\_struct, which is defined in rgb\_utils.h. Also, both functions support only true-color, non-indexed formats with 24-bits per pixel.

```
int write_bmp(FILE *outfile, struct rgb8_video_struct *rgb8_video);
int read_bmp(FILE *infile, struct rgb8_video_struct *rgb8_video);
```

Exchanging data between rgb8\_video\_struct and general video\_struct type frames/videos is facilitated by these functions:

**Note:** All image/video manipulation utility functions expect both input and output structures initialized; for example, pointing to a structure that has been allocated in memory, either as static or dynamic variables. Moreover, the input structure must have the dynamically allocated container (data or r, g, b) structures already allocated and initialized with the input frame(s). If the output container structure is pre-allocated at the time of the function call, the utility functions verify and issue an error if the output container size does not match the size of the expected output. If the output container structure is not pre-allocated, the utility functions create the appropriate container to hold results.

#### **Binary Image/Video Files**

The video\_utils.h header file declares functions that help load and save generalized video files in raw, uncompressed format.

int read\_video( FILE\* infile, struct video\_struct\* in\_video);
int write\_video(FILE\* outfile, struct video\_struct\* out\_video);

These functions serialize the video\_struct structure. The corresponding file contains a small, plain text header defining, "Mode", "Frames", "Rows", "Columns", and "Bits per Pixel". The plain text header is followed by binary data, 16-bits per component in scan line continuous format. Subsequent frames contain as many component planes as defined by the video mode value selected. Also, the size (rows, columns) of component planes can differ within each frame as defined by the actual video mode selected.

#### YUV Image Files

The yuv\_utils.h file declares functions that help access files in standard YUV format. It operates on images with three planes (Y, U and V). The following functions operate on arguments of type yuv8\_video\_struct, which is defined in yuv\_utils.h:

int write\_yuv8(FILE \*outfile, struct yuv8\_video\_struct \*yuv8\_video); int read\_yuv8(FILE \*infile, struct yuv8\_video\_struct \*yuv8\_video); Exchanging data between yuv8\_video\_struct and general video\_struct type frames/videos is facilitated by these functions:

#### Working with Video\_struct Containers

The video\_utils.h header file defines functions to simplify access to video data in video\_struct.

```
int video_planes_per_mode(int mode);
int video_rows_per_plane(struct video_struct* video, int plane);
int video_cols_per_plane(struct video_struct* video, int plane);
```

The video\_planes\_per\_mode function returns the number of component planes defined by the mode variable, as described in Table C-5. The video\_rows\_per\_plane and video\_cols\_per\_plane functions return the number of rows and columns in a given plane of the selected video structure. The following example demonstrates using these functions in conjunction to process all pixels within a video stream stored in the in\_video variable:

```
for (int frame = 0; frame < in_video->frames; frame++) {
  for (int plane = 0; plane < video_planes_per_mode(in_video->mode); plane++) {
    for (int row = 0; row < rows_per_plane(in_video, plane); row++) {
      for (int col = 0; col < cols_per_plane(in_video, plane); col++) {
      // User defined pixel operations on
    // in_video->data[plane][frame][row][col]
      }
    }
  }
}
```

#### **C Model Example Code**

An example C file, run\_bitacc\_cmodel.c, is provided to demonstrate the steps required to run the model. After following the compilation instructions, run the example executable. The executable takes the path/name of the input file and the path/name of the output file as parameters. If invoked with insufficient parameters, this help message is issued:

```
Usage:...
in_file : path/name of the input file (BIN file)
out_file : path/name of the output file (24-bit RGB BMP file)
```

During successful execution, two files are created. One file has a .bin extension and contains the output image in binary format, retaining OWIDTH bits. The other file has a .bmp extension and contains the output RGB image in bitmap format. The structure of .bin files are described in Binary Image/Video Files.

To ease modifying and debugging the provided top-level demonstrator using the built-in debugging environment of Visual Studio, the top-level command line parameters can be specified through the Project Property Pages using these steps:

- 1. In the Solution Explorer pane, right-click the project name and select Properties in the context menu.
- 2. Select Debugging on the left pane of the Property Pages dialog box.
- 3. Enter the paths and file names of the input and output images in the Command Arguments field.

### Compiling YCrCb to RGB Color-Space Converter C Model with Example Wrapper

Linux (32- and 64-bit)

To compile the example code, perform these steps:

1. Set your \$LD\_LIBRARY\_PATH environment variable to include the root directory where you unzipped the model zip file using a command such as:

setenv LD\_LIBRARY\_PATH <unzipped\_c\_model\_dir>:\${LD\_LIBRARY\_PATH}

2. Copy these files from the /lin64 directory to the root directory:

libstlport.so.5.1

libIp\_v\_ycrcb2rgb\_v4\_0\_bitacc\_cmodel.so

3. In the root directory, compile using the GNU C Compiler with this command:

```
gcc -m32 -x c++ ../run_bitacc_cmodel.c ../parsers.c -o
run_bitacc_cmodel -L. -lIp_v_ycrcb2rgb_v4_0_bitacc_cmodel -Wl,-rpath,.
gcc -m64 -x c++ ../run_bitacc_cmodel.c ../parsers.c -o
```

run\_bitacc\_cmodel -L. -lIp\_v\_ycrcb2rgb\_v4\_0\_bitacc\_cmodel -Wl,-rpath,.

#### Windows (32- and 64-bit)

The precompiled library v\_ycrcb2rgb\_v4\_0\_bitacc\_cmodel.lib, and top-level demonstration code run\_bitacc\_cmodel.c should be compiled with an ANSI C compliant compiler under Windows. An example procedure is provided here using Microsoft Visual Studio.

- 1. In Visual Studio, create a new, empty Console Application project.
- 2. As existing items, add:
  - a. libIp\_v\_ycrcb2rgb\_v4\_0\_bitacc\_cmodel.lib to the Resource Files folder of the project
  - b. run\_bitacc\_cmodel.c to the Source Files folder of the project
  - c. v\_ycrcb2rgb\_v4\_0\_bitacc\_cmodel.h to the Header Files folder of the project
- 3. After the project is created and populated, it must be compiled and linked (built) to create an executable. To perform the build step, select "Build Solution" from the Build menu. An executable matching the project name has been created either in the Debug or Release subdirectories under the project location based on whether "Debug" or "Release" has been selected in the "Configuration Manager" under the Build menu.



### Appendix D

### **Additional Resources**

#### Xilinx Resources

For support resources such as Answers, Documentation, Downloads, and Forums, see the Xilinx Support website at:f

http://www.xilinx.com/support.

For a glossary of technical terms used in Xilinx documentation, see:

http://www.xilinx.com/support/documentation/sw\_manuals/glossary.pdf.

#### **Solution Centers**

See the <u>Xilinx Solution Centers</u> for support on devices, software tools, and intellectual property at all stages of the design cycle. Topics include design assistance, advisories, and troubleshooting tips.

#### References

These documents provide supplemental material useful with this user guide:

- 1. Jack, Keith. 2004. Video Demystified, 4th Edition. Burlington, MA: Newnes: pp 15-19.
- 2. Poynton, Charles. 2003. *Digital Video and HDTV*. San Francisco: Morgan Kaufmann: pp 302 321.
- 3. ITU Recommendation BT.601-5, International Telecommunication Union, 1995.
- 4. ITU Recommendation BT.709-5, International Telecommunication Union, 2002.
- 5. Proakis, John G., and Dimitris G. Manolakis. *Digital Signal Processing*, 3rd edition. Upper Saddle River, NJ: Prentice Hall: pp 755-756.
- 6. Sullivan, Gary. 2003. Approximate theoretical analysis of RGB to YCbCr to RGB conversion error. Presented for Joint Video Team (JVT) of ISO/IEC MPEG & ITU-T VCEG (ISO/IEC JTC1/SC29/WG11 and ITU-T SG16 Q.6), July 22-24, in Trondheim, Norway
- 7. AXI Reference Guide.

#### **Technical Support**

Xilinx provides technical support at <u>www.xilinx.com/support</u> for this LogiCORE<sup>™</sup> IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support of product if implemented in devices that are not defined in the documentation, if customized beyond that allowed in the product documentation, or if changes are made to any section of the design labeled DO NOT MODIFY.

See the IP Release Notes Guide (XTP025) for more information on this core. For each core, there is a master Answer Record that contains the Release Notes and Known Issues list for the core being used. The following information is listed for each version of the core:

- New Features
- Resolved Issues
- Known Issues

#### **Ordering Information**

The YCrCb to RGB Color-Space Converter v4.0 core is provided under the <u>Xilinx End User</u> <u>License Agreement</u> and can be generated using the Xilinx<sup>®</sup> CORE Generator<sup>™</sup> system. The CORE Generator system is shipped with Xilinx ISE<sup>®</sup> Design Suite software.

A simulation evaluation license for the core is shipped with the CORE Generator system. To access the full functionality of the core, including FPGA bitstream generation, a full license must be obtained from Xilinx. For more information, visit the <u>product page</u> for this core.

Contact your local Xilinx <u>sales representative</u> for pricing and availability of additional Xilinx LogiCORE IP modules and software. Information about additional Xilinx LogiCORE IP modules is available on the Xilinx <u>IP Center</u>.

#### **Revision History**

The following table shows the revision history for this document.

| Date       | Version | Revision                |
|------------|---------|-------------------------|
| 10/19/2011 | 1.0     | Initial Xilinx release. |

#### **Notice of Disclaimer**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of the Limited Warranties which can be viewed at http://www.xilinx.com/warranty.htm; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in Critical Applications: http://www.xilinx.com/warranty.htm#critapps

© Copyright 2011 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.