-
Notifications
You must be signed in to change notification settings - Fork 0
/
End-EndDelay3links.py
executable file
·80 lines (59 loc) · 3.5 KB
/
End-EndDelay3links.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
#!/usr/bin/env python3
import argparse
from decimal import Decimal, getcontext
from tabulate import tabulate
# Set precision
getcontext().prec = 28
def trans_delay(t, M):
"""Compute Transmission Delay."""
return (M / t) * Decimal("1000")
def prop_delay(d, S):
"""Compute Propagation Delay."""
return d / (S * Decimal("100"))
def get_args():
"""Get command line arguments."""
parser = argparse.ArgumentParser(description="Calculate network transmission and propagation delays.",
formatter_class=argparse.ArgumentDefaultsHelpFormatter)
parser.add_argument('--t1', type=Decimal, default=1, help="Transmission Delay (link speed) at Link1 (value in Mbps)")
parser.add_argument('--t2', type=Decimal, default=1, help="Transmission Delay (link speed) at Link2 (value in Mbps)")
parser.add_argument('--t3', type=Decimal, default=1, help="Transmission Delay (link speed) at Link3 (value in Mbps)")
parser.add_argument('--T1', type=Decimal, help="Transmission Delay at Link1 (value in milliseconds)")
parser.add_argument('--T2', type=Decimal, help="Transmission Delay at Link2 (value in milliseconds)")
parser.add_argument('--T3', type=Decimal, help="Transmission Delay at Link3 (value in milliseconds)")
parser.add_argument('--d1', type=Decimal, default=1, help="Distance of Link1 (value in KM)")
parser.add_argument('--d2', type=Decimal, default=1, help="Distance of Link2 (value in KM)")
parser.add_argument('--d3', type=Decimal, default=1, help="Distance of Link3 (value in KM)")
parser.add_argument('--D1', type=Decimal, help="Propagation Delay at Link1 (value in milliseconds)")
parser.add_argument('--D2', type=Decimal, help="Propagation Delay at Link2 (value in milliseconds)")
parser.add_argument('--D3', type=Decimal, help="Propagation Delay at Link3 (value in milliseconds)")
parser.add_argument('-N', type=Decimal, default=1, help="Number of Packets")
parser.add_argument('-M', type=Decimal, default=1, help="Packet Size (value in Mbits)")
parser.add_argument('-S', type=Decimal, default=1, help="Propagation Speed (speed in 10^8m/s)")
parser.add_argument('-p', type=Decimal, default=0, help="Router Processing Time (processing time in milliseconds)")
return parser.parse_args()
def get_delays(args):
"""Compute delays and return them."""
data = []
n, A, queue_delay1, queue_delay2 = Decimal("1"), Decimal("0"), Decimal("0"), Decimal("0")
while n <= args.N:
td_t1 = args.T1 if args.T1 else trans_delay(args.t1, args.M)
td_t2 = args.T2 if args.T2 else trans_delay(args.t2, args.M)
td_t3 = args.T3 if args.T3 else trans_delay(args.t3, args.M)
R1 = A + td_t1 + (args.D1 if args.D1 else prop_delay(args.d1, args.S))
R2 = R1 + queue_delay1 + args.p + td_t2 + (args.D2 if args.D2 else prop_delay(args.d2, args.S))
B = R2 + queue_delay2 + args.p + td_t3 + (args.D3 if args.D3 else prop_delay(args.d3, args.S))
data.append(["P" + str(n), A, R1, R2, B, queue_delay1, queue_delay2])
if R1 < td_t2:
queue_delay1 += td_t2 - td_t1
if R2 < td_t3:
queue_delay2 += td_t3 - td_t2
n, A = n + 1, A + td_t1
return data
def main():
"""Main function."""
args = get_args()
delays = get_delays(args)
headers = ["Packet", "A (ms)", "R1 (ms)", "R2 (ms)", "B (ms)", "Queue Delay1 (ms)", "Queue Delay2 (ms)"]
print(tabulate(delays, headers=headers, tablefmt='pipe'))
if __name__ == '__main__':
main()