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 10 0.000
modules gen 1 0 196 0.004
fib_iter gen 8 7 892 0.008
loops gen 4 2 299 0.012
fib_recursive gen 11 10 901 0.012
asdl_generated gen 10 9 401 0.024
parse gen 27 24 781 0.034
classes gen 1 2 30 0.035
scoped_resource gen 46 40 1,036 0.045
containers gen 8 5 114 0.069
tuple_return_value gen 19 17 203 0.095
files gen 7 6 75 0.096
length gen 38 42 218 0.175
cartesian gen 90 79 341 0.265
escape gen 100 99 362 0.277
cgi gen 267 265 532 0.502
varargs gen 17 14 27 0.630
control_flow gen 210 160 113 1.851
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.3 4.3 12.3 0.35
gc_stack_roots gen 3.5 3.5 8.5 0.42
escape gen 3.5 3.7 8.4 0.42
modules gen 3.7 3.7 8.7 0.42
asdl_generated gen 3.7 3.5 8.5 0.43
cartesian gen 3.7 3.7 8.5 0.43
cgi gen 3.7 3.5 8.5 0.43
fib_iter gen 3.7 3.7 8.5 0.43
loops gen 3.7 3.8 8.5 0.43
tuple_return_value gen 3.7 3.8 8.5 0.43
parse gen 3.9 3.8 9.1 0.43
fib_recursive gen 3.7 3.5 8.4 0.44
files gen 3.7 3.7 8.4 0.44
length gen 3.7 3.8 8.4 0.44
scoped_resource gen 3.8 3.5 8.5 0.45
control_flow gen 3.9 3.9 8.5 0.46
containers gen 28.9 28.8 49.2 0.59
varargs gen 5.5 5.5 8.4 0.66
pea_hello gen NA NA 8.1 NA

System Time (milliseconds)

Lower ratios are better.

example name gen C++ C++-Souffle Python C++ : Python
fib_iter gen 0 1 7 0.000
fib_recursive gen 0 1 8 0.000
files gen 0 1 9 0.000
loops gen 0 1 10 0.000
tuple_return_value gen 0 1 6 0.000
scoped_resource gen 1 6 10 0.100
asdl_generated gen 1 2 9 0.109
containers gen 4 5 30 0.131
cartesian gen 1 8 6 0.167
modules gen 1 2 5 0.175
gc_stack_roots gen 2 1 10 0.176
control_flow gen 2 2 10 0.199
classes gen 2 1 9 0.234
cgi gen 3 7 11 0.273
parse gen 4 4 7 0.568
length gen 6 4 8 0.756
varargs gen 22 25 26 0.847
escape gen 5 6 5 1.002
pea_hello gen NA NA 7 NA

raw benchmark files