This is a benchmark project of NEON
vs. node-ffi-napi
vs. pure-Node.js
. It's focused to a marshalling cost.
- The "pure" is:
Node.js
↺Node.js
- The "NEON" is:
Node.js
⇄NEON
⇄native code
- The "node-ffi-napi" is:
Node.js
⇄node-ffi-napi
⇄native code
git clone [email protected]:usagi/neon-vs-node-ffi-napi.git
cd neon-vs-node-ffi-napi
yarn start
pure | NEON | node-ffi-napi | |
---|---|---|---|
empty | 47.92550206 | 128.3124983 | 5800.287876 |
rng | 35.47475487 | 175.1873791 | 5176.462751 |
buffer | 175394.375 | 534.950003 | 59332.4 |
Unit: [ns/function-call]
; See also "Main codes" section.
There are two important points these are the marshalling cost comparison and the useful usage. These individual values are not important.
- You may not need a native codes and a marshallings if you want to use only lightweight implements. Maybe, a marshalling cost be over than native code advantage.
- You should use
NEON
if you want speedup mainly with a native code. Unfortunately,node-ffi-napi
is so slow. - You may need a native code and a marshallings if you need to operate buffers such as
ArrayBuffer
.
Note: This result scored in 2020-03-31. Using Threadripper 2990WX machine.
- index.js ... Benchmarking code, pure
Node.js
implements,node-ffi-napi
marshalling part. - native/src/lib.rs ...
NEON
marshalling part. - workspace.rs/backend/src/lib.rs ... backend pure
Rust
implements.
MIT
USAGI.NETWORK / Usagi Ito https://usagi.network/