mycpp Code Generation

Measure the speedup from mycpp, and the resource usage.

Source code: oil/mycpp/examples

User Time (milliseconds)

Lower ratios are better.

example name gen C++ C++-Souffle Python C++ : Python
gc_stack_roots gen 0 1 13 0.000
modules gen 1 1 190 0.005
loops gen 2 3 302 0.006
fib_iter gen 7 8 898 0.008
fib_recursive gen 9 9 933 0.010
asdl_generated gen 8 9 397 0.019
parse gen 27 26 780 0.034
scoped_resource gen 45 45 1,040 0.043
files gen 5 8 79 0.061
containers gen 8 6 125 0.065
tuple_return_value gen 16 15 207 0.080
classes gen 3 1 31 0.103
length gen 42 40 212 0.196
cartesian gen 86 82 338 0.256
escape gen 103 92 358 0.287
cgi gen 258 267 533 0.484
varargs gen 23 18 22 1.036
control_flow gen 208 162 115 1.811
pea_hello gen NA NA 11 NA

Max Resident Set Size (MB)

Lower ratios are better. We use MB (powers of 10), not MiB (powers of 2).

example name gen C++ C++-Souffle Python C++ : Python
classes gen 4.5 4.3 12.5 0.36
cgi gen 3.5 3.7 8.5 0.42
gc_stack_roots gen 3.5 3.4 8.5 0.42
length gen 3.5 3.8 8.5 0.42
cartesian gen 3.7 3.7 8.5 0.43
parse gen 3.9 3.9 9.1 0.43
asdl_generated gen 3.7 3.7 8.4 0.44
escape gen 3.7 3.5 8.4 0.44
fib_iter gen 3.7 3.8 8.4 0.44
fib_recursive gen 3.7 3.5 8.4 0.44
tuple_return_value gen 3.7 3.8 8.4 0.44
control_flow gen 3.8 3.7 8.5 0.45
loops gen 3.8 3.8 8.5 0.45
modules gen 3.8 3.8 8.5 0.45
scoped_resource gen 3.8 3.7 8.4 0.45
files gen 3.9 3.8 8.4 0.47
containers gen 28.6 28.9 49.2 0.58
varargs gen 5.5 5.5 8.5 0.65
pea_hello gen NA NA 8.3 NA

System Time (milliseconds)

Lower ratios are better.

example name gen C++ C++-Souffle Python C++ : Python
classes gen 0 2 10 0.000
modules gen 1 1 9 0.101
control_flow gen 1 1 9 0.111
fib_iter gen 1 0 8 0.127
containers gen 4 5 24 0.169
escape gen 2 9 8 0.252
gc_stack_roots gen 2 1 7 0.263
scoped_resource gen 3 1 11 0.273
loops gen 2 0 6 0.323
length gen 4 6 10 0.405
fib_recursive gen 2 2 5 0.409
files gen 3 0 7 0.418
cgi gen 3 2 7 0.430
varargs gen 17 22 32 0.526
asdl_generated gen 3 2 6 0.536
parse gen 4 1 7 0.563
tuple_return_value gen 3 3 5 0.618
cartesian gen 5 5 7 0.716
pea_hello gen NA NA 8 NA

raw benchmark files