

# PCE04C CCSDS Turbo Encoder

**Product Specification** 

4 August 2023 (Version 1.05)

## **PCE04C** Features

- 16 state CCSDS compatible turbo encoder
- Rate 1/2 to 1/7
- Interleaver sizes from 1784 to 16056 bits
- Up to 720 MHz internal clock
- Up to 359 Mbit/s encoding speed
- Serial continuous encoded data out
- 128 6-input LUTs
- Asynchronous logic free design
- Available as EDIF and VHDL core for Xilinx FPGAs under SignOnce IP License. ASIC, Intel/Altera, Lattice and Microsemi/Actel cores available on request.

### Introduction

The PCE04C is a 16 state CCSDS [1] compatible turbo encoder. Interleaver sizes from 1784 to 16056 bits in multiples of 1784 can be implemented. Turbo code rates from 1/2 to 1/7 can be selected. The un–interleaved data is terminated with a tail using both data and parity information. The interleaved data is terminated with a tail using parity data only. The input block and interleaver size is *K*. The number of coded bits is n(K+4) where the nominal code rate is 1/n.

Figure 1 shows the schematic symbol for the PCE04C encoder. The EDIF core can be used with Xilinx Foundation or Integrated Software Environment (ISE) software. The VHDL core can be used with Xilinx ISE or Vivado software. Custom VHDL cores can be used in ASIC designs.



Figure 1: PCE04C schematic symbol.

Table 1 shows the performance achieved for various Xilinx parts for K = 1784. T<sub>cp</sub> is the minimum clock period over recommended operating

conditions. These performance figures may change due to device utilisation and configuration. Note that Zynq devices up to XC7Z020 and from XC7Z030 use programmable logic equivalent to Artix–7 and Kintex–7 devices, respectively.

#### Table 1: Example performance

| Part      | T <sub>cp</sub><br>(ns) | Speed (Mbit/s) |       |       |       |
|-----------|-------------------------|----------------|-------|-------|-------|
|           |                         | 1/2            | 1/3   | 1/4   | 1/6   |
| XC7S6-1   | 4.982                   | 100.0          | 66.7  | 50.0  | 33.3  |
| XC7S6-2   | 4.096                   | 121.7          | 81.1  | 60.8  | 40.5  |
| XC7A12T-1 | 4.912                   | 101.5          | 67.6  | 50.7  | 33.8  |
| XC7A12T-2 | 4.006                   | 124.4          | 82.9  | 62.2  | 41.5  |
| XC7A12T-3 | 3.558                   | 140.1          | 93.4  | 70.0  | 46.7  |
| XC7K70T-1 | 3.070                   | 162.4          | 108.2 | 81.2  | 54.1  |
| XC7K70T-2 | 2.461                   | 202.6          | 135.0 | 101.3 | 67.5  |
| XC7K70T-3 | 2.298                   | 216.9          | 144.6 | 108.5 | 72.3  |
| XCKU035-1 | 2.647                   | 188.3          | 125.6 | 94.2  | 62.8  |
| XCKU035-2 | 2.186                   | 228.0          | 152.0 | 114.0 | 76.0  |
| XCKU035-3 | 1.939                   | 257.1          | 171.4 | 128.6 | 85.7  |
| XCKU3P-1  | 1.801                   | 276.8          | 184.5 | 138.4 | 92.3  |
| XCKU3P-2  | 1.515                   | 329.1          | 219.4 | 164.6 | 109.7 |
| XCKU3P-3  | 1.388                   | 359.2          | 239.5 | 179.6 | 119.7 |

### **Signal Descriptions**

- CLK Encoder Clock
- KS Interleaver Size Select (0 to 8, Block Length K = 1784(KS+1))
- MODE 0 = small interleaver (XA[13:12] = 0) 1 = large interleaver
- N Code Rate (2 to 7)
- RST Synchronous Reset
- START Encoder Start
- X Data In
- XA Data In Address
- XR Data In Ready
- Y Data Out
- YE Data Out Enable
- YR Data Out Ready

#### Encoder

Figure 2 gives a block diagram of the PCE04C CCSDS 16 state turbo encoder. X is the data input and Y0 to Y6 are the coded outputs. Data is



Figure 2: PCE04C 16 state turbo encoder.

clocked during the low to high transition of CLK. Separate internal clock enables (CE1 and CE2) are used to clock the data into each encoder. Non-interleaved data is clocked into the first encoder and interleaved data is clocked into the second encoder. The twin vertical lines indicate a multiplexer.

The data is input in the sequence  $X_k X_{I(k)}$ where  $X_k$  is the data at time *k* from 0 to *K*-1 and I(k) is the interleaved address. Table 2 shows the output sequence for the various code rates. For rate 1/3 to 1/7, *k* is incremented by one from 0 to *K*-1. For rate 1/2, *k* is incremented by two.

#### Table 2: Output sequence

| Rate | Sequence                                                                |  |  |  |  |
|------|-------------------------------------------------------------------------|--|--|--|--|
| 1/2  | $Y_{k}^{0}$ $Y_{k}^{1}$ $Y_{k+1}^{0}$ $Y_{k+1}^{4}$                     |  |  |  |  |
| 1/3  | $Y_k^0  Y_k^1  Y_k^4$                                                   |  |  |  |  |
| 1/4  | $Y_k^0$ $Y_k^2$ $Y_k^3$ $Y_k^4$                                         |  |  |  |  |
| 1/5  | $Y_{k}^{0}$ $Y_{k}^{2}$ $Y_{k}^{3}$ $Y_{k}^{4}$ $Y_{k}^{5}$             |  |  |  |  |
| 1/6  | $Y_{k}^{0}$ $Y_{k}^{1}$ $Y_{k}^{2}$ $Y_{k}^{3}$ $Y_{k}^{4}$ $Y_{k}^{6}$ |  |  |  |  |
| 1/7  | $Y_k^0 \ Y_k^1 \ Y_k^2 \ Y_k^3 \ Y_k^4 \ Y_k^5 \ Y_k^6$                 |  |  |  |  |

Note that the output for all rates is output in one continuous stream. The encoder does not pause (unless YE goes low) in outputting the data. The

tail bits are output in the same sequence as the data sequence.

Figure 3 shows the initial timing diagram for encoding a block of data of length K = 1784 with R=1/3. The encoder starts and ends in state 0. When the encoder requires data X to be read from the input RAM, the data ready signal XR goes high and XA[13:0] selects the data bit. After a START signal is initiated XR goes high after one cycle (this occurs for all rates). It is assumed that the data is stored in a synchronous read RAM with XR used to control the enable input of the RAM. An asynchronous read RAM can also be used by registering the RAM output.

If YE is high, the encoded data ready signal YR goes high three clock cycles after a START signal is initiated (this occurs for all rates). YR is high for both the data block and tail. If YE is low the encoder is held during the next low–to–high transition of CLK. The output of XR also goes low when YE goes low so that the data RAM output is held. Figure 4 shows the encoding process for the tail with KS = 0 (K = 1784).

The nominal input data rate fe is

$$f_e = \frac{f_E}{n + (4n + 2)/K}$$
 (1)



Figure 3: PCE04C Initial Encoder Timing (K = 1784, R = 1/3).

where *n* is the number of coded bits (2 to 7) and  $f_E = 1/T_{cp}$  is the encoder clock speed.

#### **Ordering Information**

SW-PCE04C-SOS (SignOnce Site License) SW-PCE04C-SOP (SignOnce Project License) SW-PCE04C-VHD (VHDL ASIC License)

All licenses include EDIF and VHDL cores. The SignOnce and ASIC licenses allows unlimited

instantiations. The EDIF core can be used for Virtex–2, Spartan–3 and Virtex–4 with Foundation or ISE software. The VHDL core can be used for Virtex–5, Spartan–6, Virtex–6, 7–Series, UltraScale and UltraScale+ with ISE or Vivado software.

Note that *Small World Communications* only provides software and does not provide the actual devices themselves. Please contact *Small World Communications* for a quote.



#### References

[1] Consultative Committee for Space Data Systems, "Recommendation for space data system standards: TM Synchronization and channel coding," CCSDS 131.0–B–3, Blue Book, Sep. 2017.

Small World Communications does not assume any liability arising out of the application or use of any product described or shown herein; nor does it convey any license under its copyrights or any rights of others. Small World Communications reserves the right to make changes, at any time, in order to improve performance, function or design and to supply the best product possible. Small World Communications will not assume responsibility for the use of any circuitry described herein. Small World Communications does not represent that devices shown or products described herein are free from patent infringement or from any other third party right. Small World Communications assumes no obligation to correct any errors contained herein or to advise any user of this text of any correction if such be made. Small World Communications will not assume any liability for the accuracy or correctness of any engineering or software support or assistance provided to a user.

© 2008–2023 *Small World Communications*. All Rights Reserved. Xilinx, Spartan, Virtex, 7–Series, Zynq, Artix, Kintex, UltraScale and UltraScale+ are registered trademarks and all XC– prefix product designations are trademarks of Advanced Micro Devices, Inc. and Xilinx, Inc. All other trademarks and registered trademarks are the property of their respective owners.

Small World Communications, 6 First Avenue,

Payneham South SA 5070, Australia.info@sworld.com.auph. +61 8 8332 0319http://www.sworld.com.aufax +61 8 7117 1416

## **Revision History**

- 1.00 25 July 2008. First release
- 1.02 4 Oct. 2010. Deleted Virtex–II performance. Updated Virtex–5 performance. Added Spartan–6 and Virtex–6 performance. Updated Virtex–5 complexity.
- 1.03 7 Dec. 2017. Added Revision History. Deleted Spartan–3, Spartan–6 and Virtex–4 performance. Updated Virtex–5 and Virtex–6 performance. Added Zynq–7, Artix–7 and Kintex–7 performance. Deleted Virtex–II and Virtex–5 complexity. Added Kintex–7 complexity. Corrected XA in Figure 3. Corrected (1) and *K* in Figures 3 and 4.
- 1.04 22 Apr. 2020. Updated CCSDS reference.
- 1.05 4 Aug. 2023. Corrected Figure 4. Deleted Virtex–5, Virtex–6 and Zynq–7 performance. Updated Artix–7 and Kintex–7 performance. Added Spartan–7, UltraScale and UltraScale+ performance.