Conference Paper

Coder and Decoder of Block 3B4B with Auxiliary Channel

António D. Reis¹, José F. Rocha², Atílio S. Gameiro², and Jose P. Carvalho¹

¹University of Beira Interior
²University of Aveiro

Abstract

This work presents the coder and decoder of block 3B4B with auxiliary channel. The coder 3B4B converts an input 3 bits word in an output 4 bits word. It transmits an equal number of 1's and 0's to provide a DC constant component. It increases the transitions number, improves the system quality and security. The objective is also to improve the system potentialities with an auxiliary channel to monitor the communication (alarm). The main channel is real, but the auxiliary channel is fictitious.

Keywords: Block codes, Digital systems, Transmission lines

1. Introduction

This work studies the coder and decoder of block 3B4B with auxiliary channel [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]. The auxiliary channel (CA) does not consume physical resources. It is only achieved by programming the appropriate mBnB code in the PROMs (programmable ROM) of the encoder and decoder.

The code must satisfy the rule n=m+1 (m, n integers), to minimize the transmission elevation \( t_{x_o} = t_{x_i} \cdot n/m \). Also, n must be even to guarantee a constant DC component with many transitions. Also, m must be low to minimize the system complexity.

The coder converts a three bits word 3B in a word 4B. Posteriorly, the decoder converts newly the four bits word 4B in the original word 3B, recovering the initial sequence.

Fig.1 shows the communication system with relevance for the blocks coder and decoder 3B4B with auxiliary channel.

The coder improves certain characteristics such as:

- Constant DC component what avoids signal fluctuation.
- Sufficient transitions for clock recovery and retiming.
Figure 1: Communication system with the cod - dec 3B4B auxiliary

- Independent of the bits sequence.
- Decodification independent of the state.
- Multiplication of errors is low.
- Possibility of errors detection.
- Information for alignment of blocks / words.

In emitter, the data source provides the data, the scrambler becomes the spectrum input independent, the line coder equalizes the number of 1’s and 0,s, the signal emission adapts the signal to the channel type.

In receiver, the signal receiver provides the electric signal, the synchronizer recoveries the clock, the decoder makes the inverse of the coder, the descrambler makes the inverse of the scrambler and the destination is the final.

The code 3B4B with auxiliary channel is the same normal code 3B4B, where only one word 3B is coded differently, when the CA is zero (CA=0) or one (CA=1).

We choose, for example, the word 3B number 7. Then, it is necessary that two forbidden words belong to the dictionary and codify the situation CA = 1. We choose, for example, the words 1110, 0001 (Tab.1).

<table>
<thead>
<tr>
<th>3B word</th>
<th>+2 Disp.</th>
<th>0 Disp.</th>
<th>-2 Disp.</th>
</tr>
</thead>
<tbody>
<tr>
<td>0- 000</td>
<td>1101</td>
<td>0010</td>
<td></td>
</tr>
<tr>
<td>1- 001</td>
<td>0011</td>
<td></td>
<td></td>
</tr>
<tr>
<td>2- 010</td>
<td>0101</td>
<td></td>
<td></td>
</tr>
<tr>
<td>3- 011</td>
<td>0110</td>
<td></td>
<td></td>
</tr>
<tr>
<td>4- 100</td>
<td>1011</td>
<td></td>
<td></td>
</tr>
<tr>
<td>5- 101</td>
<td>1010</td>
<td></td>
<td></td>
</tr>
<tr>
<td>6- 110</td>
<td>1011 ‘0’</td>
<td>0100 ‘0’</td>
<td></td>
</tr>
<tr>
<td>7- 111</td>
<td>1110 ‘1’</td>
<td>0001 ‘1’</td>
<td></td>
</tr>
<tr>
<td>(7)-111</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
From a total of 16 words 4B there are 10+2 words for the dictionary (+2D=3, 0D=6, -2D=3). There are 6-2 forbidden words that are [0000, (withdrawal 0001), 0111, 1000, (withdrawal 1110), 1111]. This table produces the followings tables of codification and decodification.

2. Tables of Codification and Decodification

With the code 3B4B auxiliary, we can obtain the table of codification 3B4B and the table of decodification 3B4B.

2.1. Table of codification (PROM - Cod)

A DC constant component implies to send an equal number of 1’s and 0’s. Then, after to send a positive disparity word, ignoring the 0 disparity word, is necessary to send a negative word and vice-versa (Tab.2).

This table is programmed in the PROM (Programmable Read Only Memory) of the coder.

2.2. Table of decodification (PROM - Decod)

In the decoder PROM must be programmed the corresponding table of decodification (Tab.3)

The words with don’t care (11 - - -) are forbidden, can be associated with for example (11 - - -) ≡ (11 010).

3. Pair Coder and Decoder 3B4B

To provide the operation of encoding and decoding tables is necessary to project (create) the hardware of the coder and decoder.

3.1. Coder 3B4B

The codification table is programmed in a PROM, having a flip flop that guards the information of the parity P (positive or negative) of the last transmitted word, according to the status diagram of Fig.2.
This states diagram implemented in the flip flop controls the codification mode of the PROM (mode 0 or mode 1).
TABLE 3: Table of decodification 3B4B auxiliary (Prom-Dec)

<table>
<thead>
<tr>
<th>4B word B_1B_2B_3B_4</th>
<th>+2 Disp. C_1C_2P_1P_2A_2-A_0</th>
<th>0 Disp., ÉD C_1C_2P_1P_2A_2-A_0</th>
<th>-2 Disp. C_1C_2P_1P_2A_2-A_0</th>
</tr>
</thead>
<tbody>
<tr>
<td>0- 0 000</td>
<td></td>
<td>00 11 - - -</td>
<td></td>
</tr>
<tr>
<td>1- 0 001</td>
<td></td>
<td>Substituted</td>
<td>10 01 111 '1'</td>
</tr>
<tr>
<td>2- 0 010</td>
<td></td>
<td>00 00 001</td>
<td>00 01 000</td>
</tr>
<tr>
<td>3- 0 011</td>
<td></td>
<td></td>
<td>01 01 111 '0'</td>
</tr>
<tr>
<td>4- 0 100</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>5- 0 101</td>
<td></td>
<td>00 00 010</td>
<td></td>
</tr>
<tr>
<td>6- 0 110</td>
<td></td>
<td>00 00 011</td>
<td></td>
</tr>
<tr>
<td>7- 0 111</td>
<td></td>
<td>00 11 - - -</td>
<td></td>
</tr>
<tr>
<td>8- 1 000</td>
<td></td>
<td>00 11 - - -</td>
<td></td>
</tr>
<tr>
<td>9- 1 001</td>
<td></td>
<td>00 00 100</td>
<td></td>
</tr>
<tr>
<td>10- 1 010</td>
<td></td>
<td>00 00 101</td>
<td></td>
</tr>
<tr>
<td>11- 1 011</td>
<td>01 10 111 '0'</td>
<td></td>
<td></td>
</tr>
<tr>
<td>12- 1 100</td>
<td></td>
<td>00 00 110</td>
<td></td>
</tr>
<tr>
<td>13- 1 101</td>
<td>00 10 000</td>
<td></td>
<td></td>
</tr>
<tr>
<td>14- 1 110</td>
<td>10 10 111 '1' Substituted</td>
<td></td>
<td></td>
</tr>
<tr>
<td>15- 1 111</td>
<td>00 11 - - -</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Figure 2: States diagram of the codification (memory element)

The PROM is the core of the coder. The table, in M=0 is the mode 0 and in M=1 is the mode 1. The table of codification is in the PROM and the states diagram (controller) is in the flip flop memory (Fig.3).

Figure 3: PROM with the codification table 3B4B aux and flip flop

The flip flop receives the disparity P of the anterior word and leads to the correct codification mode (0 or 1). If the disparity P is null, it maintains the codification mode, otherwise it switches to the other codification mode.
In the coder, the data enters in serial 3B, is converted to parallel, coded 3B4B, newly converted to serial 4B and after sent. For this is necessary an input shift register serial - parallel, a normal register, memory PROM and an output parallel-serial shift register. So that this components (architecture) work correctly is necessary a controller based in a clock synthesizer involving two counters of module 3 and 4 and a PLL (Phase Lock Loop) (Fig.4).

![Figure 4: Coder 3B4B](image)

The clock generator is the reference mark (beat) that marks the operation rhythm of the global system.

In the auxiliary channel CA (7, 15, 23, 31), when CA=0 are send the words of NORMAL (1011, 0100), when CA=1 are sent the words of ALARM (1110, 0001).

### 3.2. Decoder 3B4B

The decodification table 3B4B is programmed in a PROM (Decod), but is necessary that the input words are aligned (marked).

To align correctly the input words 4B is necessary an error detector that detects the forbidden words that don’t belong to the codification dictionary and still disrespect the accumulate disparity rule. When occur more than x errors in M, there is suspicion of misalignment and then is activated the alignment mechanism.

The error detector receives information P1P0 of the words forbidden (not belongs to the dictionary) and still the disrespects to the accumulate disparity rule and leads to the error state Se, with output Z = 1 (Fig.5).

The states diagram conduct to the states table, which leads to the circuit of errors detector (Fig.6)
The errors detector was implemented with conventional logic (Karnaugh maps), but could be implemented in a PROM with 2 flip flops (states table) or in a PLD (states diagram).

The PROM (Decod) with the decodification table 3B4B and the errors detector has the configuration of Fig.7.

So that the PROM (Decod) can work (function) correctly are needed various auxiliary circuits. In the decoder, the data enters in serial 4B, it is converted to parallel, decoded 3B4B and after converted newly to serial 3B recovering the original sequence.

For this, is need an input shift register serial - parallel, a normal register, a memory (PROM) and an output parallel - serial shift register. So that this components (architecture) work in perfect harmony is need the controller based in the clocks synthesizer of two counters of

The controller of module 4 can change provisionally the counting module for 4+1=5, in order to make the word alignment, if there is more than x=8 word errors in M=64 words.
Figure 8: Decoder 3B4B

in the beginning and after 4 word errors in M=64. The clock recover (synchronizer) is the beat that marks the operation rhythm of the entire receiver.

In auxiliary channel CA, when appear the words of NORMAL (1011, 0100), C₁C₀(SR)=01, is made the latch Reset. When appear the words of ALARM (1110, 0001), C₁C₀(SR)=10 is made the latch Set (LED on). For other words C₁C₀=00 and the latch maintains the state.

4. Project, Tests and Results

We present bellow the project, tests and results [5].

4.1. Project

In the pair Coder - Decoder, such as in a digital communication system, is necessary to use good project techniques to create the hardware (architecture) with the able potentiality to execute the desired task. However, is still necessary to make them communicate using a clock synthesizer (controller) that gives unity to the system parts and whose clock is the beater that marks the rhythm.

After designed, the project was tested theoretically in the paper, with a sequence 1' and 0 alternated, however actually the simulation is the tool normally used.

Following, the pair Cod - Decod was mounted and tested in an ebonite bread-board. Finally, with previous performance guaranties, was implemented in printed circuit boards.
4.2. Tests

The pair Cod - Decod was initially connected between itself by a cooper line. In the transitory state, during the power on, occur the inherent errors until to establish the word alignment, which after in the permanent state soon finished and no more appeared.

4.3. Results

The pair Cod-Decod was integrated in the global system with transmission by fibre optic with a gap (air space) that simulated 50 km.

With a degraded signal in its relation signal - noise SNR in the minimum threshold of the CCITT (Comité Consultatif International Telephonique Télégraphique) / ITU (International Telecomunication Union) the ratio error bits/ total bits BER (Bit Error Rate) of the system (BER - measured) was $10^{-15}$ and was lesser than the values allowed by the CCITT (BER - CCITT) of $10^{-12}$.

This errors 3 - 5 in a period of 24h, have nothing with the pair Cod - Decod, but yes with the fortuitous errors of the synchronizer decision when deciphers ‘1’ or ‘0’ in a signal strongly degraded and indecipherable at human eye.

5. Conclusions

We studied the block coder 3B4B with auxiliary channel.

The coder prepares the data to be transmitted with greater quality and security.

The pair coder decoder 3B4B is based in the code 3B4B programmed in a memory PROM and input serial-parallel and output parallel - serial.

The pair coder decoder needs in the emitter of a clock generator and in the decoder of a synchronizer (clock recovery) that are the reference clock of the synthesizer that controls the work rhythm of all the system.

In the transitory state of start, it arise the inherent alignments errors, that quickly disappear when the permanent state is reached.

With the pair Cod - Decod integrated in the global system, it arise some errors, which are related with the synchronizer decider that is disturbed by the noise.

Anyway, the obtained BER - measured was 10-15 what is lesser than the allowed BER - CCITT that is 10-12.
Acknowledgments

The authors are grateful to the program FCT (Foundation for the sCience and Technology).

References


