

TELECOMMUNICATION STANDARDIZATION SECTOR OF ITU

G.726
Appendix II
Test Vectors
(03/91)

SERIES G: TRANSMISSION SYSTEMS AND MEDIA, DIGITAL SYSTEMS AND NETWORKS

Digital transmission systems – Terminal equipments – Coding of analogue signals by methods other than PCM

Description of the digital test sequences for the verification of the G.726 40, 32, 24 and 16 kbit/s ADPCM algorithm

#### **FOREWORD**

ITU (International Telecommunication Union) is the United Nations Specialized Agency in the field of telecommunications. The ITU Telecommunication Standardization Sector (ITU-T) is a permanent organ of the ITU. The ITU-T is responsible for studying technical, operating and tariff questions and issuing Recommendations on them with a view to standardizing telecommunications on a worldwide basis.

The World Telecommunication Standardization Conference (WTSC), which meets every four years, establishes the topics for study by the ITU-T Study Groups which, in their turn, produce Recommendations on these topics.

The approval of Recommendations by the Members of the ITU-T is covered by the procedure laid down in WTSC Resolution No. 1.

In some areas of information technology which fall within ITU-T's purview, the necessary standards are prepared on a collaborative basis with ISO and IEC.

#### INTELLECTUAL PROPERTY RIGHTS

The ITU draws attention to the possibility that the practice or implementation of this Recommendation may involve the use of a claimed Intellectual Property Right. The ITU takes no position concerning the evidence, validity or applicability of claimed Intellectual Property Rights, whether asserted by ITU members or others outside of the Recommendation development process.

As of the date of approval of this Recommendation, the ITU had/had not received notice of intellectual property, protected by patents, which may be required to implement this Recommendation. However, implementors are cautioned that this may not represent the latest information and are therefore strongly urged to consult the TSB patent database.

#### © ITU 1997

All rights reserved. No part of this publication may be reproduced or utilized in any form or by any means, electronic or mechanical, including photocopying and microfilm, without permission in writing from the ITU.

# DESCRIPTION OF THE DIGITAL TEST SEQUENCES FOR THE VERIFICATION OF THE G.726 40, 32, 24 AND 16 KBIT/S ADPCM ALGORITHM

#### 1 Introduction

This guide describes the test sequences (vectors) for the ADPCM algorithms of Recommendation G.726 at the four fixed bit rates (16 kbit/s, 24 kbit/s, 32 kbit/s, 40 kbit/s) for both A-law and  $\mu$ -law. It reproduces mainly the text of the CCITT collective letter No. 11/XV, dated 21/03/1991, the only amendments corresponding to the grouping on two 3½" disks of the files which were previously on four 5¼" disks.

The tests are arranged in two separate diskettes, one for the  $\mu$ -law and one for the A-law. For each law, the diskette contains the reset test vectors and the homing test vectors. The diskettes are of the  $3\frac{1}{2}$  MS-DOS format<sup>1</sup>. Within each diskette, the files are distributed in subdirectories that correspond to individual bit rates for the homing and reset case. A READ.ME file lists the contents of each diskette.

#### 2 General description

The verification testing procedure consists in applying an input sequence to an ADPCM implementation and verifying that the output sequence is the same sequence in the output file for the same test conditions (PCM coding law, type of input, initial state of the implementation).

There are three types of input sequences. The first type consists of various sinusoidal PCM inputs that are representative of the signals expected in normal operation. These are called "normal inputs". A second group of input sequences is the set of "overload inputs" that contain PCM signals of very large amplitudes. The third group is the set of ADPCM sequences that can exercise the algorithm in a manner that is not possible with any PCM input sequence. They test the arithmetic and algorithmic performance of the ADPCM decoder by driving it to states that are unreachable by PCM signals under normal conditions. For example, these states may result from errors on the transmission line. These intermediate sequences will be denoted as "I-inputs".

The values (or samples) contained in a test file are given in ASCII hexadecimal representation with two hexadecimal characters per 8-bit value. In files with 5-bit ADPCM values, the three most significant bits are set to 0. Files containing 4-bit ADPCM values have the four most significant bits or each value set to 0. Files that contain 3-bit ADPCM values have the five most significant bits of each word set to 0. For files containing 2-bit ADPCM values, the six most significant bits are set to 0. All PCM A-law inputs are in the format specified by Table 1a/G.711, i.e. the even bits are inverted

Each line in any file contains up to 32 values (or 64 characters) and ends with a line feed character. Two more hexadecimal characters representing the result of a checksum computation over the entire file are appended to each file. This checksum is the remainder of the division of 255 of the sum of all sample values (two hexadecimal characters comprise a sample value) in the file.

**Recommendation G.726 – Appendix II – Test vectors (03/91)** 

1

It has been noted that these diskettes do not always copy correctly using DISKCOPY due to the interaction of DISKCOPY with certain character sequences found in the test sequences. Either files should be copied individually using COPY, or XCOPY should be used instead of DISKCOPY.

#### 3 Test configurations

Test sequences are derived for the two configurations shown in Figures 1 and 2, respectively. The configuration of Figure 1 is the arrangement with the encoder transmitting to the decoder for error-free operation. The configuration of Figure 2 allows for input ADPCM words that would not normally emanate from an encoder and a PCM input word. The word formats of the various sequences are detailed in Table 1.



Figure 1 – Encoder and decoder configuration



Figure 2 – Decoder only configuration

| Name | Description     | Word format                                                                                                   |
|------|-----------------|---------------------------------------------------------------------------------------------------------------|
| S    | PCM input word  | Identical to that of SP described in the sub-block COMPRESS of the synchronous coding adjuster (4.2.8/G.726). |
| I    | ADPCM word      | As specified in the sub-block RECONST of the inverse adaptive quantizer (4.2.3/G.726).                        |
| SD   | PCM output word | Identical to that of SP described in the sub-block COMPRESS (4.2.8/G.726).                                    |

Table 1 – Word format of test sequences

#### 4 Test combinations

The initial state of the implementation may be either the reset state of the algorithm defined in Table 2 or a well-defined initial state that follows the application of an initialization (or homing) sequence. Accordingly, there are two types of test sequences, reset sequences and homing sequences.

Table 2 – State values at reset

| Variable                           | Value  |
|------------------------------------|--------|
| $A_1, A_2$                         | 0      |
| $B_1,, B_6$                        | 0      |
| DQ <sub>1</sub> ,, DQ <sub>6</sub> | 32     |
| $PK_1, PK_2$                       | 0      |
| $SR_1, SR_2$                       | 32     |
| TD                                 | 0      |
| YL                                 | 34 816 |
| YU                                 | 544    |

The homing sequences are based on the initial states that follow the application of an initialization (homing) sequence. These initialization sequences are described in further detail in 6.4.

For each initial state, both PCM laws (A-law and  $\mu$ -law) are considered. To allow for the interoperation of both PCM laws, four possible input/output combinations must be considered as shown in Table 3.

Table 3 – Input/output combinations

| Input | Output |
|-------|--------|
| A-law | A-law  |
| μ-law | μ-law  |
| A-law | μ-law  |
| μ-law | A-law  |

# 5 Test organization

Tables 4 to 7 contain the names of files containing various reset/homing sequences for the following cases:

- 1)  $\mu$ -law;
- 2) A-law;
- 3)  $\mu \rightarrow A$ ; and
- 4)  $A \rightarrow \mu$ .

Files whose names start with an "R" contain reset sequences while the names of files for the homing sequences start with an "H". The suffix ".I" is reserved for the intermediate ADPCM encoder response to a PCM input. Files with the suffix ".O" are the output PCM files.

Table 4 – Reset and homing sequences for  $\mu$ -law

|           | Normal         |                         | Normal I-input       |                  | Overload             |                |                         |                      |
|-----------|----------------|-------------------------|----------------------|------------------|----------------------|----------------|-------------------------|----------------------|
| Algorithm | Input<br>(PCM) | Intermediate<br>(ADPCM) | Output<br>(PCM)      | Input<br>(ADPCM) | Output<br>(PCM)      | Input<br>(PCM) | Intermediate<br>(ADPCM) | Output<br>(PCM)      |
| 16F       | NRM.M          |                         | RN16FM.O<br>HN16FM.O | I16              | RI16FM.O<br>HI16FM.O |                |                         | RV16FM.O<br>HV16FM.O |

| 24F | NRM.M | RN24FM.I<br>HN24FM.I | RN24FM.O<br>HN24FM.O | I24 | RI24FM.O<br>HI24FM.O |       |                      | RV24FM.O<br>HV24FM.O |
|-----|-------|----------------------|----------------------|-----|----------------------|-------|----------------------|----------------------|
| 32F | NRM.M | RN32FM.I<br>HN32FM.I | RN32FM.O<br>HN32FM.O | I32 | RI32FM.O<br>HI32FM.O | OVR.M |                      | RV32FM.O<br>HV32FM.O |
| 40F | NRM.M | RN40FM.I<br>HN40FM.I | RN40FM.O<br>HN40FM.O | I40 | RI40FM.O<br>HI40FM.O | OVR.M | RV40FM.I<br>HV40FM.I | RV40FM.O<br>HV40FM.O |

Table 5 – Reset and homing sequences for A-law

|           | Normal         |                      | I-input              |                  | Overload             |                |                      |                      |
|-----------|----------------|----------------------|----------------------|------------------|----------------------|----------------|----------------------|----------------------|
| Algorithm | Input<br>(PCM) | Intermediate (ADPCM) | Output<br>(PCM)      | Input<br>(ADPCM) | Output<br>(PCM)      | Input<br>(PCM) | Intermediate (ADPCM) | Output<br>(PCM)      |
| 16F       | NRM.A          |                      | RN16FA.O<br>HN16FA.O | I16              | RI16FA.O<br>HI16FA.O | OVR.A          |                      | RV16FA.O<br>HV16FA.O |
| 24F       | NRM.A          |                      | RN24FA.O<br>HN24FA.O | I24              | RI24FA.O<br>HI24FA.O | OVR.A          |                      | RV24FA.O<br>HV24FA.O |
| 32F       | NRM.A          |                      | RN32FA.O<br>HN32FA.O | I32              | RI32FA.O<br>HI32FA.O | OVR.A          |                      | RV32FA.O<br>HV32FA.O |
| 40F       | NRM.A          |                      | RN40FA.O<br>HN40FA.O | I40              | RI40FA.O<br>HI40FA.O | OVR.A          |                      | RV40FA.O<br>HV40FA.O |

Table 6 – Reset and homing cross sequences for  $\mu \rightarrow A$ 

| Normal    |                |                      | Normal               |                |                      |                      |
|-----------|----------------|----------------------|----------------------|----------------|----------------------|----------------------|
| Algorithm | Input<br>(PCM) | Intermediate (ADPCM) | Output<br>(PCM)      | Input<br>(PCM) | Intermediate (ADPCM) | Output<br>(PCM)      |
| 16F       | NRM.M          | RN16FM.I<br>HN16FM.I | RN16FC.O<br>HN16FC.O | OVR.M          | RV16FM.I<br>HV16FM.I | RV16FC.O<br>HV16FC.O |
| 24F       | NRM.M          | RN24FM.I<br>HN24FM.I | RN24FC.O<br>HN24FC.O | OVR.M          | RV24FM.I<br>HV24FM.I | RV24FC.O<br>HV24FC.O |
| 32F       | NRM.M          | RN32FM.I<br>HN32FM.I | RN32FC.O<br>HN32FC.O | OVR.M          | RV32FM.I<br>HV32FM.I | RV32FC.O<br>HV32FC.O |
| 40F       | NRM.M          | RN40FM.I<br>HN40FM.I | RN40FC.O<br>HN40FC.O | OVR.M          | RV40FM.I<br>HV40FM.I | RV40FC.O<br>HV40FC.O |

Table 7 – Reset and homing cross sequences for  $A\to \mu$ 

|           | Normal         |                      |                      |                |                      |                      |
|-----------|----------------|----------------------|----------------------|----------------|----------------------|----------------------|
| Algorithm | Input<br>(PCM) | Intermediate (ADPCM) | Output<br>(PCM)      | Input<br>(PCM) | Intermediate (ADPCM) | Output<br>(PCM)      |
| 16F       | NRM.A          | RN16FA.I<br>HN16FA.I | RN16FX.O<br>HN16FX.O | OVR.A          | RV16FA.I<br>HV16FA.I | RV16FX.O<br>HV16FX.O |
| 24F       | NRM.A          | RN24FA.I<br>HN24FA.I | RN24FX.O<br>HN24FX.O | OVR.A          | RV24FA.I<br>HV24FA.I | RV24FX.O<br>HV24FX.O |
| 32F       | NRM.A          | RN32FA.I<br>HN32FA.I | RN32FX.O<br>HN32FX.O | OVR.A          | RV32FA.I<br>HV32FA.I | RV32FX.O<br>HV32FX.O |
| 40F       | NRM.A          | RN40FA.I<br>HN40FA.I | RN40FX.O<br>HN40FX.O | OVR.A          | RV40FA.I<br>HV40FA.I | RV40FX.O<br>HV40FX.O |

#### 5.1 Reset test sequences

The test sequences that are available when the initial state of the algorithm in the reset state are:

- 1) μ-law (A-law) PCM encoder input sequences for normal operation: NRM.M and NRM.A.
- 2) ADPCM encoder output sequences corresponding to the input in 1) and for the various rates: RN16FM.I, RN16FA.I, RN24FM.I, RN24FA.I, RN32FM.I, RN32FA.I, RN40FM.I and RN40FA.I.
- 3) μ-law (A-law) PCM decoder output sequences corresponding to the ADPCM input in 2): RN16FM.O, RN16FA.O, RN24FM.O, RN24FA.O, RN32FM.O, RN32FA.O, RN40FM.O and RN40FA.O.
- 4) ADPCM intermediate sequences that are applied to the decoder: I16., I24, I32 and I40.
- 5) μ-law (A-law PCM) output sequence corresponding to the I-input ADPCM decoder input in 4): RI16FM.O, RI16FA.O, RI24FM.O, RI24FA.O, RI32FM.O, RI32FA.O, RI40FM.O and RI40FA.O.
- 6) μ-law (A-law) PCM encoder input sequence for overload conditions: OVR.M and OVR.A.
- 7) ADPCM encoder output sequence in response to the input in 6): RV16FM.I, RV16FA.I, RV24FM.I, RV24FA.I, RV32FM.I, RV32FA.I, RV40FM.I and RV40FA.I.
- 8) μ-law (A-law) PCM output sequence corresponding to the ADPCM encoder output in 7): RV16FM.O, RV16FA.O, RV24FM.O, RV24FA.O, RV32FM.O, RV32FA.O, RV40FM.O and RV40FA.O.
- 9) The  $\mu \to A$  and  $A \to \mu$  cross test sequences for the normal and overload cases: RN16FC.O, RV16FC.O, RN24FC.O, RN32FC.O, RV32FC.O, RN40FC.O, RV40FC.O, RN16FX.O, RV16FX.O, RN24FX.O, RV24FX.O, RN32FX.O, RV32FX.O, RN40FX.O and RV40FX.O.

# 5.2 Homing test sequences

The test sequences in this are:

- Initialization (homing) sequence to drive the implementation to a known initial state:  $PCM_INIT.M$  for the  $\mu$ -law and  $PCM_INIT.A$  for the A-law.
- 2)  $\mu$ -law (A-law) PCM encoder input sequence for normal operation starting from this normal state: NRM.M and NRM.A.
- 3) ADPCM encoder output sequence corresponding to the input in 2): HN16FM.I, HN16FA.I, HN24FM.I, HN24FA.I, HN32FM.I, HN32FA.I, HN40FM.I and HN40FA.I.
- 4)  $\mu$ -law (A-law) PCM decoder output sequence corresponding to the ADPCM encoder output in 3): HN16FM.O, HN16FA.O, HN24FM.O, HN24FA.O, HN32FM.O, HN32FA.O, HN40FM.O and HN40FA.O.
- 5) ADPCM initialization sequence for I-input operation: I\_INI\_16.M, I\_INI\_24.M, I\_INI\_32.M, and I\_INI\_40.M for  $\mu$ -law; I\_INI\_16.A, I\_INI\_24.A, I\_INI\_32.A and I\_INI\_40.A for A-law.
- 6) μ-law (A-law PCM) output sequence corresponding to the I-input ADPCM decoder input in 5): HI16FM.O, HI16FA.O, HI24FM.O, HI24FA.O, HI32FM.O, HI32FA.O, HI40FM.O and HI40FA.O.
- 7) µ-law (A-law) PCM encoder input sequence for overload conditions: OVR.M and OVR.A.
- 8) ADPCM encoder output sequence corresponding to the input in 7): HV16FM.O, HV16FA.O, HV24FM.O, HV24FA.O, HV32FM.O, HV32FA.O, HV40FM.O and HV40FA.O.

- 9) μ-law (A-law) PCM output sequence corresponding to the ADPCM sequence in 8): HV16FM.O, HV16FA.O, HV24FM.O, HV24FA.O, HV32FM.O, HV32FA.O, HV40FM.O and HV40FA.O.
- 10) The  $\mu \to A$  and  $A \to \mu$  cross test sequences for the normal and overload cases: HN16FC.O, HV16FC.O, HV24FC.O, HN32FC.O, HV32FC.O, HN40FC.O, HV40FC.O, HN16FX.O, HV16FX.O, HN24FX.O, HV24FX.O, HN32FX.O, HV32FX.O, HN40FX.O, and HV40FX.O.

# 6 Description of the input sequences

# 6.1 PCM normal input

The PCM normal input sequences consist of 16 384 values that represent narrow-band and broadband signal sequences as detailed in Table 8. NRM.M is the PCM normal  $\mu$ -law input sequence while NRM.A is the corresponding A-law input sequence.

Signal Length 3504 Hz tone 1 024 2054 Hz tone 1 024 1504 Hz tone 1 024 504 Hz tone 1 024 254 Hz tone 1 024 1254 Hz tone 1 024 2254 Hz tone 1 024 3254 Hz tone 1 024 4000 Hz tone 512 DC, positive, low level 512 DC, value of zero 512 DC, negative, low level 512 4800 bit/s differential phase shift keyed voice-band 3 072 data switched carrier 4800 bit/s differential phase shift keyed voice-band 3 072 data continuous carrier (with asynchronous switched carrier secondary channel) Total length of sequence 16 384

Table 8 – Sequence of PCM test signal

#### 6.2 PCM overload input

The PCM overload input sequences have 2048 values from three high level (> +1 dBm0) single frequency tones at 404, 1004 and 3204 Hz arranged in various combinations and for differing intervals. The sequence is generated digitally without analogue filtering but with the +3 dBm0 overload point enforced. OVR.M is the PCM overload  $\mu$ -law input sequence while OVR.A is the corresponding A-law sequence. Both sequences contain 2048 samples.

# 6.3 ADPCM input

The ADPCM input sequence is a combination of a sign bit sequence and a sequence of 2-, 3- or 4-bit magnitudes respectively for operation at 16, 24, 32 and 40 kbit/s. These input sequences are denoted as I16, I24, I32 and I40 respectively. The sign bit sequence consists of eight subsequences, each of length 2048 as follows:

- 1) ++++++...
- 2) ++++---...
- 3) --+--+...
- 4) ++--+--...
- 5) ++---+--...
- 6) ----+-+----
- 7) --+-+--+...
- +-+-+-...

The magnitude sequence for 32 kbit/s consists of 27 concatenated subsequences of various lengths as detailed in Table 9 (the values are shown in decimal integer form).

Table 9 – Sequence of I-input value magnitudes for 32 kbit/s

| Repetitive pattern                | Length |
|-----------------------------------|--------|
| 00000                             | 1 024  |
| Alternating sixteen 0s sixteen 1s | 512    |
| 11111                             | 512    |
| Alternating sixteen 1s sixteen 2s | 512    |
| 22222                             | 512    |
| Alternating sixteen 2s sixteen 3s | 256    |
| 33333                             | 1 024  |
| Alternating sixteen 3s sixteen 4s | 512    |
| 44444                             | 512    |
| Alternating sixteen 4s sixteen 5s | 512    |
| 55555                             | 512    |
| Alternating sixteen 5s sixteen 6s | 256    |
| 66666                             | 1 024  |
| Alternating sixteen 6s sixteen 7s | 256    |
| 77777                             | 1 024  |
| 66666                             | 1 024  |
| 55555                             | 1 024  |
| Alternating sixteen 5s sixteen 4s | 512    |
| Alternating sixteen 4s sixteen 3s | 512    |
| 33333                             | 512    |
| 22222                             | 1 024  |
| Alternating sixteen 2s sixteen 1s | 512    |
| Alternating sixteen 1s sixteen 0s | 512    |
| 00000                             | 1 024  |
| Alternating sixteen 5s sixteen 7s | 256    |
| Alternating sixteen 2s sixteen 7s | 256    |
| Alternating sixteen 1s sixteen 6s | 256    |
| Total length of sequence          | 16 384 |

Table 10 contains the magnitude sequence for 40 kbit/s which is obtained from the one for 32 kbit/s through a left shift of one bit position.

Table 10 – Sequence of I-input value magnitudes for 40 kbit/s

| Repetitive pattern                  | Length |
|-------------------------------------|--------|
| 00000                               | 1 024  |
| Alternating sixteen 0s sixteen 2s   | 512    |
| 22222                               | 512    |
| Alternating sixteen 2s sixteen 4s   | 512    |
| 44444                               | 512    |
| Alternating sixteen 4s sixteen 6s   | 256    |
| 66666                               | 1 024  |
| Alternating sixteen 6s sixteen 8s   | 512    |
| 88888                               | 512    |
| Alternating sixteen 8s sixteen 10s  | 512    |
| 1010101010                          | 512    |
| Alternating sixteen 10s sixteen 12s | 256    |
| 1212121212                          | 1 024  |
| Alternating sixteen 12s sixteen 14s | 256    |
| 1414141414                          | 1 024  |
| 1212121212                          | 1 024  |
| 1010101010                          | 1 024  |
| Alternating sixteen 10s sixteen 8s  | 512    |
| Alternating sixteen 8s sixteen 6s   | 512    |
| 66666                               | 512    |
| 44444                               | 1 024  |
| Alternating sixteen 4s sixteen 2s   | 512    |
| Alternating sixteen 2s sixteen 0s   | 512    |
| 00000                               | 1 024  |
| Alternating sixteen 10s sixteen 14s | 256    |
| Alternating sixteen 4s sixteen 14s  | 256    |
| Alternating sixteen 2s sixteen 12s  | 256    |
| Total length of sequence            | 16 384 |

Similarly, the magnitude sequence for 24 kbit/s is derived from its counterpart at 32 kbit/s through a right shift of one bit position. Table 11 contains the resulting sequence of values.

Table 11 – Sequence of I-input value magnitudes for 24 kbit/s

| Repetitive pattern                | Length |
|-----------------------------------|--------|
| 00000                             | 2 048  |
| Alternating sixteen 0s sixteen 1s | 512    |
| 11111                             | 1 792  |
| Alternating sixteen 1s sixteen 2s | 512    |
| 22222                             | 1 536  |
| Alternating sixteen 2s sixteen 3s | 256    |
| 33333                             | 3 328  |
| 22222                             | 1 536  |
| Alternating sixteen 2s sixteen 1s | 512    |
| 11111                             | 1 536  |
| Alternating sixteen 1s sixteen 0s | 512    |
| 00000                             | 1 536  |
| Alternating sixteen 2s sixteen 3s | 256    |
| Alternating sixteen 1s sixteen 3s | 256    |
| Alternating sixteen 0s sixteen 3s | 256    |
| Total length of sequence          | 16 384 |

Finally, the magnitude sequence for 16 kbit/s is derived from the sequence at 32 kbit/s by shifting to the right for two bit positions. Table 12 displays the corresponding sequence of values.

Table 12 – Sequence of I value magnitudes for 16 kbit/s

| Repetitive pattern                | Length |
|-----------------------------------|--------|
| 00000                             | 4 352  |
| Alternating sixteen 0s sixteen 1s | 512    |
| 11111                             | 6 656  |
| Alternating sixteen 1s sixteen 0s | 512    |
| 00000                             | 3 584  |
| 11111                             | 256    |
| Alternating sixteen 0s sixteen 1s | 512    |
| Total length of sequence          | 16 384 |

# 6.4 Initialization sequences

#### **6.4.1 PCM initialization sequences**

The PCM initialization sequences for both A-law and  $\mu$ -law are those described in [2]. They consist of 3496 samples. For a  $\mu$ -law encoder in normal operation for the homing case, the input becomes (PCM\_INIT.M + NRM.M) while for an A-law encoder the input becomes (PCM\_INIT.A + NRM.A). Therefore, when they are put to precede the normal inputs, the length of the combined input sequence increases to 19 880 samples. Similarly, when they are combined with the overload inputs, the combined sequences contain 5544 samples. In each case, the relevant intermediate ADPCM sequence and PCM output from the ADPCM decoder is extracted by skipping the first 3496 samples.

#### 6.4.2 μ-law ADPCM initialization

The  $\mu$ -law ADPCM initialization sequence is obtained by applying the  $\mu$ -law PCM initialization sequence to an  $\mu$ -law  $\to$  ADPCM coder at the given rate. These resulting initialization sequences are I\_INI\_16.M, I\_INI\_24.M, I\_INI\_32.M and I\_INI\_40.M for operation at 16, 24, 32 and 40 kbit/s respectively. They are prepended to the corresponding input sequence as follows: to the I16 for 16 kbit/s, I24 for 24 kbit/s, I32 for 32 kbit/s and I40 for 40 kbit/s. Thus, the length of the combined sequence increases to 19 880 samples. To check the ADPCM decoder operation the combined sequence is applied to a decoder and the PCM outputs corresponding to the i-inputs are obtained by skipping the first 3496 samples. These 3496 samples represent the  $\mu$ -law PCM initialization sequences coded by the ADPCM coder and then decoded by the ADPCM decoder at the given rate.

To test the cross-coding operation ( $\mu \to A$ ), the ADPCM initialization sequence for A-law decoding is prepended to the output of the ADPCM encoder at the respective rate. For example, at 32 kbit/s and for  $\mu$ -law PCM input and A-law PCM output, the combined sequence is I\_INI\_32.A + HN32FM.I for normal operation and I\_INI\_32.A + HV32FM.I for overload operation. Thus, the length of the combined sequence increases to 19 880 samples for normal operation and to 5544 samples for overload operation. The combined sequence is used to exercise the ADPCM decoder. After skipping the first 3496 samples, the relevant output PCM sequence, HN32FC.O or HV32FC.O, is extracted. The same can be done at the other rates.

#### 6.4.3 A-law ADPCM initialization

The A-law ADPCM initialization sequence is obtained by applying the A-law PCM initialization sequence to an A-law → ADPCM coder at the given rate. These resulting initialization sequences are I\_INI\_16.M, I\_INI\_24.M, I\_INI\_32.M and I\_INI\_40.M for operation at 16, 24, 32 and 40 kbit/s respectively. They are prepended to the corresponding input sequence as follows: to the I16 for 16 kbit/s, I24 for 24 kbit/s, I32 for 32 kbit/s and I40 for 40 kbit/s. Thus, the length of the combined sequence increases to 19 880 samples. To check the ADPCM decoder operation the combined sequence is applied to a decoder and the PCM outputs corresponding to the i-inputs are obtained by skipping the first 3496 samples. These 3496 samples represent the A-law PCM initialization sequences coded by the ADPCM coder and then decoded by the ADPCM decoder at the given rate.

To test the cross-coding operation ( $A \rightarrow \mu$ ), the ADPCM initialization sequence for  $\mu$ -law decoding is prepended to the output of the ADPCM encoder at the respective rate. For example, at 40 kbit/s and for A-law PCM input and  $\mu$ -law PCM output, the combined sequence is I\_INI\_40.M + HN40FA.I for normal operation and I\_INI\_40.M + HV40FA.I for overload operation. Thus, the length of the combined sequence increases to 19 880 samples for normal operation and to 5544 samples for overload operation. The combined sequence is used to exercise the ADPCM decoder. After skipping the first 3496 samples, the relevant output PCM sequence, HN32FX.O or HV32FX.O, is extracted. The same can be done at the other rates.

#### 7 Commonality of test sequences

Many test conditions share the same sequences; Table 13 summarizes this commonality. A table entry gives the total number of sequences for a specific test case. The superscript identifies entries that share the same test sequences. For example, the 8 ADPCM sequences in the normal case of the  $\mu$ -law are pairwise identical to the corresponding ADPCM sequences in the normal tests of the conversion from  $\mu$ -law to A-law.

Table 13 – Number and commonality of test sequences

| Test μ-law | A-law |
|------------|-------|
|------------|-------|

| sequences         | Input<br>(PCM) | ADPCM                   | Output<br>(PCM)   | Input<br>(PCM)   | ADPCM           | Output<br>(PCM)   |
|-------------------|----------------|-------------------------|-------------------|------------------|-----------------|-------------------|
| Normal            | 11             | 82                      | 8                 | 14               | 88              | 8                 |
| I-input           | N/A            | 45                      | 8                 | N/A              | 45              | 8                 |
| Overload          | 16             | 87                      | 8                 | 18               | 89              | 8                 |
| Test              | μ-law → A-law  |                         | A-law → μ-law     |                  |                 |                   |
|                   |                |                         | _                 |                  |                 |                   |
| sequences         | Input (μ-PCM)  | ADPCM                   | Output<br>(A-PCM) | Input<br>(A-PCM) | ADPCM           | Output<br>(µ-PCM) |
| sequences  Normal | _              | ADPCM<br>8 <sup>2</sup> | _                 | -                | <b>ADPCM</b> 88 | _                 |

#### **8** Note to the user

The digital sequences are chosen to exercise the major arithmetic components and give a reasonable level of confidence of the compliance of an implementation with this Recommendation. It should be noted that all states cannot be covered with such a limited number of sequences. Suggestions for increasing the coverage and/or reports of problems encountered during the usage of the test sequences should be addressed to the ITU-T.

#### References

- [1] CCITT Recommendation G.726 (1990), 40, 32, 24, 16 kbit/s Adaptive Differential Pulse Code Modulation (ADPCM).
- [2] BANERJEE (S.), BERTOCCI (G.): Testing implementations of the 32 kbit/s CCITT and ANSI ADPCM algorithm, *Proc. ICC 1987*, Vol. 3, 1487-1490, 10 June 1987.

# ITU-T RECOMMENDATIONS SERIES Series A Organization of the work of the ITU-T Series B Means of expression Series C General telecommunication statistics Series D General tariff principles Series E Telephone network and ISDN Series F Non-telephone telecommunication services Series G Transmission systems and media, digital systems and networks Series H Transmission of non-telephone signals Series I Integrated services digital network Series J Transmission of sound-programme and television signals Series K Protection against interference Series L Construction, installation and protection of cables and other elements of outside plant Maintenance: international transmission systems, telephone circuits, telegraphy, facsimile and leased circuits Series M Maintenance: international sound-programme and television transmission circuits Series N Series O Specifications of measuring equipment Series P Telephone transmission quality Series Q Switching and signalling Series R Telegraph transmission Series S Telegraph services terminal equipment Series T Terminal equipments and protocols for telematic services Series U Telegraph switching Series V Data communication over the telephone network

Data networks and open system communication

Programming languages

Series X

Series Z

# ITU-T SOFTWARE

| G.191 (11.96)             | Software Tools Library 96 (STL-96) and STL-96 Manual                                                                                                                |
|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| G.722 Appendix II (03.87) | Digital test sequences for the verification of the G.722 64 kbit/s SB-ADPCM 7 kHz codec                                                                             |
| G.723.1 Annex A (11.96)   | C reference code, test signals and test sequences for the fixed point 5.3 and 6.3 kbit/s dual rate speech coder and for the silence compression scheme, version 5.1 |
| G.723.1 Annex B (11.96)   | C reference code and test signals for the floating point 5.3 and 6.3 kbit/s dual rate speech coder, version 5.1F                                                    |
| G.723.1 Annex C (11.96)   | C reference code and test signals for the scalable channel codec, version 3.1                                                                                       |
| G.726 Appendix II (03.96) | Digital test sequences for the verification of the G.726 40, 32, 24 and 16 kbit/s ADPCM algorithm                                                                   |
| G.727 Appendix I (03.96)  | Digital test sequences for the verification of the G.727 5-, 4-, 3- and 2-bit/sample embedded ADPCM algorithm                                                       |
| G.728 Appendix I (06.95)  | Programs and test sequences for implementation verification of the algorithm of the G.728 16 kbit/s LD-CELP speech coder                                            |
| G.729 (03.96)             | C Source code and test vectors for implementation verification of the G.729 8 kbit/s CS-ACELP speech coder                                                          |
| G.729 Annex A (11.96)     | C source code and test vectors for implementation verification of the G.729 reduced complexity 8 kbit/s CS-ACELP speech coder                                       |
| G.729 Annex B (10.96)     | C source code and test vectors for implementation verification of the algorithm of the G.729 silence compression scheme                                             |
| P.501 (08.96)             | Test signals for use in telephonometry                                                                                                                              |
| P.861 (08.96)             | C reference code of Perceptual Speech Quality Measure (PSQM)                                                                                                        |
| Q.921 bis (03.93)         | Abstract test suite for LAPD conformance testing – Part I: basic rate user side                                                                                     |
| Q.931 bis (02.95)         | PICS and abstract test suite for ISDN DSS 1 layer 3 – Circuit mode, basic call control conformance testing                                                          |
| Q.933 bis (10.95)         | PICS and abstract test suite for frame mode basic call control conformance testing of PVCs – Section I: user and network sides of user-network interface            |
| T.24 (11.94)              | Standardized digitized image set                                                                                                                                    |
| T.83 (11.94)              | Compliance test data for the generic encoder and decoder for<br>the digital compression and coding of continuous-tone still<br>images                               |