HarmonyOS 原生智能之语音识别实战

打印 上一主题 下一主题

主题 1012|帖子 1012|积分 3036

HarmonyOS 原生智能之语音识别实战

背景

公司许多业务场景使用到了语音识别功能,其时我们的语音团队自研了语音识别模型,方案是云端模型加端侧SDK交互,端侧负责做语音收罗、VAD、opus编码,实时传输给云端,云端识别后返回识别结果。这些业务场景在适配鸿蒙的过程发现HarmonyOS 原生智能中提供了本地语音识别SDK,动手封装一波。
场景先容

原生语音识别能力支持两种模式:


  • 短语音模式(不高出60s)
  • 长语音模式(不高出8h)
API接口先容

1. 引擎初始化

speechRecognizer.createEngine
  1. let asrEngine: speechRecognizer.SpeechRecognitionEngine;
  2. // 创建引擎,通过callback形式返回
  3. // 设置创建引擎参数
  4. let extraParam: Record<string, Object> = {"locate": "CN", "recognizerMode": "short"};
  5. let initParamsInfo: speechRecognizer.CreateEngineParams = {
  6.   language: 'zh-CN',
  7.   online: 1,
  8.   extraParams: extraParam
  9. };
  10. // 调用createEngine方法
  11. speechRecognizer.createEngine(initParamsInfo, (err: BusinessError, speechRecognitionEngine: speechRecognizer.SpeechRecognitionEngine) => {
  12.   if (!err) {
  13.     console.info('Succeeded in creating engine.');
  14.     // 接收创建引擎的实例
  15.     asrEngine = speechRecognitionEngine;
  16.   } else {
  17.     // 无法创建引擎时返回错误码1002200008,原因:引擎正在销毁中
  18.     console.error(`Failed to create engine. Code: ${err.code}, message: ${err.message}.`);
  19.   }
  20. });
复制代码
主要是必要构建引擎参数speechRecognizer.CreateEngineParams:


  • language:语言
  • online:模式,1为离线,目前只支持离线引擎
  • extraParams:区域信息等

    • locate:区域信息,可选,不设置时默以为“CN”,当前仅支持“CN”
    • recognizerMode:识别模式,包含短语音short与场语音long
      回调中可以查看错误信息:


  • 无法创建引擎时返回错误码1002200001,缘故原由:语种不支持、模式不支持、初始化超时、资源不存在等导致创建引擎失败
  • 无法创建引擎时返回错误码1002200006,缘故原由:引擎正在繁忙中,一般多个应用同时调用语音识别引擎时触发
  • 无法创建引擎时返回错误码1002200008,缘故原由:引擎正在销毁中
2、设置RecognitionListener回调

回调主要处理识别过程中的事件,最主要的就是onResult处理识别内容,差别的对话对应差别的sessionId:
  1. // 创建回调对象
  2. let setListener: speechRecognizer.RecognitionListener = {
  3.   // 开始识别成功回调
  4.   onStart(sessionId: string, eventMessage: string) {
  5.    
  6.   },
  7.   // 事件回调
  8.   onEvent(sessionId: string, eventCode: number, eventMessage: string) {
  9.    
  10.   },
  11.   // 识别结果回调,包括中间结果和最终结果
  12.   onResult(sessionId: string, result: speechRecognizer.SpeechRecognitionResult) {
  13.    
  14.   },
  15.   // 识别完成回调
  16.   onComplete(sessionId: string, eventMessage: string) {
  17.    
  18.   },
  19.   // 错误回调,错误码通过本方法返回,如:返回错误码1002200006,识别引擎正忙,引擎正在识别中
  20.   onError(sessionId: string, errorCode: number, errorMessage: string) {
  21.    
  22.   }
  23. }
  24. // 设置回调
  25. asrEngine.setListener(setListener);
复制代码
3、开始识别

  1. let audioParam: speechRecognizer.AudioInfo = {audioType: 'pcm', sampleRate: 16000, soundChannel: 1, sampleBit: 16};
  2. let extraParam: Record<string, Object> = {"vadBegin": 2000, "vadEnd": 3000, "maxAudioDuration": 40000};
  3. let recognizerParams: speechRecognizer.StartParams = {
  4.   sessionId: sessionId,
  5.   audioInfo: audioParam,
  6.   extraParams: extraParam
  7. };
  8. // 调用开始识别方法
  9. asrEngine.startListening(recognizerParams);
复制代码
主要是设置开始识别的相关参数:


  • sessionId:会话id,与onResult回调中的sessionId要对应
  • audioInfo:音频配置信息,可选

    • audioType:目前只支持PCM,假如要识别MP3文件等必要解码后再传给引擎
    • sampleRate:音频的采样率,当前仅支持16000采样率
    • sampleBit:音频返回的采样位数,当前仅支持16位
    • soundChannel:音频返回的通道数信息,当前仅支持通道1
    • extraParams:音频的压缩率,pcm格式音频默以为0

  • extraParams:额外配置信息,主要包含:

    • recognitionMode:实时语音识别模式(不传时默以为1)

      • 0:实时灌音识别(需应用开启灌音权限:ohos.permission.MICROPHONE),若需竣事灌音,则调用finish方法
      • 1:实时音频转文字识别,开启此模式时必要额外调用writeAudio方法,传入待识别音频流;

    • vadBegin:Voice Activity Detection(VAD)前端点设置,参数范围是[500,10000],不传参时默以为10000ms
    • vadEnd:Voice Activity Detection(VAD)后端点设置。参数范围是[500,10000],不传参时默以为800ms。
    • maxAudioDuration:最大支持音频时长

      • 短语音模式支持范围[20000-60000]ms,不传参时默认20000ms。
      • 长语音模式支持范围[20000 - 8 * 60 * 60 * 1000]ms。
        VAD作用主要是语音活动检测,对静音数据不举行识别


4、传入音频流

  1. asrEngine.writeAudio(sessionId, uint8Array);
复制代码
向引擎写入音频数据,可以从麦克风大概音频文件中读取音频流。
留意:音频流长度仅支持640或1280。
5、其他接口


  • listLanguages:查询语音识别服务支持的语种信息
  • finish:竣事识别
  • 取消识别:cancel
  • shutdown:释放识别引起资源
最佳实践

实时识别的场景必要从麦克风实时读取音频,写入到asrEngine,在onResult回调中获取识别结果。
配置音频收罗参数并创建AudioCapturer实例:
  1. import { audio } from '@kit.AudioKit';
  2. let audioStreamInfo: audio.AudioStreamInfo = {
  3.    samplingRate: audio.AudioSamplingRate.SAMPLE_RATE_16000, // 采样率
  4.    channels: audio.AudioChannel.CHANNEL_1, // 通道
  5.    sampleFormat: audio.AudioSampleFormat.SAMPLE_FORMAT_S16LE, // 采样格式
  6.    encodingType: audio.AudioEncodingType.ENCODING_TYPE_RAW // 编码格式
  7. };
  8. let audioCapturerInfo: audio.AudioCapturerInfo = {
  9.    source: audio.SourceType.SOURCE_TYPE_MIC,
  10.    capturerFlags: 0
  11. };
  12. let audioCapturerOptions: audio.AudioCapturerOptions = {
  13.    streamInfo: audioStreamInfo,
  14.    capturerInfo: audioCapturerInfo
  15. };
  16. audio.createAudioCapturer(audioCapturerOptions, (err, data) => {
  17.    if (err) {
  18.      console.error(`Invoke createAudioCapturer failed, code is ${err.code}, message is ${err.message}`);
  19.    } else {
  20.      console.info('Invoke createAudioCapturer succeeded.');
  21.      let audioCapturer = data;
  22.    }
  23. });
复制代码
这里留意采样率和声道以及采样位数要符合ASR引擎要求:16k采样、单声道、16位采样位数。
接着调用on(‘readData’)方法,订阅监听音频数据读入回调:
  1. import { BusinessError } from '@kit.BasicServicesKit';
  2. import { fileIo } from '@kit.CoreFileKit';
  3. let bufferSize: number = 0;
  4. class Options {
  5.    offset?: number;
  6.    length?: number;
  7. }
  8. let readDataCallback = (buffer: ArrayBuffer) => {
  9.   //将buffer写入asr引擎
  10.   asrEngine.writeAudio(sessionId, new Uint8Array(buffer));
  11. }
  12. audioCapturer.on('readData', readDataCallback);
复制代码
这里留意写入buffer的大小表现,ASR只支持640或1280。
总结

本文先容了 HarmonyOS 官方提供的语音识别能力,详解先容了ASR引擎接口,末了基于麦克风收罗数据实现了实时麦克风语音识别功能。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

干翻全岛蛙蛙

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表