encoding is the process of converting the data or a given sequence of characters, symbols, alphabets etc., into a specified format, for the secured transmission of data. decoding is the reverse process of encoding which is to extract the information from the converted format.
data encoding
encoding is the process of using various patterns of voltage or current levels to represent 1s and 0s of the digital signals on the transmission link.
the common types of line encoding are unipolar, polar, bipolar, and manchester.
encoding techniques
the data encoding technique is divided into the following types, depending upon the type of data conversion.
- analog data to analog signals − the modulation techniques such as amplitude modulation, frequency modulation and phase modulation of analog signals, fall under this category. 
- analog data to digital signals − this process can be termed as digitization, which is done by pulse code modulation (pcm). hence, it is nothing but digital modulation. as we have already discussed, sampling and quantization are the important factors in this. delta modulation gives a better output than pcm. 
- digital data to analog signals − the modulation techniques such as amplitude shift keying (ask), frequency shift keying (fsk), phase shift keying (psk), etc., fall under this category. these will be discussed in subsequent chapters. 
- digital data to digital signals − these are in this section. there are several ways to map digital data to digital signals. some of them are − 
non return to zero (nrz)
nrz codes has 1 for high voltage level and 0 for low voltage level. the main behavior of nrz codes is that the voltage level remains constant during bit interval. the end or start of a bit will not be indicated and it will maintain the same voltage state, if the value of the previous bit and the value of the present bit are same.
the following figure explains the concept of nrz coding.
 
if the above example is considered, as there is a long sequence of constant voltage level and the clock synchronization may be lost due to the absence of bit interval, it becomes difficult for the receiver to differentiate between 0 and 1.
there are two variations in nrz namely −
nrz - l (nrz – level)
there is a change in the polarity of the signal, only when the incoming signal changes from 1 to 0 or from 0 to 1. it is the same as nrz, however, the first bit of the input signal should have a change of polarity.
nrz - i (nrz – inverted)
if a 1 occurs at the incoming signal, then there occurs a transition at the beginning of the bit interval. for a 0 at the incoming signal, there is no transition at the beginning of the bit interval.
nrz codes has a disadvantage that the synchronization of the transmitter clock with the receiver clock gets completely disturbed, when there is a string of 1s and 0s. hence, a separate clock line needs to be provided.
bi-phase encoding
the signal level is checked twice for every bit time, both initially and in the middle. hence, the clock rate is double the data transfer rate and thus the modulation rate is also doubled. the clock is taken from the signal itself. the bandwidth required for this coding is greater.
there are two types of bi-phase encoding.
- bi-phase manchester
- differential manchester
bi-phase manchester
in this type of coding, the transition is done at the middle of the bit-interval. the transition for the resultant pulse is from high to low in the middle of the interval, for the input bit 1. while the transition is from low to high for the input bit 0.
differential manchester
in this type of coding, there always occurs a transition in the middle of the bit interval. if there occurs a transition at the beginning of the bit interval, then the input bit is 0. if no transition occurs at the beginning of the bit interval, then the input bit is 1.
the following figure illustrates the waveforms of nrz-l, nrz-i, bi-phase manchester and differential manchester coding for different digital inputs.
 
block coding
among the types of block coding, the famous ones are 4b/5b encoding and 8b/6t encoding. the number of bits are processed in different manners, in both of these processes.
4b/5b encoding
in manchester encoding, to send the data, the clocks with double speed is required rather than nrz coding. here, as the name implies, 4 bits of code is mapped with 5 bits, with a minimum number of 1 bits in the group.
the clock synchronization problem in nrz-i encoding is avoided by assigning an equivalent word of 5 bits in the place of each block of 4 consecutive bits. these 5-bit words are predetermined in a dictionary.
the basic idea of selecting a 5-bit code is that, it should have one leading 0 and it should have no more than two trailing 0s. hence, these words are chosen such that two transactions take place per block of bits.
8b/6t encoding
we have used two voltage levels to send a single bit over a single signal. but if we use more than 3 voltage levels, we can send more bits per signal.
for example, if 6 voltage levels are used to represent 8 bits on a single signal, then such encoding is termed as 8b/6t encoding. hence in this method, we have as many as 729 (3^6) combinations for signal and 256 (2^8) combinations for bits.
these are the techniques mostly used for converting digital data into digital signals by compressing or coding them for reliable transmission of data.
