blob: f718b9f125cb411914ed6e6d5394b5712973755d (
plain)
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
|
#!/bin/bash
# Copyright 2023-2024 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
source tests-common.sh || exit
export LC_ALL=C
ITERATIONS=10000
RUNS=3
doit() {
local i
for (( i = 0; i < ITERATIONS; i++ )); do
"${@}"
done
}
timeit() {
local real=()
local user=()
local x vr avg
einfo "Timing ${*}"
for (( x = 0; x < RUNS; x++ )); do
while read tt tv; do
case ${tt} in
real) real+=( ${tv} );;
user) user+=( ${tv} );;
esac
done < <( ( time -p doit "${@}" ) 2>&1 )
done
[[ ${#real[@]} == ${RUNS} ]] || die "Did not get ${RUNS} real times"
[[ ${#user[@]} == ${RUNS} ]] || die "Did not get ${RUNS} user times"
local xr avg
for x in real user; do
xr="${x}[*]"
avg=$(dc -e "3 k ${ITERATIONS} ${RUNS} * ${!xr} + + / p")
printf '%s %4.0f it/s\n' "${x}" "${avg}"
done
}
PYTHON_COMPAT=( python3_{10..12} pypy3 )
inherit python-utils-r1
timeit _python_set_impls
texit
|