DGRAM: A Delay Guaranteed Routing and MAC Protocol For Wireless Sensor Networks

Download as pdf or txt
Download as pdf or txt
You are on page 1of 17

DGRAM: A Delay Guaranteed Routing and

MAC Protocol for Wireless Sensor Networks


Chilukuri Shanti, Student Member, IEEE, and Anirudha Sahoo, Member, IEEE
AbstractThis paper presents an integrated MAC and routing protocol called Delay Guaranteed Routing and MAC (DGRAM) for
delay-sensitive wireless sensor network (WSN) applications. DGRAM is a TDMA-based protocol designed to provide deterministic
delay guarantee in an energy-efficient manner. The design is based on slot reuse to reduce latency of a node in accessing the medium,
while ensuring that the medium access is contention-free. The transmission and reception slots of nodes are carefully computed so
that data is transported from the source toward the sink while the nodes could sleep at the other times to conserve energy. Thus,
routes of data packets are integrated into DGRAM, i.e., there is no need for a separate routing protocol in a DGRAM network. We
provide a detailed design of time slot assignment and delay analysis of the protocol. We have simulated DGRAM using ns2 simulator
and compared the results with those of FlexiTP, which is another TDMA protocol that claims to provide delay guarantee, and with those
of a basic TDMA MAC. Simulation results show that the delay experienced by data packets is always less than the analytical delay
bound for which the protocol is designed. Also, the TDMA frame size with DGRAM is always lesser compared to that of FlexiTP, which
makes the maximum possible delay much lesser than that of FlexiTP. The average delay experienced by packets and the average total
energy spent in the network are much lesser in a network using DGRAM than that using FlexiTP or the basic TDMA MAC.
Index TermsWSNs, delay guarantee, energy efficiency, MAC, TDMA.

1 INTRODUCTION
W
IRELESS Sensor Networks (WSNs) are an emerging
technology with a wide range of potential applica-
tions such as environment monitoring, earthquake detec-
tion, patient monitoring systems, etc. Sensor networks are
also being deployed for many military applications, such as
target tracking, surveillance, and security management.
WSNs typically consist of small, inexpensive, resource-
constrained devices that communicate among each other
using a multihop wireless network. Each node, called a
sensor node, has one sensor, embedded processors, limited
memory, and low-power radio, and is normally battery
operated. Each sensor node is responsible for sensing a
desired event locally and for relaying a remote event sensed
by other sensor nodes so that the event is reported to the
end user. Sensors have limited energy and they continue to
operate until their energy is exhausted. Therefore, applica-
tions and protocols for WSNs should be carefully designed
in an energy-efficient manner so that the lifetime of sensors
can be longer. The sensing element of a sensor probes the
surrounding environment. If an interesting event is detected,
after performing signal processing of the observed data,
sensors communicate these data to the sink or base station
using a radio link. This communication happens in a single
or multihop fashion depending on the location of the
sensing node. The node has to access the medium and then
transmit the data. Thus, in a distributed system like a WSN,
medium access control (MAC) protocol plays an important
role. MAC protocols can be broadly divided into two
categories: contention-based and TDMA-based. In conten-
tion-based MAC, the nodes can transmit without having
any predetermined time assigned to them. Thus, this may
result in collision. Hence, the protocol should provide
mechanism for resolving collision. TDMA-based protocols
are collision-free because each node has a designated time
slot in which only that particular node transmits. As stated
before, these MAC protocols should be energy efficient. In
addition, if the sensor network is to be used for real-time
applications, the MAC protocol should provide QoS (e.g.,
delay) guarantee.
In this paper, we propose a TDMA-based energy-
efficient integrated MAC and routing protocol, called Delay
Guaranteed Routing and MAC (DGRAM) protocol, which
provides deterministic delay guarantee. Traditional TDMA
MAC protocols suffer from high latency. Most of them like
[1] consider a centralized slot allocation based on graph-
coloring approach to reuse slots beyond two-hop neighbors.
However, this approach is not scalable and requires slot
allocation messages to be passed by the base station,
resulting in wastage of energy. FlexiTP reported in [2] is a
TDMA MAC protocol that has a loose slot structure and
claims guaranteed end-to-end data delivery. In this proto-
col, the nodes run a neighbor discovery phase and then slot
assignment is done so that data flow toward the sink. Both
the neighbor discovery and slot assignment phases require
message passing using CSMA/CA. On the other hand,
DGRAM requires a short beacon exchange phase for
gathering node location information. It then uses slot reuse
technique to reduce latency between two successive
medium accesses by a sensor node, with a slot allocation
strategy that does not require exchange of control messages,
which makes the deployment self-configuring. DGRAM only
requires a sensor network to be deployed with uniform
IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010 1407
. The authors are with the Department of Computer Science and
Engineering, IIT Bombay, Powai, Mumbai-400076, India.
E-mail: {shanti, sahoo}@cse.iitb.ac.in.
Manuscript received 9 Jan. 2009; revised 13 July 2009; accepted 23 Jan. 2010;
published online 1 June 2010.
For information on obtaining reprints of this article, please send e-mail to:
[email protected], and reference IEEECS Log Number TMC-2009-01-0012.
Digital Object Identifier no. 10.1109/TMC.2010.107.
1536-1233/10/$26.00 2010 IEEE Published by the IEEE CS, CASS, ComSoc, IES, & SPS
node density. Each node runs a short beacon exchange
phase to learn about the topology of the network. Data
packets are then transmitted/received following a logical
topology. While traditional TDMA MACs require a routing
protocol to run on top of them, DGRAM has the routing
mechanism built into the MAC, using coordinated sleep
and wake-up cycles. Further, DGRAM allows sensors to go
to sleep when they are not communicating (neither
transmitting nor receiving), and hence, it conserves energy.
Since DGRAM can provide delay guarantee, it is suitable
for real-time applications like detection of radioactive
radiation, earthquake, etc. We present the method by which
time slots are assigned to sensor nodes and show how the
slots are reused by nodes that are noninterfering. Then we
present the delay analysis of DGRAM to show that the
delay is bounded in DGRAM. Routing of data from source
to sink is integrated into DGRAM by carefully designing
transmission and reception slots of nodes. When a node in
an outer tier transmits in its transmission slots, certain node
in the inner tier wakes up to receive the data in those slots
(which are its receive slots). This enables the flow of data
from source toward the sink. Thus, a separate routing
protocol is not required for DGRAM. This indirectly saves
energy, which otherwise would have been expended in
determining the route of packets from source to sink. We
present our simulation results, which show that our
analytical delay bound is always guaranteed by the protocol
and that there is no packet loss as long as the event rate is
below the designed event rate. We compare the perfor-
mance of DGRAM with FlexiTP, which is also a TDMA
protocol that claims to provide end-to-end delivery guar-
antee and energy efficiency and show that DGRAM
outperforms FlexiTP in terms of delay, energy consump-
tion, and number of packets meeting deadline. We also
compare DGRAM with a basic TDMA MAC that is bundled
with ns2. It is seen that DGRAM outperforms FlexiTP and
the basic TDMA MAC in all the above aspects for different
network sizes and event rates.
The rest of the paper is organized as follows: In Section 2,
we present some related work in the area of MAC protocols
for WSNs. Section 3 describes the topology in which
DGRAM is deployed, location of sensor nodes in DGRAM
network and a few assumptions made in designing
DGRAM. A detailed description of TDMA time slots
assignment at different hierarchy is presented in Section 4.
Section 5 analyzes the energy consumption by nodes
running DGRAM. We present our simulation results in
Section 6. Finally, we conclude the paper in Section 7.
2 RELATED WORK
WSNs generally use MAC protocols that are either TDMA-
based or are contention-based. In contention-based proto-
cols, multiple nodes may access the medium simulta-
neously, resulting in collision. The MAC protocol then
provides a mechanism to resolve collision. Akyildiz et al. [3]
give an excellent overview of the various MAC protocols for
sensor networks. The IEEE 802.11 distributed coordination
function (DCF) is one such protocol. Woo and Culler [4] have
studied different configurations of CSMA and proposed an
adaptive rate control mechanism to achieve fair bandwidth
allocation to all nodes. S-MAC[5] is a popular MACprotocol
for WSNs that conserves energy by having listen and sleep
cycles so that idle listening time is minimized. S-MAC
conserves energy, but has high latency. Several extensions
and modifications to S-MAC like WiseMAC [6] and DMAC
[7] have been proposed to improve the protocol perfor-
mance. Cohen and Kapchits [8] propose an algorithm to
determine the wake-up frequency of nodes depending on
their proximity to the sink so that the overall energy spent
and delay are minimized. However, it does not give a
schedule for the wake-up cycles.
TDMA-based protocols are contention-free protocols in
which sensor nodes transmit only in their assigned time
slot. Sohrabi and Pottie proposed a self-organizing MAC for
sensor networks in which each node maintains a TDMA-
like frame called the superframe [9]. Interference between
adjacent links is avoided by using FDMA and CDMA in
potentially interfering links. Chandrakasan et al. [10]
propose a TDMA protocol in which clusters are formed
and each cluster elects a regular sensing node as a cluster
head. All the nodes in the network are assumed to have
enough radio power to communicate with the base station
directly. Cluster heads communicate directly with the base
station and other nodes communicate directly only with the
cluster head. The slot assignment is randomized. Wu and
Biswas [11] present a self-reorganizing slot allocation
mechanism for TDMA-based MAC in multicluster sensor
networks. The primary contribution of the paper is to
demonstrate that with adaptive slot allocation, it is possible
to reduce intercluster interference under low load condi-
tions. The second contribution is the design of a feedback-
based adaptive allocation reorganization protocol that
significantly reduces the intercluster interferences without
relying on any global synchronization mechanism. In [12],
the authors propose a new MAC protocol referred to as
DEE-MAC, which reduces energy consumption by making
the idle nodes sleep to reduce idle listening using
synchronization at cluster heads. Each cluster is dynami-
cally formed and all nodes contend for the position of
cluster head. Nodes can join or leave the cluster any time
they want to. RT-Link [1] focuses on reducing the
communication delay between a node and the base station.
It uses a centralized slot computing mechanism, using the
distance-k node coloring approach (slot scheduling), to
minimize the number of collisions along each transmission
hop in a multihop wireless network. It also proposes a
delay-sensitive schedule. Logical connectivity graph forma-
tion and slot assignment are done by the base station
centrally. FlexiTP [2] is another TDMA protocol, where the
nodes run a neighbor discovery algorithm after which they
mark transmission, forwarding, and receive slots. The main
goal is to reassign slots upon the occurrence of a fault,
which is detected by the absence of a packet to be received.
There have been some recent papers [13], [14] that study
real-time routing in sensor networks. However, their focus
is only on reducing the routing delay, ignoring the delay at
the MAC level. In [13], the authors discuss the design of a
stateless routing protocol for real-time communication
called SPEED. While SPEED is highly efficient and scalable,
it is limited to routing and does not take into account the
MAC layer delays. Though the protocol tries to find the best
possible route along which data have to be forwarded in
order to minimize delay, the delay at the MAC layer can be
1408 IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010
quite large as it is built on the 802.11 MAC protocol. The
number of nodes considered by the authors is large, but
simulation and experimental results are presented for a
very few number of flows. Whether the protocol can
guarantee end-to-end delay bound when all nodes generate
packets (e.g., in case of a fire or biohazard) is doubtful.
TDMA protocols need highly accurate time synchroniza-
tion for correct operation. Out-of-band, hardware-based
synchronization has been suggested for this purpose in [1].
Other mechanisms of time synchronization for TDMA
protocols are presented in [15], [16], [17]. Kulkarni et al.
[18] use a logical tier structure similar to that of DGRAM, but
it is contention-based and may not provide delay guarantee
when there is a burst of data. In [19], we discussed a routing
and MAC scheme with a logical tier structure to provide
delay guarantee and compared it with [5]. This work,
however, requires data aggregation at each node as it does
not allot any slots for forwarding data packets.
DGRAM requires each node to know its position relative
to the sink. This can be achieved by programming the nodes
with their location at the time of deployment or using any
localization algorithm reported in the literature. There are
many distributed algorithms in the literature to find the
coordinates of the nodes in a sensor network. Many
localization systems depend on having direct distance
estimates to globally accessible beacons like the Global
Positioning System (GPS). Recently, there has been some
research in localizing a wireless sensor network, where there
are no globally accessible beacons. Savvides et al. [20]
describe a distributed algorithm that recursively infers the
positions of sensors with unknown positions from a set of
sensors with known positions, using intersensor distance
estimates. While algorithms like this need seed nodes that
know their position, algorithms that do not need such seed
nodes have also been proposed. Priyantha et al. [21] propose
a localization algorithm that does not need any anchor
nodes. Khan et al. [22] describe a localization algorithm that
requires a single anchor in the network. For our protocol, this
single anchor can be the sink.
3 DEPLOYMENT OF THE WSN
3.1 Topology
We assume a circular sensing area and that the sensing area
has a base station or sink, which is wired and is not power-
constrained. The sensor nodes (henceforth referred to as just
nodes) sense the event of interest and transmit these data to
the sink using a MAC described in the paper. The nodes are
deployed with uniform density all around the sink, with the
sink at the center of the area as shown in Fig. 1. Depending
on the distance of a node from the sink and the transmission
range of the nodes, data have to traverse single or multiple
hops before being received by the sink.
Our protocol is designed with the following assumptions:
. The nodes and the sink are stationary.
. Each node knows its location relative to the sink.
. Each node is programmed with the total number of
nodes in the network.
. The sink is at the center of the circular sensing area.
. The clocks of sensor nodes are synchronized by using
out-of-band time synchronization. A similar mechan-
ism as used in [1] may be used for this purpose.
. The transmissionandinterference ranges of the nodes
are generally not exactly circular. Hence, we consider
the maximum interference radius and the minimum
transmission radius when the transmission and
reception cycles are calculated (details are given in
Sections 4.7.1 and 4.7.2). This ensures that no packets
are lost.
3.2 Location of the Sensors
DGRAM is most optimal when there is uniform density of
sensors in the sensing area. One of the main assumptions
made above is that each node knows its position with
respect to the sink. As mentioned before, this can either be
achieved by manually programming the sensors with their
coordinates or by using some known distributed algorithm
[20], [21], [22]. The position of a node is represented in
rectangular coordinates with the sink as the origin.
4 TIME SLOT ASSIGNMENT
In this section, we present a detailed discussion of time slot
assignment in DGRAM. The notations used in the discus-
sion are given in Table 1.
4.1 Logical Organization of Nodes
To facilitate multihop communication and time slot reuse,
the sensing area is divided into tiers and blocks. The sensing
area is organized into tiers, based on the radial distance of
different nodes from the sink. Then each tier is divided into
blocks based on the angular distance of nodes (measured in
clockwise direction) from the sink with respect to the
geographical North axis passing through the sink. This is
depicted in Fig. 1. Each tier is of radial width c1. The
parameter c determines the minimum node density in the
area for the network to remain connected (more details on c
are given in Section 4.5). The tier closest to the sink is the first
tier and is identified as C
1
. There are H number of tiers in the
sensing area. Thus, the tier farthest fromthe sink is identified
as C
H
. The division of the network into tiers helps in
multihop transmission of data toward the sink and helps in
slot reuse. The division into blocks also facilitates reuse of
time slots. The outermost tier C
H
may not have the full tier
width of c1. For example, if the deployment area has a
radius of 150 m, i.e., 111lo is 150 mand1and care 100 m
and 0.51, respectively, the network would have two full tiers
(that cover a radius of 2 + 0.51 + 100 m = 102 m) and an
SHANTI AND SAHOO: DGRAM: A DELAY GUARANTEED ROUTING AND MAC PROTOCOL FOR WIRELESS SENSOR NETWORKS 1409
Fig. 1. Depiction of tiers and blocks (for c = 1.0).
outermost tier that has a tier width of the remaining radial
distance to be covered, i.e., 150 m 102 m = 48 m. Based on
the position of the node and the sink, the radial distance of
the node from the sink is calculated by each node. Based on
this distance and c, each node calculates the tier C
i
to which
it belongs. If the radial distance is between (i 1)c1andic1
(i 0), the node determines itself to be in the ith tier C
i
. Data
from any node in this tier flow radially inward and hop from
outer tier to inner tier and reach the sink. We merge all the
innermost tiers that can reach the sink directly into a single
tier C
1
because nodes in these tiers can communicate with the
sink in a single hop. The number of innermost tiers that can
be merged into a single tier is 1, where
1 =
1
c
_ _
. (1)
Note that the tier C
1
has a radius of 1c1. Hence, data from
tier C
i
reach the sink in (i 1 1) hops if the nodes radial
distance from the sink is greater than 1c1 and in a single
hop if the radial distance is less than or equal to 1c1.
After merging of the innermost 1 tiers, the number of
tiers into which a network of radius 111lo is divided is
given by
H =
111lo
c1
_ _
1 1. if
111lo
c1
_ _
1.
1. otherwise.
_
_
_
Each tier is further divided into blocks for concurrent
transmission of data within a tier. A block is an angular area
covered by the interference range of a node in a given tier
(see Fig. 1). The division of a tier into blocks helps in slot
reuse within a tier, which, in turn, enables concurrent
transmission within a tier. A node in the extreme right of
block 1
i,
can interfere with transmission by a node in block
1
i(,1)
, but cannot interfere with a node to the extreme left
of the block 1
i(,2)
. Thus, nodes in alternate blocks can
transmit in the same slots without interfering with each
other. For example, nodes A and B shown in Fig. 1 can
transmit simultaneously. This calculation is done based on
the angle 0
i
that each block in tier C
i
subtends at the center
(the sink). To keep the number of nodes per block
approximately the same, the angle 0
i
is made smaller for
tiers farther away from the sink. As shown in Fig. 2, this
angle for any tier C
i
is calculated by the node as follows:
:ii(0
/
i
,2) =
u1
ci1
=
u
ci
. (2)
Since 0 _ :ii(0
/
i
,2) _ 1, from (2), we have 0 _
u
ci
_ 1. The
first condition 0 _
u
ci
is always satisfied, since u, c, and i all
take positive values. For the second condition
u
ci
_ 1 to be
true, i _
u
c
. Hence, all tiers with index less than
u
c
are not
divided into blocks. Let G
/
be the number of tiers that are
not divided into blocks before merging the first 1 tiers into
a single tier. Hence,
G
/
=
u
c
_ _
.
Since we merge the first 1 tiers into a single tier, the
effective number of tiers that are not divided into blocks is
G, where
G = G
/
1 1.
Note that G
/
is always _ 1, since u _ 1.0. Hence, G is
always positive and the first (merged) tier is never divided
into blocks. In the rest of the paper, whenever we refer to
tier C
i
, the tier index i is the index of the tier after merging
the first 1 tiers into a single tier.
Solving for 0
/
i
, we get
0
/
i
= :ii
1
2u

(c
2
(i 1 1)
2
u
2
)
_
c
2
(i 1 1)
2
. (3)
Since we allow alternate blocks to use the same half of a
subframe (explained in Section 4.2), the number of blocks
should be even. However, the number of blocks in tier C
i
1410 IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010
Fig. 2. Calculation of 0
/
for the ith tier (i G).
TABLE 1
Explanation of Various Notations
depends on the angle 0
/
i
of that tier and may not always be
an even number. To ensure that the number of blocks 7
i
in
the tier C
i
is an even number, blocks are assigned in the half
circle region, i.e., the angle for each block is assigned from
. Thus,
7
i
= 2

0
/
i
_ _
. (4)
Note that we have used the floor function in the above
equation so that the area of adjacent blocks will be greater
than or equal to that required to make them noninterfering.
Keeping the above constraints in view and using (3) and
(4), the angle subtended by a block at the sink is modified
as follows:
0
i
= 0
/
i

0
/
i

_

0
/
i
_
7
i
,2
. (5)
Now, knowing the value of 0
i
and the angular distance of
the node from the sink, the node can find out the block to
which it belongs. If the angular distance is between (, 1)0
i
and (,0
i
) (, 0), then the node belongs to ,th block, 1
i,
.
Thus, 1
i1
is the first block in tier C
i
, which is between 0 and
0
i
(in clockwise direction) with respect to geographical
North passing through the sink.
The number of nodes in the ith tier is denoted by j
i
and
is given by
j
i
=

7
i
,=1

i,
. (6)
where
i,
is the number of nodes in the ,th block of tier C
i
and is computed while a node executes Algorithm 1.
Algorithm 1. Node level slot assignment(1
i,/
, c
i,/
)
1: /
+
iod di:toicc(n) and oiq|c di:toicc(n) are radial and
angular distances, respectively, of the node (from the
sink) whose location is stored in the nth entry of
+
/
2: /
+
` is the number of nodes in the deployment area
+
/
3: /
+
r
i,/
and y
i,/
are, respectively, the X and Y
coordinates of the node trying to get its index in the
subsubframe
+
/
4: /
+
n, . and n are running indices
+
/
5: n = 1. . = 1. n = 1. / = 1
6: /
+
Initialize the number of nodes in each block and tier
to 0
+
/
7: while n _ H do
8: j
n
= 0
9: while . _ 7
n
do
10:
n.
= 0
11: . = . 1
12: end while
13: n = n 1
14: end while
15: while (n _ `) do
16: n =
iod di:toicc(n)
c1
_ _
17: if (n 1) then
18: /
+
since innermost 1 tiers are merged into one,
adjust the tier index accordingly
+
/
19: n = n 1 1
20: else
21: n = 1
22: end if
23: j
n
= j
n
1
24: . =
oiq|c di:toicc(n)
0
n
_ _
25:
n.
=
n.
1
26: if ((n == i) `1 (. == ,)) then
27: if (iod di:toicc(n) < 1
i,/
) then
28: / = / 1
29: else if (iod di:toicc(n) == 1
i,/
) then
30: if (oiq|c di:toicc(n) < c
i,/
) then
31: / = / 1
32: end if
33: end if
34: end if
35: n = n 1
36: end while
37: /
+
the node now knows values of k (this is the index of
the node in its tier and block), j
i
and
i,
for all
i [1. H[. , [1. 7
i
[
+
/
Each node needs transmission slots to relay the data
received from nodes of the outer tiers and to transmit its
own data. Assuming a slot size large enough to transmit a
single data packet, each node thus needs as many
transmission slots as the number of data packets to be
forwarded by it, in addition to one slot to transmit its own
data. The number of slots required per node in the ith tier
for relaying the outer tiers data depends on the ratio of the
number of nodes in the (i 1)th tier to the number of nodes
in this tier and on the number of slots per node in the outer
tier (o
(i1)
). Hence,
o
i
=
1
j
(i1)
j
i
_ _
o
i1
. for 1 _ i < H.
1. for i = H.
_
(7)
The numerator in the second expression of the first part of
the above equation gives the number of nodes in the
(i 1)th tier and the denominator is the number of nodes
in the ith tier. In the outermost tier C
H
, o
H
is one, as each
node needs a slot to transmit its own data and no relay slots
are needed.
4.2 Slot Assignment at the Tier and Block Level
A node in DGRAM can be in one of the two states: active or
sleeping. A node is in active state in its allotted transmission
slot if it has pending data to send. A node switches itself
into the active state at the beginning of each of its receive
slots. If it senses a preamble, it remains in active state to
listen for the rest of the slot duration to receive data from its
previous tier. Otherwise, it goes back to sleeping state. At
all other time, the node stays in sleeping state. This careful
design of active and sleeping states helps in minimizing
energy consumption, while making sure that data are
carried from the source node to the sink.
Slot assignment in DGRAM happens in three levels of
hierarchy. At the highest level, the time frame is called the
SHANTI AND SAHOO: DGRAM: A DELAY GUARANTEED ROUTING AND MAC PROTOCOL FOR WIRELESS SENSOR NETWORKS 1411
superframe. The superframe is divided into subframes, which
are assigned to different tiers. The subframes are reused
across the tiers such that the transmissions do not interfere.
Nodes in two different tiers can transmit at the same time
when they are at least 21 apart, as shown in Fig. 3. Note that
the merging of the first 1 tiers does not effect the calculation
of `, since we consider the distance 21 fromthe edge of C
1
, to
take care of the worst case. Each tier (other than tier C
1
) is c1
wide. If ` is the number of subframes, ` tier widths should
encompass the 21 length. This means that ` = 21,c1. But
we need to take care of border cases of tiers, i.e., a node on the
border between `th and (` 1)th tiers and belonging to
(` 1)th tier could interfere with the first tier. Thus, taking
an extra tier width into the calculation and the fact that
1 = u1, we have
` =
2u
c
1
_ _
. (8)
Thus, the tiers can be categorized into groups of ` tiers
each. Nodes that belong to different groups, but transmit in
the same subframe, form a set of concurrently transmitting
nodes. The tiers that transmit concurrently with tier C
i
are
C
i,(12u,c)|
. , 0. (9)
Thus, each tier has a subframe allotted to it. Further, each
subframe is split into two halves called subsubframe. One half
is used by all odd-numbered blocks whereas the other is
used by all even-numbered blocks in the tier. This is possible
because the even (odd)-numbered blocks are not within
interference range of each other. Thus, slots of subsubframes
are reused at the block level also. Note that reuse of slots
helps in reducing the size of the superframe, which leads to
reduced latency of the network. The innermost G tiers, i.e.,
tiers C
1
to C
G
, are not divided into blocks.
4.3 Node-Level Slot Assignment
Once the subframe allocation is done for tiers and
subsubframe allocation is done for blocks, the node-level
slot assignment has to be done. Nodes only transmit data
during the slots assigned to them in the subsubframe of the
block to which they belong.
Each node goes through a short beacon exchange phase
and then runs a simple algorithm (Algorithm 1) to
determine its transmission time slots within the subsub-
frame assigned to it. To know when to transmit, the node
needs to know the following:
. The organization of superframe.
. Its tier and block.
. Its index in its tier and block.
A node needs to know the number of nodes in each tier and
block of the network in order to get the structure of the
superframe. To obtain this information, a node needs to
have location information of every other node in the
network. Each node in the network goes through a short
beacon exchange phase after deployment to collect location
information of all other nodes in the network.
4.3.1 Beacon Exchange Phase
As mentioned before, each node finds out location of every
other node in the network by broadcasting periodic beacons.
In this section, we present the details of the beacon exchange
phase. Every node maintains a table , which contains the
location information of every other node. This table is
populated during this phase. An entry in is a two-tuple
of {location, seqno}. :cio fieldinthis table is usedtodetermine
freshness of a received beacon with respect to a beacon
received earlier. Initially, each node knows its location and
the total number of nodes in the network, `, and the table
is empty. Each node originates periodic beacon message as
per the flowchart shown in Fig. 4. Abeacon message contains
four fields: {location, seqno, flag, TTL} and is broadcast using
CSMAprotocol. )|oq fieldis set to1 (bythe originator) if has
(` 1) entries, which means that the originator node has
received location information of all other nodes in the
network; otherwise, it is set to 0. The TT1 field is set to
`A TT1 by the originator. `A TT1 is chosen suitably
so that the message reaches all the nodes before it is dropped.
Typically, `A TT1 should be chosen little more than the
diameter of the network (in terms of number of hops). When
the node receives location information from all other nodes,
will contain (` 1) entries, andhence, it will not originate
any periodic beacon (see Fig. 4). Instead, it will start a silence
timer. During this time, this node waits for beacon from any
other node. If it does not receive a beaconwith)|oq = 0 before
this time-out, that means all other nodes are done with this
phase, and hence, this node also ends this phase.
1412 IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010
Fig. 4. Flowchart for sending periodic beacons.
Fig. 3. Counting number of nodes in a tier.
When a node receives a beaconmessage fromits neighbor,
it may drop it or forward it further. The flowchart for this
case is shown in Fig. 5. If the location information is not there
in its table , then it adds the entry and forwards the beacon
after decrementing its TT1 value by 1. Otherwise, if the
location information carried in the beacon is already present
in table, then the beacon is forwarded only if the :cio is
more than that in the table and the TT1 value is more than
0. In other cases, the beacon message is dropped. Dropping
the beacon message based on the above criteria reduces the
extent of flooding of beacons and reduces the convergence
time of the beacon exchange phase considerably. If the )|oq
field in the beacon is 0, then it follows a part of the flowchart
in Fig. 5 (indicated by point in the two figures). This path
ensures that the node receiving this beacon sends its own
beacon (since some node in the network still has not received
all (` 1) location information). Note that silence timer
value should be long enough to ensure that no node is still
transmitting beacons with )|oq = 0. This guarantees that
every node gets the location information of all other nodes in
the network.
4.3.2 Determination of Slots at the Node Level
A node knows its position in the deployment region in
rectangular coordinates expressed as (r
i,/
, y
i,/
). However,
the node does not initially know its tier i, block ,, or index /
in that tier and block. The location of a node / in tier C
i
and
block 1
i,
in polar coordinates is essentially an ordered pair
(1
i,/
, c
i,/
), where 1
i,/
is the radial distance of the node from
the sink and c
i,/
is the angular distance of the node with
respect to the geographical North (in clockwise direction)
passing through the sink. The values of (1
i,/
, c
i,/
) can easily
be calculated based on the position (r
i,/
, y
i,/
) of the node in
the deployment area and are useful in calculating the tier
and block to which the node belongs. Now, the tier to which
the node belongs can be calculated as follows:
i =
1
i,/
c1
_ _
1 1 if
1
i,/
c1
_ _
1.
1. otherwise.
_
_
_
(10)
For example, for F = 1, if the tier width (c1) is 51 m, a node
that has a radial distance of 10 m from the sink lies in the
tier
10
51
|, i.e., tier 1. Similarly, a node with a radial distance of
110 m from the sink lies in the tier
110
51
|, i.e., tier 3. The
width of the outermost tier may not be c1, as discussed in
Section 4.1. Nevertheless, the above equation applies to all
nodes in the deployment area. Further, the block to which
the node belongs can be calculated as
, =
c
i,/
0
i
_ _
. (11)
For example, if the value of 0 for that tier is 1.3 radians and
the node is at an angle of 2.1 radians to the geographical
North, the node is in block
2.1
1.3
|, i.e., block 2. Hence, each
block includes all the nodes between its left (in clockwise
direction) boundary and the right boundary, including those
on the right boundary, but not those on its left boundary. The
division of tiers into blocks is such that slots can be reused to
the maximum extent possible without interfering transmis-
sions. In a particular slot, no two nodes belonging to a block
in a tier can transmit (in order to avoid interfering
transmissions), but two nodes belonging to alternate blocks
in the same tier may transmit in the same slot.
The index of a node (in its tier and block) is obtained by
running Algorithm 1. A node (e.g., 1 in Fig. 3) running
Algorithm 1 counts the number of nodes (from the entries in
) that belong to each tier and block of the deployment area.
Knowing this information, the node can get the organization
of the superframe as discussed in Section 4.4. Since the node
knows its tier (based on the radial distance from the base
station) and block (based on the angular distance from the
base station), it knows the subframe and subsubframe in
which to transmit. To know the slots in which to transmit
within this subsubframe, the node calculates its index within
the subsubframe in course of the algorithm.
While running the algorithm, if the node finds another
node that lies in the same block and tier as itself and has a
radial distance lesser than itself from the base station, it
increments the iidcr by 1 (Step 27). This is because nodes
are assigned indices in the increasing order of their radial
distances from the sink. In case of a tie in radial distance,
the node with lower angular distance gets lower index. By
the end of the algorithm, node 1 knows its index within its
block and tier (given by /). It then uses this information to
mark its transmission slots. For example, in Fig. 3, node 1
runs the algorithm and finds that node has lesser radial
distance than itself from the sink. Hence, it marks its index
to be one greater than that of . If no other node in the block
has lesser radial distance than 1, this would become the
final index of 1. Since there cannot be two nodes with the
same radial and angular distances from the sink, this
method gives an unique index to each node. Based on this
unique index, the node chooses unique transmission slots in
the subsubframe of that block.
Each node in the network runs Algorithm 1. After
running this algorithm, each node knows the following:
. The number of nodes in each tier and block in the
entire network.
. Its index within its tier and block.
Using these values, it can calculate the number of slots per
node in each tier, i.e., o
i
, as per (7). By now, the node has
SHANTI AND SAHOO: DGRAM: A DELAY GUARANTEED ROUTING AND MAC PROTOCOL FOR WIRELESS SENSOR NETWORKS 1413
Fig. 5. Flowchart for receiving and forwarding beacons.
enough information to calculate the size of each subframe
(o
i
), and hence, the size of the superframe (T), as discussed
in Section 4.4. Though each node independently runs the
algorithm, all nodes obtain the same values of subframe and
superframe sizes for the network. Then, the node can
calculate its transmission and reception slots as discussed in
Sections 4.7.1 and 4.7.2.
Fig. 6 shows the time slot assignment at various levels
when there are eight tiers. Note that this algorithm and
the subsequent calculation of the transmission and
reception slots are done only once and do not need any
message passing.
4.4 Calculation of Size of Superframe
In DGRAM, we make sure that there is no queuing in the
nodes. This makes it easier to provide deterministic delay
guarantee. Since the nodes are deployed with uniform
density and the tiers and blocks are angular, the number of
nodes in two blocks in the ith tier may not be the same.
Hence, the size of the subsubframe of the ith tier is
determined by the block that has the maximum number of
nodes. Also, all odd blocks of the ith tier transmit in the
same subsubframe and all the even blocks of the ith tier
transmit in the same subsubframe. Each node in the ith tier
has o
i
slots, where o
i
is given by (7). Hence, the subframe
length for an inner tier C
i
is given by
o
/
i
= 2 . o
i
. max
|
(
i|
). | [1. 7
i
[. i (G. H[. (12)
Note that since the outermost tier C
H
has one slot per node,
o
H
is one. Since tiers C
1
-C
G
have a single block, the
corresponding parameters for these tiers are given by
o
/
1
= o
1
.
11
o
/
2
= o
2
.
21
.
.
.
.
.
.
o
/
G
= o
G
.
G1
.
It is obvious from the above discussion that the numbers of
slots allotted for concurrent tiers from different groups are
not equal. Hence, we consider the largest number of slots
required by a tier in a concurrent group of tiers to be the
subframe size for that set of tiers. For example, for a
network with eight tiers and two groups, if C
1
, C
2
, C
3
, and
C
4
belong to the first group, C
5
, C
6
, C
7
, and C
8
form the
next group, and C
1
and C
5
transmit concurrently and form
part of a set of tiers that transmit concurrently. Similarly,
C
2
and C
6
transmit concurrently, C
3
and C
7
transmit
concurrently, and C
4
and C
8
transmit concurrently. The
size of the subframe in which C
1
and C
5
transmit should be
the larger of number of transmission slots needed by C
1
(o
/
1
) and C
5
(o
/
5
). Likewise, if C
2
has a larger number of
slots compared to C
6
with which it transmits concurrently,
the size of the second subframe is taken to be that of C
2
. Let
the ith subframe of the superframe be denoted by o
i
. Thus,
o
i
= max
|
(o
/
i|.`
). i [1. `[. | 0.
H
`
1
_ _ _ _
. (13)
Hence, the size of the subframe is decided by the tier that
has the maximum number of slots among a set of tiers that
transmits concurrently in that subframe. If C
r
and C
y
are a
set of tiers that transmits concurrently and o
/
r
and o
/
y
are
their respective subframe sizes such that o
/
r
o
/
y
, the
subframe size for both these tiers is taken to be o
/
r
. This
may, however, result in some slots being left over after all
the nodes of C
y
have been assigned slots. All the nodes of C
y
sleep during these slots so that no energy is wasted during
these slots. Note that these extra slots are necessary in the
subframe because some nodes in C
r
transmit during these
slots. DGRAM can work with any topology, as long as
connectivity is assured as per the discussion in Section 4.5.
However, uniform density results in minimum wastage of
slots due to unequal subframe size in a set of concurrently
transmitting tiers. ` is the number of tiers in each group
and is given by (8). Thus, the number of slots in a
superframe is given by
T =

`
i=1
o
i
. (14)
As an example, the division of slots in T for an area with
eight tiers, with u = c = 1, is shown in Fig. 6.
4.5 Dimensioning of DGRAM Parameters
For a network with given u and H, the value of T depends
on the node density `. The minimum node density that can
keep the network connected, in turn, depends on the value
of c, as described by Kulkarni et al. [18]. The authors [18]
study the effect of c for a given ` on the connectivity, which
is the number of nodes that can potentially relay data from
a given node. In Fig. 7, consider node transmitting data.
In this figure, we show two different cases of overlap
region, by showing only half of the deployment area on
either side of the vertical line. As per DGRAM, the only
nodes that can relay data from this node are those in the
shaded region. The shaded area is the region of overlap of
two circles (in the left half of the figure, for c _ 0.5): The
first is a circle centered at the node with radius 1 and the
second is a tier circle centered at the sink with radius
c(i 1)1. Let this area be
(i1)
. The value of c has to be
less than unity for a node in the ith tier to be able to relay
data to the (i 1)th tier. The number of nodes in this region
of overlap is a measure of connectivity of the network, since
only nodes in this region will ultimately relay data.
In Fig. 7, the depicted region of overlap is the minimum
area possible for all nodes in tier i, since the sender node is at
1414 IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010
Fig. 6. Time slot assignment at different hierarchy.
the edge of the ith tier. This area is minimum with respect to
i when i is as small as possible, i.e., at i
iii
=
1
c
1|. This is
because all nodes fromthe first tier to the
1
c
|th tier are within
a distance 1 from the sink and do not depend on the
connectivity since they can communicate directly with the
sink. The
1
c
1|th tier is the first tier that would require
multihop transmission. The shaded area (of Fig. 7) will be
minimum for this tier among all the tiers that need multihop
transmission. It is because similar shaded area for higher
tiers will be larger, since their circles are larger. By the cosine
rule of triangles, the area of the shaded region (in the left half
of the figure, for c _ 0.5) is given by

(i
iii
1)
= 1
2
( (i
iii
1)
2
c
2
i
iii
c:ii).
When c < 0.5, the area of overlap is as shown on the
right half of Fig. 7. Let
(i
iii
2)
be the area of intersection of
the two circles: the first is a circle centered at the node with
radius 1 and the second is a tier circle centered at the sink
with radius c(i 2)1. The value of
(iiii2)
can be
calculated in a similar manner as
(i
iii
1)
using cosine rule
of triangles. The area of the shaded region
coii
is given by

coii
=

(i
iii
1)

(i
iii
2)
if c (0. 0.5).

(i
iii
1)
if c [0.5. 1.0).
_
(15)
The average number of nodes in this area is given by
coii
`.
For a connectivity of one, the minimum value of the node
density for a given c is 1/
coii
.
Fig. 8 shows the relationship between various values of c
and the corresponding superframe size (in slots) for a
network of radius 150 m. For each value of c, we calculated

coii
using (15) and the node density ` is set to 1/
coii
, so
that a connectivity of one is provided. From this figure, we
observe that superframe size decreases as c increases from
0.1 to 0.5, but it starts increasing rapidly beyond the value of
0.5. Small values of c give rise to a large number of tiers, and
hence, several relaying slots have to be allocatedfor eachdata
unit. This results in a large superframe size. Large values of c
result in lesser number of relaying slots for each packet, but
the tiers are wider and
coii
is smaller. This requires a high
node density `, which, in turn, has the effect of increasing the
superframe size. A minimal value of the superframe size can
be observed between c = 0.3 and c = 0.5. We observed a
similar trend for networks of other radii. For simulation, we
have chosen a value of 0.5 for c to minimize the number of
tiers while keeping the superframe size small. The value of `
chosen is
1
400
, which gives a connectivity of 8, which is more
than the required connectivity of one, and thus, ensures that
there are no reception outages.
4.6 Calculation of Worst-Case Delay
The worst-case delay occurs when an event occurs in the
outermost tier C
H
and when a node in that tier which senses
the event just misses its assigned transmission slot. So it has
to wait for time T before it can transmit the packet. Once the
data are transmitted out of the source node in tier C
i
, these
are transported in i,`| cycles by the nodes in the inner
tiers. i,`| is the group number to which the source node
belongs. Once the data are on their way, these are
transmitted in subsequent subframes in a continuous
manner by the node in the respective tier until they reach
the sink. When source node is in the outermost tier C
H
, this
translates to total number of subframes assigned to all the
tiers in the network, which is H,`. But the number of tiers H
may not be an exact multiple of the number of subframes `
in a superframe. Hence, the worst-case delay is given by
d
noi:t
= T H,`|T. (16)
For a network with a given c, and whose maximum delay is
to be T H,`|T, the parameter ` has to be chosen
appropriately.
4.7 Sleep and Wake-Up Cycle of Nodes
4.7.1 Transmission Cycle of a Node
Since DGRAM follows a TDMA schedule, each node
transmits only during its assigned slots in a superframe.
Each node in a tier C
i
has o
i
slots per superframe to transmit
the data it has sensed and any data it has to relay from the
outer tiers. Consider a node belonging to the tier C
i
and
block 1
i,
. If / is the index of the node in its tier and block, the
slots it should transmit in are calculated as follows: Let the
number of slots assigned to the outer tiers (as subframes)
before the tier C
i
in the superframe be 1
i
. This is given by
1
i
=

`
(|=(i1)iod`)
o
|
if (i iod `) ,= 0.
0. otherwise.
_

_
(17)
SHANTI AND SAHOO: DGRAM: A DELAY GUARANTEED ROUTING AND MAC PROTOCOL FOR WIRELESS SENSOR NETWORKS 1415
Fig. 7. Minimum density for connectivity of the network.
Fig. 8. Effect of c on the superframe size.
Let the number of slots assigned to the blocks before block
1
i,
in the subframe assigned to C
i
be Q
i,
. Q
i,
is given by
Q
i,
= ((1
i,
1). o
i
,2) iod o
i
. i [1. H[. , [1. 7
i
[.
(18)
For example, consider the constitution of superframe of a
network with eight tiers as shown in Fig. 6. A node in the
4th block of the 7th tier, i.e., in 1
74
, has to skip slots
corresponding to the subframe meant for the 8th tier.
Hence, 1
7
is the size of the subframe of C
8
, i.e., the subframe
for C
7
should start after subframe C
8
. As the subframes are
reused across tiers, the subframe of C
8
is o
4
. Then, the node
has to leave slots for three blocks before it in its tier. The
subframe size for C
7
is o
3
, as the same subframe is allotted
to both C
7
and C
3
. Since each block takes o
3
,2 slots, the
node has to leave 3+o
3
,2 slots for blocks before it. However,
o
3
,2 slots in a subframe are reused by the odd and even
blocks in this tier. Thus, Q
i,
has a value of o
3
,2.
Now let us find the number of slots that a node has to
skip in its subsubframe. Let the number of slots before this
node in the subsubframe of its block be l
i,/
. Since this is the
/th node in its block 1
i,
and every node in this tier needs to
have o
i
slots, l
i,/
is given by
l
i,/
= (/ 1) . o
i
. (19)
Hence, this node transmits for o
i
slots starting from the slot
(1
i
Q
i,
l
i,/
1) as shown in Fig. 9. If the node in the
above example has an index of nine and the tier C
7
has
three slots per node, l
i,/
for this node would be 8+3, which
is 24. Hence, it allots itself three slots from slot number 25,
counting from the beginning of its subsubframe. From the
beginning of the superframe, the nodes transmission slots
are three slots starting from (o
4
o
3
,2 25).
4.7.2 Receive Cycle of a Node
A node in tier C
i
receives data from its previous tier C
i1
,
where (1 _ i < H). This node should receive from a
maximum of (o
i
1) slots, where o
i
is given by (7).
For relaying data, senders choose their respective
receivers so that there are no outages. Hence, to compute
the reception cycle of a node belonging to tier C
i
, the node
computes the receivers of all the senders in tier C
i1
. Then it
would come to know the particular sender(s) for which it
would be the receiver.
To compute the receivers of all the senders in the tier
C
i1
, each node in tier C
i
runs Algorithm 2. There is no
control message passing between any of the nodes regard-
ing the receive cycles. Hence, it is essential that all the nodes
in tier C
i
map senders to their respective receivers
identically, i.e., all of them must converge to the same
result after running the algorithm. So all receiver nodes of
C
i
have to run the above algorithm in the same order of
potential senders. This order in which potential senders are
considered from tier C
i1
while running the for loop in
Step 7 of Algorithm 2 is imposed by means of the ordered
list . has potential senders sorted in the nonincreasing
order of their radial distance from the sink, and in case of a
tie, by the nonincreasing order of their angular distance
from the geographical North.
Algorithm 2. Identify_sender_nodes ()
1: /
+
find sender node(s) of receiving node belonging to
tier C
i
. This algorithm is run by every receiving node in
tier C
i
.
+
/
2: = ordered list of nodes in tier C
i1
sorted in the
nonincreasing value of its radial distance from the sink
(in case of a tie, sorted in the nonincreasing order of
angular distance from geographical North)
3: for each node Y in tier C
i
do /
+
initialize the maximum
number of receiving slots of each receiver node in C
i
+
/
4: ini ic. :|ot:[Y [ = o
i
1
5: end for
6: = `l11
7: for each node A in do /
+
traverse the list in the
order in which the elements are stored in
+
/
8: iccci.ci )onid = 11o1
9: for each node Y in tier C
i
do
10: Let c
AY
= distance between A and Y
11: if c
AY
1 then /
+
since Y is outside of transmission
range, it cannot be a receiver for A
+
/
12: continue
13: end if
14: Insert (Y . c
AY
) into a temporary array
15: end for
16: sort in nonincreasing order of c
AY
elements in
are in the order of farthest to nearest w.r.t. A
+
/
17: | = 0
18: while iccci.ci )onid == 11o1 do
19: c
AY
= [|[ c
AY
/
+
get the distance between A and
Y
+
/
20: Y = [|[ Y
21: if ini ic. :|ot:[Y [ _ o
i1
then /
+
there are enough
reception slots available at the receiving node Y
+
/
22: ini ic. :|ot:[Y [ = o
i1
23: /
+
Y is the receiver of A
+
/
24: if Y == then /
+
the receiving node (which is
running this algorithm) is the receiver of A
+
/
25: insert A into
26: end if
27: iccci.ci )onid = T1l1
28: else
29: |

30: end if
31: end while
32: end for
33: /
+
Now contains the list of senders for which is the
receiver
+
/
1416 IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010
Fig. 9. Transmit cycle of the /th node in 1
i,
.
Each node in the tier C
i
can receive in maximum of up to
(o
i
1) reception slots. To find the receiver of a potential
sender A, the distance between A and every other node
(say, Y ) in its receiving tier C
i
is calculated. Note that is
the node in tier C
i
that runs the algorithm and Y is a
variable to denote any node of tier C
i
. All the nodes which
are out of the transmitting radius of A are discarded, as
these cannot receive from A. Nodes within transmitting
distance of A are entered into a temporary array . Then,
the nodes in are sorted in the nonincreasing order of their
distance from A. Now, each element in (in the order from
first to last) is checked for being a receiver of A. To check if
A can choose Y as its receiver, it is checked if Y has at least
o
i1
reception slots that are unassigned. Further, if Y is the
same as the node which is running the algorithm, then A
is marked as the sender for .
By the end of the algorithm, contains the set of senders
for . Now, can calculate the transmission slots of these
nodes as described in Section 4.7.1. Hence, node
remembers to go into active state only for those slots to
receive data. In receiving slots, node listens for a short
period of time (preamble) and then remains in active mode
for the entire duration of slot only if there is a transmission
in that slot. The node can sleep during slots other than its
transmission or reception slots. These are called idle slots.
From the discussion above, it can be seen that a sender node
always tries to choose its farthest potential receiver as its
receiver first. This ensures that all nodes (including those
close to the outer boundary of a tier) are assigned receivers.
Also, since a receiver is chosen from the list of receivers that
are all within the nodes transmission radius, there can be
no reception outages. Each node in the ith tier is assigned a
maximum of (o
i
1) reception slots. This spreads the
power usage across all the nodes in a tier uniformly. Nodes
in the tier C
H
need not receive data from any other node,
and hence, do not have a receive cycle.
This distributed slot calculation without control message
passing is a major advantage of the DGRAM, which
distinguishes it from other TDMA protocols for WSNs,
which typically have a centralized slot assignment. Also
note that the coordination of sleep and wake-up cycles
helps in transporting data from source to the sink across the
tiers, thereby eliminating the need for a separate routing
protocol. Thus, DGRAM does not require a separate routing
protocol to transport data from source to the sink. This also
means that energy which otherwise would have been spent
in finding routes is conserved in a DGRAM network.
4.8 An Example
As an example, let us consider a sensing area of 250 m
radius. Let the minimum transmission radius of each sensor
be 1 = 100 m and the maximum interference radius
1 = 100 m. Hence, for this network, u = 1,1 = 1.0. Con-
sidering a sensing radius of 30 m, for proper coverage of the
sensing area, the node density is chosen to be one node per
400 square meters. As per Section 4.5, c is fixed to be 0.5. This
gives 1 =
1
c
| = 2, which means that the first two tiers are
combined to form a single first tier. Hence, the number of
tiers in the network is H =
250
c+1
| 1 1 = 4. The number of
tiers in each group is 5 for this network (using (8)), i.e.,
` = 5. Hence, the example network has a single group with
four tiers. Calculation of the number of blocks in each tier is
done as per Section 4.1. Thus, C
1
and C
2
have one block and
C
3
and C
4
have four blocks each. Each node in C
4
has one
slot, a node in C
3
has three slots, and a node in C
2
has six
slots, as per (7). Nodes in the innermost tier C
1
have the
maximum number of slots per node, which is 13 slots, as
they have to relay data fromall outer tiers to the base station.
The superframe size is T = 1.892 slots. The worst-case delay
for this network calculated as per (16) is 3,784 slots.
5 ENERGY CONSUMPTION IN DGRAM
In this section, we calculate the maximum power consump-
tion of a node in the network running DGRAM. The
notation used in this calculation is given in Table 2. In a
WSN, energy consumption can be because of event sensing,
transmitting events to the next hop, receiving events from
the previous hop, and energy consumed while being idle.
We do not consider the energy consumption due to sensing,
since this component is common to all protocols. The
maximum number of slots in which a node in tier C
i
has to
receive is d
i,/
, where
d
i,/
= o
i
1. (20)
The minimum energy spent by a node during a single
TDMA frame is the energy spent by it when it has no
packets to receive or send. Consider a node `
i,/
, which
belongs to tier C
i
, block 1
i,
, and has an index / in its tier
and block. It is supposed to receive from a maximum of d
i,/
slots and transmit in o
i
slots. So T
i,/
id|c
= T ,(d
i,/
o
i
). To
compute the minimum energy spent by this node, we note
that it has to check the channel in the beginning of d
i,/
slots
for a possible reception and there should be no transmission
or reception. Hence, the minimum energy this node spends
is given by
SHANTI AND SAHOO: DGRAM: A DELAY GUARANTEED ROUTING AND MAC PROTOCOL FOR WIRELESS SENSOR NETWORKS 1417
TABLE 2
Notation Used in Calculation of Power Consumption
1
i,/
iii
= d
i,/
+ 1
i,/
qir
1
i,/
id|c
1
id|c
+ (d
i,/
+ (, T
qir
) ,o
i
).
(21)
The first term on the right-hand side of the above equation
is the energy spent in checking for preamble in the d
i,/
receive slots. The second term represents the idle energy
spent in time other than the transmission and receive slots.
The third term accounts for the idle energy spent during the
transmission and reception slots. In this, the term d
i,/
+ (,
T
qir
) is the time for which the node is idle in each receive
slot, after it senses the channel for T
qir
and then goes to
sleep for the rest of the slot time. The term ,o
i
is the time for
which the node is idle during its transmission slots.
The maximum energy is spent by this node in a TDMA
frame when it receives in all its d
i,/
slots and transmits in all
its o
i
slots. Thus, the maximum energy spent by this node is
given by
1
i,/
ior
= 1
i,/
id|c
d
i,/
+ 1
ir
o
i
+ 1
tr
. (22)
For every superframe, energy spent by a node `
i,/
is
computed as follows: Let us say that there are c.
i,/
number
of events to be transmitted by this node and it receives in
ic.
i,/
(ic.
i,/
_ d
i,/
) number of slots. So energy spent in a
superframe by this node is given by
1
i,/
:njci)ioic
= (d
i,/
ic.
i,/
) + 1
i,/
qir
ic.
i,/
+ 1
ir
(d
i,/
ic.
i,/
) + (, T
qir
) + 1
id|c
iii(o
i
. c.
i,/
) + 1
tr
(o
i
iii(o
i
. c.
i,/
)) + , + 1
id|c
1
i,/
id|c
.
(23)
The first three terms on the right side of (23) together give
the total energy spent in the d
i,/
receive slots. The next two
terms denote the energy spent in the o
i
transmission slots.
The last term represents the energy spent in the idle period
of the superframe.
The lifetime of a node is dependent on the TDMA frame
time and the number of TDMA slots for which the node
remains active for transmissionor reception. We compute the
lifetime of the most constrained node in the network. Among
all the nodes inthenetwork, we trackthe nodewhichdies first
anddenote the lifetime of that particular node as the lifetime of
most constrained node. This is an important parameter since
death of a node might lead to outage.
Some protocols employ Low-Power Listen CSMA (LPL-
CSMA) approach in which a node listens for preamble in a
low-power mode at random times. But the problem with
this approach is that the receiver has no way of knowing
when to listen for preamble. Hence, it might require the
sender to send long preamble so that when the receiver
listens for preamble, there is a high probability of receiver
detecting the preamble. This adversely affects the energy
consumption of nodes and the end-to-end delay of packets.
DGRAM does not exhibit this problem as the receiver
knows that it has to listen for preamble at the beginning of
every reception slot. This helps in reducing energy
consumption as well as latency.
6 SIMULATION RESULTS
We simulated DGRAM, FlexiTP, and a basic TDMA MAC
using ns2 for different radii of the sensing area and for
different event rates. FlexiTP is a TDMA-based protocol that
has a loose slot structure. The protocol has an initial
neighbor discovery phase, where each node discovers its
neighbors using HELLO messages with CSMA/CA. Then
slot assignment phase is executed, where nodes allot
themselves time slots to transmit, forward, and receive data,
and announce these slots to their neighbors. Once the slots
are decided, each node transmits, forwards, and receives
data in these slots only, and goes to sleep at all other times.
When a node detects the absence of a packet in its receive
slot, it treats this as a fault and the protocol switches to fault
tolerance mode, where a node again tries to find a neighbor
using HELLO messages. FlexiTP can work in any of the two
modes: with slot reuse ON (where the slots are reused by
nodes beyond two hops) and without slot reuse ON (where
slots are not reused). The basic TDMA MAC (henceforth
called the TDMAMAC) we have considered is the MAC that
comes bundled with ns2, extended for multihop commu-
nication by us. In this protocol, each TDMAcycle is preceded
by a preamble in which the wake-up slots for nodes for
reception are advertised by the sending nodes. These wake-
up slots are decided by the routing protocol. Each node is
given one slot for transmission of data in a TDMAframe. For
all our simulation experiments, we used the parameter
values given in Table 3. Each simulation experiment was run
for 2,000 simulation seconds. The values of the physical
parameters of the nodes are taken from [23], which contains
representative values for Mica2 Motes. We have assumed a
data rate of 19.2 Kbps for our experiments. Duration of each
time slot (,) is taken to be the duration for which packet of
64 bytes can be transmitted over a link of 19.2 Kbps
bandwidth, i.e., , =
648
19.2
ms = 27 ms. We considered dura-
tion of the preamble to be 1 ms. The simulation is done for a
circular region with the sink at the center. The sensor nodes
are uniformly distributed with a density ` = 1 node per
400 square meters. Each node knows its position with
respect to the base station, the node density `, the
transmission radius 1, the interference radius 1, the network
deployment radius RADIUS, and the total number of nodes
in the network `. The work presented in [19] assumes
uniform density of nodes in the deployed area and uses a
centralized algorithm to compute superframe structure.
Depending on the area under consideration, calculating
the number of nodes based on uniform density may not
always be accurate. This is because the uniform density of
nodes does not hold for arbitrary granularity and shape of
1418 IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010
TABLE 3
Physical Parameters Used in Simulation
the area. Hence, there may be an error in computing the
number of nodes based on uniform density. To mitigate this
problem, this paper proposes a beacon exchange phase
discussed in Section 4.3.1, where the topology information is
gathered by every node in a distributed manner. We ran
simulation to compare the above two methods. For the
beacon exchange phase, `A TT1 was set to one more
than the diameter of the network (in terms of number of
hops), silence timer time-out value was set to five times the
interbeacon time. The results of this experiment are
presented in Tables 4 and 5. It can be seen that the
distributed scheme consumes more energy and takes more
time for beacon exchange, but is 100 percent accurate in
topology gathering, and hence, in the calculation of
subframe lengths. On the other hand, the centralized scheme
ends up with an error in calculating the number of nodes.
This may result in data loss due to wrong subframe lengths
and mismatched sleep/wake-up cycles.
During the beacon exchange phase discussed in
Section 4.3.1, DGRAM spends much lesser time and
energy for networks of all radii and node densities, as
compared with FlexiTP. For example, it is noted that the
time and energy for FlexiTPs neighbor discovery phase for a
network of 100 m radius and 0.0025 nodes,m
2
are 1,072 sec
and 32.63 J, respectively. In addition, FlexiTP took
881.28 sec and spent 26.71 J for slot assignment. For the
same network scenario, DGRAM takes 676.7 sec and
spends 33.55 J for beacon exchange.
We are interested in finding out the performance of the
protocol in the worst-case scenario. Hence, events were
generated such that the interevent time is uniformly
distributed with the desired average rate. Further, when
an event generation time is up, then all the nodes in the
network are handed down an event with a time stamp,
which is uniformly distributed with the time of generation
of the event being the mean of the uniform distribution.
This scenario captures the worst-case scenario when a
phenomenon occurs, which affects the entire sensing area
(e.g., a biohazard that encompasses the entire sensing area),
and hence, all the nodes in the network would sense an
event almost at the same time. We have considered constant
bit rate (cbr) traffic and a lossless channel. Hence, when we
consider an interevent time that is 100 percent of the
superframe (which is, say, 8.964 sec), the interevent time is
8.964 sec and data generation rate is
1
8.964
packets/sec.
6.1 End-to-End Delay Guarantee
In Fig. 10, as expected, the average delay increases as the
radius of the network increases. This graph is very useful in
designing the radius of the sensing area so that the
maximum delay is less than a certain desired deadline. It is
also observed that the analytical maximum delay value is
always greater than the average delay obtained through
simulation. Also, the maximum delay experienced while
simulating DGRAM is always less than the analytical
maximum delay, though this is not clearly seen in the graph.
A similar simulation with FlexiTP and the TDMA MAC
shows that the average delay is much higher compared to
that of DGRAM for any network radius. This is because the
slot allocation in FlexiTP always leads to a larger superframe
size than DGRAM and the superframe size is the largest in
the case where the slot reuse is not done (Fig. 11). The
superframe size for the TDMA MAC is the lowest (equal to
the number of nodes) as there are no relaying slots, but the
packet delay is very high due to this absence of relaying slots.
To study the effect of different event rates on the average
packet delay, energy spent, and number of packets
SHANTI AND SAHOO: DGRAM: A DELAY GUARANTEED ROUTING AND MAC PROTOCOL FOR WIRELESS SENSOR NETWORKS 1419
TABLE 4
Simulation Results for Beacon Exchange Phase for Networks
of Different Radii (Node Density = 0.0025 Nodes,i
2
)
TABLE 5
Simulation Results for Beacon Exchange Phase for Networks of
Different Node Densities (Network Radius = 150 m)
Fig. 10. Effect of the network radius on the delay.
Fig. 11. Effect of the network radius on superframe.
delivered to the base station, we compare FlexiTP, TDMA
MAC, and DGRAM for three different scenarios and
network radii (100, 125, and 150 m). Figs. 12, 13, and 14
show the variation of average delay as the interevent time is
varied, for a network of 100, 125, and 150 m radius,
respectively. We have plotted the graph for interevent
times, which are expressed as a percentage of the super-
frame size. As expected, DGRAM gives a delay lower than
the analytical worst-case delay, for interevent times greater
than or equal to 100 percent of the superframe size (given
by (14)), since events will not stay in queue beyond the
worst-case delay. We have not shown the worst-case delay
in those graphs so as not to make them cluttered. But we
did verify that the average delay of DGRAM is lower than
the worst-case delay when interevent time is above the
superframe size. For the simulation parameters considered,
the worst-case delay is 2T for all the three networks. For
instance, superframe size for network radius of 150 m is
8.964 sec, and hence, the maximum delay is 17.928 sec. In
most of the cases, an event reaches the cluster head within a
superframe duration, since the first term in (16) accounts for
the case when the node just misses its turn, which happens
very rarely. That is why in these graphs, we notice that the
average delay drops to below the worst-case delay when
interevent time is around 100 percent of the superframe
size. For interevent times lesser than the superframe size,
buffering of events takes place and the average delay
sometimes exceeds the worst-case delay. The average delay
is more or less constant as the event rate decreases, which is
to be expected since the nodes always transmit in fixed slots
irrespective of the event rate. Hence, DGRAM is suitable for
interevent time greater than or equal to the superframe size,
when it provides deterministic delay guarantee.
FlexiTP, on the other hand, does not provide any end-to-
end delay guarantee. For interevent times lower than its
superframe size, the delay is large due to buffering. For
such cases, it is seen from these figures that the delay for
FlexiTP with and without slot reuse is much higher than
that for DGRAM. For the network radius of 100 m, FlexiTP
has the same slot allocation, and hence, same delay, both
with and without slot reuse. This is because slot reuse can
only be done beyond the transmission range, which is
100 m. For a network radius of 125 m, the slot allocation is
so similar for FlexiTP in the slot reuse and no slot reuse
cases that the difference in delay for these two cases is very
less and cannot be discerned clearly in the graph. For higher
interevent times where one would expect a guaranteed
delivery of packets at the base station, FlexiTP fails due to
its fault tolerance mechanism taking over. In this case, when
a node does not receive a packet during its receive slot, it
treats it as a missed transmission and sends a retransmis-
sion request, whereas the receive slot is actually empty
because there is no event to receive. With each superframe,
such retransmission requests grow exponentially and the
number of packets actually reaching the base station falls
rapidly. This behavior is discussed in more detail in the
next paragraph. The basic TDMA MAC simulated by us
also does not provide any end-to-end delay guarantee. As it
does not have relaying slots (each node is allotted a single
slot), buffering of data takes place and high packet delays
are seen for low interevent times. With higher interevent
times, the delay decreases, but this is the delay for the small
number of packets that reach the base station. Some packets
still remain in the buffer, waiting to be relayed. The average
delay for FlexiTP and TDMA MAC shown in the graphs,
Figs. 12, 13, and 14, is actually the delay for the very small
percentage of packets that reach the base station. DGRAM
provides 100 percent packet delivery for higher interevent
time. Thus, though FlexiTP claims to provide end-to-end
delay guarantee when slots are not reused, it is seen that
delivery guarantee exists neither for small interevent times
(where buffering of events, and hence, buffer overflow may
take place) nor for large interevent times (where absence of
an event is taken as a missed event and the fault tolerance
mechanism takes over, resulting in unnecessary loss of
energy and packets), making DGRAM an ideal choice for
both cases for different network sizes.
1420 IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010
Fig. 12. Effect of event rate on the average delay (network radius =
100 m).
Fig. 13. Effect of event rate on the average delay (network radius =
125 m).
Fig. 14. Effect of event rate on the average delay (network radius =
150 m).
In [24], the authors have reported a deployed fire-
monitoring system, where the maximum end-to-end packet
delay should be less than 30 sec. For such an application, a
DGRAM network of 150 m radius can be deployed, as it can
be seen from the graphs that such a network guarantees
packet delivery within 17.928 sec.
Figs. 15, 16, and 17 show how DGRAM guarantees
delivery of events (packets) to the sink within the deadline
in networks of 100, 125, and 150 m radius. As interevent time
increases, the percentage of packets with delay less than the
maximum allowable delay, i.e., packets meeting deadline,
increases. We have labeled these as packets delivered because
for FlexiTPandTDMAMAC, packets are actuallylost, but for
DGRAM, packets miss deadline. When interevent time is less
than superframe size, the DGRAM network has packets
missing deadline. As long as interevent time is less than the
superframe size, DGRAM is designed in such a way that the
packets flow toward the sink without exceeding the max-
imumpossible delay. If two or more events are generatedina
duration less than this value (8.964 sec for the 150 m network
radius), then there will be queuing at the source node, which
will have a cumulative queuing effect at the nodes in
subsequent tiers, eventually leading to packets missing
deadline. As the interevent time approaches superframe
size T, packets meeting their deadline (labeled as packets
delivered) fast approach 100 percent and when it is greater
than or equal to this superframe size, all the packets are
delivered before this maximum delay. Thus, DGRAM
guarantees delivery of packets within the maximum delay
as long as interevent time is greater than or equal to the
superframe size. On the contrary, as discussed before,
FlexiTP has packets lost due to buffering for low interevent
times and due to fault tolerance mechanismgetting activated
when the interevent times are high. Hence, FlexiTP does not
provide guaranteed delivery of packets in any of the cases.
For TDMA MAC, when the network radius is small (100 m),
most of the packets reach the sink directly without being
relayed. Hence, the packet delivery approaches 100 percent
for large interevent times, as seen in Fig. 15. As the network
radius increases, a lot of packets are lost in the buffer for low
interevent times, due to the lack of relaying slots. Though the
number of packets lost inthe buffer decreases withincreasing
interevent times, there is no guaranteed delivery of packets.
6.2 Energy Consumption
We ran the simulation to evaluate the energy consumption
by FlexiTP, TDMA MAC, and DGRAM for different event
rates (see Figs. 18, 19, and 20). In DGRAM, the average
energy spent decreases as the interevent time increases,
since increase in interevent time implies that fewer events
need to be sent to the base station. When FlexiTP is used,
the average energy spent remains constant for interevent
times greater than the superframe size. This is again due to
the fault tolerance mechanism of FlexiTP that takes over
when there is no event to be received. Since very few
packets reach the base station and much of the energy is
spent for fault tolerance in all such cases, energy spent
remains almost constant. The average energy spent using
FlexiTP, both with and without slot reuse schemes, is much
SHANTI AND SAHOO: DGRAM: A DELAY GUARANTEED ROUTING AND MAC PROTOCOL FOR WIRELESS SENSOR NETWORKS 1421
Fig. 15. Number of packets missing deadline as event rate changes
(network radius = 100 m).
Fig. 16. Number of packets missing deadline as event rate changes
(network radius = 125 m).
Fig. 17. Number of packets missing deadline as event rate changes
(network radius = 150 m).
Fig. 18. Total energy consumption versus event rate (network radius =
100 m).
higher for any event rate than DGRAM. TDMA MAC also
has higher energy expenditure than DGRAM for all
network radii and event rates. Note that only three plots
are visible in Fig. 18 because the plots for FlexiTP with and
without slot reuse coincide with each other.
6.3 Lifetime of the Most Constrained Node
We also wanted to compare the lifetime of the most
constrained node at different event rates for DGRAM,
TDMA MAC, and FlexiTP. For this purpose, we observe the
node that is first to die and measure the duration for which
that particular node was alive, which we refer to as lifetime
of the most constrained node in the network. As seen in Fig. 21,
this parameter is much higher for DGRAM than for FlexiTP
or the TDMA MAC network for all event rates. This makes
DGRAM a better choice not only with respect to the average
energy spent by a node, but also based on the lifetime of the
most constrained node.
7 CONCLUSION AND FUTURE WORK
We have presented a new contention-free TDMA-based
integrated MAC and routing protocol named DGRAM,
which can provide deterministic delay guarantee. Nodes in
DGRAM go through a short beacon exchange phase to learn
the location of other nodes. DGRAM is fully self-configuring
and slot assignment is done without exchange of any control
messages. We presented the detailed design of time slot
assignment, transmission and reception cycles of nodes. We
also provided the worst-case delay analysis of DGRAM. We
compared our protocol with another TDMA protocol called
FlexiTP and a basic TDMA MAC using simulation, which
showed that our protocol is a much better choice in terms of
delay, packets meeting their deadlines, and energy con-
sumption. Our simulation results also validated that the
actual delay is always less than the analytical worst-case
delay bound for which DGRAM is designed. Thus, DGRAM
can be used for hard real-time applications such as
biohazard detection, radioactive emission control, etc.
DGRAM is designed to handle interevent time greater than
or equal to the superframe size. That is, DGRAM can
guarantee delay bound and zero packet loss as long as
interevent time is greater than or equal to the superframe
size. This characteristic of DGRAM can be exploited while
choosing various operating parameters of the protocol.
Time synchronization is of paramount importance in
systems with TDMA protocols. We present a high-level
description of the synchronization protocol for DGRAM
network. After every r (where r is a tunable parameter)
TDMA cycles, the network enters into a short synchroniza-
tion phase, which consists of a synchronization superframe.
At the beginning of this phase, the sink broadcasts a
synchronization (sync) message with its clock value. All the
nodes in C
1
stay awake to listen to this message. Once they
receive the sync message, they adjust their clocks and then
relay the message in predefined TDMA slots. This process is
then repeated by the nodes in C
2
, then by C
3
, and so on, till
the outermost tier receives the sync message.
This synchronization scheme has a clear advantage of
fewer sync messages (and hence, lesser energy expendi-
ture) over flooding synchronization protocols. Each time
slot (in the DGRAM superframe) is then made long enough
for guard bands before and after the transmission of a
packet, to take care of the maximum possible clock drift
between two synchronization superframes. This ensures
that no data are lost due to clock drift before the nodes are
synchronized again.
Death of a node in the DGRAM protocol has serious
implication in terms of reporting and transporting data from
that region to the sink. Hence, we intend to incorporate
mechanisminto DGRAMso that the base stationwouldcome
to know when and where a node has become defunct. In a
DGRAMnetwork with a synchronization phase after every r
TDMA cycles, a node counts the number of sync messages it
receives from each node in its inner tier. If it does not receive
sync messages from a particular node for y (again a tunable
parameter) or more sync cycles, it assumes that that node is
1422 IEEE TRANSACTIONS ON MOBILE COMPUTING, VOL. 9, NO. 10, OCTOBER 2010
Fig. 19. Total energy consumption versus event rate (network radius =
125 m).
Fig. 20. Total energy consumption versus event rate (network radius =
150 m).
Fig. 21. Lifetime of the most constrained node versus event rate
(network radius = 150 m).
dead. It thensends this report tothe sinkina slot assignedtoit
ina fault tolerance frame. After everyy sync frames, there is
a fault tolerance frame, which is organized similar to the
DGRAM superframe, except that tierwise slot reuse is not
done andeach node stays awake for the entire duration of the
subframe of its immediate outer tier. Hence, a node in C
i
would stay awake for the entire duration of o
(i1)
and would
receive all the reports fromC
(i1)
. These reports reachthe sink
by the end of the fault tolerance cycle so that the dead nodes
can be identified and replaced, or other nodes can be made to
receive in their receive cycles if possible. Note that this
scheme relies on the reception of sync messages rather than
reception of data messages to declare a node dead, and can
work correctly even with low data rates, unlike FlexiTP.
We are currently working on the details of time
synchronization and fault tolerance aspects of DGRAM
and intend to incorporate those into DGRAM simulation.
There exists an optimal value of the tier width coefficient
c that would result in the optimal superframe size and
minimal energy consumption. We found this value of c
empirically and aim to calculate this value using optimiza-
tion techniques. There are many applications of WSNs that
do not need a hard delay bound, but can tolerate a
probabilistic delay guarantee. We plan to look at modifica-
tions necessary in DGRAM to provide probabilistic delay
guarantee, which would make it useful for a wider
spectrum of applications.
REFERENCES
[1] A. Rowe, R. Mangharam, and R. Rajkumar, RT-Link: A Global
Time-Synchronized Link Protocol for Sensor Networks, Ad Hoc
Networks, vol. 6, no. 8, pp. 1201-1220, 2008.
[2] W.L. Lee, A. Datta, and R. Cardell-Oliver, FlexiTP: A Flexible-
Schedule-Based TDMA Protocol for Fault-Tolerant and Energy-
Efficient Wireless Sensor Networks, IEEE Trans. Parallel and
Distributed Systems, vol. 19, no. 6, pp. 851-864, June 2008.
[3] I.F. Akyildiz, W. Su, Y. Sankarasubramaniam, and E. Cayirci,
Wireless Sensor Networks: A Survey, Computer Networks,
vol. 38, no. 4, pp. 393-422, 2002.
[4] A. Woo and D.E. Culler, A Transmission Control Scheme for
Media Access in Sensor Networks, Proc. ACM MobiCom, pp. 221-
235, 2001.
[5] W. Ye, J. Heidemann, and D. Estrin, Medium Access Control
with Coordinated Adaptive Sleeping for Wireless Sensor Net-
works, IEEE/ACM Trans. Networking, vol. 12, no. 3, pp. 493-506,
June 2004.
[6] A. El-Hoiydi and J.-D. Decotignie, WiseMAC: An Ultra Low
Power MAC Protocol for Multi-Hop Wireless Sensor Networks,
Proc. First Intl Workshop Algorithmic Aspects of Wireless Sensor
Networks (ALGOSENSORS), pp. 18-31, 2004.
[7] G. Lu, B. Krishnamachari, and C.S. Raghavendra, An Adaptive
Energy-Efficient and Low-Latency MAC for Data Gathering in
Wireless Sensor Networks, Proc. 18th Intl Parallel and Distributed
Processing Symp. (IPDPS 04), pp. 224-233, 2004.
[8] R. Cohen and B. Kapchits, An Optimal Algorithm for Minimizing
Energy Consumption While Limiting Maximum Delay in a Mesh
Sensor Network, Proc. IEEE INFOCOM, pp. 258-266, 2007.
[9] K. Sohrabi and G.J. Pottie, Performance of a Novel Self-
Organization Protocol for Wireless Ad-Hoc Sensor Networks,
Proc. IEEE Vehicular Technology Conf., pp. 1222-1226, 1999.
[10] A.P. Chandrakasan, A.C. Smith, and W.B. Heinzelman, An
Application-Specific Protocol Architecture for Wireless Microsen-
sor Networks, IEEE Trans. Wireless Comm., vol. 1, no. 4, pp. 660-
670, Oct. 2002.
[11] T. Wu and S. Biswas, Reducing Inter-Cluster TDMA Interference
by Adaptive MAC Allocation in Sensor Networks, Proc. First
Intl IEEE WoWMoM Workshop Autonomic Comm. and Computing
(ACC 05), pp. 507-511, 2005.
[12] S. Cho, K. Kanuri, J.-W. Cho, J.-Y. Lee, and S.-D. June, Dynamic
Energy Efficient TDMA-Based MAC Protocol for Wireless Sensor
Networks, Proc. IEEE Joint Intl Conf. Autonomic and Autonomous
Systems and Intl Conf. Networking and Services (ICAS-ICNS), p. 48,
2005.
[13] T. He, J.A. Stankovic, C. Lu, T. Abdelzaher, SPEED: A Stateless
Protocol for Real-Time Communication in Sensor Networks,
Proc. IEEE Intl Conf. Distributed Computing Systems (ICDCS 03),
p. 46, 2003.
[14] E. Felemban, C.-G. Lee, and E. Ekici, MMSPEED: Multipath
Multi-SPEED Protocol for QoS Guarantee of Reliability and
Timeliness in Wireless Sensor Networks, IEEE Trans. Mobile
Computing, vol. 5, no. 6, pp. 738-754, June 2006.
[15] D. Lucarelli and I.-J. Wang, Decentralized Synchronization
Protocols with Nearest Neighbor Communication, Proc. ACM
Intl Conf. Embedded Networked Sensor Systems (SenSys), pp. 62-68,
2004.
[16] S. Ganeriwal, R. Kumar, and M.B. Srivastava, Timing-Sync
Protocol for Sensor Networks, Proc. ACM Intl Conf. Embedded
Networked Sensor Systems (SenSys), pp. 138-149, 2003.
[17] M. Maroti, B. Kusy, G. Simon, and A. Ledeczi, The Flooding
Time Synchronization Protocol, Proc. ACM Intl Conf. Embedded
Networked Sensor Systems (SenSys), pp. 39-49, 2004.
[18] S. Kulkarni, A. Iyer, and C. Rosenberg, An Address-Light,
Integrated MAC and Routing Protocol for Wireless Sensor
Networks, IEEE/ACM Trans. Networking, vol. 14, no. 4, pp. 793-
806, Aug. 2006.
[19] S. Chilukuri and A. Sahoo, DGRAM: A Delay Guaranteed
Routing and MAC Protocol for Wireless Sensor Networks, Proc.
Ninth Intl Conf. World of Wireless, Mobile and Multimedia Networks
(WoWMoM 08), pp. 1-9, 2008.
[20] A. Savvides, C.-C. Han, and M.B. Strivastava, Dynamic Fine-
Grained Localization in Ad-Hoc Networks of Sensors, Proc. ACM
MobiCom, pp. 166-179, 2001.
[21] N.B. Priyantha, H. Balakrishnan, E. Demaine, and S. Teller,
Anchor-Free Distributed Localization in Sensor Networks,
Technical Report TR-892, MIT Laboratory for Computer Science,
Apr. 2003.
[22] H.M. Khan, S. Olariu, and M. Eltoweissy, Efficient Single-Anchor
Localization in Sensor Networks, Proc. Second IEEE Workshop
Dependability and Security in Sensor Networks and Systems (DSSNS),
pp. 35-43, 2006.
[23] E. Shih, S.-H. Cho, N. Ickes, R. Min, A. Sinha, A. Wang, and A.
Chandrasekharan, Physical Layer Driven Algorithm and Proto-
col Design for Energy-Efficient Wireless Sensor Networks, Proc.
ACM MobiCom, pp. 272-287, 2001.
[24] H. Xu, L. Huang, J. Wu, Y. Wang, B. Xu, J. Wang, and D. Wang,
Wireless Fire Monitoring System for Ancient Buildings, Proc.
Second Intl Conf. Scalable Information Systems (InfoScale 07), pp. 1-4,
2007.
Chilukuri Shanti received the BE and MTech
degrees from Andhra University, Visakhapat-
nam, in 1994 and 1999, respectively. She is
currently working toward the PhD degree at the
Indian Institute of Technology Bombay. She was
a lecturer at GITAM University from October
1999 to June 2001 and at GVP College of
Engineering, Visakhapatnam, from August 2003
to June 2006. Her research interests include
computer networks and distributed computing.
She is a student member of the IEEE.
Anirudha Sahoo received the BSc (Engg)
degree in electrical engineering from NIT,
Rourkela, and the MS and PhD degrees in
computer science from the University of Lousi-
ana and Texas A&M University, respectively. He
is currently an associate professor in the
Department of Computer Science and Engineer-
ing, Indian Institute of Technology Bombay (IIT
Bombay). Prior to joining IIT Bombay, he worked
as a software engineer in Intergraph Corpora-
tion, Alabama, for five years, and then as a senior software engineer in
Cisco Systems, California, for five years. He is a member of the IEEE.
SHANTI AND SAHOO: DGRAM: A DELAY GUARANTEED ROUTING AND MAC PROTOCOL FOR WIRELESS SENSOR NETWORKS 1423

You might also like