# TDMA scheduling algorithms for wireless sensor networks

## Abstract

Algorithms for scheduling TDMA transmissions in multi-hop networks usually determine the smallest length conflict-free assignment of slots in which each link or node is activated at least once. This is based on the assumption that there are many independent point-to-point flows in the network. In sensor networks however often data are transferred from the sensor nodes to a few central data collectors. The scheduling problem is therefore to determine the smallest length conflict-free assignment of slots during which the packets generated at each node reach their destination. The conflicting node transmissions are determined based on an interference graph, which may be different from connectivity graph due to the broadcast nature of wireless transmissions. We show that this problem is NP-complete. We first propose two centralized heuristic algorithms: one based on direct scheduling of the nodes or node-based scheduling, which is adapted from classical multi-hop scheduling algorithms for general ad hoc networks, and the other based on scheduling the levels in the routing tree before scheduling the nodes or level-based scheduling, which is a novel scheduling algorithm for many-to-one communication in sensor networks. The performance of these algorithms depends on the distribution of the nodes across the levels. We then propose a distributed algorithm based on the distributed coloring of the nodes, that increases the delay by a factor of 10–70 over centralized algorithms for 1000 nodes. We also obtain upper bound for these schedules as a function of the total number of packets generated in the network.

### Keywords

Sensor network Scheduling algorithm MAC protocol## 1 Introduction

Wireless sensor networks have been proposed for a wide range of monitoring applications such as traffic and seismic monitoring, and fire detection [1]. Such networks consist of a group of nodes, with sensing, signal processing and wireless communication capabilities and limited battery energy. The nodes must quickly report the results to a data collection node or access point. Since the nodes are battery-powered, the medium access control (MAC) protocol is critical in determining network lifetime.

Proposed MAC protocols for sensor networks provide either contention based access or time division multiple access (TDMA). The former, e.g., IEEE 802.11 [2], consume more energy than TDMA protocols because they waste energy in collisions and idle listening. Moreover, they do not give delay guarantees. TDMA protocols are more power efficient since nodes in the network can enter inactive states until their allocated time slots. They also eliminate collisions and bound the delay. For example, the TDMA protocol for a traffic monitoring network described in [3] has a lifetime of 1,200 days compared with ten days using the IEEE 802.11 protocol.

The main task in designing a TDMA schedule is to allocate time slots depending on the topology and the node packet generation rates. A good schedule not only avoids collisions by silencing the interferers of every receiver node in each time slot but also minimizes the number of time slots hence the latency: The larger latency may require a higher data rate (and hence higher energy consumption) to satisfy a deadline [4]. We therefore try to find a TDMA schedule that minimizes the number of time slots.

TDMA algorithms consider either one-hop or multi-hop scheduling. The former are for networks in which the nodes are one hop away from the base station [4, 5], and allocate time slots in the reverse channel depending on allocation request and deadline of the nodes. Because the base station is the common receiver of the transmissions, only one node can transmit in a slot. In some sensor networks however direct transmission from all sensor nodes to the base station may not be feasible nor power efficient [6].

Multi-hop TDMA scheduling is more challenging than one-hop scheduling because spatial reuse of a time slot may be possible: More than one node can transmit at the same time slot if their receivers are in non-conflicting parts of the network. There are two types of conflicts, namely, primary conflict and secondary conflict. A primary conflict occurs when a node transmits and receives at the same time slot or receives more than one transmission destined to it at the same time slot. A secondary conflict occurs when a node, an intended receiver of a particular transmission, is also within the transmission range of another transmission intended for other nodes. In the context of TDMA, the problem is to determine the smallest length conflict-free assignment of slots where each link or node is activated at least once [7]. Previous work on scheduling algorithms focus on either decreasing the length of schedules [7, 8, 9, 10, 11, 12] or distributed implementation [10, 13, 14, 15, 16].

Previous scheduling algorithms activating each link or node at least once during a TDMA frame are based on the assumption that there are many independent point-to-point flows in the network. In sensor networks however often data are transferred from the sensor nodes to a few central data collectors. In traffic monitoring [17], for example, the nodes sense the passage of vehicles at several freeway locations or at an intersection, and transmit the data to the access point on the side of the freeway or intersection. The packets are transferred to the access point over the routing tree in multiple hops. The problem therefore is to determine the smallest length conflict-free assignment of slots during which the packets generated at each node reach the access point over the routing tree.

The many-to-one scheduling has been addressed previously by [18, 19, 20]. Reference [18] proposes an evolutionary algorithm where genetic algorithm and particle swarm optimization are hybridized to enhance the searching ability however does not provide any guarantees on the performance. References [19] and [20] on the other hand propose heuristic algorithms that schedule as many independent segments as possible to increase the degree of parallel transmission but does not consider the specific nature of many-to-one communication nor the interference models in wireless communication. Since each packet is relayed on the routing path from the originating sensor node to the access point, the many-to-one scheduling problem requires considering precedence relations: If the packet follows the routing path (*k*,* k* − 1,…, 2, 1), node *j* should not be scheduled before node *i* for that packet if *j* ≤ *i*. Precedence constrained graphs have been studied in the context of allocating the tasks in the precedence constrained task graphs to the processors in the processor network so that the schedule length is minimized [21]. In this problem however the tasks are already assigned to the processors since a packet at node *j* has to be processed by node *j*. The difficulty on the other hand comes from the requirement of eliminating primary and secondary conflicts in the processor network.

The original contributions of this paper are three: First, we formulate the sensor network scheduling problem. Second, we prove the NP-completeness of the problem. Third, we generate a node based scheduling algorithm which is adapted from classical multi-hop scheduling algorithms for general ad hoc networks for the specific sensor network configuration of nodes and data generation patterns considering the interference graph in addition to the connectivity graph. Fourth, we propose a novel scheduling algorithm based on scheduling the levels of the tree before scheduling the nodes for many-to-one communication in sensor networks. Finally, we derive upper bounds for these schedules as a function of the total number of packets generated in the network.

The rest of the paper is organized as follows. The transmission and network model is described in Sect. 2. Section 3 describes the scheduling problem and proves that it is NP-complete. We then propose two heuristic centralized algorithms for solving the problem: The one in Sect. 4 is based on direct scheduling of the nodes, whereas the other is based on scheduling the levels in the routing tree before scheduling the nodes as explained in Sect. 5. Section 6 describes a token-based distributed scheduling algorithm. The algorithms are analyzed in Sect. 7. Simulations are given in Sect. 8. Section 9 collects some conclusions.

## 2 Network and transmission model

We consider a network comprising a single access point (AP) and several sensor nodes that periodically generate data, possibly at different rates, for transfer to the AP. Links are assumed to be bidirectional. This is required for proper functioning of network protocols such as distributed Bellman-Ford algorithms [22]. Bidirectionality is achieved if all sensor nodes transmit at the same power. Differences in actual transmission power due to the hardware differences can be compensated by setting up links based on received signal strength as explained in [3].

The network is represented by a graph *G* = (*V*,*E*). *V* is the set of nodes, including the access point *AP* as node 1. *N* = |*V*| is the number of nodes in *G*. The (undirected) edges *E* ⊂ *V* × *V* are the (transmission) links to be scheduled. The graph forms a *tree*. All traffic is destined for *AP*, so every data packet at a node is forwarded to the node’s parent in the tree rooted at the AP.

A node may interfere with another node, so these nodes should not transmit simultaneously. The *interference* graph *C* = (*V*,*I*) is assumed known. *I* ⊂*V* × *V* is the set of edges such that \((u, v)\,{\in}\,I\) if either *u* or *v* can hear each other or one of them can interfere with a signal intended for the other (even if they cannot hear each other). So, if *u* is transmitting, *v* should not be scheduled to receive from another node at the same time.

The *conflict* graph corresponding to *G* = (*V*,*E*) and *C* = (*V*,*I*) is called *GC* = (*V*, *EC*). In *GC*, each node \(i \,\in\, V\) corresponds to the link \((i,p_i) \,\in\, E\) where *p*_{i} is the parent of node *i* in the routing tree *G* rooted at AP. *EC* comprises the edges between node pairs in *G* that should not transmit at the same time. It is generated by taking into account the primary and secondary conflicts described in Sect. 1. *EC* contains two kinds of edges. First, if \((i, j) \,\in\, E, (i,j) \,\in\, EC,\) because a parent node and a child node cannot transmit at the same time. Second, if \((i,j) \,\in\, I\) or \((i,j) \,\in\, E\) and *c*_{j} is a child of *j* in \(G, (i, c_j) \,\in\, EC\): Because *i* and *j* interfere, if *i* is transmitting, the child *c*_{j} of *j* cannot transmit at the same time because *j* would hear from both *i* and *c*_{j}.

A *scheduling frame* is the time duration that starts when each node has generated an integer number of packets and ends when all these packets have reached *AP*. It is divided into time slots. A slot is long enough to transmit one data packet plus a guard interval to compensate for synchronization errors. A *schedule* assigns one or more time slots to each edge in *G* or, equivalently, to each node in *GC*. A node *u* may receive a packet from its child *v* during a time slot assigned to \((v,u) \,\in\, E\) or to node \(v \,\in\, V\) since its parent *u* is already known.

We use the following notation. The *distance**d*(*u*,*v*) between nodes *u* and *v* is the number of edges in the path between them in *G*; and a node *u* is at *level**k* if it is at distance *k* from *AP*.

## 3 The scheduling problem

Each node of *G* (except *AP*) generates a positive integer number of packets at the beginning of the scheduling frame. Given the interference graph *C*, the scheduling problem is to find a minimum length frame during which all nodes can send their packets to *AP*.

**Theorem 1**

*The scheduling problem is NP-complete*.

*Proof*

We reduce the NP-complete problem of finding the chromatic number of a graph to the scheduling problem. The chromatic number of a graph *G* is the smallest number *k* such that *G* is *k*-colorable. *G* is *k*-colorable if its vertices can be colored using *k* different colors in such a way that adjacent vertices have different colors. Let *GP* = (*VP*, *EP*) with *VP* = {*v*_{1},…, *v*_{N}} be an instance of a graph whose chromatic number we want to find. We first construct a conflict graph *GC* = (*V*, *EC*). First, *GC* includes all the nodes and edges of *GP*. Next, for each node *v*_{i}, add another node *w*_{i}. Then add edges \((w_i, w_j), (v_i, w_j) \,\in\, EC\) for all *i*,*j*. Lastly add another node *AP* and edges (*AP*, *w*_{i}) for all *i*. See Fig. 1.

The conflict graph *GC* is such that if *w*_{i} is active, none of the nodes in \(V {\setminus}\{w_i\}\) can be active at the same time. Also, if *v*_{i} is active, none of the nodes *w*_{j} or the conflicting nodes from *VP*, determined by the edges *EP*, can be active.

We now construct a tree *G* = (*V*,*E*) and an interference graph *C* = (*V*,*I*) whose conflict graph is *GC* = (*V*,*EC*). The edges of the tree are *E* = {(*AP*, *w*_{i}), (*w*_{i}, *v*_{i}) |1 ≤*i* ≤ *N*}. Because *AP* is a parent of \(w_i, (w_i, AP) \,\in\, EC\) for all *i*; moreover \((w_i, w_j) \,\in\, EC\) for all *i*, *j*, because they have the same parent, *AP*. And \((v_i, w_i) \,\in\, EC\) because *w*_{i} is the parent of *v*_{i}.

Let *I* consist of edges (*v*_{i}, *AP*) for all *i*, and (*v*_{i}, *w*_{j}), (*v*_{j}, *w*_{i}), whenever (*v*_{i}, *v*_{j}) ∈* EC*. Since (*v*_{i}, *AP*) ∈ *I* and \((w_j, AP) \,\in\, E, (v_i, w_j) \,\in\, EC\) for all *i*, *j*. Lastly, if (*v*_{i}, *w*_{j}) ∈ *I* and \((v_j, w_i) \,\in\, I, i \neq j, (v_i, v_j) \,\in\, EC\) because the parent of one of them is interfered by a transmission of the other. Thus *GC* is indeed the conflict graph corresponding to the tree graph *G* and interference graph *C*.

Consider the minimum schedule length for *GC* such that each node *v*_{i}, *w*_{i}, 1 ≤ *i* ≤ *N*, has one packet destined for *AP*. A packet in *w*_{i} takes the path (*w*_{i}, *AP*) and a packet in *v*_{i} takes the path (*v*_{i}, *w*_{i}, *AP*). Because each *w*_{i} conflicts with the nodes *w*_{j}, *j* ≠ *i* and all nodes *v*_{i}, it takes *N* slots to transmit the packets generated at level one to *AP*, independently of the rest of the network. Also, when the *N* packets from level two arrive at level one, it takes another *N* slots to forward them to *AP*.

*AP*, we must minimize the time to transmit the packets from level two to level one. But the conflict graph at level two is determined by the original graph

*GP*, so the minimum scheduling time is exactly 2

*N*+

*c*, where

*c*is the chromatic number of the original graph

*GP*. □

The scheduling problem is difficult because many subsets of non-conflicting nodes are candidates for each time slot, and the subset selected for transmission in one slot affects the number of transmissions in the next time slot, as some schedulable nodes may not have any packets to transmit because of the subset selected in the previous slot.

**Lemma 1**

*Assume that node*\(i {\,\in\,}V\)* has generated**g*_{i}* packets to transmit. The minimum schedule length is at least*\(\sum_{i \,\in\, V}{g_i}.\)

*Proof*

*AP* can receive at most one packet in each slot, so at least \(\sum_{i \,\in\, V}{g_i}\) slots are needed for all packets to reach *AP*. This gives the lower bound. □

## 4 Node-based scheduling algorithm

The node-based scheduling algorithm has been adapted from classical multi-hop scheduling algorithm developed for general ad hoc networks with the idea of scheduling as many non-conflicting set of nodes as possible in each time slot [12, 19, 20]. The algorithm has two parts. In the first part, we color the conflict graph *GC*_{c} = (*V*_{c},*EC*_{c}) where \(V_c =V {\setminus}\{1\}, EC_c =EC \setminus N_1\) and *N*_{1} = {(*i*,*j*)| *i* = 1}. In the second part, we schedule the links in the original network, \((u,v) \,\in\, E,\) based on this coloring.

### 4.1 Coloring the network

Any algorithm can be used to color the conflict graph *GC*_{c} such that nodes *i* and *j* are assigned different colors if \((i,j) \,\in\, EC_c.\) Computing the chromatic number of a graph is NP-complete. Incremental methods appear to be the heuristic choice of vertex coloring [13]: Vertices are colored sequentially with the colors chosen in response to colors already assigned in the vertex’s neighborhood. These methods vary in how the next vertex is selected and how it is assigned a color.

*i*in

*O*(

*i*) steps, so the running time of this algorithm is

*O*(|

*V*|

^{2}).

### 4.2 Scheduling the network

A *superslot* in a node-based scheduling algorithm is a collection of consecutive time slots such that each node with at least one packet at the beginning of the superslot transmits at least one packet during the superslot. Because two nodes assigned the same color can transmit at the same time, the number of slots in a superslot is at most equal to the total number of colors used for coloring the network.

*O*(

*l*

*d*

_{max}|

*V*|), where

*d*

_{max}is the maximum degree of a node in

*GC*and

*l*is the total number of slots in the schedule.

Two examples are given in Figs. 6 and 7. *G* = (*V*,*E*) and *C* = (*V*,*I*) are shown on the left with the resulting *GC* = (*V*,*EC*). The nodes are ordered based on their degrees in *GC* for the coloring, which are (*s*3,*s*2,*s*4,*s*5,*s*6,*s*7,*s*1) and (s2,s3,s5,s6,s1,s4) in Figs. 6 and 7 respectively. The resulting schedules are shown in part-(a) of the figures.

## 5 Level-based scheduling algorithm

The level-based scheduling algorithm has three parts. In the first part, we obtain a linear network *GL* = (*VL*, *EL*) with interference graph *CL* = (*VL*,*IL*) resulting in the conflict graph *GCL* = (*VL*, *ECL*) corresponding to the original network. In the second part, we color this linear network. In the third part, we schedule the links in the original network, \((u,v) \,\in\, E,\) based on the coloring of the linear network.

### 5.1 The linear network

If the original tree network has depth *N*, the linear network *GL* = (*VL*,*EL*) has nodes *VL* = {*v*_{1},…, *v*_{N}} with node *v*_{l} corresponding to all nodes at level *l* in the original network and edges \((v_i,v_{i+1}) \,\in\, EL\) for 1 ≤ *i* < *N*. The interference graph *CL* = (*VL*, *IL*) includes edge (*v*_{j}, *v*_{l}) if there is an interference edge between a node at level *j* and any node at level *l* in the original network for *j*, *l* ≥ 1. The resulting conflict graph *GCL* = (*VL*, *ECL*) thus includes edge (*v*_{j}, *v*_{l}) if the transmissions of a node at level *j* and a node at level *l* conflict in the original network.

*EL*between consecutive levels whereas an edge (

*v*

_{j},

*v*

_{l}) is added to the interference (conflict) graph of the linear network, i.e.,

*IL*(

*ECL*), if there is an edge between a node at level

*j*and any node at level

*l*in the interference (conflict) graph of the original network, i.e.,

*I*(

*EC*). The algorithm in Fig. 4 finds

*EL*,

*CL*and

*ECL*. Its running time is

*O*(|

*V*|

^{2}).

### 5.2 Coloring the linear network

Any coloring algorithm can be used to color the conflict graph of the linear network *GCL* = (*VL*,*ECL*). The algorithm given in Fig. 2 can be used for this purpose with *V*_{c} = *VL* and *GC*_{c} = *GCL* as input, and one color assigned to each node in *VL* and the number of colors, *M*, as output.

### 5.3 Scheduling the original network

If nodes *v*_{i}, *v*_{j} in the linear network are assigned the same color, they do not interfere. By construction of the linear network any two nodes in the original network, one chosen from level *i* and the other from level *j*, can transmit at the same time.

A *superslot* in a level-based scheduling algorithm is a collection of consecutive time slots such that each level of the tree with at least one packet at the beginning of the superslot forwards at least one packet to the lower level during the superslot. Because two nodes at different levels assigned the same color can transmit at the same time, the number of slots in a superslot is at most equal to the total number of colors used for coloring the linear network.

*O*(

*l*

*d*

_{max}|

*V*|), where

*d*

_{max}is the maximum degree of a node in

*GC*and

*l*is the total number of slots in the schedule.

*G*= (

*V*,

*E*) and

*C*= (

*V*,

*I*) are shown on the left with the resulting

*GCL*= (

*VL*,

*ECL*). The levels are in increasing order for coloring. The ordering does not affect the number of colors used in the linear network nor the schedule length for these examples. The resulting schedules are shown in part-(b) of the figures.

Figure 6 illustrates a topology where level-based scheduling performs better than node-based scheduling whereas Fig. 7 illustrates a network where node-based scheduling outperforms level-based scheduling. Figure 6 demonstrates the advantage of level-based scheduling in balancing the movement of packets across the network in a network of higher density of the packets at high levels. In topologies of equal density of the packets across the network or higher packet density at low levels, giving equal chance to the nodes balances the movement of packets as shown in Fig. 7.

## 6 Scalability and distributed implementation

The node-based and level-based scheduling algorithms described above require complete topology information, and there are two options for implementation. The first option is to send the topology information to a central controller, which then performs the slot assignment and sends it back to the nodes in the network. The second option is that each node learns the entire network topology and executes the algorithm independently to produce identical schedules. Both options may require a lot of communication among the nodes, and may become inappropriate for large networks.

One way to bring scalability to the system is clustering the nodes in the network. The central controller corresponding to each cluster should take into account the interferers that are outside their range while generating schedules. The central controllers are assigned colors so that no two conflicting controllers are assigned the same color (e.g., a simple algorithm that constructs a Δ + 1-coloring in at most *n* steps is given in [23] for Δ and *n* being the maximum degree of a vertex and the number of vertices respectively in the graph with vertices as controllers and edges between the conflicting controllers). The controllers assigned to the first color then find the schedule and broadcast this information to sensor nodes and neighboring central controllers. Neighboring controllers with the next color assign the time slots to the nodes inside their range, taking into account the already assigned common nodes, which are defined to be the nodes inside their range and the range of at least one of the central controllers of previous colors, and the interferers inside the range of another controller. The controllers corresponding to each color consider the schedules of the controllers of the previous colors in this way. Since the length of the schedules are only affected by the common nodes with the conflicting controllers and the interference coming from neighboring controllers and the schedules of sufficiently separated controllers are not affected from each other, the resulting system is scalable.

Another way to achieve scalability in the system is through distributed algorithms, in which the schedules of the nodes are generated based on the local topology information of the nodes. It is very hard to obtain a distributed version of node-based and level-based scheduling algorithms. The main reason is that these algorithms check whether the nodes that are potential transmitters in the current slot have any packets and skip that slot otherwise. Another reason is that the algorithms schedule the nodes in other colors if some of the nodes that are potential candidates for the current slot do not have any packets. Such a schedule cannot be implemented in their distributed version since the nodes cannot know how many packets their interferers have due to the lack of knowledge of global topology information.

To get an idea of the performance of a distributed algorithm, we propose a simple algorithm based on the distributed coloring of the network similar to the one described in [13]. Notice that the conflicting nodes, the nodes that have edge between them in *GC*, are either one hop or two hops away from each other in the graph *G*_{u} = (*V*, *E* ∪*I*). Assume the nodes *i* and *j* can transmit to each other if \((i,j) {\,\in\,}E {\cup}I,\) e.g., this can be achieved by increasing the transmission range of the nodes [3]. We also assume that all the transmissions during the generation of the schedules are successful, which can be guaranteed by an acknowledgment. The nodes first learn about all of their one hop and two hop neighbors in *G*_{u} and their parents in the tree *G* rooted at the AP so that they can determine their interferers in *GC*.

Similar to the algorithm described in [13], the color assignment is performed in two stages. During the first stage of the algorithm, each node picks one slot for transmission in the order of the traversal of the depth first search (DFS) [24] of the graph *G*. In the second stage, the DFS is repeated and now each node picks as many of the remaining colors as it can for transmission. At both stages, the nodes send this information to their one-hop and two-hop neighbors in *G*_{u} so that all their interferers in *GC* learn about the assignment.

The DFS traversal starts with a TOKEN message generated at the AP. Upon receipt of the token, the node performs the color assignment and then sends this information to its one-hop and two-hop neighbors in *G*_{u}. It then sends the token to each of its neighbors in *G* who have not received the token yet. Once it finds that all its neighbors have received the token, it sends the token back to its parent, which is the node from which it receives the token for the first time. At the end of the traversal, the token carries the information of the number of colors used in the network back to the AP.

The total number of token transmissions is *O*(|*E*|) at each stage and the total number of transmissions for distributing the color assignments is *O*(*d*_{max}|*V*|), in which *d*_{max} is the maximum degree of the nodes in *G*_{u}.

Two examples are given in Figs. 6 and 7. The coloring of the nodes are shown on the top right of the figures. The colors of the nodes are assigned at the first stage whereas the colors of the small circles next to the nodes are assigned at the second stage. The DFS traversal order are (*s*_{1},*s*_{2},*s*_{3},*s*_{4},*s*_{5},*s*_{6},*s*_{7}) and (*s*_{1},*s*_{4},*s*_{2},*s*_{5},*s*_{3},*s*_{6}) in Figures 6 and 7 respectively. The resulting schedules are shown in part-(c) of the figures.

## 7 Analysis of the algorithms

We consider four cases:

**Case 1**

The tree graph *G* = (*V*,*E*) is linear, that is each node \(u \,\in\, V\) has at most one child. The interference graph *C* = (*V*,*I*) is such that *I* = ∅.

**Case 2**

The tree graph *G* = (*V*,*E*) is general. The interference graph *C* = (*V*,*I*) satisfies the ancestor property, that is, there do not exist *u*,*v*,*b* such that \((u,v) \,\in\, I\) and |*d*(*u*,*b*) − *d*(*v*,*b*)| > 1. This represents the case where shortest path routing is used with the cost of each path being equal to the number of nodes on that path and only nodes that can hear each other can interfere, which is the assumption of previously proposed TDMA scheduling algorithms.

**Case 3**

The tree graph *G* = (*V*,*E*) is general and the interference graph *C* = (*V*,*I*) is such that the maximum difference between the levels of two interfering nodes is *K*.

**Case 4**

The tree graph *G* = (*V*,*E*) and the interference graph *C* = (*V*,*I*) are both general.

**Theorem 2**

*Assume that each node has one packet to transmit. For level-based scheduling algorithm, in cases 1 and 2 the maximum length of the frame is 3*|*V*| − *3 time slots; in case 3 it is (**K* + 2)(|*V*|− α*(*|*V*| − *1), in which α is the number of colors used in the linear network corresponding to**G** and**C*.

*Proof*

**Case 1** If the tree graph *G* is linear and the interference graph *C* satisfies *I* = ∅, the corresponding linear tree interference graph *CL* also satisfies *IL* = ∅. It is easy to see that this linear tree can be colored optimally with three colors when the number of levels is more than two. The colors are assigned in a round robin fashion starting with the node at level 1.

At the beginning of the frame, each node has exactly one packet. In the first superslot, one packet is transmitted from any level to the next lower level. Because each node is a parent of exactly one node except for the node at the highest level |*V*| − 1, it also receives one packet during the superslot. Thus, at the end of the first superslot, each node at level less than |*V*| − 1 has exactly one packet to transmit, the node at level |*V*| − 1 has no packet, and each node has transmitted exactly one packet during the superslot. This means that at the end of the first superslot, each packet has moved by one hop and one packet has reached the final destination *AP*.

In the same way, at the beginning of the second superslot, each node at level less than |*V*| − 1 has one packet to transmit, and at the end of the second superslot, each packet has moved by one more hop, there are no more packets at levels greater than or equal to |*V*| − 2 and the node *AP* has received exactly one packet. Continuing in this manner, at the end of (|*V*| − 1) superslots, all packets will have reached the final destination *AP*.

The maximum number of time slots in each frame is at most the product of the maximum number of slots in each superslot and the maximum number of superslots necessary for all packets to reach the destination *AP*, namely 3 (|*V*| − 1).

**Case 2** Because the interference graph of the tree network satisfies the ancestor property, the corresponding linear tree interference graph *CL* satisfies *IL* = ∅. It can therefore be colored optimally with three colors.

First assume that we select exactly one node to transmit from each level (of the original tree graph *G* = (*V*,*E*)) corresponding to the color of the slot. At the beginning of the frame, each node has one packet. In the first superslot, one packet is transmitted from each level to the next lower level. Except at the highest level, each level receives one packet. Therefore, one packet has moved one hop closer to the *AP* at each level, one packet from level one has reached *AP*, and nodes at the level of the *depth* of the tree may have no more packets.

At the end of the second superslot, the number of packets transmitted from one level to one lower level is again one except, possibly, for level *depth*. Each level less than *depth* − 1 has one packet to transmit, while nodes at levels *depth* or *depth* − 1 may have exhausted all packets. Continuing in this manner, by the end of *i*-th superslot, there are no more packets above some *threshold* level, and there is at least one packet at levels lower than this threshold. Since each level below the threshold is guaranteed to have a packet, and all levels with at least one packet can transmit once in each superslot, one packet reaches *AP* in each superslot. Therefore, the number of superslots required for all packets to reach *AP* is |*V*| − 1. Since there are three slots in each superslot, the maximum frame length is again 3(|*V*| − 1).

The scheduling algorithm allows a subset of non-conflicting nodes (instead of a single node) at each level to transmit so the resulting frame length will also be at most 3(|*V*| − 1).

**Case 3** The worst case is when there is an interfering edge between a node at level *j* and every node at level *i* with |*i* − *j*| ≤ *K*. The corresponding linear graph can be colored by *K* + 2 colors in that case. Assign color 1 to *v*_{1}. The color of the nodes {*v*_{2},…, *v*_{K+2}} cannot be 1. Assign the smallest color, 2, to node *v*_{2}. The color of {*v*_{3},…, *v*_{K+3}} cannot be 2. Assign the smallest color, 3, to *v*_{3}. Continuing in this way, *v*_{K+2} is assigned color *K* + 2. Node *v*_{K+3} is assigned color 1, since its color is restricted not to be 2,…, *K* + 2. Thus, the algorithm colors this network with *K* + 2 colors in a round robin fashion with color 1 assigned to *v*_{1}. The interference graph of any other network is a subgraph of this worst case.

The same reasoning as in Case 2 now indicates that at least one packet reaches *AP* in each superslot so the number of superslots needed is at most |*V*| − 1. Hence the frame length is at most (*K* + 2) (|*V*| − 1) time slots.

**Case 4** The number of superslots required for all packets to reach *AP* is the number of packets in the network, which is |*V*| − 1. The maximum number of slots in each superslot is the number of colors, α. The upper bound on the frame length is then α(|*V*| − 1). □

**Theorem 3**

*Assume that node*\(i {\,\in\,}V\)* has generated**g*_{i}* packets to transmit. For level-based scheduling algorithm, in cases 1 and 2 the maximum length of the frame is*\(3 \Sigma_{i \,\in\, V}{g_i}\)* time slots; in case 3 it is*\((K+2)\Sigma_{i \,\in\, V}{g_i};\)* and in case 4 it is*\(\alpha \Sigma_{i \,\in\, V}{g_i},\)* in which α is the number of colors used in the linear network corresponding to**G** and**C*.

*Proof*

The proof is similar to that of Theorem 2. The number of superslots required for all packets to reach *AP* is the number of packets in the network, which is \(\Sigma_{i \,\in\, V}{g_i}.\) The maximum number of slots in each superslot is the number of colors. □

**Theorem 4**

*Assume that node*\(i \,\in\, V\)* has generated**g*_{i}* packets to transmit. For node-based scheduling algorithm, the maximum length of the frame is*\(\alpha \Sigma_{i \,\in\, V}{g_i},\)* in which* α* is the number of colors used in the conflict graph**GC*.

*Proof*

The proof is similar to that of Theorem 2. In node-based scheduling, during each superslot, each node is given at least one chance to transmit.

Let us assume that another algorithm, namely node-level-based scheduling, schedules only one node containing at least one packet from each level of the routing tree *G* = (*V*,*E*) rooted at the AP and does not schedule any node if that level does not contain any packet. By the same reasoning as in the proof of Theorem 2, the number of superslots required for all packets to reach *AP* is the number of packets in the network, which is \(\Sigma_{i \,\in\, V}{g_i}.\)\(\Sigma_{i \,\in\, V}{g_i}\) is also the maximum number of superslots required for all packets to reach *AP* in node-based scheduling. The maximum number of slots in each superslot is the number of colors. The result follows. □

*Remark*

The chromatic number of a graph *GC* is at most 1 + *deg*_{max} [23], where *deg*_{max} is the maximum degree of the nodes in *GC*. The maximum length of the schedule in node-based and level-based scheduling algorithms is therefore \((1+deg_{max}) \Sigma_{i \,\in\, V}{g_i},\) in which *deg*_{max} is the maximum degree of the nodes in *GC* and *GCL* respectively. Since the minimum schedule length is \(\Sigma_{i \,\in\, V}{g_i}\) as shown in Lemma 1, the worst case ratio of the length of the frame to the optimal length is 1 + *deg*_{max}.

**Lemma 2**

*Assume that node*\(i \,\in\, V\)* has generated**g*_{i}* packets to transmit. For distributed scheduling algorithm, the maximum length of the frame is *\(\alpha \Sigma_{i \,\in\, V}{g_i},\)* in which α is the number of colors used in the conflict graph**GC*.

*Proof*

The proof is the same as that of Theorem 4. □

*Remark*

Node-based scheduling algorithm can be used for more general network topology whereas level-based scheduling algorithm has been especially developed for tree topologies. The upper bounds for more general topologies in node-based scheduling algorithms depends on the specific source-destination pairs and the number of packets to be transmitted between them.

## 8 Simulation

The goal of the simulations is to compare the delay performance of the centralized node-based and level-based scheduling algorithms, and the distributed algorithm.

In the simulations, 1000 nodes are randomly distributed in a circular area of radius 100 units. The density of the nodes is λ_{1} inside the radius \({\frac{100}{\sqrt{2}}}\) and λ_{2} between the radius \({\frac{100}{\sqrt{2}}}\) and 100 units. Each topology corresponds to a different configuration of the sensor nodes with respect to the base station: The locations of the sensor nodes depends on the locations that requires sensing by the application whereas the density of the nodes depends on the number of locations to be sensed in a certain area or the accuracy the application requires, i.e., the higher accuracy required, the higher the density of the nodes. The transmission range, denoted *r*_{s}, is chosen to be slightly larger than the threshold necessary for network connectivity [25].

The results discussed below are averages of the performance of ten different random configurations. Shortest path routing is used to construct the routing tree rooted at the AP, which corresponds to *G* = (*V*,*E*) in Sect. 2. The interferers of the nodes are determined according to the fixed power protocol interference model [12]: Each node has its own fixed transmission power and each node has an interference range *r*_{m} such that any node *v*_{j} will be interfered by the signal from *v*_{k} if the distance between them is less than *r*_{m} and node *v*_{k} is sending signal to some node other than node *v*_{j}. Therefore, *C* = (*V*,*I*) contain the nodes that are inside a larger range *r*_{m}, *r*_{m} ≥ *r*_{s}, of each node other than its parent and children in the routing tree *G*. In the coloring part of node and level-based scheduling algorithms, the nodes are ordered in non-increasing order of degree since high degree vertices have more color constraints and so are more likely to require an additional color if inserted late.

## 9 Conclusion

The common scheduling problem in multi-hop networks employing a TDMA MAC protocol is to determine the smallest length conflict-free assignment of slots where each link or node is activated at least once. This is based on the assumption that there are many independent point-to-point flows in the network. In sensor networks where data are often transferred from the sensor nodes to a few central data collectors, the problem is to determine the smallest length conflict-free assignment of slots during which the packets generated at each node reach their destination. This optimization problem is shown to be NP-complete.

We propose two centralized heuristic algorithms for solving the problem: node-based scheduling and level-based scheduling. In node-based scheduling, the schedule is obtained based on the coloring of the original network similar to classical multi-hop scheduling algorithms for general ad hoc networks. The nodes of the color corresponding to each slot with at least one packet are chosen first and additional nodes are added afterwards. In the novel proposed level-based scheduling on the other hand the original network is first transformed to a linear network where each node corresponds to a level in the original network. The schedule of the original network is then obtained based on the coloring of the linear network. This scheduling algorithm schedules a non-conflicting set of nodes corresponding to each level of the color for the current slot and then schedules additional nodes if possible. The movement of the packets across the network is much better balanced in level-based scheduling for topologies of higher density of the packets further away from the common sink whereas giving equal chance to the nodes in node-based scheduling performs better in topologies of equal density of the packets across the network or higher packet density at low levels.

We also propose a simple token based distributed algorithm to understand the performance of distributed algorithms compared to centralized ones. The distributed algorithm is based on a two-stage coloring algorithm at the end of which nodes assigned the same color form a maximal nonconflicting set. We observe that the delay in distributed algorithm increases by a factor of 10–70 over centralized algorithms for 1000 nodes although the number of colors used in coloring the network is almost the same. This suggests the basic disadvantage of distributed algorithms to be the scheduling of the nodes that do not have any packet, which prevents scheduling of other nodes as a result. This is hard to avoid in a distributed fashion since the global topology information is required to know whether the interfering nodes have any packets. Distributed scheduling algorithms that improve upon this token based algorithm in the context of sensor networks is an interesting research direction.

## Notes

### Open Access

This article is distributed under the terms of the Creative Commons Attribution Noncommercial License which permits any noncommercial use, distribution, and reproduction in any medium, provided the original author(s) and source are credited.

### References

- 1.Polastre, J., Szewczyk, R., Sharp, C., & Culler, D. (2004). The mote revolution: Low power wireless sensor network devices, hot chips 16:
*A symposium on high performance chips*, August.Google Scholar - 2.LAN-MAN Standards Committee of the IEEE Computer Society. (1997).
*Wireless LAN medium access control (MAC) and physical layer(PHY) specification*(1997 ed.). New York, NY, USA: IEEE, IEEE Std 802.11.Google Scholar - 3.Ergen, S. C., & Varaiya, P. (2007). PEDAMACS: Power efficient and delay aware medium access protocol for sensor networks.
*IEEE Transactions on Mobile Computing, 5*(7), 920–930.CrossRefGoogle Scholar - 4.Uysal-Biyikoglu, E., Prabhakar B., & El Gamal, A. (2002). Energy-efficient packet transmission over a wireless link.
*IEEE/ACM Transactions on Networking, 10*(12), 487–499.CrossRefGoogle Scholar - 5.Fattah, H., & Leung, C. (2002). An overview of scheduling algorithms in wireless multimedia networks.
*IEEE Wireless Communications, 9*(5), 76–83.CrossRefGoogle Scholar - 6.Ergen, S. C., & Varaiya, P. (2005). On multi-hop routing for energy efficiency.
*IEEE Communications Letters, 9*(10), 880–881.CrossRefGoogle Scholar - 7.Ramanathan, S., & Lloyd, E. L. (1993). Scheduling algorithms for multihop radio networks.
*IEEE/ACM Transactions on Networking, 1*(2), 166–177.CrossRefGoogle Scholar - 8.Ngo, C. Y., & Li, V. O. K. (2003). Centralized broadcast scheduling in packet radio networks via genetic-fix algorithms.
*IEEE Transactions on Communications, 51*(9), 1439–1441.CrossRefGoogle Scholar - 9.Chakraborty, G. (2004). Genetic algorithm to solve optimum TDMA transmission schedule in broadcast packet radio networks.
*IEEE Transactions on Communications, 52*(5), 765–777.CrossRefGoogle Scholar - 10.Gandham, S., Dawande M., & Prakash, R. (2005). Link scheduling in sensor networks: Distributed edge colering revisited.
*IEEE INFOCOM, 4*2492–2501.Google Scholar - 11.Wang, Y., & Henning, I. (2007). A deterministic distributed TDMA scheduling algorithm for wireless sensor networks.
*IEEE WiCom*, 2759–2762.Google Scholar - 12.Wang, W., Wang, Y., Li, X., Song, W., & Frieder, O. (2006). Efficient interference-aware TDMA link scheduling for static wireless networks.
*IEEE GLOBECOM*, 262–273.Google Scholar - 13.Ramaswami, R., & Parhi, K. K. (1989). Distributed scheduling of broadcasts in a radio network.
*INFOCOM, 2*, 497–504.Google Scholar - 14.Ephremides, A., & Truong, T. V. (1990). Scheduling broadcasts in multihop radio networks.
*IEEE Transactions on Communications, 38*(4), 456–460.CrossRefGoogle Scholar - 15.Tavli, B., & Heinzelman, W. B. (2004). MH-TRACE: Multihop time reservation using adaptive control for energy efficiency.
*IEEE Journal on Selected Areas in Communications, 22*(5), 942–953.CrossRefGoogle Scholar - 16.Wu, Z., & Raychaudhuri, D. (2004). D-LSMA: Distributed link scheduling multiple access protocol for QoS in Ad-hoc networks.
*IEEE GLOBECOM*, 1670–1675.Google Scholar - 17.Cheung, S. Y., Coleri, S., Dundar, B., Ganesh, S., Tan, C.W., & Varaiya, P. (2006). Traffic measurement and vehicle classification with a single magnetic sensor.
*Journal of Transportation Research Board, 1917*.Google Scholar - 18.Mao, J., Wu, Z., & Wu, X. (2007). A TDMA scheduling scheme for many-to-one communications in wireless sensor networks.
*Computer Communications, 30*(4), 863–872.CrossRefGoogle Scholar - 19.Choi, H., Wang, J., & Hughes, E. A. (2005). Scheduling on sensor hybrid networks.
*IEEE ICCCN*, 503–508.Google Scholar - 20.Gandham, S., Zhang, Y., & Huang, Q. (2008). Distributed time-optimal scheduling for convergecast in wireless sensor networks.
*Computer Networks, 52*(3), 610–629.MATHGoogle Scholar - 21.Bansal, S., Kumar, P., & Singh, K. (2003). An improved duplication strategy for scheduling precedence constrained graphs in multiprocessor systems.
*IEEE Transactions on Parallel and Distributed Systems, 14*(6), 533–544.CrossRefGoogle Scholar - 22.Narayanaswamy, S., Kawadia, V., Sreenivas, R. S., & Kumar, P. R. (2002). Power control in Ad-Hoc networks: Theory, architecture, algorithm and implementation of the COMPOW protocol.
*Proceedings of European wireless*, Italy, February.Google Scholar - 23.Hedetniemi, S. T., Jacobs, D.P., & Srimani, P. K. (2002). Fault tolerant distributed coloring algorithms that stabilize in linear time.
*International parallel and distributed processing symposium (IPDPS)*, April.Google Scholar - 24.Ahuja, R. K., Magnanti, T. L., & Orlin, J. B. (1993).
*Network flows*, Prentice Hall, Inc.Google Scholar - 25.Krishnamachari, B., Wicker, S. B., & Bejar, B. (2001). Phase transition phenomena in wireless Ad-Hoc networks.
*Symposium on Ad-Hoc wireless networks*, GlobeCom2001, San Antonio, Texas, November.Google Scholar