Build ONNX Runtime for Web
There are 2 steps to build ONNX Runtime Web:
- build ONNX Runtime for WebAssembly
- or skip and download a pre-built artifacts
- build onnxruntime-web (NPM package)
Contents
Build ONNX Runtime for WebAssembly
Prerequisites
- Checkout the source tree:
git clone --recursive https://github.com/Microsoft/onnxruntime cd onnxruntime
-
Install cmake-3.18 or higher.
-
Install Node.js (14.0+)
- Python (2.7 or 3.6+): https://www.python.org/downloads/
- python should be added to the PATH environment variable
Build Instructions
in <ORT_ROOT>/
, run one of the following commands to build WebAssembly:
# In windows, use 'build' to replace './build.sh'
# The following command build debug.
./build.sh --build_wasm
# The following command build debug with debug info.
./build.sh --build_wasm --skip_tests --enable_wasm_debug_info
# The following command build release.
./build.sh --config Release --build_wasm --skip_tests --disable_wasm_exception_catching --disable_rtti
ONNX Runtime WebAssembly can be built with or without multi-thread/SIMD support, specified by appending the following flags.
build flag | usage |
---|---|
--enable_wasm_threads | build with multi-thread support |
--enable_wasm_simd | build with SIMD support |
To get all build artifacts of ONNX Runtime WebAssembly, it needs 4 times of build with the combinations of ON/OFF of the 2 flags. A full list of build artifacts are as below:
file name | --enable_wasm_threads | --enable_wasm_simd |
---|---|---|
ort-wasm.js | X | X |
ort-wasm.wasm | X | X |
ort-wasm-threaded.js | O | X |
ort-wasm-threaded.wasm | O | X |
ort-wasm-threaded.worker.js | O | X |
ort-wasm-simd.wasm | X | O |
ort-wasm-simd-threaded.wasm | O | O |
Minimal Build Support
ONNX Runtime WebAssembly can be built with flag --minimal_build
. This will generate smaller artifacts and also have a less runtime memory usage. An ORT format model is required. A detailed instruction will come soon. See also ORT format Conversion.
FAQ
Q: unittest fails on Release build.
A: unittest requires C++ exceptions to work properly. However, for performance concern, we disabled exception catching in emscripten. So please specify
--skip_tests
in Release build.
Q: unittest fails on Debug build with debug info.
A: building with debug info will generate very huge artifacts (>1GB for unittest) and failed to load in Node.js. So please specify
--skip_tests
in build with debug info.
Q: I have a C++ project for web scenario, which runs a ML model using ONNX Runtime and generates WebAssembly as an output. Does ONNX Runtime Web support a static WebAssembly library, so that my application can link with it and make all pre/post processors to be compiled together into WebAssembly?
A: With
--build_wasm
, a build script generates.wasm
and.js
files for web scenarios and intermediate libraries are not linked properly with other C/C++ projects. When you build ONNX Runtime Web using--build_was_static_lib
instead of--build_wasm
, a build script generates a static library of ONNX Runtime Web namedlibonnxruntime_webassembly.a
in output directory. To run a simple inferencing like an unit test, what you need is three header files as follows andlibonnxruntime_webassembly.a
.
- include/onnxruntime/core/session/onnxruntime_c_api.h
- include/onnxruntime/core/session/onnxruntime_cxx_api.h
- include/onnxruntime/core/session/onnxruntime_cxx_inline.h
One important note is that ONNX Runtime has dependencies on lots of 3rd party libraries such as protobuf, onnx, and others. You may need copy necessary header files to your project. You also take care of cases of library version conflicts or emsdk version conflicts between ONNX Runtime and your project.
Build onnxruntime-web (NPM package)
Prerequisites
-
Install Node.js (14.0+)
-
Chrome or Edge browser for running tests.
Build Instructions
-
Install NPM packages
- in
<ORT_ROOT>/js/
, runnpm ci
. - in
<ORT_ROOT>/js/common/
, runnpm ci
. - in
<ORT_ROOT>/js/web/
, runnpm ci
.
- in
-
Prepare ONNX Runtime WebAssembly artifacts.
You can either use the prebuilt artifacts or build it by yourself.
-
Setup by script.
In
<ORT_ROOT>/js/web/
, runnpm run pull:wasm
to pull WebAssembly artifacts for latest master branch from CI pipeline. -
Download artifacts from pipeline manually.
you can download prebuilt WebAssembly artifacts from Windows WebAssembly CI Pipeline. Select a build, download artifact “Release_wasm” and unzip. See instructions below to put files into destination folders.
-
Build WebAssembly artifacts.
-
Build ONNX Runtime WebAssembly
Follow instructions above for building ONNX Runtime WebAssembly.
-
Copy following files from build output folder to
<ORT_ROOT>/js/web/dist/
(create the folder if it does not exist):- ort-wasm.wasm
- ort-wasm-threaded.wasm (build with flag ‘–enable_wasm_threads’)
- ort-wasm-simd.wasm (build with flag ‘–enable_wasm_simd’)
- ort-wasm-simd-threaded.wasm (build with flags ‘–enable_wasm_threads –enable_wasm_simd’)
-
Copy following files from build output folder to
<ORT_ROOT>/js/web/lib/wasm/binding/
:- ort-wasm.js
- ort-wasm-threaded.js (build with flag ‘–enable_wasm_threads’)
- ort-wasm-threaded.worker.js (build with flag ‘–enable_wasm_threads’)
-
-
-
Use following command in folder
<ORT_ROOT>/js/web
to build:npm run build