Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
This topic shows you how to install and use Windows ML to discover, download, and register execution providers (EPs) for use with the ONNX Runtime shipped with Windows ML. Windows ML handles the complexity of package management and hardware selection, automatically downloading the latest execution providers compatible with your device's hardware.
If you're not already familiar with the ONNX Runtime, we suggest reading the ONNX Runtime docs. In short, Windows ML provides a shared Windows-wide copy of the ONNX Runtime, plus the ability to dynamically download execution providers (EPs).
Prerequisites
- Windows 11 PC running version 24H2 (build 26100) or greater
- Language-specific prerequisites seen below
- .NET 6 or greater
- Targeting a Windows 10-specific TFM like
net6.0-windows10.0.19041.0
or greater
Step 1: Install or update the Windows App SDK
The Model Catalog APIs are included in the experimental version of Windows App SDK 2.0.0 or greater.
See use the Windows App SDK in an existing project for how to add the Windows App SDK to your project, or if you're already using Windows App SDK, update your packages.
Step 2: Download and register EPs
The simplest way to get started is to let Windows ML automatically discover, download, and register the latest version of all compatible execution providers. Execution providers need to be registered with the ONNX Runtime inside of Windows ML before you can use them. And if they haven't been downloaded yet, they need to be downloaded first. Calling EnsureAndRegisterCertifiedAsync()
will do both of these in one step.
using Microsoft.ML.OnnxRuntime;
using Microsoft.Windows.AI.MachineLearning;
// First we create a new instance of EnvironmentCreationOptions
EnvironmentCreationOptions envOptions = new()
{
logId = "WinMLDemo", // Use an ID of your own choice
logLevel = OrtLoggingLevel.ORT_LOGGING_LEVEL_ERROR
};
// And then use that to create the ORT environment
using var ortEnv = OrtEnv.CreateInstanceWithOptions(ref envOptions);
// Get the default ExecutionProviderCatalog
var catalog = ExecutionProviderCatalog.GetDefault();
// Ensure and register all compatible execution providers with ONNX Runtime
// This downloads any necessary components and registers them
await catalog.EnsureAndRegisterCertifiedAsync();
Tip
In production applications, wrap the EnsureAndRegisterCertifiedAsync()
call in a try-catch block to handle potential network or download failures gracefully.
Next steps
After registering execution providers, you're ready to use the ONNX Runtime APIs within Windows ML! You will want to...
- Select execution providers - Tell the runtime which execution providers you want to use
- Get your models - Use Model Catalog to dynamically download models, or include them locally
- Run model inference - Compile, load, and inference your model
Important
C# projects that use the Microsoft.ML.OnnxRuntime.Tensors
APIs must manually reference the System.Numerics.Tensors NuGet package, version 9.0.0 or greater. Without this NuGet package reference, your code will experience the following runtime error: Could not load file or assembly 'System.Numerics.Tensors, Version=9.0.0.0
.
See also
- Model Catalog - Dynamically download models from online catalogs
- Initialize execution providers - Additional ways you can handle download of EPs
- Distribute your app - Info about distributing an app using Windows ML
- ONNX versions in Windows ML - Info about which ONNX Runtime version ships with Windows ML
- Tutorial - Full end-to-end tutorial using Windows ML with the ResNet-50 model
- Code samples - Our code samples using Windows ML