the noise present in a channel creates unwanted errors between the input and the output sequences of a digital communication system. the error probability should be very low, nearly ≤ 10-6 for a reliable communication.
the channel coding in a communication system, introduces redundancy with a control, so as to improve the reliability of the system. the source coding reduces redundancy to improve the efficiency of the system.
channel coding consists of two parts of action.
- mapping incoming data sequence into a channel input sequence. 
- inverse mapping the channel output sequence into an output data sequence. 
the final target is that the overall effect of the channel noise should be minimized.
the mapping is done by the transmitter, with the help of an encoder, whereas the inverse mapping is done by the decoder in the receiver.
channel coding
let us consider a discrete memoryless channel (δ) with entropy h (δ)
ts indicates the symbols that δ gives per second
channel capacity is indicated by c
channel can be used for every tc secs
hence, the maximum capability of the channel is c/tc
the data sent = $\frac{h(\delta)}{t_s}$
if $\frac{h(\delta)}{t_s} \leq \frac{c}{t_c}$ it means the transmission is good and can be reproduced with a small probability of error.
in this, $\frac{c}{t_c}$ is the critical rate of channel capacity.
if $\frac{h(\delta)}{t_s} = \frac{c}{t_c}$ then the system is said to be signaling at a critical rate.
conversely, if $\frac{h(\delta)}{t_s} > \frac{c}{t_c}$, then the transmission is not possible.
hence, the maximum rate of the transmission is equal to the critical rate of the channel capacity, for reliable error-free messages, which can take place, over a discrete memoryless channel. this is called as channel coding theorem.
