-
Notifications
You must be signed in to change notification settings - Fork 0
/
test5.py
84 lines (68 loc) · 2.24 KB
/
test5.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
import os
import sys
import matplotlib.pyplot as plt
class TraceStringFormat:
def __init__(self, line):
self.event = line[0]
self.time = float(line[1])
self.fromNode = int(line[2])
self.toNode = int(line[3])
self.type = line[4]
self.size = int(line[5])
self.flags = FlagsFormat(line[6])
self.flowID = int(line[7])
self.source = line[8]
self.destination = line[9]
self.sequenceNumber = int(line[10])
self.packetID = int(line[11])
class FlagsFormat:
def __init__(self, flags):
self.flag1 = flags[0]
self.flag2 = flags[1]
self.flag3 = flags[2]
self.flag4 = flags[3]
self.flag5 = flags[4]
self.flag6 = flags[5]
self.flag7 = flags[6]
traceList = []
with open('iz.tr', 'r') as inputFile: # open file
while True:
line = inputFile.readline().strip('\n').split(' ') # readline and split
if (line == ['']): # check end of file
break
traceString = TraceStringFormat(line) # format line
traceList.append(traceString) # add formatted line to list
start_time, stop_time = [], []
packet_durations = []
x = []
y = []
for packet in traceList:
try:
if start_time[packet.packetID] == 0:
start_time[packet.packetID] = packet.time
except IndexError:
start_time.insert(packet.packetID, packet.time)
try:
if packet.event == "r" and (packet.type == "tcp" or packet.type == "ack"):
stop_time[packet.packetID] = packet.time
else:
stop_time[packet.packetID] = -1
except IndexError:
stop_time.insert(packet.packetID, packet.time)
for i in range(0, len(start_time)):
packet_duration = stop_time[i] - start_time[i]
if packet_duration > 0:
packet_durations.insert(i, [packet_duration, stop_time[i]])
for i in range(0, len(packet_durations)-1):
x.append(packet_durations[i+1][1])
y.append(abs(packet_durations[i+1][0]-packet_durations[i][0])*1000)
# plotting the points
plt.plot(x, y)
# naming the x axis
plt.xlabel('Zaman')
# naming the y axis
plt.ylabel('Seğirme (ms)')
# giving a title to my graph
plt.title('Seğirme Dağılımı (Jitter)')
# function to show the plot
plt.show()