1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- #!/usr/bin/env python3
- import wave
- import numpy as np
- import sherpa_ncnn
- def main():
- recognizer = sherpa_ncnn.Recognizer(
- tokens="./sherpa-ncnn-conv-emformer-transducer-2022-12-06/tokens.txt",
- encoder_param="./sherpa-ncnn-conv-emformer-transducer-2022-12-06/encoder_jit_trace-pnnx.ncnn.param",
- encoder_bin="./sherpa-ncnn-conv-emformer-transducer-2022-12-06/encoder_jit_trace-pnnx.ncnn.bin",
- decoder_param="./sherpa-ncnn-conv-emformer-transducer-2022-12-06/decoder_jit_trace-pnnx.ncnn.param",
- decoder_bin="./sherpa-ncnn-conv-emformer-transducer-2022-12-06/decoder_jit_trace-pnnx.ncnn.bin",
- joiner_param="./sherpa-ncnn-conv-emformer-transducer-2022-12-06/joiner_jit_trace-pnnx.ncnn.param",
- joiner_bin="./sherpa-ncnn-conv-emformer-transducer-2022-12-06/joiner_jit_trace-pnnx.ncnn.bin",
- num_threads=4,
- )
- filename = "./sherpa-ncnn-conv-emformer-transducer-2022-12-06/test_wavs/5.wav"
- with wave.open(filename) as f:
- assert f.getframerate() == recognizer.sample_rate, (
- f.getframerate(),
- recognizer.sample_rate,
- )
- assert f.getnchannels() == 1, f.getnchannels()
- assert f.getsampwidth() == 2, f.getsampwidth() # it is in bytes
- num_samples = f.getnframes()
- samples = f.readframes(num_samples)
- samples_int16 = np.frombuffer(samples, dtype=np.int16)
- samples_float32 = samples_int16.astype(np.float32)
- samples_float32 = samples_float32 / 32768
- recognizer.accept_waveform(recognizer.sample_rate, samples_float32)
- tail_paddings = np.zeros(int(recognizer.sample_rate * 0.5), dtype=np.float32)
- recognizer.accept_waveform(recognizer.sample_rate, tail_paddings)
- recognizer.input_finished()
- print(recognizer.text)
- if __name__ == "__main__":
- main()
|