#machine-learning #neural-network #wasm-bindings #llm #wasi-nn

wasmedge-wasi-nn

High-level Rust bindings for wasi-nn, with LLM extensions

3 unstable releases

0.8.0 Jul 1, 2024
0.7.1 Apr 23, 2024
0.7.0 Mar 4, 2024

#87 in WebAssembly

Download history 631/week @ 2024-07-30 666/week @ 2024-08-06 680/week @ 2024-08-13 759/week @ 2024-08-20 711/week @ 2024-08-27 713/week @ 2024-09-03 629/week @ 2024-09-10 588/week @ 2024-09-17 1040/week @ 2024-09-24 829/week @ 2024-10-01 911/week @ 2024-10-08 767/week @ 2024-10-15 886/week @ 2024-10-22 830/week @ 2024-10-29 865/week @ 2024-11-05 706/week @ 2024-11-12

3,438 downloads per month
Used in llama-core

Apache-2.0

46KB
1K SLoC

wasi-nn bindings for Rust, with LLM extensions

This package is inspired by the wasi-nn package, but with additional support for the LLM.


This package contains high-level Rust bindings for wasi-nn system calls. It is similar in purpose to the WASI bindings but this package provides optional access to a system's machine learning functionality from WebAssembly.

NOTE: These bindings are experimental (use at your own risk) and subject to upstream changes in the wasi-nn specification.

Use

  1. Depend on this crate in your Cargo.toml:

    [dependencies]
    wasmedge-wasi-nn = "0.7.1"
    
  2. Use the wasi-nn APIs in your application, for example:

    use wasi_nn;
    let graph = GraphBuilder::new(GraphEncoding::TensorflowLite, ExecutionTarget::CPU)
        .build_from_files([model_path])?;
    let mut ctx = graph.init_execution_context()?;
    ctx.set_input(0, TensorType::F32, &input_dims, &input_buffer)?;
    ctx.compute()?;
    let output_num_bytes = ctx.get_output(0, &mut output_buffer)?;
    
  3. Compile the application to WebAssembly:

    cargo build --target=wasm32-wasi
    
  4. Run the generated WebAssembly in a runtime supporting wasi-nn, e.g., Wasmtime, WasmEdge.

Build

To build this crate from source, use: cargo build --target wasm32-wasi.

Generation

This crate contains code (src/generated.rs) generated by witx-bindgen. To regenerate this code, run the following script:

$ scripts/regenerate-bindings-from-witx.sh

Examples

The examples demonstrate how to use wasi-nn from a Rust program.

License

This project is licensed under the Apache 2.0 license. See LICENSE for more details.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this project by you, as defined in the Apache-2.0 license, shall be licensed as above, without any additional terms or conditions.

Dependencies

~230–680KB
~16K SLoC