Features

- Supports Virtex, Virtex™-E, and Spartan™-II devices
- X_DCT_IDCT supports both DCT and IDCT on an 8x8 block of samples
- DCT and IDCT operations performed at one clock/sample
- DCT input precision 8 bits; output precision 12 bits
- IDCT input precision 12 bits; output precision 8 bits
- Suitable for JPEG, MPEG, H261 designs
- Fully synchronous design
- Test benches provided

Table 1: Core Implementation Data

<table>
<thead>
<tr>
<th>Supported Family</th>
<th>Device Tested</th>
<th>CLB Slices</th>
<th>Clock IOBs</th>
<th>IOBs</th>
<th>Performance (MHz)</th>
<th>Xilinx Tools</th>
<th>Special Features</th>
</tr>
</thead>
<tbody>
<tr>
<td>Spartan-II</td>
<td>2CS100-6</td>
<td>1027</td>
<td>912</td>
<td>1</td>
<td>1</td>
<td>28</td>
<td>25</td>
</tr>
<tr>
<td>Virtex-E</td>
<td>V100E-8</td>
<td>1027</td>
<td>912</td>
<td>1</td>
<td>1</td>
<td>28</td>
<td>25</td>
</tr>
<tr>
<td>Virtex</td>
<td>V100-6</td>
<td>1140</td>
<td>943</td>
<td>1</td>
<td>1</td>
<td>28</td>
<td>25</td>
</tr>
</tbody>
</table>

Notes:
1. Assuming all core I/Os are routed off-chip

AllianceCORE™ Facts

<table>
<thead>
<tr>
<th>Core Specifics</th>
<th>Provided with Core</th>
</tr>
</thead>
<tbody>
<tr>
<td>Documentation</td>
<td>Product Datasheet</td>
</tr>
<tr>
<td>Design File Formats</td>
<td>EDIF netlist</td>
</tr>
<tr>
<td>Constraints File</td>
<td>dctchip.ucf</td>
</tr>
<tr>
<td>Verification</td>
<td>Testbench, test vectors</td>
</tr>
<tr>
<td>Instantiation Templates</td>
<td>VHDL, Verilog</td>
</tr>
<tr>
<td>Reference Designs and Application Notes</td>
<td>None</td>
</tr>
<tr>
<td>Additional Items</td>
<td>None</td>
</tr>
</tbody>
</table>

Simulation Tool Used

ModelSim 5.3b

Support

Provided by Xentec, Inc.
Applications

X_DCT_IDCT is a typical building block for image processing, printers, desktop video editing, digital still cameras, surveillance systems, and video conferencing cores.

General Description

X_DCT_IDCT can perform the two dimensional Discrete Cosine Transform (DCT) and its inverse (IDCT) on an 8x8 block of samples. The simple, fully synchronous design allows for fast operation while maintaining a low gate count. It offers high performance and many features to meet your multimedia, digital video and digital printing applications.

Functional Description

This core can perform both Discrete Cosine Transform (DCT) and its inverse (IDCT) on an 8X8 block of samples. The mathematical definition for the DCT and IDCT are shown below.

\[
Y_{uv} = \frac{1}{4} C_u C_v \sum_{i=0}^{7} \sum_{j=0}^{7} X_{ij} \cos \left(\frac{(2i+1)u\pi}{16}\right) \cos \left(\frac{(2j+1)v\pi}{16}\right)
\]

\[
Y_{uv} = \frac{1}{4} \sum_{u=0}^{7} \sum_{v=0}^{7} C_u C_v Y_{uv} \cos \left(\frac{(2i+1)u\pi}{16}\right) \cos \left(\frac{(2j+1)v\pi}{16}\right)
\]

Where \(C_u = C_v = 1 / \sqrt{2}\) for \(u, v=0\), and \(C_u = C_v = 1\) otherwise.

Input samples are provided to the \(X\) port, while transformation results are available from port \(Y\). If we consider a block of samples as shown below, the input port \(X\) accepts rows of samples. This means that input samples are to be provided in the order \(X_{00}, X_{01}, \ldots, X_{77}\).

\[
X_{10}, \ldots, X_{70}, \ldots, X_{77}. \text{ Port } Y \text{ outputs transformed samples as columns (i.e. } Y_{00}, Y_{10}, \ldots, Y_{70}, Y_{01}, \ldots, Y_{07}, \ldots, Y_{77} \text{)} \text{ after a latency period of 64 clock cycles.}
\]

Port \(Y\) outputs transformed samples as columns (i.e. \(Y_{00}, Y_{10}, \ldots, Y_{70}, Y_{01}, \ldots, Y_{07}, \ldots, Y_{77}\) after a latency period of 64 clock cycles.

A clock cycle wide pulse on the START input indicates the very first sample \(X_{00}\) of a series of blocks that need to be transformed.

The idct pin selects the type of transform to be performed on the input samples, DCT or IDCT. This input must be stable from the input sample \(X_{00}\) to at least the output sample \(Y_{77}\).
Pinout

The pinout of the X_DCT_IDCT core has not been fixed to specific FPGA I/O, thereby allowing flexibility with a user's application. Signal names are shown in Figure 1 and described in Table 2.

Verification Methods

Extensive functional (pre-synthesis) and timing (post-synthesis) simulation has been performed, using the Model Technology ModelSim simulator. Test vectors and the test bench used for design verification are provided with the core.

Recommended Design Experience

A basic understanding of digital signal processing algorithms and DCT/IDCT is suggested. Users should be familiar with Verilog or VHDL synthesis and simulation and Xilinx design flows as well.

Ordering Information

The X_DCT_IDCT core is provided under license by Xentec for use in Xilinx programmable logic devices. RTL synthesizable source code is also available. Please contact Xentec for information about pricing, terms, and conditions of sale.

Xentec reserves the right to change any specification detailed in this document at any time without notice, and assumes no responsibility for any error in this document.

Table 2: Core Signal Pinout

<table>
<thead>
<tr>
<th>Signal</th>
<th>Signal Direction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>EN</td>
<td>Input</td>
<td>Enable</td>
</tr>
<tr>
<td>IDCT</td>
<td>Input</td>
<td>IDCT selector: idct=0, DCT operation idct=1, IDCT operation</td>
</tr>
<tr>
<td>START</td>
<td>Input</td>
<td>Indicator of the 1st sample in the input block</td>
</tr>
<tr>
<td>X[10:0]</td>
<td>Input</td>
<td>Input data</td>
</tr>
<tr>
<td>CLK</td>
<td>Input</td>
<td>System clock</td>
</tr>
<tr>
<td>RSTN</td>
<td>Input</td>
<td>Asynchronous system reset</td>
</tr>
<tr>
<td>READY</td>
<td>Output</td>
<td>Indicator of the 1st sample in the output block</td>
</tr>
<tr>
<td>Y[11:0]</td>
<td>Output</td>
<td>Output data</td>
</tr>
</tbody>
</table>

Related Information

Xilinx Programmable Logic

For information on Xilinx programmable logic or development system software, contact your local Xilinx sales office, or:

Xilinx, Inc.
2100 Logic Drive
San Jose, CA 95124
Phone:+1 408-559-7778
Fax: +1 408-559-7114
URL: www.xilinx.com

For general Xilinx literature, contact:

Phone: +1 800-231-3386 (inside the US)
+1 408-879-5017 (outside the US)
E-mail: literature@xilinx.com

For AllianceCORE™ specific information, contact:

Phone: +1 408-879-5381
E-mail: alliancere@xilinx.com