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
modules gen 0 2 186 0.000
fib_iter gen 9 8 898 0.010
fib_recursive gen 11 11 889 0.012
loops gen 4 3 298 0.012
asdl_generated gen 11 11 388 0.028
parse gen 30 23 773 0.039
files gen 4 7 86 0.043
scoped_resource gen 47 45 1,082 0.044
containers gen 8 0 112 0.069
tuple_return_value gen 14 18 186 0.076
classes gen 3 3 26 0.124
gc_stack_roots gen 2 0 12 0.143
length gen 41 42 205 0.199
escape gen 102 96 349 0.292
cartesian gen 99 82 333 0.299
cgi gen 265 266 525 0.505
varargs gen 21 16 24 0.852
control_flow gen 210 156 120 1.752
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.5 12.3 0.36
gc_stack_roots gen 3.5 3.4 8.5 0.42
parse gen 3.8 3.8 9.1 0.42
escape gen 3.5 3.7 8.4 0.42
cgi gen 3.7 3.5 8.5 0.43
asdl_generated gen 3.7 3.7 8.4 0.44
cartesian gen 3.7 3.5 8.4 0.44
fib_recursive gen 3.7 3.8 8.4 0.44
modules gen 3.8 3.7 8.7 0.44
files gen 3.8 3.7 8.5 0.45
length gen 3.8 3.8 8.5 0.45
loops gen 3.8 3.8 8.5 0.45
scoped_resource gen 3.8 3.8 8.5 0.45
tuple_return_value gen 3.8 3.8 8.5 0.45
fib_iter gen 3.8 3.7 8.4 0.45
control_flow gen 3.9 3.7 8.5 0.46
containers gen 28.4 28.5 49.2 0.58
varargs gen 5.5 5.5 8.5 0.65
pea_hello gen NA NA 8.1 NA

System Time (milliseconds)

Lower ratios are better.

example name gen C++ C++-Souffle Python C++ : Python
asdl_generated gen 0 0 4 0.000
cartesian gen 0 4 8 0.000
classes gen 0 0 13 0.000
control_flow gen 0 4 4 0.000
fib_iter gen 0 0 8 0.000
fib_recursive gen 0 0 8 0.000
gc_stack_roots gen 0 2 8 0.000
loops gen 0 0 12 0.000
parse gen 0 4 8 0.000
scoped_resource gen 0 0 8 0.000
modules gen 2 0 12 0.155
containers gen 8 14 32 0.243
escape gen 4 8 12 0.338
length gen 4 4 12 0.339
tuple_return_value gen 5 0 12 0.389
varargs gen 45 49 56 0.803
cgi gen 4 0 4 1.003
files gen 4 0 0 inf
pea_hello gen NA NA 7 NA

raw benchmark files