# Hardware Circuit Implementation and Performance Analysis of **Three-Slot NP-CSMA**

# Xu Lu<sup>1</sup>, Hongwei Ding<sup>1, \*</sup>, Zejun Han<sup>1</sup>, Zhijun Yang<sup>1</sup>, Liqing Wang<sup>1</sup> and Livong Bao<sup>1</sup>

Abstract: The development of wireless communication technology has become increasingly important in the communications industry. How to allocate limited channel resources reasonably and reliably to each competing user is a problem that the access protocol of the MAC (Multiple Access Control) layer needs to solve. As an important way of random access, NP-CSMA (Non Persistent Carrier Sense Multiple Access) has a higher network throughput rate when the arrival rate is higher. This paper analyzes and improves the implemented NP-CSMA model, and obtains a three-slot NP-CSMA model. The mathematical tool MATLAB is used to analyze the network throughput, delay and energy efficiency of the model, and compare several random multiple access protocols adheres to the network throughput, they are NP-CSMA, Three-slot NP-CSMA, 1-persistent CSMA, P-persistent CSMA, and concludes that the three-slot NP-CSMA is significantly letter than several other multiple access protocols. Finally, using Quartus to design the three-slot NP-CSMA circuit, the statistical value of the circuit system is compared with the theoretical value of the model, and the error is less than 0.01, which proves that the system is reasonable in design and can be applied to wireless communication networks.

Keywords: Three-slot NP-CSMA, FPGA, delay, throughput rate, energy consumption.

## **1** Introduction

At present, wireless sensor networks have been successfully applied to many research fields including military, natural environment monitoring, industrial production monitoring, medical care and other daily life of human beings [Sun (2015)]. The sensor node is responsible for sensing the environmental information in the network, collecting the monitoring data and reporting it to the user node through the aggregation node. Wireless sensor network nodes need to share common channel resources. Random multiple access is an important access method for network nodes. Carrier sense multiple access CSMA is a protocol that uses a competitive method to determine channel usage rights. The protocol only applies to networks that are logically part of the bus topology [Jian, Liu, Wei et al. (2017)]. In the network of the bus, each station can independently determine the transmission of the frame. If two or more stations simultaneously transmit the frame, a collision will occur, resulting in an error in the transmitted frame [Ashrafi,

<sup>&</sup>lt;sup>1</sup> School of information, Yunnan University, Kunming, 650091, China.

<sup>\*</sup> Corresponding Author: Hongwei Ding. Email: dhw1964@163.com.

Feng and Roy (2017)]. The idea of CSMA technology is that the transmitting station first monitors the channel before transmitting the data. If no other station transmits data, the station transmits the data. If there are other stations transmitting data, they will be retired according to a certain strategy. The commonly used back-off strategies are persistent carrier sense multi-access and non-persistent type [Buratti and Verdone (2016)]. In the case of a high arrival rate, the non-persistent throughput rate is higher than the adherence type throughput rate. Based on the analysis of the NP-CSMA model, a three-slot NP-CSMA circuit system is designed and several important performances are analyzed. It is concluded that the performance of the improved multiple access system is significantly better than that of NP-CSMA. 1-persistent CSMA, P-persistent CSMA several random multiple access protocols [Chen, Wong, Motani et al. (2013); Chowdhury, Ashrafuzzaman and Kwak (2014); Jin, Seo and Sung (2014)].

Multiple wireless users access the channel. If there is no control protocol to queue the data input by each user, a large number of data collisions will occur, resulting in a very low throughput of the system. The access system model is shown in Fig. 1 and Fig. 2 below [Buratti and Verdone (2013): P-CSMA: a priority-based CSMA protocol for multi-hop linear wireles (2013); Wei, Bianchi, Cheng et al. (2015)]. The article realizes the three-slot NP-CSMA multiple access protocol through FPGA design, realizes the reasonable queuing of the data input channel before the data access channel, and increases the throughput rate of the system.







Figure 2: Multi-user access model with added control protocol

#### 2 Model analysis

## 2. 1 NP-CSMA model analysis

Principle of NP-CSMA: Before the data frame is sent, the station needs to detect the channel. If the channel is detected to be idle, the data frame is sent. Otherwise, if the channel is busy, it will wait for a period of time before sending [Lee and Cho (2018); Guerroumi, Pathan and Derhab (2017)].



Figure 3: NP-CSMA protocol model

In Fig. 3, U, B, and I respectively represent three states of successful data frame transmission, data frame collision, and channel idle. TP indicates a transmission time when a packet is successfully transmitted or a collision occurs. BU indicates a joint event in which the packet is successfully transmitted and a collision occurs, indicating that the channel is busy, and Tn indicates a cycle in which the busy period and the idle period occur [Doost, Naderi and Chowdhury (2016); Sarode and Bakal (2017)].

Before analyzing the NP-CSMA model, make the following assumptions and definitions for the model [Atmaca, Şayli, Yuan et al. (2017); Kai, Zhang and Wang (2018)]:

(1) It is assumed that the channel has no noise interference and is ideal;

(2) The mode of channel access is NP-CSMA protocol, and the information packet arrival process on the channel satisfies the Poisson distribution with independent parameter  $\lambda$ ;

(3) The length of the time slot in which the channel is idle is a, and the length of the time slot when the packet is transmitted is unit length 1 (1 is an integral multiple of a);

(5) E(U) represents the average length required for the information packet to be successfully transmitted, E(BU) represents the average length required for the information packet to be successfully transmitted or collided, and E(I) represents the average length of the idle period;

(6) P (BU) represents the probability of consecutive occurrences of j BU events in a busy cycle; P (I) represents the probability of consecutive occurrences of idle events in one cycle; P (BU, I) represents one cycle of consecutive, the joint probability of the idle event and the j busy events; the number of packets successfully transmitted in the joint event of the BU is k; S represents the throughput rate.

The probability that a time slot is idle is:

 $P = e^{-a\lambda} \tag{1}$ 

The probability that no information packet arrives within a transmission time slot TP is:

$$P = e^{-(1+a)\lambda} \tag{2}$$

The probability distribution of consecutive i idle time slots during an idle period is:

$$P(I) = \left(e^{-a\lambda}\right)^{i} \tag{3}$$

The probability distribution of consecutive j BU in a busy cycle is:

$$P(BU) = \left(1 - e^{-a\lambda}\right)^{j} \tag{4}$$

The joint probability of an (I, BU) event occurring within a cycle is:

642 Copyright © 2019 Tech Science Press CMES, vol.119, no.3, pp.639-658, 2019

$$P(I,BU) = \left(e^{-a\lambda}\right)^{i} \left(1 - e^{-a\lambda}\right)^{j}$$
(5)

Average length of the idle period E(I):

$$E(I) = a \times \sum_{i=1}^{\infty} \sum_{j=1}^{\infty} i \left( e^{-a\lambda} \right)^i \left( 1 - e^{-a\lambda} \right)^j = \frac{a}{1 - e^{-a\lambda}}$$
(6)

Average length of busy period E (BU):

$$E(BU) = (1+a) \times \sum_{i=1}^{\infty} \sum_{j=1}^{\infty} j \left( e^{-a\lambda} \right)^i \left( 1 - e^{-a\lambda} \right)^j = \frac{1+a}{e^{-a\lambda}}$$
(7)

The condition that a packet of information is successfully transmitted is that no packet arrives within the previous transmission slot delay and only one packet needs to be transmitted in this slot. Then the average length of the information packet successfully sent is:

$$E(U) = 1 \times \sum_{i=1}^{\infty} \sum_{j=1}^{\infty} C_{j}^{k} k \left( e^{-a\lambda} \right)^{i} \left( a\lambda e^{-a\lambda} \right)^{k} \left( 1 - e^{-a\lambda} - a\lambda e^{-a\lambda} \right)^{j-k} = \frac{a\lambda}{1 - e^{-a\lambda}}$$
(8)

According to  $S = \frac{E(U)}{E(BU) + E(I)}$ , the system throughput rate S is:

$$S = \frac{\frac{a\lambda}{1 - e^{-a\lambda}}}{\frac{1 + a}{e^{-a\lambda}} + \frac{a}{1 - e^{-a\lambda}}} = \frac{a\lambda e^{-a\lambda}}{1 + a - e^{-a\lambda}}$$
(9)

#### 2.2 Three-slot NP-CSMA model analysis

The principle of three-slot NP-CSMA: The station needs to detect the channel before sending the data frame, and if it hears that the channel is idle, it sends the data frame; Otherwise, if the channel is busy, it will wait for a period of time before sending.



Figure 4: Three-slot NP-CSMA protocol model

In Fig. 4, U, B, and I respectively represent three states of data frame, it is that success transmission, collision occurrence, and channel idleness. BU indicates a joint event in which the information packet is successfully transmitted and a collision occurs, indicating that the channel is in a busy state.

On the basis of Section 1.1, the following assumptions and definitions are made for the system:

(1) The length of the time slot in which the channel is idle is a, the length of the time slot

in which the information packet collides is l, and the length of the time slot when the information packet is successfully transmitted is unit length 1 (1 is an integer multiple of a);

(2)  $\overline{K_U}$  indicates the average number of successful events U,  $\overline{K_B}$  indicates the average number of collision events B,  $\overline{K_{BU}}$  indicates the average number of BU composite events, and  $\overline{K_I}$  indicates the average number of idle events I.

According to the formulas (1), (2), (3), (4), (5) in Section 1.1, there are: The average number of idle periods I is:

$$\overline{K_I} = \sum_{i=1}^{\infty} \sum_{j=1}^{\infty} i \left( e^{-a\lambda} \right)^i \left( 1 - e^{-a\lambda} \right)^j = \frac{1}{1 - e^{-a\lambda}}$$
(10)

The average number of composite events BU is:

$$\overline{K_{BU}} = \sum_{i=1}^{\infty} \sum_{j=1}^{\infty} j \left( e^{-a\lambda} \right)^i \left( 1 - e^{-a\lambda} \right)^j = \frac{1}{e^{-a\lambda}}$$
(11)

The average number of successful events U is:

$$\overline{K_U} = \sum_{i=1}^{\infty} \sum_{j=1}^{\infty} C_j^k k \left( e^{-a\lambda} \right)^i \left( a\lambda e^{-a\lambda} \right)^k \left( 1 - e^{-a\lambda} - a\lambda e^{-a\lambda} \right)^{j-k} = \frac{a\lambda}{1 - e^{-a\lambda}}$$
(12)

The average number of collision events B is:

$$\overline{K_B} = \overline{K_{BU}} - \overline{K_U}$$
(13)

The average length of the idle period I is:

$$E(I) = \frac{a}{1 - e^{-a\lambda}} \tag{14}$$

The average length of the success event U is:

$$E(U) = \frac{a\lambda}{1 - e^{-a\lambda}} \tag{15}$$

The average length of the collision event B is:

$$E(B) = l \times \frac{1 - e^{-a\lambda} - a\lambda e^{-a\lambda}}{e^{-a\lambda} \left(1 - e^{-a\lambda}\right)}$$
(16)

According to  $S = \frac{E(U)}{E(BU) + E(I)}$ , the throughput S of the three-slot NP-CSMA is:

$$S = \frac{a\lambda e^{-a\lambda}}{a\lambda e^{-a\lambda} (1-l) + l + a - l \times e^{-a\lambda}}$$
(17)

#### 3 Implementation of three-slot NP-CSMA based on FPGA

#### 3.1 The overall architecture of the system

Fig. 5 above shows the circuit diagram of the three-slot NP-CSMA protocol based on FPGA (Field-Programmable Gate Array). Firstly, the design of the information source input module is performed. The module generates the poisson data stream through the software MATLAB, and inputs the poisson data stream into the Quartus for access. Secondly, the state classification module classifies the input initial data; then the slot length control module pairs Data of different states are allocated for time slots of different lengths; next, the channel monitoring control module monitors by setting a monitoring channel, and implements a random back-off strategy by generating a pseudo-random series; finally, the data receiving statistics module classifies and counts the received data. Comparing the statistical value with the theoretical value to determine whether the design of the hardware circuit is successful [Xu, Ding, Yang et al. (2018); Sun and Dai (2016); Cao, Chen, Cheng et al. (2015)].



Figure 5: overall architecture of the system

#### 3.2 Data source input module

The data source input module is also the source generating module. In order to obtain a valid possion data stream, first using MATLAB to generate a possion data stream, and then convert it into a data source that can be read by Quartus, using random access in Quartus. The memory (RAM) accesses the possion data [Uddin, Rosenberg, Zhuang et al. (2014)]. The circuit design in Quartus is shown in Fig. 6 below:



Figure 6: Data source input module diagram in Quartus

#### 3.3 Channel state classification module

When multiple users compete for one channel at a time, it is necessary to classify the channels in order to facilitate subsequent processing of the collision data. When no user sends data, the channel is in an idle state, denoted by I; when only one user sends data, the

data can be successfully sent, denoted by U; when two or more users send data, the data collides, this is indicated by B. In the FPGA circuit design, the possion data stream sent by the initial station is mapped by eight bits (for example, 0000\_0001 indicates that the channel is idle; 0000\_0110 indicates that the channel successfully transmits data; 0000 0111 indicates data collision), thereby realizing the state classification of the channel.

### 3.4 Time slot length control module

The three-slot NP-CSMA needs to normalize the slot length. The length of the idle slot is equal to the length of the transmission delay, which is defined as a, and the length of the successfully transmitted slot is 1, which is just a free slot10 times. In this paper, when using FPGA to implement three-slot NP-CSMA, the length of the collision time slot is set to 0.5, which is exactly five times that of the idle time slot. In the FPGA, the asynchronous FIFO (First Input First Output) and the read/write control module are used to realize the control of the time slot length. The read/write control module is implemented by Verilog, and the data outputted by the FIFO is monitored and analyzed, and then fed back to the read enable end of the asynchronous FIFO. The asynchronous FIFO performs read control based on the feedback data, so that different channel states occupy different time slot lengths [Casares-Giner and Martínez-Bauset (2017); Zhang, Yi, Wang et al. (2011)]. The logic block diagram of the time slot length control module is shown in Fig. 7 below:



Figure 7: Schematic diagram of the slot length control module

## 3.5. Channel monitoring control module

In order to monitor channel status and reasonable access of the site in real time, the site is divided into a transmitting site and a monitoring site. The monitoring site transmits only a small amount of data in actual applications, mainly monitoring the state of the channel, and the amount of data sent by the transmitting site. When the channel monitoring station detects that the channel is busy, the three-slot NP-CSMA adopts a control strategy of randomly retreating for a period of time and then monitoring, and the FPGA realizes the function of random back-off by generating a pseudo-random series [Sarkar, Misra, Bandyopadhyay et al. (2015); Chan, Berger and Tong (2013); Bae, Choi and Alfa (2014)]. This module implements the multiple access strategy of three-slot NP-CSMA.

#### 3.6 Data receiving statistics module

The module mainly implements statistics on the received data, and the number of

timeslots occupied by the station is successfully transmitted, and the throughput rate of the system is obtained by calculating the ratio of the number of occupied slots and the total time slot. This module consists of counters used to count the number of successful time slots for data transmission on the channel [Xu, Ding, Yang et al. (2018)].

$$s = \frac{N_U \times T_U}{t} \times \frac{1}{1+a} \tag{18}$$

In formula (18), t is the total duration of simulation,  $N_U$  is the number of successful time slots for data transmission in circuit simulation, and  $T_U$  is the length of time slot in the busy state of the channel, this time slot length is an information packet sent in the algorithm protocol, the theoretical value is 1+a, and the success time slot length is 1, so the length of the calculation success state should be multiplied by  $\frac{1}{1+a}$ .

## 4 System performance analysis

#### 4.1 Time delay analysis

The paper analyzes the time delay of the three-slot NP-CSMA under the condition that the propagation delay of the information is a,  $E_d$  represents the average length of the delay, and  $S_d$  represents the ratio of the delay to the total time slot length [Lee, Jae-Hyoung, Cho et al. (2017)]. The average time delay and the proportion of time delay to total time are:

$$E_d = a \times \overline{K_{BU}} = \frac{a}{e^{-a\lambda}} \tag{19}$$

$$S_{d} = \frac{E_{d}}{E(BU) + E(I)} = \frac{a(1 - e^{a\lambda})}{ae^{-a\lambda} + a\lambda e^{-a\lambda} + l \times (1 - e^{-a\lambda} - a\lambda e^{-a\lambda})}$$
(20)

The time delay of the three-slot NP-CSMA is simulated by MATLAB, and the result shown in Fig. 8 is obtained as follows.



Figure 8: Delay of the system at different arrival rates

Analysis of Fig. 8 above shows that the delay of the three-slot NP-CSMA increases with the increase of the reaching rate. In the actual network, because there is too much data to be transmitted, and the channel resources are limited, the delay is also increasing due to the waiting for sending data or the collision of transmitted data. At the same time, we can find that the ratio of the delay to the total time slot length increases with the increase of the reach rate, but when the arrival rate is greater than 70, the ratio tends to 20%. It is indicated that because the arrival rate is increasing, the monitoring function of the control strategy plays a role, so that the delay steadily approaches a certain value.

The ratio of the time extension of the three-slot NP-CSMA to the total time slot length is simulated by MATLAB under different collision time slots, the result shown in Fig. 9 is obtained as shown below:



Figure 9: System delay for different collision time slots

It is not difficult to find in the above Fig. 9. Firstly, under the condition of different collision time slot lengths, the change trend of the proportion of the delay is the same as the increase of the arrival rate; secondly, under the same arrival rate condition, the larger the value of the collision slot length l, the smaller the proportion of the delay.

#### 4.2 Energy efficiency analysis

In this paper, when analyzing the energy efficiency of the protocol, the wireless channel energy model proposed in the reference [Ashrafi, Feng, Roy et al. (2015); El-Hoiydi (2002); Nirmala and Nallusamy (2012)] is used. The energy consumption considers the transmission energy consumption, the reception energy consumption and the sensing energy consumption.

Based on the battery model of the paper [El-Hoiydi (2002); Liu, Li, He et al. (2018)], it is assumed that the power is  $P_{TX}$  when each node is in the transmission state,  $P_{RX}$  when in the receiving state, and  $P_{lm}$  in the channel detection state.

The battery leakage power is 10%, the total energy is E(Wh), and the total energy leaked is 0.1E. The energy consumed is:

648

Copyright © 2019 Tech Science Press CMES, vol.119, no.3, pp.639-658, 2019

$$E_{h} = E - 0.1 \times E = 0.9E \tag{21}$$

When the average power of the sensor node is P, then the life time of the node when the battery energy is exhausted is [Ashrafi, Feng, Roy et al. (2015); Dai and Sun (2013)]:

$$T = \frac{0.9 \times E \times 1000}{365 \times 24 \times P} \quad (\text{year}) \tag{22}$$

The average power of the three-slot NP-CSMA control protocol is:

$$P = \frac{P_{TX} \times E(U) + P_{RX} \times E(B) \times \frac{a+l}{l} + P_{lm} \times E(I)}{E(U) + E(B) + E(I)}$$
(23)

For a LR6 battery, the voltage peaks are 1.5 V and 0.9 V, the average voltage is U=1.2 V, and the capacity is 2.6 Ah. If the battery life is T, the total energy of the battery is:

$$E = UIT = 1.2 \times \frac{2.6}{T} \times T = 3.12Wh \tag{24}$$

To simplify the calculation, assume the transmission power:  $P_{TX} = 1.8(mW)$ . Power when receiving state:  $P_{RX} = 9(mW)$ . Power in channel detection state:  $P_{lm} = 0.5(mW)$ . Then the life cycle of the three-slot NP-CSMA control protocol is:

$$T = \frac{0.9 \times E \times 1000}{365 \times 24 \times P} = \frac{2808 \times [E(U) + E(B) + E(I)]}{8760 \times \left[1.8 \times E(U) + 9 \times E(B) \times \frac{a+l}{l} + 0.5 \times E(I)\right]}$$

$$= \frac{2808 \times \left[ae^{-a\lambda} + a\lambda e^{-a\lambda} + l \times \left(1 - e^{-a\lambda} - a\lambda e^{-a\lambda}\right)\right]}{4380ae^{-a\lambda} + 15768a\lambda e^{-a\lambda} + 78840(a+l) \times \left(1 - e^{-a\lambda} - a\lambda e^{-a\lambda}\right)}$$
(25)

Using MATLAB to simulate the life cycle of three-slot NP-CSMA at different arrival rates, the results shown in Fig. 10 are obtained.

Analysis Fig. 10 is easy: with the increase of the arrival rate, the life cycle of the node is decreasing, but when the arrival rate of the node increases to 40, the life cycle of the node tends to a certain value, this is because the arrival rate is increasing, and the monitoring function of the control strategy plays a role, so that the life cycle of the node steadily approaches a certain value.



Figure 10: Node life cycle at different arrival rates

Using MATLAB to simulate the life cycle of three-slot NP-CSMA under different collision time slots, the results shown in Fig. 11 are obtained.



Figure 11: Node life cycle under different collision time slots

Analysis of Fig. 11 above is not difficult to find: first, under different collision time slot length conditions, the life cycle change trend of the nodes is the same with the increase of the arrival rate; secondly, under the same arrival rate condition, the value of the collision time slot length 1 is larger, and the shorter the life cycle of a node.

# 4.3 Throughput analysis

#### 4.3.1 Simulation Analysis of MATALAB

When the length of the idle time slot a is 0.1, the length of the collision time slot l is 0.5, and the length of the successful time slot is 1. Using MATLAB to simulate the system throughput of NP-CSMA, three-slot NP-CSMA, 1-persistent CSMA, and P-persistent

#### 650 Copyright © 2019 Tech Science Press

CSMA multiple access protocols at different arrival rates [Zhou, Ding, Yang et al. (2017); Tadayon, Wang and Chen (2014)], the results shown in Fig. 12 below are obtained.

According to the above Fig. 12, it can be obtained that in the case of a small arrival rate, the system throughput rate of the CSMA is increased faster, but the arrival rate only increases to 1 and begins to decrease; the three-slot NP-CSMA system throughput rate is accompanied by the arrival rate. The increase increases until the system throughput rate reaches a maximum at 5 and then begins to decrease. The throughput of the three-slot NP-CSMA is significantly larger than that of several other multiple access protocols after the arrival rate is greater than three.



Figure 12: Throughput of different multiple access protocols

When the length of the idle time slot a is 0.1, the length of the collision time slot l is 0.5, and the length of the successful time slot is 1, the system throughput of the three-slot NP-CSMA at the arrival rate is simulated by MATLAB, and the following is obtained. The result shown in Fig. 13.



**Figure 13:** Three-slot NP-CSMA throughput rate at l = 0.5

Analysis Fig. 13 shows that with the increase of the arrival rate, the throughput of the three-slot NP-CSMA increases sharply first, and the maximum value is 0.6764 when the arrival rate is 5, and then the throughput of the system decreases with the increase of the arrival rate.

When the length of the idle time slot a is 0.1 and the length of the successful time slot is 1, the system throughput of the three-slot NP-CSMA at different collision time slots is simulated by MATLAB, and the result shown in Fig. 14 is obtained as follows [Zhou, Ding, Yang et al. (2017); Tadayon, Wang and Chen (2014)].



Figure 14: System throughput under different *l* values

Analysis of the above Fig. 14 found: First, under different collision time slot lengths, the system throughput rate changes with the increase of the arrival rate; Secondly, when the arrival rate is greater than 3 and the arrival rate is the same, the larger the value of the collision time slot length l, the smaller the throughput rate of the system.

### 4.3.2 Analysis of throughput of three-slot NP-CSMA realized by FPGA

The Quartus software is used for synthesis and routing. The minimum clock period for the system is 10 ns, the length of information transmitted by the station is 8 bits, the idle time slot is a=0.1, the collision time slot is l=0.5, and the length of the time slot occupied by the idle information is 80 ns, the length of the time slot occupied by the successfully transmitted packet is 800 ns, and the length of the time slot occupied by the collision packet is 400 ns.

The three-slot NP-CSMA system was designed by Quartus software. The statistical results obtained are shown in Tab. 1 below:

|                          | 1                                        |                                         | 5                 |
|--------------------------|------------------------------------------|-----------------------------------------|-------------------|
| Arrival rate $(\lambda)$ | Theoretical value of throughput rate (S) | Simulation value of throughput rate (S) | Relative<br>error |
| 0.5                      | 0.3210                                   | 0.3248                                  | 1.18%             |
| 1.0                      | 0.4693                                   | 0.4609                                  | 1.79%             |
| 2.0                      | 0.6009                                   | 0.5987                                  | 0.37%             |
| 3.0                      | 0.6523                                   | 0.6516                                  | 0.11%             |
| 4.0                      | 0.6722                                   | 0.6627                                  | 1.41%             |
| 5.0                      | 0.6764                                   | 0.6686                                  | 1.15%             |
| 6.0                      | 0.6717                                   | 0.6618                                  | 1.47%             |
| 7.0                      | 0.6615                                   | 0.6557                                  | 0.88%             |
| 8.0                      | 0.6476                                   | 0.6468                                  | 0.12%             |
| 9.0                      | 0.6312                                   | 0.6299                                  | 0.21%             |
| 10.0                     | 0.6131                                   | 0.6132                                  | 0.02%             |
| 11.0                     | 0.5938                                   | 0.6006                                  | 1.14%             |
| 12.0                     | 0.5736                                   | 0.5753                                  | 0.30%             |
| 13.0                     | 0.5528                                   | 0.5402                                  | 2.28%             |
| 14.0                     | 0.5317                                   | 0.5335                                  | 0.34%             |
| 15.0                     | 0.5104                                   | 0.5127                                  | 0.45%             |
| 16.0                     | 0.4890                                   | 0.4863                                  | 0.55%             |
| 17.0                     | 0.4678                                   | 0.4687                                  | 0.19%             |
| 18.0                     | 0.4467                                   | 0.4543                                  | 1.70%             |
| 19.0                     | 0.4259                                   | 0.4213                                  | 1.08%             |
| 20.0                     | 0.4054                                   | 0.408                                   | 0.64%             |

**Table 1:** Comparison of statistical and theoretical values of the system

Analysis Tab. 1 gets: The statistical value of the throughput rate obtained by the three-slot NP-CSMA system designed by Quartus software is less than 0.01 compared with the theoretical value, indicating that the design system is reasonable. The theoretical values in the above table are directly calculated by the calculation formula of throughput rate. The statistical values in the table are obtained by running the three-slot NP-CSMA system in software Quartus. By comparing the statistical values and theoretical values, the rationality of the system design is proved. Figs. 15-21 below shows the specific test results for the three-slot NP-CSMA system at the arrival rate  $\lambda$ =1 to  $\lambda$ =7.

(1) Set the simulation time to 1000 us, the total system information arrival rate  $\lambda=1$ ,  $\lambda 1=0.89$ ,  $\lambda 2=0.11$ . According to the above coefficient setting, the circuit simulation is completed, and the following timing simulation results are obtained as shown in the following figure:

995 84 ....

003 02 mm 004 56 mm

005 2 m

|  |          |   |   |          |       |          |      | · · · |
|--|----------|---|---|----------|-------|----------|------|-------|
|  |          |   |   |          |       |          |      |       |
|  | <u> </u> | c | , | <u> </u> | 4 101 | <u> </u> | 4    |       |
|  |          |   |   |          |       |          |      |       |
|  |          |   |   |          |       |          | ┚╹╌╌ |       |

997 12 m

997 76 ....

008 / 10

999 04 95

996 //8 ....

**Figure 15:** Test simulation diagram of the system when  $\lambda = 1$ 

As shown in the Fig. 15 above, the number of data transmission success event slots on the bus is 6338. The hardware circuit is simulated under the condition of  $T = 1000us, a = 0.1, \lambda = 1$ . According to formula (18), the simulation value of system throughput is 0.4609.

(2) Set the simulation time to 1000us, the total system information arrival rate  $\lambda=2$ ,  $\lambda 1=1.86$ ,  $\lambda 2=0.14$ . According to the above coefficient setting, the circuit simulation is completed, and the following timing simulation results are obtained as shown in the following figure:

| 999. 9 us | 999. 91 us | 999.92 us | 999. 93 us | 999.94 us | 999.95 us | 999.96 us | 999.97 us | 999.98 us | 999.99 us | 1.0 ms |
|-----------|------------|-----------|------------|-----------|-----------|-----------|-----------|-----------|-----------|--------|
|           |            |           |            |           |           |           |           |           |           |        |
|           |            |           |            |           |           |           |           |           |           |        |
|           |            |           |            |           | 8         |           |           |           |           |        |
| -         |            |           |            |           |           |           |           |           |           |        |
|           |            |           |            |           |           |           |           |           |           |        |
| 8         | 3230 X     |           |            |           | 82        | 31        |           |           |           | X 8232 |

**Figure 16:** Test simulation diagram of the system when  $\lambda=2$ 

As shown in the Fig. 16 above, the number of data transmission success event slots on the bus is 8232. The hardware circuit is simulated under the condition of  $T = 1000us, a = 0.1, \lambda = 2$ . According to formula (18), the simulation value of system throughput is 0.5987.

(3) Set the simulation time to 1000us, the total system information arrival rate  $\lambda=3$ ,  $\lambda 1=2.78$ ,  $\lambda 2=0.22$ . According to the above coefficient setting, the circuit simulation is completed, and the following timing simulation results are obtained as shown in the following figure:



**Figure 17:** Test simulation diagram of the system when  $\lambda$ =3

As shown in the Fig. 17 above, the number of data transmission success event slots on the bus is 8959. The hardware circuit is simulated under the condition of

000 68 ....

 $T = 1000us, a = 0.1, \lambda = 3$ . According to formula (18), the simulation value of system throughput is 0.6516.

(4) Set the simulation time to 1000 us, the total system information arrival rate  $\lambda=4$ ,  $\lambda 1=3.18$ ,  $\lambda 2=0.82$ . According to the above coefficient setting, the circuit simulation is completed, and the following timing simulation results are obtained as shown in the following figure:



**Figure 18:** Test simulation diagram of the system when  $\lambda$ =4

As shown in the Fig. 18 above, the number of data transmission success event slots on the bus is 9112. The hardware circuit is simulated under the condition of  $T = 1000us, a = 0.1, \lambda = 4$ . According to formula (18), the simulation value of system throughput is 0.6627.

(5) Set the simulation time to 1000us, the total system information arrival rate  $\lambda$ =5,  $\lambda$ 1=4.2,  $\lambda$ 2=0.8 According to the above coefficient setting, the circuit simulation is completed, and the following timing simulation results are obtained as shown in the following figure:

| 951.35 | us        | 956 | 6. <b>4</b> ' | ľus   | ;   |       | 96   | 1.5 | 59  | us  | ;   |    | 9 | 966  | • 7 | 1 1 | 15  |     |      | 97  | 1.) | ŖЗ  | us   | ;  |      | 91   | 16.  | <b>9</b> 5 | us  | ;    |                          | 98   | 32.1 | <b>0</b> 7 | us   |   |   | 98 | 87. | 19 | us | 5 |    | 9 | 92 | . 31 | 1 u | 15 |   |    | 99' | 7.4 | 3 | us |   |
|--------|-----------|-----|---------------|-------|-----|-------|------|-----|-----|-----|-----|----|---|------|-----|-----|-----|-----|------|-----|-----|-----|------|----|------|------|------|------------|-----|------|--------------------------|------|------|------------|------|---|---|----|-----|----|----|---|----|---|----|------|-----|----|---|----|-----|-----|---|----|---|
|        |           |     |               |       |     | _     |      |     |     |     |     |    |   |      |     |     |     | _   |      |     |     |     |      |    |      | _    |      |            | _   |      |                          | _    |      |            |      |   | _ |    |     |    |    |   |    |   |    |      |     |    |   |    |     |     |   |    | - |
| 9      | $\square$ |     |               |       | 8   |       |      |     |     |     |     | Æ  | Ċ |      |     |     |     |     |      |     |     |     |      |    | 8    |      |      |            |     |      |                          |      |      |            |      | X |   |    |     |    |    |   |    |   | 9  | 1    |     | 1  |   |    |     |     |   |    | χ |
|        |           |     |               |       |     |       |      |     |     |     |     | 1  |   |      |     |     |     |     |      |     |     |     |      |    |      |      |      |            |     |      |                          |      |      |            |      |   |   |    |     |    |    |   |    |   |    |      | T   |    |   |    |     |     |   | T  | T |
|        |           |     |               |       |     | U     | I    | U   |     | 1   | I   | ı  |   | U    | 1   |     |     |     |      |     |     |     |      |    |      |      |      | U          |     |      |                          |      |      |            |      |   |   |    |     |    | u  |   | l  | L |    |      | L   |    |   |    | Ī   | U   |   | I  | ī |
| Ш      |           | J.  | L             |       |     |       | L    | J   |     | L   |     | Ľ  | L | l    |     | L   | J   |     | L    |     | L   |     |      | L  |      |      | L    |            |     | I.   |                          |      | L    | J          |      |   | Ц | L  | L   | L  | ū  | L | I. | L | Ш  | Ĺ    | L   | L  | U | ЦĹ | L   | Ū   | 1 | L  | ſ |
| 8823   | 3)))      | 000 | ())))         | ))))) | 000 | ))))) | )))) | 0)) | ))) | ]]] | ))) | 95 | 灁 | )))) | I)) | ))) | ))) | ))) | )))) | ))) | 0)) | ))) | )))) | 00 | )))) | )))) | )))) | 00)        | 000 | )))) | $\left( \right) \right)$ | )))) | )))) | ))))       | )))) | C |   |    |     |    |    |   |    |   | 91 | 93   | 1   |    |   |    |     |     |   |    |   |

**Figure 19:** Test simulation diagram of the system when  $\lambda$ =5

As shown in the Fig. 19 above, the number of data transmission success event slots on the bus is 9193. The hardware circuit is simulated under the condition of  $T = 1000us, a = 0.1, \lambda = 5$ . According to formula (18), the simulation value of system throughput is 0.6686.

(6) Set the simulation time to 1000us, the total system information arrival rate  $\lambda=6$ ,  $\lambda 1=5.13$ ,  $\lambda 2=0.87$ . According to the above coefficient setting, the circuit simulation is completed, and the following timing simulation results are obtained as shown in the following figure:

| 999, 89 us | 999. <sub>.</sub> 9 us | 999.91 us | 999.92 us | 999.93 us | 999.94 us | 999.95 us | 999.96 us | 999.97 us | 999.98 us | 999. 99 us | 1.0 ms |
|------------|------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|------------|--------|
|            |                        |           |           |           |           |           |           |           |           |            |        |
|            |                        |           |           |           |           |           |           |           |           |            |        |
|            |                        |           |           |           | 0         |           |           |           |           |            |        |
| -          |                        |           |           |           |           |           |           |           |           |            |        |
|            |                        |           |           |           |           |           |           |           |           |            |        |
|            | 9098                   | ,         | Y         |           |           | 90        | 99        |           |           |            | X 9100 |

**Figure 20:** Test simulation diagram of the system when  $\lambda$ =6

As shown in the Fig. 20 above, the number of data transmission success event slots on the bus is 9100. The hardware circuit is simulated under the condition of  $T = 1000us, a = 0.1, \lambda = 6$ . According to formula (18), the simulation value of system throughput is 0.6618.

(7) Set the simulation time to 1000us, the total system information arrival rate  $\lambda$ =7,  $\lambda$ 1=6.14,  $\lambda$ 2=0.86. According to the above coefficient setting, the circuit simulation is completed, and the following timing simulation results are obtained as shown in the following figure:



**Figure 21:** Test simulation diagram of the system when  $\lambda=7$ 

As shown in the Fig. 21 above, the number of data transmission success event slots on the bus is 9016. The hardware circuit is simulated under the condition of  $T = 1000us, a = 0.1, \lambda = 7$ . According to formula (18), the simulation value of system throughput is 0.6557.

# **5** Conclusion

Based on the analysis of NP-CSMA and three-slot NP-CSMA models, the hardware circuit design of three-slot NP-CSMA is designed by Quartus. After the design is completed, the throughput rate is verified, the error between the calculated throughput rate and the theoretical value is less than 0.01, indicating that the three-slot NP-CSMA system can be used for random access in wireless networks. The performance of three-slot NP-CSMA random multiple access protocol with delay, node energy consumption and throughput rate were simulated by MATLAB, the results are basically consistent with the theoretical values. Compared with other simulations of several multiple access protocols, it is found that the throughput of three-slot NP-CSMA is significantly higher than that of NP-CSMA, 1-persistent CSMA, and P-persistent CSMA, and it is more obvious when the arrival rate is relatively high.

656 Copyright © 2019 Tech Science Press

Acknowledgements: This work was supported by the National Natural Science Foundation of China (61461053, 61461054, 61072079, 61463049); The Financial Support of Yunnan University (No. XT412004).

#### References

Ashrafi, S.; Feng, C.; Roy, S. (2017): Performance analysis of CSMA with multi-packet reception: the inhomogeneous case. *IEEE Transactions on Communications*, vol. 65, no. 1, pp. 230-243.

Ashrafi, S.; Feng, C.; Roy, S.; Kschischang, F. R. (2015): Slotted ALOHA with compute-and-forward. *IEEE International Symposium on Information Theory*, pp. 571-575.

Atmaca, S.; Şayli, Ö.; Yuan, J.; Kavak, A. (2017): Throughput maximization of CSMA in cognitive radio networks with cooperative spectrum sensing. *Wireless Personal Communications: An International Journal*, vol. 92, no. 4, pp. 1473-1492.

**Bae, Y. H.; Choi, B. D.; Alfa, A. S.** (2014): Achieving maximum throughput in random access protocols with multipacket reception. *IEEE Transactions on Mobile Computing*, vol. 13, no. 3, pp. 497-511.

Buratti, C.; Verdone, R. (2013): P-CSMA: a priority-based CSMA protocol for multi-hop linear wireless networks *19th European Wireless Conference*, pp. 1-8.

**Buratti, C.; Verdone, R.** (2016): L-CSMA: a MAC protocol for multihop linear wireless (sensor) networks. *IEEE Transactions on Vehicular Technology*, vol. 65, no. 1, pp. 251-265.

**Cao, X.; Chen, J.; Cheng, Y.; Shen, X.; Sun, Y.** (2015): An analytical MAC model for IEEE 802.15.4 enabled wireless networks with periodic traffic. *IEEE Transactions on Wireless Communications*, vol. 14, no. 10, pp. 5261-5273.

**Casares-Giner, V.; Martínez-Bauset, J.** (2017): Performance evaluation of framed slotted aloha with reservation packets for m2m networks. *IEEE 5th International Conference on Future Internet of Things and Cloud*, pp. 18-24.

**Chan, D. S.; Berger, T.; Tong, L.** (2013): Carrier sense multiple access communications on multipacket reception channels: theory and applications to IEEE 802.11 wireless networks. *IEEE Transactions on Communications*, vol. 61, no. 1, pp. 266-278.

Chen, Q.; Wong, W.; Motani, M.; Liang, Y. (2013): MAC protocol design and performance analysis for random access cognitive radio networks. *IEEE Journal on Selected Areas in Communications*, vol. 31, no. 11, pp. 2289-2300.

Chowdhury, M. S.; Ashrafuzzaman, K.; Kwak, K. S. (2014): Saturation throughput analysis of IEEE 802.15.6 slotted aloha in heterogeneous conditions. *IEEE Wireless Communications Letters*, vol. 3, no. 3, pp. 257-260.

Dai, L.; Sun, X. (2013): A unified analysis of IEEE 802.11 DCF networks: stability, throughput, and delay. *IEEE Transactions on Mobile Computing*, vol. 12, no. 8, pp. 1558-1572.

**Doost, M. R.; Naderi, M. Y.; Chowdhury, K. R.** (2016): Performance analysis of CSMA/CA based medium access in full duplex wireless communications. *IEEE Transactions on Mobile Computing*, vol. 15, no. 6, pp. 1457-1470.

**El-Hoiydi, A.** (2002): Aloha with preamble sampling for sporadic traffic in ad hoc wireless sensor networks. *IEEE International Conference on Communications. Conference Proceedings. ICC 2002.* 

**El-Hoiydi**, A. (2002): Spatial TDMA and CSMA with preamble sampling for low power ad hoc wireless sensor networks. *Proceedings-International Symposium on Computers and Communications*.

Guerroumi, M.; Pathan, A. K.; Derhab, A.; Badache, N.; Moussaoui, S. (2017): MMSMAC: a multi-mode medium access control protocol for wireless sensor networks with latency and energy-awareness. *Wireless Personal Communications: An International Journal*, vol. 96, no. 4, pp. 4973-5010.

Jaeho, L. (2018): Evaluations and optimizations of CSMA-based protocols considering energy-efficient wireless personal area networks. *Wireless Personal Communications: An International Journal*, vol. 98, no. 2, pp. 2319-2331.

Jian, X.; Liu, Y.; Wei, Y.; Zeng, X.; Tan, X. (2017): Random access delay distribution of multichannel slotted ALOHA with its applications for machine type communications. *IEEE Internet of Things Journal*, vol. 4, no. 1, pp. 21-28.

Jin, H.; Seo, J. B.; Sung, D. K. (2014): Stability analysis of p-persistent slotted CSMA systems with finite population. *IEEE Transactions on Communications*, vol. 62, no. 12, pp. 4373-4386.

Kai, C.; Zhang, S. L.; Wang, L. S. (2018): Impacts of packet collisions on link throughput in CSMA wireless networks. *China Communications*, vol. 15, no. 3, pp. 1-14.

Lee, J. H.; Cho, S. H. (2017): Tree TDMA MAC algorithm using time and frequency slot allocations in tree-based WSNs. *Wireless personal communications: An International Journal*, vol. 95, no. 3, pp. 2575-2597.

Liu, X. T.; Li, H.; He, Y.; Zheng, X. X.; Zeng, G. J. (2018): SOC estimation method based on iupf algorithm and variable parameter battery model. *Journal of Southeast University (Natural Science Edition)*, vol. 48, no. 1, pp. 54-62.

Nirmala, S.; Nallusamy, R. (2012): An energy-efficient and enhanced QoS aware of MAC application specific protocol in the distributed wireless sensor networks. *Fourth International Conference on Advanced Computing*.

Sarkar, S.; Misra, S.; Bandyopadhyay, B.; Chakraborty, C.; Obaidat, M. S. (2015): Performance analysis of IEEE 802.15.6 MAC protocol under non-ideal channel conditions and saturated traffic regime. *IEEE Transactions on Computers*, vol. 64, no. 10, pp. 2912-2925.

Sarode, S.; Bakal, J. (2017): Performance analysis of beacon enabled prioritized CSMA/CA for IEEE sensor networks. *International Journal of Applied Engineering Research*, vol. 12, no. 8, pp. 1622-1627.

Seo, J. H.; Bae, J. (2017): Stability region of p-persistent csma systems. *IEEE communications letters: A publication of the IEEE Communications Society*, vol. 21, no. 3, pp. 652-655.

Sun, L. (2015): Summary of the latest development of wireless sensor network application system. *China New Communications*, vol. 17, no. 6, pp. 112.

**Sun, X.; Dai, L.** (2016): Performance optimization of CSMA networks with a finite retry limit. *IEEE Transactions on Wireless Communications*, vol. 15, no. 9, pp. 5947-5962.

Tadayon, N.; Wang, H.; Chen, H. H. (2014): Performance analysis of distributed access multihop poisson networks. *IEEE Transactions on Vehicular Technology*, vol. 63, no. 2, pp. 849-858.

Uddin, M. F.; Rosenberg, C.; Zhuang, W.; Mitran, P.; Girard, A. (2014): Joint routing and medium access control in fixed random access wireless multihop networks. *IEEE/ACM Transactions on Networking*, vol. 22, no. 1, pp. 80-93.

Wei, C. H.; Bianchi, G.; Cheng, R. G. (2015): Modeling and analysis of random access channels with bursty arrivals in OFDMA wireless networks. *IEEE Transactions on Wireless Communications*, vol. 14, no. 4, pp. 1940-1953.

Xu, Z.; Ding, H. W.; Yang, Z. J.; He, M.; Bao, L. Y. et al. (2018): Research on dual priority mac protocol based on FPGA cognitive wireless network. *Modern Electronic Technology*, vol. 41, no. 17, pp. 34-39.

Yigitel, A. M.; Incel, O. D.; Ersoy, C. (2015): QoS vs. energy: a traffic-aware topology management scheme for green heterogeneous networks. *Computer Networks*, vol. 78.

Zhang, Y. J.; Yi, C. L.; Wang, J. Q.; Zhang, J. Y. (2011): Asynchronous FIFO implementation using FPGA. *Proceedings of 2011 International Conference on Electronics and Optoelectronics*, pp. 666-668.

Zhou, S. J.; Ding, H. W.; Yang, Z. J.; Liu, Q. L. (2017): Research on adaptive three-dimensional probability CSMA control strategy. *Acta Electronica Sinica*, vol. 45, no. 2, pp. 440-445.