Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/han-minhee/yolo-rust-ort
Rust implementation of YOLOv10 using ONNX (ort)
https://github.com/han-minhee/yolo-rust-ort
Last synced: 2 months ago
JSON representation
Rust implementation of YOLOv10 using ONNX (ort)
- Host: GitHub
- URL: https://github.com/han-minhee/yolo-rust-ort
- Owner: han-minhee
- License: gpl-3.0
- Created: 2024-08-15T11:49:28.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-09-11T04:37:04.000Z (5 months ago)
- Last Synced: 2024-09-11T15:25:32.324Z (5 months ago)
- Language: Rust
- Size: 23.7 MB
- Stars: 11
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# yolo-rust-ort
A Rust implementation of YOLO using ONNX Runtime (ort)![people sitting around a table](./output/people1.jpg)
## Overview
This small example demonstrates how to implement Ultralytics YOLOv8/YOLOv10 object detection in Rust using [ort](https://github.com/pykeio/ort) crate as a backend for running ONNX models. `ort` is a wrapper around [ONNX Runtime](https://onnxruntime.ai/).## Getting Started
### Prerequisites
Ensure you have a basic Rust development environment set up. If you want to download a specific YOLO model, you'll also need Python with the `ultralytics` package installed. Note that it only supports `yolov8` and `yolov10` models.### Running the demo
1. **(Optional) Download the YOLO Model**
To download a specific YOLOv10 model, use the following command:
```bash
python ./download_model.py --model yolov10n.pt
```
Alternatively, you can use the pre-included model at `./onnx/yolov10n.onnx` or `./onnx/yolov8n.onnx`.2. **Run the Rust Application**
```bash
cargo run -- path/to/your/image.jpg path/to/your/model.onnx model_name use_nms
```
For example, to run inference of a YOLOv8 model, run the command:```bash
cargo run -- ./sample/people0.jpg onnx/yolov8n.onnx yolov8 true
```
NMS is disabled by default. However, you can explicitly enable it by passing a boolean flag. YOLOv10 model doesn't need nms, so you can set it to `false` for YOLOv10 and `true` for YOLOv83. **Check the output**
The processed image and its corresponding detection results will be saved in the ./output directory. The output will include:
- A JPEG image with bounding boxes drawn with colors according to the class IDs.
- A text file containing the detection results in COCO format.### Requirements
`raqote` requires some packages installed in the system, and in case of a Linux system, you should have `fontconfig` (`libfontconfig1-dev` for Ubuntu, and `fontconfig-devel` for Fedora) and `pkg-config` packages installed.## Disclaimer
This project is my first attempt at Rust, so the code can be really messy.## References
[ort](https://github.com/pykeio/ort)[ultralytics](https://github.com/ultralytics/ultralytics)
[THU-MIG](https://github.com/THU-MIG/yolov10)