applied sciences Article
Intelligent Video Surveillance Platform for Wireless Multimedia Sensor Networks Nasim Abbas 1,2 1 2
*
ID
, Fengqi Yu 1,2, * and Yang Fan 1,2
Shenzhen Institutes of Advanced Technology, Chinese Academy of Sciences, Shenzhen 518055, China;
[email protected] (N.A.);
[email protected] (Y.F.) University of Chinese Academy of Sciences, Beijing 100049, China Correspondence:
[email protected]; Tel.: +86-755-8639-2172
Received: 18 January 2018; Accepted: 23 February 2018; Published: 28 February 2018
Abstract: Wireless multimedia sensor networks (WMSNs) are increasingly being deployed for surveillance and monitoring applications. WMSNs applications produce large amount of data, which require high transmission rates. An efficient and seamless delivery of multimedia services in WMSNs is still a challenging task. This article proposes an intelligent video surveillance platform (IVSP) for wireless multimedia sensor networks. IVSP presents the design of a networked system for joint rate control and error control of video over resource-constrained embedded devices. First, a combination of two different congestion indicators is introduced to differentiate between congestion levels and handle them accordingly. Second, a feedback-based rate controller is developed to maximize received video quality, in which sensor nodes can adaptively adjust their sending rates. Finally, a different retransmission mechanism for different packets is proposed. Lost packets can be stored temporarily and resend when free channel is available to avoid congestion. The core component of IVSP is an open source hardware platform, which is based on Raspberry Pi sensor nodes. IVSP is extensively evaluated on 7 Raspberry Pi sensor nodes. We present the results of 7-node real-world deployment of IVSP in a video surveillance application and show that it works well in long-term deployments. Keywords: wireless sensor networks; congestion control; error control; wireless video transmission; wireless multimedia sensor networks
1. Introduction Rapid development in micro electro-mechanical systems (MEMS), embedded computing, and wireless communication technologies has provided us with low-power, low-cost, and multifunctional sensor nodes. These sensor nodes can be organized to form a network called wireless sensor networks (WSNs) [1]. Each sensor node can be equipped with visual and audio information collection modules such as microphones and video cameras. This has encouraged the development of wireless multimedia sensor networks (WMSNs) [2]. WMSNs consist of a large number of embedded devices that are equipped with low power cameras. These camera nodes are able to retrieve multimedia content from the environment at variable rates and transmit the captured information through multi-hop communication to base station [3,4]. WMSNs have generated much interest in recent years, and it is predicted that WMSNs will become useful in our daily life [5–7]. WMSNs have been widely applied to healthcare [5], video-based environment surveillance [6], biometric tracking [7], and habitat monitoring [8]. Extensive studies have been carried out in recent years on the physical layer [9], the media access control layer [10,11], the network layer [12], and the transport layer [13,14] in WMSNs. Recently, there has been substantial research and extensive development in solving wireless multimedia sensor network challenges. There are several issues that must be addressed such as high packet loss rate, mobility, shared channel, limited bandwidth, high variable delays, and lack of fixed infrastructure in WMSNs [15,16]. However, the main issue of enabling real time video streaming in Appl. Sci. 2018, 8, 348; doi:10.3390/app8030348
www.mdpi.com/journal/applsci
Appl. Sci. 2018, 8, 348
2 of 14
multi-hop WMSNs of embedded devices is still open and largely unexplored. WMSNs produce a large amount of video data; therefore, the probability of congestion in WMSNs is more than that in low-speed wireless sensor networks. Congestion degrades the overall performance of the network and affects the reliability due to the packet loss. Therefore, wireless transmission for multimedia with guaranteed packet delivery in WMSNs is of substantial significance due to higher data rate requirements. This paper focuses on the most challenging case in which multimedia data can be transferred from a source node to sink node through multi-hop communication. We describe efforts that involve system design and implementation of an embedded platform based on raspberry pi (RPi) sensor nodes. In this paper, we discuss the design and implementation of IVSP deployed for surveillance applications, and our intention is to ensure the reliable delivery of video data from collections of sensors to a sink, while avoiding congestion collapse. This video monitoring data may need to be played back later on. Therefore, when transmission fails, data packets should not be simply discarded. To the best of our knowledge, video surveillance application has not been addressed in this context before. The major contributions of this article are summarized as follows: (1) We design a cost-effective and computationally intelligent wireless video sensor network platform over multi-hop WMSNs. Our platform consists of 7 WMSN nodes, and each node is built by a raspberry pi (RPi); (2) To get the precise measurement of congestion, we introduce a combination of two different congestion indicators to differentiate congestion levels and handle them correspondingly; (3) We present a method in which each source node maintains its data sending rate and periodically updates its data sending rate according to its parents’ congestion level. Each node has a unique IP address and can establish a routing path from itself to the sink through multi-hop communication; (4) We propose different retransmission mechanisms for different packets. Lost packets can be stored temporarily and retransmitted when congestion situation is improved; (5) The proposed platform is flexible, scalable, and suitable for wireless monitoring of buildings, open terrain, remote areas, etc. The remainder of this paper is organized as follows. Section 2 gives the related work. Section 3 discusses the description of WMSNs system. Section 4 briefly describes the design implementation. Section 5 provides an experimental environment that includes parameter selection, optimization, and performance evaluation. Section 6 concludes our work. 2. Related Work In recent years, there have been studies on congestion control, reliable transmission, and congestion mitigation in WMSNs [17–19], but few of them really consider timing of realistic hardware constraints. Transmission control protocol (TCP) provides famous rate control scheme [20,21]. TCP applies an additive increase and multiplicative decrease algorithm (AIMD). When the media rate approaches the bottleneck, the encoding rate also demonstrates sawtooth performance. The algorithm, which constantly generates sawtooth behavior, is not suitable for multimedia communication [22]. This rate variation in TCP results in poor video quality [23]. Numerous equation-based rate control schemes have also been investigated [24]. TCP friendly rate control (TFRC) is one of them [25]. TFRC is an equation-based congestion control algorithm, which uses throughput of TCP Reno. However, TFRC needs feedback on the basis of per-packet, which generates decrease or increase in the media rate (sawtooth) in very limited duration [26]. However, in WMSNs, priority should be given to delay sensitive data instead of delay tolerant flows. For these reasons, in this paper, we do not consider TCP fairness for our scheme. Existing work in congestion control can be divided into two sections. In the first section, we describe protocols with centralized congestion control scheme. In the centralized congestion control schemes, all the actions related to avoiding or controlling congestion are undertaken by the sink node.In a typical centralized congestion control scheme, the sink periodically collects data from the sensor node, detects the possibility of congestion, and accordingly sends messages to the involved sensor to overcome congestion. Rate-controlled reliable transport protocol (RCRT) is one example of a centralized congestion control scheme [27]. In RCRT, all functions including rate allocation, rate
Appl. Sci. 2018, 8, 348
3 of 14
adaptation, and congestion detection are applied at sink node. RCRT uses negative acknowledgement (NACK) based technique to implement end-to-end explicit loss recovery mechanism. However, RCRT has very slow convergence when the network has extremely unstable RTTs. Quasi-static centralized rate allocation for sensor networks (QCRA) is a centralized rate allocation scheme that assigns a fair and efficient rate to each node given the link loss rate information, topology, and routing tree information [28]. This scheme determines the traffic levels in the vicinity of a node by computing a TDMA schedule among all neighbors of that node. The node with the highest traffic level determines the fair rate allocation. They also derive rate adaptation parameter by observing the behavior of the network during an epoch. Event-to-sink reliable transport protocol (ESRT) distinguishes network into five sections [29]. Rate allocation is centrally determined in ESRT. In ESRT, sending rate is regulated in such a way that packets reach at a sink node without generating congestion. Due to disadvantages of centralized methods, transient congestion is difficult to manage in ESRT. Centralized congestion control routing protocol based on multi-metrics (CCRPM) [30] combines the residual energy of a node, buffer occupancy rate, wireless link quality, and the current number of sub-nodes for the candidate parent to reduce the probability of network congestion in the process of network construction. In addition, it adopts a centralized way of determining whether the sub-nodes of the congested node need to be switched based on the traffic analysis when network congestion occurs. In the second section, we describe protocols with distributed congestion control mechanism. Congestion detection and avoidance (CODA) uses congestion mitigation technique [31]. The source needs to maintain its data rate using feedback from sink for persistent congestion. For transient congestion, every sensor node observes buffer occupancy level and channel utilization to detect congestion. CODA proposes closed loop multi-source regulation technique and an open loop hop-by-hop backpressure strategy. Fusion uses prioritized MAC, hop-by-hop, and rate-limiting flow control methods to ease congestion [32]. Fusion has better fairness and higher goodput with heavy loads than previous techniques. Unlike CODA, Fusion explicitly focuses on per-source fairness. Our previous work, enhanced congestion detection and avoidance (ECODA), uses dual buffer-based congestion detection method [33]. ECODA discriminates route through traffic and locally generated traffic for the queue control. In ECODA, packets are dropped according to their priorities to control congestion. Both congestion control and fairness (CCF) [34] routing scheme and interference-aware fair control (IFRC) [35] protocols provide fairness. CCF presents two schemes to ensure fairness. One is epoch-based proportional selection and other is probabilistic selection. IFRC employs multi-level buffer threshold. When buffer occupancy goes beyond certain limit, IFRC reduces the sending rate and sustains its buffer occupancy at less than certain limit. Aghdam et al. [36] propose congestion control protocol for WMSNs (WCCP). WCCP uses Recipient Congestion Control Protocol (RCCP) at the intermediate nodes and the Source Congestion Avoidance Protocol (SCAP) at the source nodes. RCCP uses buffer length to detect congestion, while SCAP uses group of pictures (GOP) to avoid congestion. In addition, WCCP protects only I-frame data packets and discards less important data packets in congestion situation. Sergiou et al. [37] propose hierarchical tree alternative path scheme for WSNs (HTAP).Their work provides reliability and minimizes congestion by giving information to other nodes about congestion. When congestion is imminent, HTAP securely transmit the data by creating substitute routes from source to destination. HTAP algorithm consists of four major parts: Alternative Path Creation Algorithm, Flooding with Level Discovery Functionality, Alternative Path Creation Algorithm, The Hierarchical Tree Algorithm, and the Handling of Powerless (Dead Nodes). Siphon [38] provides congestion avoidance, congestion detection, and application fidelity by using virtual sinks (VSs) with multiple radios in the sensor network. VSs tunnel traffic events that show the signs of high traffic loads. Siphon employs a combination of end-to-end and hop-by-hop congestion control based on the location of congestion. In congestion situation, Siphon adopts the end-to-end congestion control approach between the virtual sinks and sink, and hop-by-hop method between source nodes and the virtual sinks. Gholipour et al. [39] propose a dynamic and distributed hop-by-hop congestion control scheme to control congestion by adjusting data rate of nodes. They use virtual gradient field
Appl. Sci. 2018, 8, 348
4 of 14
to provide a trade-off between possible shortest path and congested path. Sergiou et al. [40] propose a dynamic alternative path selection scheme for wireless sensor networks (DAlPaS). DAlPaS uses channel interference, node energy, and buffer occupancy to detect congestion. It dynamically routes the traffic and selects thePEER shortest path to avoid congestion. DAlPaS consists of two stages:4 ofhard stage Appl. Sci. 2018, 8, x FOR REVIEW 15 and soft stage. In the hard stage, the network protects the receiving node from congestion by forcing hop-by-hop congestion controlInscheme to control adjustingdata data from rate ofonly nodes. They the flows to change their paths. the soft stage, congestion each nodebyreceives one stream to use virtual gradient field to provide a trade-off between possible shortest path and congested path. avoid congestion. Brahma et al. [41] present a distributed congestion control algorithm that adaptively Sergiou et al. [40] propose a dynamic alternative path selection scheme for wireless sensor networks assigns (DAlPaS). a fair and DAlPaS efficient uses transmission rate to all nodes. node and controls its aggregate channel interference, node Each energy, andmonitors buffer occupancy to detect input and output Ittraffic rate. Aroutes nodethe decides increase or decrease the tobandwidth based on the congestion. dynamically traffic to and selects the shortest path avoid congestion. DAlPaS consists of two stages: hardtraffic stage and soft stage. In the hard stage, the network protects the difference between input and output rates. receiving node from congestion by forcing the flows was to change their paths. In the soft each The main idea of above mentioned researchers to classify the priority ofstage, the packets and node receives data from only one stream to avoid congestion. Brahma et al. [41] present a distributed guarantee the transmission of these packets by the resource assignment. However, they do not consider congestion control algorithm that adaptively assigns a fair and efficient transmission rate to all the packets with low priority which sometimes may be lost because of no protecting mechanism. nodes. Each node monitors and controls its aggregate input and output traffic rate. A node decides to increase or decrease the bandwidth based on the difference between input and output traffic rates. 3. Description of WMSNs System The main idea of above mentioned researchers was to classify the priority of the packets and guarantee the transmission of these packets by the resource assignment. However, they do not consider 3.1. Sensor Node Architecture the packets with low priority which sometimes may be lost because of no protecting mechanism.
A multimedia sensor node consists of many components including a sensing unit with a camera, 3. Description of WMSNs System a wireless communication unit, and a processing unit; the whole sensor should be powered by a power unit as shown in Figure 1. The processing unit is particularly essential to the sensor node. 3.1. Sensor Node Architecture The processing unit should have low power consumption, high speed calculation, and also should A multimedia sensor node consists of many components including a sensing unit with a be small. For these reasons, we use raspberry (RPi) (Raspberry Pi Foundation, Cambridge, camera, a wireless communication unit, and apiprocessing unit; the whole sensor should be powered United Kingdom) a processing unit in asFigure shown in Figure 2a.The pi 2essential modelto B the includes by aas power unit as shown 1. The processing unitRaspberry is particularly sensor 1GB node.of RAM The processing unit quad-core should haveARM low power consumption, speed calculation, and United also should and powerful 900 MHz Cortex-A7 (ARMhigh Holding, Cambridge, Kingdom) be small. For these reasons, we use raspberry pi (RPi) (Raspberry Pi Foundation, Cambridge, United CPU. It is based on broadcom BCM2835 system on a chip. It has HDMI socket, a SD slot card memory, Kingdom) as a processing unit as shown in Figure 2a.The Raspberry pi 2 model B includes 1GB of a couple of USB connectors, and anethernet connector. With these connections, raspberry pi is a decent RAM and powerful 900 MHz quad-core ARM Cortex-A7 (ARM Holding, Cambridge, United educational desktop useonraspbian system, is has based on socket, a debian Kingdom) CPU.PC. It isWe based broadcomoperating BCM2835 system on which a chip. It HDMI a SDdistribution. slot Raspbian operating (raspbian-wheezy, Pi Foundation, United Kingdom, card memory,system a couple of USB connectors,Raspberry and anethernet connector. Cambridge, With these connections, pi is a decent educational desktop PC. Weraspberry use raspbian system, is based 2015) israspberry a linux/GNU version (3.18) developed for pi operating hardware. Our which platform consists of on a pi debian distribution. Raspbian 7 raspberry model 2B sensor nodes. operating system (raspbian-wheezy, Raspberry Pi Foundation, Cambridge, United Kingdom, 2015) is a linux/GNU version (3.18) developed for raspberry pi The wireless communication unit has the responsibility of transmitting video data in WMSNs. hardware. Our platform consists of 7 raspberry pi model 2B sensor nodes. For wirelessThe communication, we use commercially available EDIMAX wi-fi dongle as shown in wireless communication unit has the responsibility of transmitting video data in WMSNs. Figure 2b. EDIMAX wi-fi dongle Edimax, Taipei, Taiwan) is attached to USB port For wireless communication, we(EW-7811Un, use commercially available EDIMAX wi-fi dongle as shown in of eachFigure raspberry pi board. The dongle has data rates up to 150 Mbps, complies 2b. EDIMAX wi-fi dongle (EW-7811Un, Edimax, Taipei, Taiwan) is attached to USB with port ofwireless each raspberry pi board. The dongle has data ratescontrol up to 150 Mbps, complies with wireless 802.11 802.11 b/g/n, and it supports smart transmit power and auto-idle adjustment. With low power b/g/n, and it supports smart transmit power control and auto-idle adjustment. With low power consumptions, these dongles are particularly suitable for fast prototyping for wireless multimedia consumptions, these dongles are particularly suitable for fast prototyping for wireless multimedia sensor network applications. sensor network applications.
Figure 1. Sensor node architecture.
Figure 1. Sensor node architecture.
Appl. Sci. 2018, 8, 348 Appl. Sci. 2018, 8, x FOR PEER REVIEW
5 of 14 5 of 15
Appl. Sci. 2018, 8, x FOR PEER REVIEW
5 of 15
(a) (a)
(b) (b)
Figure 2. (a) Raspberry Pi model 2B; (b) Edimax Wi-Fi dongle. Figure 2. (a) Raspberry Pi model 2B; (b) Edimax Wi-Fi dongle. Figure 2. (a) Raspberry Pi model 2B; (b) Edimax Wi-Fi dongle.
3.2. Network Architecture 3.2. Network Architecture 3.2. Network Architecture Our wireless multimedia sensor network system consists of number of WMSN nodes with a Our wireless multimedia sensor network system consists of N number of WMSN nodes with a Our wireless system consists number of WMSN with a single sink node, multimedia as shown insensor Figurenetwork 3. The sink is capable of of handling all the complexnodes calculations. single sink node, as shown in Figure 3. The sink is capable of handling all the complex calculations. All sensor nodes as areshown capable of creating and relaying video Allall sensor nodes are capable of single sink node, in Figure 3. The sink is capable of traffic. handling the complex calculations. All sensor nodes are capable of creating and relaying video traffic. All sensor nodes are capable All sensor nodes are capable of creating and relaying video traffic. are capableThe of retrieving multimedia contents and transmitting the captured videoAll to sensor the sinknodes via multi-hops. of retrieving multimedia contents and transmitting the captured video to the sink via multi-hops. retrieving multimedia contents and transmitting captured video to the sink via multi-hops. The topology of our networks is a linear topology. Inthe linear topology, each node (except leave and sink) The topology of our networks is a linear topology. In linear topology, each node (except leave and sink) topology of our is aone linear topology. In linear topology, node has exactly twonetworks neighbors: parent and one child node. Eacheach node gets(except packetsleave fromand its sink) child has exactly two neighbors: one parent and one child node. Each node gets packets from its child node has exactly two neighbors: one parent and one child node. the Each node gets The packets from its nodes child node and forwards these packets to its parent node to reach destination. intermediate and forwards these packets to its parent node to reach the destination. The intermediate nodes forward node andall forwards these packets its parent node to to reach the destination. The intermediate nodes forward the incoming packetstofrom their children its single parent to reach the sink node. The all the incoming packets from their children to its single parent to reach the sink node. The video forward all thegenerated incomingfrom packets their children toatitsthe single to multi-hops. reach the sink node. The video stream eachfrom sensor node arrives sinkparent through stream generated from each sensor node arrives at the sink through multi-hops. video stream generated from each sensor node arrives at the sink through multi-hops.
Figure 3. Network architecture. Figure 3. Network architecture. Figure 3. Network architecture.
4. Design Implementation 4. Design Implementation 4. Design Implementation 4.1. The Formation and Transmission of Video Packet 4.1. The Formation and Transmission of Video Packet 4.1. The Formation Transmission of Video Our aim is toand send video streams withPacket high frame rate and good quality. For these reasons, IVSP usesOur H.264 video compression. The server generates videoreasons, streamIVSP from aimstandard is to sendfor video streams with high frame rateapplication and good quality. Forathese Our aim is to send video streams with high frame rate and good quality. For these reasons, IVSP uses H.264 standard for video The server application generates a video stream from either live or stored source andcompression. converts video data in H.264 streams. According to H.264 standard, uses H.264 standard for video compression. The server application generates a video stream from either andWe converts in H.264 streams. According H.264 standard, there live are or I, Pstored and Bsource frames. do notvideo use Bdata frames in experiments, becausetothe decoding and either live or stored source and converts video data in H.264 streams. According to H.264 standard, there are I,ofPthese and frames B frames. We do not frames in In experiments, because andP encoding is dependent onuse the B next frame. our experiments, we the use decoding I frames and there are I, P and B frames. We do not use B frames in experiments, because the decoding and encoding encoding thesepriority frames isisdependent on the next than frame.P In our experiments, weause I frames and be P frames. I of frame always much higher frame. The length of packet should of these frames is dependent on the next frame. In our experiments, we use I frames and P frames. frames. frame is always muchthe higher than P frame. The length a packet be adjustedI in suchpriority a way that it can fulfill requirements of transmission. If aofpacket has should very small I frame priority is always much higher than P frame. The length of a packet should be adjusted in such adjusted that it can fulfillto thetransmit requirements of transmission. If a packet very small amount in ofsuch data,a way every node needs quickly. This will increase the has probability of a way that it can fulfill the requirements of transmission. If a packet has very small amount of data, congestion, energyevery waste, and needs more collisions in wireless If aincrease packet has amount of of amount of data, node to transmit quickly.channel. This will thelarge probability every node needs to transmit quickly. This will increase the probability of congestion, energy waste, congestion, waste, of and moreframes, collisions in wireless channel. If auntil packet has video large amount of data, whichenergy may consist many every packet has to wait all the frames are and more collisions in wireless channel. If a packet has large amount of data, which may consist of data, maycause consist of delay. many Therefore, frames, every packet has tomust waitbeuntil all in theappropriate video frames are made.which This will more length of packet chosen way. many frames, every packet has to wait until all the video frames are made. This will cause more delay. made.We This will cause more delay. Therefore, chosenthis in appropriate way. assume that maximum packet lengthlength is l. If of thepacket lengthmust goesbe beyond threshold, the video Therefore, length of packet must be chosen in appropriate way. that maximum length l. If the length the video dataWe willassume be divided into manypacket packets. The is packet will be I goes framebeyond packet,this if athreshold, packet contains the We assume that maximum packet length is l. If the length goes beyond this threshold, the video data divided into many packets. be IWe frame packet, if a packet contains theis data will of I be frame. Otherwise, packet will The be Ppacket frame will packet. know that wireless transmission data will be divided into many packets. The packet will be I frame packet, if a packet contains the data data of I frame. Otherwise, will befeature. P frame We knowloss thatwill wireless unreliable, so packet loss ispacket an obvious Anpacket. I frame packet resulttransmission in loss of allisP of I frame. Otherwise, packet will be P frame packet. We know that wireless transmission is unreliable, frame packets, because they willobvious not be decoded andpacket will beloss useless. If P frame packets unreliable, so packet loss is an feature. properly An I frame will result in loss of allare P so packet loss is an obvious feature. An I frame packet loss will result in loss of all P frame packets, frame packets, becausewill theycarry will not decoded properly and in willvideo be useless. If P lost, video decoding on be with some disturbances data. If I frame packets packets are are because they will not be decoded properly and will be useless. If P frame packets are lost, video lost, video decoding will carry with some disturbances in video data. I frame packets are retransmitted very quickly, theonconsequence of loss packets will not be Ifprominent. Therefore, decoding will carry on with some disturbances in video data. If I frame packets are retransmitted very retransmitted quickly, the consequence of loss packets will video not bedata. prominent. Therefore, retransmissionvery of I frame packets is very important for good quality retransmission of I frame packets is very important for good quality video data.
Appl. Sci. 2018, 8, 348
6 of 14
quickly, the consequence of loss packets will not be prominent. Therefore, retransmission of I frame packets is very important for good quality video data. Appl. Sci. 2018, 8, x FOR PEER REVIEW 6 of 15 4.2. Queue Scheduler 4.2. Queue Scheduler As we discussed in Section 4.1, different kinds of packets have different retransmission As we discussed in Section 4.1, different kinds of packets have different retransmission requirements. According to the degree of significance, packets can be divided into four priorities requirements. According to the degree of significance, packets can be divided into four priorities from high to low: The I frame packets have highest priority, P frame packets have high priority, from high to low: The I frame packets have highest priority, P frame packets have high priority, lost I lost I frame packets that need retransmission have low priority, and lost P frame packets that needs frame packets that need retransmission have low priority, and lost P frame packets that needs retransmission have lowest priority. Figure 4 shows the packet storage and transmission process at a retransmission have lowest priority. Figure 4 shows the packet storage and transmission process at a sensor node. When a node generates or receives a data packet, the packet is moved to the I-Frame sensor node. When a node generates or receives a data packet, the packet is moved to the I-Frame packet queue or P-Frame packet queue depending on its attribute. These two queues are used to packet queue or P-Frame packet queue depending on its attribute. These two queues are used to store the unconfirmed packets temporarily, waiting for the retransmission if needed. I frame packets store the unconfirmed packets temporarily, waiting for the retransmission if needed. I frame packets are of significant importance in supporting the real time traffic. Therefore, we give the maximum are of significant importance in supporting the real time traffic. Therefore, we give the maximum priority to I frame packets, because our main aim is to protect I frame packets. If I-frame packet is lost, priority to I frame packets, because our main aim is to protect I frame packets. If I-frame packet is it goes into lost I frame queue, and if a P frame packet is lost it goes into lost P frame queue. In our lost, it goes into lost I frame queue, and if a P frame packet is lost it goes into lost P frame queue. In experiments, in order to deal with traffic classes with different priorities in an efficient way, weighted our experiments, in order to deal with traffic classes with different priorities in an efficient way, round-robin scheduler is used [42]. In the weighted round-robin scheduler, we allocated a weight w , weighted round-robin scheduler is used [42]. In the weighted round-robin scheduler, we allocated a i i e{ I Frame, P Frame}, that is, it is assigned wi slots during each round. A traffic source with a higher weight , ε { , }, that is, it is assigned slots during each round. A traffic source weight receives more network bandwidth than a traffic source with less weight. with a higher weight receives more network bandwidth than a traffic source with less weight.
Figure 4. Queue schedular. Figure 4. Queue schedular.
4.3. Congestion Detection 4.3. Congestion Detection To measure congestion in wireless sensor networks, we present a combination of two different To measure congestion in wireless sensor networks, we present a combination of two different congestion indicators to accurately detect congestion at each sensor node. The first indicator is buffer congestion indicators to accurately detect congestion at each sensor node. The first indicator is buffer occupancy T, and second indicator is buffer occupancy change rate δ. The buffer occupancy is a very occupancy T, and second indicator is buffer occupancy change rate δ. The buffer occupancy is a important indicator of congestion. It is adopted to evaluate the amount of buffer occupied by the very important indicator of congestion. It is adopted to evaluate the amount of buffer occupied by packets at a node over its end-to-end transmission. The advantage of buffer occupancy is that the packets at a node over its end-to-end transmission. The advantage of buffer occupancy is that congestion at each node can be directly and quickly detected. Buffer occupancy T can be expressed congestion at each node can be directly and quickly detected. Buffer occupancy T can be expressed into three states: normal state, slow state, and urgent state as shown in Figure 5. To distinguish into three states: normal state, slow state, and urgent state as shown in Figure 5. To distinguish between different buffer states, we use two different thresholds and , as shown in Figure 5. between different buffer states, we use two different thresholds T1 and T2 , as shown in Figure 5. Buffer occupancy change rate δ is used to detect the network congestion and can be defined as: Buffer occupancy change rate δ is used to detect the network congestion and can be defined as: − (1) = , ϵ{ , } T−c − TiL δi = i , i e I f rame, P f rame (1) { } Tmax − Tic { } and , ϵ , show the buffer occupancy in current and last round, in which respectively. From above equation, we can get the buffer occupancy change rate δ =
∑
× ∑
,
ϵ{
,
}
(2)
4.3.2. Slow State The sensor node is in slow state when its buffer occupancy is within [T1, T2].During this state, the traffic around the node is close to congestion. Large amount of data are injected into the buffer, so the buffer occupancy will increase rapidly until exceeds ρ. The node transfers to slow state, which indicates Appl. Sci. 2018, 8, 348 that it may have congestion soon, and then activates the rate adjustment algorithm,7 of 14 which will be described later. c L 4.3.3. T Urgent State in which i and Ti , i e { I Frame, P Frame } show the buffer occupancy in current and last round, respectively. From above equation, we can get sensor the buffer occupancy change ratestate δ have a loss In this state, congestion happensatthe node. The packets in this
probability. The buffer occupancyis fluctuating between regardless of value of . At this , wi × δshould ∑i node i state, the children of the sensor slow down their δ= , i e{ I f rame, P f rame} sending rates to transmita i wi Usually only high priority packets are buffered, because smalleramount of data to the sensor ∑ node. their father’squeue utilization is too high.
(2)
Figure5.5.Buffer Bufferstates states for Figure for congestion congestiondetection. detection.
4.4. Distributed Source Sending Rate Control
All priority queues have the same buffer size Tmax . The buffer occupancy change rate δ reflects The rate controloccupancy. increases the video quality of several videos sent through thevalue network. the tendency of buffer For a given buffer occupancy, the larger the of δ,Source the higher nodes should control their rates to reduce the packets loss due to buffer overflow. To avoid buffer the probability of queue overflow is. Similarly, a negative δ shows that congestion has been alleviated overflow, sensor nodes should reduce their sending rate if buffer increases to stage that network and buffer occupancy is reduced. According to these two congestion indicators, the sensor nodes have cannot maintain. We present a method in which each source node maintains its data sending rate a total of periodically three states.updates its data sending rate according to its neighbor’s congestion level. Each and node has a unique IP address and can establish a routing path from itself to the sink through multi-hop communication. In thethe beginning, sink node broadcasts theWhen assigned maximum transmission of immediately its child Initially, buffer ofthe a sensor node is empty. a packet arrives, a sensorrate node through feedback mechanism. Then, the sink’s child broadcasts and calculates the maximum switches to normal state. The buffer occupancy during this state is within [0, T1 ] and buffer occupancy transmission rate to its child again. After a while, every node will have a maximum transmission change rate is also less than $. $ is predefined limit of δ. All packets are delivered successfully; rate. The goal of this feedback mechanism is to maximize the quality of the played streams. The therefore, queue utilization is low. feedback process analyses the occupancy at each node and sends feedback information to the sender node. The sender node gets the feedback information, analyses it, and makes required adjustments 4.3.2. Slow State to its transmitted streams. The idea is to modify the quantity of transmitted data according to the feedback information: when thestate network appears to be heavily loaded, quantity data state, The sensor node is in slow when its buffer occupancy is the within [T1 ,ofT2transmitted ].During this is reduced; when network appears to be lightlyLarge loaded, the quantity of are transmitted the traffic around thethe node is close to congestion. amount of data injecteddata intocan thebe buffer, increased again. In this way, the source sending rate can be adjusted more efficiently and accurately. so the buffer occupancy will increase rapidly until δ exceeds ρ. The node transfers to slow state,
4.3.1. Normal State
which indicates that it may have congestion soon, and then activates the rate adjustment algorithm, which will be described later. 4.3.3. Urgent State In this state, congestion happensatthe sensor node. The packets in this state have a loss probability. The buffer occupancyis fluctuating between [ T2 , Tmax ] regardless of value of δ. At this state, the children of the sensor node should slow down their sending rates to transmita smalleramount of data to the sensor node. Usually only high priority packets are buffered, because their father’squeue utilization is too high. 4.4. Distributed Source Sending Rate Control The rate control increases the video quality of several videos sent through the network. Source nodes should control their rates to reduce the packets loss due to buffer overflow. To avoid buffer overflow, sensor nodes should reduce their sending rate if buffer increases to stage that network cannot maintain. We present a method in which each source node maintains its data sending rate and periodically updates its data sending rate according to its neighbor’s congestion level. Each node has a unique IP address and can establish a routing path from itself to the sink through multi-hop communication. In the beginning, the sink node broadcasts the assigned maximum transmission rate of its child through feedback mechanism. Then, the sink’s child broadcasts and calculates the maximum transmission rate to its child again. After a while, every node will have a maximum transmission rate. The goal of this feedback mechanism is to maximize the quality of the played streams. The feedback
Appl. Sci. 2018, 8, 348
8 of 14
process analyses the occupancy at each node and sends feedback information to the sender node. The sender node gets the feedback information, analyses it, and makes required adjustments to its transmitted streams. The idea is to modify the quantity of transmitted data according to the feedback information: when the network appears to be heavily loaded, the quantity of transmitted data is reduced; when the network appears to be lightly loaded, the quantity of transmitted data can be Appl. Sci. 2018, 8, x FOR PEERway, REVIEW 8 of 15 increased again. In this the source sending rate can be adjusted more efficiently and accurately. We use β to denote the falling speed of the sending rate at each time when a state turns to its We useone.toTherefore, denote the falling speed sending at each time when a state to its next slower the sending rateofatthe node n canrate be expressed as (3), where Sn turns represents next slower one. Therefore, the sending rate at node cansending be expressed (3), where represents minimum sending rate of node, and S N represents normal rate ofasstate. minimum sending rate of node, and represents normal sending rate of state. Sn ==βS N
(3) (3)
The normal normal sending sending rate, rate, minimum minimum sending sending rate, rate, and and β can can be be obtained obtained from from the the experiments. experiments. The 4.5. Traffic Traffic Control Control Protocol Protocol Figure 6 shows the retransmission mechanism of IVSP. The traffic control is different for both I and P frame frame packet packet transmission. transmission. If parent node receives any packet, packet, it it sends sends an an acknowledgement acknowledgement (ACK) (ACK) to to tell tell its its child child node node and and transmission transmission of of that that particular particular packet packet is is completed. completed. If parent parent node node does not receive packet, packet, it it returns returns sequence sequence number number of of lost lost packet packet to to the the child child node. node. The child child node retransmits the lost packet again. The The child child node node must must guarantee guarantee to to receive receive these these return packets. Each packet packet needs to be confirmed confirmed by by both the child node and the parent node in order to protect the loss of packet in an efficient manner. manner. If child node is not able to receive any confirmed packet, it will send send a timeout message message to to its parent. parent. The parent node will send the return return packet packet again. again. If the parent node successfully packet, thethe packet is immediately removed from the child successfullyreceives receivesthe the packet, packet is immediately removed from the node childqueue. node If the parent still cannot receive the requested packets after calling for retransmission for several times, queue. If the parent still cannot receive the requested packets after calling for retransmission for it thinkstimes, that the packetsthat are the lostpackets at its son and notson recall these anymore. The lost packets several it thinks are lostwill at its and willpackets not recall these packets anymore. will transferred to lost I frame queue P frame queue, packets willand be retransmitted The be lost packets will be transferred to or lostlost I frame queue or and lost these P frame queue, these packets during state. during normal state. will be normal retransmitted
Figure 6. Retransmission mechanism. Figure 6. Retransmission mechanism.
The differences between the lost I frame queue and the lost P frame queue are retransmission The between lost I frame queue lost Ppacket frame has queue retransmission time anddifferences packet priority. Thethe retransmission of theand lostthe I-frame loware priority, and the time and packet The retransmission the lost I-frame packet has low priority, the retransmission ofpriority. the lost P-frame packet has theoflowest priority. The retransmission of theseand packets retransmission of the lost P-frame packet has the lowest priority. The retransmission of these packets should be arranged when link is not busy to avoid congestion. When sink node gets out of order should link is not to avoid congestion. sink number. node gets of order packets,be it arranged adjusts thewhen packet order of busy packets according to packetWhen sequence If out parent node packets, it adjusts the packet order of packets according to packet sequence number. If parent has lost few packets, the parent node sends their sequence number. If these packets are found, node these has lost few the parentwhen nodecongestion sends theirissequence number. If these found, packets will packets, be retransmitted alleviated. If parent nodepackets cannotare receive thethese lost packets after few attempts, it will not recall the lost packets. Retransmission probability of I frame and P frame packets is an important parameter in IVSP. If retransmission probability is very small, there is not enough of a chance to retransmit the lost packets. Therefore, packet loss rate will be much higher. If I frame packet is lost in transmission, all P frame packets after it cannot be decoded correctly and will be useless. Therefore, we give more retransmission probability to lost I frame packets and less retransmission probability to P frame
Appl. Sci. 2018, 8, 348
9 of 14
packets will be retransmitted when congestion is alleviated. If parent node cannot receive the lost packets after few attempts, it will not recall the lost packets. Retransmission probability of I frame and P frame packets is an important parameter in IVSP. If retransmission probability is very small, there is not enough of a chance to retransmit the lost packets. Therefore, packet loss rate will be much higher. If I frame packet is lost in transmission, all P frame packets after it cannot be decoded correctly and will be useless. Therefore, we give more retransmission probability to lost I frame packets and less retransmission probability to P frame packets. However, Appl. Sci. 2018, 8, x FOR PEER REVIEW 9 of 15 too many retransmissions can increase delay, which is not desirable in wireless multimedia sensor networks.chosen Therefore, the appropriate retransmission probability be carefully chosen to meet carefully to meet the retransmission requirements so thatshould the impact of retransmissions on the retransmission requirements so that the impact of retransmissions on normal network traffic can normal network traffic can be minimized. be minimized.
5. Experimental Results 5. Experimental Results We have deployed our platform at Shenzhen Institutes of Advanced Technology, Chinese We have deployed our platform at Shenzhen Institutes of Advanced Technology, Chinese Academy of Sciences for development and testing purposes. The algorithms are implemented in C. Academy of Sciences for development and testing purposes. The algorithms are implemented in We must emphasize that every experiment reported in this paper is based on actual implementation C. We must emphasize that every experiment reported in this paper is based on actual implementation running on a real test-bed. Experimental setup consists of 7 raspberry pi sensor nodes. All running on a real test-bed. Experimental setup consists of 7 raspberry pi sensor nodes. All multimedia multimedia data can be transferred from a source node to sink node through multi-hop data can be transferred from a source node to sink node through multi-hop communication. In each communication. In each raspberry pi, we stored a stream of pre-recorded video that was recorded in raspberry pi, we stored a stream of pre-recorded video that was recorded in cubicle environment. cubicle environment. Figure 7 shows the network topology analyzed in this paper. All the nodes are statically deployed Figure 7 shows the network topology analyzed in this paper. All the nodes are statically in the deployment area. Node 7 is connected to the PC computer, in which the collected data of each deployed in the deployment area. Node 7 is connected to the PC computer, in which the collected node are visualized. Since the distance between nodes is short, we assign each node an IP address. data of each node are visualized. Since the distance between nodes is short, we assign each node an We establish the network using IP address. For example, we write the destination address of node 1 IP address. We establish the network using IP address. For example, we write the destination as IP address of node 2, the destination address of node 2 as IP address of node 3, and so on. In the address of node 1 as IP address of node 2, the destination address of node 2 as IP address of node 3, experiments, the following metrics are compared: buffer occupancy, I-frame packet loss, and P-frame and so on. In the experiments, the following metrics are compared: buffer occupancy, I-frame packet packet loss. The parameters used in our experiments are shown in Table 1. The following three schemes loss, and P-frame packet loss. The parameters used in our experiments are shown in Table 1. The are implemented: following three schemes are implemented: (1) IVSP: It is the scheme proposed in this paper. (1) IVSP: It is the scheme proposed in this paper. (2) ECODA [33]: Enhanced congestion detection and avoidance for multiple class of traffic in (2) ECODA [33]: Enhanced congestion detection and avoidance for multiple class of traffic in sensor networks sensor networks (3) No congestion control: This is the baseline and no congestion control scheme is used. In this (3) No congestion control: This is the baseline and no congestion control scheme is used. In this scheme, packets are dropped by congested sensors, and no further action is taken. We call this scheme, packets are dropped by congested sensors, and no further action is taken. We call this scheme as NoIVSP. scheme as NoIVSP.
Figure 7. Routing topology used in IVSP. Figure 7. Routing topology used in IVSP. Table 1. Parameters Table 1. Parameters used used in in our our experiments. experiments.
Parameter Parameter Number of video sensor nodes Number of video sensor nodes Number of sink nodes Number of sink nodes Frames per second (fps) Frames per second (fps) Number of retransmissions I frame packets Number of retransmissions for I framefor packets Number of retransmissions P frame packets Number of retransmissions for P framefor packets
Value Value 7 71 1 15 15 33 11
Figure presentsthe the status of the buffer occupancy at different dataforrates for the Figure NoIVSP. Figure 88presents status of the buffer occupancy at different data rates the NoIVSP. 8a Figure 8a shows that just node 7 gets congested and remaining nodes do not experience any shows that just node 7 gets congested and remaining nodes do not experience any congestion at data congestion at data rate of 0.1 Mbps. Increment in the data rate at up to 0.5 Mbps involves two other nodes in congestion, which can be seen in Figure 8b. However, nodes 1 to 4 do not experience any congestion so far. Similarly, Figure 8c shows that node 4 gets congested by further increase in the data rate. Results in Figure 8d indicate that at the data rate of 2 Mbps, congestion happens at every node except node 1; it does not suffer any congestion, because data is only generated at node 1 and it
Appl. Sci. 2018, 8, 348
10 of 14
rate of 0.1 Mbps. Increment in the data rate at up to 0.5 Mbps involves two other nodes in congestion, which can be seen in Figure 8b. However, nodes 1 to 4 do not experience any congestion so far. Similarly, Figure 8c shows that node 4 gets congested by further increase in the data rate. Results in Figure 8d indicate that at the data rate of 2 Mbps, congestion happens at every node except node 1; it does not suffer any congestion, because data is only generated at node 1 and it does not relay any traffic. Therefore, probability of congestion is very minimal at node 1. Figure 9a,b represents the progress made with IVSP. In Figure 9a,b, the y-axis is buffer occupancy, and the x-axis is time in minutes. We can observe that IVSP efficiently adopts the buffer occupancy of sensor nodes according to network condition. Therefore, IVSP achieves superior congestion-free rate. The buffer occupancy over-shoots first and then falls down. The reason is that the network was not congestedwhen sensor nodes started sending the packets at the beginning. Figure 8 shows that in the case of NoIVSP, the buffer begins to overflow immediately, because it has no congestion control mechanism. Whereas, whenever IVSP determines the network is congested, it applies the rate decrease Appl. Sci. 2018, 8, x FORcomputes PEER REVIEWa new rate allocation, and sends the new rate to its child 10 ofnode. 15 step we have described,
(a)
(b)
(c)
(d)
Figure 8.Buffer occupancy with NoIVSP for different data rates: (a) 0.1 Mbps; (b) 0.5 Mbps; (c) 1
Figure 8.Mbps; Buffer occupancy and (d) 2 Mbps.with NoIVSP for different data rates: (a) 0.1 Mbps; (b) 0.5 Mbps; (c) 1 Mbps; and (d) 2 Mbps. Figure 9a,b represents the progress made with IVSP. In Figure 9a,b, the y-axis is buffer occupancy, and the x-axis is time in minutes. We can observe that IVSP efficiently adopts the buffer Figure 9a,b also represents the variation of β at different values. When β is small, we have less occupancy of sensor nodes according to network condition. Therefore, IVSP achieves superior incoming data, whichrate. shows that congestion probability reduced. bufferisoccupancy congestion-free The buffer occupancy over-shoots firstisand then fallsTherefore, down. The reason that shuffles the between normal state, slow state, and urgent state. Whereas, when β is incoming network was not congestedwhen sensor nodes started sending the packets at the large, beginning. Figure very 8 shows thatwhich in the case of NoIVSP, the buffer begins to overflowofimmediately, it has buffer data becomes high, shows that there is more probability congestion.because Therefore, no congestion control mechanism. Whereas, whenever IVSP determines the network congested, it occupancy continuously fluctuates between slow and urgent state. Therefore, β is should be carefully applies the rate decrease step we have described, computes a new rate allocation, and sends the new chosen. From Figure 9a, for small β, we can observe that buffer occupancy comes to the normal state rate to its child node. and then goes back to the urgent state. Whereas in Figure 9b, for large β, buffer occupancy does not go Figure 9a,b also represents the variation of β at different values. When β is small, we have less to the normal state at all andshows continuously fluctuates between urgent Therefore, and normal state. incoming data, which that congestion probability is reduced. buffer occupancy shuffles between normal state, slow state, and urgent state. Whereas, when β is large, incoming data becomes very high, which shows that there is more probability of congestion. Therefore, buffer occupancy continuously fluctuates between slow and urgent state. Therefore, β should be carefully chosen. From Figure 9a, for small β, we can observe that buffer occupancy comes to the normal state and then goes back to the urgent state. Whereas in Figure 9b, for large β, buffer occupancy does not go to the normal state at all and continuously fluctuates between urgent and normal state.
Appl. Sci. 2018, 8, 348
11 of 14
Appl. Sci. 2018, 8, x FOR PEER REVIEW
11 of 15
(a)
(b) Figure 9. (a) Buffer occupancy with IVSP when β = 0.25; (b) buffer occupancy with IVSP when β = 0.5.
Figure 9. (a) Buffer occupancy with IVSP when β = 0.25; (b) buffer occupancy with IVSP when β = 0.5. Figure 10 shows the packet delivery ratio of I frame packets with respect to time. The x-axis shows the time and y-axis represents packet delivery ratio. The objective of our protocol is to protect priority; therefore,ratio IVSP has mechanisms to protect Frame packets. If I The x-axis Figure the 10 packets showswith thehigh packet delivery of more I frame packets with Irespect to time. frameand packet is lostrepresents in transmission, all P frame packetsratio. after it The cannot be decodedof correctly and will is to protect shows the time y-axis packet delivery objective our protocol be useless. Since there is no retransmission mechanism for lost packets in ECODA and NoIVSP, the the packets with priority; has and more mechanisms to than protect Frame packets. If I packet high delivery ratio of I therefore, frame packetsIVSP in NoIVSP ECODA is much lower IVSP.I ECODA some packets with dynamic priority in severe IVSPcorrectly saves frame packetprotocol is lostdrops in transmission, allhigh P frame packets after it congestion, cannot bewhereas decoded and will high priority in congestion situation and retransmits priority whenand free NoIVSP, the be useless. Since therepackets is no retransmission mechanism forthose losthigh packets inpackets ECODA channel is available. Figure 10 shows that I frame packets have 98.7%, 93.5% and 69.2% packet packet delivery ratio offor I frame packets NoIVSP and ECODA is much lower than IVSP. ECODA delivery ratio IVSP, ECODA andinNoIVSP, respectively, when time approaches 2 min. Less I-frame packet loss in IVSP means the video will not be in interrupted video quality in IVSP IVSP saves protocol drops some packets with highthat dynamic priority severe and congestion, whereas be muchin superior to NoIVSP and ECODA. high prioritywill packets congestion situation and retransmits those high priority packets when free
channel is available. Figure 10 shows that I frame packets have 98.7%, 93.5% and 69.2% packet delivery ratio for IVSP, ECODA and NoIVSP, respectively, when time approaches 2 min. Less I-frame packet loss in IVSP means that the video will not be interrupted and video quality in IVSP will be much superior to NoIVSP and ECODA.
Packet delivery ratio(%)
Appl. Sci. 2018, 8, x FOR PEER REVIEW
12 of 15
120 100 80 60
IVSP
40
ECODA
20
NoIVSP
0 2
4
6
8
10
Time (minutes) Figure 10. Packet Delivery ratio of I Frame packets.
Figure 10. Packet Delivery ratio of I Frame packets. Figure 11 represents the packet delivery ratio of P frame packets with respect to time. Similar to I frame packets, lost P-frame packet retransmission in IVSP should be arranged when the link is not busy to avoid congestion. ECODA drops P frame packets in congestion situations to save I frame packets. Therefore, P frame packet loss in ECODA and NoCC is much higher than P frame packet loss in IVSP. Figure 11 shows that P frame packets has 95.8%, 87.5%, and 65.3% packet delivery ratio for IVSP, ECODA, and NoIVSP, respectively, when time approaches to 2 min. Again, NoIVSP has the highest number of lost P-frames. IVSP shows lower number of lost P-frames in comparison with NoIVSP and ECODA.
Packet deliv
40
ECODA
20
NoIVSP
0 2
4
Appl. Sci. 2018, 8, 348
6
8
10 12 of 14
Time (minutes) Figure 10. Packet Delivery ratio of I Frame packets.
Packet delivery ratio(%)
Figure 11 represents the packet delivery ratio of P frame packets with respect to time. Similar to I frame Figure packets, lost P-frame packetdelivery retransmission in IVSP should arranged when thetolink is 11 represents the packet ratio of P frame packets withbe respect to time. Similar I frame packets, lost P-frame packet retransmission inpackets IVSP should be arrangedsituations when the link is not not busy to avoid congestion. ECODA drops P frame in congestion to save I frame busy to avoid congestion. ECODAloss drops P frame packets in congestion to save I framepacket packets. Therefore, P frame packet in ECODA and NoCC is muchsituations higher than P frame Therefore, P framethat packet loss inpackets ECODAhas and95.8%, NoCC 87.5%, is muchand higher thanpacket P frame packet ratio loss inpackets. IVSP. Figure 11 shows P frame 65.3% delivery loss in IVSP. Figure 11 shows that P frame packets has 95.8%, 87.5%, and 65.3% packet delivery ratio for IVSP, ECODA, and NoIVSP, respectively, when time approaches to 2 min. Again, NoIVSP has for IVSP, ECODA, and NoIVSP, respectively, when time approaches to 2 min. Again, NoIVSP has the highest number of lost P-frames. IVSP shows lower number of lost P-frames in comparison with the highest number of lost P-frames. IVSP shows lower number of lost P-frames in comparison with NoIVSP and ECODA. NoIVSP and ECODA. 120 100 80 60
IVSP
40
ECODA
20
NoIVSP
0 2
4
6
8
10
Time (minutes) Figure 11. Packet Delivery ratio of P Frame packets.
Figure 11. Packet Delivery ratio of P Frame packets. 6. Conclusions
6. Conclusions
Providing reliable data transmission over WMSNs is a challenging open issue due to the
inherent features thesetransmission kinds of networks. The proposal is motivated by the issue unreliability data Providing reliableofdata over WMSNs is a challenging open due to of the inherent transmission over WMSNs. In this paper, to resolve high packet loss rate in WMSNs, an intelligent features of these kinds of networks. The proposal is motivated by the unreliability of data transmission video surveillance platform for wireless multimedia sensor networks (IVSP) is proposed. We classify over WMSNs. In this paper, to resolve high packet loss rate in WMSNs, an intelligent video surveillance the traffic into two classes and correspondingly maintain priority queues in each sensor nodes. To platform for wireless multimedia sensor networks (IVSP) is proposed. We classify the traffic into predict the congestion more accurately, we detect congestion by combining buffer length and its two classes correspondingly priority queues in each sensor IP nodes. predict change and rate together. We adopt maintain a procedure in which every node has unique addressTo and can the congestion more accurately, we detect congestion by combining buffer length and its change establish a route from itself to sink through multi-hop communication. Our rate control mechanism rate analyses occupancy at each node and sends feedback theaddress sender node. together. We the adopt a procedure in which every node information has uniquetoIP and The cansender establish a feedback information, analyses it, and makesOur anyrate required adjustments to analyses its route node from gets itselfthe to sink through multi-hop communication. control mechanism transmittedatstreams. We propose the different retransmission mechanisms for different packets. The node the occupancy each node and sends feedback information to the sender node. The sender packets with lower priority can be retransmitted when the link is not busy to avoid congestion. We gets the feedback information, analyses it, and makes any required adjustments to its transmitted analyze the performance of proposed IVSP and show that IVSP outperforms ECODA and NoIVSP streams. We propose the different retransmission mechanisms for different packets. The packets with in terms of packet delivery ratio. lower priority can be retransmitted when the link is not busy to avoid congestion. We analyze the performance of proposed IVSP and show that IVSP outperforms ECODA and NoIVSP in terms of packet delivery ratio.
Acknowledgments: This work was supported in part by National key R&D plan (Grant number 2016YFC0105002 and 61674162), Shenzhen Key Lab for RF Integrated Circuits, Shenzhen Shared Technology Service Center for Internet of Things, Guangdong government funds (Grant numbers 2013S046 and 2015B010104005), Shenzhen government funds (Grant numbers JCYJ20160331192843950), and Shenzhen Peacock Plan. Author Contributions: Nasim Abbas and Fengqi Yu contributed to the main idea of this paper; Nasim Abbas and Yang fan performed the experiments; Nasim Abbas and Yang fan analyzed the data; Nasim Abbas wrote the paper; Fengqi Yu provided the funding. Conflicts of Interest: The authors declare no conflict of interest.
References 1.
Horneber, J.; Hergenröder, A. A Survey on Testbeds and Experimentation Environments for Wireless Sensor Networks. IEEE Commun. Surv. Tutor. 2014, 16, 1820–1838. [CrossRef]
Appl. Sci. 2018, 8, 348
2. 3. 4.
5. 6. 7.
8. 9.
10. 11. 12. 13. 14. 15. 16. 17. 18. 19.
20. 21.
22.
23. 24.
13 of 14
Gandino, F.; Celozzi, C.; Rebaudengo, M. A Key Management Scheme for Mobile Wireless Sensor Networks. Appl. Sci. 2017, 7, 490. [CrossRef] Li, N.; Martínez-Ortega, J.-F.; Diaz, V.H.; MenesesChaus, J.M. Probability of Interference-Optimal and Energy-Efficient Analysis for Topology Control in Wireless Sensor Networks. Appl. Sci. 2016, 6, 396. [CrossRef] Garcia-Sanchez, A.-J.; Losilla, F.; Rodenas-Herraiz, D.; Cruz-Martinez, F.; Garcia-Sanchez, F. On the Feasibility of Wireless Multimedia Sensor Networks over IEEE 802.15.5 Mesh Topologies. Sensors 2016, 16, 643. [CrossRef] [PubMed] EI Kader, M.E.E.D.A.; Youssif, A.A.A.; Ghalwash, A.Z. Energy Aware and Adaptive Cross-Layer Scheme for Video Transmission over Wireless Sensor Networks. IEEE Sens. J. 2016, 16, 7792–7802. [CrossRef] He, D.; Kumar, N.; Chen, J.; Lee, C.C.; Chilamkurti, N.; Yeo, S.S. Robust anonymous authentication protocol for health-care applications using wireless medical sensor networks. Multimedia Syst. 2015, 21, 49–60. [CrossRef] Burchett, J.; Shankar, M.; Hamza, A.B.; Guenther, B.D.; Pitsianis, N.; Brady, D.J. Lightweight biometric detection system for human classification using pyroelectric infrared detectors. Appl. Opt. 2006, 45, 3031–3037. [CrossRef] [PubMed] Fu, P.; Cheng, Y.; Tang, H.; Li, B.; Pei, J.; Yuan, X. An Effective and Robust Decentralized Target Tracking Scheme in Wireless Camera Sensor Networks. Sensors 2017, 17, 639. [CrossRef] [PubMed] Niewiadomska-Szynkiewicz, E.; Sikora, A.; Marks, M. A Movement-Assisted Deployment of Collaborating Autonomous Sensors for Indoor and Outdoor Environment Monitoring. Sensors 2016, 16, 1497. [CrossRef] [PubMed] Navrati, S.; Abhishek, R.; Jitae, S. Dynamic duty cycle and adaptive contention window based QoS-MAC protocol for wireless multimedia sensor networks. Comput. Netw. 2008, 52, 2532–2542. Kim, T.; Kim, I.H.; Sun, Y.; Jin, Z. Physical layer and medium access control design in energy efficient sensor networks: An overview. IEEE Trans. Ind. Inform. 2015, 11, 2–15. [CrossRef] Poor, H.V. Information and inference in the wireless physical layer. IEEE Wirel. Commun. 2012, 19, 40–47. [CrossRef] Oh, H.; Bahn, H.; Chae, K. An Energy-Efficient Sensor Routing Scheme for Home Automation Networks. IEEE Trans. Consum. Electr. 2005, 51, 836–839. Alanazi, A.; Elleithy, K. Real-Time QoS Routing Protocols in Wireless Multimedia Sensor Networks: Study and Analysis. Sensors 2015, 15, 22209–22233. [CrossRef] [PubMed] Sundaresan, K.; Anantharaman, V.; Hsieh, H.; Sivakumar, R. ATP: A Reliable Transport Protocol. IEEE Trans. Mob. Comput. 2005, 4, 588–603. [CrossRef] Mammeri, A.; Boukerche, A.; Fang, Z. Video Streaming over Vehicular Ad Hoc Networks Using Erasure Coding. IEEE Syst. J. 2016, 10, 785–796. [CrossRef] Sonmez, C.; Incel, O.D.; Isik, S.; Donmez, M.Y.; Ersoy, C. Fuzzy-based congestion control for wireless multimedia sensor networks. EURASIP J. Wirel. Commun. Netw. 2014, 63, 1–17. [CrossRef] Wang, Z.; Yu, F. A flexible and reliable traffic control protocol for wireless multimedia sensor networks. Int. J. Distrib. Sens. Netw. 2014, 10, 1–17. [CrossRef] Abbas, N.; Yu, F. Performance analysis of end-to-end delay and reliability for linear wireless multimedia sensor networks. In Proceedings of the 2017 IEEE 3rd Information Technology and Mechatronics Engineering Conference (ITOEC), Chongqing, China, 3–5 October 2017; pp. 554–558. Allman, M.; Paxon, V.; Blanton, E. TCP Congestion Control. IETF RFC 5681. 2009. Available online: https://tools.ietf.org/html/rfc5681 (accessed on 5 January 2018). Tan, K.; Song, J.; Zhang, Q.; Sridharan, M. A compound TCP approach for high-speed and long distance networks. In Proceedings of the 2006 IEEE International Conference on Computer Communications (INFOCOM 2006), Barcelona, Spain, 23–29 April 2006. Balan, H.V.; Eggert, L.; Niccolini, S.; Brunner, M. An experimental evaluation of voice quality over the datagram congestion control protocol. In Proceedings of the 2007 IEEE International Conference on Computer Communications (INFOCOM 2007), Barcelona, Spain, 6–12 May 2007. Tan, W.T.; Zakhor, A. Real-time internet video using error resilient scalable compression and TCP-friendly transport protocol. IEEE Trans. Multimedia 1999, 1, 172–186. [CrossRef] Handley, S.; Padhye, M.; Widmer, J. Equation-based congestion control for unicast applications. In Proceedings of the ACM Conference on Applications, Technologies, Architectures, and Protocols for Computer Communication, Stockholm, Sweden, 28 August–1 September 2000.
Appl. Sci. 2018, 8, 348
25. 26.
27. 28.
29.
30. 31.
32.
33. 34.
35.
36. 37. 38.
39. 40. 41.
42.
14 of 14
Floyd, S.; Handley, M.; Padhye, J.; Widmer, J. TCP Friendly Rate Control (TFRC): Protocol Specification. IETF RFC 5348. 2008. Available online: https://tools.ietf.org/html/rfc5348 (accessed on 5 January 2018). Singh, V.; Ott, J.; Curcio, I. Rate adaptation for conversational 3G video. In Proceedings of the 2009 IEEE International Conference on Computer Communications (INFOCOM 2009), Rio de Janeiro, Brazil, 19–25 April 2009. Paek, J.; Govindan, R. RCRT: Rate-controlled reliable transport protocol for wireless sensor networks. ACM Trans. Sens. Netw. 2010, 7, 1–45. [CrossRef] Bian, F.; Rangwala, S.; Govindan, R. Quasi-static centralized rate allocation for sensor networks. In Proceedings of the 4th Annual IEEE Communications Society Conference on Sensor, Mesh and Ad Hoc Communications and Networks (SECON’07), San Diego, CA, USA, 18–21 June 2007; pp. 361–370. Sankarasubramaniam, Y.; Akan, O.; Akyildiz, I.F. ESRT: Event-to-sink reliable transport in wireless sensor networks. In Proceedings of the 2003 ACM International Symposium on Mobile Ad Hoc Networking & Computing (Mobi-Hoc), Annapolis, MD, USA, 1–3 June 2003; pp. 177–188. Yao, Y.; Liu, J.; Xu, D.; Ren, Z.; Hu, Q. Centralized congestion control routing protocol based on multi-metrics for low power and lossy networks. J. China Univ. Posts Telecommun. 2017, 24, 35–43. Wan, C.V.; Eisenman, S.B.; Campbell, A.T. CODA: Congestion detection and avoidance in sensor networks. In Proceedings of the 1st ACM International Conference on Embedded Networked Sensor Systems (SENSYS), Los Angeles, CA, USA, 5–7 November 2003; pp. 177–188. Hull, B.; Jamieson, K.; Balakrishnan, H. Mitigating congestion in wireless sensor networks. In Proceedings of the 2nd ACM International Conference on Embedded Networked Sensor Systems (SENSYS), Baltimore, MD, USA, 3–5 November 2004; pp. 134–147. Tao, L.Q.; Yu, F.Q. ECODA: Enhanced congestion detection and avoidance for multiple class of traffic in sensor networks. IEEE Trans. Consum. Electr. 2010, 56, 1387–1394. [CrossRef] Ee, C.T.; Bajcsy, R. Congestion control and fairness for many-to-one routing in sensor networks. In Proceedings of the 2nd International Conference on Embedded Networked Sensor Systems (SENSYS), Baltimore, MD, USA, 3–5 November 2004; pp. 148–161. Rangwala, S.; Gummadi, R.; Govindan, R.; Psounis, K. Interference- aware fair rate control in wireless sensor networks. In Proceedings of the 2006 ACM Conference on Applications, Technologies, Architectures, and Protocols for Computer Communications, Pisa, Italy, 11–15 September 2006; pp. 63–74. Aghdam, S.M.; Khasari, M.; Rabiee, H.R.; Salehi, M. WCCP: A congestion control protocol for wireless multimedia communication in sensor networks. Ad Hoc Netw. 2014, 13, 516–534. [CrossRef] Sergiou, C.; Vassiliou, V.; Paphitis, A. Hierarchical Tree Alternative Path (HTAP) algorithm for congestion control in wireless sensor networks. Ad Hoc Netw. 2013, 11, 257–272. [CrossRef] Wan, C.Y.; Eisenman, S.B.; Campbell, A.T.; Crowcroft, J. Siphon: Overload traffic management using multi-radio virtual sinks in sensor networks. In Proceedings of the 3rd International Conference on Embedded Networked Sensor Systems, Los Angeles, CA, USA, 5–7 November 2005; ACM: New York, NY, USA, 2005; pp. 116–129. Gholipour, M.; Haghighat, A.T.; Meybodi, M.R. Hop-by-hop traffic-aware routing to congestion control in wireless sensor networks. EURASIP J. Wirel. Commun. Netw. 2015, 15, 1–15. [CrossRef] Sergiou, C.; Vassiliou, V.; Paphitis, A. Congestion control in wireless sensor networks through dynamic alternative path selection. Comput. Netw. 2014, 75, 226–238. [CrossRef] Brahma, S.; Chatterjee, M.; Kwiat, K. Congestion control and fairness in wireless sensor networks. In Proceedings of the 2010 8th IEEE International Conference on Pervasive Computing and Communications Workshops (PERCOM Workshops), Mannheim, Germany, 29 March–2 April 2010; pp. 413–418. Le, L.; Hossain, E.; Alfa, A. Service differentiation in multirate wireless networks with weighted round-robin scheduling and ARQ-based error control. IEEE Trans. Commun. 2006, 54, 208–215. [CrossRef] © 2018 by the authors. Licensee MDPI, Basel, Switzerland. This article is an open access article distributed under the terms and conditions of the Creative Commons Attribution (CC BY) license (http://creativecommons.org/licenses/by/4.0/).