-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjit_1.awk
98 lines (59 loc) · 1.29 KB
/
jit_1.awk
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
#This program is used to calculate the jitters for CBR
# jitter =((recvtime(j)-sendtime(j))-(recvtime(i)-sendtime(i)))/(j-i), j > i
BEGIN {
# Initialization
highest_packet_id = 0;
}
{
action = $1;
time = $2;
from = $3;
to = $4;
type = $5;
pktsize = $6;
flow_id = $8;
src = $9;
dst = $10;
seq_no = $11;
packet_id = $12;
if ( packet_id > highest_packet_id ) {
highest_packet_id = packet_id;
}
#Record the transmission time
if (start_time[packet_id] == 0 ) {
# Record the sequence number
pkt_seqno[packet_id] = seq_no;
start_time[packet_id] = time;
}
#Record the receiving time for CBR (flow_id=2)
#if ( flow_id == 1 && action != "d" && from == 2) {
if ( action == "r" ) {
end_time[packet_id] = time;
}
else {
end_time[packet_id] = -1;
}
}
END {
last_seqno = 0;
last_delay = 0;
seqno_diff = 0;
for ( packet_id = 0; packet_id <= highest_packet_id; packet_id++ ) {
start = start_time[packet_id];
end = end_time[packet_id];
packet_duration=end - start;
if ( start < end ) {
seqno_diff = pkt_seqno[packet_id] - last_seqno;
delay_diff = packet_duration - last_delay;
if (seqno_diff !=0) {
jitter = delay_diff/seqno_diff;
}
else {
jitter =0;
}
last_seqno = pkt_seqno[packet_id];
last_delay = packet_duration;
}
}
printf("Average Jitter (CBR):\t\t%1.2f\n",jitter);
}