Contents

About this User Guide ................................................................. v
   Revision History ................................................................. v
   How to Contact Altera ........................................................ v
   Typographic Conventions .................................................... vi

Chapter 1. About this MegaCore Function
   Release Information ............................................................. 1–1
   Device Family Support ......................................................... 1–1
   Introduction ........................................................................ 1–2
   New in Version 2.3.0 ........................................................... 1–2
   Features ................................................................................ 1–2
   General Description ............................................................ 1–2
      OpenCore Plus Evaluation .............................................. 1–3
      DSP Builder Support ...................................................... 1–3
   Performance ........................................................................ 1–4

Chapter 2. Getting Started
   System Requirements ........................................................... 2–1
   Design Flow .......................................................................... 2–1
   Obtain & Install the CSC MegaCore Function .................... 2–2
      Download the CSC MegaCore Function ......................... 2–2
      Install the CSC MegaCore Function Files ........................ 2–3
   Directory Structure ............................................................ 2–4
   CSC MegaCore Function Walkthrough ............................... 2–4
      Create a New Quartus II Project ...................................... 2–5
      Launch IP Toolbench ....................................................... 2–5
      Step 1: Parameterize ....................................................... 2–8
      Step 2: Set Up Simulation .............................................. 2–12
      Step 3: Generate .......................................................... 2–14
   Simulate the Design ............................................................. 2–16
   Compile the Design ............................................................ 2–16
   Program a Device ............................................................... 2–17
   Set Up Licensing ............................................................... 2–17
      Append the License to Your license.dat File .................... 2–17
      Specify the License File in the Quartus II Software .......... 2–18

Chapter 3. Specifications
   Functional Description ......................................................... 3–1
   Signals ................................................................................ 3–2
   OpenCore Plus Time-Out Behavior ..................................... 3–2
## Contents

Parameters .............................................................................................................................................. 3–3  
Signals .................................................................................................................................................. 3–5  
MegaCore Verification .......................................................................................................................... 3–5  
References ............................................................................................................................................. 3–6
About this User Guide

Revision History

The table below displays the revision history for the chapters in this User Guide.

<table>
<thead>
<tr>
<th>Chapter</th>
<th>Date</th>
<th>Version</th>
<th>Changes Made</th>
</tr>
</thead>
</table>
| All     | October 2005 | 2.3.0   | ● Updated system requirements.  
● Updated version numbers.  
● Updated generated files table. |
| All     | June 2004   | 2.2.0   | Updated the User Guide for version 2.2.0 of the Color Space Converter (CSC) MegaCore function. Edited for standards conformance and included all new screenshots. |

How to Contact Altera

For technical support or other information about Altera products, go to the Altera world-wide web site at www.altera.com. You can also contact Altera through your local sales representative or any of the sources listed below.

<table>
<thead>
<tr>
<th>Information Type</th>
<th>USA &amp; Canada</th>
<th>All Other Locations</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>800-800-EPLD (3753)</td>
<td>+1 408-544-8767</td>
</tr>
<tr>
<td></td>
<td>7:00 a.m. to 5:00 p.m. Pacific Time</td>
<td>7:00 a.m. to 5:00 p.m. (GMT -8:00) Pacific Time</td>
</tr>
<tr>
<td>Product literature</td>
<td><a href="http://www.altera.com">www.altera.com</a></td>
<td><a href="http://www.altera.com">www.altera.com</a></td>
</tr>
<tr>
<td>Altera literature services</td>
<td><a href="mailto:lit_req@altera.com">lit_req@altera.com</a></td>
<td><a href="mailto:lit_req@altera.com">lit_req@altera.com</a></td>
</tr>
<tr>
<td>Non-technical customer service</td>
<td>800-767-3753</td>
<td>+1 408-544-7000</td>
</tr>
<tr>
<td></td>
<td>7:00 a.m. to 5:00 p.m. Pacific Time</td>
<td>7:00 a.m. to 5:00 p.m. (GMT -8:00) Pacific Time</td>
</tr>
<tr>
<td>FTP site</td>
<td>ftp.altera.com</td>
<td>ftp.altera.com</td>
</tr>
</tbody>
</table>
Typographic Conventions

This document uses the typographic conventions shown below.

<table>
<thead>
<tr>
<th>Visual Cue</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Bold Type with Initial Capital Letters</strong></td>
<td>Command names, dialog box titles, checkbox options, and dialog box options are shown in bold, initial capital letters. Example: <strong>Save As</strong> dialog box.</td>
</tr>
<tr>
<td><strong>bold type</strong></td>
<td>External timing parameters, directory names, project names, disk drive names, filenames, filename extensions, and software utility names are shown in bold type. Examples: f\textsubscript{MAX}, \texttt{\textbackslash qdesigns} directory, \texttt{d:} drive, \texttt{chiptrip.gdf} file.</td>
</tr>
<tr>
<td><strong>Italic Type with Initial Capital Letters</strong></td>
<td>Document titles are shown in italic type with initial capital letters. Example: <em>AN 75: High-Speed Board Design</em>.</td>
</tr>
<tr>
<td><strong>Italic type</strong></td>
<td>Internal timing parameters and variables are shown in italic type. Examples: \texttt{t\textsubscript{PIA}}, \texttt{n + 1}.</td>
</tr>
<tr>
<td></td>
<td>Variable names are enclosed in angle brackets (&lt; &gt;) and shown in italic type. Example: \texttt{&lt;file name&gt;}, \texttt{&lt;project name&gt;.pof} file.</td>
</tr>
<tr>
<td>Initial Capital Letters</td>
<td>Keyboard keys and menu names are shown with initial capital letters. Examples: Delete key, the Options menu.</td>
</tr>
<tr>
<td>“Subheading Title”</td>
<td>References to sections within a document and titles of on-line help topics are shown in quotation marks. Example: “Typographic Conventions.”</td>
</tr>
<tr>
<td><strong>Courier type</strong></td>
<td>Signal and port names are shown in lowercase Courier type. Examples: data\texttt{1}, tdi, input. Active-low signals are denoted by suffix \texttt{n}, e.g., resetn.</td>
</tr>
<tr>
<td></td>
<td>Anything that must be typed exactly as it appears is shown in Courier type. For example: \texttt{c:\textbackslash qdesigns\tutorial\chiptrip.gdf}. Also, sections of an actual file, such as a Report File, references to parts of files (e.g., the AHDL keyword \texttt{SUBDESIGN}), as well as logic function names (e.g., \texttt{TRI}) are shown in Courier.</td>
</tr>
<tr>
<td>1., 2., 3., and a., b., c., etc.</td>
<td>Numbered steps are used in a list of items when the sequence of the items is important, such as the steps listed in a procedure.</td>
</tr>
<tr>
<td>■   ●</td>
<td>Bullets are used in a list of items when the sequence of the items is not important.</td>
</tr>
<tr>
<td>✔</td>
<td>The checkmark indicates a procedure that consists of one step only.</td>
</tr>
<tr>
<td>!   &quot;CAUTION&quot;</td>
<td>The hand points to information that requires special attention.</td>
</tr>
<tr>
<td>!   &quot;CAUTION&quot;</td>
<td>The caution indicates required information that needs special consideration and understanding and should be read prior to starting or continuing with the procedure or process.</td>
</tr>
<tr>
<td>!</td>
<td>The warning indicates information that should be read prior to starting or continuing the procedure or processes</td>
</tr>
<tr>
<td>←</td>
<td>The angled arrow indicates you should press the Enter key.</td>
</tr>
<tr>
<td>&quot;~&quot;</td>
<td>The feet direct you to more information on a particular topic.</td>
</tr>
</tbody>
</table>
1. About This MegaCore Function

Release Information

Table 1–1 provides information about this release of the Color Space Converter (CSC) MegaCore® function.

<table>
<thead>
<tr>
<th>Item</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Version</td>
<td>2.3.0</td>
</tr>
<tr>
<td>Release Date</td>
<td>October 2005</td>
</tr>
<tr>
<td>Ordering Code</td>
<td>IP-CSC</td>
</tr>
<tr>
<td>Product ID(s)</td>
<td>0x03</td>
</tr>
<tr>
<td>Vendor ID(s)</td>
<td>6AF7</td>
</tr>
</tbody>
</table>

Device Family Support

MegaCore functions provide either full or preliminary support for target Altera device families, as described below:

- Full support means the MegaCore function meets all functional and timing requirements for the device family and may be used in production designs.
- Preliminary support means the MegaCore function meets all functional requirements, but may still be undergoing timing analysis for the device family; it may be used in production designs with caution.

Table 1–2 shows the level of support offered by the CSC MegaCore function to each Altera device family.

<table>
<thead>
<tr>
<th>Device Family</th>
<th>Support</th>
</tr>
</thead>
<tbody>
<tr>
<td>Stratix® II</td>
<td>Full</td>
</tr>
<tr>
<td>Stratix II GX</td>
<td>Preliminary</td>
</tr>
<tr>
<td>Stratix</td>
<td>Full</td>
</tr>
<tr>
<td>Stratix GX</td>
<td>Full</td>
</tr>
<tr>
<td>HardCopy® II</td>
<td>Preliminary</td>
</tr>
<tr>
<td>HardCopy Stratix</td>
<td>Full</td>
</tr>
</tbody>
</table>
**Introduction**

A color space is a method for precisely specifying the display of color using a three-dimensional coordinate system. Different color spaces are best for different devices, such as RGB (red-green-blue) for CRT monitors or YCbCr (luminance-chrominance) for digital television. The CSC MegaCore function provides a flexible and efficient means to convert image data from one color space to another, and is suitable for use in a wide variety of image processing and display applications.

**New in Version 2.3.0**

- During underflow the color space conversion result is zeroed
- Preliminary support for HardCopy® II and Stratix® II GX devices

**Features**

- Computes one output per clock cycle
- Typically runs at clock speeds over 200 MHz in Stratix devices
- Supports a variety of conversion functions:
  - Studio video R’G’B’ to Y’CbCr
  - Y’CbCr to studio video R’G’B’
  - Computer R’G’B’ to Y’CbCr
  - Y’CbCr to computer R’G’B’
  - Y’IQ to Y’UV
  - Computer R’G’B’ to Y’UV
  - Y’UV to computer R’G’B’
  - User-specified conversion constants
- Supports signed and unsigned input data widths from 2 to 32 bits
- Provides user-selectable output precision via parameterizable rounding, saturation, and truncation

<table>
<thead>
<tr>
<th>Device Family</th>
<th>Support</th>
</tr>
</thead>
<tbody>
<tr>
<td>Cyclone™ II</td>
<td>Full</td>
</tr>
<tr>
<td>Cyclone</td>
<td>Full</td>
</tr>
<tr>
<td>ACEX® 1K</td>
<td>Full</td>
</tr>
<tr>
<td>APEX™ II</td>
<td>Full</td>
</tr>
<tr>
<td>APEX 20KE &amp; APEX 20KC</td>
<td>Full</td>
</tr>
<tr>
<td>APEX 20K</td>
<td>Full</td>
</tr>
<tr>
<td>FLEX 10K®</td>
<td>Full</td>
</tr>
<tr>
<td>Other device families</td>
<td>No support</td>
</tr>
</tbody>
</table>
Color space conversion is often necessary when transferring data between devices that use different color space models. For example, to transfer a television image to a computer monitor, you may need to convert the image from the Y’CrCb color space to the R’G’B’ color space. Conversely, transferring an image from a computer display to a television set may require a transformation from the R’G’B’ color space to the Y’CrCb color space. You can use the CSC MegaCore function to perform these types of color transformations for a variety of applications, including image filtering, machine vision, and digital video.

OpenCore Plus Evaluation

With the Altera free OpenCore Plus evaluation feature, you can perform the following actions:

- Simulate the behavior of a MegaCore function within your system
- Verify the functionality of your design, as well as quickly and easily evaluate its size and speed
- Generate time-limited device programming files for designs that include MegaCore functions
- Program a device and verify your design in hardware

You only need to purchase a license for the MegaCore function when you are completely satisfied with its functionality and performance, and want to take your design to production.

For more information on OpenCore Plus hardware evaluation using the CSC MegaCore function, see “OpenCore Plus Time-Out Behavior” on page 3–1 and application note AN 320: OpenCore Plus Evaluation of Megafunctions from the Altera web site.

DSP Builder Support

Altera’s DSP Builder shortens DSP design cycles by helping you create the hardware representation of a DSP design in an algorithm-friendly development environment.

You can combine existing MATLAB/Simulink blocks with Altera DSP Builder/MegaCore blocks to verify system level specifications and generate hardware implementations. After installing this MegaCore function, a Simulink symbol of this MegaCore function appears in the Simulink library browser in the MegaCore library from the Altera DSP
Performance

Builder blockset. To use this MegaCore function with DSP Builder, you require DSP Builder v5.1 or higher and the Quartus II software version 5.1 or higher.

For more information on DSP Builder, refer to the DSP Builder User Guide and the DSP Builder Reference Manual.

Performance

The CSC MegaCore function yields efficient implementation results, and its parameterization allows you to fine tune these results to achieve the utilization and performance you require.

Table 1–3 shows the resource utilization and maximum clock frequency for several sample implementations in different device families. These all use the computer R’G’B’ to Y’CrCb color model conversion function, and differ in their choice of hardware implementation method, input data width, and pipeline level. The figures were generated using the Quartus® II software version 5.1.

<table>
<thead>
<tr>
<th>Family</th>
<th>Speed Grade</th>
<th>Hardware Implementation</th>
<th>Width of Input Data</th>
<th>Pipeline Level</th>
<th>LEs or ALUTs (1)</th>
<th>18*18 Mults</th>
<th>fMAX (MHz)</th>
<th>Tpd (ns)</th>
</tr>
</thead>
<tbody>
<tr>
<td>Stratix</td>
<td>-5</td>
<td>Distributed Arithmetic in LUTs</td>
<td>8</td>
<td>6</td>
<td>297</td>
<td>0</td>
<td>314</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using LUTs</td>
<td>8</td>
<td>6</td>
<td>287</td>
<td>0</td>
<td>271</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using DSP blocks</td>
<td>8</td>
<td>6</td>
<td>204</td>
<td>9</td>
<td>260</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using LUTs (2)</td>
<td>8</td>
<td>0</td>
<td>103</td>
<td>0</td>
<td>180</td>
<td>5.5</td>
</tr>
<tr>
<td>Cyclone II</td>
<td>-3</td>
<td>Distributed Arithmetic in LUTs</td>
<td>8</td>
<td>6</td>
<td>292</td>
<td>0</td>
<td>216</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using LUTs</td>
<td>8</td>
<td>6</td>
<td>299</td>
<td>0</td>
<td>308</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using DSP blocks</td>
<td>8</td>
<td>6</td>
<td>243</td>
<td>9</td>
<td>230</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using LUTs (2)</td>
<td>8</td>
<td>0</td>
<td>78</td>
<td>0</td>
<td>175</td>
<td>5.7</td>
</tr>
<tr>
<td>Stratix II</td>
<td>-3</td>
<td>Distributed Arithmetic in LUTs</td>
<td>10</td>
<td>6</td>
<td>520</td>
<td>0</td>
<td>380</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using LUTs</td>
<td>10</td>
<td>6</td>
<td>490</td>
<td>0</td>
<td>410</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using DSP blocks</td>
<td>10</td>
<td>6</td>
<td>150</td>
<td>9</td>
<td>270</td>
<td>–</td>
</tr>
<tr>
<td></td>
<td></td>
<td>Multipliers using LUTs (2)</td>
<td>10</td>
<td>0</td>
<td>87</td>
<td>0</td>
<td>240</td>
<td>4.1</td>
</tr>
</tbody>
</table>

Notes to Table 1–3:
(1) Stratix II devices use adaptive look-up tables (ALUTs); other devices use logic elements (LEs).
(2) Yields the minimum area possible without using DSP blocks.
2. Getting Started

System Requirements

The instructions in this section require the following hardware and software:

- A computer running any of the following operating systems:
  - Windows 2000/XP
  - Red Hat Linux 8.0
  - Red Hat Enterprise Linux 3 WS (with support for 32-bit, AMD64, or Intel EM64T workstations)
  - Solaris 8 or 9 (32-bit or 64-bit)
- Quartus® II software version 5.1 or higher
- An Altera-supported VHDL or Verilog HDL simulator (optional).

Design Flow

To evaluate the Color Space Converter (CSC) MegaCore® function using the OpenCore® Plus feature, the design flow involves the following steps:

1. Obtain and install the CSC MegaCore function.

2. Create a custom variation of the CSC MegaCore function using IP Toolbench.

   IP Toolbench is a toolbar from which you can quickly and easily view documentation, specify parameters, and generate all of the files necessary for integrating the parameterized MegaCore function into your design. You can launch IP Toolbench from within the Quartus II software.

3. Implement the rest of your design using the design entry method of your choice.

4. Use the IP functional simulation model generated by IP Toolbench to verify the operation of your design.

   For more information on IP functional simulation models, refer to the Simulating Altera in Third-Party Simulation Tools chapter in volume 3 of the Quartus II Handbook.

5. Use the Quartus II software to compile your design.
Obtain & Install the CSC MegaCore Function

You can generate an OpenCore Plus time-limited programming file, which you can use to verify the operation of your design in hardware for a limited time. For more information on OpenCore Plus hardware evaluation using the CSC MegaCore function, see “OpenCore Plus Time-Out Behavior” on page 3–1, and AN 320: OpenCore Plus Evaluation of Megafunctions.

6. Purchase a license for the CSC MegaCore function.

Once you have purchased a license for the CSC MegaCore function, the design flow involves the following additional steps:

1. Set up licensing.
2. Generate a programming file for the Altera device(s) on your board.
3. Program the Altera device(s) with the completed design.
4. Perform design verification.

Obtain & Install the CSC MegaCore Function

Before you can use the CSC MegaCore function you must obtain the CSC MegaCore function files and install them on your computer. Altera® MegaCore functions can be installed from the MegaCore IP Library CD-ROM during or after Quartus II installation, or downloaded individually from the Altera web site and installed separately.

The following instructions describe downloading and installing the CSC MegaCore function. If you have already installed the CSC MegaCore function from the MegaCore IP Library CD-ROM, skip to “Directory Structure” on page 2–4.

Download the CSC MegaCore Function

If you have Internet access, you can download MegaCore functions from Altera’s web site at www.altera.com. Follow the instructions below to obtain the CSC MegaCore function from the Internet. If you do not have Internet access, you can obtain the CSC MegaCore function from your local Altera representative.

1. Point your web browser to www.altera.com/ipmegastore.
2. Type CSC in the IP MegaSearch box.
3. Click Go.
4. Choose the Altera Color Space Converter from the search results page. The product description web page displays.

5. Click Download Free Evaluation on the top right of the product description web page.

6. Complete the registration form and click Submit Request.

7. Read the Altera MegaCore license agreement, turn on the I have read the license agreement check box, and click Proceed to Download Page.

8. Follow the instructions on the CSC MegaCore function download and installation page to download the MegaCore function and save it to your hard disk.

Ensure you download the MegaCore function for the operating system on which the MegaCore function will be running.

Install the CSC MegaCore Function Files

The following instructions describe how you install the CSC MegaCore function on computers running the Windows, Solaris, or Linux operating systems.

Windows

To install the CSC MegaCore function on a computer running the Windows operating system, follow these steps:

1. Choose Run (Start menu).

2. Type <path>\csc-v2.3.0.exe where <path> is the location of the downloaded MegaCore function.

3. Click OK. The CSC MegaCore function installation dialog box appears. Follow the on-screen instructions to finish installation.

Solaris & Linux

Follow these steps to install the CSC MegaCore function on a computer running supported versions of the Solaris or Linux operating systems:

1. Move the compressed files to the desired installation directory and make that directory your current directory.
2. Decompress the package by typing the following command:
   
   ```
   gunzip -d csc-v2.3.0_<operating system>.tar.gz
   ```
   
   where `<operating system>` is either `solaris` or `linux`.

3. Extract the package contents by typing the following command:
   
   ```
   tar -xvf csc-v2.3.0_<operating system>.tar
   ```
   
   where `<operating system>` is either `solaris` or `linux`.

### Directory Structure

Figure 2–1 shows the directory structure for the CSC MegaCore function, where `<path>` is the CSC MegaCore function installation directory.

#### Figure 2–1. CSC MegaCore Function Directory Structure

- `<path>`
  - `common`
    - Contains the common MegaCore function files.
  - `ip_toolbench`
    - Contains the common IP Toolbench files.
  - `csc-v2.3.0`
    - Contains the CSC MegaCore function files and documentation.
  - `doc`
    - Contains the documentation for the MegaCore functions.
  - `lib`
    - Contains encrypted lower-level design files and some clear-text example files that are used in the design flow.

This walkthrough explains how to create a custom variation of a CSC MegaCore function using IP Toolbench and the Quartus II software. When you are finished generating a custom variation of a CSC MegaCore function, you can incorporate it into your overall project.

This walkthrough consists of these steps:

- “Create a New Quartus II Project” on page 2–5
- “Launch IP Toolbench” on page 2–6
- “Step 1: Parameterize” on page 2–8
- “Step 2: Set Up Simulation” on page 2–12
- “Step 3: Generate” on page 2–14
Create a New Quartus II Project

Before you begin, you must create a new Quartus II project. With the Quar tus II New Project Wizard, you specify the working directory for the project, assign the project name, and designate the name of the top-level design entity. You will also specify the CSC MegaCore function user library. To create a new project, follow these steps:

1. Choose Programs > Altera > Quartus II <version> (Windows Start menu) to run the Quartus II software.

2. Choose New Project Wizard (File menu).

3. Click Next in the introduction (the introduction will not display if you turned it off previously).

4. Specify the working directory for your project. This walkthrough uses the directory d:\temp.

5. Specify the name of the project. This walkthrough uses example.

6. Click Next.

7. For Linux and Solaris operating systems, add the user libraries:

   a. Click User Library Pathnames.

   b. Type <path>csc-v2.3.0\lib\ into the Library name box, where <path> is the directory in which you installed the CSC MegaCore function. The default installation directory is c:\altera\megacore.

   c. Click Add.

   d. Click OK.

8. Click Next.

9. In the Family list, select Stratix. Under Do you want to select a specific device? select No.

10. Click Finish.

You have finished creating your new Quartus II project.
Launch IP Toolbench

To launch IP Toolbench in the Quartus II software, follow these steps:

1. Start the MegaWizard® Plug-In Manager by choosing MegaWizard Plug-In Manager (Tools menu). The MegaWizard Plug-In Manager dialog box is displayed.

Refer to the Quartus II Help for more information on how to use the MegaWizard Plug-In Manager.

2. Specify that you want to create a new custom megafuction variation and click Next.

3. Select CSC v2.3.0 in the DSP > Image & Video Processing directory.

4. Choose the output file type for your design; the wizard supports VHDL and Verilog HDL.
5. Specify a name for the output file, `<directory name>\<variation name>`. Figure 2–2 shows the wizard after you have made these settings.

**Figure 2–2. Select the MegaCore Function**

![Wizard for selecting a MegaCore Function](image)

Notes: To compile a project successfully in the Quartus II software, your design files must be in the project directory, in the global user libraries specified in the Options dialog box (Tools menu), in a user library specified in the User Libraries page of the Settings dialog box (Assignments menu).

Your current user library directories are:
6. Click **Next** to launch IP Toolbench for the CSC MegaCore function (Figure 2–3).

**Figure 2–3. IP Toolbench—Parameterize**

---

**Step 1: Parameterize**

To parameterize your CSC MegaCore function, follow these steps:

- For more information about the parameters, refer to “Parameters” on page 3–2.

1. Click **Step 1: Parameterize** in IP Toolbench (see Figure 2–4).
2. Choose the following parameters:

- The bit width of the input data bus
- The core latency or pipeline level
- The hardware implementation
- Signed or unsigned input data (the signed representation uses the two’s complement numbering scheme)

3. Click Next (see Figure 2–5).
4. Under **Select the Coefficient Values**, you can use a predefined function by checking **Convert between fundamental color models** and selecting from the preset color space conversions in the drop-down list. Or turn off **Convert between fundamental color models** and manually enter or edit specific values to define your own custom transform matrix.

5. Under **Floating Point to Fixed Point Conversion**, you can optionally scale the transform functions. You can specify from 4 to 28 bits of precision, choose to use only power-of-two scaling factors, or no scaling at all. Click **Scale Coefficients** to see the resulting new values in the array.
6. Click Next (see Figure 2–6).

Figure 2–6. Select the Output Resolution

7. Define the resolution of the X_OUT, Y_OUT, and Z_OUT signals generated by the CSC MegaCore function.

8. Select Full Precision or Limited Precision for these output signals.

   The CSC MegaCore function determines the bit width of the output based on the bits of precision and the bit width of the input. These two parameters define a range of maximum positive and negative output values.

   The CSC MegaCore function extrapolates the number of bits required to represent that range of values. For Full Precision, you must use this number of bits in your system. If you choose Limited Precision, the wizard gives you the option of truncating or saturating the most significant bit (MSB) and/or rounding or truncating the least significant bit (LSB). Saturation and rounding are non-linear operations.

9. Click Finish.
Step 2: Set Up Simulation

An IP functional simulation model is a cycle-accurate VHDL or Verilog HDL model file produced by the Quartus II software. It allows for fast functional simulation of IP using industry-standard VHDL and Verilog HDL simulators.

You may only use these simulation model output files for simulation purposes and expressly not for synthesis or any other purposes. Using these models for synthesis creates a nonfunctional design.

To generate an IP functional simulation model for your MegaCore function, follow these steps:

1. Click Step 2: Set Up Simulation in IP Toolbench (Figure 2–7).

Figure 2–7. IP Toolbench—Set Up Simulation
2. Turn on **Generate Simulation Model** (Figure 2–8).

![Figure 2–8. Generate Simulation Model](image)

3. Choose the language in the **Language** list.

4. Click **OK**.
Step 3: Generate

To generate your MegaCore function, follow these steps:

1. Click **Step 3: Generate** in IP Toolbench (Figure 2–9).

Figure 2–9. IP Toolbench—Generate
2. The generation report lists the design files that IP Toolbench creates (Figure 2–10). Click Exit.

**Figure 2–10. Generation**

![Generation Report - CSC MegaCore Function v2.3.0](image)

**Table 2–1 describes the IP Toolbench-generated files.**

<table>
<thead>
<tr>
<th>Filename</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>&lt;variation name&gt;.bsf</code></td>
<td>Quartus II symbol file for the MegaCore function variation. You can use this file in the Quartus II block diagram editor.</td>
</tr>
<tr>
<td><code>&lt;variation name&gt;.cmp</code></td>
<td>A VHDL component declaration file for the MegaCore function variation. Add the contents of this file to any VHDL architecture that instantiates the MegaCore function.</td>
</tr>
<tr>
<td><code>&lt;variation name&gt;.html</code></td>
<td>MegaCore function report file.</td>
</tr>
<tr>
<td><code>&lt;variation name&gt;.vo or .vho</code></td>
<td>VHDL or Verilog HDL IP functional simulation model.</td>
</tr>
</tbody>
</table>
Simulate the Design

You can now integrate your CSC MegaCore function variation into your design and simulate and compile.

Simulate the Design

You can simulate your design using the IP Toolbench-generated VHDL and Verilog HDL IP functional simulation models. The IP functional simulation model is the .vo or .vho file you specified in “Step 2: Set Up Simulation” on page 2–12. Compile the file in your simulation environment and perform functional simulation of your custom CSC MegaCore function.

For more information on IP functional simulation models, refer to the Simulating Altera in Third-Party Simulation Tools chapter in volume 3 of the Quartus II Handbook.

Compile the Design

You can use the Quartus II software to compile your design. Refer to Quartus II Help for instructions on performing compilation.

Refer to Quartus II Help (F1) or the Introduction to Quartus II Handbook for further instructions on compiling and analyzing your design.

Program a Device

After you have compiled your design, program your targeted Altera device, and verify your design in hardware.

With Altera's free OpenCore Plus evaluation feature, you can evaluate the CSC MegaCore function before you purchase a license. OpenCore Plus evaluation allows you to generate an IP functional simulation model, and produce a time-limited programming file.

---

Table 2–1. IP Toolbench-Generated Files (Part 2 of 2)  Note (1)

<table>
<thead>
<tr>
<th>Filename</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td><code>variation name</code>.vhd, or .v</td>
<td>A MegaCore function variation file, which defines a VHDL or Verilog HDL top-level description of the custom MegaCore function. Instantiate the entity defined by this file inside of your design. Include this file when compiling your design in the Quartus II software.</td>
</tr>
<tr>
<td><code>variation name</code>_bb.v</td>
<td>Verilog HDL black-box file for the MegaCore function variation. Use this file when using a third-party EDA tool to synthesize your design.</td>
</tr>
</tbody>
</table>

Notes to Table 2–1:

(1) `<variation name>` is the variation name.
For more information on IP functional simulation models, refer to the Simulating Altera in Third-Party Simulation Tools chapter in volume 3 of the Quartus II Handbook.

For more information on OpenCore Plus hardware evaluation using the CSC MegaCore function, see “OpenCore Plus Time-Out Behavior” on page 3–1 and AN 320: OpenCore Plus Evaluation of Megafunctions.

Set Up Licensing

You need to purchase a license for a CSC MegaCore function only when you are completely satisfied with its functionality and performance, and want to take your design to production.

After you purchase a license for a CSC MegaCore function, you can request a license file from the Altera website at www.altera.com/licensing and install it on your computer. When you request a license file, Altera e-mails you a license.dat file. If you do not have Internet access, contact your local Altera representative.

To install your license, you can either append the license to your existing Quartus II license file or you can specify the CSC MegaCore function’s license.dat file in the Quartus II software.

Before you set up licensing for a CSC MegaCore function, you must already have the Quartus II software installed and licensed on your computer.

Append the License to Your license.dat File

To append the license, follow these steps:

1. Close the following software if it is running on your computer:
   - Quartus II software
   - MAX+PLUS® II software
   - LeonardoSpectrum™ synthesis tool
   - Synplify software
   - ModelSim® simulator

2. Open the CSC MegaCore function license file in a text editor. The file should contain one FEATURE line, spanning 2 lines.

3. Open your Quartus II license.dat file in a text editor.

4. Copy the FEATURE line from the CSC MegaCore function license file and paste it into the Quartus II license file.
Do not delete any FEATURE lines from the Quartus II license file.

5. Save the Quartus II license file.

When using editors such as Microsoft Word or Notepad, ensure that the file does not have extra extensions appended to it after you save (e.g., license.dat.txt or license.dat.doc). Verify the filename in a DOS box or at a command prompt.

Specify the License File in the Quartus II Software

To specify the CSC MegaCore function’s license file, follow these steps:

1. Altera recommends that you give the file a unique name, e.g., altera-csc_license.dat.

2. Start the Quartus II software.

3. Choose License Setup (Tools menu). The Options dialog box opens to the License Setup page.

4. In the License file box, add a semicolon to the end of the existing license path and filename.

5. Type the path and filename of the CSC MegaCore function license file after the semicolon.

   Do not include any spaces either around the semicolon or in the path/filename.

6. Click OK to save your changes.
3. Specifications

Functional Description

A three-dimensional color space is defined as a mathematical representation of a set of colors, where each color is mapped to three coordinates. The Color Space Converter (CSC) MegaCore® function transforms a color from one three-dimensional color space to another by multiplying the tri-stimulus value by a $3 \times 4$-matrix transform.

The CSC MegaCore function uses this equation to convert data from one color space to another:

$$
\begin{bmatrix}
X_{OUT} \\
Y_{OUT} \\
Z_{OUT}
\end{bmatrix} = 
\begin{bmatrix}
c_{11} & c_{12} & c_{13} & c_{14} \\
c_{21} & c_{22} & c_{23} & c_{24} \\
c_{31} & c_{32} & c_{33} & c_{34}
\end{bmatrix}
\begin{bmatrix}
A \\
B \\
C \\
1
\end{bmatrix}
$$

Because the inputs are multiplied by constant values, the look-up table (LUT) architecture of Altera® SRAM-based FPGAs is ideal for implementing the conversion equations. Pre-computing partial products and storing them in look-up tables can provide a smaller, faster implementation than one that can be realized with soft multipliers.

For more information on color spaces and converting between them, see “References” on page 3–5.

OpenCore Plus Time-Out Behavior

OpenCore® Plus hardware evaluation can support the following two modes of operation:

- **Untethered**—the design runs for a limited time
- **Tethered**—requires a connection between your board and the host computer. If tethered mode is supported by all megafunctions in a design, the device can operate for a longer time or indefinitely

All megafunctions in a device time out simultaneously when the most restrictive evaluation time is reached. If there is more than one megafunction in a design, a specific megafunction’s time-out behavior may be masked by the time-out behavior of the other megafunctions.
For the CSC and other MegaCore functions, the untethered timeout is one hour, and the tethered timeout value is indefinite.

The output signals $X_{\text{OUT}}$, $Y_{\text{OUT}}$, and $Z_{\text{OUT}}$ go low when the evaluation time for the CSC MegaCore function expires.

For more information on OpenCore Plus hardware evaluation, see “OpenCore Plus Evaluation” on page 1–3 and AN 320: OpenCore Plus Evaluation of Megafunctions.

Parameters

You configure the CSC MegaCore function with IP Toolbench (see “CSC MegaCore Function Walkthrough” on page 2–4). Tables 3–1, 3–2, and 3–3 list the parameters relevant to each page in the wizard.

Table 3–1. Parameters on the First Page of the Wizard

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value (default)</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>Width of the input data</td>
<td>2 to 32 (8)</td>
<td>Defines the width of the input bus carrying the color data.</td>
</tr>
<tr>
<td>Core latency (pipeline level)</td>
<td>0 to 9 (2)</td>
<td>Affects the time required to process the color data. A higher number yields a faster but larger architecture.</td>
</tr>
<tr>
<td>Hardware Implementation</td>
<td>Auto (default) Distributed Arithmetic in LUTs Multipliers using LUTs Multipliers using DSP blocks</td>
<td>Determines the hardware implementation used for the CSC. May be the default implementation for the targeted device family, or a specific style as specified. For details, refer to AN 306: Techniques for Implementing Multipliers in Stratix® , Stratix GX &amp; Cyclone™ Devices.</td>
</tr>
<tr>
<td>Input data signed or unsigned?</td>
<td>Signed (default) or unsigned</td>
<td>Identifies whether the input data is signed or unsigned.</td>
</tr>
</tbody>
</table>
### Table 3–2. Parameters on the Second Page of the Wizard

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Value (default)</th>
<th>Description</th>
</tr>
</thead>
</table>
| Convert between fundamental color models     | On or off       | Turn on to use a set of coefficients based on the preset color model conversion you then choose from the drop-down list:  
- Studio Video RGB to YCbCr  
- YCbCr to Studio Video RGB  
- Computer RGB to YCbCr  
- YIQ to YUV  
- YUV to Computer RGB  
- Computer RGB to YUV  
Turn off to edit the floating-point value of each coefficient of the color space conversion equations. See “References” on page 3–5 for more information on color model conversion. |
| Scale to use up to X bits of precision       | 4 to 28 (12)    | Allows you to convert the floating-point coefficients defined above to fixed-point coefficients using the number of bits of precision that you specify. This conversion consists of multiplying all the floating-point coefficients with a common scaling factor and casting the floating-point multiplication result to a two’s complement integer (a fixed-point coefficient). The scaling factor is defined so that the floating-point dynamic range (min-max value) gets mapped to the coefficient bit-width dynamic range (min-max). |
| Use only power of two scaling factors        | On or off       | Turn on to round the scaling factor to the nearest power-of-two integer value                                                                                                                                 |
| Do not apply any scaling                     | On or off       | Turn on to set the scaling factor to 1.0                                                                                                                                                                    |
Signals

Table 3–4 describes the external signals of the CSC MegaCore function.

<table>
<thead>
<tr>
<th>Signal</th>
<th>Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CLK</td>
<td>Input</td>
<td>The system clock.</td>
</tr>
<tr>
<td>SCLR</td>
<td>Input</td>
<td>The synchronous clear signal, which is active at 1.</td>
</tr>
<tr>
<td>A[]</td>
<td>Input</td>
<td>The input busses.</td>
</tr>
<tr>
<td>B[]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>C[]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>X_OUT[]</td>
<td>Output</td>
<td>The converted data.</td>
</tr>
<tr>
<td>Y_OUT[]</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Z_OUT[]</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

MegaCore Verification

Before releasing a version of the CSC MegaCore function, Altera runs comprehensive regression tests to verify its quality and correctness.

Custom variations of the CSC MegaCore function are generated to exercise its various parameter options, and the resulting simulation models are thoroughly simulated and the results verified against bit-accurate master simulation models.
References

Altera application notes, white papers, and user guides providing more detailed explanations of how to effectively design with MegaCore functions and the Quartus® II software are available at the Altera web site (www.altera.com).

The following third-party references provide technical information on color spaces and the transformations between them.

- C. Shi, and R. W. Brodersen, *Floating-point to fixed-point conversion with decision errors due to quantization*, Proceeding, IEEE Int. Conf. on Acoustics, Speech, and Signal Processing, 2004, Montreal, Canada