Skip to content

Latest commit

 

History

History
54 lines (39 loc) · 1.94 KB

README.md

File metadata and controls

54 lines (39 loc) · 1.94 KB

WASM + YOLO Real-time Object Detection

This project demonstrates real-time object detection entirely in the browser using YOLOv8 and WebAssembly (WASM). The front-end is built with React.js and integrates with the webcam to capture and process video frames, while the object detection is handled by a Rust module compiled into WebAssembly.

The advantage of this setup is that all object detection happens locally in the browser, without the need for a server backend, resulting in better performance and user privacy.

Check out the live version here!

Demo

Running Locally

Prerequisites

Steps

  1. Clone the repository

    git clone https://github.com/martishin/react-rust-wasm-yolo-object-detection
    cd react-rust-wasm-yolo-object-detection
  2. Install client dependencies

    cd client
    npm install
  3. Running the React client

    npm run dev

    The client will be running at http://localhost:5173/

  4. If you want to rebuild WASM module

    cd yolo_wasm
    make build

    Compiled module will be placed into client/src/model

Technologies Used

  • React (Client) - for capturing video frames and displaying object detection results
  • Rust (WASM) - for real-time object detection using WASM and YOLOv8 model
  • Candle ML - minimalist Rust machine learning framework, used for reimplementing the YOLOv8 model
  • YOLOv8 - state-of-the-art object detection model. Only the pre-trained weights (in safetensors format) are used