2022-03-20 16:01:38 -04:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
|
|
Fixed a terrible bug where turns out I used the same name for a block and a parameter in the comparison meta-function -
they share the same namespace in the wasm DSL, so when I used it like a parameter in a loop it resolved to the number of scopes between the statement and the block'th parameter
which had the same type and the calculation worked fine, but it overwrote the parameter I thought wasn't being used and called a function later with.
Also, that seemed like that last of the really bad leaks & corruption, so re-enabling the freelist and am able to run some less-trivial benchmarks, namely (fib 30)!
The compiled version is between 4.7x and 65x slower than Python, depending on if you're using wasmer, wasmtime, wasm3. Would like to try WAVM as well.
A solid place to start, I think, and hopefully we'll be faster than Python once I implement a variety of dont-be-dumb optimizations (real-er malloc, static calls of statically known functions, etc)
2022-03-29 23:49:51 -04:00
|
|
|
NUMBER=30
|
2022-03-30 21:27:01 -04:00
|
|
|
#NUMBER=25
|
2022-03-20 16:01:38 -04:00
|
|
|
|
2022-04-09 00:45:58 -04:00
|
|
|
#touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib.kp && time perf record -k mono wasmtime --jitdump ./csc_out.wasm
|
|
|
|
|
#exit
|
|
|
|
|
|
2022-03-20 16:01:38 -04:00
|
|
|
echo "Compile Straight"
|
Fixed a terrible bug where turns out I used the same name for a block and a parameter in the comparison meta-function -
they share the same namespace in the wasm DSL, so when I used it like a parameter in a loop it resolved to the number of scopes between the statement and the block'th parameter
which had the same type and the calculation worked fine, but it overwrote the parameter I thought wasn't being used and called a function later with.
Also, that seemed like that last of the really bad leaks & corruption, so re-enabling the freelist and am able to run some less-trivial benchmarks, namely (fib 30)!
The compiled version is between 4.7x and 65x slower than Python, depending on if you're using wasmer, wasmtime, wasm3. Would like to try WAVM as well.
A solid place to start, I think, and hopefully we'll be faster than Python once I implement a variety of dont-be-dumb optimizations (real-er malloc, static calls of statically known functions, etc)
2022-03-29 23:49:51 -04:00
|
|
|
#touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib.kp && time echo $NUMBER | wasm3 ./csc_out.wasm
|
2022-03-30 21:27:01 -04:00
|
|
|
touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib.kp && time echo $NUMBER | wasmtime ./csc_out.wasm
|
2022-04-09 00:45:58 -04:00
|
|
|
#cp csc_out.wasm comp_fib_dyn.wasm
|
|
|
|
|
|
2022-04-11 16:07:11 -04:00
|
|
|
echo "Compile Straight 2"
|
|
|
|
|
#touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib.kp && time echo $NUMBER | wasm3 ./csc_out.wasm
|
|
|
|
|
touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib2.kp && time echo $NUMBER | wasmtime ./csc_out.wasm
|
|
|
|
|
|
|
|
|
|
echo "Python"
|
|
|
|
|
time python3 ./fib.py $NUMBER
|
|
|
|
|
|
|
|
|
|
echo "Rust Wasm Debug"
|
|
|
|
|
pushd rust_fib
|
|
|
|
|
cargo build --target=wasm32-wasi && time echo $NUMBER | wasmtime target/wasm32-wasi/debug/rust_let.wasm
|
|
|
|
|
popd
|
|
|
|
|
|
|
|
|
|
echo "Rust Wasm Release"
|
|
|
|
|
pushd rust_fib
|
|
|
|
|
cargo build --release --target=wasm32-wasi && time echo $NUMBER | wasmtime target/wasm32-wasi/release/rust_let.wasm
|
|
|
|
|
popd
|
|
|
|
|
|
|
|
|
|
exit
|
2022-03-20 16:01:38 -04:00
|
|
|
|
2022-03-30 21:27:01 -04:00
|
|
|
echo "Interpret Straight"
|
Fixed a terrible bug where turns out I used the same name for a block and a parameter in the comparison meta-function -
they share the same namespace in the wasm DSL, so when I used it like a parameter in a loop it resolved to the number of scopes between the statement and the block'th parameter
which had the same type and the calculation worked fine, but it overwrote the parameter I thought wasn't being used and called a function later with.
Also, that seemed like that last of the really bad leaks & corruption, so re-enabling the freelist and am able to run some less-trivial benchmarks, namely (fib 30)!
The compiled version is between 4.7x and 65x slower than Python, depending on if you're using wasmer, wasmtime, wasm3. Would like to try WAVM as well.
A solid place to start, I think, and hopefully we'll be faster than Python once I implement a variety of dont-be-dumb optimizations (real-er malloc, static calls of statically known functions, etc)
2022-03-29 23:49:51 -04:00
|
|
|
#touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib.kp no_compile && time echo $NUMBER | wasm3 ./csc_out.wasm
|
2022-03-30 21:27:01 -04:00
|
|
|
touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib.kp no_compile && time echo $NUMBER | wasmtime ./csc_out.wasm
|
2022-03-20 16:01:38 -04:00
|
|
|
|
2022-04-09 00:45:58 -04:00
|
|
|
echo "Compile Let"
|
Fixed a terrible bug where turns out I used the same name for a block and a parameter in the comparison meta-function -
they share the same namespace in the wasm DSL, so when I used it like a parameter in a loop it resolved to the number of scopes between the statement and the block'th parameter
which had the same type and the calculation worked fine, but it overwrote the parameter I thought wasn't being used and called a function later with.
Also, that seemed like that last of the really bad leaks & corruption, so re-enabling the freelist and am able to run some less-trivial benchmarks, namely (fib 30)!
The compiled version is between 4.7x and 65x slower than Python, depending on if you're using wasmer, wasmtime, wasm3. Would like to try WAVM as well.
A solid place to start, I think, and hopefully we'll be faster than Python once I implement a variety of dont-be-dumb optimizations (real-er malloc, static calls of statically known functions, etc)
2022-03-29 23:49:51 -04:00
|
|
|
#touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib_let.kp && time echo $NUMBER | wasm3 ./csc_out.wasm
|
2022-04-09 00:45:58 -04:00
|
|
|
touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib_let.kp && time echo $NUMBER | wasmtime ./csc_out.wasm
|
2022-03-20 16:01:38 -04:00
|
|
|
|
2022-04-09 00:45:58 -04:00
|
|
|
echo "Interpret Let"
|
Fixed a terrible bug where turns out I used the same name for a block and a parameter in the comparison meta-function -
they share the same namespace in the wasm DSL, so when I used it like a parameter in a loop it resolved to the number of scopes between the statement and the block'th parameter
which had the same type and the calculation worked fine, but it overwrote the parameter I thought wasn't being used and called a function later with.
Also, that seemed like that last of the really bad leaks & corruption, so re-enabling the freelist and am able to run some less-trivial benchmarks, namely (fib 30)!
The compiled version is between 4.7x and 65x slower than Python, depending on if you're using wasmer, wasmtime, wasm3. Would like to try WAVM as well.
A solid place to start, I think, and hopefully we'll be faster than Python once I implement a variety of dont-be-dumb optimizations (real-er malloc, static calls of statically known functions, etc)
2022-03-29 23:49:51 -04:00
|
|
|
#touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib_let.kp no_compile && time echo $NUMBER | wasm3 ./csc_out.wasm
|
2022-04-09 00:45:58 -04:00
|
|
|
touch csc_out.wasm && rm csc_out.wasm && scheme --script ./partial_eval.scm fib_let.kp no_compile && time echo $NUMBER | wasmtime ./csc_out.wasm
|
2022-03-20 16:01:38 -04:00
|
|
|
|
2022-04-09 00:45:58 -04:00
|
|
|
echo "Chez Scheme"
|
|
|
|
|
time scheme --script ./fib.scm $NUMBER
|
2022-04-11 16:07:11 -04:00
|
|
|
|
|
|
|
|
echo "Chez Scheme Let"
|
|
|
|
|
time scheme --script ./fib_let.scm $NUMBER
|
|
|
|
|
|
|
|
|
|
echo "Python"
|
|
|
|
|
time python3 ./fib.py $NUMBER
|
|
|
|
|
|
|
|
|
|
echo "Python Let"
|
|
|
|
|
time python3 ./fib_let.py $NUMBER
|
|
|
|
|
|
|
|
|
|
echo "C"
|
|
|
|
|
clang-11 fib.c -o fib && time ./fib $NUMBER
|
|
|
|
|
|
|
|
|
|
echo "C let"
|
|
|
|
|
clang-11 fib_let.c -o fib_let && time ./fib_let $NUMBER
|
2022-03-20 16:01:38 -04:00
|
|
|
|