Given a model and targeted hardware, Olive (abbreviation of Onnx LIVE) composes the best suitable optimization techniques to output the most efficient ONNX model(s) for inferencing on the cloud or edge, while taking a set of constraints such as accuracy and latency into consideration.
Here are some recent videos, blog articles and labs that highlight Olive:
- [ Sep 2025 ] [Olive examples are relocated to new Olive-recipes repository]((https://github.com/microsoft/olive-recipes)
- [ Aug 2025 ] Olive 0.9.2 is released with new quantization algorithms
- [ May 2025 ] Olive 0.9.0 is released with support for NPUs
- [ Mar 2025 ] Olive 0.8.0 is released with new quantization techniques
- [ Feb 2025 ] New Notebook available - Finetune and Optimize DeepSeek R1 with Olive π
- [ Nov 2024 ] Democratizing AI Model optimization with the new Olive CLI
- [ Nov 2024 ] Unlocking NLP Potential: Fine-Tuning with Microsoft Olive (Ignite Pre-Day Lab PRE016)
- [ Nov 2024 ] Olive supports generating models for MultiLoRA serving on the ONNX Runtime
- [ Oct 2024 ] Windows Dev Chat: Optimizing models from Hugging Face for the ONNX Runtime (video)
- [ May 2024 ] AI Toolkit - VS Code Extension that uses Olive to fine tune models
For a full list of news and blogs, read the news archive.
If you prefer using the command line directly instead of Jupyter notebooks, we've outlined the quickstart commands here.
We recommend installing Olive in a virtual environment or a conda environment.
pip install olive-ai[auto-opt]
pip install transformers onnxruntime-genai
Note
Olive has optional dependencies that can be installed to enable additional features. Please refer to Olive package config for the list of extras and their dependencies.
In this quickstart you'll be optimizing Qwen/Qwen2.5-0.5B-Instruct, which has many model files in the Hugging Face repo for different precisions that are not required by Olive.
Run the automatic optimization:
olive optimize \
--model_name_or_path Qwen/Qwen2.5-0.5B-Instruct \
--precision int4 \
--output_path models/qwen
Tip
PowerShell Users
Line continuation between Bash and PowerShell are not interchangable. If you are using PowerShell, then you can copy-and-paste the following command that uses compatible line continuation.olive optimize `
--model_name_or_path Qwen/Qwen2.5-0.5B-Instruct `
--output_path models/qwen `
--precision int4
The automatic optimizer will:
- Acquire the model from the the Hugging Face model repo.
- Quantize the model to
int4
using GPTQ. - Capture the ONNX Graph and store the weights in an ONNX data file.
- Optimize the ONNX Graph.
Olive can automatically optimize popular model architectures like Llama, Phi, Qwen, Gemma, etc out-of-the-box - see detailed list here. Also, you can optimize other model architectures by providing details on the input/outputs of the model (io_config
).
The ONNX Runtime (ORT) is a fast and light-weight cross-platform inference engine with bindings for popular programming language such as Python, C/C++, C#, Java, JavaScript, etc. ORT enables you to infuse AI models into your applications so that inference is handled on-device.
The sample chat app to run is found as model-chat.py in the onnxruntime-genai Github repository.
- We welcome contributions! Please read the contribution guidelines for more details on how to contribute to the Olive project.
- For feature requests or bug reports, file a GitHub Issue.
- For general discussion or questions, use GitHub Discussions.
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the MIT License.