-
Notifications
You must be signed in to change notification settings - Fork 13
/
run_benchmarks.jl
80 lines (74 loc) · 2.89 KB
/
run_benchmarks.jl
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
using DeepDiffs
using TimerOutputs
const VERIFY = "verify" in ARGS
const NUM_THREADS = 4
const CPU_TARGET = "core2"
struct Benchmark
name::String
benchmark::Union{Number, String}
verify::Union{Number, String}
requires_fasta::Bool
end
Benchmark(name, benchmark, verify) = Benchmark(name, benchmark, verify, false)
const BENCHMARKS = [
Benchmark("binarytrees", 21, 10),
Benchmark("fannkuchredux", 12, 7),
Benchmark("fasta", 25000000, 1000),
Benchmark("knucleotide", "fasta.txt", "knucleotide/knucleotide-input.txt", true),
Benchmark("mandelbrot", 16000, 200),
Benchmark("nbody", 50000000, 1000),
Benchmark("pidigits", 10000, 27),
Benchmark("regexredux", "fasta.txt", "regexredux/regexredux-input.txt", true),
Benchmark("revcomp", "fasta.txt", "revcomp/revcomp-input.txt", true),
Benchmark("spectralnorm", 5500, 100),
]
function run_benchmarks()
VERIFY && println("VERIFYING!")
errored = false
result_file = "result.bin"
TimerOutputs.reset_timer!()
for benchmark in BENCHMARKS
if !VERIFY && benchmark.requires_fasta
if !isfile(joinpath(@__DIR__, "fasta.txt"))
fasta_gen = joinpath(@__DIR__, "fasta", "fasta.jl")
@info "Generating fasta file"
run(pipeline(`$(Base.julia_cmd()) $fasta_gen 25000000` ;stdout = "fasta.txt"))
end
end
dir = benchmark.name
_arg = VERIFY ? benchmark.verify : benchmark.benchmark
println("Running $dir")
bdir = joinpath(@__DIR__, dir)
arg, input = _arg isa String ? ("", "$(_arg)") : (string(_arg), "")
@timeit dir begin
for file in readdir(bdir)
endswith(file, ".jl") || continue
println(" $file:")
withenv("JULIA_NUM_THREADS" => NUM_THREADS) do
if !isempty(input)
cmd = pipeline(`$(Base.julia_cmd()) --cpu-target=$CPU_TARGET $(joinpath(bdir, file))`;
stdin=input, stdout = result_file)
else
cmd = pipeline(`$(Base.julia_cmd()) --cpu-target=$CPU_TARGET $(joinpath(bdir, file)) $(arg)`;
stdout = result_file)
end
@timeit file run(cmd)
end
if VERIFY
bench_output = read(result_file, String)
correct_output = read(joinpath(bdir, string(dir, "-output.txt")), String)
if bench_output != correct_output
println(deepdiff(correct_output, bench_output))
errored = true
end
end
end
end
end
TimerOutputs.print_timer(; compact=true, allocations=false)
if errored
println()
error("Some verification failed")
end
end
run_benchmarks()