Parallel Transmission of Distributed Sensor Based on SCTP and TCP for Heterogeneous Wireless Networks in IoT †
Abstract
:1. Introduction
- Based on the analysis and simulation results of the IEEE 802.11 wireless multi-hop network, the performance and problems of SCTP and TCP under different network environments are analyzed and compared.
- A multipath switching scheme MS-SCTP is proposed to apply SCTP to data transmission in high speed networks. MS-SCTP judges the network transmission situation of each link based on packet loss rate, and then selects the main line in advance to ensure the link transmission quality.
- TCP and SCTP are more suitable for wireless cable network transmission. Based on packet loss rate, the TCP-SCTP method predicts the current link transmission condition. When the link transmission quality becomes worse, the TCP-SCTP switch process improves the transmission quality.
- Simulation and analysis of TCP-SCTP and MS-SCTP in network transmission show that TCP-SCTP and MS-SCTP improve throughput and stability, and improve network transmission quality.
2. Problem Statement
2.1. Simulation Scenarios
2.2. Comparison of the Average Throughput
2.3. Comparison of the Real-Time Throughput
2.4. Comparison of the Packet Loss Rate
2.5. Comparison of the Stability
3. Algorithm Design and Analysis
3.1. MS-SCTP Method
3.1.1. Model Description
3.1.2. Parameter Descriptions in MS-SCTP Method
3.1.3. Algorithm Design
- Line 1 indicates that the switching algorithm began when the main path needed reselection.
- Line 2 indicates that the link probe needed to be performed before switching between the master and the slave paths. If the path was found unreachable, the Max array and the last array values corresponding to the path were updated. When the path was not reachable, the value of the Max array and the corresponding position in the Last array was set to 101.
- Lines 3 and 4 show that the algorithm traversed the Max and the Last arrays and recorded the Max and Last values for each path.
- Line 5 indicates that the path with the smallest result was selected by calculating 0.25 × Max + 0.75 × Last.
- Lines 6 through 14 show that if more than one alternative path was selected, the algorithm needed to confirm whether the alternative paths package included the current main path. If the alternate paths included the current primary path, it was not necessary to re-switch the primary path. If the alternative paths did not include the current main path, the scheme randomly selected one as the new main path and recorded it.
- Lines 15 through 18 indicate that when making a primary path switch, the algorithm first determined whether the recorded PathNumber variable had the same value as the current primary PathNumber. If so, then it did not have to switch. If not, the algorithm set the new primary path based on the value of the recorded path number and updated the CurrentNumber value.
| Algorithm 1. MS-SCTP Method | 
| Input: Max[], Last[], CurrentNumber Output: CurrentNumber 1: Method begin 2: Detect the reachability of the path, update the Max array and Last array 3: Search the Max array and Last array 4: Record the max value as Max and record the last value as Last 5: Calculate 0.25 * Max + 0.75 * Last and select the paths with the smallest value 6: If results have more than one path number 7: If results contains the CurrentNumber 8: Let PathNumber = CurrentNumber 9: Else Choose one at random and record the PathNumber 10: End Else 11: End If 12: Else Record the PathNumber 13: End Else 14: End If 15: If CurrentNumber == PathNumber 16: No longer switch 17: Else Set the primary path according the PathNumber 18: Let CurrentNumber = PathNumber 19: End Else 20: End If 21: End Method | 
3.2. TCP-SCTP Switch Process
3.2.1. Parameter Descriptions in TCP-SCTP Switch Process
3.2.2. Process Design
| Algorithm 2. TCP-SCTP Switch Process | 
| Input: ProtocolType Output: ProtocolType 1: Process begin 2: If ProtocolType == 0 3: Program apply SCTP to establish the connection 4: Let ProtocolType = 1 5: Else 6: Program apply TCP to establish the connection 7: Let ProtocolType = 0 8: End Else 9: End If 10: End Process | 
- Line 1 indicates that the process started running when the TCP-SCTP method judged that it needed to make protocol switch.
- Line 2 shows that the process needed to judge which type of protocol was running. If the current ProtocolType value was zero, it indicated that the TCP protocol was currently running. The protocol needed to be switched to SCTP.
- Line 3 indicates that the current transport protocol was set to SCTP.
- Line 4 was used to record the protocol type for process switching. The current usage protocol was set as SCTP, and the ProtocolType was assigned a value of one. The TCP-SCTP switch process ended.
- Line 5 indicates that Line 2 was false. The current ProtocolType value was one, therefore the SCTP protocol was currently running. The protocol needed to be switched to TCP.
- Line 6 shows that the current transport protocol was set to TCP.
- Line 7 was used to record the protocol type for process switching. The current usage protocol was set as TCP, and the ProtocolType was assigned a value of zero. The TCP-SCTP switch process ended.
3.3. TCP-SCTP Method
3.3.1. TCP-SCTP Method Description
3.3.2. Parameter Descriptions in TCP-SCTP Method
3.3.3. Algorithm Design
| Algorithm 3. TCP-SCTP Method | 
| Input: trace file (computing packet loss rate), DetectSlot Output: Rate 1: Method begin 2: Wait DetectSlot time 3: Record the current packet loss rate in Rate, update LastRate be Rate 4: While true 5: Wait DetectSlot time, then record the current packet loss rate in Rate 6: If Rate > 5% 7: We need to apply MS-SCTP method or TCP-SCTP switch process 8: Let LastRate = Rate 9: Let Count = 0 10: Let DetectSlot = DetectSlot 11: Continue 12: End If 13: Else If Rate >= lastRate 14: Let LastRate = Rate 15: Let Count = Count + 1 16: Let DetectSlot = DetectSlot / 2 17: Else 18: Let LastRate = Rate 19: Let Count = 0 20: Let DetectSlot = DetectSlot * 2 21: End Else 22: End If 23: If Count >= 3 24: We need to apply MS-SCTP method or TCP-SCTP switch process 25: Let Count = 0 26: End If 27: End Else 28: End While 29: Procedure run 600 s, and then end procedure 30: End Method | 
- Line 1 indicates that the algorithm started executing after the initial connection was established.
- Line 2 indicates that the method waited for the default detection interval time before starting to detect network conditions.
- Line 3 indicates that after the algorithm calculated the packet loss rate, it recorded the packet loss rate into the Rate variable, and at the same time updated the value of LastRate so that it could compare with the next time detection of the packet loss rate so as to predict the state of the network.
- The algorithm needed to repeatedly detect packet loss rate of packets, thus Line 4 kept the algorithm running by setting the loop condition to true.
- After the algorithm started running, it initially got a packet loss rate value, and Line 5 waited for the DetectSlot time before detecting the network status.
- The algorithm got the packet loss rate again after the time interval of the DetectSlot. After the calculation packet loss rate, Line 6 started to judge the packet loss rate. If the packet loss rate was greater than 5%, then the network situation was poor.
- Line 7 shows that the algorithm called the previously defined MS-SCTP method or the TCP-SCTP switch process. After calling the MS-SCTP method or the TCP-SCTP switch process, we needed to update some parameter variables.
- Line 8 was used to update the LastRate value. It detected the new packet loss rate of the loop every time, thus it needed to update the LastRate every time as well.
- Line 9 shows this algorithm set Count value to zero. Because the Count was used to record the times, the PER continued to rise. After switch another protocol, the Count is set to zero.
- Line 10 set the interval between the next detection of packet loss rate. The data transmission improved after switching the protocol. Therefore, the DetectSlot kept the current value.
- Line 11 indicates that the algorithm should have continued the next loop after switching the protocol instead of continuing to perform the following judgment.
- Line 13 represents the algorithm’s processing scheme if the detected packet loss rate was less than 5%. Firstly, the packet loss rate obtained at present was compared with the packet loss rate recorded last time to predict network transmission quality. If the packet loss rate of the current packet was greater than the packet loss rate recorded last time, the network condition was worse than that of the last time.
- Line 14 was used to update the LastRate value for comparison with the packet loss rate next time.
- Line 15 was used to update the value of Count, and the algorithm needed to add one to the value of Count.
- Line 16 updated the value of DetectSlot. The network was getting worse, thus it set the value of DetectSlot to half the original value.
- Line 17 indicates that the current packet loss rate was less than the last recorded packet loss rate.
- The same Line 18 was used to update the LastRate value.
- Line 19 was used to update the value of Count. The packet loss rate did not keep increasing, thus the algorithm needed to reset the value of Count to zero.
- Line 20 was used to update the value of DetectSlot. The algorithm determined that the network condition was getting better, thus it did not need to frequently detect the trend of the network condition. It set the value of DetectSlot to twice the original value.
- After obtaining the new packet loss rate every time, Line 23 started to judge whether or not the packet loss rate kept increasing for three times through the value of Count. If the packet loss rate kept increasing for three times, it was considered that the network condition kept getting worse.
- Line 24 shows the algorithm calling the MS-SCTP method or the TCP-SCTP switch process.
- Line 25 indicates that the Count value was reset to zero after the protocol switch.
- Line 29 shows that after the simulation process lasted 600 s, the program execution process ended.
4. Simulations and Analysis
4.1. Simulation Results of MS-SCTP Method
4.2. Simulation Results of TCP-SCTP Switch Process
4.3. Implementation Analysis
5. Conclusions and Future Work
Author Contributions
Funding
Acknowledgments
Conflicts of Interest
References
- Qiu, T.; Qiao, R.; Wu, D.O. EABS: An Event-Aware Backpressure Scheduling Scheme for Emergency Internet of Things. IEEE Trans. Mob. Comput. 2018, 17, 72–84. [Google Scholar] [CrossRef]
- Qiu, T.; Zheng, K.; Han, M.; Chen, C.L.P.; Xu, M. A Data-Emergency-Aware Scheduling Scheme for Internet of Things in Smart Cities. IEEE Trans. Ind. Inform. 2018, 14, 2042–2051. [Google Scholar] [CrossRef]
- Zhou, L.; Wang, L.; Ai, T.; Sun, Y. BeeKeeper 2.0: Confidential Blockchain-Enabled IoT System with Fully Homomorphic Computation. Sensors 2018, 18, 3785. [Google Scholar] [CrossRef] [PubMed]
- Porcel-Rodríguez, F.; Valenzuela-Valdés, J.; Padilla, P.; Luna-Valero, F.; Luque-Baena, R.; López-Gordo, M. Ángel Clustering and Beamforming for Efficient Communication in Wireless Sensor Networks. Sensors 2016, 16, 1334. [Google Scholar] [CrossRef] [PubMed]
- Wang, S. CyberGIS. In The International Encyclopedia of Geography; John Wiley & Sons, Ltd.: Hoboken, NJ, USA, 2017. [Google Scholar]
- Cha, H.J.; Yang, H.K.; Song, Y.J. A Study on the Design of Fog Computing Architecture Using Sensor Networks. Sensors 2018, 18, 3633. [Google Scholar] [CrossRef] [PubMed]
- Miguel, M.L.F.; Jamhour, E.; Pellenz, M.E.; Penna, M.C. SDN Architecture for 6LoWPAN Wireless Sensor Networks. Sensors 2018, 18, 3738. [Google Scholar] [CrossRef] [PubMed]
- Park, H.; Lim, Y. Energy-Effective Power Control Algorithm with Mobility Prediction for 5G Heterogeneous Cloud Radio Access Network. Sensors 2018, 18, 2904. [Google Scholar] [CrossRef] [PubMed]
- Qiu, T.; Chen, N.; Li, K.; Atiquzzaman, M.; Zhao, W. How Can Heterogeneous Internet of Things Build Our Future: A Survey. IEEE Commun. Surv. Tutor. 2018, 20, 2011–2027. [Google Scholar] [CrossRef]
- Mishra, D.; Alexandropoulos, G.C. Jointly Optimal Spatial Channel Assignment and Power Allocation for MIMO SWIPT Systems. IEEE Wirel. Commun. Lett. 2018, 7, 214–217. [Google Scholar] [CrossRef]
- Shukla, S.; Bhardwaj, O.; Abouzeid, A.A.; Salonidis, T.; He, T. Hold’em Caching: Proactive Retention-Aware Caching with Multi-path Routing for Wireless Edge Networks. In Proceedings of the 18th ACM International Symposium on Mobile Ad Hoc Networking and Computing, Chennai, India, 10–14 July 2017; p. 24. [Google Scholar]
- Peng, Q.; Walid, A.; Hwang, J.; Low, S.H. Multipath TCP: Analysis, Design, and Implementation. IEEE/ACM Trans. Netw. 2016, 24, 596–609. [Google Scholar] [CrossRef]
- Wan, Z.; Yuan, X.; Zhou, Z.; Xiong, N. Cross-Layer Optimization of Dynamic Packet Assignment for Video Transmission Over IEEE 802.11e Networks. Wirel. Pers. Commun. 2018, 102, 2417–2428. [Google Scholar] [CrossRef]
- Tian, J.; Zhang, H.; Wu, D.; Yuan, D. Interference-Aware Cross-layer Design for Distributed Video Transmission in Wireless Networks. IEEE Trans. Circuits Syst. Video Technol. 2016, 26, 978–991. [Google Scholar] [CrossRef]
- Gligoroski, D.; Kralevska, K. Families of Optimal Binary Non-MDS Erasure Codes. In Proceedings of the 2014 IEEE International Symposium on Information Theory, Honolulu, HI, USA, 29 June–4 July 2014; pp. 3150–3154. [Google Scholar]
- Kralevska, K.; Øverby, H.; Gligoroski, D. Joint balanced source and network coding. In Proceedings of the 2014 22nd Telecommunications Forum Telfor (TELFOR), Belgrade, Serbia, 25–27 November 2014; pp. 589–592. [Google Scholar]
- Sundararajan, J.K.; Shah, D.; Médard, M.; Jakubczak, S.; Mitzenmacher, M.; Barros, J. Network Coding Meets TCP: Theory and Implementation. Proc. IEEE 2011, 99, 490–512. [Google Scholar] [CrossRef]
- Sun, W.; Yu, S.; Xing, Y.; Zhang, D. A Multi-path Switching Method Based on SCTP for Heterogeneous Wireless Networks in Smart IoT. In Proceedings of the 2018 IEEE International Conference on Smart Internet of Things (SmartIoT), Xi’an, China, 17–19 August 2018; pp. 15–22. [Google Scholar]
- Sun, J.; Zhang, Y.; Wang, X.; Xiao, S.; Xu, Z.; Wu, H.; Chen, X.; Han, Y. DC^ 2-MTCP: Light-Weight Coding for Efficient Multi-Path Transmission in Data Center Network. In Proceedings of the 2017 IEEE International Parallel and Distributed Processing Symposium (IPDPS), Orlando, FL, USA, 29 May–2 June 2017; pp. 419–428. [Google Scholar]
- Hou, W.; Ning, Z.; Guo, L. Green Survivable Collaborative Edge Computing in Smart Cities. IEEE Trans. Ind. Inform. 2018, 14, 1594–1605. [Google Scholar] [CrossRef]
- Eklund, J.; Grinnemo, K.-J.; Brunstrom, A. Efficient scheduling to reduce latency for signaling traffic using CMT-SCTP. In Proceedings of the 2016 IEEE 27th Annual International Symposium on Personal, Indoor, and Mobile Radio Communications (PIMRC), Valencia, Spain, 4–8 September 2016; pp. 1–6. [Google Scholar]
- Nor, S.A.; Alubady, R.; Kamil, W.A. Simulated performance of TCP, SCTP, DCCP and UDP protocols over 4G network. Procedia Comput. Sci. 2017, 111, 2–7. [Google Scholar]
- Ramiro, C.; Simarro, M.Á.; Gonzalez, A.; Vidal, A.M. Parallel SUMIS soft detector for large MIMO systems on multicore and GPU. J. Supercomput. 2018, 75, 1256–1267. [Google Scholar] [CrossRef]
- Qin, K.; Huang, C.; Ganesan, N.; Liu, K.; Chen, X. Minimum Cost Multi-Path Parallel Transmission with Delay Constraint by Extending Openflow. China Commun. 2018, 15, 15–26. [Google Scholar] [CrossRef]
- Wegner, M.; Rottmann, S.; Wolf, L.C. SCTPCL: An SCTP convergence layer protocol for DTN. In Proceedings of the Eleventh ACM Workshop on Challenged Networks, New York City, NY, USA, 3–7 October 2016; pp. 19–24. [Google Scholar]














| Parameter | Value | 
|---|---|
| Wireless protocol | IEEE 802.11 | 
| Time slot | 20 μs | 
| Wireless bandwidth | 1 MBps | 
| Wired bandwidth | 5 MBps | 
| Link delay | 2 ms | 
| SCTP maximum transmission unit (MTU) | 1500 B | 
| SCTP chunk size | 1468 B | 
| Simulation time | 600 s | 
| Error rate type | Packet error rate | 
| Rate values | 0%~50% | 
| Parameter | Description | 
|---|---|
| Max [] | Record the maximum packet loss rate for each path | 
| Last [] | Record the latest packet loss rate for each path | 
| CurrentNumber | Record the current primary path number | 
| PathNumber | Record the selected new primary path number | 
| Parameter | Description | 
|---|---|
| ProtocolType | Record the protocol type | 
| Parameter | Description | 
|---|---|
| DetectSlot | Record the detection interval of packet loss rate | 
| Count | Record the consecutive increase times of packet loss rate | 
| LastRate | Record the previous packet loss rate | 
| Rate | Record the current packet loss rate | 
| Max[] | Record the maximum packet loss rate for each path | 
| Min[] | Record the minimum packet loss rate for each path | 
© 2019 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/).
Share and Cite
Sun, W.; Yu, S.; Xing, Y.; Qin, Z. Parallel Transmission of Distributed Sensor Based on SCTP and TCP for Heterogeneous Wireless Networks in IoT. Sensors 2019, 19, 2005. https://doi.org/10.3390/s19092005
Sun W, Yu S, Xing Y, Qin Z. Parallel Transmission of Distributed Sensor Based on SCTP and TCP for Heterogeneous Wireless Networks in IoT. Sensors. 2019; 19(9):2005. https://doi.org/10.3390/s19092005
Chicago/Turabian StyleSun, Weifeng, Shumiao Yu, Yuanxun Xing, and Zhenquan Qin. 2019. "Parallel Transmission of Distributed Sensor Based on SCTP and TCP for Heterogeneous Wireless Networks in IoT" Sensors 19, no. 9: 2005. https://doi.org/10.3390/s19092005
APA StyleSun, W., Yu, S., Xing, Y., & Qin, Z. (2019). Parallel Transmission of Distributed Sensor Based on SCTP and TCP for Heterogeneous Wireless Networks in IoT. Sensors, 19(9), 2005. https://doi.org/10.3390/s19092005
 
        
 
       