-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathspeedplot.gp
183 lines (149 loc) · 4.36 KB
/
speedplot.gp
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
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
#intime(COL) = strptime("%H:%M:%S",strcol(COL))
set datafile separator ";"
#stats 'bps.dat' using 2
set term png background "#330000" size 2560, 1080 \
font "/usr/share/fonts/truetype/msttcorefonts/Arial.ttf,10"
#######################
##############################
set autoscale xfix
set output "speedtest.png"
set multiplot layout 3,1
set tmargin 2
set bmargin 4
set title "Analysing speed WAN with date curl -L -w google.com " textcolor linestyle 1
####W
stats 'bps.dat' using 2 prefix "A"
set xdata time
#set style fill solid 1.0
set datafile separator ";"
#set xlabel " Date Time" textcolor linestyle 1
set timefmt "%d/%m/%y %H:%M:%S"
set format x "%H:%M:%S\n%d/%m"
set yrange [ 0 : ]
set xdata time
set autoscale x
set ylabel "Speeed \nbytes/s" textcolor linestyle 1
set grid
##colors
# Define custom display styles
set style line 1 lt 1 lc rgb "#FFCC66"
set style line 2 lt 2 lc rgb "#FF00FF" pt 6
set style line 3 lc rgb "#FFFFFF"
# Axis tic marks
set xtics textcolor linestyle 3
set key tc ls 3
#set bmargin 8
set ytics textcolor linestyle 1
set y2tics textcolor linestyle 2
#y2 mbit
set y2label "Speeed Megabytes/s" textcolor linestyle 1
set tics nomirror
FACTOR=0.001
set link y2 via FACTOR*y inverse y/FACTOR
#average
# number of points in moving average
n = 60
# initialize the variables
do for [i=1:n] {
eval(sprintf("back%d=0", i))
}
# build shift function (back_n = back_n-1, ..., back1=x)
shift = "("
do for [i=n:2:-1] {
shift = sprintf("%sback%d = back%d, ", shift, i, i-1)
}
shift = shift."back1 = x)"
# uncomment the next line for a check
# print shift
# build sum function (back1 + ... + backn)
sum = "(back1"
do for [i=2:n] {
sum = sprintf("%s+back%d", sum, i)
}
sum = sum.")"
# uncomment the next line for a check
# print sum
# define the functions like in the gnuplot demo
# use macro expansion for turning the strings into real functions
samples(x) = $0 > (n-1) ? n : ($0+1)
avg_n(x) = (shift_n(x), @sum/samples($0))
shift_n(x) = @shift
#plot
set autoscale xfix
##################################
#set style line 4 lt 2 lc rgb "green" lw 2
set label 4 'set style line 4 lt 2 lc rgb "#90EE90" lw 2' at -0.4, -0.55 tc rgb "#90EE90"
set label 5 'set style line 5 lt 2 lc rgb "#009E60" lw 2' at -0.4, -0.55 tc rgb "white"
##################################
plot 'bps.dat' using 1:2 t 'bytes/s' w points, 'bps.dat' using 1:(avg_n($2)) w l lc rgb "red" lw 2 title "avg 60 probs(10 minutes)", A_mean ls 4 title " Mean", A_median ls 5 title " Median"
set title "Averages"
set timefmt "%d/%m/%y %H:%M:%S"
#set format x "%H\n%d/%m"
#set style data histogram
#set style fill solid
#set key autotitle column
set autoscale x
set autoscale xfix
#binwidth = 0.1
#set boxwidth binwidth
#sum = 0
n = 6
nn = 360
# initialize the variables
do for [i=1:n] {
eval(sprintf("back%d=0", i))
}
# build shift function (back_n = back_n-1, ..., back1=x)
shift = "("
do for [i=n:2:-1] {
shift = sprintf("%sback%d = back%d, ", shift, i, i-1)
}
shift = shift."back1 = x)"
# uncomment the next line for a check
# print shift
# build sum function (back1 + ... + backn)
sum = "(back1"
do for [i=2:n] {
sum = sprintf("%s+back%d", sum, i)
}
sum = sum.")"
samples(x) = $0 > (n-1) ? n : ($0+1)
avg_n(x) = (shift_n(x), @sum/samples($0))
shift_n(x) = @shift
#######################
do for [r=1:nn] {
eval(sprintf("backw%d=0", r))
}
# build shift function (back_n = back_n-1, ..., back1=x)
shiftw = "("
do for [r=nn:2:-1] {
shiftw = sprintf("%sbackw%d = backw%d, ", shiftw, r, r-1)
}
shiftw = shiftw."backw1 = tt)"
# uncomment the next line for a check
# print shift
# build sum function (back1 + ... + backn)
sumw = "(backw1"
do for [r=2:nn] {
sumw = sprintf("%s+backw%d", sumw, r)
}
sumw = sumw.")"
samplesw(tt) = $0 > (nn-1) ? nn : ($0+1)
avg_nw(tt) = (shift_nw(tt), @sumw/samplesw($0))
shift_nw(tt) = @shiftw
#######################
#######################
plot 'bps.dat' using 1:(avg_n($2)) w dots lc rgb "red" lw 2 title "avg 6 probs(1 minutes)", 'bps.dat' using 1:(avg_nw($2)) w dots lc rgb "green" lw 2 title "avg 360 probs(1 hour)"
#stats 'bps.dat' using 3
set title "Ping time "
set autoscale x
set autoscale xfix
set ylabel "time \nMiliceonds " textcolor linestyle 1
set y2label "time \n seconds " textcolor linestyle 1
#set logscale y
set autoscale y2
set yrange [0:350]
plot 'bps.dat' using 1:3 t 'time miliceconds' w impulses
set xrange[*:*]
unset multiplot
reset