Computer Network (Unit 1)
Computer Network (Unit 1)
Data Communications are the exchange of data between two devices via some formi of
transmission medium such as cables, telephone lines, radio waves, satellite etc.
The term Computer network means an interconnected collection of autonomous computers. Two
computers are said to be interconnected if they are able to exchange information.
Two or more autonomous computers that are linked together in order to * Share resources (files,
printers, scanners, modems). # Share application softwares (MS office). Allow electronic
communication (e-mail, video conferencing). * Increase productivity (makes it easier to share
data among users).
1. Local Area Network (LAN): is usually a privately owned and links the devices in a single
office, building, or campus currently, LAN size is limited to a few kilometers. LAN's are
designed to allow resources to be shared between personal computers or workstations. The
resources to be shared can include hardware, software or data.
2. Metropolitan Area Network (MAN): is a network with a size between a LAN and a WAN. It
normally covers the area inside a town or a city. It is designed for customers who need a high
speed connectivity, normal to the internet, and have end points spread over a part of city or full.
3. Wide Area Networks (WAN): is a network that provides long-distance transmission of data,
image, audio and video information over large geographical area and covers different cities states
and even countries.
Evolution of Networking:
Internet:
∙ The internet is a worldwide network of computer network evolved from the first network
ARPANET.
∙ Internet is an interconnection of large and small networks around the globe. ∙ The common use
of internet standards allows users connected to one network to communicate with users on
another network.
A computer network consists of software and hardware that is used to send and receive data from
one device to another. The role of hardware is to prove the physical equipment that are required
in order to send and receive data while software defines the set of instructions that uses the
hardware equipment for data transmission. A simple transmission of data consists of several
steps at various layers of the computer network. In computer network models we will discuss the
models in detail to understand how the data is actually transferred and received at a computer
level.
3. Dividing a model into layers makes the structure quite simple and makes it easy to identify the
issue if it occurs. There are three main components of a computer network model. Sender,
receiver and carrier.
At sender Side:
Higher layer: Higher layer serves the middle layer, directs the message (or data) to middle layer
Middle layer: Middle layer picks up the data from higher layer and transfer it to the lower layer
lower layer: The data is transmitted to the lower layer of the receiver side.
At receiver Side:
lower layer: Receives the data from the lower layer of the sender side and transfers it to the
middle layer.
Middle layer: Middle layer picks up the data from the lower layer and transfers to the higher
layer.
Higher layer: Higher layer transfers the data to the receiver.
4. We will discuss more than one computer model here, each model has a different set and design
of layers.
Protocol Layering
A protocol is a set of rules and standards that primarily outline a language that devices will use
to communicate. There are an excellent range of protocols in use extensively in networking, and
that they are usually implemented in numerous layers.
It provides a communication service where the process is used to exchange the messages. When
the communication is simple, we can use only one simple protocol.
When the communication is complex, we must divide the task between different layers, so, we
need to follow a protocol at each layer, this technique we used to call protocol layering. This
layering allows us to separate the services from the implementation.
Each layer needs to receive a set of services from the lower layer and to give the services to the
upper layer. The modification done in any one layer will not affect the other layers.
Advantages :
● This layered architecture follows the abstraction principle. Change in one layer does not
impact much on other layers.
● It follows the divide and conquers technique. All the services are distinguished in various
layers. So administration and maintenance for these OSI model architecture are
straightforward and easy.
● It is more secure and adaptable than having all services bundled in a single layer.
Disadvantages
● The upper-level layers cannot see what is within the lower layers, implying that an
application cannot correct where in an exceedingly connection a problem is or precisely
what the matter is.
● The higher-level layers cannot control all aspects of the lower layers, so that they cannot
modify the transfer system if helpful (like controlling windowing, header compression,
CRC/parity checking, et cetera), nor specify routing, and should rely on the lower
protocols operating, and cannot specify alternatives when there are issues.
● There is also interdependence among the layers. These layers cannot work in parallel.
They have to be in wait to receive data from its predecessor.
1.OSI model
OSI model was introduced by the International Organisation for standardisation (ISO) in 1984.
There are seven layers in a OSI model
Application layer
Presentation Layer
Session layer
Transport layer
Network Layer
DataLink layer
Physical layer
Application layer
1. Application layer is used by computer applications such as google chrome, outlook, FireFox,
Skype etc.
2. Application layer defines the protocols that are used by computer applications for example:
HTTP and HTTPS protocols are used by web browsers such as google chrome, FireFox, Safari
etc.
FTP protocol is used for file transfer between two or more computers.
There are dozens of other protocol that forms the application layer, such as NFS, FMTP, DHCP,
SNMP, POP3, IRC, NNTP etc.
3. In short you can say that application layer provides the services to computer applications with
the help of protocols that are defined in it.
Presentation Layer
Presentation layer receives the data from top most layer which is application layer.
Translation: The data received from application layer is in form of characters and numbers such
as 1234, ERFF etc. The presentation layer converts these characters and numbers into machine
understandable format which is known as binary format for example 100111101.
Encryption: To protect the sensitivity of data, presentation layer encrypts the data at the sender
side before the transmission and the receiver side this data is decrypted by the presentation layer
at the receiver side. Secure sockets layer protocol (SSL) is used by the presentation layer for
encryption and decryption.
Compression: Compress the data to small size so that it can be transferred faster over a network.
This compression can be lossy or lossless compression.
Session Layer
The main role of session layer is to setup and maintain the connection between different systems.
Main functions of session layer:
Authentication: Before a computer can be connected to a server, the computer has to provide user
name and password for the authentication. The function of authentication and setting up a
connection after authentication is performed by session layer.
Authorization: Once a connection is established, session layer checks whether the connected
computer is authorised to access the data, this function of authorisation checking is also
performed by session layer.
Session management: Session layer also checks that the data which is received from the server in
form of data packets belongs to which application for example when you access Facebook
profile through your browser, the data transferred from the Facebook server is transferred to your
web browser application, thus the session layer helps in session management.
Transport layer
The main role of transport layer is to check the reliability of data communication.
Flow control: It controls the flow of data. It checks the capability of the receiver device receiving
capability before transmitting data. For example a sender server can send the data at a rate of
200Mbps but a receiving data can only receive data at a rate of 10 Mbps then it controls the flow
of data to 10Mbps so that the data doesn’t get lost during transmission.
Error control: Transport layer also performs error control using Automatic Repeat Request, if a
data is lost during transmission, it is send again using automatic repeat request. Transport layer
also adds a group of bits called checksum with each segment to check whether the data received
at receiver side is not corrupt.
The main purpose of network layer is to receive the data segments from transport layer and
transfer them from one computer to another computer on different network.
Routing: It is a method of transferring data packets from source to destination. It uses the
combination of Mask and IP address to transfer the data to correct destination. Each data packets
contains three addition components mask, sender IP, receiver IP. The Mask determines the
computer network to which the data needs to be delivered and then the IP address determines
which computer on that particular network needs to receive the data packet.
Physical Layer
We now learned that a transport layer converts the data into segments, network layer converts the
segments into packets and data link layer converts the packets into frames. A frame is nothing
but a sequence of bits such as 1001011.
Physical layer converts these binary sequences into signals and transfer it through a transmission
media such as cables etc.
The signals generated by physical layer is based on the transmission media. For example an
electrical signal is generated if the media is copper cable, light signal if media is optical fibre and
radio signal in case of transmission media is air. This generated signal is received by the physical
layer at the receiver side and converts it into bits.
Line coding:
A digital data is in form of binary sequence such as 1000111 (combination of 0s and 1s). Line
coding uses three schemes to represent these binary sequences in form of signals that can be
transferred.
TCP/IP model
TCP/IP Model helps you to determine how a specific computer should be connected to the
internet and how data should be transmitted between them. It helps you to create a virtual
network when multiple computer networks are connected together. The purpose of TCP/IP
model is to allow communication over large distances.
TCP/IP stands for Transmission Control Protocol/ Internet Protocol. TCP/IP Stack is specifically
designed as a model to offer highly reliable and end-to-end byte stream over an unreliable
internetwork.
The functionality of the TCP IP model is divided into four layers, and each includes specific
protocols.
TCP/IP is a layered server architecture system in which each layer is defined according to a
specific function to perform. All these four TCP IP layers work collaboratively to transmit the
data from one layer to another.
There are 4 layers in TCP/IP Layer
Application Layer
Transport Layer
Internet Layer
Network Access Layer
Application layer
At the top of the Transport layer, the Application Layer is present in the TCP/IP Model. The
Application layer defines the procedure of interaction between the host applications and the
protocols. In this interaction, the applications interact with the transport layer services for using
the network. It also specifies the protocols going to be used by TCP/IP applications.
Functions
The Application layer provides access to global information about numerous services and objects
from distributed database sources.
This layer plays its part in the identification of communication partners, communication
synchronization, and resource availability.
The application layer enables users to connect to a remote server.
It also offers a variety of e-mail services.
Example of the application layer is an application such as file transfer, email, remote login, etc.
Application Layer Protocols
Higher-level protocols such as HTTP, RDP, DHCP, DNS, X Windows, Telnet, SMTP, SSH,
TFTP, SNMP (, FTP, all are included in the Application layer.
Transport layer
Transport layer helps you to control the reliability of a link through flow control, error control,
and segmentation or de-segmentation.
Functions
It divides the message received from the session layer into segments and numbers them to make
a sequence.
Transport layer makes sure that the message is delivered to the correct process on the destination
machine.
It also makes sure that the entire message arrives without any error else it should be
retransmitted.
Transport Layer Protocols
The Transport Layer employs TCP and UDP protocols.
Internet Layer
In the TCP/IP model, the Network layer or the Internet layer is the second layer. Data is packed
into IP datagrams by the Internet layer, including source and destination address information for
forwarding datagrams across networks and between hosts. This layer is present in between
Transport and Network Access Layer.
Functions
One of the main functions of the Internet layer is to send data packets to their destination
networks.
It can handle forwarding, path determination, and logical addressing.
IP datagram routing comes under the responsibilities of the Internet layer.
Routing protocols are utilized at this layer to help routers learn about various networks they can
access and deliver error messages.
Internet Layer Protocols
IP, RARP, ICMP, IGMP, and ARP are the primary protocols used at the Internet layer (Internet
Group Management Protocol).
The Network Access Layer defines the mechanism of how data is physically transmitted via the
network. It also includes how bits are optically or electrically communicated by hardware
devices that directly interact with a network medium, such as twisted-pair copper wire, optical
fiber, and coaxial cable. In TCP/IP model, Network Access Layer is the lowermost layer.
Functions
The Network Access Layer defines the procedure of data transmission over a network.
It is primarily in charge of the data transmission between two networked devices.
This layer performs functions such as translating IP addresses to physical addresses and
encapsulating IP datagrams into network frames.
Network Access Layer Protocols
FDDI, X.25, Ethernet, Frame Relay, Token Ring are included in the Network Access Layer.
Transmission impairments
Transmission impairment occurs when the received signal is different from the transmitted
signal.
Causes of impairment –
Attenuation – It means loss of energy. The strength of signal decreases with increasing distance
which causes loss of energy in overcoming resistance of medium. This is also known as
attenuated signal. Amplifiers are used to amplify the attenuated signal which gives the original
signal back and compensate for this loss.
Distortion – It means changes in the form or shape of the signal. This is generally seen in
composite signals made up with different frequencies. Each frequency component has its own
propagation speed travelling through a medium. And thats why it delay in arriving at the final
destination Every component arrive at different time which leads to distortion. Therefore, they
have different phases at receiver end from what they had at senders end.
Noise – The random or unwanted signal that mixes up with the original signal is called noise.
There are several types of noise such as induced noise, crosstalk noise, thermal noise and
impulse noise which may corrupt the signal.
Induced noise comes from sources such as motors and appliances. These devices act as sending
antenna and transmission medium act as receiving antenna. Thermal noise is movement of
electrons in wire which creates an extra signal. Crosstalk noise is when one wire affects the other
wire. Impulse noise is a signal with high energy that comes from lightning or power lines
For example, if there is a noiseless channel with a bandwidth of 4 KHz that is transmitting a
signal with 4 discrete levels, then the maximum bit rate will be computed as, maximum bit rate =
2 × 4000 × log24 = 16,000 bps = 16 kbps
Shannon's Capacity
Claude Shannon extended Nyquist's work for actual channels that are subject to noise. Noise can
be of various types like thermal noise, impulse noise, cross-talks etc. Among all the noise types,
thermal noise is unavoidable. The random movement of electrons in the channel creates an
extraneous signal not present in the original signal, called the thermal noise. The amount of
thermal noise is calculated as the ratio of the signal power to noise power, SNR.
Since SNR is the ratio of two powers that varies over a very large range, it is often expressed in
decibels, called SNRdb and calculated as: SNRdb = 10log10SNR.
Shannon's Capacity gives the theoretical maximum data rate or capacity of a noisy channel. It is
expressed as:
For example, if the bandwidth of a noisy channel is 4 KHz, and the signal to noise ratio is 100,
then the maximum bit rate can be computed as:
Performance
● Bandwidth
● Throughput
● Latency (Delay)
● Packet Loss
● Jitter
Bandwidth
The quantity of bandwidth allocated to the network is one of the most important conditions of a
website's performance. The web server's bandwidth controls how quickly it can transfer the
requested data. While there are many elements to consider regarding a site's speed, bandwidth is
frequently the limiting issue.
The amount of data or information that can be transmitted in a given amount of time is referred
to as bandwidth. The phrase can be applied in two ways, each having its own set of estimating
values. The bandwidth of digital devices is measured in bits per second (bps) or bytes per second
(bps). The bandwidth of analog devices is measured in cycles per second, or Hertz (Hz).
More bandwidth does not mean more speed instead it shows the maximum data transmission rate
possible on a network.
Bandwidth is therefore a measure of capacity rather than speed.
Throughput
The number of messages successfully delivered per unit time is referred to as throughput.
Throughput is influenced by the available bandwidth, as well as the available signal-to-noise
ratio and device limitations.
Throughput measures the network’s actual data transmission rate.
Latency
Latency is simply the time it takes for data to travel from one designated location to another
regarding network performance evaluation. The term "delay" is sometimes used to describe this
attribute. The latency of a network should be as low as possible.
Speed of light is the fundamental factor for latency, but packet queuing and refractive index of
fiber optic cable are also two factors that can be used to reduce latency.
Packet Loss
Packet loss refers to the number of packets that fail to transfer from one destination to another
regarding network performance measurement. This statistic can be measured by recording traffic
data on both ends and then identifying lost packets and packet retransmission.
Several factors such as network congestion, router performance, and software problems can
cause pocket loss.
Network congestion, router performance, and software difficulties, among other things, can
cause packet loss.
Jitter
The variance in time delay for data packets carried over a network is known as jitter. This
variable denotes an interruption in data packet sequencing that has been identified. Jitter and
latency are linked because jitter generates increased or uneven latency between data packets,
which can damage network performance and cause packet loss and congestion.
While some jitter is to be expected and can typically be tolerated, quantifying network jitter is an
integral part of measuring overall network performance.
This is often caused by network congestion, and sometimes route changes.
A link-layer address is called a link address, called a physical address, and sometimes a MAC
address. Since a link is controlled at the data-link layer, the addresses need to belong to the
data-link layer.
When a datagram passes from the network layer to the data-link layer,the datagram will be
encapsulated in a frame and two data-link addresses are added to the frame header.These two
addresses are changed every time the frame moves from one link to another.
Figure shows, IP addresses and link-layer addresses in a small internet.
Here we have three links and two routers. We have two hosts: Alice (source) and Bob
(destination). For each host, we have shown two addresses, the IP addresses (N) and the
link-layer addresses (L).
We have three frames, one in each link.Each frame carries the same datagram with the same
source and destination addresses (N1 and N8), but the link-layer addresses of the frame change
from link to link. In link 1, the link-layer addresses are L1 and L2. In link 2, they are L4 and L5.
In link 3, they are L7 and L8.
Note that the IP addresses and the link-layer addresses are not in the same order. For IP
addresses, the source address comes before the destination address; for link-layer addresses, the
destination address comes before the source.
Unicast Address
Each host or each interface of a router is assigned a unicast address. Unicasting means one
to-one communication. A frame with a unicast address destination is destined onlyf or one entity
in the link.
Example
The unicast link-layer addresses in the most common LAN, Ethernet, are 48 bits (six bytes) that
are presented as 12 hexadecimal digits separated by colons; for example, the following is a
link-layer address of a computer.
A3:34:45:11:92:F1
Multicast Address
Some link-layer protocols define multicast addresses. Multicasting means one-to many
communication.
Example
The multicast link-layer addresses in the most common LAN,Ethernet, are 48 bits (six bytes) that
are presented as 12 hexadecimal digits separated by colons.The second digit, needs to be an even
number in hexadecimal. The following shows a multicast address:
A2:34:45:11:92:F1
Broadcast Address
Some link-layer protocols define a broadcast address. Broadcasting means one-to-all
communication. A frame with a destination broadcast address is sent to all entities in the link.
Example
The broadcast link-layer addresses in the most common LAN,Ethernet, are 48 bits, all 1s, that
are presented as 12 hexadecimal digits separated by colons.
The following shows a broadcast address: FF:FF:FF:FF:FF:FF .
Address Resolution Protocol
The ARP protocol is one of the protocols defined in the network layer, as shown in Figure . It
belongs to the network layer. It maps an IP address to a logical-link address. The main work of
ARP : It accepts an IP address from the IP protocol, maps the address to the corresponding link
layer address, and passes it to the data-link layer.
If a host or a router needs to find the link-layer address of another host or router in its network,
it sends an ARP request packet.The packet includes the link-layer and IP addresses of the sender
and the IP address of the receiver. Because the sender does not know the link-layer address of
the receiver, the query is broadcast over the link using the link-layer broadcast address.
Every host or router on the network receives and processes the ARP request packet, but only
the intended recipient recognizes its IP address and sends back an ARP response packet.
The response packet contains the recipient’s IP and link-layer addresses. The packet is
unicast directly to the node that sent the request packet.
In Figure 1.7.3, the system on the left (A) has a packet that needs to be delivered to another
system (B) with IP address N2. System A needs to pass the packet to its data-link layer for the
actual delivery, but it does not know the physical address of the recipient. It uses the services of
ARP by asking the ARP protocol to send a broadcast ARP request packet to ask for the physical
address of a system with an IP address of N2.This packet is received by every system on the
physical network, but only system B will answer it, as shown in Figure 1.7.3b.System B sends
an ARP reply packet that includes its physical address. Now system A can send all the packets it
has for this destination using the physical address it received.
Packet Format
Figure shows the format of an ARP packet. The hardware type field defines the type of
the link-layer protocol; Ethernet is given the type 1. The protocol type field defines the
network-layer protocol: IPv4 protocol is (0800)16.
The source hardware and source protocol addresses are variable-length fields defining the
link-layer and network-layer addresses of the sender. The destination hardware address and
destination
protocol address fields define the receiver link layer rand network-layer addresses. An ARP
packet is encapsulated directly into a data-link frame. The frame needs to have a field to show
that the payload belongs to the ARP and not to the network-layer datagram.
Error detection and correction:
Block coding
In block coding, we divide our message into blocks, each of k bits, called data words. We add r
redundant bits to each block to make the length n = k + r. The resulting n-bit blocks are called
code words.
For example, we have a set of data words, each of size k, and a set of code words, each of size of
n. With k bits, we can create a combination of 2k data words, with n bits; we can create a
combination of 2n code words. Since n > k, the number of possible code words is larger than
the number of possible data words.
The block coding process is one-to-one; the same data word is always encoded as the same
code word. This means that we have 2n-2k code words that are not used. We call these code
words invalid or illegal. The following figure shows the situation.
Error Detection
If the following two conditions are met, the receiver can detect a change in the original code
word by using Block coding technique.
1. The receiver has (or can find) a list of valid code words.
The block coding process is one-to-one; the same data word is always encoded as the same
code word. This means that we have 2n-2k code words that are not used. We call these code
words invalid or illegal. The following figure shows the situation.
Error Detection
If the following two conditions are met, the receiver can detect a change in the original code
word by using Block coding technique.
1. The receiver has (or can find) a list of valid code words.
The sender creates code words out of data words by using a generator that applies the rules
and procedures of encoding (discussed later). Each code word sent to the receiver may change
during transmission. If the received code word is the same as one of the valid code words, the
word is accepted; the corresponding data word is extracted for use.
If the received code word is not valid, it is discarded. However, if the code word is corrupted
during transmission but the received word still matches a valid code word, the error remains
undetected. This type of coding can detect only single errors. Two or more errors may remain
undetected.
For example consider the following table of data words and Code words:
Assume the sender encodes the data word 01 as 011 and sends it to the receiver. Consider the
following cases:
1. The receiver receives O11. It is a valid code word. The receiver extracts the data word 01
from it.
2. The code word is corrupted during transmission, and 111 is received (the leftmost bit is
corrupted). This is not a valid code word and is discarded.
3. The code word is corrupted during transmission, and 000 is received (the right two bits are
corrupted). This is a valid code word. The receiver incorrectly extracts the data word 00. Two
corrupted bits have made the error undetectable.
Error Correction:
Error correction is much more difficult than error detection. In error detection, the receiver needs
to know only that the received code word is invalid, in error correction the receiver needs to find
(or guess) the original code word sent. So, we need more redundant bits for error correction
than for error detection.
Assume the data word is 01. The sender consults the table (or uses an algorithm) to create the
code word 01011. The code word is corrupted during transmission, and 01001 is received (error
in the second bit from the right). First, the receiver finds that the received code word is not in the
table. This means an error has occurred. (Detection must come before correction.) The receiver,
assuming that there is only 1 bit corrupted, uses the following strategy to guess the correct data
word.
1. Comparing the received code word with the first code word in the table (01001 versus
00000), the receiver decides that the first code word is not the one that was sent
because there are two different bits.
2. By the same reasoning, the original code word cannot be the third or fourth one in the
table.
3. The original code word must be the second one in the table because this is the only one
that differs from the received code word by 1 bit. The receiver replaces 01001 with
01011 and consults the table to find the data word 01.
Cyclic code
Cyclic codes are special linear block codes with one extra property. In a cyclic code, if a code
word is cyclically shifted (rotated), the result is another code word. For example, if 1011000 is a
code word and we cyclically left-shift, then 0110001 is also a code word.
In this case, if we call the bits in the first word a0 to a6 and the bits in the second word b0 to b6,
we can shift the bits by using the following:
One of the categories of cyclic codes called the cyclic redundancy check (CRC) that is used in
networks such as LANs and WANs.
CRC or Cyclic Redundancy Check is a method of detecting accidental changes/errors in the
communication channel.
CRC uses Generator Polynomial which is available on both sender and receiver side. An
example generator polynomial is of the form like x3 + x + 1. This generator polynomial
represents key 1011. Another example is x2 + 1 that represents key 101.
Sender Side (Generation of Encoded Data from Data and Generator Polynomial (or Key)):
1. The binary data is first augmented by adding k-1 zeros in the end of the data
2. Use modulo-2 binary division to divide binary data by the key and store remainder of
division.
3. Append the remainder at the end of the data to form the encoded data and send the
same
Receiver Side (Check if there are errors introduced in transmission)
Perform modulo-2 division again and if the remainder is 0, then there are no errors.
In this article we will focus only on finding the remainder i.e. check word and the code word.
Modulo 2 Division:
The process of modulo-2 binary division is the same as the familiar division process we use for
decimal numbers. Just that instead of subtraction, we use XOR here.
● In each step, a copy of the divisor (or data) is XORed with the k bits of the dividend
(or key).
● The result of the XOR operation (remainder) is (n-1) bits, which is used for the next
step after 1 extra bit is pulled down to make it n bits long.
● When there are no bits left to pull down, we have a result. The (n-1)-bit remainder
which is appended at the sender side.
Illustration:
Example 1 (No error in transmission):
Data word to be sent - 100100
Key - 1101 [ Or generator polynomial x3 + x2 + 1]
Sender Side:
Sender Side:
Therefore, the remainder is 001 and hence the
code word sent is 100100001.
Receiver Side
Let there be an error in transmission media
Code word received at the receiver side - 100000001
Since the remainder is not all zeroes, the error
is detected at the receiver side.
Checksum
Checksum is the error detection method used by upper layer protocols . This method makes the
use of Checksum Generator on Sender side and Checksum Checker on Receiver side.
At the Sender side, the data is divided into equal subunits of n bit length by the checksum
generator. This bit is generally of 16-bit length. These subunits are then added together using
one’s complement method. This sum is of n bits. The resultant bit is then complemented. This
complemented sum which is called checksum is appended to the end of original data unit and is
then transmitted to Receiver.
The Receiver after receiving data + checksum passes it to checksum checker. Checksum checker
divides this data unit into various subunits of equal length and adds all these subunits. These
subunits also contain checksum as one of the subunits. The resultant bit is then complemented. If
the complemented result is zero, it means the data is error-free. If the result is non-zero it means
the data contains an error and Receiver rejects it.
Example –
If the data unit to be transmitted is 10101001 00111001, the following procedure is used at
Sender site and Receiver site.
Sender Site :
10101001 subunit 1
00111001 subunit 2
11100010 sum (using 1s complement)
00011101 checksum (complement of sum)
10101001 subunit 1
00111001 subunit 2
00011101 checksum
11111111 sum
00000000 sum's complement
Advantage :
The checksum detects all the errors involving an odd number of bits as well as the error
involving an even number of bits.
Disadvantage :
The main problem is that the error goes undetected if one or more bits of a subunit is damaged
and the corresponding bit or bits of a subunit are damaged and the corresponding bit or bits of
opposite value in second subunit are also damaged. This is because the sum of those columns
remains unchanged.
Example –
If the data transmitted along with checksum is 10101001 00111001 00011101. But the data
received at destination is 00101001 10111001 00011101.
Receiver Site :