// sherpa-onnx/csrc/vocoder.h // // Copyright (c) 2025 Xiaomi Corporation #ifndef SHERPA_ONNX_CSRC_VOCODER_H_ #define SHERPA_ONNX_CSRC_VOCODER_H_ #include #include #include #include "onnxruntime_cxx_api.h" // NOLINT #include "sherpa-onnx/csrc/offline-tts-model-config.h" namespace sherpa_onnx { class Vocoder { public: virtual ~Vocoder() = default; static std::unique_ptr Create(const OfflineTtsModelConfig &config); template static std::unique_ptr Create(Manager *mgr, const OfflineTtsModelConfig &config); /** @param mel A float32 tensor of shape (batch_size, feat_dim, num_frames). * @return Return a float32 vector containing audio samples.. */ virtual std::vector Run(Ort::Value mel) const = 0; }; } // namespace sherpa_onnx #endif // SHERPA_ONNX_CSRC_VOCODER_H_