This repository has been archived on 2025-08-26. You can view files and clone it, but cannot push or open issues or pull requests.
Files
enginex-mr_series-sherpa-onnx/sherpa-onnx/csrc/provider.h
2024-07-22 23:50:48 +08:00

37 lines
999 B
C++

// sherpa-onnx/csrc/provider.h
//
// Copyright (c) 2023 Xiaomi Corporation
#ifndef SHERPA_ONNX_CSRC_PROVIDER_H_
#define SHERPA_ONNX_CSRC_PROVIDER_H_
#include <string>
#include "sherpa-onnx/csrc/provider-config.h"
namespace sherpa_onnx {
// Please refer to
// https://github.com/microsoft/onnxruntime/blob/main/java/src/main/java/ai/onnxruntime/OrtProvider.java
// for a list of available providers
enum class Provider {
kCPU = 0, // CPUExecutionProvider
kCUDA = 1, // CUDAExecutionProvider
kCoreML = 2, // CoreMLExecutionProvider
kXnnpack = 3, // XnnpackExecutionProvider
kNNAPI = 4, // NnapiExecutionProvider
kTRT = 5, // TensorRTExecutionProvider
kDirectML = 6, // DmlExecutionProvider
};
/**
* Convert a string to an enum.
*
* @param s We will convert it to lowercase before comparing.
* @return Return an instance of Provider.
*/
Provider StringToProvider(std::string s);
} // namespace sherpa_onnx
#endif // SHERPA_ONNX_CSRC_PROVIDER_H_