-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathsystem.py
145 lines (122 loc) · 5.35 KB
/
system.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
"""
This module simulates the entire transmission of messages from the sender to the receiver
"""
# Import necessary modules
import sender
import receiver
import random
from channel_erasure import bernouli_erasure, gilbert_elliot_erasure
import argparse
def system(
length = 8,
number = 50000,
size = 3,
delay_tolerance = 16,
feedback_interval = 1,
channel_erasure_model = 'Bernouli',
Pbg = 0.6,
Pgb = 0.4,
prob_feedback = 1,
scheme = 'repetition',
degree_not_feedback = 2
):
"""
Simulates transmission of every message
Parameters
----------
length : `int`
Number of bits in 1 message
number : `int`
No. of messages
size : `int`
No. of messages in a packet
delay_tolerance : `int`
No. of previous packets of interest at the current moment
feedback_interval : `int`
Feedback sent after every these many packets
channel_erasure_model: `string`
Type of channel erasure
Pbg : `float`
Probability of transition from bad to good (Also works as channel
success probability for a bernouli channel)
Pgb : `float`
Probability of transition from good to bad
erasure_prob_feedback : `float`
Feedback erasure probability
Returns
-------
`float`
Delivery failure rate
"""
# Placeholder for all packets
messages = [[random.randint(0,1) for _ in range(length)]] * number
# Create a sender
transmitter = sender.Sender(messages, delay_tolerance, degree_not_feedback)
# Creating a receiver
gateway = receiver.Receiver(number)
# Transmission
for i in range(number):
# Senders' side
p_i_h, p_i = transmitter.send_packet(i, size, scheme)
# Channel erasure
if channel_erasure_model == 'Bernouli':
received = bernouli_erasure(Pbg)
elif channel_erasure_model == 'Gilbert-Elliot':
previous_status = gateway.received_packet_list[i-1] if i>=0 else True
received = gilbert_elliot_erasure(previous_status, Pbg, Pgb)
# Receiver's side
if received:
gateway.receive_packet(p_i_h, p_i, size)
gateway.update_packet_reception(i, received)
# The feedback is sent for each received packet
if i % feedback_interval==0:
feedback_received = bernouli_erasure(prob_feedback)
if feedback_received:
feedback = gateway.send_feedback(i, delay_tolerance)
transmitter.store_feedback(i, feedback)
# Analysis
reception_rate = sum(gateway.received_messages_list[:number - delay_tolerance]) / (number - delay_tolerance)
unreceived = (number - delay_tolerance) - sum(gateway.received_messages_list[:number - delay_tolerance])
dfr = ((number - delay_tolerance) - sum(gateway.received_messages_list[:number - delay_tolerance])) / (number - delay_tolerance)
print("********")
print("Channel Erasure: ", channel_erasure_model)
if channel_erasure_model=='Gilbert-Elliot':
print("Probability bad to good: ", Pbg)
print('Probability good to bad: ', Pgb)
elif channel_erasure_model=='Bernouli':
print('Reception Probability: ', Pbg)
print("Number of messages: ", number)
print("Feedback Reception Probability: ", prob_feedback)
print("Delay Tolerance: ", delay_tolerance)
print("Reception Rate: ", reception_rate)
print("Number of unreceived packets: ", unreceived)
print("Delivery Failure Rate: ", dfr)
print("********")
return dfr
if __name__=="__main__":
parser = argparse.ArgumentParser()
parser.add_argument('-l', '--length', help='Length of one message in binary', type=int, default=8)
parser.add_argument('-n', '--number', help='Number of messages to transmit', type=int, default=50000)
parser.add_argument('-c', '--channel', help='The channel erasure model', choices=['Bernouli', 'Gilbert-Elliot'], type=str, default='Bernouli')
parser.add_argument('-s', '--size', help='Size of the packet', type=int, default=3)
parser.add_argument('-d', '--delay_tolerance', help='Delay Tolerance', type=int, default=16)
parser.add_argument('-pbg', '--pbg', help='Channel Packet Reception Probability for Bernouli or Probability of good to bad transition in Gilbert Elliot', type=float, default=0.4)
parser.add_argument('-pgb', '--pgb', help='Probability of bad to good transition in Gilbert Elliot', type=float, default=0.4)
parser.add_argument('-f', '--feedback', help='Feedback probability', type=float, default=1.0)
parser.add_argument('-i', '--feedback_interval', help='The interval of sending feedback', type=int, default=1)
parser.add_argument('--dnf', '--degree_nf', help='The coding degree when feedback is not present', type=int, default=2)
parser.add_argument('--scheme', help='The coding scheme to use', choices=['ICC', 'repetition'], type=str, default='repetition')
args = parser.parse_args()
system(
length = args.length,
number = args.number,
size = args.size,
delay_tolerance = args.delay_tolerance,
feedback_interval = args.feedback_interval,
channel_erasure_model = args.channel,
Pbg = args.pbg,
Pgb = args.pgb,
prob_feedback = args.feedback,
scheme = args.scheme,
degree_not_feedback = args.dnf
)