# Τεміс

MATRA MHS

## **JPEG Decoder**

### Description

The 29C82 performs decompression of still pictures in accordance with the ISO JPEG 8 R6 standard for basic systems (pixels coded in 8 bits, sequential display, HUFFMAN coding, etc). The 29C82 independently executes most following of the adaptive discrete cosine transform (ADCT) algorithm :

- VLC (HUFFMAN) decoding using tables created by the user or contained in the JPEG image frame. Two AC tables and two DC tables can be loaded into the 29C82.
- de-quantization using tables contained in the JPEG image frame. Two DC tables and two AC tables can be loaded into the 29C82.
- inverse COSINE transform.

### Features

- Decoding of still images to the ISO JPEG-8 Rev6 standard.
- Performs VLC decoding, de-quantization and inverse discrete cosine transform (IDCT).
- Maximum system clock frequency : CLK = 20 MHz.
- Maximum output bit rate : 1.25 mega-pixels/s on the private bus.

Figure 1. Application Block Diagram using 29C82

The 29C82 is a peripheral circuit which communicates with the microprocessor over the DATA [0..7] and ADDRESS [0..3] busses. The microprocessor performs decoding of the JPEG image frame header in order to extract the markers, the image parameters, the quantization, and the VLC tables. These tables and parameters are then used to program the 29C82. After decoding, the pixels are available on pixels bus PIXEL[0..7] of the 29C82 or on the DATA [0..7] system bus. The 29C82 is able to provide pixels at a speed of 1.25 MPixels/s on PIXEL[0..7], with the system clock (CLK) at 20 MHz.

- 8-bit microprocessor interface.
- Dedicated 8-bit pixel bus
- 5 V DC power supply.
- Package : PLCC68



SYSTEM

\* CCETT License

This data sheet includes information obtained from CCETT

TEMIC MATRA MHS

#### Architecture

#### Figure 2. 2982 Block Diagram



The 29C82 is a peripheral circuit, the system bus of which is compatible with a demultiplexed address/data bus of the INTEL type. It contains 4 blocks which are interconnected over the internal bus (BUSDIF). The internal "VLC decoder", "de-quantization operator" and "DCT operator" blocks are also interconnected over a data path which enables the passage of coefficients between the various blocks to be optimized, and the traffic on the internal BUSDIF bus to be reduced. After decompression over the various stages mentioned previously, the pixels can then be read by the system bus (over BUSDIF) or on the PIXEL[7..0] private bus.

The 29C82 includes the following blocks :

- the VLC block :
  - VLC decoder (see appendix 3).
  - 2 VLC DC tables, each containing  $32 \times 5$  bits.
  - 2 VLC AC tables, each containing  $512 \times 9$  bits.
  - 2 sets of registers (Nblock and Mux)

the de-quantization block

- the de-quantization operator (see appendix 1).
- 4 de-quantization tables, each containing 64 levels.
- 1 programming register (PROGRAMQ)
- the IDCT block :
- 1 inverse DCT operator of the Duhamel-Guillemot type
- 1 output FIFO with two 64-byte pages working alternately each page can be accessed by the DATA[7..0] system bus or by the PIXEL[7..0] bus (like a single 64-bit FIFO).
- the microprocessor interface
  - 1 interrupt monitor with status and control registers.
  - 1 interface block to allow connection to a microprocessor over the DATA[7..0] bus, the ADDR[3..0] bus, WR, RD, CS and READY.

**29C82** 

### **Pin Configuration**

Figure 3. 29C82 68 pin PLCC Package. Top View



| NAME                                                        | ТҮРЕ                                           | FUNCTION                                                                                                                                                    |
|-------------------------------------------------------------|------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Vdd (A1/A4)<br>Vdd (A3)<br>Vdd (A2)<br>Vdd (B2)<br>Vdd (B1) | supply<br>supply<br>supply<br>supply<br>supply | core positive supply (+ 5V)<br>core positive supply (+ 5V)<br>core positive supply (+ 5V)<br>buffer positive supply (+ 5V)<br>buffer positive supply (+ 5V) |
| Vss (A1)<br>Vss (A2)<br>Vss (A3/A4)<br>Vss (B1)<br>Vss (B2) | supply<br>supply<br>supply<br>supply<br>supply | core negative supply (0V)<br>core negative supply (0V)<br>core negative supply (0V)<br>buffer negative supply (0V)<br>buffer negative supply (0V)           |
| CLK                                                         | Ι                                              | reference clock                                                                                                                                             |
| RESET                                                       | Ι                                              | hardware reset (active high)<br>table contents are not changed by reset                                                                                     |
| DATA[70]                                                    | I/O                                            | 8 bit system DATA bus                                                                                                                                       |
| ADDR[30]                                                    | Ι                                              | 4 bit system ADDRESS bus                                                                                                                                    |
| CS                                                          | Ι                                              | chip select active low                                                                                                                                      |
| RD                                                          | Ι                                              | READ active low                                                                                                                                             |
| WR                                                          | Ι                                              | WRITE active low                                                                                                                                            |
| READY                                                       | 0                                              | READY output signal active low                                                                                                                              |

#### MATRA MHS

| NAME      | ТҮРЕ | FUNCTION                                                                              |
|-----------|------|---------------------------------------------------------------------------------------|
| INT       | 0    | interrupt signal active high                                                          |
| PRQ       | Ι    | pixel request used to request from 29C82 a block of pixels on pixel bus (active high) |
| PIXEL[07] | 0    | 8 bit tristate pixel bus (at CLK frequency)                                           |
| CTYPE[10] | 0    | component type (tree state) user defined code (ex : cyan, green, Y)                   |
| BLKRDY    | 0    | block ready, indicates that a new 64 pixel block is available (active high)           |
| PIXOUT    | 0    | pixel out flag, indicates that pixels are present on pixel bus (active high)          |
| TEST1     | Ι    | TEST pin, should be left floating in normal mode                                      |
| TEST2     | Ι    | TEST pin, should be left floating in normal mode                                      |

### **Description of Inputs And Outputs**

Initialization of the 29C82, loading of the blocks to be decoded into the input FIFO (FIFE), and pixel read after decoding, are all accomplished over the microprocessor interface connected to an ADDR[3..0]/ DATA[7..0] demultiplexed bus. The 29C82 is a peripheral circuit of the microprocessor, it is accessed the 29C82 through a 16-address window which corresponds to registers, tables or FIFOs. A STATUS register, combined with an INTerrupt register, informs the  $\mu$ P on any detected change in status or errors.

A PIXEL[7..0] bus, dedicated to an image memory interface, is used to read the pixels after decompression. This bus is able to carry  $8 \times 8$  pixel blocks (line by line) at a system clock frequency of 20 MHz. When the bus is not used (pixel output on the system bus), PIXEL (7..0] and CTYPE[1..0] are in the high-impedance mode in order to allow the connection of several 29C82's in parallel.

#### Figure 4. 29C82 Read/Write Bus Cycles



#### MATRA MHS

#### Figure 5. Pixel Block Output Timing



#### **Description of the Registers**

The microprocessor communicates with the 29C82 over an 8-bit data bus and a 4 bits address bus, (16 possible addresses). When one of these 16 addresses corresponds to a FIFO or a table or a multiple register, read or write access to the various parts of the FIFO, table or register set is accomplished sequentially, keeping the address on ADDR[3..0] constant.

#### The VLC Tables

The 29C82 contains 4 VLC tables. Two are for DC coefficients and two for AC coefficients. Each VLC table contains the HUFFMAN tree associated with decoding of the various AC and DC coefficients.

• the DC tables

٠

address: T0\_DC: 00H.

```
T1_DC: 03H.
```

depth :  $32 \times 5$ -bit words **centered** on the 5 LSB's of the byte written over the microprocessor bus. Access : write in sequential mode. T0\_DC/T1\_DC selection is performed in the

NTAB register of the GENMUX register set.

- the AC tables
  - address: T0\_AC: 01H (Nodes) and 02H (leaves). T1\_AC: 04H (Nodes) and 05H (leaves).

- depth : 512 × 9-bit words, with the 9th bit (LSB) obtained by address decoding. This is forced to 1 for a leaf of the HUFFMAN tree, and to 0 for a node of the tree.
- access : write in sequential mode.

#### **The Quantization Tables**

The 29C82 contains 4 quantization tables :

• address Q0:09H

| Q1 : | 0AH |
|------|-----|
| Q2 : | 0BH |
| Q3 : | 0CH |

- depth :  $64 \times 8$ -bit words
- access : write in sequential mode.

The threshold levels in the quantization tables are written into Q0 to Q3 in the following order :

| 01- | ×02-       | •06 –      | ×07- | ×15− | ×16− | ×28-                  | ≥29            |
|-----|------------|------------|------|------|------|-----------------------|----------------|
| K   | ' L        | ' K        | ' ¥  | ' ¥  | ' ¥  | / ¥                   | /              |
| 03  | 05         | 08         | 14   | 17   | 27   | 30                    | 43             |
| 1 1 | * <i>L</i> | ' 7        | n k  | / /  | 1 K  | / /                   | ″↓             |
| 04  | 09         | 13         | 18   | 26   | 31   | 42                    | 44             |
| K   | ' 1        | ' ¥        | / /  | 1 K  | / /  | <i>n</i> <sub>k</sub> | /              |
| 10  | 12         | 19         | 25   | 32   | 41   | 45                    | 54             |
| 1 1 | 7          | 7          | 1    | /    | 1    | /                     | ″↓             |
| 11  | 20         | 24         | 33   | 40   | 46   | 53                    | 55             |
| K   | ' 1        | ' <i>v</i> | / /  | 1 K  | / /  | 1 K                   | /              |
| 21  | 23         | 34         | 39   | 47   | 52   | 56                    | 61             |
| 1 1 | * <i>L</i> | ' 7        | n k  | / /  | 1 K  | / /                   | ″↓             |
| 22  | 35         | 38         | 48   | 51   | 57   | 60                    | 62             |
| K   | ' 1        | ' <i>v</i> | / /  | 1 K  | / /  | 1 K                   | /              |
| 36- | ≥37        | 49-        | ≥50  | 58-  | ⇒59  | 63 -                  | <b>&gt;</b> 64 |

Q0 to Q3 selection is accomplished using the PROGRAMQ register.

# **29C82**

# TEMIC MATRA MHS

## Registers

|                      |                           |             |                    | 7       |             |         |         |          |             |          |      |                      |                        |                |                     |            | 7        | dea     | ared t  | by RI   | ESET                | •                            | 0             |
|----------------------|---------------------------|-------------|--------------------|---------|-------------|---------|---------|----------|-------------|----------|------|----------------------|------------------------|----------------|---------------------|------------|----------|---------|---------|---------|---------------------|------------------------------|---------------|
| ADDR<br>(hex)<br>00H | NAME                      | type<br>W   | DEPTH<br>32 bytes  | d7      | d6          | d5      | d4      | d3       | d           | 2 d      | 11   | d0 (h<br>0           | DR NAM<br>ex) MU<br>8H | ME TYI<br>XGEN | PE DEPT<br>W 7 byte | н<br>ж     | ×        | ×       | ×       | ×       | V<br>CC<br>n_<br>BC | LCT<br>MP<br>CT<br>CT<br>T n | x<br>X]<br>X] |
|                      |                           |             | L                  | 1       |             |         | L       |          | _ <b>_</b>  |          |      | !                    |                        |                |                     |            |          | k       |         |         | L                   |                              |               |
| ADDR<br>(hex)<br>01H | NAME<br>T0_AC<br>(nodes)  | type<br>W   | DEPTH<br>256 bytes | d7      | d6          | d5      | d4      | dЗ       | d2          | d1       | d0   | ADDF<br>(hex)<br>09H | NAME<br>Q0<br>quantif  | TYPE<br>W      | DEPTH<br>64 bytes   | d7         | d6       | d5      | d4      | d3      | d2                  | d1                           | d0            |
|                      |                           |             |                    |         |             |         |         |          |             |          |      |                      |                        |                |                     |            |          |         |         |         |                     |                              |               |
| ADDR<br>(hex)<br>02H | NAME<br>T0_AC<br>(leaves) | TYPE<br>W   | DEPTH<br>256 bytes | d7      | d6          | d5      | d4      | d3       | d2          | d1       | d0   | ADDF<br>(hex)<br>AH  | NAME<br>Q1<br>quantif  | TYPE<br>W      | DEPTH<br>64 bytes   | d7         | d6       | d5      | d4      | d3      | d2                  | d1                           | d0            |
|                      |                           |             |                    |         |             |         |         |          |             |          |      |                      |                        |                |                     |            |          |         |         |         |                     |                              |               |
| ADDR<br>(hex)<br>03H | NAME<br>T1_DC             | type<br>W   | DEPTH<br>32 bytes  | d7      | d6          | d5      | d4      | d3       | d2          | d1       | d0   | ADDF<br>(hex)<br>BH  | NAME<br>Q2<br>quantif  | TYPE<br>W      | DEPTH<br>64 bytes   | d7         | d6       | d5      | d4      | d3      | d2                  | d1                           | d0            |
|                      |                           |             |                    |         |             |         |         |          |             |          |      |                      |                        |                |                     |            |          |         |         |         |                     |                              |               |
| ADDR<br>(hex)<br>04H | NAME<br>T1_AC<br>(nodes)  | type<br>W   | DEPTH<br>256 bytes | d7      | d6          | d5      | d4      | d3       | d2          | d1       | d0   | ADDF<br>(hex)<br>CH  | NAME<br>Q3<br>quantif  | type<br>W      | DEPTH<br>64 bytes   | d7         | d6       | d5      | d4      | d3      | d2                  | d1                           | d0            |
|                      |                           |             |                    |         |             |         |         |          |             |          |      |                      |                        |                |                     |            |          |         |         |         |                     |                              |               |
|                      |                           |             |                    |         |             |         |         |          |             |          | _    |                      |                        |                |                     | 7          | 1        | dea     | ared I  | by RI   | ESEI                | -                            | 0             |
| ADDR<br>(hex)<br>05H | NAME<br>T1_AC<br>(nodes)  | TYPE<br>W   | DEPTH<br>256 bytes | d7      | d6          | d5      | d4      | 3 Ct     | 12 0        | 11 d     | 0    | ADDR<br>(hex)<br>0DH | PROGRA                 | VIQ V          | PE DEPI<br>/ 1byt   | e j        | OCT 3 U] | QCT2[1] | QCT2[0] | QCT1[1] | OCT1[0]             | OCTO[1]                      | QCT0[0]       |
|                      |                           |             |                    | L       | L           | ł       |         | <b>!</b> | <b>-</b>    | <b>I</b> |      |                      |                        |                |                     | -          |          |         | -       | -       | 1                   |                              |               |
|                      |                           |             |                    |         |             |         |         |          |             |          |      |                      |                        | _              |                     | 7          | dea      | ared b  | by ha   | rdwa    | re Ri               | ESE                          | TO            |
| ADDR                 | NAME                      | TYPE        | DEPTH<br>64 bytes  | d7      | d6          | d5      | d4      | d3 0     | 12 0        | 11 d     | 0    | ADDR<br>(bex)        |                        | TY<br>DL V     | PE DEPT<br>V 1.bvt  | H d<br>e 2 |          |         |         | INT3    | INT2                |                              | RESE          |
| 06H                  |                           |             | <i>04 0</i> 7100   |         |             |         |         |          |             |          |      | EH                   |                        |                |                     |            | គ ទ្រ    | ਜ<br>ਜਿ | Ŕ       | Z       | B                   | Z                            | 4             |
|                      |                           |             |                    |         |             |         |         |          |             |          |      |                      |                        |                |                     |            |          |         |         |         |                     |                              |               |
|                      |                           |             |                    | 7       | d           | eare    | dby     | RES      | ET          |          | 0    |                      |                        |                |                     | 7          | dea      | ared t  | by ha   | irdwa   | are R               | ESE                          | T 0           |
|                      |                           | TYPE<br>BM/ | DEPTH<br>3 bytes   | NBLK[22 | NBLK(22     | NBLK[22 | NBLK[21 | NBLK[20  | VBLK[19     | BLK18    |      | ADDR<br>(hex)        | NAME<br>STATUS         | ТҮ<br>В. Р     | PE DEPT<br>3. 1.bvi |            |          |         |         |         |                     |                              | FIFE          |
| 07H                  |                           |             |                    | ,16,7]  | .14,6]      | 16,7]   | 12,6]   | 12,4]    | 11,2]       | 10.21    | 202  | ΈH                   |                        | -              |                     | Ξ          | 3 3      |         | N S     | Ϋ́      | ۶                   | RR                           | 5             |
|                      |                           |             |                    |         |             |         |         |          |             |          |      |                      |                        |                |                     |            |          |         |         |         |                     |                              |               |
|                      |                           |             |                    | A       | DDF         | 1 8     | MAN     | E        | ty <b>p</b> | EC       | DEP  | тн 📃                 |                        |                |                     | ]          |          |         |         |         |                     |                              |               |
|                      |                           |             |                    | (       | (hex)<br>FH | м       | EMF     | NX       | R           | 12       | 28 b | ytes a7              | 06 05 0                | 14 03 0        |                     |            |          |         |         |         |                     |                              |               |

#### MATRA MHS

The FIFO's

The input FIFO - FIFE

- address : 06H
- depth : 64 bytes
- access type : sequential write
- pointer reset by hardware or software RESET

Write access to FIFE is made through the mP bus. Reading from FIFE is done via the VLC decoder. The FIFE\_MT bit of the status register is used to indicate that FIFE is three-quarters empty (3 16 bytes available in FIFE). The microprocessor is responsible for limiting the number of write into the FIFO so that its capacity is not exceeded. When the FIFO is 100% empty, the VLC decoder does not hold up 29C82 operation.

The output FIFO - MEMPIX

- address : 0F
- depth : 64 bytes 2 y 64
- access type : sequential read
- pointer reset by RESET

Writing to the output Pixel FIFO (MEMPIX) is achieved using the DCT operator. Read is accomplished :

- over the PIXEL[7..0] bus if PIX\_BUS = 1 (CONTROL register)
- over the DATA[7..0] bus if  $PIX_BUS = 0$

The PIXELS FIFO is splitted into two pages of 64 bytes, accessed alternately by the DCT operator. While the operator is calculating the inverse DCT for a block of 8x8 coefficients, the second page of 64 bytes can be accessed over the PIXEL[7..0] bus or via the DATA[7..0] bus to output the results of the DCT calculation on the preceding 8x8 block. When the output FIFO is full up, the BLK\_RDY bit of the STATUS register goes to 1, and an interrupt (INT) is activated if this has been enabled by the INT3\_EN bit in the CONTROL register.

The registers

| CONTROL address : 0EH |         |         |         | Access type : w    | RESET Hardware     |                    |               |  |
|-----------------------|---------|---------|---------|--------------------|--------------------|--------------------|---------------|--|
| START                 | PIX_BUS | CL_FIFE | RSC_ACK | INT3_EN<br>BLK_RDY | INT2_EN<br>FIFE_MT | INT1_EN<br>VLC_ERR | RESET<br>SOFT |  |
| 7                     | 6       | 5       | 4       | 3                  | 2                  | 1                  | 0             |  |

#### START : DECODING START.

START=1 enables the start of image decoding. This bit is reset to 0 one clock period (CLK) after it has been written to 1 in the control register.

#### PIX\_BUS : BUS PIXEL

- PIX\_BUS=0. Read access to the output FIFO, MEMPIX, occurs over the microprocessor bus. The PIXEL[7..0] and CTYPE[1..0] outputs are in the high-impedance state, PIXOUT=0, BLKRDY is active and PRQ is inactive.
- PIX\_BUS=1, read access to the output FIFO is performed over the PIXEL[7..0] private bus.
- CL\_FIFE : Input FIFO reset CL\_FIFE=1 causes a zero reset of the input FIFO, FIFE. This bit is automatically reset to 0 one CLK period after it has been written to 1 in the CONTROL register.

RSC\_ACK : DECODING OF THE RESYNCHRO-NISATION MARKERS. RSC\_ACK=1 enables decoding of the RSC0(FFD0) to RSC7(FFD7) markers. Note: The JPEG standard specifies the use of re-synchronisation markers in order to segment the image. These markers are alined on the byte borders. They can be used for partial re-transmission of images after detection of errors.

#### The Interrupts

When the INTx\_EN enable bit is at 1, the interrupt request (INT) can be activated :

- INT3\_EN : if the output FIFO, MEMPIX, contains a full block of 8x8pixels (bit BLK\_RDY=1 in the STATUS register). Reading a single pixel from MEMPIX causes a reset of the interrupt request.
- INT2\_EN : if the input FIFO, FIFE, is three-quarters empty (bit FIFE\_MT=1 in the STATUS register).
- INT1\_EN : when a VLC decoding error is detected (bit VLC\_ERR=1 in the STATUS register).

The microprocessor must read the STATUS register to identify the cause of the interrupt. One interrupt process cycle allows the output INT to be forced to 0 (at least

during the cycle period) and the associated interrupt request to be de-activated in the following way :

- INT-1 (VLC error) : read NBLOCK register. If INT-2 or INT-3 are active, INT goes back to 1 after fully reading NBLOCK (3 bytes).
- INT-2 (FIFE three-quarters empty) : a write to FIFE is used to reset the FIFE\_MT bit of the STATUS register to 0, and to force the INT output to 0. If INT-1 or INT-3 are active, INT goes back to 1 after the write cycle to FIFE. Caution : the fact that one or more bytes

have been written to FIFE after an INT-2 interrupt request does not necessarily cause the FIFO pointer to go to a value over 16 (the 3/4 empty level). In such a case, a new INT-2 interrupt occurs.

INT-3 (block ready in the output FIFO) : reading (one pixel only) from MEMPIX resets BLK\_RDY (the status register) and the BLKROY/INT outputs to "0". If INT-1 or INT-2 are active, INT goes back to 1 after the first read cycle from MEMPIX.



- INT3\_EN : "OUTPUT BLOCK READY" INTERRUPT ENABLE. INT3\_EN=1 enables transmission of INT-3 (BLOCK READY) interrupt request to the microprocessor.
- INT2\_EN : "FIFE 3/4 EMPTY" INTERRUPT ENABLE. INT2\_EN=1 enables transmission of INT-2 (FIFE 3/4 EMPTY) interrupt request to the microprocessor.
- INT1\_EN : "VLC ERROR" INTERRUPT ENABLE. INT1\_EN=1 enables transmission of INT-2

(VLC ERROR) interrupt request to the microprocessor.

RESET : SOFTWARE RESET RESET=1 is used to re-initialise the internal STATUS register and also the FIFO pointers without affecting the contents of the tables and the CONTROL, PROGRAMQ, NBLOCK, and MUXGEN registers. This bit is automatically reset to 0 one CLK period after it has been written to "1".

| STATUS   | address 01 | EH      | Access Type : r    | ead                | RESET SOFTWARE or HARDWARE |         |         |  |  |
|----------|------------|---------|--------------------|--------------------|----------------------------|---------|---------|--|--|
| CTYP [1] | CTYP [0]   | BLK_RDY | DCT_BSY<br>RSC [2] | QZT_BSY<br>RSC [1] | VLC_BSY<br>RSC [0]         | VLC_ERR | FIFE_MT |  |  |
| 7        | 6          | 5       | 4                  | 3                  | 2                          | 1       | 0       |  |  |

#### MATRA MHS

- CTYP[1..0] : COMPONENT TYPE. These two bits are used to indicate the image component to which the pixel block available in MEMPIX belongs. The CTYPE[1..0] bits are in the same state as the CTYPE[1..0] outputs.
- BLK\_RDY: PIXEL BLOCK READY. The BLK\_RDY bit goes to 1 when a new 8 × 8 pixel block is available in MEMPIX. BLK\_RDY bit is in the same state as the BLKRDY output.
- DCT\_BSY: DCT OPERATOR ACTIVE (FOR INFORMATION ONLY). DCT\_BSY=1 indicates that the reverse DCT operator is active. If bit VLC\_ERR=1, this bit is re-defined as RSC[2] (see description of the VLC\_ERR bit).
- QZT\_BSY: DE-QUANTIZATION OPERATOR ACTIVE (FOR INFORMATION ONLY). QZT\_BSY=1 indicates that the de-quantization operator is active. If bit VLC\_ERR=1, this bit is re-defined as RSC[1] (see description of the VLC\_ERR bit).
- VLC\_BSY: VLC DECODING OPERATOR ACTIVE (FOR INFORMATION ONLY). VLC\_BSY=1 indicates that the VLC operator is active. If bit VLC\_ERR=1, this bit is re-defined as RSC[0] (see description of the VLC\_ERR bit). The VLC operator is always active, even if FIFE is completely empty. VLC\_BSY is reset to 0 only after a RESET and before the START bit has been set to 1.

VLC\_ERR : VLC ERROR. VLC\_ERR=1 indicates that a VLC decoding error has been detected. This type of error can be caused by :

> – detection of an EOI or RSC marker with the content of the NBLOCK register different from 0.

> – detection of a VLC code with a length of more than 16 bits.

– a coefficient pointer over 63.

In this case, the RSC[2..0] of the status register represent the three LSB's of the last re-synchronisation marker detected before the error. Output INT goes to 1 if bit INT1\_EN of the CONTROL register is at 1. The microprossor reads from NBLOCK the number of blocks remaining to be (NBLOCK decoded acts as а down-counter) in order to reset the interrupt and the VLC ERR bit to 0. In the case where there is no re-synchronisation, the  $\mu P$  (APPLICATION) selects the strategy to be used (re-transmission of BLOCK, SCAN, FRAME, IMAGE, etc.) When one or more re-synchronisation markers exist, the 29C82 waits for the next resynchronisation marker so that it can continue decoding of the current image.

FIFE\_MT : FIFE 3/4 EMPTY. FIFE\_MT=1 when the input FIFO, FIFE, is three-quarters empty (16 bytes left ≤). When the INT2\_EN bit of the CONTROL register is at 1, the INT output goes to 1. In this case, the microprossor can write 48 new bytes into FIFE.

| PROGRAMQ | â        | address 0DH | Access   | s type : write | Reset : HARDWARE |          |          |  |
|----------|----------|-------------|----------|----------------|------------------|----------|----------|--|
| QCT3 [1] | QCT3 [1] | QCT2 [1]    | QCT2 [0] | QCT1 [1]       | QCT1 [0]         | QCT0 [1] | QCT0 [0] |  |
| 7        | 6        | 5           | 4        | 3              | 2                | 1        | 0        |  |

QCT3[1..0] : "QUANTIZATION TABLE" REFERENCE FOR COMPONENT 3. These two bits code the reference of the quantization table for a block which belongs to a type-3 image component.

QCT2[1..0] : "QUANTIZATION TABLE" REFERENCE FOR COMPONENT 2. These two bits code the reference of the quantization table for a block which belongs to a type-2 image component.

#### QCT1[1..0] : "QUANTIZATION TABLE" REFERENCE FOR COMPONENT 1. These two bits code the reference of the

quantization table for a block which belongs to a type-1 image component.

QCT0[1..0] : "QUANTIZATION TABLE" REFERENCE FOR COMPONENT 0. These two bits code the reference of the quantization table for a block which belongs to a type-0 image component.

TEMIC MATRA MHS

### The Multiple Registers

| NBLOCK addre<br>depth | ess 07H<br>n : 3 bytes | Access typ<br>RESET HA | e : sequential read.<br>ARDWARE | /write   |          |          |          |
|-----------------------|------------------------|------------------------|---------------------------------|----------|----------|----------|----------|
| NBLK[23]              | NBLK[22]               | NBLK[21]               | NBLK[20]                        | NBLK[19] | NBLK[18] | NBLK[17] | NBLK[16] |
| 7                     | 6                      | 5                      | 4                               | 3        | 2        | 1        | 0        |
| NBLK[15]              | NBLK[14]               | NBLK[13]               | NBLK[12]                        | NBLK[11] | NBLK[10] | NBLK[09] | NBLK[08] |
| 7                     | 6                      | 5                      | 4                               | 3        | 2        | 1        | 0        |
| NBLK[07]              | NBLK[06]               | NBLK[05]               | NBLK[04]                        | NBLK[03] | NBLK[02] | NBLK[01] | NBLK[00] |
| 7                     | 6                      | 5                      | 4                               | 3        | 2        | 1        | 0        |

#### NBLK[23..0] : NUMBER OF BLOCKS

NBLK[23..0] contains the number of blocks to be decoded between the two markers (RSC\_ACK=1) or for a full image (RSC\_ACK=0). The 29C82 uses NBLOCK as a down-counter.

MUXGEN address 08H Access type : sequential write depth : 7 bytes RESET HARDWARE

The ADCT algorithm allows two interlacing modes :

- the frame interlace mode, where each component is coded separately and transmitted sequentially for a complete image (e.g. press images, "yellow", "blue", "red", "black" transmission).

The block interlacing mode, where the 8x8 blocks are interlaced in accordance with a repeating pattern (MDU) (e.g. Videotext transmission of two 8x8 luminance blocks, one  $8 \times 8$  "red" chrominance block, 1 "blue" chrominance block, ...)

MUXGEN contains 7 registers :

| NTAB |   |   |   |   |       |       |       |       |
|------|---|---|---|---|-------|-------|-------|-------|
| X    | X |   | Х | Х | VLCT3 | VLCT2 | VLCT1 | VLCT0 |
| 7    | · | 6 | 5 | 4 | 3     | 2     | 1     | 0     |

VLCT3: VLC TABLE FOR TYPE-3 IMAGE VLCT1: COMPONENT. This bit indicates which VCL table will be used for a block belonging to the type-3 component. ("0" for T0\_DC/ T0\_AC and "1" for T1\_DC/T1\_AC).
VLCT2: VLC TABLE FOR TYPE-2 IMAGE VLCT0: COMPONENT.

This bit indicates which VCL table will be used for a block belonging to the type-2 component. ("0" for T0\_DC/ T0\_AC and "1" for T1\_DC/T1\_AC). VLCT1: VLC TABLE FOR TYPE-1 IMAGE COMPONENT.

This bit indicates which VCL table will be used for a block belonging to the type-1 component. ("0" for T0\_DC/T0\_AC and "1" for T1\_DC/T1\_AC).

VLC TABLE FOR TYPE-0 IMAGE COMPONENT.

This bit indicates which VCL table will be used for a block belonging to the type-0 component. ("0" for T0\_DC/T0\_AC and "1" for T1\_DC/T1\_AC).

NCOMP

| Х | Х | Х | Х | Х | Х | COMP[1] | COMP[0] |
|---|---|---|---|---|---|---------|---------|
| 7 | 6 | 5 | 4 | 3 | 2 | 1       | 0       |

#### COMP[1..0] : NUMBER OF IMAGE COMPONENTS

COMP[1..0] contains the number of image components to be decoded :  $11 \rightarrow 4$  components

 $10 \rightarrow 3$  components  $01 \rightarrow 2$  components  $00 \rightarrow 1$  components

ORDER

| 1_CT[1] | 1_CT[0] | 2_CT[1] | 2_CT[0] | 3_CT[1] | 3_CT[0] | 4_CT[1] | 4_CT[0] |
|---------|---------|---------|---------|---------|---------|---------|---------|
| 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |

The "quantization table", "VLC table"..., data associated with each image component are clearly specified in the JPEG header (see appendix 2). The ORDER register is used to associate indirectly a component type with a component of the JPEG frame. The PROGRAMQ and NTAB registers are used to associate the VLC and quantization tables with each component type.

1\_CT[1..0]: TYPE OF FIRST COMPONENT. These two bits code the type of the first component to be processed.

BLOCK-0

| BCT0[7] | BCT0[6] | BCT0[5] | BCT0[4] | BCT0[3] | BCT0[2] | BCT0[1] | BCT0[0] |
|---------|---------|---------|---------|---------|---------|---------|---------|
| 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |

## BCT0[7..0]: NUMBER OF SUCCESSIVE BLOCKS FOR TYPE-0 COMPONENT.

The BLOCK-0 register indicates (in 8 bits) the number of successive  $8 \times 8$  blocks contained in 1 MDU.

2\_CT[1..0]: TYPE OF FIRST COMPONENT. These

component to be processed.

3\_CT[1..0]: TYPE OF FIRST COMPONENT. These

component to be processed.

4 CT[1..0]: TYPE OF FIRST COMPONENT. These

component to be processed.

two bits code the type of the second

two bits code the type of the third

two bits code the type of the fourth

| BCT1[7] | BCT1[6] | BCT1[5] | BCT1[4] | BCT1[3] | BCT1[2] | BCT1[1] | BCT1[0] |
|---------|---------|---------|---------|---------|---------|---------|---------|
| 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |

#### BCT1[7..0]: NUMBER OF SUCCESSIVE BLOCKS FOR TYPE-1 COMPONENT.

The BLOCK-1 register indicates (in 8 bits) the number of successive  $8 \times 8$  blocks contained in 1 MDU.

BLOCK-2

| Γ | BCT2[7] | BCT2[6] | BCT2[5] | BCT2[4] | BCT2[3] | BCT2[2] | BCT2[1] | BCT2[0] |
|---|---------|---------|---------|---------|---------|---------|---------|---------|
|   | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |

#### BCT2[7..0]: NUMBER OF SUCCESSIVE BLOCKS FOR TYPE-2 COMPONENT.

The BLOCK-2 register indicates (in 8 bits) the number of successive  $8 \times 8$  blocks contained in 1 MDU.

BLOCK-3

| BCT3[7] | BCT3[6] | BCT3[5] | BCT3[4] | BCT3[3] | BCT3[2] | BCT3[1] | BCT3[0] |
|---------|---------|---------|---------|---------|---------|---------|---------|
| 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |

#### BCT3[7..0]: NUMBER OF SUCCESSIVE BLOCKS FOR TYPE-3 COMPONENT.

The BLOCK-3 register indicates (in 8 bits) the number of successive  $8 \times 8$  blocks contained in 1 MDU.

### Initialisation

Before it can be used, the 29C82 has to be programmed by the microprocessor as follows :

- 1 the RESET bit of the CONTROL register is put to 1 for a partial reset, or a complete reset is achieved by forcing the RESET pin to 1.
- 2 in any order :
  - load the NBLOCK register
  - load the MUXGEN register
  - load the VLC table (example in appendix 4)
  - load the quantization tables (example in appendix 5)

- write to register PROGRAMQ
- write to the CONTROL register (START=0).
- 3 Put the START bit of the CONTROL register to 1.
- 4 Load the input FIFO (FIFE). This step can be programmed after setting CL\_FIFE and before setting the START bits.

After the 29C82 has started decoding, the microprocessor is able to poll the STATUS register or the state of the output INT to discover the state of progress of the current decoded block.

### **Electrical Characteristics**

#### **Absolute Maximum Ratings**

#### **Operating Characteristics**

| VCC to earth          | $\dots$ -0.5V to +7V  |
|-----------------------|-----------------------|
| Input/output voltage( | 0.3V to VCC + $0.3V$  |
| Storage temperature   | $\dots$ -65 to +150°C |

| VCC supply voltage | $\ldots$ 4.5V to +5.5V                    |
|--------------------|-------------------------------------------|
| Temperature        | $\ldots \ldots \ldots 0$ to $70^{\circ}C$ |
| Load capacity      | 50pF on each output                       |

#### **Electrical DC Characteristics**

| PARAMETER                           | CONDITIONS    | MIN   | MAX     |
|-------------------------------------|---------------|-------|---------|
| Input voltage VIL                   | Ι=5μΑ         |       | 0.8V    |
| Input voltage VIH                   | Ι=5μΑ         | 2.2V  |         |
| All inputs except Test 1 and Test 2 |               | – 5µA | + 5µA   |
| Test 1 and Test 2                   |               |       | + 100µA |
| Output voltage, level 0             | I = 6.4 mA    |       | 0.4V    |
| Output voltage, level 1             | 6.4mA         | 2.4 V |         |
| Dynamic consumption                 | VCC=5V, 20MHz |       | 120mA   |

MATRA MHS



#### **AC Timings**

VCC =  $5V \pm 10\%$ . Temperature = 0 to 70°C 50 pF load on all outputs

| NAME  | DESCRIPTION                     | MIN<br>ns | MAX<br>ns |
|-------|---------------------------------|-----------|-----------|
| tphch | PRQ to CLK setup time           | 20        |           |
| tchpl | PRQ to CLK hold time            | 5         |           |
| tchqv | CLK to PIXEL_BUS data delay     |           | 40        |
| tchqx | CLK to PIXEL_BUS not floating   | 5         |           |
| tchqz | CLK to PIXEL_BUS floating       |           | 35        |
| tdvwh | DATA[07] to WR setup time       | 5         |           |
| twhdx | DATA[07] to WR hold time        | 5         |           |
| twhyh | CS/WR high to READY low delay   |           | 20        |
| twlyl | CS/WR low to READY low delay    |           | 20        |
| tchcl | minimum high CLK pulse width    | 25        |           |
| tclch | minimum low CLK pulse width     | 25        |           |
| trlyl | CS/RD low to READY low          |           | 5tclk+30  |
| trhyh | CS/RD high to READY high        |           | 25        |
| trldv | RD/CS to DATA_BUS data delay    |           | 5tclk+35  |
| trldx | RD/CS to DATA_BUS not floating  |           | 5tclk+5   |
| trhdz | RD/CS high to DATA_BUS floating |           | 20        |
| tclk  | CLK period                      | 50        |           |
| twlwh | write pulse width               | 1tclk     |           |
| twhax | ADDR[30] / WR hold time         | 2tclk     |           |
| tavw  | address hold time (write)       | 3tclk     |           |
| trlrh | RD pulse width                  | 6tclk     |           |
| trhax | ADDR[30] / RD hold time         | 1tclk     |           |
| tavr  | address hold time (read)        | 7tclk     |           |

### **AC Timings**



## Appendix 1

### The various stages of ADCT

The successive stages of image de-compression for a basic JPEG system are the VLC coding (Huffman)

decoding, the dequantization and the Inverse cosine transform.



#### The two-dimensional Cosine Transform

The image is divided into  $8 \times 8$  pixel blocks and then polled in the order shown in figure 1. In the case of a 720  $\times$  576 pixel image in 4:2:2 for example, the image will be divided into  $90 \times 72$  blocks for Y luminance and  $45 \times 72$  blocks for Cr and Cb chrominance.

#### Figure 7.



#### Level transposition

Before applying the Cosine Transform to the unsigned data (Y,Cr,Cb) a level transposition is performed by subtracting 128 (for 8-bit data).

#### The Cosine Transform

For each block, the Cosine Transform is used to convert from the space domain (the pixels) to the frequency domain (the coefficients), by applying the direct Cosine Transform (FDCT).

$$F(u, v) = 1/4C(u) \cdot C(v) \sum_{i=0}^{7} \sum_{j=0}^{7} F(i, j) \cos(2i + 1)u \cdot \pi/16 \cdot \cos(2j + 1)v \cdot \pi i/16$$

or from the frequency domain to the space domain using the inverse Cosine Transform (IDCT).

$$F(i,j) = 1/4 \sum_{u=0}^{7} \sum_{v=0}^{7} C(u) \cdot C(v)F(u,v) \cos(2i + 1)u \cdot \pi/16 \cdot \cos(2j + 1)v\pi i/16$$

Figure 8.



#### Quantization

An essential property of the Cosine Transform is the concentration of the energy in the coefficients between

| DC | AC | Ą¢ | AC | AC | AC | AC | AC |
|----|----|----|----|----|----|----|----|
| AC |
| AC |
| AQ | AC |
| AC |
| AC |
| AC |
| AC |

Decreasing frequency

each 8x8 block into the DC component and some 'low-frequency' AC components.

Increasing frequency

# TEMIC

#### MATRA MHS

Since the human eye is not very sensitive to high-frequency AC components, these can be quantized in a coarser manner.

Each coefficient is quantized as follows :

F(u,v)0 : C(u,v) =

full division (F(u,v)+(Q(u,v)/2))/Q(u,v)F(u,v): C(u,v) =

full division (F(u,v) - (Q(u,v)/2))/Q(u,v)

F(u,v) is the coefficient before quantization C(u,v) is the coefficient after quantization Q(u,v) indicates no quantization

De-quantization is performed in a similar fashion :

$$F'(u,v) = C(u,v) * Q(u,v)$$

#### HUFFMAN coding

The average number of bits necessary to code a signal without loss of information can be measured by entropy of the signal. A procedure used commonly to construct the associated variable-length code words is known as HUFFMAN coding.

One intuitively associates short code words to frequent signal values and longer code words to the less frequent values.

c - association of Code

Rev. B (20/05/94)

Example :

| signal value | probability |
|--------------|-------------|
| 0            | .11         |
| 1            | .52         |
| 2            | .25         |
| 3            | .01         |
| 4            | .11         |
|              |             |

a - classification of probabilities in decreasing order, and grouping of the lowest probability values.

**29C82** 

.52, .25, .11, .11, .01 .52, .25, .12, .11, .52, .25, .23 .52, .48

b - construction of the HUFFMAN tree



| SIGNAL VALUE | SIGNAL VALUE PROBABILITY |           | CODE LENGTH |
|--------------|--------------------------|-----------|-------------|
| 1            | .52                      | 0         | 1           |
|              | .25                      | 10<br>111 | 2<br>3      |
| 4            | .11                      | 1100      | 4           |
| 3            | .01                      | 1101      | 4           |

This technique is used in the JPEG frame for coding the DC and AC components after quantization. Each  $8 \times 8$  block of coefficients is transmitted in the following

| 0  | 1  | 5  | 6  | 14 | 15 | 27 | 28 |
|----|----|----|----|----|----|----|----|
| 2  | 4  | 7  | 13 | 16 | 26 | 29 | 42 |
| 3  | 8  | 12 | 17 | 25 | 30 | 41 | 43 |
| 9  | 11 | 18 | 24 | 31 | 40 | 44 | 53 |
| 10 | 19 | 23 | 32 | 39 | 45 | 52 | 54 |
| 20 | 22 | 33 | 38 | 46 | 51 | 55 | 61 |
| 35 | 36 | 48 | 49 | 57 | 58 | 62 | 63 |

order : ~ 7 ~

0 = DC coefficient

A JPEG image is divided into signalling or data segments. Each segment starts with an FFxx marker in hex notation. The last xx byte of the marker identifies the function of the segment. The last data item of a segment is ended with a "1" so that FFxx is aligned on a byte border.

#### Figure 9.

| SOI  | FFD8 | IMAGE START                                                                                                                                                                                                                    |
|------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SOC  | FFFE | COMMENTS                                                                                                                                                                                                                       |
| DQT  | FFD8 | QUANTIZATION TABLES                                                                                                                                                                                                            |
| DHT  | FFC4 | VLC TABLES                                                                                                                                                                                                                     |
| S0F0 | FFC0 | FRAME<br>Parameter definition :<br>sample precisio,n number of line,s number of samples per lin,e num-<br>ber of components in fram,e vertical sampling factor horizontal<br>sampling facto,r selection of quantization table. |
| SOS  | FFDA | SCAN 1 Parameter definition : number of scan components, choice<br>of HUFFMAN matrix (AC, DC), choice of mode (sequential, pro-<br>gressive). Coded data                                                                       |
|      |      |                                                                                                                                                                                                                                |
| E0I  | FFD9 | IMAGE END                                                                                                                                                                                                                      |

#### Comments

Example

 fffe
 : COM marker

 0020
 : Comment length (30 usable bytes)

 432d 4355 4245 204d
 : MATRA MHS Electronic – APPLICATION LAB

 6963 726f 7379 7374
 : 1992

 656d 7320 496e 632e
 : JPEG image example

 2031 2e30 3000
 :

#### Quantization tables

The quantization tables are always included in the header of the frame (1 per component type).

Example

 ffdb
 : DQT marker

 007F
 : Table length (2 tables × 8 bits)

 00
 : Table 0 : luminance

 10 0b 0c 0e 0a 10 0e
 : Table 0 : luminance

 0d 0e 12 11 10 13 18 28
 : Table 25

 1a 18 16 16 18 31 23 25
 : Table 28 3a 33 3c 3c 39 33

 38 37 40 48 5c 4e 40 44
 : Table 37 38 50 6d 51 57

 5f 70 64 78 5c 65 67 63
 : Table 28 3a 33 3c 3c 39 33

#### MATRA MHS

01

: table 1 : Chrominance (Cr/Cb)

11 12 12 18 15 18 2f 1a 1a 2f 63 42 38 42 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63 63

#### The HUFFMAN Tables

#### Coding the DC coefficients

Only the DC coefficient of the first block is transmitted in the form of an absolute value. The following coefficients are transmitted differentially in relation to this first block. The value of the DC coefficient to be transmitted is divided into 16 categories coded in 4 bits, ssss, and corresponds to the length of the DC delta code to be sent :

| SSSS | DC delta                |
|------|-------------------------|
| 0    | 0                       |
| 1    | -1,+1                   |
| 2    | -3,-2,2,3               |
| 3    | -74,47                  |
| 4    | -158,815                |
| 5    | -3116,1631              |
| 6    | -6332,3263              |
| 7    | -12764,64127            |
| 8    | -255128,128255          |
| 9    | -511256,256511          |
| 10   | -1023512,5121023        |
| 11   | -20471024,10242047      |
| 12   | -40952048,20484095      |
| 13   | -81914096,40968191      |
| 14   | -163838192,819216383    |
| 15   | -3276716384, 1638432767 |

The DC coefficients are coded in the following manner :

|--|

HUF(ssss) = the HUFFMAN code associated with ssss

The HUFFMAN table (HUFCODE) associated with ssss is not transmitted directly in the JPEG image header. In fact two tables, [BITS] and [HUFVAL], are used for this :

2**9(`8**2

[BITS] is 16 bytes long and contains the number of ssss values (categories) coded in 1 bit, 2 bits, 3 bits ... 16 bits in the HUFFMAN table.

[HUFVAL] contains the list of ssss values (categories) sorted into ascending order of length of the HUFFMAN code (1 bit to 16 bits).

In a basic system, there can be a maximum of two [BITS] - [HUFVAL] pairs, transmitted by the DC coefficients.

| Example :            |                 |
|----------------------|-----------------|
| ffc4                 | : DHT marker    |
| 01a2                 | : Table length  |
| 00                   | : DC table 1    |
| 0001 0501 0101 0101  | : BITS matrix   |
| 00100 0000 0000 0000 |                 |
| 0001 0203 0405 0607  | : HUFVAL matrix |
| 0809 0a0b            | (12 elements)   |
| 01                   | : DC table 2    |
| 0003 0101 0101 0101  | : BITS matrix   |
| 0101 0100 0000 0000  |                 |
| 0001 0203 0405 0607  | : HUFVAL matrix |
| 0809 0a0b            | (12 elements)   |
|                      |                 |

# Creation of matrices [EHUFCO] and [EHUFSI] from [BITS] and [HUFVAL] (JPEG standard) :

The following algorithm is used to create the [HUFSIZE] table containing the length of the HUFFMAN codes

associated with ssss as a function of decreasing priority values :



The following algorithm is used to create the associated with ssss as a function of decreasing priority [HUFCODE] table containing the HUFFMAN codes values :



The following algorithm is used to reorganise HUFSIZE and HUFCODE as a function of decreasing ssss (HUFVAL) values :



Example

| SSSS | EHUHSI | EHUFCO    |
|------|--------|-----------|
| 0    | 3      | 010       |
| 1    | 3      | 011       |
| 2    | 3      | 100       |
| 3    | 2      | 00        |
| 4    | 3      | 101       |
|      |        |           |
| 11   | 9      | 111111110 |

The reconstitution of the HUFFMAN decoding tree (see appendix 1) can be accomplished using EHUFCO and EHUFSI :



#### Coding the AC coefficients

The AC coefficients to be transmitted are divided into 256 categories, coded in 8 bits, nnnnssss.

nnnn gives the number of coefficients equal to 0 between two non-zero coefficients, and ssss gives the amplitude category for the AC coefficients. 00000000 represents E0B which is the end-of-block indicator.

| ssss | AC coefficient          |
|------|-------------------------|
| 0    | 0                       |
| 1    | -1,+1                   |
| 2    | -3,-2,2,3               |
| 3    | -74,47                  |
| 4    | -158,815                |
| 5    | -3116,1631              |
| 6    | -6332,3263              |
| 7    | -12764, 64127           |
| 8    | -255128,128255          |
| 9    | -511256,256511          |
| 10   | -1023512,5121023        |
| 11   | -20471024,10242047      |
| 12   | -40952048,20484095      |
| 13   | -81914096,40968191      |
| 14   | -163838192,819216383    |
| 15   | -3276716384, 1638432767 |

The AC coefficients are coded in the following manner :

| HUF(nnnssss) | AC coefficient |
|--------------|----------------|
|--------------|----------------|

HUF(nnnssss) = the HUFFMAN code associated with nnnnssss

The HUFFMAN table (HUFCODE) associated with nnnnssss is not transmitted directly in the JPEG image header (ss DC coefficients). In fact two tables, [BITS] and [HUFVAL], are used for this.

In 16 bytes, [BITS] contains the number of nnnnssss values (categories) coded in 1 bit, 2 bits, 3 bits ... 16 bits in the HUFFMAN table.

[HUFVAL] contains the list of nnnnssss values (categories) sorted into ascending order of length of the HUFFMAN code (1 bit to 16 bits).

In a basic system, and for the AC coefficients, there can be a maximum of two [BITS] - [HUFVAL] pairs.

### Example

| 10                  |
|---------------------|
| 0002 0103 0302 0403 |
| 0605 0404 0000 017d |
| 0102 0300 0411 0612 |
| 2131 4106 1351 6107 |
| 2271 1432 8191 a108 |
| 2342 b1c1 1552 d1f0 |
| 2433 6272 8209 0a16 |
| 1718 191a 2526 2728 |
| 292a 3435 3637 3839 |
| 3a43 4445 4647 4849 |
| 4a53 5455 5657 5859 |
| 5a63 6465 6667 6869 |
| 6a73 7475 7677 7879 |
| 7a83 8485 8687 8889 |
| 8a92 9394 9596 9798 |
| 999a a2a3 a4a5 a6a7 |
| a8a9 aab2 b3b4 b5b6 |
| b7b8 b9ba c2c3 c4c5 |
| c6c7 c8c9 cad2 d3d4 |
| d5d6 d7d8 d9da e1e2 |
| e3e4 e5e6 e7e8 e9ea |
| f1f2 f3f4 f5f6 f7f8 |
| f0fo                |
| 1710                |

11 0002 0102 0404 0304 0705 0404 0000 0277 0001 0203 1104 0521 3106 1241 5107 6171 1322 3281 0814 4291 a1b1 c109 2333 52f0 1562 72d1 0a16 2434 e125 f117 1819 1a26 2728 292a 3536 3738 393a 4344 4546 4748 494a 5354 5556 5758 595a 6364 6566 6768 696a 7374 7576 7778 797a 8283 8485 8687 8889 8a92 9394 9596 9798 999a a2a3 a4a5 a6a7 a8a9 aab2 b3b4 b5b6 b7b8 b9ba c2c3 c4c5 c6c7 c8c9 cad2 d3d4 d5d6 d7d8 d9da e2e3 e4e5 e6e7 e8e9 eaf2 f3f4 f5f6 f7f8 f9fa

# TEMIC

#### MATRA MHS

: AC table 1 : BITS matrix

: HUFVAL matrix (162 elements)

: AC table 2 : BITS matrix

: HUFVAL matrix (289 elements)

# TEMIC

#### MATRA MHS

The algorithms given in the paragraph dealing with coding of the DCcoefficients are used to create the [EHUFSI] table containing the length of the HUFFMAN codes associated with nnnnssss and the [EHUFCO] table containing the HUFFMAN codes associated with nnnnssss.

#### Start of frame (DCT basic mode)

The number of components in a frame is limited to 4 (quadrichromy - black, blue, yellow and red). Each frame can contain several successive scans, each corresponding to one component of the image.

There are two scan modes :

the non-interleave mode, where each scan contains a

single image component,

\_ the interleavce mode, where a single scan contains the data for all components in the frame.

Within the frame, data is transmitted in MDU form. In the non-interlace mode, an MDU is a block of  $8 \times 8$ coefficients which correspond, for example, to Y (luminance) or Cr/Cb (chrominance). In the interlace mode, and MDU is an interlacing of blocks defined by the sampling factor Hi,Vi and by NS, the number of components in the scan. In the following example, the scan is described by three components, Y, Cr and Cb, with respective sampling factors of 2h :1v, 1h :1v, and 1h :1v.

The MDU is described by the following :

 $Y_1, Y_2, C_{r1}, C_{b1}; Y_3, Y_4, C_{r2}, C_{b2}..., Y_{2n}, Y_{2n+1}, C_{rn}, C_{bn}...$ 

: V3 vertical sampling factor = 1

#### Data

The data are sent with the most significant byte leading and most significant bit leading.

| Example :<br>93fd 1639 9954 7c9e<br>5fda 653e 667e fe57 |                                                                |
|---------------------------------------------------------|----------------------------------------------------------------|
| 3cee 1cee 2df8 ff00                                     | when FF is created during coding, byte 00 is added to the data |
|                                                         |                                                                |
| d476 96d1 cd74 e2df                                     |                                                                |
| 7e0b 7ef3 f7ca bb63                                     |                                                                |
| c705 7e99 1c00 f418                                     |                                                                |
| ffds                                                    | : marker EOI, end of image                                     |

| Example | : |  |
|---------|---|--|
|---------|---|--|

| -    |                                             | 01       | : selection of quantization table 1       |
|------|---------------------------------------------|----------|-------------------------------------------|
| FFC0 | : SOF0 marker                               | Scanning | -                                         |
| 0011 | : fields length $= 17$                      | ffda     | : SOS = start scan marker                 |
| 08   | : sample precision $= 8$ bits               | 000C     | : length of field (10 usable bytes)       |
| 0100 | : number of Y lines $= 256$                 | 03       | : Ns = number of components in scan = $3$ |
| 0100 | : number of $\times$ samples per line = 256 | 01       | : selection of scan component $= 1$       |
| 03   | : number of image components                | 0        | : selection of HUFFMAN table, $DC = 0$    |
|      | in the frame $= 3$                          | 0        | : selection of HUFFMAN table, $AC = 0$    |
| 01   | : component 1                               | 02       | : selection of scan component $= 2$       |
| 2    | : H1 horizontal sampling factor = 2         | 1        | : selection of HUFFMAN table, $DC = 1$    |
| 1    | : V1 vertical sampling factor = 1           | 1        | : selection of HUFFMAN table, $AC = 1$    |
| 00   | : selection of quantization table 0         | 03       | : selection of scan component $= 3$       |
| 02   | : component 2                               | 1        | : selection of HUFFMAN table, $DC = 1$    |
| 1    | : H2 horizontal sampling factor = 1         | 1        | : selection of HUFFMAN table, $AC = 1$    |
| 1    | : V2 vertical sampling factor $= 1$         | 003F00   | : DCT/Sequential mode, $Ss = 0$ ,         |
| 01   | : selection of quantization table 1         |          | Se = 63,                                  |
| 03   | : component 3                               |          | Ah = 0, Al = 0                            |
| 1    | : H3 horizontal sampling factor $= 1$       |          |                                           |

1

### Appendix 3

#### **Operation of the VLC Decoder (29C82)**

The VLC RAM contains the HUFFMAN decoding tree (see appendix 1). This tree is obtained from the [BITS] and [HUFVAL] matrices contained in the frame header

#### a - LOADING THE TABLES

Tables T0-DC and T0-AC are respectively programmed with :

| T0-] | DC : |     |      |    |    |     |     |     |     |     |    |     |     |     |     |            |      |
|------|------|-----|------|----|----|-----|-----|-----|-----|-----|----|-----|-----|-----|-----|------------|------|
| 02   | 01   | 09  | 07 ( | )3 | 01 | 01  | 01  | 01  | 01  | 01  | 01 | 01  | 01  | 01  | 01  |            |      |
| 04   | 05   | 06  | 08 ( | 01 | 01 | 01  | 01  | 01  | 01  | 01  | 01 | 01  | 01  | 01  | 01  |            |      |
| T0-2 | AC   |     |      |    |    |     |     |     |     |     |    |     |     |     |     |            |      |
| 002  | 001  | 00E | 008  | 00 | )A | 005 | 023 | 0E3 | 043 | 019 | 9  | 143 | 083 | 0A3 | 001 | 001        | 001  |
|      |      |     |      |    |    |     |     |     |     |     |    |     |     |     |     | <br>(16 li | nes) |
| 004  | 003  | 006 | 012  | 00 | )c | 007 | 025 | 010 | 063 | 014 | 4  | 016 | 001 | 0c3 | 001 | 001        | 001  |
|      |      |     |      |    |    |     |     |     |     |     |    |     |     |     |     | (16 li     | nes) |

JPEG frame.

Each VLC table is divided into 2 zones  $(2 \times 16 \text{ bytes for})$  the DC tables and  $2 \times 256 \text{ bytes for the AC tables}$ . The last bit extracted from the data stream indicated the zone to be addressed.

it contains the address of the next node (or leaf) of the HUFFMAN tree, shifted 1 bit left, the LSB being forced to 0.

(see appendix 2). The following example illustrates the

extraction of DC and AC parameters from the data of the

#### Conventions

Each word in the VLC table containing a node of the HUFFMAN table is forced to an even value. In this case

Each word of the VLC table containing a leaf of the tree will be forced to an odd number. In this case it contains ssss (or nnnnssss) shifted 1 bit left, the LSB being forced to 1.

# TEMIC MATRA MHS

#### Figure 10.



Organisation of the AC VLC RAM (example)

#### b - DECODING THE DATA

#### b1 - extraction of the DC parameters

Each DC VLC table is composed of 32 5-bit words, with the LSB forced to 0 or 1 depending on whether the word corresponds to a node or a leaf of the VLC tree.

#### Extraction of DC delta from block 0 :

- reading the first data bit

initial data stream (after header)  $\rightarrow$ 

#### 011001110110010100001000010... first bit

calculation of the address of the node (or leaf) of the HUFFMAN tree :

The address is formed by concatenating :

- a 4-bit register containing the 4 MSB's of the VLC word corresponding to the preceding node of the HUFFMAN tree (after shifting one bit right). For each new coefficient, the register is reset to 0.
- the last bit extracted from the data stream

ADDRESS = 1st data bit (MSB) + contents of 4-bit register = 00H

- reading address 00H of the VLC DC table :

[@(00)] = 02H. This memory point corresponds to a node (in line with the conventions)

- right shift and load into 4-bit register :

$$0 \quad 0 \quad 0 \quad 0 \quad 0 \quad 0 = 1 \text{ st data bit + contents of the 4-bit register = 01H}$$

- reading the 2nd data bit : data stream  $\rightarrow$ 

0110011101100101000010000010... 2nd bit

- concatenation with the 4-bit register :

reading address 11H

[@(11H)] = 05H. This memory point corresponds to a leaf (in line with the conventions)

– right shift :

ssss = 2 and the DC coefficient of block 0 is 2 bits long.

extraction of the DC coefficient from the data stream : data stream  $\rightarrow$ 

#### 0110011101100101000010000010... delta DC\_bloc\_0 = 10

#### b2 - extraction of AC parameters Extraction of AC delta from block 0 :

 reading the fifth data bit initial data stream (after header) →

> 0110011101100101000010000010... fifth bit

- calculation of the address of the node (or leaf) of the HUFFMAN tree :

The address is formed by concatenating :

- an 8-bit register containing the 8 MSB's of the VLC word corresponding to the preceding node of the HUFFMAN tree (after shifting one bit right. The LSB (bit 9) is obtained by address decoding). For each new coefficient, the 8-bit register is reset to 0.
- the last bit extracted from the data stream

|--|

ADDRESS = 1st data bit (MSB) + contents of 8-bit register = 00H

- reading address 00H of the VLC AC table :

[@(00)] = 02H. This memory point corresponds to a node (in line with the conventions)

- right shift and load into 8-bit register :

- reading the 6th data bit : data stream  $\rightarrow$ 

011001110110010100001000010...

6th bit

concatenation with the 8-bit register :

$$1 \quad 0 \quad 1 = 101 \text{H}$$

#### MATRA MHS

reading address 101H

[@(101H)] = 03H. This memory point corresponds to a leaf (in line with the conventions)

- right shift :

nnnsss = 0000001

- nnnn = 0. The number of zero coefficients = 0.
- ssss = 1. The first AC coefficient of block 0 is 1 bit long.
- extraction of the AC coefficient from the data stream : data stream  $\rightarrow$

011001110110010100001000010.. AC\_1\_bloc\_0 = 1

## Appendix 4

#### **Example of Program for Creation of VLC Table**



```
CONSTRUCTION OF VLC TABLES */
/*
/*
     DC TABLES
                    */
void vlctable_dc (BITS, VALUE, HUFCODE, SIZE)
            BITS[17];
int
            VALUES[16];
int
            HUFCODE[16];
int
{
            PNTR;
int
int
            I,J ;
int
            SIZO[16];
int
            SI:
int
                   WORD;
unsigned int CODE ;
for (I=0 < 16; I++)
            \{SIZO[I] = 0;\}
PNTR = 0;
for (I=1 ; I < 17 ; I++)
      for (J=1; J<=BITS[I]; J++)
```

Note : nnnnssss = 00H corresponds to detection of an end-of-block (EOB) character. nnnnssss = 0FH corresponds to detection of an escape character (15 zero coefficients). In this case one has to set the following 15 coefficients to 0, and then resume the decoding sequence by re-initialising the 8-bit register to 0.

```
\{SIZO[PNTR] = I; PNTR ++; \}
for (I=0; I < 16; I++)
{HUFCODE[I] = 0 ; SIZE[I] = 0 ; }
WORD = 0;
CODE = 0;
SI = SIZO[0];
HUFCODE[VALUES[WORD]] = CODE ;
SIZE[VALUES[WORD]] = SI;
do
{
            do
             {
            HUFCODE[VALUES[WORD]] = CODE ;
             SIZE[VALUES[WORD]] = SI;
             CODE++;
             WORD++;
             }
             while (SIZO[WORD] == SI);
            if (SIZO[WORD] ! = 0)
             do
             \{\text{CODE} = (\text{CODE} \ll 1); \text{SI} + +; \} while (\text{SIZO}[\text{WORD}] ! = \text{SI}); else
             {break ;}
}
while (SIZO[WORD] == SI);
return;
}
/*
      DC TABLES */
void vlctables_ac (BITS, VALUES, HUFCODE, SIZE)
            BITS[17];
int
int
             VALUES[256];
            HUFCODE[256];
int
            SIZE[256];
int
{
int
            PNTR :
int
            I,J;
            SIZO[256];
int
int
            SI;
int
             WORD ;
unsigned int CODE ;
for (I=0; I < 256; I++)
      \{SIZO[I] = 0;\}
PNTR = 0;
for (I=1 ; I<17 ; I++)
      for (J=1 ; J<=BITS[I] ; J++)
      \{SIZO[PNTR] = I; PNTR ++; \}
for (I=0; I < 256; I++)
      \{HUFCODE[I] = SIZE[I] = 0;\}
WORD = 0;
CODE = 0;
SI = SIZO[0];
HUFCODE[VALUES[WORD]] = CODE ;
SIZE[VALUES[WORD]] = SI;
do
{
```

# TEMIC

#### MATRA MHS

**29C82** 

```
do
            {
            HUFCODE[VALUES[WORD]] = CODE ;
            SIZE[VALUES[WORD]] = SI;
            CODE++;
            WORD++;
            }
            while (SIZO[WORD] == SI);
if
            (SIZO[WORD] ! = 0)
                  do
                  \{\text{CODE} = (\text{CODE} \ll 1); \text{SI} + +; \} while (\text{SIZO}[\text{WORD}] ! = \text{SI}); else
                  {break ;}
}
while (SIZO[WORD] == SI);
return ;
}
/*
      CONSTRUCTION OF DECODING TREE
                                                      */
/*
                                                */
      CONSTRUCTION OF DC TREE
void makecodar dc (HUFCODE, SIZE, PARR)
            HUFCODE[16];
int
            SIZE[16];
int
int
            PARR[32];
            INDEX :
int
int
            Ι;
int
            NEXT;
int
            CODENO:
            CODESIZE ;
int
            CODELO;
int
for (I=0; I < 32; I++)
            \{PARR[I] = 0;\}
NEXT = 0;
for (CODENO = 0; CODENO < 16; CODENO++)
            if (SIZE[CODENO] ! = 0)
                  {
                        INDEX = 0;
                        CODESIZE = SIZE[CODENO];
            CODELO = HUFCODE[CODENO] :
            CODELO = (CODELO << (16 - CODESIZE));
            for (I=1; I < CODESIZE ; I++)
                        if (CODELO < 0) INDEX += 16;
                        if (PARR[INDEX] != 0) INDEX = PARR[INDEX]; else
                                    {
                                          {
                              NEXT ++:
                              PARR[INDEX] = NEXT;
                              INDEX = NEXT;
                        }
                              CODELO = (CODELO << 1);
                  }
            if (CODELO < 0) INDEX += 16;
            PARR[INDEX] = (CODENO << 8);
                  }
            }
```

return ; } , /\* CONSTRUCTION OF AC TREE \*/ void makecodar\_ac (HUFCODE, SIZE, PARR) int HUFCODE[256]; SIZE[256]; int int PARR[512]; { INDEX; int int Ι; NEXT; int CODENO; int CODESIZE; int int CODELO; for (I=0; I < 512; I++)  $\{PARR[I] = 0;\}$ NEXT = 0; for (CODENO = 0; CODENO < 256; CODENO++) { if (SIZE[CODENO] != 0) { INDEX = 0; CODESIZE = SIZE[CODENO];CODELO = HUFCODE[CODENO]; CODELO = (CODELO << (16 - CODESIZE)); for (I=1; I < CODESIZE; I++) ł if (CODELO < 0) INDEX += 256; if (PARR[INDEX] != 0) INDEX = PARR[INDEX]; else { NEXT ++ ; PARR[INDEX] = NEXT; INDEX = NEXT;} CODELO = (CODELO << 1);} if (CODELO < 0) INDEX += 256; PARR[INDEX] = (CODENO << 8);} } return; }

MATRA MHS

**29C82** 

## Appendix 5

#### **Decoupling and Layout Precautions**







It is recommended that ceramic capacitors of the CMS type should be used.

In order to improve decoupling, and to compensate for voltage peaks of inductive origin, a second 10 nF capacitor can be placed in parallel with each 100 nF capacitor. This additional capacitor should be placed as close as possible to the package.

#### Layout precautions

In order to reduce noise, it is recommended that a card with 4 levels of metalling be used, one level of which is reserved as the earth plane and a second for Vcc.

## **Appendix 6**

#### Application

The use of an MHS HM67202  $1k \times 9$  FIFO enables the frequency of accesses to the DATA bus to be reduced, thereby improving system flexibility.

The latch placed on the ADD[3..0] bus is sampled on the





## Appendix 7

#### 29C82 PC Evaluation Board (8-bit)

- Schematic
- EPLD equation

| Address configuration:                                                |
|-----------------------------------------------------------------------|
| -Space : I/O                                                          |
| —A ddress : 300h to 31Fh                                              |
| x29C82 : 300h to 30Fh<br>(cf Data Sheet)                              |
| #FIFO : 310h to 31Fh<br>•Data : 310h to 317h<br>•Status: 318h to 31Fh |

**29C82** 

#### C22V10

{29C82 Evaluation PC-Board} {82EPC.CYP} {On Board Logic & IO DECODING} {Appli.Lab – J.T – 13.11.92}

#### CONFIGURE

| ICLK | (node = 1),    | A11   | (node = 2),  | A10 | (node = 3),  |
|------|----------------|-------|--------------|-----|--------------|
| A9   | (node = 4),    | A8    | (node = 5),  | A7  | (node = 6),  |
| A3   | (node = 10),   | /WR   | (node = 11), | /RD | (node = 13), |
| /RDF | (node = 14, N) | OREG  | ),           |     |              |
| /EFF | (node = 15, N) | OREG  | ), {Input}   |     |              |
| /HFF | (node = 16, N) | OREG  | ), {Input}   |     |              |
| D0   | (node = 17, N) | OREG  | , NINV),     |     |              |
| ALE  | (node = 18, N) | OREG  | , NINV),     |     |              |
| /C82 | (node = 19, N) | OREG  | ),           |     |              |
| PRQ  | (node = 20, N) | INV), |              |     |              |
| /WRF | (node = 21, N) | OREG  | ),           |     |              |
| POUT | (node = 22, N) | OREG  | ), {Input}   |     |              |
| OCLK | (node = 23, N) | OREG  | , NINV),     |     |              |
|      |                |       |              |     |              |

#### **EQUATIONS**

| RDF =  | {Read Control for FIFO Device. @IO = 310h to 317h.}          |
|--------|--------------------------------------------------------------|
|        | <pre><oe></oe></pre>                                         |
| D0 =   | {reading Empty Flag from FIFO. @IO = 318h to 31Fh.}          |
|        | <oe>RD*/A11*/A10*A9*A8*/A7*/A6*/A5*A4*A3</oe>                |
|        | <sum>/EFF;</sum>                                             |
| C82 =  | {Chip Select Control for 29C82 Device. @IO = 300h to 30Fh.}  |
|        | <sum>/A11*/A10*A9*A8*/A7*/A6*/A5*/A4;</sum>                  |
| ALE =  | {Address Latch Enable for Latch Device type 74LS373.}        |
|        | <sum>/A11*/A10*A9*A8*/A7*/A6*/A5*RD</sum>                    |
|        | <sum>/A11*/A10*A9*A8*/A7*/A6*/A5*WR;</sum>                   |
| WRF =  | {Write Control for FIFO Device.}                             |
|        | <0e>                                                         |
|        | <sum>/ICLK*POUT;</sum>                                       |
| PRQ =  | {Pixel request to 29C82 synchronized by Clock.}              |
|        | {Available only if Half Full Flag from FIFO is not Present.} |
|        | <0e>                                                         |
|        | <sum>/HFF;</sum>                                             |
| OCLK = | {Clock for 29C82 synchronous with /WRF.}                     |
|        |                                                              |
|        | <sum> ICLK;</sum>                                            |

MATRA MHS

**29C82** 



## **Ordering Information**





TEMPERATURE RANGE Ø COMMERCIAL 0 TO 70 °C I INDUSTRIAL –40 TO 85 °C PACKAGE : S = PLCC

Part number 29C82

29C82

The information contained herein is subject to change without notice. No responsibility is assumed by MATRA MHS SA for using this publication and/or circuits described herein : nor for any possible infringements of patents or other rights of third parties which may result from its use.