Add C++ example for streaming ASR with SenseVoice. (#2199)

This commit is contained in:
Fangjun Kuang
2025-05-11 00:23:32 +08:00
committed by GitHub
parent fc2121c307
commit 028b8f2718
16 changed files with 514 additions and 60 deletions

View File

@@ -678,4 +678,42 @@ void VoiceActivityDetector::Flush() const {
SherpaOnnxVoiceActivityDetectorFlush(p_);
}
LinearResampler LinearResampler::Create(int32_t samp_rate_in_hz,
int32_t samp_rate_out_hz,
float filter_cutoff_hz,
int32_t num_zeros) {
auto p = SherpaOnnxCreateLinearResampler(samp_rate_in_hz, samp_rate_out_hz,
filter_cutoff_hz, num_zeros);
return LinearResampler(p);
}
LinearResampler::LinearResampler(const SherpaOnnxLinearResampler *p)
: MoveOnly<LinearResampler, SherpaOnnxLinearResampler>(p) {}
void LinearResampler::Destroy(const SherpaOnnxLinearResampler *p) const {
SherpaOnnxDestroyLinearResampler(p);
}
void LinearResampler::Reset() const { SherpaOnnxLinearResamplerReset(p_); }
std::vector<float> LinearResampler::Resample(const float *input,
int32_t input_dim,
bool flush) const {
auto out = SherpaOnnxLinearResamplerResample(p_, input, input_dim, flush);
std::vector<float> ans{out->samples, out->samples + out->n};
SherpaOnnxLinearResamplerResampleFree(out);
return ans;
}
int32_t LinearResampler::GetInputSamplingRate() const {
return SherpaOnnxLinearResamplerResampleGetInputSampleRate(p_);
}
int32_t LinearResampler::GetOutputSamplingRate() const {
return SherpaOnnxLinearResamplerResampleGetOutputSampleRate(p_);
}
} // namespace sherpa_onnx::cxx

View File

@@ -111,6 +111,7 @@ SHERPA_ONNX_API bool WriteWave(const std::string &filename, const Wave &wave);
template <typename Derived, typename T>
class SHERPA_ONNX_API MoveOnly {
public:
MoveOnly() = default;
explicit MoveOnly(const T *p) : p_(p) {}
~MoveOnly() { Destroy(); }
@@ -591,6 +592,28 @@ class SHERPA_ONNX_API VoiceActivityDetector
explicit VoiceActivityDetector(const SherpaOnnxVoiceActivityDetector *p);
};
class SHERPA_ONNX_API LinearResampler
: public MoveOnly<LinearResampler, SherpaOnnxLinearResampler> {
public:
LinearResampler() = default;
static LinearResampler Create(int32_t samp_rate_in_hz,
int32_t samp_rate_out_hz,
float filter_cutoff_hz, int32_t num_zeros);
void Destroy(const SherpaOnnxLinearResampler *p) const;
void Reset() const;
std::vector<float> Resample(const float *input, int32_t input_dim,
bool flush) const;
int32_t GetInputSamplingRate() const;
int32_t GetOutputSamplingRate() const;
private:
explicit LinearResampler(const SherpaOnnxLinearResampler *p);
};
} // namespace sherpa_onnx::cxx
#endif // SHERPA_ONNX_C_API_CXX_API_H_