Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
O
OpenXG-RAN
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Operations
Operations
Metrics
Environments
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
OpenXG
OpenXG-RAN
Commits
e290b2ab
Commit
e290b2ab
authored
Apr 09, 2024
by
Robert Schmidt
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/ci-iperf3-analysis-fix' into integration_2024_w14
parents
e66588b5
ffe9096b
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
59 additions
and
191 deletions
+59
-191
ci-scripts/active_net_interfaces.awk
ci-scripts/active_net_interfaces.awk
+0
-21
ci-scripts/add_user_to_conf_file.awk
ci-scripts/add_user_to_conf_file.awk
+0
-33
ci-scripts/add_user_to_subscriber_list.awk
ci-scripts/add_user_to_subscriber_list.awk
+0
-27
ci-scripts/cls_containerize.py
ci-scripts/cls_containerize.py
+24
-26
ci-scripts/cls_oaicitest.py
ci-scripts/cls_oaicitest.py
+35
-41
ci-scripts/main.py
ci-scripts/main.py
+0
-4
ci-scripts/ran.py
ci-scripts/ran.py
+0
-1
ci-scripts/tcp_iperf_stats.awk
ci-scripts/tcp_iperf_stats.awk
+0
-38
No files found.
ci-scripts/active_net_interfaces.awk
deleted
100644 → 0
View file @
e66588b5
#/*
# * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
# * contributor license agreements. See the NOTICE file distributed with
# * this work for additional information regarding copyright ownership.
# * The OpenAirInterface Software Alliance licenses this file to You under
# * the OAI Public License, Version 1.1 (the "License"); you may not use this file
# * except in compliance with the License.
# * You may obtain a copy of the License at
# *
# * http://www.openairinterface.org/?page_id=698
# *
# * Unless required by applicable law or agreed to in writing, software
# * distributed under the License is distributed on an "AS IS" BASIS,
# * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# * See the License for the specific language governing permissions and
# * limitations under the License.
# *-------------------------------------------------------------------------------
# * For more information about the OpenAirInterface (OAI) Software Alliance:
# * contact@openairinterface.org
# */
/
inet
.
*
brd
/
{
print
"interfaceToUse="
$NF
"done"
}
ci-scripts/add_user_to_conf_file.awk
deleted
100644 → 0
View file @
e66588b5
BEGIN
{
lineIdx
=
0
;
captureUEDesc
=
0
}
{
if
(
$0
~
/UE0/
)
{
captureUEDesc
=
1
}
if
(
captureUEDesc
==
1
)
{
captureLine
[
lineIdx
]
=
$0
lineIdx
=
lineIdx
+
1
}
print
$0
}
END
{
for
(
ueIdx
=
1
;
ueIdx
<
num_ues
;
ueIdx
++
)
{
print
""
for
(
k
=
0
;
k
<
lineIdx
;
k
++
)
{
if
(
captureLine
[
k
]
~
/UE0/
)
{
mLine
=
captureLine
[
k
]
gsub
(
"UE0"
,
"UE"
ueIdx
,
mLine
)
print
mLine
}
else
{
if
(
captureLine
[
k
]
~
/MSIN=/
)
{
mLine
=
captureLine
[
k
]
MSIN
=
sprintf
(
"%08d"
,
1111
+
int
(
ueIdx
))
gsub
(
"00001111"
,
MSIN
,
mLine
)
print
mLine
}
else
{
print
captureLine
[
k
]
}
}
}
}
}
ci-scripts/add_user_to_subscriber_list.awk
deleted
100644 → 0
View file @
e66588b5
BEGIN
{
lineIdx
=
0
}
{
captureLine
[
lineIdx
]
=
$0
lineIdx
=
lineIdx
+
1
print
$0
}
END
{
for
(
ueIdx
=
1
;
ueIdx
<
num_ues
;
ueIdx
++
)
{
for
(
k
=
0
;
k
<
lineIdx
;
k
++
)
{
if
(
captureLine
[
k
]
~
/UserName=/
)
{
mLine
=
captureLine
[
k
]
MSIN
=
sprintf
(
"%08d"
,
1111
+
int
(
ueIdx
))
gsub
(
"00001111"
,
MSIN
,
mLine
)
print
mLine
}
else
{
if
(
captureLine
[
k
]
~
/SubscriptionIndex/
)
{
mLine
=
captureLine
[
k
]
MSIN
=
sprintf
(
"%d"
,
111
+
int
(
ueIdx
))
gsub
(
"111"
,
MSIN
,
mLine
)
print
mLine
}
else
{
print
captureLine
[
k
]
}
}
}
}
}
ci-scripts/cls_containerize.py
View file @
e290b2ab
...
...
@@ -169,6 +169,27 @@ def AnalyzeBuildLogs(buildRoot, images, globalStatus):
collectInfo
[
image
]
=
files
return
collectInfo
# pyshark livecapture launches 2 processes:
# * One using dumpcap -i lIfs -w - (ie redirecting the packets to STDOUT)
# * One using tshark -i - -w loFile (ie capturing from STDIN from previous process)
# but in fact the packets are read by the following loop before being in fact
# really written to loFile.
# So it is mandatory to keep the loop
def
LaunchPySharkCapture
(
lIfs
,
lFilter
,
loFile
):
capture
=
pyshark
.
LiveCapture
(
interface
=
lIfs
,
bpf_filter
=
lFilter
,
output_file
=
loFile
,
debug
=
False
)
for
packet
in
capture
.
sniff_continuously
():
pass
def
StopPySharkCapture
(
testcase
):
with
cls_cmd
.
LocalCmd
()
as
myCmd
:
cmd
=
'killall tshark'
myCmd
.
run
(
cmd
,
reportNonZero
=
False
)
cmd
=
'killall dumpcap'
myCmd
.
run
(
cmd
,
reportNonZero
=
False
)
time
.
sleep
(
5
)
cmd
=
f'mv /tmp/capture_
{
testcase
}
.pcap ../cmake_targets/log/
{
testcase
}
/.'
myCmd
.
run
(
cmd
,
timeout
=
100
,
reportNonZero
=
False
)
return
False
#-----------------------------------------------------------
# Class Declaration
#-----------------------------------------------------------
...
...
@@ -1183,17 +1204,6 @@ class Containerize():
self
.
UndeployGenObject
(
HTML
,
RAN
,
UE
)
self
.
exitStatus
=
1
# pyshark livecapture launches 2 processes:
# * One using dumpcap -i lIfs -w - (ie redirecting the packets to STDOUT)
# * One using tshark -i - -w loFile (ie capturing from STDIN from previous process)
# but in fact the packets are read by the following loop before being in fact
# really written to loFile.
# So it is mandatory to keep the loop
def
LaunchPySharkCapture
(
self
,
lIfs
,
lFilter
,
loFile
):
capture
=
pyshark
.
LiveCapture
(
interface
=
lIfs
,
bpf_filter
=
lFilter
,
output_file
=
loFile
,
debug
=
False
)
for
packet
in
capture
.
sniff_continuously
():
pass
def
CaptureOnDockerNetworks
(
self
):
myCmd
=
cls_cmd
.
LocalCmd
(
d
=
self
.
yamlPath
[
0
])
cmd
=
'docker-compose -f docker-compose-ci.yml config | grep com.docker.network.bridge.name | sed -e "s@^.*name: @@"'
...
...
@@ -1218,7 +1228,7 @@ class Containerize():
myCmd
.
run
(
cmd
,
timeout
=
5
,
reportNonZero
=
False
)
myCmd
.
close
()
return
x
=
threading
.
Thread
(
target
=
self
.
LaunchPySharkCapture
,
args
=
(
interfaces
,
capture_filter
,
output_file
,))
x
=
threading
.
Thread
(
target
=
LaunchPySharkCapture
,
args
=
(
interfaces
,
capture_filter
,
output_file
,))
x
.
daemon
=
True
x
.
start
()
...
...
@@ -1307,21 +1317,9 @@ class Containerize():
HTML
.
CreateHtmlTestRow
(
'UE log Analysis'
,
'KO'
,
logStatus
)
else
:
HTML
.
CreateHtmlTestRow
(
'UE log Analysis'
,
'OK'
,
CONST
.
ALL_PROCESSES_OK
)
if
self
.
tsharkStarted
:
self
.
tsharkStarted
=
True
cmd
=
'killall tshark'
myCmd2
.
run
(
cmd
,
reportNonZero
=
False
)
cmd
=
'killall dumpcap'
myCmd2
.
run
(
cmd
,
reportNonZero
=
False
)
time
.
sleep
(
5
)
ymlPath
=
self
.
yamlPath
[
0
].
split
(
'/'
)
# The working dir is still logPath
cmd
=
f'mv /tmp/capture_
{
ymlPath
[
1
]
}
.pcap .'
myCmd2
.
run
(
cmd
,
timeout
=
100
,
reportNonZero
=
False
)
self
.
tsharkStarted
=
False
myCmd2
.
close
()
if
self
.
tsharkStarted
:
self
.
tsharkStarted
=
StopPySharkCapture
(
ymlPath
[
1
])
logging
.
debug
(
'
\u001B
[1m Undeploying
\u001B
[0m'
)
logging
.
debug
(
f'Working dir is back
{
self
.
yamlPath
[
0
]
}
'
)
cmd
=
'docker-compose -f docker-compose-ci.yml down -v'
...
...
ci-scripts/cls_oaicitest.py
View file @
e290b2ab
...
...
@@ -66,26 +66,28 @@ import numpy as np
def
Iperf_ComputeModifiedBW
(
idx
,
ue_num
,
profile
,
args
):
result
=
re
.
search
(
'-b\s*(?P<iperf_bandwidth>[0-9\.]+)(?P<unit>[KMG])'
,
str
(
args
))
if
result
is
None
:
raise
Exception
(
'Iperf bandwidth not found or in incorrect format!'
)
iperf_bandwidth
=
result
.
group
(
'iperf_bandwidth'
)
raise
ValueError
(
f'requested iperf bandwidth not found in iperf options "
{
args
}
"'
)
iperf_bandwidth
=
float
(
result
.
group
(
'iperf_bandwidth'
))
if
iperf_bandwidth
==
0
:
raise
ValueError
(
'iperf bandwidth set to 0 - invalid value'
)
if
profile
==
'balanced'
:
iperf_bandwidth_new
=
float
(
iperf_bandwidth
)
/
ue_num
if
profile
==
'single-ue'
:
iperf_bandwidth_new
=
float
(
iperf_bandwidth
)
iperf_bandwidth_new
=
iperf_bandwidth
/
ue_num
if
profile
==
'single-ue'
:
iperf_bandwidth_new
=
iperf_bandwidth
if
profile
==
'unbalanced'
:
# residual is 2% of max bw
residualBW
=
float
(
iperf_bandwidth
)
/
50
residualBW
=
iperf_bandwidth
/
50
if
idx
==
0
:
iperf_bandwidth_new
=
float
(
iperf_bandwidth
)
-
((
ue_num
-
1
)
*
residualBW
)
iperf_bandwidth_new
=
iperf_bandwidth
-
((
ue_num
-
1
)
*
residualBW
)
else
:
iperf_bandwidth_new
=
residualBW
iperf_bandwidth_str
=
result
.
group
(
0
)
iperf_bandwidth_unit
=
result
.
group
(
2
)
iperf_bandwidth_str_new
=
f"-b
{
'%.2f'
%
iperf_bandwidth_new
}{
iperf_bandwidth_unit
}
"
result
=
re
.
sub
(
iperf_bandwidth_str
,
iperf_bandwidth_str_new
,
str
(
args
))
if
result
is
None
:
raise
Exception
(
'Calculate Iperf bandwidth failed!'
)
return
result
args_new
=
re
.
sub
(
iperf_bandwidth_str
,
iperf_bandwidth_str_new
,
str
(
args
))
if
iperf_bandwidth_unit
==
'K'
:
iperf_bandwidth_new
=
iperf_bandwidth_new
/
1000
return
iperf_bandwidth_new
,
args_new
def
Iperf_ComputeTime
(
args
):
result
=
re
.
search
(
'-t\s*(?P<iperf_time>\d+)'
,
str
(
args
))
...
...
@@ -140,7 +142,7 @@ def Iperf_analyzeV3BIDIRJson(filename):
msg
+=
f'Receiver Bitrate UL :
{
receiver_bitrate_ul
}
Mbps
\n
'
return
(
True
,
msg
)
def
Iperf_analyzeV3UDP
(
filename
,
iperf_bitrate_threshold
,
iperf_packetloss_threshold
):
def
Iperf_analyzeV3UDP
(
filename
,
iperf_bitrate_threshold
,
iperf_packetloss_threshold
,
target_bitrate
):
if
(
not
os
.
path
.
isfile
(
filename
)):
return
(
False
,
'Iperf3 UDP: Log file not present'
)
if
(
os
.
path
.
getsize
(
filename
)
==
0
):
...
...
@@ -171,12 +173,12 @@ def Iperf_analyzeV3UDP(filename, iperf_bitrate_threshold, iperf_packetloss_thres
sender_bitrate
=
float
(
sender_bitrate
)
/
1000
if
receiver_unit
==
'Kbits/sec'
:
receiver_bitrate
=
float
(
receiver_bitrate
)
/
1000
br_perf
=
100
*
float
(
receiver_bitrate
)
/
float
(
sender
_bitrate
)
br_perf
=
100
*
float
(
receiver_bitrate
)
/
float
(
target
_bitrate
)
br_perf
=
'%.2f '
%
br_perf
sender_bitrate
=
'%.2f '
%
float
(
sender_bitrate
)
receiver_bitrate
=
'%.2f '
%
float
(
receiver_bitrate
)
req_msg
=
f'Sender Bitrate :
{
sender_bitrate
}
Mbps'
bir_msg
=
f'Receiver Bitrate
:
{
receiver_bitrate
}
Mbps'
bir_msg
=
f'Receiver Bitrate:
{
receiver_bitrate
}
Mbps'
brl_msg
=
f'
{
br_perf
}
%'
jit_msg
=
f'Jitter :
{
receiver_jitter
}
'
pal_msg
=
f'Packet Loss :
{
receiver_packetloss
}
%'
...
...
@@ -189,29 +191,21 @@ def Iperf_analyzeV3UDP(filename, iperf_bitrate_threshold, iperf_packetloss_thres
else
:
return
(
False
,
'Could not analyze iperf report'
)
def
Iperf_analyzeV2UDP
(
server_filename
,
iperf_bitrate_threshold
,
iperf_packetloss_threshold
,
iperf_opt
):
def
Iperf_analyzeV2UDP
(
server_filename
,
iperf_bitrate_threshold
,
iperf_packetloss_threshold
,
target_bitrate
):
result
=
None
if
(
not
os
.
path
.
isfile
(
server_filename
)):
return
(
False
,
'Could not analyze, server report not found!'
)
return
(
False
,
'Iperf UDP: Server report not found!'
)
if
(
os
.
path
.
getsize
(
server_filename
)
==
0
):
return
(
False
,
'Iperf UDP: Log file is empty'
)
# Computing the requested bandwidth in float
req_bw
=
1.0
# default iperf throughput, in Mbps
result
=
re
.
search
(
'-b *(?P<iperf_bandwidth>[0-9\.]+)(?P<magnitude>[kKMG])'
,
iperf_opt
)
if
result
is
not
None
:
req_bw
=
float
(
result
.
group
(
'iperf_bandwidth'
))
magn
=
result
.
group
(
'magnitude'
)
if
magn
==
"k"
or
magn
==
"K"
:
req_bw
/=
1000
elif
magn
==
"G"
:
req_bw
*=
1000
statusTemplate
=
'(?:|\[ *\d+\].*) +0\.0-\s*(?P<duration>[0-9\.]+) +sec +[0-9\.]+ [kKMG]Bytes +(?P<bitrate>[0-9\.]+) (?P<magnitude>[kKMG])bits\/sec +(?P<jitter>[0-9\.]+) ms +(\d+\/ *\d+) +(\((?P<packetloss>[0-9\.]+)%\))'
statusTemplate
=
r'(?:|\[ *\d+\].*) +0\.0-\s*(?P<duration>[0-9\.]+) +sec +[0-9\.]+ [kKMG]Bytes +(?P<bitrate>[0-9\.]+) (?P<magnitude>[kKMG])bits\/sec +(?P<jitter>[0-9\.]+) ms +(\d+\/ *\d+) +(\((?P<packetloss>[0-9\.]+)%\))'
with
open
(
server_filename
,
'r'
)
as
server_file
:
for
line
in
server_file
.
readlines
():
res
=
re
.
search
(
statusTemplate
,
str
(
line
))
if
res
is
not
None
:
result
=
res
res
ult
=
re
.
search
(
statusTemplate
,
str
(
line
))
if
res
ult
is
not
None
:
break
if
result
is
None
:
return
(
False
,
'Could not parse server report!'
)
bitrate
=
float
(
result
.
group
(
'bitrate'
))
magn
=
result
.
group
(
'magnitude'
)
if
magn
==
"k"
or
magn
==
"K"
:
...
...
@@ -220,11 +214,11 @@ def Iperf_analyzeV2UDP(server_filename, iperf_bitrate_threshold, iperf_packetlos
bitrate
*=
1000
jitter
=
float
(
result
.
group
(
'jitter'
))
packetloss
=
float
(
result
.
group
(
'packetloss'
))
br_perf
=
float
(
bitrate
)
/
float
(
req_bw
)
*
100
br_perf
=
float
(
bitrate
)
/
float
(
target_bitrate
)
*
100
br_perf
=
'%.2f '
%
br_perf
result
=
float
(
br_perf
)
>=
float
(
iperf_bitrate_threshold
)
and
float
(
packetloss
)
<=
float
(
iperf_packetloss_threshold
)
req_msg
=
f'Req Bitrate :
{
req_bw
}
'
req_msg
=
f'Req Bitrate :
{
target_bitrate
}
'
bir_msg
=
f'Bitrate :
{
bitrate
}
'
brl_msg
=
f'Bitrate Perf:
{
br_perf
}
%'
if
float
(
br_perf
)
<
float
(
iperf_bitrate_threshold
):
...
...
@@ -801,7 +795,7 @@ class OaiCiTest():
logPath
=
f'../cmake_targets/log/
{
ymlPath
[
1
]
}
'
if
udpIperf
:
iperf_opt
=
Iperf_ComputeModifiedBW
(
idx
,
ue_num
,
self
.
iperf_profile
,
self
.
iperf_args
)
target_bitrate
,
iperf_opt
=
Iperf_ComputeModifiedBW
(
idx
,
ue_num
,
self
.
iperf_profile
,
self
.
iperf_args
)
# note: for UDP testing we don't want to use json report - reports 0 Mbps received bitrate
jsonReport
=
""
# note: enable server report collection on the UE side, no need to store and collect server report separately on the server side
...
...
@@ -819,7 +813,7 @@ class OaiCiTest():
cmd_svr
.
run
(
f'
{
svr
.
getCmdPrefix
()
}
iperf -c
{
ueIP
}
-B
{
svrIP
}
{
iperf_opt
}
-i1 2>&1 | tee
{
client_filename
}
'
,
timeout
=
iperf_time
*
1.5
)
cmd_ue
.
run
(
f'cp
{
client_filename
}
{
logPath
}
/
{
client_filename
}
'
)
cmd_ue
.
run
(
f'cp
{
server_filename
}
{
logPath
}
/
{
server_filename
}
'
)
status
,
msg
=
Iperf_analyzeV2UDP
(
server_filename
,
self
.
iperf_bitrate_threshold
,
self
.
iperf_packetloss_threshold
,
iperf_opt
)
status
,
msg
=
Iperf_analyzeV2UDP
(
server_filename
,
self
.
iperf_bitrate_threshold
,
self
.
iperf_packetloss_threshold
,
target_bitrate
)
else
:
with
cls_cmd
.
getConnection
(
ue
.
getHost
())
as
cmd_ue
,
cls_cmd
.
getConnection
(
EPC
.
IPAddress
)
as
cmd_svr
:
port
=
5002
+
idx
...
...
@@ -835,7 +829,7 @@ class OaiCiTest():
else
:
cmd_ue
.
copyin
(
f'/tmp/
{
client_filename
}
'
,
client_filename
)
if
udpIperf
:
status
,
msg
=
Iperf_analyzeV3UDP
(
client_filename
,
self
.
iperf_bitrate_threshold
,
self
.
iperf_packetloss_threshold
)
status
,
msg
=
Iperf_analyzeV3UDP
(
client_filename
,
self
.
iperf_bitrate_threshold
,
self
.
iperf_packetloss_threshold
,
target_bitrate
)
elif
bidirIperf
:
status
,
msg
=
Iperf_analyzeV3BIDIRJson
(
client_filename
)
else
:
...
...
ci-scripts/main.py
View file @
e290b2ab
...
...
@@ -611,10 +611,6 @@ elif re.match('^TesteNB$', mode, re.IGNORECASE) or re.match('^TestUE$', mode, re
if
RAN
.
eNBIPAddress
==
''
or
RAN
.
eNBUserName
==
''
or
RAN
.
eNBPassword
==
''
or
RAN
.
eNBSourceCodePath
==
''
:
HELP
.
eNBSrvHelp
(
RAN
.
eNBIPAddress
,
RAN
.
eNBUserName
,
RAN
.
eNBPassword
,
RAN
.
eNBSourceCodePath
)
sys
.
exit
(
'Insufficient Parameter'
)
if
(
EPC
.
IPAddress
!=
''
)
and
(
EPC
.
IPAddress
!=
'none'
):
SSH
.
copyout
(
EPC
.
IPAddress
,
EPC
.
UserName
,
EPC
.
Password
,
cwd
+
"/tcp_iperf_stats.awk"
,
"/tmp"
)
SSH
.
copyout
(
EPC
.
IPAddress
,
EPC
.
UserName
,
EPC
.
Password
,
cwd
+
"/active_net_interfaces.awk"
,
"/tmp"
)
else
:
if
CiTestObj
.
UEIPAddress
==
''
or
CiTestObj
.
ranRepository
==
''
or
CiTestObj
.
ranBranch
==
''
or
CiTestObj
.
UEUserName
==
''
or
CiTestObj
.
UEPassword
==
''
or
CiTestObj
.
UESourceCodePath
==
''
:
HELP
.
GenericHelp
(
CONST
.
Version
)
...
...
ci-scripts/ran.py
View file @
e290b2ab
...
...
@@ -366,7 +366,6 @@ class RANManagement():
self
.
testCase_id
=
HTML
.
testCase_id
mySSH
=
SSH
.
SSHConnection
()
cwd
=
os
.
getcwd
()
mySSH
.
copyout
(
lIpAddr
,
lUserName
,
lPassWord
,
cwd
+
"/active_net_interfaces.awk"
,
"/tmp"
)
#Get pcap on enb and/or gnb if enabled in the xml
if
self
.
eNB_Trace
==
'yes'
:
...
...
ci-scripts/tcp_iperf_stats.awk
deleted
100644 → 0
View file @
e66588b5
#/*
# * Licensed to the OpenAirInterface (OAI) Software Alliance under one or more
# * contributor license agreements. See the NOTICE file distributed with
# * this work for additional information regarding copyright ownership.
# * The OpenAirInterface Software Alliance licenses this file to You under
# * the OAI Public License, Version 1.1 (the "License"); you may not use this file
# * except in compliance with the License.
# * You may obtain a copy of the License at
# *
# * http://www.openairinterface.org/?page_id=698
# *
# * Unless required by applicable law or agreed to in writing, software
# * distributed under the License is distributed on an "AS IS" BASIS,
# * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# * See the License for the specific language governing permissions and
# * limitations under the License.
# *-------------------------------------------------------------------------------
# * For more information about the OpenAirInterface (OAI) Software Alliance:
# * contact@openairinterface.org
# */
BEGIN
{
max
=
0
;
min
=
10000
}
{
if
(
$0
~
/Mbits/
)
{
if
(
$0
~
/KBytes/
)
{
split
(
$0
,
a
,
"KBytes"
)
}
else
{
split
(
$0
,
a
,
"MBytes"
)
}
split
(
a
[
2
],
b
)
if
(
b
[
1
]
>
max
)
{
max
=
b
[
1
]
}
if
(
b
[
1
]
<
min
)
{
min
=
b
[
1
]
}
}
}
END
{
print
"Avg Bitrate : "
b
[
1
]
" Mbits/sec Max Bitrate : "
max
" Mbits/sec Min Bitrate : "
min
" Mbits/sec"
}
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment